/*
Theme Name: BBGTK Modern
Theme URI: https://bbgtksumut.kemendikdasmen.go.id
Author: BBGTK Sumatera Utara
Description: Tema resmi BBGTK Sumatera Utara.

Lead Developer : Zulfahmi Pasaribu
Version: 2.0
*/
/* =========================================================
   1. RESET & GLOBAL
========================================================= */
*{
    box-sizing:border-box;
}

html{
    scroll-behavior:smooth;
}

body{
    margin:0;
    font-family:Arial, sans-serif;
    color:#0f172a;
    background:#f4f8fd;
}

a{
    color:inherit;
    text-decoration:none;
}

img{
    max-width:100%;
    height:auto;
}

.bbgtk-container{
    width:min(1180px, 92%);
    margin:auto;
}

/* =========================================================
   2. HEADER & NAVIGATION
========================================================= */
.bbgtk-header{
    background:#002f6c;
    color:#fff;
    position:sticky;
    top:0;
    z-index:9999;
}

.admin-bar .bbgtk-header{
    top:32px;
}

.bbgtk-header-wrap{
    display:flex;
    align-items:center;
    gap:24px;
    min-height:76px;
}

.bbgtk-logo{
    display:flex;
    align-items:center;
    color:#fff;
    flex-shrink:0;
}

.bbgtk-logo img{
    height:54px;
    width:auto;
    display:block;
}

.bbgtk-nav{
    flex:1;
}

.bbgtk-menu,
.bbgtk-menu ul,
.bbgtk-nav ul{
    list-style:none;
    margin:0;
    padding:0;
}

.bbgtk-menu{
    display:flex;
    align-items:center;
    justify-content:center;
    gap:24px;
}

.bbgtk-menu > li{
    position:relative;
}

.bbgtk-menu > li > a{
    color:#fff;
    display:block;
    padding:28px 0;
    font-size:14px;
    font-weight:700;
    white-space:nowrap;
    position:relative;
}

.bbgtk-menu > li > a::before{
    content:"";
    position:absolute;
    left:0;
    bottom:20px;
    width:0;
    height:3px;
    background:#f59e0b;
    transition:.25s;
}

.bbgtk-menu > li:hover > a,
.bbgtk-menu > li.current-menu-item > a,
.bbgtk-menu > li.current-menu-ancestor > a{
    color:#f59e0b;
}

.bbgtk-menu > li:hover > a::before,
.bbgtk-menu > li.current-menu-item > a::before,
.bbgtk-menu > li.current-menu-ancestor > a::before{
    width:100%;
}

.bbgtk-menu > li.menu-item-has-children > a::after{
    content:" ▾";
    font-size:11px;
    margin-left:5px;
}

.bbgtk-menu .sub-menu{
    display:block;
    position:absolute;
    top:100%;
    left:0;
    min-width:260px;
    background:#003b7a;
    opacity:0;
    visibility:hidden;
    transform:translateY(10px);
    transition:.25s;
    z-index:99999;
    border-radius:0 0 12px 12px;
    box-shadow:0 14px 30px rgba(0,0,0,.22);
}

.bbgtk-menu > li:hover > .sub-menu{
    opacity:1;
    visibility:visible;
    transform:translateY(0);
}

.bbgtk-menu .sub-menu a{
    display:block;
    color:#fff;
    padding:14px 20px;
    font-size:14px;
    font-weight:600;
    transition:.2s;
}

.bbgtk-menu .sub-menu a:hover{
    background:rgba(255,255,255,.12);
    color:#f59e0b;
    padding-left:28px;
}

.bbgtk-ppid{
    background:#f59e0b;
    color:#fff;
    padding:11px 22px;
    border-radius:10px;
    font-weight:700;
    flex-shrink:0;
}

.bbgtk-ppid:hover{
    background:#d97706;
    color:#fff;
}

.bbgtk-mobile-toggle{
    display:none !important;
}

/* =========================================================
   3. SEARCH
========================================================= */
.bbgtk-search-desktop{
    width:42px;
    height:42px;
    border:none;
    background:rgba(255,255,255,.10);
    color:#fff;
    border-radius:50%;
    display:flex;
    align-items:center;
    justify-content:center;
    cursor:pointer;
    transition:.25s;
    flex-shrink:0;
}

.bbgtk-search-desktop:hover{
    background:rgba(255,255,255,.18);
    transform:translateY(-2px);
}

.bbgtk-search-desktop svg{
    width:21px;
    height:21px;
}

.bbgtk-search-mobile{
    display:none;
}

.bbgtk-search-overlay{
    position:fixed;
    inset:0;
    background:rgba(0,31,72,.78);
    backdrop-filter:blur(8px);
    z-index:99999;
    display:none;
    align-items:center;
    justify-content:center;
    padding:20px;
}

.bbgtk-search-overlay.active{
    display:flex;
}

.bbgtk-search-box{
    background:#fff;
    width:min(620px, 94%);
    border-radius:22px;
    padding:34px;
    position:relative;
    box-shadow:0 25px 70px rgba(0,0,0,.25);
}

.bbgtk-search-box h2{
    margin:0 0 20px;
    color:#002f6c;
    font-size:30px;
}

.bbgtk-search-box form{
    display:flex;
    gap:12px;
}

.bbgtk-search-box input{
    flex:1;
    border:1px solid #dbe4f0;
    border-radius:12px;
    padding:15px 16px;
    font-size:16px;
}

.bbgtk-search-box button[type="submit"]{
    background:#f59e0b;
    color:#fff;
    border:0;
    border-radius:12px;
    padding:0 24px;
    font-weight:700;
    cursor:pointer;
}

.bbgtk-search-close{
    position:absolute;
    top:14px;
    right:18px;
    background:transparent;
    border:0;
    font-size:32px;
    cursor:pointer;
    color:#002f6c;
}

/* =========================================================
   4. HERO HOMEPAGE
========================================================= */
.bbgtk-hero{
    min-height:560px;
    color:#fff;
    background:
        linear-gradient(90deg, rgba(0,47,108,.94) 0%, rgba(0,74,150,.62) 45%, rgba(0,91,172,.05) 100%),
        url('assets/img/hero-bbgtk.jpg');
    background-size:cover;
    background-position:center;
    display:flex;
    align-items:center;
    position:relative;
}

.bbgtk-label{
    font-size:18px;
    font-weight:700;
}

.bbgtk-hero h1{
    font-size:52px;
    max-width:760px;
    line-height:1.12;
    margin:12px 0;
    font-weight:800;
}

.bbgtk-desc{
    max-width:720px;
    line-height:1.8;
    font-size:17px;
}

.bbgtk-actions{
    margin-top:28px;
    display:flex;
    gap:14px;
    flex-wrap:wrap;
}

.bbgtk-btn{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    padding:14px 24px;
    border-radius:12px;
    font-weight:700;
    transition:.2s;
}

.bbgtk-btn-primary{
    background:#f59e0b;
    color:#fff;
    border:1px solid #f59e0b;
}

.bbgtk-btn-primary:hover{
    background:#d97706;
    border-color:#d97706;
    color:#fff;
}

.bbgtk-btn-outline{
    border:1px solid rgba(255,255,255,.75);
    color:#fff;
}

