body {
   font-family: "Helvetica Neue",Helvetica,Arial,sans-serif;
   background-color: #fbfaf8;
}
body a {
   color: #202020;
}
body a:hover {
   color: gray;
   text-decoration: none;
}
/* TOP BAR */
.top-bar {
   background-color: #00a63e;
   color: #FFF;
   font-size: 14px;
   padding: 5px 0 5px 0;
}
.top-bar .top-left {
   display: flex;
   gap: 10px;
   margin: 0;
   padding: 0;
   line-height: 1.6;
}
.top-bar .top-left li {
   vertical-align: middle;
}
.top-bar .top-right {
   margin: 0;
   padding: 0;
   line-height: 1.6;
   vertical-align: middle;
}
.top-bar a {
   color: #FFF;
}
.top-bar a:hover {
   color: #FFF;
}
.top-bar i {
   margin-right: 5px;
}

/* MENU BAR - background #FFF, text #000 */
.menu-bar {
   text-transform: uppercase;
   font-weight: bold;
   background-color: #FFF;
   color: #000;
   border-bottom: 1px solid #e0e0e0;
}
.menu-bar .sm-clean,
.menu-bar .sm-clean ul {
   background: #FFF !important;
}
.menu-bar .sm-clean a,
.menu-bar .sm-clean a:hover,
.menu-bar .sm-clean a:focus,
.menu-bar .sm-clean a:active,
.menu-bar .sm-clean a.highlighted {
   color: #000 !important;
}
.menu-bar .sm-clean ul a,
.menu-bar .sm-clean ul a:hover,
.menu-bar .sm-clean ul a:focus,
.menu-bar .sm-clean ul a:active,
.menu-bar .sm-clean ul a.highlighted {
   color: #000 !important;
}
.sticky.is-sticky {
    position: fixed;
    left: 0;
    right: 0;
    top: 0;
    z-index: 1000;
    width: 100%;
}
.sm-clean {
   background: #FFF;
}
.sm-clean ul {
   background: #FFF;
}
.sm-clean ul a {
   color: #000;
}
/* Dropdown hover background Menu */
.sm-clean ul a:hover, .sm-clean ul a:focus, .sm-clean ul a:active, .sm-clean ul a.highlighted {
   background: #f0f0f0;
   color: #000;
}

/* Submenu arrow: fa fa-angle-down / fa fa-angle-up */
.sm-clean a .sub-arrow::before {
   content: "\f107";
   font-family: FontAwesome;
   font-weight: normal;
}
.sm-clean a.highlighted .sub-arrow::before {
   content: "\f106";
   font-family: FontAwesome;
   font-weight: normal;
}

/* CAROUSEL */
.carousel-caption {
   border-top: 1px solid #fff;
   color: #00a63e;
   font-weight: bold;
   background: #f0fdf4;
   opacity: 0.8;
   right: 0;
   left: 0;
   bottom: 0;
   text-align: left;
   padding: 30px;
}
.carousel-caption h2 {
   color: #fff;
}
.carousel-indicators li {
   background-color: #fff;
}
.carousel-indicators .active {
   background-color: #fbbc05;
}

/*  LOGO */
.brand {
   font-family: Arial, sans-serif, "Helvetica Neue", Helvetica;
   font-weight: bold;
   text-transform: uppercase;
   color: #fbbc05;
}

/* PAGE TITLE */
.page-title {
   font-weight: bold;
   margin-bottom: 15px;
   padding-bottom: 10px;
   margin-top: 0px;
}
.page-title:after {
   width: 30%;
   display: block;
   position: absolute;
   content: '';
   padding-bottom: 10px;
}
/* TESTIMONI */
.quote {
   overflow: hidden;
   background-color: #32642d;
}
.quote-title {
   font-size: 14px;
   font-weight: bold;
   text-transform: uppercase;
   display: inline-block;
   padding: 15px 15px;
   color: #FFF;
   float: left;
   background-color: #fbbc05;
   left: 0px;
   top: 0px;
   height: 50px;
}
ul.quote {
   display: block;
   padding: 0;
   margin: 0;
   list-style: none;
   line-height: 1;
   position: relative;
   overflow: hidden;
   height: 50px;
   background-color: transparent;
}
ul.quote li {
   color: #fff;
   position: absolute;
   top: -950em;
   left: 0;
   display: block;
   white-space: nowrap;
   font: 14px Helvetica, Arial, sans-serif;
   padding: 17px 15px 15px 15px;
}
ul.quote li span {
   color: #fbbc05;
   font-weight: bold;
}

