/* ====================================================================
   THEME.CSS — Public Site + Admin Panel
   ==================================================================== */

/* -- Variables -- */
:root{
  --primary:#0b3d91;
  --secondary:#0b78b7;
  --muted:#6c757d;
  --accent:#ff6b6b;
  --accent-2:#00b894;
  --bg:#f6f8fb;
  --surface:#ffffff;
  --muted-2:#98a0b3;
  --radius:12px;
  --shadow-sm:0 2px 8px rgba(9,37,59,0.04);
  --shadow-md:0 8px 24px rgba(9,37,59,0.06);
  --shadow-lg:0 16px 48px rgba(9,37,59,0.08);
  --transition:0.25s cubic-bezier(0.4,0,0.2,1);
}

/* -- Base reset -- */
*,*::before,*::after{box-sizing:border-box}
html,body{height:100%;margin:0}
body{
  display:flex;flex-direction:column;min-height:100vh;
  font-family:'Poppins','Inter',system-ui,-apple-system,'Segoe UI',Roboto,'Helvetica Neue',Arial,sans-serif;
  background:var(--bg);color:#0b2538;
  -webkit-font-smoothing:antialiased;
}
main{flex:1}

/* -- Layout -- */
.container{max-width:100%;padding-left:0;padding-right:0}
.inner-container{max-width:1280px;margin-left:auto;margin-right:auto;padding-left:20px;padding-right:20px}

/* -- Typography -- */
h1{font-size:2.1rem;letter-spacing:-0.02em;font-weight:700}
h2{font-size:1.6rem;font-weight:700;letter-spacing:-0.01em}
h3{font-size:1.25rem;font-weight:600}
h5{font-weight:600}
p.lead{font-size:1.05rem;color:rgba(255,255,255,0.92)}

/* ====================================================================
   HEADER: Contact bar, Brand area, Navigation
   ==================================================================== */

/* Contact bar */
.contact-bar{
  background:var(--top-contact-bg,var(--accent));
  border-bottom:1px solid rgba(11,37,59,0.03);
  color:rgba(255,255,255,0.95);
}
.contact-bar a.footer-link,.contact-bar a.social-link{color:rgba(255,255,255,0.95);text-decoration:none}
.contact-bar a.footer-link:hover{text-decoration:underline}