.bbgtk-btn-outline:hover{
    background:#fff;
    color:#073b78;
}

.bbgtk-hero .bbgtk-campaign{
    position:absolute;
    right:40px;
    bottom:30px;
    background:rgba(255,255,255,.92);
    backdrop-filter:blur(8px);
    border-radius:16px;
    padding:12px 18px;
    box-shadow:0 10px 25px rgba(0,0,0,.15);
    z-index:5;
}

.bbgtk-hero .bbgtk-campaign-grid{
    display:flex;
    align-items:center;
    gap:18px;
}

.bbgtk-hero .bbgtk-campaign-item{
    background:transparent;
    box-shadow:none;
    padding:0;
    width:auto;
    height:auto;
    min-height:0;
}

.bbgtk-hero .bbgtk-campaign-item img{
    height:42px;
    width:auto;
    max-width:120px;
    object-fit:contain;
    display:block;
}

/* =========================================================
   5. SECTIONS, SERVICES, STATS
========================================================= */
.bbgtk-section{
    width:min(1180px, 92%);
    margin:55px auto;
}

.bbgtk-section h2{
    color:#002f6c;
    font-size:32px;
    margin:0;
}

.bbgtk-title-row{
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:20px;
    margin-bottom:26px;
}

.bbgtk-title-row a{
    color:#005bac;
    font-weight:700;
    font-size:14px;
}

.bbgtk-services-section{
    margin-top:40px;
}

.bbgtk-services-section h2{
    font-size:42px;
    font-weight:800;
    color:#073b78;
    text-align:center;
    margin-bottom:40px;
}

.bbgtk-services{
    display:flex;
    justify-content:center;
    gap:24px;
    flex-wrap:wrap;
}

.bbgtk-service{
    background:#fff;
    border-radius:16px;
    padding:28px 16px;
    text-align:center;
    box-shadow:0 10px 28px rgba(15,23,42,.08);
    font-size:34px;
    transition:.25s;
    width:210px;
    min-height:140px;
}

.bbgtk-service:hover{
    transform:translateY(-6px);
}

.bbgtk-service span{
    display:block;
    font-size:14px;
    font-weight:800;
    margin-top:10px;
}

.bbgtk-stats{
    text-align:center;
}

.bbgtk-stats-title{
    text-align:center !important;
    margin-bottom:8px;
}

.bbgtk-stats-source{
    text-align:center !important;
    max-width:900px;
    margin:0 auto 40px;
    color:#64748b;
    font-size:14px;
}

.bbgtk-stats-source a{
    color:#0a4ea3;
    font-weight:600;
}

.bbgtk-stats-source a:hover{
    text-decoration:underline;
}

.bbgtk-stats-grid{
    display:grid;
    grid-template-columns:repeat(4,1fr);
    gap:22px;
}

.bbgtk-stats-grid div{
    background:#fff;
    border-radius:20px;
    padding:26px 18px;
    text-align:center;
    box-shadow:0 12px 32px rgba(15,23,42,.08);
}

.bbgtk-stats-grid strong{
    display:block;
    color:#073b78;
    font-size:36px;
    line-height:1;
    margin-bottom:10px;
}

.bbgtk-stats-grid span{
    display:block;
    color:#475569;
    font-size:15px;
    font-weight:700;
    line-height:1.4;
}

/* =========================================================
   6. NEWS & CARDS
========================================================= */
.bbgtk-news-section{
    margin-top:65px;
}

.bbgtk-news-grid{
    display:grid;
    grid-template-columns:repeat(4, 1fr);
    gap:22px;
}

.bbgtk-card{
    background:#fff;
    border:1px solid #e2e8f0;
    border-radius:18px;
    overflow:hidden;
    box-shadow:0 10px 28px rgba(15,23,42,.08);
    transition:.25s;
    height:100%;
}

.bbgtk-card:hover{
    transform:translateY(-8px);
    box-shadow:0 20px 45px rgba(15,23,42,.12);
}

.bbgtk-card a{
    display:flex;
    flex-direction:column;
    height:100%;
}

.bbgtk-card img,
.bbgtk-card .wp-post-image,
.bbgtk-card-placeholder{
    width:100%;
    height:210px;
    object-fit:cover;
    display:block;
}

.bbgtk-card-placeholder{
    background:
        linear-gradient(135deg, rgba(0,47,108,.92), rgba(0,91,172,.7)),
        url('assets/img/hero-bbgtk.jpg');
    background-size:cover;
    background-position:center;
    color:#fff;
    display:grid;
    place-items:center;
    text-align:center;
}

.bbgtk-card-placeholder span{
    display:block;
    font-size:28px;
    font-weight:800;
}

.bbgtk-card-placeholder strong{
    display:block;
    font-size:14px;
}

.bbgtk-card-body{
    padding:18px;
    flex:1;
}

.bbgtk-card-body small{
    color:#64748b;
}

.bbgtk-card-body h3{
    color:#002f6c;
    font-size:18px;
    line-height:1.35;
    display:-webkit-box;
    -webkit-box-orient:vertical;
    -webkit-line-clamp:3;
    overflow:hidden;
}

.bbgtk-card-body p{
    color:#64748b;
    font-size:14px;
    line-height:1.6;
    display:-webkit-box;
    -webkit-box-orient:vertical;
    -webkit-line-clamp:3;
    overflow:hidden;
}

/* =========================================================
   PENGUMUMAN HOMEPAGE - FULL WIDTH
========================================================= */

.bbgtk-pengumuman-full{
    display:block !important;
    padding:44px 0 70px;
}

.bbgtk-pengumuman-full .bbgtk-agenda-box{
    width:100%;
    max-width:none;
    margin:0 auto;
}

.bbgtk-pengumuman-full .bbgtk-title-row{
    margin-bottom:24px;
}

/* Card utama */
.bbgtk-pengumuman-card{
    width:100%;
    min-height:340px;
    background:#fff;
    border-radius:26px;
    padding:34px 40px;
    box-shadow:0 18px 40px rgba(15,23,42,.08);
}

/* Pengumuman utama */
.bbgtk-pengumuman-main{
    display:grid;
    grid-template-columns:82px 1fr;
    gap:24px;
    text-decoration:none;
    color:#0b2f63;
    padding-bottom:28px;
    border-bottom:1px solid #e5e7eb;
}

.bbgtk-pengumuman-date-big{
    width:72px;
    height:78px;
    border-radius:20px;
    background:#eef5ff;
    text-align:center;
    flex-shrink:0;
    padding-top:11px;
}

.bbgtk-pengumuman-date-big strong{
    display:block;
    font-size:32px;
    line-height:1;
    color:#0b66c3;
}

.bbgtk-pengumuman-date-big span{
    display:block;
    margin-top:5px;
    font-size:12px;
    font-weight:800;
    text-transform:uppercase;
    color:#64748b;
}

.bbgtk-pengumuman-main small{
    display:block;
    color:#f59e0b;
    font-weight:800;
    margin-bottom:8px;
}

.bbgtk-pengumuman-main h3{
    margin:0 0 12px;
    font-size:30px;
    line-height:1.25;
    color:#073b7a;
    max-width:920px;
}