/*  Conten */
h5.card-title {
   font-size: 16px;
   font-weight: bold;
}

/* Sidebar */
.sidebar .list-group-item {
   border: 1px solid #6c757d;
}

/* Footer */
footer {
   color: #1a1a1a;
   font-size: 14px;
}
footer .primary-footer {
   border-top: 1px solid #d1d1d1;
   background-color: #f0fdf4;
   padding: 30px 0;
}
footer .secondary-footer {
   border-top: 1px solid rgba(0,0,0,.1);
   background-color: #f0fdf4;
   padding: 10px 0;
}
footer .copyright {
   color: #1a1a1a;
   /* border-top: 1px solid #fff; */
}
footer a {
   color: #1a1a1a;
}
footer a:hover {
   color: #32642d;
}
footer .page-title {
   color: #1a1a1a;
}
footer .primary-footer .text-white,
footer .secondary-footer .text-white {
   color: #1a1a1a !important;
}
footer .primary-footer .text-white-50,
footer .secondary-footer .text-white-50 {
   color: rgba(0, 0, 0, 0.6) !important;
}
.social-icon {
   width: 40px;
   height: 40px;
   font-size: 15px;
   background-color: blue;
   color: #fff;
   text-align: center;
   margin-right: 10px;
   padding-top: 12px;
   border-radius: 50%;
}
.linked-in{
   background-color:#007bb6;
}
.facebook{
   background-color:#3b5998;
}
.twitter{
   background-color:#1da1f2;
}
.instagram {
   background-color:#fbbc05;
}
.youtube {
   background-color:#ef4e17;
}
.primary-footer nav ol.breadcrumb {
   background-color: transparent;
}

/* Tags */
.tag-content-block {
   display:block;
}
.tag a {
   border: 1px solid #fff;
   padding:12px 10px 8px 10px;
   color:#fff;
   display:inline-block;
   font-size:12px;
   text-transform:uppercase;
   line-height:11px;
   margin-bottom:5px;
   margin-right:2px;
   text-decoration:none;
}
.tag a:hover {
   border: 1px solid #fbbc05;
   color: #fff;
}

/* Fullscreen Search */
#search_form {
   z-index: 999999;
   position: fixed;
   top: 45px;
   left: 0px;
   width: 100%;
   height: 50px;
   background-color: rgba(0, 0, 0, 0.9);
   -webkit-transition: all 0.5s ease-in-out;
   -moz-transition: all 0.5s ease-in-out;
   -o-transition: all 0.5s ease-in-out;
   -ms-transition: all 0.5s ease-in-out;
   transition: all 0.5s ease-in-out;
   -webkit-transform: translate(0px, -100%) scale(0, 0);
   -moz-transform: translate(0px, -100%) scale(0, 0);
   -o-transform: translate(0px, -100%) scale(0, 0);
   -ms-transform: translate(0px, -100%) scale(0, 0);
   transform: translate(0px, -100%) scale(0, 0);
   opacity: 0;
}

#search_form.open {
   -webkit-transform: translate(0px, 0px) scale(1, 1);
   -moz-transform: translate(0px, 0px) scale(1, 1);
   -o-transform: translate(0px, 0px) scale(1, 1);
   -ms-transform: translate(0px, 0px) scale(1, 1);
   transform: translate(0px, 0px) scale(1, 1);
   opacity: 1;
}

#search_form input[type="search_form"] {
   position: relative;
   width: 100%;
   color: rgb(255, 255, 255);
   background: rgba(0, 0, 0, 0);
   font-size: 20px;
   font-weight: 300;
   text-align: center;
   border: 0px;
   margin: 0px auto;
   padding-left: 30px;
   padding-right: 30px;
   outline: none;
}
#search_form .btn {
   position: relative;
}

.action-button {
   background-color: #00a63e;
   color: #fff;
}
.action-button:hover {
   background-color: #32642d;
   color: #fff;
}

