:root{
  --primary:#0b3d91; /* deeper navy */
  --secondary:#0b78b7; /* sky */
  --muted:#6c757d;
  --accent:#ff6b6b; /* warmer accent */
  --accent-2:#00b894; /* teal accent */
  --bg:#f6f8fb;
  --surface:#ffffff;
  --muted-2:#98a0b3;
  font-family: 'Poppins', 'Inter', system-ui, -apple-system, 'Segoe UI', Roboto, 'Helvetica Neue', Arial;
}
html,body{height:100%;margin:0}
body{display:flex;flex-direction:column;min-height:100vh}
main{flex:1}
/* make site full width with no left/right gutters */
.container{max-width:100%;padding-left:0;padding-right:0}
.inner-container{max-width:1280px;margin-left:auto;margin-right:auto;padding-left:18px;padding-right:18px}
body{font-family:Inter,system-ui, -apple-system, 'Segoe UI', Roboto, 'Helvetica Neue', Arial; background:var(--bg);color:#0b2538}
.site-navbar{box-shadow:0 6px 30px rgba(11,61,145,0.06)}
.site-navbar {background: var(--primary); padding-top:6px;padding-bottom:6px}
.site-navbar .nav-link{opacity:.95;color:rgba(255,255,255,0.95)}
.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}
/* Centered desktop nav styling */
.site-navbar{background: rgba(11,61,145,0.82);backdrop-filter: blur(8px);box-shadow:0 12px 40px rgba(11,61,145,0.08);padding-top:10px;padding-bottom:10px}
.site-navbar .inner-container{display:block;position:relative}
.site-navbar .center-nav{ /* legacy center-nav: ensure it doesn't affect layout if present */
  position:static !important; left:auto !important; top:auto !important; transform:none !important; display:none !important;
}

/* Desktop nav rendered next to the logo */
.desktop-nav{
  display:flex !important;
  flex-direction:row !important;
  gap:18px;
  margin-left:24px;
  align-items:center;
  list-style:none;
  padding:0;
  margin:0;
}
.desktop-nav li{display:inline-flex;align-items:center;margin:0}
.desktop-nav .nav-link{display:inline-block;padding:10px 12px;font-weight:600;color:rgba(11,37,59,0.95);}
.desktop-nav .nav-link::after{content:'';display:block;height:2px;width:0;background:var(--accent);transition:width .22s ease;margin-top:6px;border-radius:2px}
.desktop-nav .nav-link:hover::after,.desktop-nav .nav-link.active::after{width:100%}

/* ensure dropdowns for desktop-nav appear correctly */
.desktop-nav .dropdown-menu{z-index:2100}

/* Ensure the brand area spreads content correctly */
.brand-area .inner-container{display:flex;justify-content:space-between;align-items:center}
.site-navbar .nav-actions .btn-theme{padding:8px 12px}

@media (max-width: 991px){
  .site-navbar{backdrop-filter:none;background:var(--primary)}
  .site-navbar .center-nav{display:none}
}
/* ensure dropdowns appear above centered nav and other elements */
.site-navbar .dropdown-menu{z-index:2100}
.contact-bar{background:var(--top-contact-bg);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}
.brand-area{background:transparent}
.brand-area .h4{color:var(--primary)}
.brand-logo{height:56px;object-fit:contain;border-radius:8px}
.brand-title .h4{font-size:1.25rem}
.brand-area{border-bottom:1px solid rgba(11,37,59,0.04)}

/* Social icon styles used in the contact bar */
.contact-right .social-link{display:inline-flex;text-decoration:none}
.social-icon{display:inline-flex;width:36px;height:36px;border-radius:50%;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:0.95rem}
.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.12);color:var(--primary)}

/* Make navbar sticky so it remains visible when scrolling */
.site-navbar.navbar-sticky{position:sticky;top:0;z-index:1050}

/* Reduce brand/spacing on small screens */
@media (max-width: 767px){
  .brand-logo{height:44px}
  .brand-title .h4{font-size:1rem}
  .contact-right{display:none}
}