.bbgtk-pengumuman-main p{
    margin:0 0 14px;
    max-width:880px;
    color:#64748b;
    font-size:15px;
    line-height:1.7;
}

.bbgtk-pengumuman-main em{
    font-style:normal;
    font-weight:800;
    color:#0b66c3;
}

/* Daftar pengumuman lainnya */
.bbgtk-pengumuman-more{
    margin-top:24px;
}

.bbgtk-pengumuman-more h4{
    margin:0 0 14px;
    color:#073b7a;
    font-size:18px;
}

.bbgtk-pengumuman-more a{
    display:grid;
    grid-template-columns:90px 1fr;
    gap:16px;
    align-items:start;
    text-decoration:none;
    padding:13px 0;
    border-bottom:1px dashed #e5e7eb;
}

.bbgtk-pengumuman-more a:last-child{
    border-bottom:none;
}

.bbgtk-pengumuman-more span{
    color:#f59e0b;
    font-size:12px;
    font-weight:800;
    text-transform:uppercase;
}

.bbgtk-pengumuman-more strong{
    color:#0b2f63;
    font-size:15px;
    line-height:1.4;
}

/* Hover halus */
.bbgtk-pengumuman-main:hover h3,
.bbgtk-pengumuman-more a:hover strong{
    color:#0b66c3;
}

/* Mobile */
@media(max-width:768px){
    .bbgtk-pengumuman-full{
        padding:34px 0 52px;
    }

    .bbgtk-pengumuman-card{
        padding:24px;
        min-height:auto;
        border-radius:22px;
    }

    .bbgtk-pengumuman-main{
        grid-template-columns:1fr;
        gap:16px;
    }

    .bbgtk-pengumuman-main h3{
        font-size:24px;
    }

    .bbgtk-pengumuman-more a{
        grid-template-columns:1fr;
        gap:4px;
    }
}

/* FIX PENGUMUMAN HOMEPAGE - OVERRIDE FINAL */
.home .bbgtk-pengumuman-full{
    width:100%;
    padding:44px 0 70px !important;
}

.home .bbgtk-pengumuman-full .bbgtk-agenda-box{
    width:100% !important;
    max-width:1120px !important;
    margin:0 auto !important;
    padding:0 22px !important;
}

.home .bbgtk-pengumuman-full .bbgtk-pengumuman-card{
    width:100% !important;
    max-width:none !important;
    background:#fff !important;
    border-radius:26px !important;
    padding:34px 40px !important;
    box-shadow:0 18px 40px rgba(15,23,42,.08) !important;
}

.home .bbgtk-pengumuman-full .bbgtk-pengumuman-main{
    display:grid !important;
    grid-template-columns:82px 1fr !important;
    gap:24px !important;
}

.home .bbgtk-pengumuman-full .bbgtk-pengumuman-main h3{
    font-size:30px !important;
    line-height:1.25 !important;
}

/* =========================================================
   NEWS TICKER PENGUMUMAN HOMEPAGE - FIX FINAL
========================================================= */

.bbgtk-pengumuman-ticker{
    width:100% !important;
    background:#f4f8fd !important;
    padding:18px 0 10px !important;
    margin:0 !important;
}

.bbgtk-pengumuman-ticker .bbgtk-container{
    width:min(1180px, 92%) !important;
    margin:0 auto !important;
}

.bbgtk-news-ticker{
    display:flex !important;
    align-items:center !important;
    gap:14px !important;
    width:100% !important;
    background:#ffffff !important;
    border:1px solid #e2e8f0 !important;
    border-radius:18px !important;
    padding:12px 14px !important;
    box-shadow:0 10px 26px rgba(15,23,42,.07) !important;
    overflow:hidden !important;
}

.bbgtk-news-ticker-label{
    flex:0 0 auto !important;
    display:flex !important;
    align-items:center !important;
    gap:7px !important;
    background:#eef5ff !important;
    color:#073b78 !important;
    border-radius:999px !important;
    padding:8px 14px !important;
    font-size:13px !important;
    font-weight:900 !important;
    line-height:1 !important;
    white-space:nowrap !important;
}

.bbgtk-news-ticker-label span,
.bbgtk-news-ticker-label strong{
    display:inline-block !important;
}

.bbgtk-news-ticker-content{
    flex:1 1 auto !important;
    min-width:0 !important;
    overflow:hidden !important;
}

.bbgtk-news-ticker-content a{
    display:flex !important;
    align-items:center !important;
    gap:10px !important;
    width:100% !important;
    color:#0b2f63 !important;
    text-decoration:none !important;
    font-size:14px !important;
    font-weight:800 !important;
    line-height:1.3 !important;
    white-space:nowrap !important;
    overflow:hidden !important;
}

.bbgtk-news-ticker-date{
    flex:0 0 auto !important;
    color:#f59e0b !important;
    font-size:12px !important;
    font-weight:900 !important;
    text-transform:uppercase !important;
}

.bbgtk-news-ticker-title{
    display:block !important;
    min-width:0 !important;
    overflow:hidden !important;
    text-overflow:ellipsis !important;
    white-space:nowrap !important;
}

.bbgtk-news-ticker-more{
    flex:0 0 auto !important;
    display:inline-flex !important;
    align-items:center !important;
    justify-content:center !important;
    background:#f59e0b !important;
    color:#ffffff !important;
    border-radius:999px !important;
    padding:8px 15px !important;
    font-size:12px !important;
    font-weight:900 !important;
    text-decoration:none !important;
    white-space:nowrap !important;
}

.bbgtk-news-ticker-more:hover{
    background:#d97706 !important;
    color:#ffffff !important;
}

@media(max-width:768px){
    .bbgtk-pengumuman-ticker{
        padding:12px 0 6px !important;
    }

    .bbgtk-news-ticker{
        flex-wrap:wrap !important;
        align-items:flex-start !important;
        gap:10px !important;
        border-radius:16px !important;
        padding:12px !important;
    }

    .bbgtk-news-ticker-content{
        order:3 !important;
        flex:0 0 100% !important;
        width:100% !important;
    }

    .bbgtk-news-ticker-content a{
        white-space:normal !important;
        align-items:flex-start !important;
        line-height:1.45 !important;
    }

    .bbgtk-news-ticker-title{
        white-space:normal !important;
    }

    .bbgtk-news-ticker-more{
        margin-left:auto !important;
    }
}
/* =========================================================
   8. HOMEPAGE BANNER CAROUSEL
========================================================= */
.bbgtk-home-banner-section{
    width:min(1180px, 92%);
    margin:30px auto 60px;
}

.bbgtk-home-banner-wrap{
    position:relative;
    overflow:hidden;
    border-radius:24px;
    background:#fff;
    box-shadow:0 18px 45px rgba(15,23,42,.12);
}

.bbgtk-home-banner-track{
    display:flex;
    transition:transform .8s ease-in-out;
}

.bbgtk-home-banner-slide{
    min-width:100%;
    flex:0 0 100%;
}

.bbgtk-home-banner-slide img{
    width:100%;
    height:auto;
    display:block;
}

