/*!
 * Bootstrap 5.3 Grid + Essential Components (minified subset)
 * + NU Sambong Dukuh Custom Styles
 */

/* ===== BOOTSTRAP RESET & GRID ===== */
*,::after,::before{box-sizing:border-box}
html{font-size:16px;scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{margin:0;font-family:'Open Sans','Segoe UI',system-ui,sans-serif;font-size:1rem;font-weight:400;line-height:1.5;color:#212529;background-color:#fff;-webkit-tap-highlight-color:rgba(0,0,0,0);overflow-x:hidden}
h1,h2,h3,h4,h5,h6{margin-top:0;margin-bottom:.5rem;font-weight:700;line-height:1.2;font-family:'Poppins','Segoe UI',sans-serif;color:#1e293b}
p{margin-top:0;margin-bottom:1rem}
a{color:#00703C;text-decoration:none;transition:color .2s}
a:hover{color:#005a30}
img{max-width:100%;height:auto;vertical-align:middle}
ul{margin-top:0;margin-bottom:1rem;padding-left:2rem}
button{cursor:pointer}
input,button,select,textarea{margin:0;font-family:inherit;font-size:inherit;line-height:inherit;border-radius:0}
textarea{resize:vertical}
::selection{background:#00703C;color:#fff}
::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:#f1f5f9}::-webkit-scrollbar-thumb{background:#00703C;border-radius:3px}

/* Container */
.container{width:100%;padding-right:12px;padding-left:12px;margin-right:auto;margin-left:auto}
@media(min-width:576px){.container{max-width:540px}}
@media(min-width:768px){.container{max-width:720px}}
@media(min-width:992px){.container{max-width:960px}}
@media(min-width:1200px){.container{max-width:1140px}}
@media(min-width:1400px){.container{max-width:1320px}}
.container-fluid{width:100%;padding-right:12px;padding-left:12px;margin-right:auto;margin-left:auto}

/* Grid */
.row{display:flex;flex-wrap:wrap;margin-right:-12px;margin-left:-12px}
.col,.col-1,.col-2,.col-3,.col-4,.col-5,.col-6,.col-7,.col-8,.col-9,.col-10,.col-11,.col-12,
.col-sm-1,.col-sm-2,.col-sm-3,.col-sm-4,.col-sm-5,.col-sm-6,.col-sm-7,.col-sm-8,.col-sm-9,.col-sm-10,.col-sm-11,.col-sm-12,
.col-md-1,.col-md-2,.col-md-3,.col-md-4,.col-md-5,.col-md-6,.col-md-7,.col-md-8,.col-md-9,.col-md-10,.col-md-11,.col-md-12,
.col-lg-1,.col-lg-2,.col-lg-3,.col-lg-4,.col-lg-5,.col-lg-6,.col-lg-7,.col-lg-8,.col-lg-9,.col-lg-10,.col-lg-11,.col-lg-12,
.col-xl-1,.col-xl-2,.col-xl-3,.col-xl-4,.col-xl-5,.col-xl-6{position:relative;width:100%;padding-right:12px;padding-left:12px}
.col{flex:1 0 0%}.col-auto{flex:0 0 auto;width:auto}
.col-1{flex:0 0 auto;width:8.333333%}.col-2{flex:0 0 auto;width:16.666667%}
.col-3{flex:0 0 auto;width:25%}.col-4{flex:0 0 auto;width:33.333333%}
.col-5{flex:0 0 auto;width:41.666667%}.col-6{flex:0 0 auto;width:50%}
.col-7{flex:0 0 auto;width:58.333333%}.col-8{flex:0 0 auto;width:66.666667%}
.col-9{flex:0 0 auto;width:75%}.col-10{flex:0 0 auto;width:83.333333%}
.col-11{flex:0 0 auto;width:91.666667%}.col-12{flex:0 0 auto;width:100%}
@media(min-width:576px){
.col-sm-1{flex:0 0 auto;width:8.333333%}.col-sm-2{flex:0 0 auto;width:16.666667%}
.col-sm-3{flex:0 0 auto;width:25%}.col-sm-4{flex:0 0 auto;width:33.333333%}
.col-sm-5{flex:0 0 auto;width:41.666667%}.col-sm-6{flex:0 0 auto;width:50%}
.col-sm-7{flex:0 0 auto;width:58.333333%}.col-sm-8{flex:0 0 auto;width:66.666667%}
.col-sm-9{flex:0 0 auto;width:75%}.col-sm-10{flex:0 0 auto;width:83.333333%}
.col-sm-11{flex:0 0 auto;width:91.666667%}.col-sm-12{flex:0 0 auto;width:100%}}
@media(min-width:768px){
.col-md-1{flex:0 0 auto;width:8.333333%}.col-md-2{flex:0 0 auto;width:16.666667%}
.col-md-3{flex:0 0 auto;width:25%}.col-md-4{flex:0 0 auto;width:33.333333%}
.col-md-5{flex:0 0 auto;width:41.666667%}.col-md-6{flex:0 0 auto;width:50%}
.col-md-7{flex:0 0 auto;width:58.333333%}.col-md-8{flex:0 0 auto;width:66.666667%}
.col-md-9{flex:0 0 auto;width:75%}.col-md-10{flex:0 0 auto;width:83.333333%}
.col-md-11{flex:0 0 auto;width:91.666667%}.col-md-12{flex:0 0 auto;width:100%}}
@media(min-width:992px){
.col-lg-1{flex:0 0 auto;width:8.333333%}.col-lg-2{flex:0 0 auto;width:16.666667%}
.col-lg-3{flex:0 0 auto;width:25%}.col-lg-4{flex:0 0 auto;width:33.333333%}
.col-lg-5{flex:0 0 auto;width:41.666667%}.col-lg-6{flex:0 0 auto;width:50%}
.col-lg-7{flex:0 0 auto;width:58.333333%}.col-lg-8{flex:0 0 auto;width:66.666667%}
.col-lg-9{flex:0 0 auto;width:75%}.col-lg-10{flex:0 0 auto;width:83.333333%}
.col-lg-11{flex:0 0 auto;width:91.666667%}.col-lg-12{flex:0 0 auto;width:100%}}
@media(min-width:1200px){
.col-xl-1{flex:0 0 auto;width:8.333333%}.col-xl-2{flex:0 0 auto;width:16.666667%}
.col-xl-3{flex:0 0 auto;width:25%}.col-xl-4{flex:0 0 auto;width:33.333333%}
.col-xl-5{flex:0 0 auto;width:41.666667%}.col-xl-6{flex:0 0 auto;width:50%}
.col-xl-7{flex:0 0 auto;width:58.333333%}.col-xl-8{flex:0 0 auto;width:66.666667%}
.col-xl-9{flex:0 0 auto;width:75%}.col-xl-10{flex:0 0 auto;width:83.333333%}
.col-xl-11{flex:0 0 auto;width:91.666667%}.col-xl-12{flex:0 0 auto;width:100%}}

/* Gaps */
.g-0,.gx-0{--bs-gutter-x:0}.g-0,.gy-0{--bs-gutter-y:0}
.g-1,.gx-1{--bs-gutter-x:.25rem}.g-1,.gy-1{--bs-gutter-y:.25rem}
.g-2,.gx-2{--bs-gutter-x:.5rem}.g-2,.gy-2{--bs-gutter-y:.5rem}
.g-3,.gx-3{--bs-gutter-x:1rem}.g-3,.gy-3{--bs-gutter-y:1rem}
.g-4,.gx-4{--bs-gutter-x:1.5rem}.g-4,.gy-4{--bs-gutter-y:1.5rem}
.g-5,.gx-5{--bs-gutter-x:3rem}.g-5,.gy-5{--bs-gutter-y:3rem}
.row>*{padding-right:calc(var(--bs-gutter-x,.75rem)*.5);padding-left:calc(var(--bs-gutter-x,.75rem)*.5);margin-top:var(--bs-gutter-y,0)}

/* Display */
.d-none{display:none!important}.d-block{display:block!important}.d-flex{display:flex!important}
.d-inline{display:inline!important}.d-inline-block{display:inline-block!important}.d-inline-flex{display:inline-flex!important}
@media(min-width:768px){.d-md-block{display:block!important}.d-md-none{display:none!important}.d-md-flex{display:flex!important}}
@media(min-width:992px){.d-lg-block{display:block!important}.d-lg-none{display:none!important}.d-lg-flex{display:flex!important}}

/* Flex helpers */
.flex-wrap{flex-wrap:wrap!important}.flex-nowrap{flex-wrap:nowrap!important}
.flex-column{flex-direction:column!important}.flex-row{flex-direction:row!important}
.align-items-center{align-items:center!important}.align-items-start{align-items:flex-start!important}.align-items-end{align-items:flex-end!important}
.justify-content-center{justify-content:center!important}.justify-content-between{justify-content:space-between!important}
.justify-content-end{justify-content:flex-end!important}.justify-content-start{justify-content:flex-start!important}
.flex-1{flex:1}.flex-shrink-0{flex-shrink:0!important}

/* Spacing */
.m-0{margin:0!important}.m-1{margin:.25rem!important}.m-2{margin:.5rem!important}.m-3{margin:1rem!important}.m-4{margin:1.5rem!important}
.mt-0{margin-top:0!important}.mt-1{margin-top:.25rem!important}.mt-2{margin-top:.5rem!important}.mt-3{margin-top:1rem!important}.mt-4{margin-top:1.5rem!important}.mt-5{margin-top:3rem!important}
.mb-0{margin-bottom:0!important}.mb-1{margin-bottom:.25rem!important}.mb-2{margin-bottom:.5rem!important}.mb-3{margin-bottom:1rem!important}.mb-4{margin-bottom:1.5rem!important}.mb-5{margin-bottom:3rem!important}
.ms-0{margin-left:0!important}.ms-1{margin-left:.25rem!important}.ms-2{margin-left:.5rem!important}.ms-3{margin-left:1rem!important}.ms-auto{margin-left:auto!important}
.me-0{margin-right:0!important}.me-1{margin-right:.25rem!important}.me-2{margin-right:.5rem!important}.me-3{margin-right:1rem!important}.me-auto{margin-right:auto!important}
.mx-auto{margin-left:auto!important;margin-right:auto!important}
.p-0{padding:0!important}.p-1{padding:.25rem!important}.p-2{padding:.5rem!important}.p-3{padding:1rem!important}.p-4{padding:1.5rem!important}
.px-1{padding-left:.25rem!important;padding-right:.25rem!important}.px-2{padding-left:.5rem!important;padding-right:.5rem!important}
.px-3{padding-left:1rem!important;padding-right:1rem!important}.px-4{padding-left:1.5rem!important;padding-right:1.5rem!important}.px-5{padding-left:3rem!important;padding-right:3rem!important}
.py-1{padding-top:.25rem!important;padding-bottom:.25rem!important}.py-2{padding-top:.5rem!important;padding-bottom:.5rem!important}
.py-3{padding-top:1rem!important;padding-bottom:1rem!important}.py-4{padding-top:1.5rem!important;padding-bottom:1.5rem!important}.py-5{padding-top:3rem!important;padding-bottom:3rem!important}
.pt-1{padding-top:.25rem!important}.pt-2{padding-top:.5rem!important}.pt-3{padding-top:1rem!important}.pt-4{padding-top:1.5rem!important}
.pb-1{padding-bottom:.25rem!important}.pb-2{padding-bottom:.5rem!important}.pb-3{padding-bottom:1rem!important}.pb-4{padding-bottom:1.5rem!important}
.ps-1{padding-left:.25rem!important}.ps-2{padding-left:.5rem!important}.ps-3{padding-left:1rem!important}
.pe-1{padding-right:.25rem!important}.pe-2{padding-right:.5rem!important}.pe-3{padding-right:1rem!important}
.gap-1{gap:.25rem!important}.gap-2{gap:.5rem!important}.gap-3{gap:1rem!important}.gap-4{gap:1.5rem!important}.gap-5{gap:3rem!important}

/* Text */
.text-center{text-align:center!important}.text-end{text-align:right!important}.text-start{text-align:left!important}
@media(min-width:768px){.text-md-end{text-align:right!important}.text-md-start{text-align:left!important}}
.text-muted{color:#6c757d!important}.text-white{color:#fff!important}.text-primary{color:#00703C!important}
.text-decoration-none{text-decoration:none!important}
.fw-600{font-weight:600!important}.fw-700{font-weight:700!important}.fw-800{font-weight:800!important}
.fs-1{font-size:2.5rem!important}.fs-2{font-size:2rem!important}.fs-3{font-size:1.75rem!important}
.fs-4{font-size:1.5rem!important}.fs-5{font-size:1.25rem!important}.fs-6{font-size:1rem!important}
.small{font-size:.875em!important}
.h-100{height:100%!important}.w-100{width:100%!important}
.position-relative{position:relative!important}.position-absolute{position:absolute!important}

/* Bg colors */
.bg-white{background-color:#fff!important}.bg-light{background-color:#f8f9fa!important}
.bg-primary{background-color:#00703C!important}.bg-success{background-color:#198754!important}

/* Alert */
.alert{padding:.75rem 1rem;margin-bottom:1rem;border-radius:.5rem;border:1px solid transparent;position:relative}
.alert-success{background:#d1e7dd;border-color:#badbcc;color:#0a3622}
.alert-danger{background:#f8d7da;border-color:#f5c2c7;color:#58151c}
.alert-warning{background:#fff3cd;border-color:#ffecb5;color:#664d03}
.alert-dismissible{padding-right:3rem}
.btn-close{position:absolute;top:.5rem;right:.5rem;background:transparent;border:0;font-size:1.2rem;cursor:pointer;opacity:.6;line-height:1}
.btn-close::before{content:'×'}
.fade.show{opacity:1}

/* Form */
.form-control{display:block;width:100%;padding:.5rem .75rem;font-size:1rem;font-weight:400;line-height:1.5;color:#212529;background-color:#fff;background-clip:padding-box;border:1px solid #ced4da;border-radius:.5rem;transition:border-color .15s,box-shadow .15s;outline:0}
.form-control:focus{border-color:#00703C;box-shadow:0 0 0 .2rem rgba(0,112,60,.15)}
.form-label{margin-bottom:.3rem;font-weight:600;font-size:.875rem;color:#1e293b}
.form-select{display:block;width:100%;padding:.5rem 2.25rem .5rem .75rem;font-size:1rem;line-height:1.5;color:#212529;background-color:#fff;border:1px solid #ced4da;border-radius:.5rem;outline:0;appearance:none;background-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3e%3cpath fill='none' stroke='%23343a40' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='m2 5 6 6 6-6'/%3e%3c/svg%3e");background-repeat:no-repeat;background-position:right .75rem center;background-size:16px 12px}
.form-select:focus{border-color:#00703C;box-shadow:0 0 0 .2rem rgba(0,112,60,.15)}
.mb-3{margin-bottom:1rem!important}
.input-group{position:relative;display:flex;flex-wrap:wrap;align-items:stretch;width:100%}

/* Button */
.btn{display:inline-flex;align-items:center;justify-content:center;padding:.45rem 1rem;font-size:.9rem;font-weight:600;line-height:1.5;text-align:center;text-decoration:none;cursor:pointer;border:2px solid transparent;border-radius:.5rem;transition:all .2s;gap:5px;white-space:nowrap}
.btn:focus{outline:0;box-shadow:0 0 0 .2rem rgba(0,112,60,.25)}
.btn-primary{background:#00703C;border-color:#00703C;color:#fff}
.btn-primary:hover{background:#005a30;border-color:#005a30;color:#fff}
.btn-outline-primary{background:transparent;border-color:#00703C;color:#00703C}
.btn-outline-primary:hover{background:#00703C;color:#fff}
.btn-outline-success{background:transparent;border-color:#00703C;color:#00703C}
.btn-outline-success:hover{background:#00703C;color:#fff}
.btn-outline-secondary{background:transparent;border-color:#6c757d;color:#6c757d}
.btn-outline-secondary:hover{background:#6c757d;color:#fff}
.btn-outline-light{background:transparent;border-color:rgba(255,255,255,.6);color:#fff}
.btn-outline-light:hover{background:rgba(255,255,255,.15);color:#fff}
.btn-sm{padding:.25rem .6rem;font-size:.8rem}
.btn-lg{padding:.7rem 1.5rem;font-size:1.05rem}

/* Navbar (Bootstrap) */
.navbar{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;padding:.5rem 1rem}
.navbar-brand{margin-right:1rem;text-decoration:none}
.navbar-nav{display:flex;flex-direction:column;padding-left:0;margin-bottom:0;list-style:none}
.navbar-nav .nav-link{padding:.5rem .85rem;display:block}
.nav-item{}.nav-link{display:block;text-decoration:none}
.navbar-collapse{flex-basis:100%;flex-grow:1;align-items:center}
.navbar-expand-lg .navbar-collapse{display:flex!important;flex-basis:auto}
.navbar-expand-lg .navbar-nav{flex-direction:row}
.navbar-expand-lg .navbar-toggler{display:none}
@media(max-width:991.98px){
  .navbar-expand-lg>.container{flex-wrap:wrap}
  .navbar-expand-lg .navbar-collapse{flex-basis:100%}
  .navbar-expand-lg .navbar-nav{flex-direction:column;width:100%;padding:.5rem 0}
  .navbar-expand-lg .navbar-toggler{display:block}
  .collapse:not(.show){display:none}
}
.dropdown{position:relative}
.dropdown-menu{position:absolute;top:100%;left:0;z-index:1000;min-width:200px;padding:.3rem 0;background:#fff;border:1px solid rgba(0,0,0,.1);border-radius:.5rem;box-shadow:0 6px 20px rgba(0,0,0,.1);display:none}
.dropdown-menu.show{display:block}
.dropdown-item{display:block;width:100%;padding:.45rem 1rem;font-size:.88rem;color:#212529;text-decoration:none;background:0 0;border:0;transition:.15s}
.dropdown-item:hover{background:#e8f5ee;color:#00703C}

/* Table */
.table{width:100%;border-collapse:collapse;vertical-align:middle}
.table th,.table td{padding:.6rem .75rem;border-bottom:1px solid #e2e8f0;vertical-align:middle}
.table thead th{background:#f8fafc;font-weight:700;font-size:.82rem;color:#64748b;text-transform:uppercase;letter-spacing:.04em;border-bottom:2px solid #e2e8f0}
.table-responsive{overflow-x:auto}
.table-striped>tbody>tr:nth-of-type(odd)>*{background:#f8fafc}

/* Badge */
.badge{display:inline-block;padding:.3em .6em;font-size:.73em;font-weight:700;line-height:1;text-align:center;white-space:nowrap;vertical-align:baseline;border-radius:.375rem}
.bg-success{background:#198754!important;color:#fff}
.bg-danger{background:#dc3545!important;color:#fff}
.bg-warning{background:#ffc107!important;color:#000}
.bg-secondary{background:#6c757d!important;color:#fff}

/* Pagination */
.pagination{display:flex;list-style:none;padding-left:0;gap:4px}
.page-item.active .page-link{background:#00703C;border-color:#00703C;color:#fff}
.page-item.disabled .page-link{color:#adb5bd;pointer-events:none;background:#fff;border-color:#dee2e6}
.page-link{display:flex;align-items:center;justify-content:center;padding:.4rem .7rem;color:#00703C;text-decoration:none;background:#fff;border:1px solid #dee2e6;border-radius:.375rem;transition:.15s}
.page-link:hover{background:#e8f5ee;color:#005a30}

/* ===================================================================
   NU SAMBONG DUKUH — CUSTOM STYLES
   =================================================================== */
:root{
  --nu-green:#00703C;--nu-dk:#005a30;--nu-lt:#e8f5ee;--nu-gold:#f4c430;
  --font-h:'Poppins','Segoe UI',sans-serif;--font-b:'Open Sans','Segoe UI',sans-serif;
  --radius:12px;--shadow:0 4px 16px rgba(0,0,0,.08);--shadow-md:0 8px 24px rgba(0,0,0,.10);
}

/* TOPBAR */
.topbar{background:var(--nu-dk);color:rgba(255,255,255,.85);font-size:.82rem;padding:8px 0;border-bottom:1px solid rgba(255,255,255,.1)}
.topbar .container{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:6px}
.topbar-left{display:flex;align-items:center;gap:16px;flex-wrap:wrap}
.topbar-left span{color:rgba(255,255,255,.8);display:flex;align-items:center;gap:4px}
.topbar-right{display:flex;align-items:center;gap:8px}
.topbar-right a{color:rgba(255,255,255,.75);font-size:.95rem;transition:.2s}
.topbar-right a:hover{color:var(--nu-gold)}
.btn-topbar{background:rgba(255,255,255,.12);padding:3px 12px;border-radius:20px;font-size:.8rem!important;color:rgba(255,255,255,.9)!important;text-decoration:none;display:inline-flex;align-items:center;gap:4px}
.topbar-hijri{color:var(--nu-gold);font-weight:600;font-size:.78rem}

/* NAVBAR */
.navbar-main{background:#fff;border-bottom:3px solid var(--nu-green);box-shadow:0 2px 12px rgba(0,0,0,.06);position:sticky;top:0;z-index:999;padding:.6rem 0}
.navbar-logo{display:flex;align-items:center;gap:12px}
.logo-icon{width:48px;height:48px;flex-shrink:0;display:flex;align-items:center;justify-content:center}
.logo-text{display:flex;flex-direction:column;line-height:1.25}
.logo-name{font-family:var(--font-h);font-weight:800;font-size:.92rem;color:var(--nu-green)}
.logo-tagline{font-size:.6rem;font-weight:700;color:var(--nu-green);opacity:.7;text-transform:uppercase;letter-spacing:.05em}
.navbar-main .nav-link{color:#374151;font-weight:500;font-size:.88rem;padding:.45rem .8rem!important;border-radius:6px;transition:.2s}
.navbar-main .nav-link:hover,.navbar-main .nav-link.active{color:var(--nu-green);background:#e8f5ee}
.navbar-main .dropdown-menu{border:none;border-top:3px solid var(--nu-green);box-shadow:0 8px 24px rgba(0,0,0,.1);border-radius:0 0 12px 12px;padding:.3rem 0;margin-top:4px}
.navbar-main .dropdown-item{padding:.48rem 1.1rem;font-size:.86rem;color:#374151;display:flex;align-items:center;gap:6px}
.navbar-main .dropdown-item:hover{background:#e8f5ee;color:var(--nu-green)}
.navbar-toggler{border:none;background:none;padding:4px 6px;cursor:pointer}
.navbar-toggler:focus{outline:none}
.toggler-icon{display:block;width:22px;height:2.5px;background:var(--nu-green);margin:5px 0;border-radius:2px;transition:.3s}
.btn-ppdb{background:var(--nu-green);color:#fff!important;border:2px solid var(--nu-green);border-radius:8px;padding:.38rem 1rem;font-size:.84rem;font-weight:700;text-decoration:none;transition:.2s;display:inline-flex;align-items:center;gap:5px}
.btn-ppdb:hover{background:var(--nu-dk);border-color:var(--nu-dk);color:#fff!important;transform:translateY(-1px)}
.navbar-cta{margin-left:.5rem}
@media(max-width:991px){.navbar-cta{margin:.5rem 0}}

/* HERO */
.hero-section{position:relative;height:92vh;min-height:480px;max-height:820px;overflow:hidden;background:var(--nu-dk)}
.swiper,.hero-swiper{width:100%;height:100%}
.hero-slide{position:relative;width:100%;height:100%;background:linear-gradient(135deg,var(--nu-green),var(--nu-dk));display:flex;align-items:center}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(135deg,rgba(0,80,40,.78) 0%,rgba(0,40,20,.55) 100%);z-index:1}
.hero-content{position:relative;z-index:2;width:100%;padding:3rem 0}
.hero-text{max-width:680px}
.hero-badge{display:inline-flex;align-items:center;gap:6px;background:rgba(244,196,48,.15);border:1px solid rgba(244,196,48,.35);color:var(--nu-gold);padding:5px 16px;border-radius:30px;font-size:.78rem;font-weight:700;margin-bottom:1.2rem;letter-spacing:.05em}
.hero-title{font-family:var(--font-h);font-size:clamp(2rem,5vw,3.4rem);font-weight:800;color:#fff;line-height:1.15;margin-bottom:1rem}
.hero-title-accent{color:var(--nu-gold)}
.hero-subtitle{color:rgba(255,255,255,.85);font-size:1.05rem;max-width:540px;margin-bottom:1.5rem;line-height:1.7}
.hero-actions{display:flex;gap:12px;flex-wrap:wrap}
.btn-hero-primary{background:var(--nu-green);color:#fff;border:2px solid var(--nu-green);padding:.7rem 1.8rem;border-radius:8px;font-weight:700;font-size:.95rem;text-decoration:none;transition:.25s;display:inline-flex;align-items:center;gap:6px}
.btn-hero-primary:hover{background:var(--nu-dk);border-color:var(--nu-dk);color:#fff;transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,112,60,.3)}
.btn-hero-secondary{background:rgba(255,255,255,.1);color:#fff;border:2px solid rgba(255,255,255,.4);padding:.7rem 1.8rem;border-radius:8px;font-weight:600;font-size:.95rem;text-decoration:none;transition:.25s;backdrop-filter:blur(4px)}
.btn-hero-secondary:hover{background:rgba(255,255,255,.2);color:#fff}
.swiper-button-next,.swiper-button-prev{color:#fff!important}
.swiper-button-next::after,.swiper-button-prev::after{font-size:1.2rem!important;font-weight:bold}
.swiper-pagination-bullet{background:rgba(255,255,255,.5)!important;opacity:1!important;width:10px!important;height:10px!important}
.swiper-pagination-bullet-active{background:#fff!important;transform:scale(1.4)}

/* TICKER */
.announcement-ticker{background:var(--nu-dk);padding:10px 0;overflow:hidden}
.ticker-wrap{display:flex;align-items:center}
.ticker-label{background:var(--nu-gold);color:#333;font-weight:700;font-size:.78rem;padding:4px 14px;border-radius:4px;flex-shrink:0;display:flex;align-items:center;gap:5px;white-space:nowrap;margin-right:12px}
.ticker-content{flex:1;overflow:hidden}
.ticker-items{display:flex;gap:60px;white-space:nowrap;animation:tickerRoll 28s linear infinite}
.ticker-item{color:rgba(255,255,255,.9);font-size:.84rem;flex-shrink:0}
.ticker-more{color:var(--nu-gold);font-size:.78rem;font-weight:700;flex-shrink:0;white-space:nowrap;text-decoration:none;margin-left:12px;padding:2px 10px;border:1px solid rgba(244,196,48,.4);border-radius:4px}
@keyframes tickerRoll{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}

/* PRAYER */
.prayer-widget{background:linear-gradient(135deg,var(--nu-green),#1a8a5a);color:#fff;border-radius:var(--radius);padding:1.2rem 1.5rem;box-shadow:var(--shadow-md)}
.prayer-widget-title{font-family:var(--font-h);font-size:.95rem;font-weight:700;margin-bottom:.6rem;display:flex;align-items:center;gap:8px;border-bottom:1px solid rgba(255,255,255,.2);padding-bottom:.5rem}
.prayer-widget-title i{color:var(--nu-gold);font-size:1rem}
.prayer-date{font-size:.72rem;opacity:.7;display:flex;justify-content:space-between;margin-bottom:.5rem}
.prayer-time-row{display:flex;justify-content:space-between;flex-wrap:wrap;gap:4px}
.prayer-item{text-align:center;flex:1;min-width:55px;padding:5px 3px;border-radius:8px;transition:.2s}
.prayer-item.next-prayer{background:rgba(255,255,255,.18)}
.p-name{font-size:.63rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;opacity:.75;display:block}
.p-time{font-size:.9rem;font-weight:800;font-family:var(--font-h);color:var(--nu-gold);display:block;margin-top:2px}
.prayer-item.next-prayer .p-name{opacity:1;color:#fff}
.prayer-item.next-prayer .p-time{color:#fff}

/* QUICK ACCESS */
.quick-access{background:#fff;padding:2rem 0}
.quick-card{display:flex;flex-direction:column;align-items:center;gap:8px;background:#fff;border-radius:var(--radius);padding:1.2rem .8rem;border:1.5px solid #e2e8f0;text-decoration:none;color:#374151;transition:.25s;text-align:center;font-size:.82rem;font-weight:600}
.quick-card:hover{border-color:var(--nu-green);transform:translateY(-4px);box-shadow:var(--shadow-md);color:var(--nu-green)}
.quick-icon{width:52px;height:52px;border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:1.4rem;color:#fff}

/* STATS */
.stats-section{background:linear-gradient(135deg,var(--nu-green),#1a7a4a);padding:3rem 0;position:relative}
.stat-card{background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.2);border-radius:var(--radius);padding:1.5rem;text-align:center;color:#fff;transition:.25s;height:100%}
.stat-card:hover{background:rgba(255,255,255,.2);transform:translateY(-3px)}
.stat-icon{font-size:1.8rem;margin-bottom:.5rem;color:var(--nu-gold)}
.stat-number{font-family:var(--font-h);font-size:2rem;font-weight:800;color:#fff;line-height:1;margin-bottom:.2rem}
.stat-label{font-size:.82rem;color:rgba(255,255,255,.8)}

/* SAMBUTAN */
.section-sambutan{background:#f8fafc;padding:4rem 0}
.sambutan-image-wrap{position:relative;padding:20px}
.sambutan-image{border-radius:20px;overflow:hidden;box-shadow:0 16px 48px rgba(0,0,0,.12)}
.sambutan-image img{width:100%;display:block;object-fit:cover;max-height:400px}
.sambutan-badge{position:absolute;bottom:0;left:0;background:#fff;border-radius:0 12px 0 0;padding:12px 16px;box-shadow:0 4px 16px rgba(0,0,0,.1);display:flex;align-items:center;gap:10px}
.sambutan-badge i{font-size:1.6rem;color:var(--nu-green)}
.sambutan-badge strong{display:block;font-size:.75rem;color:#64748b}
.sambutan-badge span{font-size:.88rem;font-weight:700;color:#1e293b}
.sambutan-quote i{font-size:3.5rem;color:var(--nu-green);opacity:.12;line-height:1}
.sambutan-text{color:#475569;line-height:1.9;font-size:.95rem}
.section-tag{background:#e8f5ee;color:var(--nu-green);font-size:.7rem;font-weight:700;padding:4px 14px;border-radius:20px;display:inline-block;margin-bottom:.6rem;text-transform:uppercase;letter-spacing:.06em}
.section-title{font-family:var(--font-h);font-size:clamp(1.4rem,3vw,2rem);font-weight:800;color:#1e293b;margin-bottom:1rem}

/* NEWS */
.news-card{background:#fff;border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden;border:1px solid #e2e8f0;transition:.25s}
.news-card:hover{box-shadow:var(--shadow-md);transform:translateY(-4px)}
.news-img{position:relative;overflow:hidden;height:195px}
.news-img img{width:100%;height:100%;object-fit:cover;transition:.4s}
.news-card:hover .news-img img{transform:scale(1.06)}
.news-cat{position:absolute;top:10px;left:10px;background:var(--nu-green);color:#fff;font-size:.7rem;font-weight:700;padding:3px 10px;border-radius:20px}
.news-body{padding:1.2rem}
.news-meta{font-size:.73rem;color:#94a3b8;margin-bottom:.5rem;display:flex;align-items:center;gap:5px}
.news-title a{font-weight:700;color:#1e293b;font-size:.93rem;text-decoration:none;line-height:1.4;display:block}
.news-title a:hover{color:var(--nu-green)}
.news-excerpt{font-size:.82rem;color:#64748b;margin-bottom:.8rem;line-height:1.6}
.news-more{font-size:.82rem;font-weight:700;color:var(--nu-green);text-decoration:none;display:flex;align-items:center;gap:4px}
.news-more:hover{color:var(--nu-dk)}

/* BANOM */
.banom-card{background:#fff;border-radius:var(--radius);padding:1.4rem;text-align:center;box-shadow:var(--shadow);border:1.5px solid #e2e8f0;transition:.25s;height:100%;display:block;text-decoration:none;color:inherit}
.banom-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);border-color:var(--nu-green);color:inherit}
.banom-icon{width:60px;height:60px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.5rem;margin:0 auto 1rem}
.banom-card h5{font-size:.92rem;font-weight:700;color:var(--nu-green);margin-bottom:.25rem}
.banom-card p{font-size:.78rem;color:#64748b;margin:0}

/* PROGRAM ITEMS */
.program-item{display:flex;align-items:flex-start;gap:1rem;padding:1rem;background:#fff;border-radius:var(--radius);box-shadow:0 2px 8px rgba(0,0,0,.06);border-left:4px solid var(--nu-green);margin-bottom:.8rem;transition:.2s}
.program-item:hover{transform:translateX(4px);box-shadow:var(--shadow)}
.program-item-icon{width:42px;height:42px;background:#e8f5ee;border-radius:10px;display:flex;align-items:center;justify-content:center;color:var(--nu-green);font-size:1.2rem;flex-shrink:0}
.program-item-text h6{font-size:.88rem;font-weight:700;margin-bottom:.2rem;color:#1e293b}
.program-item-text p{font-size:.79rem;color:#64748b;margin:0;line-height:1.5}

/* PAGE BANNER */
.page-banner{background:linear-gradient(135deg,var(--nu-green),var(--nu-dk));padding:52px 0 44px;color:#fff;position:relative;overflow:hidden}
.page-banner::before{content:'';position:absolute;inset:0;background:url("data:image/svg+xml,%3Csvg width='40' height='40' viewBox='0 0 40 40' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='%23ffffff' fill-opacity='0.04'%3E%3Cpath d='M20 20h-4v-4h4v4zm0-12h-4v4h4V8zm12 12h-4v-4h4v4z'/%3E%3C/g%3E%3C/svg%3E")}
.page-banner-content{position:relative;z-index:2}
.page-banner-breadcrumb{display:flex;align-items:center;gap:8px;font-size:.8rem;margin-bottom:.6rem;color:rgba(255,255,255,.7)}
.page-banner-breadcrumb a{color:rgba(255,255,255,.85);text-decoration:none}
.page-banner-breadcrumb a:hover{color:#fff}
.page-banner-title{font-size:clamp(1.6rem,4vw,2.4rem);font-weight:800;margin:0 0 8px;color:#fff;font-family:var(--font-h)}
.page-banner-subtitle{font-size:.95rem;color:rgba(255,255,255,.8);margin:0}

/* FOOTER */
.footer{background:var(--nu-dk);color:rgba(255,255,255,.8)}
.footer-main{padding:52px 0 36px}
.footer-heading{font-family:var(--font-h);font-size:.88rem;font-weight:700;color:#fff;margin-bottom:.9rem;padding-bottom:.5rem;border-bottom:1px solid rgba(255,255,255,.12)}
.footer-links{list-style:none;padding:0;margin:0}
.footer-links li{margin-bottom:.4rem}
.footer-links a{color:rgba(255,255,255,.65);font-size:.83rem;text-decoration:none;transition:.2s;display:flex;align-items:center;gap:5px}
.footer-links a:hover{color:#fff;padding-left:4px}
.footer-tagline{color:rgba(255,255,255,.65);font-size:.83rem;margin-top:.5rem;line-height:1.6}
.footer-contact-info{margin-top:1rem}
.footer-contact-item{display:flex;align-items:flex-start;gap:8px;margin-bottom:.55rem;font-size:.82rem;color:rgba(255,255,255,.7);line-height:1.4}
.footer-contact-item i{color:var(--nu-gold);margin-top:2px;flex-shrink:0}
.footer-program-item{display:flex;align-items:center;gap:8px;margin-bottom:.5rem;font-size:.82rem;color:rgba(255,255,255,.75)}
.footer-social{display:flex;gap:8px;flex-wrap:wrap;margin-top:.8rem}
.footer-social a{width:34px;height:34px;background:rgba(255,255,255,.1);border-radius:8px;display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,.75);font-size:.95rem;text-decoration:none;transition:.2s}
.footer-social a:hover{background:var(--nu-green);color:#fff;transform:translateY(-2px)}
.footer-bottom{background:rgba(0,0,0,.25);padding:1rem 0;font-size:.82rem;color:rgba(255,255,255,.6)}
.footer-logo{display:flex;align-items:center;gap:10px;margin-bottom:.5rem}
.footer-logo span{font-weight:800;color:#fff;font-size:.95rem}

/* Kontak */
.form-control{border-radius:8px}

/* Section NU Banom (beranda) */
.section-nu-banom{background:#f9fdf9;padding:3rem 0;border-top:4px solid var(--nu-green)}

/* Responsive */
@media(max-width:991px){
  .hero-section{height:78vh;min-height:380px}
  .stats-section .row{flex-wrap:wrap}
}
@media(max-width:767px){
  .hero-section{height:68vh;min-height:340px}
  .hero-title{font-size:1.7rem}
  .footer-main{padding:36px 0 24px}
  .prayer-time-row{gap:2px}
  .p-time{font-size:.82rem}
}
@media(max-width:575px){
  .prayer-item{min-width:48px}
  .p-name{font-size:.58rem}
  .stat-number{font-size:1.6rem}
  .section-title{font-size:1.3rem}
}