/* Social icons in contact bar */
.contact-right .social-link{display:inline-flex;text-decoration:none}
.social-icon{display:inline-flex;width:34px;height:34px;border-radius:50%;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:0.9rem;transition:transform var(--transition)}
.social-icon:hover{transform:scale(1.1)}
.social-icon .si-initial{line-height:1}
.social-fb{background:#1877F2}
.social-ig{background:linear-gradient(45deg,#f58529,#dd2a7b,#8134af)}
.social-li{background:#0A66C2}
.social-wa{background:#25D366;color:#06372b}
.social-yt{background:#FF0000}
.social-generic{background:rgba(255,255,255,0.15);color:#fff}

/* Brand area */
.brand-area{background:#fff;border-bottom:1px solid rgba(11,37,59,0.06)}
.brand-area .inner-container{display:flex;justify-content:space-between;align-items:center}
.brand-area .h4{color:var(--primary)}
.brand-logo{height:56px;object-fit:contain;border-radius:8px}
.brand-title .h4{font-size:1.25rem}
.brand-right .btn-theme{margin-left:8px}
.navbar-brand-img{height:56px;object-fit:contain;border-radius:8px}
.navbar-brand-fallback{width:56px;height:56px;border-radius:8px;background:var(--accent);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700}

/* Desktop nav next to logo */
.desktop-nav{
  display:flex !important;flex-direction:row !important;
  gap:4px;align-items:center;list-style:none;padding:0;margin:0;flex-wrap:wrap;
}
.desktop-nav li{display:inline-flex;align-items:center;margin:0}
.desktop-nav .nav-link{
  display:inline-block;padding:10px 14px;font-weight:600;color:rgba(11,37,59,0.85);
  font-size:0.92rem;border-radius:8px;transition:all var(--transition);
}
.desktop-nav .nav-link:hover{color:var(--primary);background:rgba(11,61,145,0.05)}
.desktop-nav .nav-link::after{
  content:'';display:block;height:2px;width:0;
  background:var(--accent);transition:width .22s ease;margin-top:4px;border-radius:2px;
}
.desktop-nav .nav-link:hover::after,.desktop-nav .nav-link.active::after{width:100%}
.desktop-nav .dropdown-menu{z-index:2100;border-radius:10px;border:0;box-shadow:var(--shadow-lg);padding:8px 0}
.desktop-nav .dropdown-item{padding:8px 16px;font-size:0.9rem;border-radius:6px;margin:0 6px;transition:background var(--transition)}
.desktop-nav .dropdown-item:hover{background:rgba(11,61,145,0.05)}

/* Old site-navbar (hidden by default, kept for compatibility) */
.site-navbar{display:none}
.site-navbar .nav-link{color:rgba(255,255,255,0.95);padding:10px 12px}
.site-navbar .dropdown-menu{z-index:2100;border-radius:10px;border:0;box-shadow:var(--shadow-lg)}

@media (min-width: 768px){
  .brand-area{z-index:1055}
  .site-navbar{z-index:1050}
}

/* Mobile hamburger toggler for public site */
.navbar-toggler{
  border:1.5px solid rgba(11,37,59,0.12);border-radius:8px;padding:6px 10px;
  background:transparent;transition:all var(--transition);
}
.navbar-toggler:focus{box-shadow:0 0 0 3px rgba(11,61,145,0.1);outline:none}
.navbar-toggler-icon{
  width:22px;height:22px;
  background-image:url("data:image/svg+xml,%3csvg viewBox='0 0 30 30' xmlns='http://www.w3.org/2000/svg'%3e%3cpath stroke='rgba(11,37,59,0.7)' stroke-width='2' stroke-linecap='round' d='M4 7h22M4 15h22M4 23h22'/%3e%3c/svg%3e");
}
#mainNav{
  background:#fff;border-radius:var(--radius);box-shadow:var(--shadow-lg);
  padding:12px;margin-top:8px;
}
#mainNav .nav-link{color:#0b2538;font-weight:500;padding:10px 12px;border-radius:8px}
#mainNav .nav-link:hover{background:rgba(11,61,145,0.04)}
#mainNav .dropdown-menu{border:0;box-shadow:none;padding-left:16px}

@media (max-width: 767px){
  .brand-logo{height:44px}
  .brand-title .h4{font-size:1rem}
  .contact-right{display:none !important}
}

/* Mobile nav */
@media (max-width: 767px){
  .site-navbar nav{display:none}
}

/* ====================================================================
   HOME PAGE: Carousel / Slider
   ==================================================================== */

/* Carousel */
#homeCarousel{border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-md)}
#homeCarousel .carousel-item img{height:440px;object-fit:cover;display:block;width:100%}
#homeCarousel .carousel-item > div{height:440px}
#homeCarousel .carousel-caption{
  background:linear-gradient(0deg,rgba(0,0,0,0.6) 0%,transparent 100%);
  left:0;right:0;bottom:0;padding:30px 24px 20px;text-align:left;
}
#homeCarousel .carousel-caption h5{font-weight:700;font-size:1.2rem;text-shadow:0 2px 8px rgba(0,0,0,0.3)}
#homeCarousel .carousel-control-prev,
#homeCarousel .carousel-control-next{width:48px;height:48px;top:50%;transform:translateY(-50%);bottom:auto;border-radius:12px;background:rgba(255,255,255,0.15);backdrop-filter:blur(4px);margin:0 12px;opacity:0;transition:opacity var(--transition)}
#homeCarousel:hover .carousel-control-prev,
#homeCarousel:hover .carousel-control-next{opacity:1}

@media (max-width:768px){
  #homeCarousel .carousel-item img,
  #homeCarousel .carousel-item > div{height:280px}
}

/* ====================================================================
   COLOR BAR: Admissions / Downloads / Contact cards
   ==================================================================== */

.color-bar{margin-bottom:28px;margin-top:-1px}
.color-bar .color-card{
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  text-decoration:none;color:inherit;padding:24px 18px;
  transition:all var(--transition);position:relative;overflow:hidden;
}
.color-bar .color-card::before{
  content:'';position:absolute;inset:0;background:rgba(0,0,0,0);transition:background var(--transition);
}
.color-bar .color-card:hover::before{background:rgba(0,0,0,0.08)}
.color-bar .color-card:hover{text-decoration:none;transform:none}
.color-bar .color-card h5{color:#fff;margin:0;font-weight:700;font-size:1.05rem;position:relative;z-index:1}
.color-bar .color-card p{color:rgba(255,255,255,0.9);margin:6px 0 0;font-size:0.88rem;position:relative;z-index:1}
.color-bar .card-cta{
  background:rgba(255,255,255,0.18);color:#fff;padding:7px 16px;border-radius:8px;font-weight:600;
  text-decoration:none;display:inline-block;margin:12px 0 0;border:none;font-size:0.85rem;
  transition:all var(--transition);position:relative;z-index:1;
}
.color-bar .card-cta:hover{background:rgba(255,255,255,0.3);transform:translateY(-1px)}
.color-bar .color-icon{display:none}

/* ====================================================================
   ABOUT SECTION: Grid, Leadership panel, Vision/Mission
   ==================================================================== */

.card-spot{border:none;box-shadow:var(--shadow-md);background:var(--surface);border-radius:var(--radius)}
.kicker{font-size:0.82rem;color:var(--muted-2);font-weight:600;text-transform:uppercase;letter-spacing:0.04em}

/* About layout */
.about-grid{align-items:stretch}
.about-grid .section-accent-panel,.about-grid .card-spot{height:100%}
.about-grid .card-spot{display:flex;flex-direction:column;border-radius:var(--radius)}
.about-grid .card-spot .about-details{flex:1}

/* Leadership panel (right side) */
.section-accent-panel{border-radius:var(--radius);padding:28px;color:#fff;background:var(--accent);min-height:180px;display:flex;flex-direction:column;justify-content:center}
.section-accent-panel .kicker{color:rgba(255,255,255,0.95);font-weight:700;text-transform:uppercase}
.leadership-panel{background:var(--lead-bg,var(--accent-2)) !important;border-radius:var(--radius);color:#fff !important;display:flex;flex-direction:column;justify-content:flex-start;min-height:180px}
.leadership-panel .kicker{color:rgba(255,255,255,0.95) !important}
.leadership-panel > .d-flex .btn-readmore{background:rgba(255,255,255,0.25) !important;color:#fff !important;border:none !important}
.leadership-panel > .d-flex .btn-readmore:hover{background:rgba(255,255,255,0.35) !important}
.leadership-panel .about-leaders{display:flex;flex-direction:column;gap:12px}
.leadership-panel .leader-card{background:#fff !important;padding:14px;border-radius:10px;box-shadow:0 2px 8px rgba(0,0,0,0.08) !important;border:none !important}
.leadership-panel .leader-avatar{width:56px;height:56px;border-radius:50%;object-fit:cover;border:2px solid rgba(0,0,0,0.06)}
.leadership-panel .leader-avatar.initials{display:flex;align-items:center;justify-content:center;background:#eef6ff;color:var(--primary) !important;font-weight:700;font-size:16px}
.leadership-panel .leader-name{color:#0b2538 !important;font-weight:700}
.leadership-panel .leader-title{color:var(--muted) !important;font-size:0.85rem}
.leadership-panel .leader-message{color:#333 !important}
.leadership-panel .leader-card .text-muted{color:var(--muted) !important}
.leadership-panel .leader-card .btn-readmore{background:var(--accent) !important;color:#fff !important}

/* Leader mini snippets in about panel */
.about-leaders{margin-top:12px;display:flex;flex-direction:column;gap:12px}
.about-leaders .leader-mini{display:flex;gap:10px;align-items:flex-start}
.about-leaders .leader-mini .avatar{width:48px;height:48px;border-radius:8px;object-fit:cover;background:#fff}
.about-leaders .leader-mini .meta{flex:1}
.about-leaders .leader-mini .name{font-weight:700;font-size:0.95rem}
.about-leaders .leader-mini .title{font-size:0.85rem;color:var(--muted);margin-bottom:4px}
.about-leaders .leader-mini .msg{font-size:0.9rem;color:rgba(255,255,255,0.95)}

/* Vision/Mission tiles */
.vision-panel{background:var(--accent-2);border-radius:10px}
.mission-panel{background:var(--secondary);border-radius:10px}
.about-vision-row .col-md-6{display:flex}
.about-details .vision-panel,.about-details .mission-panel{display:flex;flex-direction:column}
.about-details .vision-panel .small,.about-details .mission-panel .small{flex:1}

/* Accent cards */
.card-accent-1{background:var(--card-accent-1,var(--accent));box-shadow:var(--shadow-md)}
.card-accent-2{background:var(--card-accent-2,var(--accent-2));box-shadow:var(--shadow-md)}
.card-accent-3{background:var(--card-accent-3,#ff7b00);box-shadow:var(--shadow-md)}
.card-accent-1 h5,.card-accent-2 h5,.card-accent-3 h5{color:#fff}
.card-accent-1 p,.card-accent-2 p,.card-accent-3 p{color:rgba(255,255,255,0.92)}
.card-accent-1 .btn-readmore,.card-accent-2 .btn-readmore,.card-accent-3 .btn-readmore{background:#fff;color:var(--primary)}

/* ====================================================================
   HIGHLIGHTS ROW
   ==================================================================== */

.highlight-row .card{
  border:none;box-shadow:var(--shadow-md);transition:transform var(--transition),box-shadow var(--transition);
  padding:24px;background:#fff;border-radius:var(--radius);
}
.highlight-row .card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg)}

/* ====================================================================
   ANNOUNCEMENTS TICKER
   ==================================================================== */

.announcement-ticker{overflow:hidden;width:100%;position:relative;padding:4px 0}
.ticker-track{display:flex;gap:18px;align-items:stretch;padding:6px 0;animation:scrollTicker 24s linear infinite}
.ticker-card{
  min-width:320px;flex:0 0 auto;box-shadow:var(--shadow-sm);border-radius:var(--radius);
  border:1px solid rgba(11,37,59,0.04);background:#fff;transition:box-shadow var(--transition);
}
.ticker-card:hover{box-shadow:var(--shadow-md)}
.ticker-card .card-body{padding:16px}
.ticker-card .card-body h6{color:var(--primary);font-weight:700}
@keyframes scrollTicker{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.announcement-ticker:hover .ticker-track{animation-play-state:paused}

@media (max-width:768px){
  .ticker-card{min-width:260px}
}

/* ====================================================================
   GALLERY
   ==================================================================== */

/* Gallery grid */
.gallery-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:16px}
.gallery-item{
  display:block;overflow:hidden;border-radius:var(--radius);background:#fff;
  box-shadow:var(--shadow-sm);transition:box-shadow var(--transition),transform var(--transition);
  opacity:0;transform:translateY(12px);animation:galleryFadeIn .5s cubic-bezier(.16,.84,.3,1) forwards;
  animation-delay:var(--i,0s);
}
.gallery-item:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}
.gallery-item img{width:100%;height:220px;object-fit:cover;display:block;transition:transform .4s ease}
.gallery-item:hover img{transform:scale(1.04)}
@keyframes galleryFadeIn{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}

/* Gallery filter buttons */
.gallery-filters .btn-theme-outline{
  border:1px solid rgba(11,37,59,0.1);border-radius:20px;padding:6px 16px;
  font-size:0.85rem;font-weight:500;transition:all var(--transition);
}
.gallery-filters .btn-theme-outline:hover,
.gallery-filters .btn-theme-outline.btn-active{
  background:var(--primary);color:#fff;border-color:var(--primary);
}

/* Gallery loader */
.gallery-loader{display:none;text-align:center;padding:10px;margin-bottom:10px}
.gallery-loader .spinner{width:36px;height:36px;margin:6px auto;border-radius:50%;border:4px solid rgba(0,0,0,0.08);border-top-color:var(--accent);animation:spin 0.9s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}

/* Home gallery scroller */
.home-gallery-scroller{position:relative;display:flex;align-items:center}
.scroller-viewport{overflow:hidden;flex:1}
.scroller-track{display:flex;gap:12px;padding:6px 2px;scroll-behavior:smooth}
.scroller-item{
  flex:0 0 calc(33.333% - 8px);display:block;border-radius:10px;overflow:hidden;
  background:#fff;text-decoration:none;color:inherit;box-shadow:var(--shadow-sm);
  transition:box-shadow var(--transition),transform var(--transition);
}
.scroller-item:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}
.scroller-item img{width:100%;height:160px;object-fit:cover;display:block}
.scroller-caption{padding:6px 8px;color:var(--muted);font-size:0.85rem}
.scroller-btn{
  flex:0 0 auto;margin:0 8px;background:rgba(255,255,255,0.95);border:0;
  width:40px;height:40px;border-radius:10px;box-shadow:var(--shadow-md);
  display:flex;align-items:center;justify-content:center;cursor:pointer;
  font-size:1.2rem;color:var(--primary);transition:all var(--transition);
}
.scroller-btn:hover{background:#fff;box-shadow:var(--shadow-lg);transform:scale(1.05)}
.scroller-btn:focus{outline:none;box-shadow:var(--shadow-lg)}
.scroller-btn[disabled]{opacity:0.3;pointer-events:none}

@media (min-width:1200px){.scroller-item{flex:0 0 calc(25% - 9px)}}
@media (min-width:768px) and (max-width:1199px){.scroller-item{flex:0 0 calc(33.333% - 8px)}}
@media (max-width:767px){
  .scroller-item{flex:0 0 calc(50% - 8px)}
  .scroller-item img{height:120px}
  .scroller-btn{width:36px;height:36px}
  .gallery-item img{height:140px}
}

/* Lightbox */
.lb-overlay{position:fixed;left:0;top:0;right:0;bottom:0;background:rgba(0,0,0,0.88);display:flex;align-items:center;justify-content:center;z-index:9999;padding:20px;backdrop-filter:blur(4px)}
.lb-overlay img{max-width:100%;max-height:100%;border-radius:8px;box-shadow:0 20px 60px rgba(0,0,0,0.5)}
.lb-close{position:absolute;right:18px;top:18px;color:#fff;background:rgba(255,255,255,0.1);border:0;font-size:24px;cursor:pointer;width:44px;height:44px;border-radius:10px;display:flex;align-items:center;justify-content:center;transition:background var(--transition)}
.lb-close:hover{background:rgba(255,255,255,0.2)}
.lb-prev,.lb-next{position:absolute;top:50%;transform:translateY(-50%);background:rgba(255,255,255,0.1);border:0;color:#fff;width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background var(--transition)}
.lb-prev{left:18px}
.lb-next{right:18px}
.lb-prev:hover,.lb-next:hover{background:rgba(255,255,255,0.2)}
.lb-caption{position:absolute;left:50%;transform:translateX(-50%);bottom:24px;color:#fff;max-width:90%;text-align:center;font-size:0.95rem;text-shadow:0 2px 8px rgba(0,0,0,0.4)}

/* ====================================================================
   FEATURES / FACILITIES
   ==================================================================== */

.feature-list .feature-card{
  min-height:340px;height:340px;display:flex;flex-direction:column;justify-content:space-between;
  border-radius:18px;padding:28px;color:#fff;
  background:var(--feat-card-bg,var(--accent));
  box-shadow:var(--shadow-lg);transition:transform var(--transition),box-shadow var(--transition);
  position:relative;overflow:hidden;width:100%;
}
.feature-list .feature-card:hover{transform:translateY(-8px);box-shadow:0 24px 60px rgba(9,37,59,0.14)}
.feature-list .feature-card::after{
  content:'';position:absolute;right:-20px;top:-20px;width:120px;height:120px;
  background:radial-gradient(circle,rgba(255,255,255,0.08),transparent 70%);
  border-radius:50%;pointer-events:none;
}
.feature-list .feature-icon{
  width:80px;height:80px;font-size:36px;line-height:1;
  color:var(--feat-icon-fg,#fff);display:flex;align-items:center;justify-content:center;
  border-radius:16px;background:rgba(255,255,255,0.15);
  margin:0 auto;backdrop-filter:blur(4px);
}
.feature-list .feature-icon img{width:100%;height:100%;border-radius:12px;object-fit:cover;display:block}
.feature-list .feature-icon .emoji-bubble{font-size:32px;color:var(--feat-icon-fg,#fff);background:transparent;border:0;box-shadow:none}
.feature-list .feature-card h5,.feature-list .feature-card p{color:#fff}
.feature-list .feature-card h5{font-weight:700}
.feature-list .feature-readmore{
  background:rgba(255,255,255,0.2);color:#fff;border-radius:10px;
  padding:10px 20px !important;font-weight:700;display:inline-block;text-decoration:none;
  font-size:0.9rem !important;border:0;backdrop-filter:blur(2px);transition:all var(--transition);
}
.feature-list .feature-readmore:hover{background:rgba(255,255,255,0.3)}

/* Per-card colors */
.feature-list .col-md-4:nth-child(1) .feature-card{background:var(--card-accent-1,var(--accent))}
.feature-list .col-md-4:nth-child(2) .feature-card{background:var(--card-accent-2,var(--accent-2))}
.feature-list .col-md-4:nth-child(3) .feature-card{background:var(--card-accent-3,#ff7b00)}
.feature-list .col-md-4:nth-child(4) .feature-card{background:var(--primary)}
.feature-list .col-md-4:nth-child(5) .feature-card{background:var(--accent-2)}
.feature-list .col-md-4:nth-child(6) .feature-card{background:var(--accent)}

@media (max-width:768px){
  .feature-list .feature-card{min-height:auto;height:auto;padding:20px}
  .feature-list .feature-icon{width:64px;height:64px}
}

/* ====================================================================
   LEADERSHIP PAGES
   ==================================================================== */

.leadership-row .leader-card{border-radius:var(--radius);padding:14px;background:#fff;box-shadow:var(--shadow-md);height:100%}
.leadership-row .leader-avatar{width:72px;height:72px;border-radius:50%;object-fit:cover;background:#eef6ff;display:block}
.leadership-row .leader-avatar.initials{display:flex;align-items:center;justify-content:center;background:#eef6ff;color:var(--primary);font-weight:700}
.leadership-row .leader-name{font-weight:700}
.leadership-row .leader-title{font-size:.95rem;color:var(--muted);margin-bottom:6px}
.leader-card .leader-message{margin-top:6px;color:#213243}

.page-leadership .leader-card{display:flex;align-items:center;gap:18px;background:#fff;border-radius:var(--radius);box-shadow:var(--shadow-md);padding:20px}
.page-leadership .leader-avatar{width:96px;height:96px;border-radius:var(--radius);object-fit:cover}
.page-leadership .leader-avatar.initials{border-radius:50%}
.page-leadership .leader-name{font-weight:700;font-size:1.05rem}
.page-leadership .leader-title{color:var(--muted);margin-top:2px}
.page-leadership .leader-message{margin-top:8px;color:#213243}

@media (max-width:767px){
  .leadership-panel .leader-card{flex-direction:row;gap:12px}
  .leadership-panel .leader-avatar{width:48px;height:48px}
  .page-leadership .leader-card{flex-direction:row;align-items:center}
  .page-leadership .leader-avatar{width:72px;height:72px}
}

/* ====================================================================
   BUTTONS
   ==================================================================== */

.btn-theme{
  background:var(--accent);border:0;color:#fff;border-radius:10px;
  padding:10px 18px;font-weight:600;transition:all var(--transition);
  display:inline-block;text-decoration:none;
}
.btn-theme:hover{opacity:0.9;transform:translateY(-1px);color:#fff}
.btn-theme:focus,.btn-theme:active{outline:none;box-shadow:0 4px 16px rgba(11,61,145,0.14)}
.btn-theme-outline{
  background:transparent;border:1.5px solid rgba(11,37,59,0.1);color:var(--primary);
  border-radius:10px;padding:10px 18px;transition:all var(--transition);
}
.btn-theme-outline:hover{border-color:var(--primary);background:rgba(11,61,145,0.03)}

/* Button size variants */
.btn-theme-lg{padding:14px 22px;font-size:1rem;border-radius:12px}
.btn-theme-md{padding:10px 18px;font-size:0.92rem;border-radius:10px}
.btn-theme-sm{padding:6px 12px;font-size:0.85rem;border-radius:8px}

/* Read-more buttons */
.btn-readmore{
  background:var(--accent);border:0;color:#fff;border-radius:8px;
  padding:8px 14px;font-weight:600;font-size:0.88rem;
  text-decoration:none;display:inline-block;transition:all var(--transition);
}
.btn-readmore:hover{opacity:0.9;transform:translateY(-1px);color:#fff}
.btn-accent{background:var(--accent);border:0;color:#fff;border-radius:8px;transition:all var(--transition)}
.btn-accent:hover{opacity:0.9}
.btn-cta{background:var(--primary);color:#fff;border-radius:10px;padding:12px 20px;font-weight:600;box-shadow:0 10px 30px rgba(11,61,145,0.12);border:0}
.btn-ghost{background:transparent;border:2px solid rgba(255,255,255,0.14);color:#fff;border-radius:10px;padding:10px 18px}

/* Global small button override */
.btn,.btn-theme,.btn-cta,.btn-readmore{padding:8px 14px !important;font-size:.9rem !important}
.btn{height:auto}

/* ====================================================================
   FORMS
   ==================================================================== */

.form-label{font-weight:600;color:var(--primary);margin-bottom:6px;font-size:0.9rem}
.form-control{border-radius:10px;box-shadow:none;border:1.5px solid rgba(9,37,59,0.1);padding:10px 14px;transition:all var(--transition)}
.form-control:focus{box-shadow:0 0 0 3px rgba(11,61,145,0.08);border-color:var(--accent)}
.alert-success{background:linear-gradient(90deg,rgba(0,184,148,0.08),rgba(33,150,243,0.04));border:1px solid rgba(0,184,148,0.15);color:var(--primary);border-radius:10px}

/* ====================================================================
   DOWNLOADS
   ==================================================================== */

.downloads-table{width:100%;border-collapse:separate;border-spacing:0;margin-top:12px}
.downloads-table th{background:transparent;text-align:left;padding:12px 16px;color:var(--muted);font-weight:700;font-size:0.85rem}
.downloads-table td{padding:12px 16px;border-bottom:0}
.downloads-table tbody tr:nth-child(odd){background:rgba(0,0,0,0.015);border-radius:8px}
.downloads-table .file-link{display:block;color:var(--primary);font-weight:600;text-decoration:none}
.downloads-table .file-link:hover{text-decoration:underline}
.downloads-meta{font-size:.9rem;color:var(--muted)}
@media (max-width:768px){
  .downloads-card{border-radius:var(--radius);padding:14px;margin-bottom:10px;background:#fff;box-shadow:var(--shadow-sm)}
}

/* ====================================================================
   MAP
   ==================================================================== */

.map-embed{position:relative;padding-top:56.25%;overflow:hidden;border-radius:10px}
.map-embed iframe,.map-embed > *{position:absolute;left:0;top:0;width:100%;height:100%;border:0}

/* ====================================================================
   FOOTER
   ==================================================================== */

footer{background:transparent}
.site-footer{
  background:var(--footer-bg,#0b3d91);color:#fff;
  padding-top:56px;padding-bottom:40px;margin-top:0;
}
.site-footer .inner,.site-footer .inner-container{max-width:1280px;margin:0 auto;padding-left:20px;padding-right:20px}
.site-footer a.footer-link{color:rgba(255,255,255,0.85);text-decoration:none;transition:color var(--transition)}
.site-footer a.footer-link:hover{color:#fff;text-decoration:underline}
.site-footer .social-link{color:rgba(255,255,255,0.85);text-decoration:none;margin-right:8px}
.site-footer .social-link:hover{color:#fff}
.site-footer h6{color:#fff;font-size:1rem;margin-bottom:0.6rem}
.site-footer .small{font-size:.92rem}
.site-footer .container{max-width:1100px}
.site-footer .social-icon{
  display:inline-flex;align-items:center;justify-content:center;
  width:44px;height:44px;border-radius:10px;background:rgba(255,255,255,0.08);
  color:#fff;margin-right:8px;text-decoration:none;font-size:16px;
  transition:all var(--transition);
}
.site-footer .social-icon svg{display:block}
.site-footer .social-icon:hover{background:rgba(255,255,255,0.16);transform:translateY(-2px)}

/* Light footer variant */
.site-footer.site-footer-light{background:#f8f9fb;color:#0b2338}
.site-footer.site-footer-light a.footer-link{color:var(--primary)}
.site-footer.site-footer-light .social-link,.site-footer.site-footer-light .social-icon{color:var(--muted)}
.site-footer.site-footer-light h6{color:var(--primary)}
.site-footer.site-footer-light .social-icon{background:transparent}

/* ====================================================================
   MISC
   ==================================================================== */

.rounded-thumb{width:64px;height:64px;object-fit:cover;border-radius:8px}
.admin-feature-thumb{width:36px;height:36px;object-fit:contain;border-radius:6px}
.admin-feature-icon-text{font-size:20px;width:36px;text-align:center}
.announcement{background:white;padding:12px;border-radius:6px;box-shadow:var(--shadow-sm)}
.handle,.drag-handle{padding:6px 8px;border-radius:6px;background:var(--surface);box-shadow:var(--shadow-sm);display:inline-block;cursor:grab;touch-action:pan-y}
.handle:active,.drag-handle:active{cursor:grabbing}
.card-spot.accent-left{border-left:5px solid var(--accent);padding-left:18px}
.card-hover{transition:transform var(--transition),box-shadow var(--transition)}
.card-hover:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg)}
.muted{color:var(--muted-2)}
.about-excerpt{color:var(--primary)}
.toast-notice{position:fixed;right:20px;bottom:20px;background:#198754;color:#fff;padding:10px 14px;border-radius:8px;box-shadow:var(--shadow-lg);display:none}

/* Hero */
.hero{background:var(--primary);color:white;padding:64px 0;border-radius:10px;margin-bottom:28px}
.hero-full{position:relative;width:100%;overflow:hidden}
.hero-full .hero-media img{width:100%;height:620px;object-fit:cover;filter:brightness(.6);display:block}
.hero-media.hero-media-gradient{height:620px;background:var(--primary);display:block}
.hero-overlay{position:absolute;left:0;right:0;top:0;bottom:0;display:flex;align-items:center}
.hero-inner{max-width:1100px;margin:0 auto;padding:48px;color:#fff}

/* Topper card styles */
.topper-card{display:flex;gap:18px;align-items:center;border-radius:var(--radius);background:var(--surface);box-shadow:var(--shadow-md);padding:18px}
.topper-thumb img{width:160px;height:160px;object-fit:cover;border-radius:var(--radius)}
.topper-meta h5{margin:0;font-weight:800}
.topper-gallery .topper-card{height:100%}
.topper-gallery .gallery-panel{height:100%;display:flex;flex-direction:column}
.topper-gallery .gallery-panel .gallery-grid{flex:1;display:grid;grid-template-columns:repeat(2,1fr);gap:10px;align-content:start}
.topper-gallery .gallery-panel .gallery-item img{width:100%;height:100%;object-fit:cover;border-radius:8px}
.topper-carousel{display:flex;overflow-x:auto;gap:12px;padding:8px 4px;scroll-snap-type:x mandatory}
.topper-carousel::-webkit-scrollbar{height:8px}
.topper-carousel::-webkit-scrollbar-thumb{background:rgba(11,37,59,0.12);border-radius:8px}
.topper-item{flex:0 0 auto;border-radius:var(--radius);background:var(--surface);box-shadow:var(--shadow-md);padding:16px;display:flex;flex-direction:column;align-items:center;scroll-snap-align:center}
.topper-item img{border-radius:10px}
.topper-scroll-btn{position:absolute;top:50%;transform:translateY(-50%);width:40px;height:40px;border-radius:8px;background:rgba(11,37,59,0.6);color:#fff;border:0;display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:20}
.topper-scroll-btn.left{left:6px}
.topper-scroll-btn.right{right:6px}
.topper-carousel-wrap{position:relative}
.topper-fade-wrap{position:relative;min-height:220px}
.fade-slide{position:absolute;left:0;right:0;top:0;opacity:0;display:flex;gap:12px;padding:8px 4px;justify-content:center;align-items:stretch}
.fade-slide .topper-item{flex:0 0 auto;min-width:220px}
.fade-slide[aria-hidden="true"]{opacity:0}
.fade-slide.show{opacity:1}

/* Home gallery carousel */
.home-gallery .carousel-item img{width:100%;height:320px;object-fit:cover;border-radius:8px}
.home-gallery .carousel-caption{background:linear-gradient(180deg,rgba(0,0,0,0.35),transparent);padding:6px 12px;border-radius:6px}
.home-gallery .gallery-viewall{border-radius:10px;padding:6px 14px}

/* Animations */
@keyframes fadeUp{from{transform:translateY(10px);opacity:0}to{transform:none;opacity:1}}
.fade-up{animation:fadeUp .7s ease both}

/* Reduce top gap so content sits closer to header */
main.container.py-4{padding-top:1rem !important}

/* Background pattern */
body{
  background-color:#ffffff !important;
  background-image:url('/assets/bg-lines.svg');
  background-repeat:repeat;background-position:top center;
  background-size:320px 160px;background-attachment:local;
}
.brand-area,.site-navbar,.site-footer,.card-spot,.section-accent-panel,.topper-card,.feature-card,.gallery-panel{background-clip:padding-box}
body::before{pointer-events:none}

/* Mega menu */
.mega-menu{width:100%;left:0;right:0;border-radius:10px;padding:18px 22px;box-shadow:var(--shadow-lg)}
.mega-menu .row{gap:12px}
.mega-menu h6{font-weight:700;margin-bottom:8px}
.mega-menu .mega-col{min-width:160px}
.mega-menu a.dropdown-item{display:block;padding:6px 8px;color:var(--muted)}
.mega-menu a.dropdown-item:hover{background:transparent;color:var(--primary)}

@media (min-width:992px){
  .navbar .dropdown:hover > .dropdown-menu{display:block}
  .topper-gallery .gallery-panel .gallery-grid{grid-template-columns:repeat(3,1fr)}
}

/* Responsive adjustments */
@media (max-width:768px){
  .hero-full .hero-media img,.hero-media.hero-media-gradient{height:320px}
  .hero-inner{padding:20px}
  .container{padding-left:8px;padding-right:8px}
  .topper-thumb img{width:96px;height:96px}
  .home-gallery .carousel-item img{height:180px}
  .topper-gallery .topper-card,.topper-gallery .gallery-panel{min-height:160px}
  .gallery-panel .gallery-grid{grid-template-columns:repeat(2,1fr)}
}

@media (min-width:768px){
  .topper-gallery .col-md-6:first-child{border-right:1px solid rgba(11,37,59,0.06);padding-right:16px}
  .topper-gallery .col-md-6:last-child{padding-left:16px}
  .topper-gallery .topper-card,.topper-gallery .gallery-panel{min-height:220px}
}

/* Safety: collapse hidden at desktop */
@media (min-width:992px){
  .site-navbar .collapse.navbar-collapse{display:none !important}
  .site-navbar .center-nav{display:flex !important}
}
.site-navbar .center-nav{display:none !important}

/* ====================================================================
   ADMIN PANEL STYLES
   Scoped under body.admin-panel to avoid affecting the public site.
   ==================================================================== */

body.admin-panel {
  --admin-sidebar-bg: #1e293b;
  --admin-sidebar-width: 260px;
  --admin-sidebar-text: #94a3b8;
  --admin-sidebar-text-hover: #f1f5f9;
  --admin-sidebar-active-bg: rgba(99,102,241,0.15);
  --admin-sidebar-active-text: #818cf8;
  --admin-sidebar-active-border: #818cf8;
  --admin-sidebar-section-text: #64748b;
  --admin-sidebar-border: rgba(255,255,255,0.06);
  --admin-topbar-bg: #ffffff;
  --admin-topbar-shadow: 0 1px 3px rgba(0,0,0,0.06);
  --admin-topbar-height: 60px;
  --admin-page-bg: #f8fafc;
  --admin-card-bg: #ffffff;
  --admin-card-radius: 12px;
  --admin-card-shadow: 0 1px 3px rgba(0,0,0,0.04), 0 4px 12px rgba(0,0,0,0.03);
  --admin-card-shadow-hover: 0 4px 12px rgba(0,0,0,0.08), 0 12px 28px rgba(0,0,0,0.06);
  --admin-accent: #6366f1;
  --admin-accent-light: #e0e7ff;
  --admin-success: #10b981;
  --admin-warning: #f59e0b;
  --admin-danger: #ef4444;
  --admin-info: #3b82f6;
  --stat-1: #6366f1;
  --stat-2: #10b981;
  --stat-3: #f59e0b;
  --stat-4: #3b82f6;
  --stat-5: #ec4899;
  --stat-6: #8b5cf6;
  --admin-transition: 0.2s cubic-bezier(0.4, 0, 0.2, 1);
}

body.admin-panel {
  background: var(--admin-page-bg) !important;
  background-image: none !important;
  font-family: 'Inter', system-ui, -apple-system, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif;
}

/* -- Sidebar -- */
body.admin-panel .admin-sidebar {
  width: var(--admin-sidebar-width);
  background: var(--admin-sidebar-bg);
  border-right: none;
  position: fixed;
  top: 0; left: 0; bottom: 0;
  z-index: 1040;
  padding: 0;
  overflow-y: auto; overflow-x: hidden;
  display: flex; flex-direction: column;
  scrollbar-width: thin;
  scrollbar-color: rgba(255,255,255,0.1) transparent;
  transition: transform var(--admin-transition);
}
body.admin-panel .admin-sidebar::-webkit-scrollbar { width: 6px }
body.admin-panel .admin-sidebar::-webkit-scrollbar-thumb { background: rgba(255,255,255,0.1); border-radius: 3px }

.admin-sidebar-brand {
  padding: 20px 20px 16px;
  border-bottom: 1px solid var(--admin-sidebar-border);
  display: flex; align-items: center; gap: 12px; flex-shrink: 0;
}
.admin-sidebar-brand img { height: 36px; object-fit: contain; border-radius: 8px }
.admin-sidebar-brand strong { color: #f1f5f9; font-size: 1.05rem; font-weight: 700 }

.admin-sidebar-nav { flex: 1; padding: 8px 0; overflow-y: auto }

.admin-section-title {
  font-size: 11px; font-weight: 600; color: var(--admin-sidebar-section-text);
  text-transform: uppercase; letter-spacing: 0.08em; padding: 20px 20px 8px; margin: 0;
}

.admin-nav-link {
  display: flex; align-items: center; gap: 10px;
  padding: 9px 20px; color: var(--admin-sidebar-text); text-decoration: none;
  font-size: 0.9rem; font-weight: 500;
  border-left: 3px solid transparent;
  transition: all var(--admin-transition); margin: 1px 0;
}
.admin-nav-link:hover { color: var(--admin-sidebar-text-hover); background: rgba(255,255,255,0.04); text-decoration: none }
.admin-nav-link.active { color: var(--admin-sidebar-active-text); background: var(--admin-sidebar-active-bg); border-left-color: var(--admin-sidebar-active-border) }

.admin-nav-icon { font-size: 1.1rem; width: 22px; text-align: center; flex-shrink: 0 }
.admin-nav-label { flex: 1 }
.admin-nav-badge {
  font-size: 11px; font-weight: 600;
  background: rgba(255,255,255,0.1); color: #94a3b8;
  padding: 2px 8px; border-radius: 10px; line-height: 1.4;
}

.admin-sidebar-user {
  padding: 16px 20px;
  border-top: 1px solid var(--admin-sidebar-border);
  flex-shrink: 0; background: var(--admin-sidebar-bg);
}
.admin-sidebar-user .user-name { font-size: 0.85rem; color: #94a3b8; margin-bottom: 8px }
.admin-sidebar-user .btn-logout {
  display: block; width: 100%; padding: 8px;
  background: rgba(255,255,255,0.06); border: none; color: #94a3b8;
  border-radius: 8px; font-size: 0.85rem; font-weight: 500;
  text-align: center; text-decoration: none; transition: all var(--admin-transition);
}
.admin-sidebar-user .btn-logout:hover { background: rgba(239,68,68,0.15); color: #fca5a5 }

/* -- Top bar -- */
body.admin-panel .admin-topbar {
  position: sticky; top: 0; z-index: 1030;
  height: var(--admin-topbar-height);
  background: var(--admin-topbar-bg);
  box-shadow: var(--admin-topbar-shadow);
  display: flex; align-items: center; padding: 0 28px; gap: 16px;
}
.admin-breadcrumb { display: flex; align-items: center; gap: 8px; font-size: 0.95rem }
.breadcrumb-root { color: #94a3b8; font-weight: 500 }
.breadcrumb-sep { color: #cbd5e1 }
.breadcrumb-current { color: #1e293b; font-weight: 600 }
.admin-topbar-actions { margin-left: auto; display: flex; align-items: center; gap: 12px }
.btn-view-site {
  font-size: 0.85rem; font-weight: 500; color: var(--admin-accent);
  text-decoration: none; padding: 6px 14px;
  border: 1px solid var(--admin-accent-light); border-radius: 8px;
  transition: all var(--admin-transition);
}
.btn-view-site:hover { background: var(--admin-accent-light); color: var(--admin-accent) }

/* -- Main content area -- */
body.admin-panel .admin-main {
  margin-left: var(--admin-sidebar-width); min-height: 100vh;
  padding: 0; background: var(--admin-page-bg);
}

/* -- Cards -- */
body.admin-panel .card {
  border: none; border-radius: var(--admin-card-radius);
  box-shadow: var(--admin-card-shadow);
  transition: box-shadow var(--admin-transition), transform var(--admin-transition);
}
body.admin-panel .card:hover { box-shadow: var(--admin-card-shadow-hover) }

/* -- Forms -- */
body.admin-panel .form-control {
  border: 1px solid #e2e8f0; border-radius: 8px; padding: 10px 14px; font-size: 0.9rem;
  transition: border-color var(--admin-transition), box-shadow var(--admin-transition);
}
body.admin-panel .form-control:focus { border-color: var(--admin-accent); box-shadow: 0 0 0 3px var(--admin-accent-light) }
body.admin-panel .form-select {
  border: 1px solid #e2e8f0; border-radius: 8px; padding: 10px 14px; font-size: 0.9rem;
}
body.admin-panel .form-select:focus { border-color: var(--admin-accent); box-shadow: 0 0 0 3px var(--admin-accent-light) }
body.admin-panel .form-label { font-weight: 600; color: #334155; font-size: 0.875rem }

/* -- Buttons -- */
body.admin-panel .btn-primary {
  background: var(--admin-accent); border-color: var(--admin-accent);
  border-radius: 8px; font-weight: 500; padding: 8px 18px;
  transition: all var(--admin-transition);
}
body.admin-panel .btn-primary:hover {
  background: #4f46e5; border-color: #4f46e5;
  transform: translateY(-1px); box-shadow: 0 4px 12px rgba(99,102,241,0.3);
}
body.admin-panel .btn-outline-primary { color: var(--admin-accent); border-color: var(--admin-accent); border-radius: 8px }
body.admin-panel .btn-outline-primary:hover { background: var(--admin-accent); border-color: var(--admin-accent) }
body.admin-panel .btn-danger { border-radius: 8px }
body.admin-panel .btn-outline-secondary { border-radius: 8px }
body.admin-panel .btn-sm { padding: 5px 12px !important; font-size: 0.85rem !important; border-radius: 6px }

/* -- Headings -- */
body.admin-panel h2.h4, body.admin-panel .h4 { font-weight: 700; color: #1e293b; font-size: 1.35rem; letter-spacing: -0.01em }
body.admin-panel h3.h5, body.admin-panel .h5 { font-weight: 600; color: #334155; font-size: 1.1rem }

/* -- Alerts -- */
body.admin-panel .alert-success { background: #ecfdf5; border: 1px solid #a7f3d0; color: #065f46; border-radius: 10px }

/* -- Tables -- */
body.admin-panel .table { border-radius: var(--admin-card-radius); overflow: hidden }
body.admin-panel .table thead th {
  background: #f8fafc; font-weight: 600; font-size: 0.8rem;
  text-transform: uppercase; letter-spacing: 0.04em; color: #64748b;
  border-bottom: 2px solid #e2e8f0; padding: 12px 16px;
}
body.admin-panel .table tbody td { padding: 12px 16px; vertical-align: middle; border-bottom: 1px solid #f1f5f9 }

/* -- List groups (drag reorder) -- */
body.admin-panel .list-group-item {
  border: none; border-bottom: 1px solid #f1f5f9; padding: 12px 16px;
  transition: background var(--admin-transition);
}
body.admin-panel .list-group-item:hover { background: #f8fafc }

/* -- Dashboard stat cards -- */
.admin-stat-card {
  display: flex; align-items: center; gap: 16px; padding: 20px;
  background: var(--admin-card-bg); border-radius: var(--admin-card-radius);
  box-shadow: var(--admin-card-shadow);
  border-left: 4px solid var(--stat-accent, var(--admin-accent));
  text-decoration: none; color: inherit;
  transition: all var(--admin-transition); height: 100%;
}
.admin-stat-card:hover { transform: translateY(-3px); box-shadow: var(--admin-card-shadow-hover); text-decoration: none; color: inherit }
.stat-icon {
  font-size: 1.8rem; width: 52px; height: 52px;
  display: flex; align-items: center; justify-content: center;
  background: rgba(99,102,241,0.1); border-radius: 12px; flex-shrink: 0;
}
.stat-body { flex: 1 }
.stat-count { font-size: 1.75rem; font-weight: 800; color: #1e293b; line-height: 1.2 }
.stat-label { font-size: 0.85rem; color: #64748b; font-weight: 500; margin-top: 2px }

.admin-section-heading {
  font-size: 0.8rem; font-weight: 700; text-transform: uppercase;
  letter-spacing: 0.06em; color: #94a3b8;
  margin-bottom: 12px; padding-bottom: 8px; border-bottom: 1px solid #e2e8f0;
}

/* -- Toast improvements -- */
body.admin-panel .toast { border-radius: 10px; border: none; box-shadow: 0 8px 24px rgba(0,0,0,0.12); font-size: 0.9rem }

/* -- Quill editor improvements -- */
body.admin-panel .quill-editor { border-radius: 0 0 10px 10px; border: 1px solid #e2e8f0; border-top: none }
body.admin-panel .ql-toolbar { border-radius: 10px 10px 0 0; border-color: #e2e8f0; background: #f8fafc }

/* -- Mobile hamburger -- */
.admin-sidebar-toggle {
  display: none; flex-direction: column; gap: 5px;
  background: none; border: none; padding: 8px; cursor: pointer;
}
.admin-sidebar-toggle span { display: block; width: 22px; height: 2px; background: #475569; border-radius: 2px; transition: all var(--admin-transition) }

.admin-sidebar-overlay { display: none; position: fixed; inset: 0; background: rgba(0,0,0,0.4); z-index: 1035; backdrop-filter: blur(2px) }

/* -- Mobile responsive -- */
@media (max-width: 991.98px) {
  .admin-sidebar-toggle { display: flex }
  body.admin-panel .admin-sidebar { transform: translateX(-100%); z-index: 1045 }
  body.admin-panel.sidebar-open .admin-sidebar { transform: translateX(0) }
  body.admin-panel.sidebar-open .admin-sidebar-overlay { display: block }
  body.admin-panel .admin-main { margin-left: 0 }
  body.admin-panel .admin-topbar { padding: 0 16px }
  .admin-stat-card { padding: 16px }
  .stat-count { font-size: 1.4rem }
  .stat-icon { width: 44px; height: 44px; font-size: 1.5rem }
}

@media (max-width: 575.98px) {
  .admin-breadcrumb { font-size: 0.85rem }
}