/* Tautan Cepat: dropdown under 640px, normal list above */
.quick-links-dropdown {
   display: block;
}
.quick-links-dropdown-toggle {
   cursor: pointer;
   list-style: none;
   font-size: 1rem;
   font-weight: 600;
   margin-bottom: 0.75rem;
}
.quick-links-dropdown-toggle::-webkit-details-marker,
.quick-links-dropdown-toggle::marker {
   display: none;
}
@media (max-width: 991.98px) {
   .top-bar {
      display: block;
   }
   .top-bar .top-right {
      display: none;
   }
}
@media (max-width: 639px) {
   .sticky.is-sticky {
      padding: 0;
   }
   .quick-links-dropdown {
      border: 1px solid rgba(255,255,255,0.3);
      border-radius: 4px;
      padding: 0;
   }
   .quick-links-dropdown-toggle {
      padding: 10px 0;
      margin-bottom: 0;
      color: #fff;
      display: flex;
      align-items: center;
      justify-content: space-between;
   }
   .quick-links-dropdown-toggle::after {
      content: "\f107";
      font-family: FontAwesome;
      font-weight: normal;
      transition: transform 0.2s;
      position: relative;
      align-items: center;
      width: 10px;
      padding: 0;
   }
   .quick-links-dropdown[open] .quick-links-dropdown-toggle::after {
      transform: rotate(180deg);
   }
   .quick-links-dropdown-content {
      padding: 0 12px 12px;
      border-top: 1px solid rgba(255,255,255,0.2);
   }
}
@media (min-width: 640px) {
   .quick-links-dropdown {
      display: block;
   }
   .quick-links-dropdown .quick-links-dropdown-content {
      display: block !important;
   }
   .quick-links-dropdown-toggle {
      pointer-events: none;
      font-weight: 600;
      color: inherit;
   }
   .quick-links-dropdown-toggle::after {
      display: none;
   }
}

/* Responsive */
/*  Extra small devices (portrait phones, less than 576px) */
@media (max-width: 575.98px) {
   .top-left{
      text-align: center !important;
   }
   .top-right {
      display: none;
   }
   .hero-section h1 {
      font-size: 2rem !important;
   }
}

/* Small devices (landscape phones, 576px and up) */
@media (min-width: 576px) and (max-width: 767.98px) {
   .top-left{
      text-align: center !important;
   }
   .top-right {
      display: none;
   }
}

/* Medium devices (tablets, 768px and up) */
@media (min-width: 768px) and (max-width: 991.98px) {
   .top-left{
      text-align: center !important;
   }
   .top-right {
      display: none;
   }
}

/* Overide Toastr color */
.toast {
  background-color: #030303;
}
/* custom toastr success */
.toast-success {
  background-color: #00cb18;
}
/* custom toastr error */
.toast-error {
  background-color: #ef5137;
}
/* custom toastr info */
.toast-info {
  background-color: #4b8df8;
}
/* custom toastr warning */
.toast-warning {
  background-color: #ffb848;
}
.toast-title, .toast-message {
   text-align: left;
}
.top-header {
  display: flex;
  align-items: center/* vertical alignment */
}
/* return to top */
#return-to-top {
   opacity: 0.7;
   z-index: 10000;
   position: fixed;
   bottom: 15px;
   right: 15px;
   background: #fbbc05;
   width: 30px;
   height: 30px;
   display: block;
   text-decoration: none;
   display: none;
   -webkit-transition: all 0.3s linear;
   -moz-transition: all 0.3s ease;
   -ms-transition: all 0.3s ease;
   -o-transition: all 0.3s ease;
   transition: all 0.3s ease;
}
#return-to-top i {
   color: #fff;
   margin: 0;
   position: relative;
   left: 9px;
   top: 5px;
   font-size: 19px;
   -webkit-transition: all 0.3s ease;
   -moz-transition: all 0.3s ease;
   -ms-transition: all 0.3s ease;
   -o-transition: all 0.3s ease;
   transition: all 0.3s ease;
}
#return-to-top:hover {
   background: #000;
}
#return-to-top:hover i {
   color: #fff;
}

/* ========== HOME PAGE ========== */