/* Safety: ensure mobile collapsed menu is hidden on large screens to avoid duplicate menus
   (this forces the collapse block hidden at desktop breakpoints if markup appears twice) */
@media (min-width: 992px) {
  .site-navbar .collapse.navbar-collapse { display: none !important; }
  .site-navbar .center-nav { display: flex !important; }
}
.site-navbar{padding:0}
.site-navbar .inner-container{display:block;padding-top:8px;padding-bottom:8px}
.site-navbar .nav-link{color:rgba(255,255,255,0.95);padding:10px 12px}
.site-navbar .nav-link.active, .site-navbar .nav-link:focus{color:#fff}
.btn-cta{background:var(--accent);border:0;color:#fff}
.site-navbar .nav-link:hover{color:#fff}
.site-navbar .dropdown-menu{border-radius:10px;border:0;box-shadow:0 12px 30px rgba(9,37,59,0.08)}

/* Mega menu styles */
.mega-menu{width:100%;left:0;right:0;border-radius:10px;padding:18px 22px}
.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}
}

/* ensure the mega menu sits below the nav with subtle shadow */
.mega-menu{box-shadow:0 20px 60px rgba(9,37,59,0.08)}
.hero{background:var(--primary); color:white; padding:64px 0; border-radius:10px; margin-bottom:28px}
.card-spot{border:none;box-shadow:0 10px 30px rgba(9,37,59,0.04);background:var(--surface)}
.feature-list .icon{font-size:28px;color:var(--accent);} 
.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:0 18px 50px rgba(9,37,59,0.08);transition:transform .28s cubic-bezier(.2,.9,.2,1),box-shadow .28s ease}
/* fixed square-ish card so all feature tiles have same height/width feel */
.feature-list .feature-card{width:100%}
.feature-list .feature-card:hover{transform:translateY(-10px);box-shadow:0 30px 70px rgba(9,37,59,0.12)}
.feature-list .feature-card::after{content:'';position:absolute;right:18px;top:18px;width:48px;height:48px;background:linear-gradient(135deg,rgba(255,255,255,0.06),rgba(255,255,255,0.02));transform:rotate(20deg);border-radius:8px;pointer-events:none}
.feature-list .feature-card{position:relative;overflow:hidden}
.feature-list .feature-icon{width:96px;height:96px;font-size:40px;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.12);box-shadow:0 12px 34px rgba(11,37,59,0.06);margin:0 auto}
.feature-list .feature-icon img{width:100%;height:100%;border-radius:12px;object-fit:cover;background:transparent;display:block}
.feature-list .feature-icon .emoji-bubble{font-size:36px;color:var(--feat-icon-fg, #fff);background:transparent;border:0;box-shadow:none;display:inline-flex;align-items:center;justify-content:center}

/* Per-card flat colors to make the features section colourful */
.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, #0b3d91);}
.feature-list .col-md-4:nth-child(5) .feature-card{background:var(--accent-2, #00b894);} 
.feature-list .col-md-4:nth-child(6) .feature-card{background:var(--accent, #ff6b6b);} 

/* Ensure text and readmore button contrast nicely on coloured backgrounds */
.feature-list .feature-card h5, .feature-list .feature-card p, .feature-list .feature-card .feature-readmore{color:#fff}
.feature-list .feature-card .feature-readmore{background:rgba(255,255,255,0.12);border-radius:12px;padding:10px 18px;color:#fff;border:0}
.feature-list .feature-card .feature-readmore:hover{background:rgba(255,255,255,0.18)}
.announcement{background:white;padding:12px;border-radius:6px;box-shadow:0 6px 20px rgba(0,0,0,0.03);} 
.handle{padding:6px 10px;border-radius:6px;background:var(--surface);box-shadow:0 6px 18px rgba(9,37,59,0.04);margin-left:8px}
.handle:active{cursor:grabbing}
/* touch-friendly */
.handle{touch-action:pan-y}
.handle{cursor:grab}
.drag-handle{padding:6px 8px;border-radius:6px;background:var(--surface);box-shadow:0 6px 18px rgba(9,37,59,0.04);display:inline-block;z-index:5}
.drag-handle:active{cursor:grabbing}

.highlight-row .card{border:none;box-shadow:0 18px 50px rgba(9,37,59,0.06);transition:transform .18s ease;padding:22px;background:#fff}
.highlight-row .card:hover{transform:translateY(-6px)}
.hero-cta .btn{padding:12px 20px;border-radius:8px}
.feature-list .card h5{font-weight:700}
.toast-notice{position:fixed;right:20px;bottom:20px;background:#198754;color:#fff;padding:10px 14px;border-radius:8px;box-shadow:0 8px 30px rgba(0,0,0,0.12);display:none}
footer{background:transparent}
.site-footer{background:var(--footer-bg,#0b3d91);color:#fff;padding-top:56px;padding-bottom:56px;min-height:44vh;margin-top:0}
.site-footer .inner{max-width:1280px;margin:0 auto}
.site-footer .inner-container{max-width:1280px;margin:0 auto;padding-left:18px;padding-right:18px}
.site-footer a.footer-link{color:rgba(255,255,255,0.95);text-decoration:none}
.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}
.site-footer .container{max-width:1100px}

/* compact social icons */
.site-footer .social-icon{display:inline-flex;align-items:center;justify-content:center;width:52px;height:52px;border-radius:12px;background:rgba(255,255,255,0.06);color:#fff;margin-right:10px;text-decoration:none;font-size:16px}
.site-footer .social-icon svg{display:block}
.site-footer .social-icon:hover{background:rgba(255,255,255,0.14);color:#fff}
.site-footer.site-footer-light .social-icon{background:transparent;color:var(--muted)}
.site-footer .social-icon[title]{cursor:pointer}

/* typographic tweaks for taller footer */
.site-footer .h6, .site-footer h6{font-size:1rem;margin-bottom:0.6rem}
.site-footer .small{font-size:.95rem}

/* 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{color:var(--muted)}
.site-footer.site-footer-light h6{color:var(--primary)}
.btn-accent{background:var(--accent);border:0;color:#fff}
.rounded-thumb{width:64px;height:64px;object-fit:cover;border-radius:8px}

/* Admin list thumbnails */
.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}

/* Leadership cards on home page */
.leadership-row .leader-card{border-radius:12px;padding:18px;background:#fff;box-shadow:0 12px 30px rgba(9,37,59,0.06);height:100%}
.leadership-row .leader-avatar{width:72px;height:72px;border-radius:10px;object-fit:cover;background:#eef6ff}
.leadership-row .leader-name{font-weight:700;margin-top:8px}
.leadership-row .leader-title{font-size:.95rem;color:var(--muted)}
.leader-card .leader-message{margin-top:10px;color:#213243}

/* New colorful sections and CTAs */
.section-accent-panel{border-radius:12px;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}
.section-accent-panel .accent-cta{margin-top:14px}
.btn-theme{background:var(--accent);border:0;color:#fff;border-radius:10px;padding:10px 16px;font-weight:700}
.btn-theme:focus,.btn-theme:active{outline:none;box-shadow:0 8px 30px rgba(11,61,145,0.14)}
.btn-theme-outline{background:transparent;border:2px solid rgba(0,0,0,0.06);color:var(--primary);border-radius:10px;padding:10px 16px}
.about-excerpt{color:var(--primary)}

/* Make small CTA buttons variant */
.btn-theme.btn-sm{padding:6px 10px;border-radius:8px;font-size:.9rem}

/* Button size variants for Admission/Downloads/Contact */
.btn-theme-lg{padding:14px 20px;font-size:1.05rem;border-radius:12px}
.btn-theme-md{padding:10px 16px;font-size:0.95rem;border-radius:10px}
.btn-theme-sm{padding:6px 10px;font-size:0.9rem;border-radius:8px}

/* Single-color readmore buttons */
.btn-readmore{background:var(--accent);border:0;color:#fff;border-radius:8px;padding:8px 12px;font-weight:700}
.btn-readmore:focus,.btn-readmore:active{outline:none;box-shadow:0 8px 30px rgba(11,61,145,0.14)}

/* Larger read-more variant for features — overrides global small-button rule */
.feature-list .feature-readmore{background:var(--primary);color:#fff;border-radius:12px;padding:12px 20px;font-weight:800;display:inline-block;text-decoration:none}
.feature-list .feature-readmore:focus,.feature-list .feature-readmore:active{box-shadow:0 12px 36px rgba(11,61,145,0.18);outline:none}
.feature-list .feature-readmore{padding:12px 20px !important;font-size:1rem !important}


/* Leadership right-panel styling */
.leadership-panel{background:var(--lead-bg, var(--accent-2));border-radius:12px;color:#fff;display:flex;flex-direction:column;justify-content:flex-start;min-height:180px}
.leadership-panel .kicker{color:rgba(255,255,255,0.95)}
.leadership-panel .about-leaders .leader-mini .msg{color:rgba(255,255,255,0.95)}

/* Vision/Mission tiles inside About */
.vision-panel{background:var(--accent-2)}
.mission-panel{background:var(--secondary)}

/* Ensure Vision & Mission tiles are equal height */
.vision-row .col-md-6{display:flex}
.vision-panel,.mission-panel{display:flex;flex-direction:column}
.vision-panel .small,.mission-panel .small{flex:1}
/* also apply equal-height behavior when panels are inside the About card */
.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 for Admissions / Downloads / Contact */
.card-accent-1{background:var(--card-accent-1, var(--accent));box-shadow:0 12px 28px rgba(9,37,59,0.06)}
.card-accent-2{background:var(--card-accent-2, var(--accent-2));box-shadow:0 12px 28px rgba(9,37,59,0.06)}
.card-accent-3{background:var(--card-accent-3, #ff7b00);box-shadow:0 12px 28px rgba(9,37,59,0.06)}
.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.95)}
.card-accent-1 .btn-readmore,.card-accent-2 .btn-readmore,.card-accent-3 .btn-readmore{background:#fff;color:var(--primary)}
.card-accent-1 .btn-readmore:hover,.card-accent-2 .btn-readmore:hover,.card-accent-3 .btn-readmore:hover{opacity:0.95}

/* Color bar with clickable cards (Admissions / Downloads / Contact) */
.color-bar{margin-bottom:28px}
.color-bar .color-card{display:flex;flex-direction:column;align-items:center;justify-content:center;text-decoration:none;color:inherit;padding:22px 18px;height:140px}
.color-bar .color-card h5{color:#fff;margin:0;font-weight:800}
.color-bar .color-card p{color:rgba(255,255,255,0.95);margin:6px 0 0;font-size:.95rem}
.color-bar .color-card:focus,.color-bar .color-card:hover{transform:translateY(-4px);box-shadow:0 18px 40px rgba(9,37,59,0.12);text-decoration:none}

@media (max-width:768px){
  .color-bar .color-card{height:120px;padding:12px}
}

/* CTA button inside each color-card: make transparent so it doesn't show a white box;
  keep a subtle white border and white text for contrast on the colored card */
.color-bar .card-cta{background:transparent;color:#fff;padding:6px 12px;border-radius:8px;font-weight:700;text-decoration:none;display:inline-block;margin:10px 0 0;border:1px solid rgba(255,255,255,0.12);transition:all .18s ease}
.color-bar .card-cta:hover,.color-bar .card-cta:focus{opacity:1;background:rgba(255,255,255,0.12);border-color:rgba(255,255,255,0.22);transform:translateY(-2px)}

/* Slightly reduce color-card height so buttons sit visually aligned with slider */
.color-bar .color-card{height:128px}

@media (max-width:768px){
  .color-bar .color-card{height:110px}
}

/* Icons above title removed — hide any leftover icon elements if present */
.color-bar .color-icon{display:none}

/* Force all buttons to be small */
.btn, .btn-theme, .btn-cta, .btn-readmore {padding:6px 10px !important; font-size:.9rem !important}
.btn {height:auto}



/* Card-spot accent left border for more colour */
.card-spot.accent-left{border-left:6px solid var(--accent);padding-left:18px}

/* About layout: make left panel and right card equal height */
.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}
.about-grid .card-spot .about-details{flex:1}
/* compact leader snippets used in About left panel */
.about-leaders{margin-top:12px;display:flex;flex-direction:column;gap:10px}
.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)}


/* ensure full-bleed sections truly reach edges */
.container{max-width:100%;padding-left:0;padding-right:0}
.inner-container{max-width:1280px;margin-left:auto;margin-right:auto;padding-left:18px;padding-right:18px}

/* typographic scale */
h1{font-size:2.1rem;letter-spacing:-0.02em}
h2{font-size:1.6rem}
h3{font-size:1.2rem}
p.lead{font-size:1.05rem;color:rgba(255,255,255,0.92)}

/* Hero & CTA */
.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}
.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}

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

/* Global form improvements: nicer inputs, labels and spacing */
.form-label{font-weight:600;color:var(--primary);margin-bottom:6px}
.form-control{border-radius:10px;box-shadow:none;border:1px solid rgba(9,37,59,0.08)}
.form-control:focus{box-shadow:0 8px 28px 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.12);color:var(--primary)}

/* Responsive map embed container to keep iframes fluid */
.map-embed{position:relative;padding-top:56.25%;overflow:hidden;border-radius:8px}
.map-embed iframe, .map-embed > *{position:absolute;left:0;top:0;width:100%;height:100%;border:0}

/* Downloads table / cards: alternating color rows and clean layout */
.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}
.downloads-table td{padding:12px 16px;border-bottom:0}
.downloads-table tbody tr:nth-child(odd){background:rgba(0,0,0,0.02)}
.downloads-table tbody tr:nth-child(even){background:rgba(255,255,255,0.0)}
.downloads-table .file-link{display:block;color:var(--primary);font-weight:700}
.downloads-meta{font-size:.9rem;color:var(--muted);}

/* Card-style downloads list for small screens */
@media (max-width:768px){
  .downloads-card{border-radius:12px;padding:12px;margin-bottom:10px;background:linear-gradient(180deg, #fff, #fafafa);box-shadow:0 8px 20px rgba(9,37,59,0.03)}
}

/* cards and grids */
.card-hover{transition:transform .18s ease,box-shadow .18s ease}
.card-hover:hover{transform:translateY(-6px);box-shadow:0 30px 60px rgba(9,37,59,0.08)}

/* small utilities */
.muted {color:var(--muted-2)}
.kicker{font-size:.9rem;color:var(--muted-2);font-weight:600}

@media (max-width:768px){
  .site-navbar nav{display:none}
}

/* Announcement ticker */
.announcement-ticker{overflow:hidden;width:100%;position:relative}
.ticker-track{display:flex;gap:18px;align-items:stretch;padding:6px 0}
.ticker-card{min-width:320px;flex:0 0 auto;box-shadow:0 8px 24px rgba(9,37,59,0.06);border-radius:10px}
.ticker-card .card-body{padding:14px}
.ticker-track{animation:scrollTicker 22s linear infinite}
@keyframes scrollTicker{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* pause on hover for readability */
.announcement-ticker:hover .ticker-track{animation-play-state:paused}

/* reduce side padding at small widths */
@media (max-width:768px){
  .container{padding-left:8px;padding-right:8px}
  .ticker-card{min-width:240px}
}

/* Topper card styles */
.topper-card{display:flex;gap:18px;align-items:center;border-radius:12px;background:var(--surface);box-shadow:0 12px 30px rgba(9,37,59,0.04);padding:18px}
.topper-thumb img{width:160px;height:160px;object-fit:cover;border-radius:12px}
.topper-meta h5{margin:0;font-weight:800}

/* Topper + Gallery combined layout */
.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}

@media (min-width: 992px){
  .topper-gallery .gallery-panel .gallery-grid{grid-template-columns:repeat(3,1fr)}
}

@media (max-width:768px){
  .topper-thumb img{width:96px;height:96px}
  .gallery-panel .gallery-grid{grid-template-columns:repeat(2,1fr)}
}

/* Divider between topper and gallery on desktop */
@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 carousel styles (horizontal scroll) */
.topper-carousel{display:flex;overflow-x:auto;gap:12px;padding:8px 4px}
.topper-carousel{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:12px;background:var(--surface);box-shadow:0 10px 30px rgba(9,37,59,0.04);padding:16px;display:flex;flex-direction:column;align-items:center;justify-content:flex-start}
.topper-item{scroll-snap-align:center}
.topper-item img{border-radius:10px}

/* Give topper + gallery a slightly larger footprint */
.topper-gallery .topper-card, .topper-gallery .gallery-panel{min-height:220px}

@media (max-width:768px){
  .topper-gallery .topper-card, .topper-gallery .gallery-panel{min-height:160px}
}

/* Scroll buttons for topper carousel */
.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-scroll-btn:focus{outline:none;box-shadow:0 6px 18px rgba(0,0,0,0.2)}
/* Fading slideshow styles for topper groups */
.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 img{border-radius:10px}
.fade-slide[aria-hidden="true"]{opacity:0}
.fade-slide.show{opacity:1}

/* Gallery preview grid */
.gallery-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:12px}
.gallery-item img{width:100%;height:96px;object-fit:cover;border-radius:8px;display:block}
.gallery-item{display:block}

@media (max-width:768px){
  .topper-thumb img{width:96px;height:96px}
  .gallery-item img{height:72px}
}

/* Lightbox styles for gallery preview */
.lb-overlay{position:fixed;left:0;top:0;right:0;bottom:0;background:rgba(0,0,0,0.85);display:flex;align-items:center;justify-content:center;z-index:9999;padding:20px}
.lb-overlay img{max-width:100%;max-height:100%;border-radius:6px;box-shadow:0 12px 40px rgba(0,0,0,0.6)}
.lb-close{position:absolute;right:18px;top:18px;color:#fff;background:transparent;border:0;font-size:28px;cursor:pointer}

/* Lightbox prev/next and caption */
.lb-prev,.lb-next{position:absolute;top:50%;transform:translateY(-50%);background:rgba(0,0,0,0.4);border:0;color:#fff;width:48px;height:48px;border-radius:8px;display:flex;align-items:center;justify-content:center;cursor:pointer}
.lb-prev{left:18px}
.lb-next{right:18px}
.lb-caption{position:absolute;left:50%;transform:translateX(-50%);bottom:24px;color:#fff;max-width:90%;text-align:center;font-size:0.95rem}

/* Subtle repeating diagonal line background across the site. */
/* Uses a low-opacity tiled SVG so it doesn't compete with content. */

body{
  /* white page background with a denser multicolour decorative pattern */
  background-color: #ffffff !important;
  background-image: url('/assets/bg-lines.svg');
  /* tile both horizontally and vertically for full coverage */
  background-repeat: repeat;
  background-position: top center;
  background-size: 320px 160px; /* denser tiling for visible multicolour lines */
  background-attachment: local;
  background-blend-mode: normal;
}

/* Make sure large full-bleed elements still look solid: ensure they render above the tiled background. */
.brand-area, .site-navbar, .site-footer, .card-spot, .section-accent-panel, .topper-card, .feature-card, .gallery-panel{
  background-clip: padding-box;
}

/* Disable pointer events on the decorative background image (defensive) */
body::before{pointer-events:none}

/* Brand row action styling: small Apply button on the right of the brand area */
.brand-right .btn-theme{margin-left:8px}

/* Keep centered nav above background/hero but below any floating header actions */
.site-navbar .center-nav{z-index:2;position:absolute}

/* Extra safety to ensure the Apply button in brand row doesn't overlap the centered nav on medium screens */
@media (min-width: 768px){
  .brand-area{z-index:1055}
  .site-navbar{z-index:1050}
}