.bbgtk-banner-nav{
    position:absolute;
    top:50%;
    transform:translateY(-50%);
    width:48px;
    height:48px;
    border:none;
    border-radius:50%;
    background:rgba(255,255,255,.9);
    color:#073b78;
    font-size:30px;
    font-weight:700;
    cursor:pointer;
    z-index:10;
    box-shadow:0 8px 20px rgba(0,0,0,.15);
}

.bbgtk-banner-prev{
    left:20px;
}

.bbgtk-banner-next{
    right:20px;
}

.bbgtk-banner-nav:hover{
    background:#f59e0b;
    color:#fff;
}

/* =========================================================
   9. PARTNERS & FOOTER
========================================================= */
.bbgtk-partners{
    background:#fff;
    padding:24px 0;
    border-top:1px solid #e5edf7;
}

.bbgtk-partner-row{
    display:flex;
    gap:28px;
    align-items:center;
    justify-content:space-between;
    overflow-x:auto;
}

.bbgtk-partner-row span{
    color:#64748b;
    white-space:nowrap;
    font-weight:700;
}

.bbgtk-footer{
    background:#002f6c;
    color:#fff;
    margin-top:0;
    padding-top:45px;
}

.bbgtk-footer h3{
    margin:0 0 18px;
    font-size:20px;
    color:#fff;
}

.bbgtk-footer h3::after{
    content:"";
    display:block;
    width:46px;
    height:3px;
    background:#f59e0b;
    border-radius:10px;
    margin-top:9px;
}

.bbgtk-footer-grid{
    display:grid;
    grid-template-columns:1fr 1fr 1.4fr;
    gap:35px;
    align-items:start;
}

.bbgtk-footer p{
    color:#dbeafe;
}

.bbgtk-footer-menu{
    list-style:none;
    margin:0;
    padding:0;
}

.bbgtk-footer-menu li{
    margin:0;
}

.bbgtk-footer-menu a{
    display:flex;
    align-items:center;
    gap:10px;
    padding:8px 0;
    color:rgba(255,255,255,.9);
    font-size:16px;
    line-height:1.4;
    transition:.25s ease;
}

.bbgtk-footer-menu a::before{
    content:"›";
    color:#f59e0b;
    font-size:18px;
    font-weight:700;
    flex-shrink:0;
}

.bbgtk-footer-menu a:hover{
    color:#fff;
    padding-left:6px;
}

.bbgtk-footer-menu a:hover::before{
    color:#fff;
}

.bbgtk-footer-social{
    display:flex;
    flex-wrap:wrap;
    gap:10px;
    margin-top:18px;
}

.bbgtk-footer-social a{
    background:rgba(255,255,255,.12);
    color:#fff;
    padding:8px 12px;
    border-radius:10px;
    font-size:13px;
    font-weight:700;
}

.bbgtk-footer-social a:hover{
    background:#f59e0b;
    color:#fff;
}

.bbgtk-footer-stats{
    display:grid;
    gap:10px;
}

.bbgtk-footer-stats p{
    margin:0;
    padding:11px 13px;
    border-radius:12px;
    background:rgba(255,255,255,.10);
    display:flex;
    justify-content:space-between;
    align-items:center;
}

.bbgtk-footer-stats span{
    color:#dbeafe;
    font-size:14px;
}

.bbgtk-footer-stats strong{
    color:#fff;
    font-size:18px;
}

.bbgtk-footer-map{
    margin-top:18px;
    border-radius:16px;
    overflow:hidden;
    border:3px solid rgba(255,255,255,.14);
}

.bbgtk-footer-map iframe{
    width:100%;
    height:210px;
    border:0;
    display:block;
}

.bbgtk-copyright{
    margin-top:35px;
    padding:16px;
    text-align:center;
    background:#001f48;
    font-size:14px;
}

/* =========================================================
   10. ARCHIVE, CATEGORY, SINGLE
========================================================= */
.bbgtk-archive-wrap,
.bbgtk-archive-page{
    padding:45px 20px 70px;
    background:#f4f8fc;
}

.bbgtk-archive-container{
    max-width:1200px;
    margin:0 auto;
    display:grid;
    grid-template-columns:minmax(0, 1fr) 300px;
    gap:30px;
    align-items:start;
}

.bbgtk-archive-heading,
.bbgtk-archive-title{
    margin-bottom:28px;
}

.bbgtk-archive-heading span,
.bbgtk-archive-title span{
    display:inline-block;
    color:#f59e0b;
    font-weight:800;
    text-transform:uppercase;
    font-size:13px;
    margin-bottom:8px;
}

.bbgtk-archive-heading h1,
.bbgtk-archive-title h1{
    margin:6px 0 0;
    font-size:42px;
    color:#073b78;
}

.bbgtk-post-list{
    display:flex;
    flex-direction:column;
    gap:18px;
}

.bbgtk-post-item{
    background:#fff;
    border-radius:20px;
    display:grid;
    grid-template-columns:210px 1fr;
    overflow:hidden;
    min-height:165px;
    box-shadow:0 14px 35px rgba(15,23,42,.08);
}