/* Hero Section */
.hero-section {
   background: linear-gradient(135deg, #f0fdf4 0%, #FFF 100%);
   color: #000;
   border-radius: 10px;
}
.hero-section .text-white {
   color: #000 !important;
}
.hero-section h1 {
   font-size: 2.5rem;
   font-weight: 700;
   color: #000;
}
.hero-section .hero-tagline {
   font-size: 1.5rem;
   font-weight: 500;
   color: #000;
}
.hero-section .hero-intro {
   font-size: 1rem;
   line-height: 1.8;
   color: #000;
}
.btn-hero-primary {
   background-color: #00a63e;
   color: #fff;
   border: none;
   padding: 12px 30px;
   font-weight: 600;
}
.btn-hero-outline {
   background-color: transparent;
   color: #000;
   border: 2px solid #000;
   padding: 12px 30px;
   font-weight: 600;
}
#heroCarousel {
   max-width: 950px;
   width: 100%;
   border-radius: 10px;
   overflow: hidden;
}
#heroCarousel .hero-carousel-inner {
   width: 100%;
   height: 400px;
   overflow: hidden;
   border-radius: 10px;
}
#heroCarousel .carousel-item {
   width: 100%;
   height: 400px;
}
#heroCarousel .carousel-item img {
   width: 100%;
   height: 100%;
   border-radius: 10px;
}
#heroCarousel .carousel-caption {
   text-align: center;
   left: 0;
   right: 0;
}
#heroCarousel .carousel-caption p,
#heroCarousel .carousel-caption {
   text-align: center;
   margin: 0;
}
#heroCarousel .carousel-caption {
   left: 0;
   right: 0;
}

/* Why Choose & Statistics Section */
.section-gray {
   background-color: #f5f5f5;
}
.why-choose-title {
   color: #333;
}
.why-choose-icon-box {
   width: 60px;
   height: 60px;
   background-color: #fbbc05;
   display: flex;
   align-items: center;
   justify-content: center;
   border-radius: 12px;
}
.why-choose-icon-box i {
   color: #fff;
}
.why-choose-point-title {
   color: #333;
}
.why-choose-desc {
   line-height: 1.6;
}
.btn-profil {
   background-color: #00a63e;
   color: #fff;
   padding: 12px 30px;
   font-weight: 600;
   border-radius: 12px;
}
.stats-box {
   background-color: #00a63e;
   height: 100%;
   border-radius: 12px;
}
.stats-value {
   font-size: 2.5rem;
   color: #fbbc05;
}
.stats-label {
   font-size: 0.9rem;
}

/* News & Cards */
.card-img-cover {
   object-fit: cover;
}
.link-school-color {
   color: #00a63e;
}
.link-school-color:hover {
   color: #00a63e;
}
.card-text-small {
   font-size: 0.9rem;
}
.btn-baca {
   background-color: #00a63e;
   color: #fff;
}

/* Sidebar: Pengumuman, Prestasi, Agenda */
.sidebar-desc {
   font-size: 0.9rem;
}
.sidebar-hr {
   border-top: 1px solid #e0e0e0;
}
.list-group-item-sidebar {
   border-color: #e0e0e0;
}
.link-more {
   font-size: 0.85rem;
}
.badge-event {
   font-size: 10px;
   padding: 4px 8px;
}

/* Akses Cepat */
.quick-link-card {
   text-decoration: none;
   color: #00a63e;
   border-color: #32642d !important;
}
.quick-link-card:hover {
   color: #00a63e;
   text-decoration: none;
}

/* About Section */
.about-intro {
   line-height: 1.8;
   color: #555;
}

/* Vision & Mission */
.vision-icon {
   color: #fbbc05;
}
.vision-blockquote {
   border-left: 4px solid #32642d;
   padding-left: 20px;
   font-style: italic;
   color: #555;
   font-size: 1rem;
}
.mission-icon {
   color: #32642d;
}
.mission-list {
   word-wrap: break-word;
   overflow-wrap: break-word;
}
.mission-list li {
   word-wrap: break-word;
   overflow-wrap: break-word;
   line-height: 1.6;
   display: flex;
   align-items: baseline;
}
.mission-list li i {
   flex-shrink: 0;
   align-self: baseline;
}
.mission-list li span {
   flex: 1;
   word-wrap: break-word;
   overflow-wrap: break-word;
}

