:root{
    --primary:#0b3d2e;
    --primary-dark:#06281d;
    --green:#2f9e44;
    --gold:#e0e94b;
    --light:#f3f3f3;
    --text:#1f2937;
}

*{box-sizing:border-box}

body{
    margin:0;
    font-family:Arial,Helvetica,sans-serif;
    background:var(--light);
    color:var(--text);
}

/* =========================
   GLOBAL / BASIC
========================= */
.bro-navbar{
    background:linear-gradient(90deg,#003b12,#0b3d2e);
    box-shadow:0 8px 16px rgba(0,0,0,.1);
}

.site-logo{
    width:46px;
    height:46px;
    border-radius:50%;
    object-fit:contain;
    background:#fff;
    padding:4px;
}

.brand-main{font-weight:700;line-height:1}
.brand-sub{color:#d7f1e0}

.hero{
    background:linear-gradient(rgba(6,40,29,.82),rgba(6,40,29,.82)),url('../images/hero-bg.jpg') center/cover no-repeat;
    color:#fff;
    padding:90px 0;
}

.hero-card{
    background:rgba(255,255,255,.08);
    backdrop-filter:blur(8px);
    padding:28px;
    border-radius:22px;
    border:1px solid rgba(255,255,255,.15);
}

.hero-title{
    font-size:2.6rem;
    font-weight:800;
    line-height:1.15;
}

.hero-subtitle{
    font-size:1.05rem;
    opacity:.95;
}

.card-soft,
.quick-card,
.news-card,
.service-card,
.download-card,
.info-card{
    background:#fff;
    border:none;
    border-radius:20px;
    box-shadow:0 10px 22px rgba(0,0,0,.07);
}

.section-title{
    font-weight:800;
    color:var(--primary);
    margin-bottom:18px;
}

.section-subtitle{color:#687280}

.icon-wrap{
    width:60px;
    height:60px;
    border-radius:18px;
    display:grid;
    place-items:center;
    background:rgba(11,61,46,.08);
    color:var(--primary);
    font-size:24px;
}

.stat-box{
    border-radius:18px;
    background:#fff;
    box-shadow:0 8px 18px rgba(0,0,0,.06);
    padding:24px;
    text-align:center;
}

.page-hero{
    background:linear-gradient(135deg,#0b3d2e,#145c47);
    color:#fff;
    padding:70px 0;
}

/* =========================
   CONTACT / PARTNERS / FOOTER BASE
========================= */
.contact-section,
.partners-section{
    padding:50px 0;
    background:#f3f3f3;
}

.section-ribbon{
    display:inline-block;
    background:#2f9e44;
    color:#fff;
    font-size:20px;
    font-weight:700;
    padding:14px 50px;
    margin-bottom:30px;
    position:relative;
}

.section-ribbon::after{
    content:"";
    display:inline-block;
    width:830px;
    max-width:calc(100vw - 260px);
    height:2px;
    background:#76c77a;
    vertical-align:middle;
    margin-left:20px;
}

.contact-grid{
    display:grid;
    grid-template-columns:1.3fr 1fr;
    gap:40px;
    align-items:start;
}

.map-box iframe{
    border-radius:4px;
    box-shadow:0 3px 10px rgba(0,0,0,.08);
}

.contact-item{
    display:flex;
    align-items:flex-start;
    gap:16px;
    margin-bottom:28px;
    color:#137333;
    font-size:16px;
    line-height:1.7;
}

.contact-item .icon{
    width:38px;
    height:38px;
    border-radius:50%;
    background:#67c66d;
    color:#fff;
    display:flex;
    align-items:center;
    justify-content:center;
    flex-shrink:0;
}

.partners-logos{
    display:grid;
    grid-template-columns:repeat(9,1fr);
    gap:30px;
    align-items:center;
    justify-items:center;
    padding:20px 0 40px;
    border-bottom:2px solid #666;
}

.partners-logos img{
    max-width:120px;
    max-height:90px;
    object-fit:contain;
}

.main-footer{
    background:linear-gradient(90deg,#002b0f,#003b12);
    color:#fff;
    margin-top:0;
}

.footer-col h4{
    color:#fff;
    margin-bottom:18px;
    font-size:26px;
    font-weight:700;
}

.footer-col p,
.footer-col li,
.footer-col a{
    color:#f1f1f1;
    text-decoration:none;
    line-height:1.9;
    font-size:15px;
}

.footer-col a:hover{color:#ffde59}

.footer-bottom{
    background:#d9ea3f;
    color:#111;
    text-align:center;
    padding:14px 10px;
    font-size:14px;
    font-weight:600;
}

/* =========================
   ADMIN
========================= */
.admin-shell{
    display:flex;
    min-height:100vh;
    background:#eef3f8;
}

.admin-sidebar{
    width:260px;
    background:#0c2f24;
    color:#fff;
    padding:20px;
}

.admin-sidebar a{
    color:#dfeee8;
    text-decoration:none;
    display:block;
    padding:12px 14px;
    border-radius:12px;
    margin-bottom:8px;
}

.admin-sidebar a:hover{
    background:rgba(255,255,255,.08);
    color:#fff;
}

.admin-main{
    flex:1;
    padding:24px;
}

.admin-topbar{
    background:#fff;
    border-radius:18px;
    box-shadow:0 8px 18px rgba(0,0,0,.06);
    padding:18px 22px;
    margin-bottom:20px;
}

.admin-card{
    background:#fff;
    border:none;
    border-radius:18px;
    box-shadow:0 8px 18px rgba(0,0,0,.06);
}

/* =========================
   TOP HEADER IMPROVED LAYOUT
========================= */
.bro-top-header{
    background:linear-gradient(90deg,#0a6500 0%,#045000 50%,#024300 100%);
    position:relative;
    overflow:hidden;
    border-top:4px solid #b6c53d;
}

.bro-top-header::after{
    content:"";
    position:absolute;
    top:0;
    right:14%;
    width:240px;
    height:100%;
    background:linear-gradient(135deg,rgba(228,190,31,.95),rgba(179,136,0,.95));
    clip-path:polygon(35% 0,100% 0,65% 100%,0 100%);
    opacity:.95;
    z-index:1;
}

.bro-top-inner{
    min-height:150px;
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:18px;
    position:relative;
    z-index:2;
    padding-top:14px;
    padding-bottom:14px;
}

.bro-brand-wrap{
    display:flex;
    align-items:center;
    gap:18px;
    min-width:0;
    flex:1 1 auto;
}

.bro-main-logo{
    width:120px;
    height:120px;
    object-fit:contain;
    flex-shrink:0;
}

.bro-brand-text{
    color:#fff;
    line-height:1.15;
    min-width:0;
}

.bro-region{
    font-size:17px;
    margin-bottom:6px;
    border-bottom:4px solid rgba(255,255,255,.8);
    padding-bottom:4px;
    width:fit-content;
    max-width:100%;
}

.bro-ministry{
    font-size:18px;
    font-weight:700;
    letter-spacing:.4px;
    margin-bottom:4px;
}

.bro-office{
    font-size:25px;
    font-weight:800;
    letter-spacing:2px;
}

.bro-header-right{
    display:flex;
    align-items:center;
    justify-content:flex-end;
    gap:18px;
    flex-shrink:0;
    min-width:0;
    margin-left:auto;
    position:relative;
    z-index:3;
}

.bro-header-icons{
    display:flex;
    align-items:center;
    gap:12px;
    flex-shrink:0;
}

.bro-header-icons img{
    width:78px;
    height:78px;
    object-fit:contain;
    background:rgba(255,255,255,.92);
    border-radius:50%;
    padding:8px;
    box-shadow:0 4px 10px rgba(0,0,0,.18);
}

/* =========================
   PST CLOCK
========================= */
.pst-clock-wrapper{
    display:flex;
    flex-direction:column;
    align-items:flex-start;
    justify-content:center;
    min-width:190px;
    max-width:220px;
}

.pst-title{
    color:#ffffff;
    font-size:11px;
    font-weight:700;
    margin-bottom:3px;
    line-height:1.2;
    letter-spacing:.3px;
    text-transform:uppercase;
    white-space:nowrap;
    text-shadow:0 1px 2px rgba(0,0,0,.28);
}

.clock{
    transform:scale(.42);
    transform-origin:left center;
    height:42px;
    display:flex;
    align-items:center;
    margin-left:-28px;
}

.flip-clock-wrapper{
    margin:0 !important;
    width:auto !important;
}

.flip-clock-wrapper ul{
    width:34px !important;
    height:52px !important;
    margin:2px !important;
}

.flip-clock-wrapper ul li{
    line-height:52px !important;
}

.flip-clock-wrapper ul li a div div.inn{
    font-size:34px !important;
    line-height:52px !important;
    background:#2c2c2c !important;
    color:#f2f2f2 !important;
    text-shadow:0 1px 2px rgba(0,0,0,.4);
    border-radius:6px !important;
}

.flip-clock-divider{
    width:14px !important;
    height:54px !important;
}

.flip-clock-dot{
    left:5px !important;
    width:6px !important;
    height:6px !important;
    background:#173d18 !important;
    box-shadow:none !important;
}

.flip-clock-divider .flip-clock-label{
    display:none !important;
}

.flip-clock-meridium{
    color:#ffffff !important;
    font-size:22px !important;
    font-weight:700 !important;
    text-shadow:0 1px 2px rgba(0,0,0,.28);
    margin-left:6px !important;
}

/* =========================
   FINAL GOV-STYLE NAVBAR
========================= */
.bro-navbar-main{
    background:linear-gradient(90deg,#052f1d 0%, #0a4a2d 55%, #0b3d2e 100%);
    border-bottom:1px solid rgba(255,255,255,.14);
    box-shadow:0 6px 14px rgba(0,0,0,.08);
    padding-top:0;
    padding-bottom:0;
    z-index:1030;
}

.bro-nav-list{
    gap:2px;
}

.bro-navbar-main .navbar-nav{
    align-items:stretch !important;
}

.bro-nav-link,
.bro-navbar-main .nav-link{
    position:relative;
    color:#ffffff !important;
    font-size:13px;
    font-weight:600;
    letter-spacing:.15px;
    padding:13px 14px !important;
    border-radius:4px;
    transition:all .22s ease;
    white-space:nowrap;
    text-transform:none;
}

.bro-nav-link::after,
.bro-navbar-main .nav-link::after{
    content:"";
    position:absolute;
    left:14px;
    right:14px;
    bottom:7px;
    height:2px;
    background:#d9ea3f;
    transform:scaleX(0);
    transform-origin:center;
    transition:transform .22s ease;
    border-radius:20px;
}

.bro-nav-link:hover,
.bro-navbar-main .nav-link:hover{
    background:rgba(255,255,255,.06);
    color:#fff !important;
}

.bro-nav-link:hover::after,
.bro-navbar-main .nav-link:hover::after{
    transform:scaleX(1);
}

.bro-nav-link.active,
.bro-navbar-main .nav-link.active{
    background:rgba(255,255,255,.09);
    color:#fff !important;
    font-weight:700;
}

.bro-nav-link.active::after,
.bro-navbar-main .nav-link.active::after{
    transform:scaleX(1);
    background:#ffd54a;
}

.bro-navbar-main .dropdown-toggle::after{
    margin-left:6px;
    vertical-align:middle;
    transition:transform .2s ease;
    font-size:12px;
}

.bro-hover-dropdown.show > .dropdown-toggle::after,
.bro-hover-dropdown:hover > .dropdown-toggle::after{
    transform:rotate(180deg);
}

.bro-dropdown{
    margin-top:0;
    min-width:250px;
    border:none;
    border-radius:0 0 10px 10px;
    padding:6px 0;
    background:#ffffff;
    box-shadow:0 10px 22px rgba(0,0,0,.12);
    overflow:hidden;
}

.bro-dropdown .dropdown-item{
    position:relative;
    padding:10px 16px 10px 18px;
    font-size:13px;
    font-weight:500;
    color:#344054;
    transition:all .2s ease;
    white-space:normal;
    line-height:1.45;
}

.bro-dropdown .dropdown-item::before{
    content:"";
    position:absolute;
    left:0;
    top:0;
    bottom:0;
    width:3px;
    background:#2ea43d;
    transform:scaleY(0);
    transition:transform .2s ease;
}

.bro-dropdown .dropdown-item:hover{
    background:#edf8ef;
    color:#0a6e2f;
    padding-left:22px;
}

.bro-dropdown .dropdown-item:hover::before{
    transform:scaleY(1);
}

.bro-search-form{
    position:relative;
    width:240px;
    max-width:100%;
}

.bro-search-form i{
    position:absolute;
    left:14px;
    top:50%;
    transform:translateY(-50%);
    color:#7b8794;
    font-size:14px;
}

.bro-search-input{
    width:100%;
    border:1px solid rgba(0,0,0,.08);
    background:#fff;
    height:40px;
    padding:0 14px 0 40px;
    outline:none;
    font-size:13px;
    border-radius:999px;
    transition:all .22s ease;
    box-shadow:0 4px 10px rgba(0,0,0,.05);
}

.bro-search-input:focus{
    border-color:#2ea43d;
    box-shadow:0 0 0 4px rgba(46,164,61,.10);
}

@media (min-width:992px){
    .bro-hover-dropdown{
        position:relative;
    }

    .bro-hover-dropdown .bro-dropdown{
        display:block;
        opacity:0;
        visibility:hidden;
        transform:translateY(8px);
        pointer-events:none;
        transition:opacity .22s ease, transform .22s ease, visibility .22s ease;
    }

    .bro-hover-dropdown:hover > .bro-dropdown,
    .bro-hover-dropdown:focus-within > .bro-dropdown,
    .bro-hover-dropdown.show > .bro-dropdown{
        opacity:1;
        visibility:visible;
        transform:translateY(0);
        pointer-events:auto;
    }
}

/* =========================
   HERO OVERRIDE
========================= */
.hero.bro-hero-section{
    background:#efefef !important;
    color:#1f2937 !important;
    padding:38px 0 52px !important;
    position:relative;
    overflow:hidden;
}

.hero.bro-hero-section .container{
    position:relative;
    z-index:2;
}

.bro-hero-wrap{
    display:grid;
    grid-template-columns:minmax(0, 2fr) minmax(280px, 1fr);
    gap:28px;
    align-items:start;
}

.bro-hero-left{min-width:0}

.bro-hero-banner{
    position:relative;
    min-height:390px;
    background:linear-gradient(180deg,#eef3d7 0%, #e5eed4 40%, #d9e7d5 100%);
    border-radius:2px;
    overflow:hidden;
    box-shadow:0 10px 24px rgba(0,0,0,.08);
    padding:28px 26px 20px;
}

.bro-hero-text{
    position:relative;
    z-index:5;
    text-align:center;
}

.bro-hero-big{
    margin:0;
    font-size:5.1rem;
    font-weight:900;
    line-height:.92;
    letter-spacing:1px;
    color:#156b2e;
    text-transform:uppercase;
}

.bro-hero-small{
    margin:8px 0 0;
    font-size:1.2rem;
    line-height:1.15;
    font-weight:900;
    letter-spacing:.6px;
    color:#23a447;
    text-transform:uppercase;
}

.bro-hero-device{
    position:relative;
    z-index:5;
    display:flex;
    justify-content:center;
    align-items:center;
    margin-top:18px;
}

.bro-hero-device img{
    width:min(100%, 430px);
    max-width:100%;
    height:auto;
    display:block;
    object-fit:contain;
    filter:drop-shadow(0 8px 14px rgba(0,0,0,.24));
}

.bro-hero-banner::before{
    content:"";
    position:absolute;
    left:-110px;
    bottom:-90px;
    width:470px;
    height:220px;
    background:rgba(58, 154, 84, .28);
    border-radius:58% 42% 0 0;
    transform:rotate(-9deg);
    z-index:1;
}

.bro-hero-banner::after{
    content:"";
    position:absolute;
    left:0;
    right:0;
    bottom:0;
    height:88px;
    background:linear-gradient(180deg, rgba(255,255,255,0) 0%, rgba(207,224,204,.62) 100%);
    z-index:2;
}

.bro-hero-curve{
    position:absolute;
    right:-18px;
    top:92px;
    width:210px;
    height:255px;
    border:7px solid rgba(53, 158, 78, .72);
    border-left:none;
    border-bottom:none;
    border-radius:0 170px 0 0;
    transform:rotate(18deg);
    z-index:3;
    opacity:.9;
}

.bro-hero-arrow{
    position:absolute;
    top:86px;
    right:16px;
    z-index:4;
    color:#1d7b37;
    font-size:48px;
    transform:rotate(-8deg);
    line-height:1;
}

.bro-hero-dots{
    display:flex;
    justify-content:center;
    gap:10px;
    padding-top:10px;
}

.bro-hero-dots span{
    width:8px;
    height:8px;
    border-radius:50%;
    background:#cfcfcf;
    display:inline-block;
}

.bro-hero-dots span.active{
    background:#1f8f36;
}

.bro-hero-right{
    padding:18px 10px 8px;
    min-height:390px;
    display:flex;
    flex-direction:column;
    justify-content:flex-start;
}

.bro-mandate-title{
    margin:0 0 14px;
    color:#00712d;
    font-size:2rem;
    font-weight:800;
    line-height:1.1;
}

.bro-mandate-logo{
    margin-bottom:18px;
}

.bro-mandate-logo img{
    width:100px;
    max-width:100%;
    height:auto;
    object-fit:contain;
    display:block;
}

.bro-mandate-text{
    margin:0;
    color:#806d61;
    font-size:1rem;
    line-height:1.9;
    text-align:justify;
}

.hero.bro-hero-section .hero-card{
    background:transparent !important;
    backdrop-filter:none !important;
    border:none !important;
    box-shadow:none !important;
    padding:0 !important;
    border-radius:0 !important;
}

.hero.bro-hero-section .hero-title,
.hero.bro-hero-section .hero-subtitle{
    margin:0 !important;
    color:inherit !important;
}

/* =========================
   LATEST NEWS + RIGHT CORNER
========================= */
.bro-news-section{
    background:#efefef;
    padding-top:60px;
    padding-bottom:60px;
}

.bro-news-layout{
    display:grid;
    grid-template-columns:minmax(0, 2.1fr) 360px;
    gap:38px;
    align-items:start;
}

.bro-news-left{min-width:0}

.bro-news-heading-wrap{
    margin-bottom:34px;
    text-align:left;
}

.bro-news-heading{
    display:inline-block;
    margin:0;
    background:#2ea43d;
    color:#fff;
    font-size:1.8rem;
    font-weight:800;
    line-height:1.2;
    padding:14px 28px;
    border-radius:2px;
    box-shadow:0 8px 18px rgba(0,0,0,.08);
}

.bro-news-grid{
    display:grid;
    grid-template-columns:repeat(3, minmax(0, 1fr));
    gap:28px;
}

.bro-news-item{
    background:transparent;
    display:flex;
    flex-direction:column;
    height:100%;
}

.bro-news-thumb-link{text-decoration:none}

.bro-news-thumb{
    position:relative;
    overflow:hidden;
    background:#ddd;
    border-radius:2px;
    box-shadow:0 6px 16px rgba(0,0,0,.08);
}

.bro-news-thumb img{
    width:100%;
    height:180px;
    object-fit:cover;
    display:block;
    transition:transform .35s ease;
}

.bro-news-item:hover .bro-news-thumb img{
    transform:scale(1.04);
}

.bro-news-badge{
    position:absolute;
    left:10px;
    top:10px;
    display:inline-block;
    background:rgba(10,95,28,.92);
    color:#fff;
    font-size:.76rem;
    font-weight:700;
    padding:6px 10px;
    border-radius:30px;
    letter-spacing:.3px;
}

.bro-news-body{
    padding-top:16px;
}

.bro-news-title{
    margin:0 0 10px;
    font-size:1.1rem;
    line-height:1.45;
    font-weight:800;
}

.bro-news-title a{
    color:#475569;
    text-decoration:none;
    transition:.2s ease;
}

.bro-news-title a:hover{
    color:#0b6b2d;
}

.bro-news-meta{
    display:flex;
    flex-wrap:wrap;
    gap:12px;
    margin-bottom:12px;
    color:#8a8f96;
    font-size:.93rem;
}

.bro-news-meta i{
    margin-right:6px;
    color:#3d9b43;
}

.bro-news-summary{
    margin:0 0 14px;
    color:#5f6670;
    font-size:.98rem;
    line-height:1.7;
}

.bro-news-readmore{
    display:inline-block;
    color:#0c6f22;
    font-weight:700;
    text-decoration:none;
    font-size:.96rem;
}

.bro-news-readmore:hover{
    color:#084c18;
    text-decoration:underline;
}

.bro-news-more-wrap{
    text-align:center;
    margin-top:20px;
}

.bro-news-more-btn{
    background:#2EA43D;
    color:#fff;
    padding:10px 22px;
    border-radius:6px;
    text-decoration:none;
    font-weight:600;
    display:inline-block;
    transition:all .2s ease;
}

.bro-news-more-btn:hover{
    background:#FFC107;
    color:#fff;
}

.bro-corner-right{
    display:flex;
    flex-direction:column;
    gap:8px;
}

.bro-corner-card{
    display:block;
    overflow:hidden;
    border-radius:2px;
    box-shadow:0 6px 16px rgba(0,0,0,.08);
    transition:transform .2s ease, box-shadow .2s ease;
    background:#fff;
}

.bro-corner-card:hover{
    transform:translateY(-2px);
    box-shadow:0 10px 20px rgba(0,0,0,.12);
}

.bro-corner-card img{
    display:block;
    width:100%;
    height:auto;
    object-fit:cover;
}

.announcement-card-image{
    width:100%;
    height:260px;
    overflow:hidden;
    background:#e9ecef;
}

.announcement-card-image img{
    width:100%;
    height:100%;
    object-fit:cover;
    display:block;
    transition:transform .35s ease;
}

.news-card:hover .announcement-card-image img{
    transform:scale(1.04);
}

/* =========================
   PARTNERS LOGO SLIDER
========================= */
.partners-slider{
    width:100%;
    overflow:hidden;
    position:relative;
    margin-top:20px;
}

.partners-track{
    display:flex;
    align-items:center;
    gap:60px;
    width:max-content;
    animation:partnersScroll 40s linear infinite;
}

.partners-track img{
    height:80px;
    width:auto;
    object-fit:contain;
    transition:transform .3s ease;
}

.partners-track img:hover{
    transform:scale(1.1);
}

@keyframes partnersScroll{
    0%{transform:translateX(0)}
    100%{transform:translateX(-50%)}
}

/* =========================
   FOOTER FLAT STRUCTURE
========================= */
.footer-grid{
    display:grid;
    grid-template-columns:1.4fr 1fr 1fr 1fr;
    gap:40px;
    padding:55px 0;
}

.footer-col{
    background:none;
    border:none;
    box-shadow:none;
}

.footer-logo-row{
    display:flex;
    align-items:center;
    gap:16px;
    margin-bottom:16px;
}

.footer-logo{
    width:100px;
    height:100px;
    object-fit:contain;
}

.footer-brand-info p{
    margin:0 0 8px;
}

.footer-col ul{
    list-style:none;
    padding:0;
    margin:0;
}

.footer-col ul li{
    margin-bottom:6px;
}

.footer-col ul li a{
    color:#f1f1f1;
    text-decoration:none;
    font-size:15px;
    transition:.2s;
}

.footer-col ul li a:hover{
    color:#ffde59;
}

/* =========================
   RESPONSIVE
========================= */
@media (max-width:1399.98px){
    .bro-top-header::after{
        right:18%;
        width:180px;
    }

    .bro-main-logo{
        width:105px;
        height:105px;
    }

    .bro-region{font-size:15px}
    .bro-ministry{font-size:16px}
    .bro-office{
        font-size:22px;
        letter-spacing:1.3px;
    }

    .bro-header-icons img{
        width:68px;
        height:68px;
    }

    .pst-clock-wrapper{
        min-width:170px;
        max-width:190px;
    }

    .clock{
        transform:scale(.37);
        margin-left:-34px;
    }
}

@media (max-width:1199.98px){
    .bro-top-inner{gap:14px}

    .bro-main-logo{
        width:95px;
        height:95px;
    }

    .bro-region{font-size:14px}
    .bro-ministry{font-size:15px}
    .bro-office{font-size:20px}

    .bro-header-right{gap:12px}

    .bro-header-icons img{
        width:60px;
        height:60px;
        padding:7px;
    }

    .pst-clock-wrapper{
        min-width:150px;
        max-width:170px;
    }

    .pst-title{font-size:10px}

    .clock{
        transform:scale(.33);
        margin-left:-38px;
        height:36px;
    }

    .bro-news-layout{
        grid-template-columns:1fr 320px;
        gap:28px;
    }

    .bro-news-grid{
        grid-template-columns:repeat(2, minmax(0, 1fr));
    }
}

@media (min-width:1200px){
    .bro-hero-wrap{gap:34px}
    .bro-hero-banner{min-height:390px}
    .bro-hero-big{font-size:5.5rem}
    .bro-hero-small{font-size:1.28rem}
}

@media (max-width:992px){
    .hero-title{font-size:2.1rem}
    .contact-grid{grid-template-columns:1fr}
    .partners-logos{grid-template-columns:repeat(3,1fr)}
    .section-ribbon::after{display:none}
    .admin-shell{display:block}
    .admin-sidebar{width:100%}

    .footer-grid{
        grid-template-columns:1fr 1fr;
        gap:30px;
    }

    .footer-logo{
        width:90px;
        height:90px;
    }

    .partners-track{
        gap:40px;
        animation:partnersScroll 30s linear infinite;
    }

    .partners-track img{height:70px}
}

@media (max-width:991.98px){
    .bro-top-header::after{display:none}

    .bro-top-inner{
        flex-direction:column;
        align-items:flex-start;
        gap:12px;
        min-height:auto;
    }

    .bro-brand-wrap{width:100%}

    .bro-header-right{
        width:100%;
        justify-content:space-between;
        gap:14px;
        flex-wrap:wrap;
    }

    .bro-header-icons{order:1}

    .pst-clock-wrapper{
        order:2;
        min-width:auto;
        max-width:none;
        align-items:flex-start;
    }

    .clock{
        transform:scale(.34);
        margin-left:-36px;
    }

    .bro-navbar-main .navbar-collapse{
        background:#073a23;
        margin-top:10px;
        border-radius:12px;
        padding:10px;
        box-shadow:0 10px 18px rgba(0,0,0,.10);
    }

    .bro-nav-link,
    .bro-navbar-main .nav-link{
        font-size:13px;
        font-weight:600;
        padding:11px 12px !important;
        border-radius:8px;
    }

    .bro-nav-link::after,
    .bro-navbar-main .nav-link::after{
        display:none;
    }

    .bro-dropdown{
        min-width:100%;
        margin-top:4px;
        border-radius:10px;
        box-shadow:none;
        padding:6px 0;
    }

    .bro-dropdown .dropdown-item{
        font-size:13px;
        padding:10px 14px 10px 16px;
    }

    .bro-search-form{
        width:100%;
        margin-top:10px;
    }

    .bro-search-input{
        height:38px;
        font-size:13px;
    }

    .hero.bro-hero-section{
        padding:30px 0 44px !important;
    }

    .bro-hero-wrap{
        grid-template-columns:1fr;
        gap:18px;
    }

    .bro-hero-right{
        min-height:auto;
        padding:10px 0 0;
    }

    .bro-hero-banner{
        min-height:auto;
        padding:26px 22px 18px;
    }

    .bro-hero-big{font-size:3.5rem}
    .bro-hero-small{font-size:1.05rem}

    .bro-hero-curve{
        width:165px;
        height:210px;
        top:102px;
        right:-18px;
    }

    .bro-hero-arrow{
        font-size:38px;
        top:92px;
        right:12px;
    }

    .bro-mandate-title{font-size:1.7rem}

    .bro-mandate-logo img{width:95px}

    .bro-mandate-text{
        font-size:1rem;
        line-height:1.75;
    }

    .bro-news-layout{
        grid-template-columns:1fr;
    }

    .bro-news-grid{
        grid-template-columns:repeat(2, minmax(0, 1fr));
    }

    .bro-corner-right{
        margin-top:10px;
        display:grid;
        grid-template-columns:repeat(2, minmax(0, 1fr));
        gap:12px;
    }
}

@media (max-width:768px){
    .footer-grid{
        grid-template-columns:1fr;
        text-align:center;
        gap:28px;
    }

    .footer-brand{
        align-items:center;
    }

    .footer-logo-row{
        justify-content:center;
    }

    .footer-logo{
        width:85px;
        height:85px;
    }

    .social-icons{
        justify-content:center;
    }

    .footer-col h4{
        text-align:center;
        margin-top:10px;
    }

    .footer-col ul li{
        text-align:center;
    }
}

@media (max-width:767.98px){
    .bro-top-inner{
        padding-top:12px;
        padding-bottom:12px;
    }

    .bro-brand-wrap{
        align-items:flex-start;
        gap:12px;
    }

    .bro-main-logo{
        width:72px;
        height:72px;
    }

    .bro-region{
        font-size:12px;
        border-bottom:2px solid rgba(255,255,255,.8);
        margin-bottom:4px;
        padding-bottom:3px;
    }

    .bro-ministry{
        font-size:13px;
        margin-bottom:3px;
    }

    .bro-office{
        font-size:17px;
        letter-spacing:.8px;
    }

    .bro-header-right{
        width:100%;
        justify-content:space-between;
        align-items:center;
    }

    .bro-header-icons img{
        width:46px;
        height:46px;
        padding:5px;
    }

    .pst-title{
        font-size:9px;
        margin-bottom:1px;
    }

    .clock{
        transform:scale(.26);
        margin-left:-52px;
        height:28px;
    }

    .bro-news-heading{
        font-size:1.35rem;
        padding:12px 20px;
    }

    .bro-news-grid{
        grid-template-columns:1fr;
        gap:24px;
    }

    .bro-news-thumb img{
        height:210px;
    }

    .bro-corner-right{
        grid-template-columns:1fr;
    }

    .bro-top-header{
        padding:0;
    }

    .bro-top-header::after{
        display:none !important;
    }

    .bro-top-inner{
        min-height:auto;
        display:flex;
        flex-direction:column;
        align-items:center;
        justify-content:center;
        gap:12px;
        padding:22px 16px 26px;
        text-align:center;
    }

    .bro-brand-wrap{
        width:100%;
        display:flex;
        flex-direction:column;
        align-items:center;
        justify-content:center;
        gap:14px;
    }

    .bro-main-logo{
        width:150px;
        height:150px;
        max-width:100%;
        object-fit:contain;
        margin:0 auto;
    }

    .bro-brand-text{
        width:100%;
        display:flex;
        flex-direction:column;
        align-items:center;
        justify-content:center;
        text-align:center;
        line-height:1.25;
    }

    .bro-region{
        width:100%;
        max-width:390px;
        margin:0 auto 8px;
        font-size:14px;
        font-weight:500;
        line-height:1.35;
        border-bottom:3px solid rgba(255,255,255,.85);
        padding-bottom:8px;
        text-align:center;
    }

    .bro-ministry{
        font-size:13px;
        font-weight:800;
        line-height:1.35;
        margin-bottom:0;
        letter-spacing:0;
        text-align:center;
    }

    .bro-header-right{
        display:none !important;
    }

    .bro-navbar-main{
        padding:0;
    }

    .bro-navbar-main .container{
        padding-left:12px;
        padding-right:12px;
    }

    .navbar-toggler{
        padding:10px 8px;
        font-size:22px;
    }

    .bro-search-form{
        width:100%;
        margin-top:12px;
    }

    .bro-search-input{
        height:40px;
        font-size:14px;
    }

    .bro-navbar-main .nav-link{
        font-size:13px;
        padding:11px 12px !important;
    }

    .bro-dropdown{
        border-radius:10px;
        margin-top:4px;
    }
}

@media (max-width:576px){
    .partners-logos{grid-template-columns:repeat(2,1fr)}

    .partners-track{
        gap:28px;
        animation:partnersScroll 20s linear infinite;
    }

    .partners-track img{height:60px}
}

@media (max-width:575.98px){
    .hero.bro-hero-section{
        padding:24px 0 36px !important;
    }

    .bro-hero-banner{
        padding:20px 16px 16px;
        min-height:auto;
    }

    .bro-hero-big{
        font-size:2.35rem;
        line-height:1;
    }

    .bro-hero-small{
        font-size:.92rem;
        line-height:1.2;
    }

    .bro-hero-device{
        margin-top:14px;
    }

    .bro-hero-device img{
        width:min(100%, 300px);
    }

    .bro-hero-banner::before{
        width:300px;
        height:150px;
        left:-65px;
        bottom:-52px;
    }

    .bro-hero-curve{
        width:110px;
        height:145px;
        border-width:5px;
        top:95px;
        right:-14px;
    }

    .bro-hero-arrow{
        font-size:28px;
        top:84px;
        right:10px;
    }

    .bro-mandate-title{
        font-size:1.45rem;
        margin-bottom:10px;
    }

    .bro-mandate-logo{
        margin-bottom:12px;
    }

    .bro-mandate-logo img{
        width:78px;
    }

    .bro-mandate-text{
        font-size:.95rem;
        line-height:1.7;
    }

    .bro-hero-dots{
        padding-top:8px;
    }

    .bro-header-right{
        flex-direction:column;
        align-items:flex-start;
        gap:8px;
    }

    .bro-header-icons{
        gap:8px;
    }

    .bro-header-icons img{
        width:42px;
        height:42px;
    }

    .pst-clock-wrapper{
        width:100%;
    }

    .clock{
        transform:scale(.24);
        margin-left:-58px;
        height:24px;
    }
}

@media (max-width:480px){
    .footer-logo{
        width:72px;
        height:72px;
    }

    .footer-col ul li a{
        font-size:14px;
    }

    .footer-bottom{
        font-size:13px;
    }
}
/* =========================================================
   BRO HERO SLIDER - WHITE VERSION
========================================================= */
.bro-hero-slider{
    position:relative;
    overflow:hidden;
    background:
        radial-gradient(circle at top right, rgba(15, 99, 34, 0.08), transparent 28%),
        radial-gradient(circle at bottom left, rgba(255, 193, 7, 0.08), transparent 25%),
        linear-gradient(135deg, #ffffff 0%, #f8faf8 35%, #f3f8f3 65%, #ffffff 100%);
    padding: 60px 0 50px;
    min-height: 100vh;
    display:flex;
    align-items:center;
}

.bro-hero-slider::before{
    content:"";
    position:absolute;
    inset:0;
    background:
        linear-gradient(120deg, rgba(11,61,46,.03) 0%, transparent 20%, rgba(11,61,46,.02) 40%, transparent 60%, rgba(11,61,46,.03) 100%);
    animation: heroShine 12s linear infinite;
    pointer-events:none;
}

.bro-hero-container{
    position:relative;
    z-index:2;
}

.bro-hero-content{
    display:grid;
    grid-template-columns: 1.2fr .9fr;
    gap:40px;
    align-items:center;
}

.bro-hero-textbox{
    color:#0b3d2e;
    animation: fadeUpHero 1s ease;
}

.bro-hero-tag{
    display:inline-block;
    background:rgba(11,61,46,.06);
    color:#0b3d2e;
    border:1px solid rgba(11,61,46,.12);
    padding:10px 18px;
    border-radius:999px;
    font-size:14px;
    font-weight:600;
    letter-spacing:.8px;
    margin-bottom:22px;
    backdrop-filter: blur(8px);
}

.bro-hero-title-main{
    margin:0;
    font-size:clamp(48px, 8vw, 118px);
    line-height:.9;
    font-weight:900;
    letter-spacing:4px;
    text-transform:uppercase;
    color:#0b3d2e;
    text-shadow:0 8px 18px rgba(0,0,0,.08);
}

.bro-hero-title-sub{
    margin:10px 0 0;
    font-size:clamp(28px, 4vw, 72px);
    line-height:1;
    font-weight:800;
    letter-spacing:6px;
    text-transform:uppercase;
    color:#14532d;
}

.bro-hero-under{
    margin:22px 0 0;
    max-width:780px;
    font-size:clamp(14px, 1.5vw, 25px);
    font-weight:700;
    letter-spacing:1.6px;
    line-height:1.6;
    color:#2f4f3a;
    text-transform:uppercase;
}

.bro-hero-buttons{
    display:flex;
    flex-wrap:wrap;
    gap:14px;
    margin-top:30px;
}

.bro-btn{
    text-decoration:none;
    padding:14px 24px;
    border-radius:14px;
    font-weight:700;
    transition:.3s ease;
    display:inline-flex;
    align-items:center;
    justify-content:center;
    min-width:180px;
}

.bro-btn-primary{
    background:#0b3d2e;
    color:#fff;
    box-shadow:0 10px 25px rgba(0,0,0,.10);
}

.bro-btn-primary:hover{
    transform:translateY(-3px);
    color:#fff;
}

.bro-btn-outline{
    border:2px solid rgba(11,61,46,.25);
    color:#0b3d2e;
    background:rgba(11,61,46,.03);
    backdrop-filter: blur(6px);
}

.bro-btn-outline:hover{
    background:#0b3d2e;
    color:#fff;
    transform:translateY(-3px);
}

.bro-hero-logo-area{
    position:relative;
    display:flex;
    flex-direction:column;
    align-items:center;
    justify-content:center;
    animation: fadeUpHero 1.2s ease;
}

.bro-logo-slider{
    position:relative;
    width:100%;
    max-width:620px;
    min-height:520px;
    display:flex;
    align-items:center;
    justify-content:center;
}

.bro-logo-slide{
    position:absolute;
    inset:0;
    opacity:0;
    transform:scale(.96);
    transition:opacity 1s ease, transform 1s ease;
    display:flex;
    align-items:center;
    justify-content:center;
}

.bro-logo-slide.active{
    opacity:1;
    transform:scale(1);
}

.bro-logo-slide img{
    max-width:100%;
    max-height:520px;
    object-fit:contain;
    filter:drop-shadow(0 18px 35px rgba(0,0,0,.12));
    animation: floatLogo 4s ease-in-out infinite;
}

.bro-slider-dots{
    display:flex;
    justify-content:center;
    gap:10px;
    margin-top:18px;
}

.bro-slider-dots button{
    width:14px;
    height:14px;
    border:none;
    outline:none;
    border-radius:50%;
    background:rgba(11,61,46,.25);
    cursor:pointer;
    transition:.3s ease;
}

.bro-slider-dots button.active{
    background:#0b3d2e;
    transform:scale(1.2);
    box-shadow:0 0 0 4px rgba(11,61,46,.10);
}

.bro-functions-box{
    margin-top:40px;
    background:rgba(255,255,255,.72);
    border:1px solid rgba(11,61,46,.10);
    backdrop-filter: blur(12px);
    border-radius:28px;
    padding:28px;
    box-shadow:0 16px 40px rgba(0,0,0,.08);
    position:relative;
    z-index:2;
}

.bro-functions-head{
    margin-bottom:24px;
    text-align:center;
}

.bro-functions-head h3{
    margin:0;
    color:#0b3d2e;
    font-size:30px;
    font-weight:800;
    letter-spacing:1px;
}

.bro-functions-head span{
    display:block;
    margin-top:6px;
    color:#557062;
    font-size:14px;
    letter-spacing:1px;
    text-transform:uppercase;
}

.bro-functions-grid{
    display:grid;
    grid-template-columns:repeat(2, 1fr);
    gap:18px;
}

.bro-function-card{
    background:#ffffff;
    border:1px solid rgba(11,61,46,.08);
    border-radius:22px;
    padding:20px;
    display:flex;
    gap:14px;
    align-items:flex-start;
    transition:.3s ease;
    box-shadow:0 8px 24px rgba(0,0,0,.04);
}

.bro-function-card:hover{
    transform:translateY(-5px);
    background:#fcfffc;
}

.bro-function-card-wide{
    grid-column:1 / -1;
}

.bro-function-icon{
    width:54px;
    height:54px;
    border-radius:16px;
    background:linear-gradient(135deg, #ffe56d, #ffcc00);
    color:#06680a;
    display:flex;
    align-items:center;
    justify-content:center;
    font-size:22px;
    flex-shrink:0;
    box-shadow:0 8px 18px rgba(0,0,0,.08);
}

.bro-function-card p{
    margin:0;
    color:#234031;
    font-size:15px;
    line-height:1.7;
    font-weight:500;
}

.bro-hero-bg-shapes{
    position:absolute;
    inset:0;
    overflow:hidden;
    pointer-events:none;
    z-index:1;
}

.bro-hero-bg-shapes .shape{
    position:absolute;
    border-radius:50%;
    background:radial-gradient(circle, rgba(11,61,46,.10), rgba(11,61,46,.02));
    animation: floatShape linear infinite;
}

.bro-hero-bg-shapes .s1{
    width:220px;
    height:220px;
    left:4%;
    top:10%;
    animation-duration:16s;
}

.bro-hero-bg-shapes .s2{
    width:340px;
    height:340px;
    right:7%;
    top:8%;
    animation-duration:18s;
}

.bro-hero-bg-shapes .s3{
    width:140px;
    height:140px;
    left:38%;
    bottom:12%;
    animation-duration:14s;
}

.bro-hero-bg-shapes .s4{
    width:280px;
    height:280px;
    right:32%;
    bottom:-30px;
    animation-duration:20s;
}

.bro-hero-bg-shapes .s5{
    width:110px;
    height:110px;
    left:22%;
    top:58%;
    animation-duration:13s;
}

/* =========================================================
   RESPONSIVE - TABLET
========================================================= */
@media (max-width: 1199px){
    .bro-hero-slider{
        padding: 50px 0 40px;
        min-height: auto;
    }

    .bro-hero-content{
        grid-template-columns: 1fr;
        gap: 25px;
        text-align: center;
    }

    .bro-hero-textbox{
        display: flex;
        flex-direction: column;
        align-items: center;
    }

    .bro-hero-under{
        max-width: 100%;
    }

    .bro-hero-buttons{
        justify-content: center;
    }

    .bro-hero-logo-area{
        margin-top: 10px;
    }

    .bro-logo-slider{
        max-width: 500px;
        min-height: 380px;
    }

    .bro-logo-slide img{
        max-height: 380px;
    }

    .bro-functions-grid{
        grid-template-columns: 1fr 1fr;
    }
}

/* =========================================================
   RESPONSIVE - MOBILE
========================================================= */
@media (max-width: 768px){
    .bro-hero-slider{
        padding: 35px 0 30px;
    }

    .bro-hero-container{
        padding-left: 15px;
        padding-right: 15px;
    }

    .bro-hero-content{
        gap: 18px;
    }

    .bro-hero-tag{
        font-size: 12px;
        padding: 8px 14px;
        margin-bottom: 16px;
    }

    .bro-hero-title-main{
        font-size: clamp(38px, 13vw, 58px);
        line-height: .95;
        letter-spacing: 2px;
    }

    .bro-hero-title-sub{
        font-size: clamp(22px, 7vw, 34px);
        letter-spacing: 2px;
        margin-top: 8px;
    }

    .bro-hero-under{
        margin-top: 14px;
        font-size: 12px;
        line-height: 1.6;
        letter-spacing: .8px;
        padding: 0 5px;
    }

    .bro-hero-buttons{
        width: 100%;
        flex-direction: column;
        gap: 10px;
        margin-top: 20px;
    }

    .bro-btn{
        width: 100%;
        min-width: unset;
        padding: 13px 18px;
        font-size: 14px;
    }

    .bro-logo-slider{
        max-width: 100%;
        min-height: 240px;
    }

    .bro-logo-slide img{
        max-height: 240px;
        width: 100%;
    }

    .bro-slider-dots{
        margin-top: 12px;
    }

    .bro-slider-dots button{
        width: 12px;
        height: 12px;
    }

    .bro-functions-box{
        margin-top: 25px;
        padding: 18px 14px;
        border-radius: 18px;
    }

    .bro-functions-head{
        margin-bottom: 16px;
    }

    .bro-functions-head h3{
        font-size: 22px;
    }

    .bro-functions-head span{
        font-size: 11px;
        letter-spacing: .8px;
    }

    .bro-functions-grid{
        grid-template-columns: 1fr;
        gap: 12px;
    }

    .bro-function-card,
    .bro-function-card-wide{
        grid-column: auto;
    }

    .bro-function-card{
        padding: 15px;
        border-radius: 16px;
        gap: 12px;
        flex-direction: column;
        align-items: flex-start;
    }

    .bro-function-icon{
        width: 46px;
        height: 46px;
        font-size: 18px;
        border-radius: 12px;
    }

    .bro-function-card p{
        font-size: 14px;
        line-height: 1.6;
    }

    .bro-hero-bg-shapes .s1{
        width: 120px;
        height: 120px;
    }

    .bro-hero-bg-shapes .s2{
        width: 180px;
        height: 180px;
    }

    .bro-hero-bg-shapes .s3{
        width: 90px;
        height: 90px;
    }

    .bro-hero-bg-shapes .s4{
        width: 140px;
        height: 140px;
    }

    .bro-hero-bg-shapes .s5{
        width: 70px;
        height: 70px;
    }
}

/* =========================================================
   RESPONSIVE - SMALL MOBILE
========================================================= */
@media (max-width: 480px){
    .bro-hero-slider{
        padding: 28px 0 24px;
    }

    .bro-hero-title-main{
        font-size: 34px;
        letter-spacing: 1px;
    }

    .bro-hero-title-sub{
        font-size: 20px;
        letter-spacing: 1.5px;
    }

    .bro-hero-under{
        font-size: 11px;
    }

    .bro-logo-slider{
        min-height: 200px;
    }

    .bro-logo-slide img{
        max-height: 200px;
    }

    .bro-functions-box{
        padding: 14px 12px;
    }

    .bro-functions-head h3{
        font-size: 20px;
    }

    .bro-function-card{
        padding: 13px;
    }

    .bro-function-card p{
        font-size: 13px;
    }
}