.bbgtk-post-thumb{
    height:165px;
    min-height:165px;
    background:linear-gradient(135deg, #e8f1fb, #dbeafe);
    display:block;
}

.bbgtk-post-thumb img{
    width:100%;
    height:100%;
    object-fit:cover;
    display:block;
}

.bbgtk-post-noimg{
    height:100%;
    display:flex;
    align-items:center;
    justify-content:center;
    font-size:0;
}

.bbgtk-post-noimg::after{
    content:"BBGTK";
    font-size:22px;
    color:#073b78;
    font-weight:900;
}

.bbgtk-post-info{
    padding:20px 26px;
}

.bbgtk-post-date{
    color:#64748b;
    font-size:14px;
    margin-bottom:8px;
}

.bbgtk-post-info h2{
    margin:0 0 10px;
    font-size:22px;
    line-height:1.32;
}

.bbgtk-post-info h2 a{
    color:#073b78;
}

.bbgtk-post-info p{
    color:#52657a;
    font-size:15px;
    line-height:1.6;
    margin:0 0 12px;
}

.bbgtk-post-more,
.bbgtk-readmore{
    color:#f59e0b;
    font-weight:800;
}

.bbgtk-archive-sidebar,
.bbgtk-single-sidebar{
    display:flex;
    flex-direction:column;
    gap:22px;
}

.bbgtk-archive-sidebar{
    padding-top:70px;
}

.bbgtk-side-box{
    background:#fff;
    border-radius:18px;
    padding:24px 26px;
    max-width:300px;
    box-shadow:0 14px 35px rgba(15,23,42,.08);
}

.bbgtk-side-box:empty{
    display:none;
}

.bbgtk-side-box h3{
    margin:0 0 14px;
    color:#073b78;
    font-size:18px;
}

.bbgtk-side-box ul{
    list-style:none;
    margin:0;
    padding:0;
}

.bbgtk-side-box li{
    padding:10px 0;
    border-bottom:1px solid #e5eaf0;
}

.bbgtk-side-box a{
    color:#334155;
    font-weight:600;
}

.bbgtk-side-post{
    display:block;
    padding:12px 0;
    border-bottom:1px solid #e5eaf0;
}

.bbgtk-side-post small{
    display:block;
    color:#64748b;
    margin-bottom:4px;
    font-size:12px;
}

.bbgtk-side-post strong{
    color:#073b78;
    line-height:1.28;
    font-size:14px;
}

.bbgtk-pagination{
    margin-top:34px;
    display:flex;
    justify-content:center;
    gap:8px;
    flex-wrap:wrap;
}

.bbgtk-pagination .page-numbers{
    min-width:42px;
    height:42px;
    padding:0 14px;
    border-radius:999px;
    background:#fff;
    border:1px solid #e2e8f0;
    color:#073b78;
    display:inline-flex;
    align-items:center;
    justify-content:center;
    font-weight:800;
}

.bbgtk-pagination .current{
    background:#073b78;
    color:#fff;
}

.bbgtk-archive-grid{
    display:grid;
    grid-template-columns:repeat(3, 1fr);
    gap:22px;
}

.bbgtk-archive-card{
    background:#fff;
    border:1px solid #e2e8f0;
    border-radius:22px;
    overflow:hidden;
    box-shadow:0 12px 30px rgba(15,23,42,.06);
}

.bbgtk-archive-thumb{
    display:block;
    height:190px;
    overflow:hidden;
}

.bbgtk-archive-thumb img{
    width:100%;
    height:100%;
    object-fit:cover;
    display:block;
}

.bbgtk-archive-content{
    padding:20px;
}

.bbgtk-archive-meta{
    font-size:13px;
    color:#64748b;
    margin-bottom:8px;
}

.bbgtk-archive-content h2{
    font-size:20px;
    line-height:1.35;
    margin:0 0 10px;
}

.bbgtk-archive-content h2 a{
    color:#0f172a;
}

.bbgtk-archive-content p{
    color:#64748b;
    line-height:1.6;
    margin:0 0 16px;
}

.bbgtk-empty-state{
    background:#fff;
    border:1px solid #e2e8f0;
    border-radius:22px;
    padding:40px;
    text-align:center;
}

.bbgtk-single-wrap{
    padding:70px 20px;
    background:#f4f8fc;
}

.bbgtk-single-container{
    max-width:1200px;
    margin:0 auto;
    display:grid;
    grid-template-columns:minmax(0, 1fr) 300px;
    gap:36px;
}

.bbgtk-single-main{
    min-width:0;
}

.bbgtk-single-article{
    max-width:none;
    margin:0 auto;
    background:#fff;
    border-radius:22px;
    padding:42px;
    box-shadow:0 14px 35px rgba(15,23,42,.08);
}

.bbgtk-single-meta,
.bbgtk-single-meta a{
    color:#f59e0b;
    font-weight:800;
    margin-bottom:12px;
}

.bbgtk-single-article h1{
    font-size:40px;
    line-height:1.25;
    color:#073b78;
    margin:0 0 14px;
}

.bbgtk-single-author{
    color:#64748b;
    margin-bottom:26px;
}

.bbgtk-single-thumb{
    margin-bottom:30px;
}

.bbgtk-single-thumb img{
    width:100%;
    height:auto;
    border-radius:18px;
    display:block;
}

.bbgtk-single-content{
    font-size:18px;
    line-height:1.85;
    color:#1e293b;
}

.bbgtk-single-content p{
    margin:0 0 22px;
}

.bbgtk-single-content p:first-of-type{
    font-size:20px;
    line-height:1.8;
    color:#0f172a;
}

.bbgtk-single-content img{
    max-width:100%;
    height:auto;
    border-radius:14px;
}

/* =========================================================
   11. PAGE TEMPLATE
========================================================= */
.bbgtk-page-hero{
    background:
        linear-gradient(90deg, rgba(0,47,108,.95), rgba(0,91,172,.72)),
        url('assets/img/hero-bbgtk.jpg');
    background-size:cover;
    background-position:center;
    padding:78px 0;
    color:#fff;
}

.bbgtk-page-hero span{
    display:inline-block;
    color:#fbbf24;
    font-weight:800;
    text-transform:uppercase;
    font-size:13px;
    margin-bottom:10px;
}

.bbgtk-page-hero h1{
    margin:0;
    font-size:44px;
    line-height:1.2;
    max-width:850px;
}

.bbgtk-page-wrap{
    padding:60px 20px 75px;
    background:#f4f8fc;
}

.bbgtk-page-container{
    max-width:1000px;
    margin:0 auto;
}

.bbgtk-page-content{
    background:#fff;
    border-radius:24px;
    padding:42px;
    box-shadow:0 14px 35px rgba(15,23,42,.08);
}

.bbgtk-page-thumb{
    margin-bottom:30px;
}

.bbgtk-page-thumb img{
    width:100%;
    height:auto;
    border-radius:18px;
    display:block;
}

.bbgtk-page-text{
    font-size:18px;
    line-height:1.85;
    color:#1e293b;
}

.bbgtk-page-text p{
    margin:0 0 22px;
}

.bbgtk-page-text h2,
.bbgtk-page-text h3,
.bbgtk-page-text h4{
    color:#073b78;
    line-height:1.3;
    margin-top:32px;
    margin-bottom:14px;
}

.bbgtk-page-text ul,
.bbgtk-page-text ol{
    padding-left:24px;
    margin-bottom:22px;
}

.bbgtk-page-text li{
    margin-bottom:8px;
}

.bbgtk-page-text img{
    max-width:100%;
    height:auto;
    border-radius:14px;
}

.bbgtk-page-text table{
    width:100%;
    border-collapse:collapse;
    margin:24px 0;
    background:#fff;
}

.bbgtk-page-text table th,
.bbgtk-page-text table td{
    border:1px solid #dbe4f0;
    padding:12px 14px;
    text-align:left;
}

.bbgtk-page-text table th{
    background:#eaf3ff;
    color:#073b78;
}

.bbgtk-sewa-box{
    background:#f8fafc;
    border:1px solid #dbe4f0;
    border-radius:16px;
    padding:25px;
    margin:30px 0;
}

.bbgtk-sewa-box h3{
    margin:0 0 10px;
    color:#073b78;
}

.bbgtk-sewa-box p{
    margin-bottom:20px;
}

.bbgtk-sewa-btn{
    display:inline-block;
    background:#f59e0b;
    color:#fff !important;
    padding:12px 22px;
    border-radius:10px;
    font-weight:700;
    transition:.2s;
}

.bbgtk-sewa-btn:hover{
    background:#073b78;
}

/* =========================================================
   12. SEARCH RESULT PAGE
========================================================= */
.bbgtk-search-page{
    padding:42px 0 80px;
    background:#f4f8fc;
}

.bbgtk-search-hero{
    background:linear-gradient(135deg,#073b7a,#0b4fa3);
    border-radius:26px;
    padding:34px;
    margin-bottom:28px;
    color:#fff;
    display:flex;
    justify-content:space-between;
    gap:28px;
    align-items:center;
    box-shadow:0 18px 40px rgba(7,59,122,.18);
}

.bbgtk-search-hero span{
    display:inline-block;
    background:#f6a400;
    color:#073b7a;
    padding:7px 14px;
    border-radius:999px;
    font-weight:900;
    margin-bottom:14px;
}

.bbgtk-search-hero h1{
    margin:0 0 8px;
    font-size:42px;
    color:#fff;
}

.bbgtk-search-hero p{
    margin:0;
    font-size:17px;
    color:#eaf3ff;
}

.bbgtk-search-hero form{
    display:flex;
    background:#fff;
    padding:8px;
    border-radius:16px;
    min-width:390px;
}

.bbgtk-search-hero input{
    border:0;
    outline:none;
    padding:13px 14px;
    flex:1;
    font-size:15px;
}

.bbgtk-search-hero button{
    border:0;
    border-radius:12px;
    background:#f6a400;
    color:#073b7a;
    padding:0 22px;
    font-weight:900;
    cursor:pointer;
}

.bbgtk-search-list{
    display:flex;
    flex-direction:column;
    gap:18px;
}

.bbgtk-search-item{
    background:#fff;
    border:1px solid #dbeafe;
    border-radius:22px;
    padding:16px;
    display:grid;
    grid-template-columns:280px 1fr;
    gap:22px;
    box-shadow:0 12px 30px rgba(15,23,42,.07);
}

.bbgtk-search-img{
    display:block;
    height:175px;
    border-radius:16px;
    overflow:hidden;
    background:#eaf3ff;
}

.bbgtk-search-img img{
    width:100%;
    height:100%;
    object-fit:cover;
}

.bbgtk-search-placeholder{
    height:100%;
    display:flex;
    align-items:center;
    justify-content:center;
    color:#073b7a;
    font-weight:900;
    font-size:26px;
}

.bbgtk-search-info{
    padding:4px 8px 4px 0;
}

.bbgtk-search-info small{
    color:#64748b;
    font-weight:700;
}

.bbgtk-search-info h2{
    margin:8px 0 10px;
    font-size:26px;
    line-height:1.25;
}

.bbgtk-search-info h2 a{
    color:#073b7a;
}

.bbgtk-search-info p{
    color:#334155;
    font-size:16px;
    line-height:1.7;
    margin:0 0 14px;
}

/* =========================================================
   13. CONTACT PAGE
========================================================= */
.bbgtk-contact-wrap{
    max-width:1080px;
    margin:0 auto;
}

.bbgtk-contact-head{
    margin-bottom:28px;
}

.bbgtk-contact-head span{
    display:inline-block;
    color:#f59e0b;
    font-size:13px;
    font-weight:800;
    text-transform:uppercase;
    margin-bottom:10px;
}

.bbgtk-contact-head h2{
    margin:0 0 12px;
    color:#073b78;
    font-size:40px;
}

.bbgtk-contact-head p{
    margin:0;
    color:#475569;
    font-size:17px;
    line-height:1.7;
}

.bbgtk-contact-layout{
    display:grid;
    grid-template-columns:minmax(0,1.1fr) minmax(320px,.9fr);
    gap:28px;
    align-items:start;
}

.bbgtk-contact-form,
.bbgtk-contact-info{
    background:#fff;
    border:1px solid #dbeafe;
    border-radius:24px;
    padding:30px;
    box-shadow:0 14px 35px rgba(15,23,42,.08);
}

.bbgtk-contact-form label{
    display:block;
    margin:0 0 8px;
    color:#073b78;
    font-weight:800;
}

.bbgtk-contact-form input,
.bbgtk-contact-form select,
.bbgtk-contact-form textarea{
    width:100%;
    margin-bottom:16px;
    padding:13px 14px;
    border:1px solid #cbd5e1;
    border-radius:12px;
    font-size:15px;
}

.bbgtk-contact-form textarea{
    resize:vertical;
}

.bbgtk-contact-form button{
    width:100%;
    border:0;
    border-radius:14px;
    background:#f59e0b;
    color:#073b78;
    padding:14px 18px;
    font-weight:900;
    cursor:pointer;
}

.bbgtk-contact-info h3{
    margin:0 0 18px;
    color:#073b78;
    font-size:26px;
}

.bbgtk-contact-info p{
    margin:0 0 18px;
    color:#334155;
    line-height:1.65;
}

.bbgtk-contact-info strong{
    color:#073b78;
}

.bbgtk-contact-info iframe{
    width:100%;
    height:280px;
    border:0;
    border-radius:18px;
    margin-top:8px;
}

.bbgtk-contact-alert{
    max-width:1080px;
    margin:0 auto 20px;
    padding:14px 18px;
    border-radius:14px;
    font-weight:700;
}

.bbgtk-contact-alert.success{
    background:#dcfce7;
    color:#166534;
}

.bbgtk-contact-alert.failed{
    background:#fee2e2;
    color:#991b1b;
}

/* =========================================================
   14. WBS PAGE & FORM
========================================================= */
.bbgtk-wbs-page{
    max-width:1100px;
    margin:0 auto;
}

.bbgtk-wbs-hero{
    background:linear-gradient(135deg,#073b78,#0a5ab8);
    color:#fff;
    border-radius:28px;
    padding:46px;
    margin-bottom:34px;
    box-shadow:0 18px 45px rgba(7,59,120,.18);
}

.bbgtk-wbs-hero span{
    display:inline-block;
    background:#f59e0b;
    color:#073b78;
    font-weight:900;
    padding:8px 16px;
    border-radius:999px;
    margin-bottom:18px;
}

.bbgtk-wbs-hero h2{
    margin:0 0 14px;
    font-size:42px;
    line-height:1.2;
    color:#fff;
}

.bbgtk-wbs-hero p{
    max-width:780px;
    font-size:17px;
    line-height:1.8;
    color:#eaf3ff;
}

.bbgtk-wbs-btn,
.bbgtk-wbs-channel a{
    display:inline-block;
    background:#f59e0b;
    color:#073b78 !important;
    padding:13px 22px;
    border-radius:12px;
    font-weight:900;
}

.bbgtk-wbs-section{
    margin:36px 0;
}

.bbgtk-wbs-section h3,
.bbgtk-wbs-protection h3{
    color:#073b78;
    font-size:30px;
    margin:0 0 22px;
}

.bbgtk-wbs-cards,
.bbgtk-wbs-steps{
    display:grid;
    grid-template-columns:repeat(4,1fr);
    gap:20px;
}

.bbgtk-wbs-cards div,
.bbgtk-wbs-steps div,
.bbgtk-wbs-channel div{
    background:#fff;
    border-radius:22px;
    padding:26px;
    box-shadow:0 14px 35px rgba(15,23,42,.08);
}

.bbgtk-wbs-cards div{
    font-size:34px;
}

.bbgtk-wbs-cards strong{
    display:block;
    color:#073b78;
    font-size:19px;
    margin:14px 0 8px;
}

.bbgtk-wbs-cards p{
    margin:0;
    color:#475569;
    font-size:15px;
    line-height:1.6;
}

.bbgtk-wbs-steps div{
    text-align:center;
    border-radius:18px;
    padding:24px;
}

.bbgtk-wbs-steps b{
    width:42px;
    height:42px;
    border-radius:50%;
    background:#073b78;
    color:#fff;
    display:grid;
    place-items:center;
    margin:0 auto 12px;
}

.bbgtk-wbs-steps span{
    color:#073b78;
    font-weight:900;
}

.bbgtk-wbs-protection{
    background:#eaf3ff;
    border-left:6px solid #073b78;
    border-radius:22px;
    padding:30px;
    margin:36px 0;
}

.bbgtk-wbs-protection ul{
    margin:0;
    padding-left:20px;
}

.bbgtk-wbs-protection li{
    margin-bottom:10px;
    color:#334155;
    line-height:1.7;
}

.bbgtk-wbs-channel{
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:22px;
}

.bbgtk-wbs-channel h4{
    margin:0 0 10px;
    color:#073b78;
    font-size:24px;
}

.bbgtk-wbs-channel p{
    color:#475569;
    line-height:1.7;
}

.bbgtk-wbs-form-wrap{
    margin-top:20px;
}

.bbgtk-wbs-form-head{
    display:none;
}

.bbgtk-wbs-form{
    background:#fff;
    border:1px solid #dbeafe;
    border-radius:24px;
    padding:32px;
    box-shadow:0 14px 35px rgba(15,23,42,.08);
}

.bbgtk-wbs-grid{
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:20px;
}

.bbgtk-wbs-full{
    grid-column:1 / -1;
}

.bbgtk-wbs-form label{
    display:block;
    color:#073b78;
    font-weight:800;
    margin-bottom:8px;
}

.bbgtk-wbs-form label small{
    color:#64748b;
    font-weight:600;
}

.bbgtk-wbs-form input,
.bbgtk-wbs-form select,
.bbgtk-wbs-form textarea{
    width:100%;
    border:1px solid #cbd5e1;
    border-radius:12px;
    padding:13px 14px;
    font-size:15px;
    background:#fff;
}

.bbgtk-wbs-form textarea{
    min-height:150px;
    resize:vertical;
}

.bbgtk-wbs-note{
    background:#eaf3ff;
    border-left:5px solid #073b78;
    border-radius:14px;
    padding:14px 16px;
    margin:22px 0;
    color:#334155;
    line-height:1.6;
}

.bbgtk-wbs-form button{
    border:0;
    background:#f59e0b;
    color:#073b78;
    font-weight:900;
    padding:14px 24px;
    border-radius:12px;
    cursor:pointer;
    font-size:15px;
}

.bbgtk-wbs-check{
    margin-top:30px;
    background:#fff;
    border:1px solid #dbeafe;
    border-radius:22px;
    padding:28px;
    box-shadow:0 14px 35px rgba(15,23,42,.08);
}

.bbgtk-wbs-check h3{
    margin:0 0 16px;
    color:#073b78;
    font-size:26px;
}

.bbgtk-wbs-check form{
    display:flex;
    gap:12px;
}

.bbgtk-wbs-check input{
    flex:1;
    border:1px solid #cbd5e1;
    border-radius:12px;
    padding:13px 14px;
}

.bbgtk-wbs-check button{
    border:0;
    background:#073b78;
    color:#fff;
    font-weight:800;
    padding:13px 20px;
    border-radius:12px;
}

.bbgtk-wbs-alert,
.bbgtk-wbs-status-box{
    background:#eaf3ff;
    border-radius:16px;
    padding:16px 18px;
    margin-bottom:20px;
    color:#073b78;
    font-weight:700;
}

.bbgtk-wbs-alert.success{
    background:#dcfce7;
    color:#166534;
}

.bbgtk-wbs-alert.failed,
.bbgtk-wbs-status-box.failed{
    background:#fee2e2;
    color:#991b1b;
}

/* =========================================================
   15. FLOATING MENU
========================================================= */
.bbgtk-float-menu{
    position:fixed;
    right:0;
    top:50%;
    transform:translateY(-50%);
    z-index:99999;
}

.bbgtk-float-label{
    background:#073b78;
    color:#fff;
    padding:13px 15px;
    border-radius:14px 0 0 14px;
    font-size:13px;
    font-weight:900;
    line-height:1.35;
    letter-spacing:.5px;
    text-align:center;
    cursor:pointer;
    box-shadow:0 10px 28px rgba(7,59,120,.25);
}

.bbgtk-float-panel{
    position:absolute;
    right:100%;
    top:50%;
    transform:translateY(-50%) translateX(10px);
    width:260px;
    background:#fff;
    border-radius:18px;
    padding:10px;
    box-shadow:0 18px 45px rgba(15,23,42,.18);
    opacity:0;
    visibility:hidden;
    transition:.25s ease;
}

.bbgtk-float-menu:hover .bbgtk-float-panel{
    opacity:1;
    visibility:visible;
    transform:translateY(-50%) translateX(-10px);
}

.bbgtk-float-panel a{
    display:flex;
    align-items:center;
    gap:10px;
    padding:13px 14px;
    border-radius:12px;
    color:#073b78;
    font-size:14px;
    font-weight:800;
    transition:.2s;
}

.bbgtk-float-panel a:hover{
    background:#eaf3ff;
    color:#f59e0b;
}

/* =========================================================
   16. BREADCRUMB & ERROR PAGES
========================================================= */
.bbgtk-breadcrumb-wrap{
    background:#f8fafc;
    border-bottom:1px solid #e2e8f0;
}

.bbgtk-breadcrumb{
    max-width:1200px;
    margin:0 auto;
    padding:12px 20px;
    font-size:14px;
    color:#64748b;
}

.bbgtk-breadcrumb a{
    color:#0b3a82;
    font-weight:700;
}

.bbgtk-breadcrumb span{
    margin:0 7px;
}

.bbgtk-404,
.bbgtk-error-page{
    min-height:70vh;
    display:flex;
    align-items:center;
    justify-content:center;
    padding:80px 20px;
    text-align:center;
    background:#f8fafc;
}

.bbgtk-404-inner,
.bbgtk-error-box{
    max-width:720px;
}

.bbgtk-error-box{
    background:#fff;
    border:1px solid #e2e8f0;
    border-radius:28px;
    padding:50px 35px;
    box-shadow:0 20px 50px rgba(15,23,42,.08);
}

.bbgtk-404-code,
.bbgtk-error-code{
    font-size:96px;
    line-height:1;
    font-weight:900;
    color:#0b3a82;
    margin-bottom:18px;
}

.bbgtk-404-code{
    font-size:120px;
}

.bbgtk-404 h1,
.bbgtk-error-box h1{
    margin:15px 0;
    font-size:34px;
    color:#0f172a;
}

.bbgtk-404 p,
.bbgtk-error-box p{
    font-size:17px;
    line-height:1.7;
    color:#64748b;
    margin:0 auto 28px;
}

.bbgtk-404-actions{
    display:flex;
    gap:12px;
    justify-content:center;
    flex-wrap:wrap;
    margin-bottom:30px;
}

.bbgtk-error-btn,
.bbgtk-404 .bbgtk-btn-primary{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    background:#0b3a82;
    color:#fff;
    padding:13px 24px;
    border-radius:999px;
    font-weight:700;
}

.bbgtk-error-btn:hover{
    background:#082f6d;
    color:#fff;
}

.bbgtk-404-search{
    display:flex;
    gap:10px;
    justify-content:center;
}

.bbgtk-404-search input{
    width:350px;
    max-width:100%;
    padding:12px 14px;
    border:1px solid #dbe3ef;
    border-radius:10px;
}

.bbgtk-404-search button{
    background:#f59e0b;
    border:none;
    color:#fff;
    padding:12px 20px;
    border-radius:10px;
    cursor:pointer;
}

/* =========================================================
   17. RESPONSIVE
========================================================= */
@media(max-width:900px){
    .admin-bar .bbgtk-header{
        top:46px;
    }

    .bbgtk-header-wrap{
        flex-wrap:wrap;
        padding:14px 0;
    }

    .bbgtk-logo img{
        height:46px;
    }

    .bbgtk-mobile-toggle{
        display:block !important;
        margin-left:auto;
        background:transparent;
        border:0;
        color:#fff;
        font-size:26px;
        cursor:pointer;
    }

    .bbgtk-nav{
        display:none;
        width:100%;
        order:5;
    }

    .bbgtk-nav.active{
        display:block;
    }

    .bbgtk-menu{
        flex-direction:column;
        align-items:flex-start;
        gap:0;
    }

    .bbgtk-menu > li,
    .bbgtk-menu .sub-menu{
        width:100%;
    }

    .bbgtk-menu > li > a{
        padding:12px 0;
    }

    .bbgtk-menu .sub-menu{
        position:static;
        opacity:1;
        visibility:visible;
        transform:none;
        box-shadow:none;
        background:rgba(255,255,255,.08);
        min-width:100%;
        margin-left:15px;
        border-radius:12px;
    }

    .bbgtk-search-desktop{
        display:none;
    }

    .bbgtk-search-mobile{
        display:block;
        background:transparent;
        border:0;
        color:#fff;
        font-size:15px;
        font-weight:700;
        padding:14px 0;
        cursor:pointer;
    }

    .bbgtk-search-box form,
    .bbgtk-search-hero,
    .bbgtk-search-hero form,
    .bbgtk-404-search,
    .bbgtk-wbs-check form{
        flex-direction:column;
    }

    .bbgtk-search-box button[type="submit"],
    .bbgtk-search-hero button{
        padding:14px 24px;
    }

    .bbgtk-hero{
        min-height:auto;
        padding:70px 0;
    }

    .bbgtk-hero h1{
        font-size:34px;
    }

    .bbgtk-hero .bbgtk-campaign{
        position:static;
        margin:24px auto 0;
        width:fit-content;
        max-width:92%;
    }

    .bbgtk-hero .bbgtk-campaign-grid{
        flex-wrap:wrap;
        justify-content:center;
    }

    .bbgtk-actions,
    .bbgtk-title-row{
        flex-direction:column;
        align-items:flex-start;
    }

    .bbgtk-news-grid,
    .bbgtk-main-services-grid,
    .bbgtk-media-agenda,
    .bbgtk-footer-grid,
    .bbgtk-archive-container,
    .bbgtk-single-container,
    .bbgtk-contact-layout,
    .bbgtk-wbs-cards,
    .bbgtk-wbs-steps,
    .bbgtk-wbs-channel,
    .bbgtk-wbs-grid{
        grid-template-columns:1fr;
    }

    .bbgtk-stats-grid,
    .bbgtk-archive-grid{
        grid-template-columns:repeat(2,1fr);
    }

    .bbgtk-pengumuman-item{
        grid-template-columns:58px 1fr;
    }

    .bbgtk-home-banner-section{
        margin:28px auto 42px;
    }

    .bbgtk-home-banner-wrap{
        border-radius:18px;
    }

    .bbgtk-home-banner-slide img{
        height:210px;
        object-fit:cover;
    }

    .bbgtk-banner-nav{
        width:38px;
        height:38px;
        font-size:24px;
    }

    .bbgtk-banner-prev{
        left:10px;
    }

    .bbgtk-banner-next{
        right:10px;
    }

    .bbgtk-archive-sidebar{
        padding-top:0;
    }

    .bbgtk-side-box{
        max-width:100%;
    }

    .bbgtk-post-item,
    .bbgtk-search-item{
        grid-template-columns:1fr;
    }

    .bbgtk-post-thumb,
    .bbgtk-search-img{
        height:210px;
        min-height:210px;
    }

    .bbgtk-single-article,
    .bbgtk-page-content{
        padding:26px;
        border-radius:20px;
    }

    .bbgtk-single-article h1{
        font-size:30px;
    }

    .bbgtk-page-hero{
        padding:55px 0;
    }

    .bbgtk-page-hero h1,
    .bbgtk-contact-head h2,
    .bbgtk-wbs-hero h2{
        font-size:32px;
    }

    .bbgtk-page-wrap{
        padding:40px 16px 60px;
    }

    .bbgtk-page-text{
        font-size:16px;
    }

    .bbgtk-contact-info iframe,
    .bbgtk-footer-map iframe{
        height:260px;
    }

    .bbgtk-wbs-hero{
        padding:32px;
    }

    .bbgtk-float-menu{
        display:none;
    }
}

@media(max-width:640px){
    .bbgtk-search-hero{
        padding:24px;
        border-radius:20px;
    }

    .bbgtk-search-hero h1{
        font-size:30px;
    }

    .bbgtk-search-item{
        padding:12px;
    }

    .bbgtk-error-code,
    .bbgtk-404-code{
        font-size:72px;
    }

    .bbgtk-error-box h1,
    .bbgtk-404 h1{
        font-size:27px;
    }

    .bbgtk-archive-grid,
    .bbgtk-stats-grid{
        grid-template-columns:1fr;
    }
}
/* =========================================================
   FIX HERO MOBILE
========================================================= */

@media(max-width:768px){
    .bbgtk-hero{
        min-height:auto !important;
        padding:42px 0 56px !important;
    }

    .bbgtk-hero .bbgtk-container{
        padding-left:22px !important;
        padding-right:22px !important;
    }

    .bbgtk-hero-grid{
        display:block !important;
    }

    .bbgtk-hero h1{
        font-size:38px !important;
        line-height:1.12 !important;
        max-width:92% !important;
        margin-bottom:18px !important;
    }

    .bbgtk-hero .bbgtk-desc{
        font-size:18px !important;
        line-height:1.75 !important;
        max-width:92% !important;
    }

    .bbgtk-hero .bbgtk-actions{
        margin-top:24px !important;
    }

    .bbgtk-hero .bbgtk-btn{
        width:auto !important;
        max-width:100%;
        padding:15px 22px !important;
        font-size:16px !important;
    }

    .bbgtk-hero [class*="campaign"],
    .bbgtk-hero .bbgtk-campaign{
        position:relative !important;
        width:100% !important;
        max-width:92% !important;
        margin:26px auto 0 !important;
        right:auto !important;
        top:auto !important;
        transform:none !important;
    }
}

@media(max-width:480px){
    .bbgtk-hero h1{
        font-size:34px !important;
    }

    .bbgtk-hero .bbgtk-desc{
        font-size:17px !important;
    }
}

@media (max-width:768px){

    .bbgtk-campaign{
        width:280px !important;
        max-width:280px !important;
        padding:18px !important;
        margin-left:auto !important;
        margin-right:0 !important;
    }

    .bbgtk-campaign img{
        max-width:100% !important;
        height:auto !important;
    }

}