/* Advantages Section */
.section-white {
   background-color: #ffffff;
}
.advantages-card {
   background-color: #f5f5f5;
   border-radius: 12px;
   padding: 40px;
}
.advantages-title {
   color: #00a63e;
   font-size: 2rem;
}
.advantages-desc {
   font-size: 1.1rem;
   line-height: 1.6;
   color: #555;
}
.btn-ppdb {
   background-color: #fbbc05;
   color: #000;
   border: none;
   padding: 12px 30px;
   border-radius: 8px;
   font-size: 1rem;
}
.btn-hubungi {
   background-color: #ffffff;
   color: #00a63e;
   border: 1px solid #e0e0e0;
   padding: 12px 30px;
   border-radius: 8px;
   font-size: 1rem;
}

/* Facilities Section */
.facility-card-img {
   height: 200px;
   object-fit: cover;
}
.facility-card-text {
   font-size: 0.9rem;
}
.facility-icon {
   color: #32642d;
}

/* Home: list-group-item with sidebar border */
.list-group-item.border-left-0.border-right-0.border-top-0.list-group-item-sidebar {
   border-color: #e0e0e0;
}

/* ========== INDEX LAYOUT (from index.php) ========== */

/* Navbar brand title */
.menu-bar .navbar-brand .brand {
   font-size: 24px;
   color: #000;
}
.menu-bar .navbar-toggler .fa {
   color: #000;
}

/* PPDB button in nav */
#main-menu .nav-ppdb-btn {
   background-color: #fbbc05;
   color: #000;
   border: none;
   padding: 8px 20px;
   margin-top: 5px;
}

/* Footer: logo + text wrap */
.primary-footer .footer-logo-wrap {
   display: flex;
   align-items: center;
   gap: 10px;
}

.primary-footer .footer-school-name {
   font-size: 16px;
}

.primary-footer .footer-tagline-small {
   font-size: 0.9rem;
}

.primary-footer .about-footer p {
   color: rgba(0, 0, 0, 0.6) !important;
   text-align: justify;
}

.social-icons-footer .fa {
   color: #1a1a1a;
}

/* Footer quick links - no underline */
.primary-footer .list-unstyled a,
.primary-footer .footer-quick-link {
   text-decoration: none;
}

/* Newsletter form - border radius 10px */
.newsletter-form .input-group {
   overflow: hidden;
}
.newsletter-form .form-control {
   border-radius: 10px 0 0 10px;
}
.newsletter-form .input-group-append .btn,
.newsletter-form .newsletter-submit-btn {
   border-radius: 0 10px 10px 0;
}

/* Newsletter submit button */
.newsletter-form .btn[type="submit"],
.newsletter-submit-btn {
   background-color: #00a63e;
   color: #FFF;
   border: none;
}

/* Gallery videos - rounded corners */
.videos {
   border-radius: 10px;
   overflow: hidden;
}

/* Copyright / secondary footer links */
.secondary-footer .copyright a {
   text-decoration: none;
}

/* Single event schedule - countdown */
.countdown-box {
   background: linear-gradient(135deg, #00a63e 0%, #008030 100%);
   color: white;
   padding: 30px;
   border-radius: 10px;
   margin-bottom: 30px;
}
.countdown-box .countdown-item {
   text-align: center;
   padding: 15px;
   background: rgba(255, 255, 255, 0.2);
   border-radius: 8px;
   margin: 5px;
}
.countdown-box .countdown-number {
   font-size: 2.5em;
   font-weight: bold;
   display: block;
}
.countdown-box .countdown-label {
   font-size: 0.9em;
   opacity: 0.9;
   margin-top: 5px;
}

/* Loop quotes - quote cards */
.quote-card {
   transition: transform 0.3s ease, box-shadow 0.3s ease;
}
.quote-card:hover {
   transform: translateY(-5px);
   box-shadow: 0 4px 8px rgba(0, 0, 0, 0.2) !important;
}
.quote-text {
   font-style: italic;
   line-height: 1.8;
   color: #333;
   min-height: 100px;
}
.quote-icon {
   opacity: 0.3;
}

/* Loop event schedules - agenda cards */
.event-card {
   position: relative;
   transition: transform 0.3s ease, box-shadow 0.3s ease;
}
.event-card:hover {
   transform: translateY(-5px);
   box-shadow: 0 4px 8px rgba(0, 0, 0, 0.2) !important;
}
.event-card .badge {
   position: absolute;
   top: 10px;
   right: 10px;
   z-index: 10;
   padding: 8px 12px;
   font-size: 12px;
}
.event-card .card-img {
   height: 200px;
   width: 100%;
   object-fit: cover;
}
