/* =========================================================
   Kunagram Village Info — Main Stylesheet
   Institutional / Government style, mobile-first, Bangla-first
   ========================================================= */

:root{
    --kg-primary: #0b6e4f;      /* institutional green - overridden by Customizer */
    --kg-primary-dark: #084d38;
    --kg-accent: #c99b30;       /* gold accent */
    --kg-bg: #f7f8f5;
    --kg-card-bg: #ffffff;
    --kg-text: #22281f;
    --kg-text-light: #5a6357;
    --kg-border: #e3e6de;
    --kg-danger: #b3261e;
    --kg-radius: 10px;
    --kg-shadow: 0 2px 10px rgba(20,30,20,.06);
    --kg-shadow-hover: 0 6px 20px rgba(20,30,20,.12);
    --font-bn: 'Hind Siliguri', 'Noto Sans Bengali', 'SolaimanLipi', sans-serif;
    --font-en: 'Noto Sans Bengali', 'Hind Siliguri', 'Segoe UI', Arial, sans-serif;
}

/* ---------- Reset ---------- */
*,*::before,*::after{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
    margin:0;
    background:var(--kg-bg);
    color:var(--kg-text);
    font-family:var(--font-bn);
    font-size:16px;
    line-height:1.75;
    -webkit-font-smoothing:antialiased;
}
img{max-width:100%;height:auto;display:block;}
a{color:var(--kg-primary);text-decoration:none;}
a:hover{color:var(--kg-accent);}
ul{list-style:none;margin:0;padding:0;}
h1,h2,h3,h4,h5,h6{
    font-family:var(--font-bn);
    font-weight:700;
    line-height:1.35;
    margin:0 0 .6em;
    color:var(--kg-primary-dark);
}
p{margin:0 0 1em;}
button,input,textarea,select{font-family:inherit;font-size:1em;}
.screen-reader-text{
    position:absolute!important;width:1px;height:1px;overflow:hidden;
    clip:rect(1px,1px,1px,1px);white-space:nowrap;
}
.container{max-width:1180px;margin:0 auto;padding:0 16px;}
.section{padding:44px 0;}
.section-title{
    display:flex;align-items:center;gap:10px;
    font-size:1.5rem;margin-bottom:24px;
    border-bottom:3px solid var(--kg-accent);
    padding-bottom:10px;
}
.section-title .dashicons{color:var(--kg-accent);}
.section-title-en{
    font-size:.85rem;color:var(--kg-text-light);font-weight:400;
    display:block;margin-top:2px;
}
.btn{
    display:inline-block;padding:10px 22px;border-radius:6px;
    background:var(--kg-primary);color:#fff;font-weight:700;border:none;
    cursor:pointer;transition:.2s;
}
.btn:hover{background:var(--kg-primary-dark);color:#fff;}
.btn-outline{
    background:transparent;border:2px solid var(--kg-primary);color:var(--kg-primary);
}
.btn-outline:hover{background:var(--kg-primary);color:#fff;}

/* ---------- Skip Link ---------- */
.skip-link{
    position:absolute;left:-9999px;top:0;background:var(--kg-primary);color:#fff;
    padding:10px 18px;z-index:9999;
}
.skip-link:focus{left:10px;top:10px;}

/* ---------- Top Utility Bar ---------- */
.kg-topbar{
    background:var(--kg-primary-dark);color:#eef4ee;font-size:.85rem;
}
.kg-topbar .container{display:flex;align-items:center;justify-content:space-between;gap:16px;padding-top:6px;padding-bottom:6px;flex-wrap:wrap;}
.kg-topbar a{color:#eef4ee;}
.kg-topbar .kg-topbar-left{display:flex;gap:16px;flex-wrap:wrap;align-items:center;}
.kg-lang-switch{display:flex;gap:6px;align-items:center;}
.kg-lang-switch button{
    background:transparent;border:1px solid rgba(255,255,255,.4);color:#eef4ee;
    padding:2px 10px;border-radius:20px;cursor:pointer;font-size:.8rem;
}
.kg-lang-switch button.active{background:var(--kg-accent);border-color:var(--kg-accent);color:#1a1a1a;font-weight:700;}

/* ---------- Announcement Ticker ---------- */
.kg-ticker{
    background:var(--kg-accent);color:#28210a;overflow:hidden;position:relative;
    display:flex;align-items:center;
}
.kg-ticker-label{
    flex:0 0 auto;background:var(--kg-danger);color:#fff;font-weight:700;
    padding:8px 16px;font-size:.85rem;white-space:nowrap;z-index:2;
}
.kg-ticker-track{
    flex:1 1 auto;overflow:hidden;white-space:nowrap;position:relative;
}
.kg-ticker-inner{
    display:inline-block;padding-left:100%;
    animation:kg-ticker-scroll 30s linear infinite;
}
.kg-ticker-inner a{color:#28210a;font-weight:600;margin-right:60px;}
@keyframes kg-ticker-scroll{
    0%{transform:translateX(0);}
    100%{transform:translateX(-100%);}
}
.kg-ticker:hover .kg-ticker-inner{animation-play-state:paused;}

/* ---------- Header ---------- */
.kg-header{
    background:#fff;box-shadow:var(--kg-shadow);position:sticky;top:0;z-index:500;
}
.kg-header-inner{
    display:flex;align-items:center;justify-content:space-between;
    padding:12px 0;gap:16px;
}
.kg-brand{display:flex;align-items:center;gap:12px;}
.kg-brand img{height:56px;width:auto;border-radius:6px;}
.kg-brand-text .kg-site-title{
    font-size:1.35rem;margin:0;color:var(--kg-primary-dark);
}
.kg-brand-text .kg-site-tagline{
    font-size:.8rem;color:var(--kg-text-light);margin:0;
}

/* ---------- Nav ---------- */
.kg-nav-toggle{
    display:flex;flex-direction:column;justify-content:center;gap:5px;
    width:42px;height:42px;border:1px solid var(--kg-border);border-radius:6px;
    background:#fff;cursor:pointer;
}
.kg-nav-toggle span{display:block;height:2px;background:var(--kg-primary-dark);border-radius:2px;}
.kg-primary-nav{
    background:var(--kg-primary);
}
.kg-primary-nav ul{display:flex;flex-wrap:wrap;}
.kg-primary-nav ul li{position:relative;}
.kg-primary-nav ul li a{
    display:block;padding:12px 16px;color:#fff;font-weight:600;font-size:.95rem;
}
.kg-primary-nav ul li a:hover,
.kg-primary-nav ul li.current-menu-item > a{background:var(--kg-primary-dark);color:#fff;}
.kg-primary-nav ul ul{
    position:absolute;left:0;top:100%;min-width:200px;background:var(--kg-primary-dark);
    display:none;flex-direction:column;z-index:100;box-shadow:var(--kg-shadow-hover);
}
.kg-primary-nav ul li:hover > ul{display:flex;}

@media (max-width:860px){
    .kg-nav-toggle{display:flex;}
    .kg-primary-nav{display:none;position:absolute;left:0;right:0;top:100%;}
    .kg-primary-nav.is-open{display:block;}
    .kg-primary-nav ul{flex-direction:column;}
    .kg-primary-nav ul ul{position:static;display:none;box-shadow:none;}
    .kg-primary-nav ul li.submenu-open > ul{display:flex;}
    .kg-header-inner{position:relative;}
}
@media (min-width:861px){
    .kg-nav-toggle{display:none;}
}

/* ---------- Hero ---------- */
.kg-hero{
    position:relative;color:#fff;background:linear-gradient(180deg,rgba(8,77,56,.75),rgba(8,77,56,.9)),var(--kg-primary);
    background-size:cover;background-position:center;padding:70px 0;text-align:center;
}
.kg-hero h1{color:#fff;font-size:2.2rem;margin-bottom:8px;}
.kg-hero .kg-hero-en{font-size:1rem;opacity:.85;margin-bottom:18px;font-family:var(--font-en);}
.kg-hero p.kg-hero-desc{max-width:700px;margin:0 auto 20px;opacity:.95;}
.kg-hero-actions{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;}
.kg-hero-stats{
    display:flex;justify-content:center;gap:30px;margin-top:30px;flex-wrap:wrap;
}
.kg-hero-stats div{background:rgba(255,255,255,.12);padding:14px 22px;border-radius:8px;min-width:120px;}
.kg-hero-stats strong{display:block;font-size:1.5rem;color:var(--kg-accent);}

/* ---------- Cards / Grid ---------- */
.kg-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;}
@media (max-width:960px){.kg-grid{grid-template-columns:repeat(2,1fr);}}
@media (max-width:640px){.kg-grid{grid-template-columns:1fr;}}

.kg-card{
    background:var(--kg-card-bg);border:1px solid var(--kg-border);border-radius:var(--kg-radius);
    overflow:hidden;box-shadow:var(--kg-shadow);transition:.2s;display:flex;flex-direction:column;
}
.kg-card:hover{box-shadow:var(--kg-shadow-hover);transform:translateY(-3px);}
.kg-card-thumb{aspect-ratio:16/10;overflow:hidden;background:var(--kg-border);}
.kg-card-thumb img{width:100%;height:100%;object-fit:cover;}
.kg-card-body{padding:16px;flex:1;display:flex;flex-direction:column;}
.kg-card-cat{
    display:inline-block;background:var(--kg-primary);color:#fff;font-size:.72rem;
    padding:2px 10px;border-radius:20px;margin-bottom:8px;align-self:flex-start;
}
.kg-card-title{font-size:1.05rem;margin-bottom:8px;}
.kg-card-title a{color:var(--kg-primary-dark);}
.kg-card-meta{font-size:.78rem;color:var(--kg-text-light);margin-bottom:8px;}
.kg-card-excerpt{font-size:.9rem;color:var(--kg-text-light);flex:1;}
.kg-card-link{margin-top:10px;font-weight:700;font-size:.85rem;}

/* ---------- Notice Board ---------- */
.kg-notice-section{background:#fff4e0;border:1px solid #f0d9a6;border-radius:var(--kg-radius);padding:22px;}
.kg-notice-list li{
    display:flex;justify-content:space-between;gap:12px;align-items:flex-start;
    padding:12px 0;border-bottom:1px dashed #e6cd8f;
}
.kg-notice-list li:last-child{border-bottom:none;}
.kg-notice-list a{font-weight:700;color:var(--kg-primary-dark);}
.kg-notice-date{font-size:.78rem;background:var(--kg-danger);color:#fff;padding:2px 10px;border-radius:14px;white-space:nowrap;}
.kg-notice-pdf{font-size:.78rem;margin-left:8px;color:var(--kg-primary);}

/* ---------- Services Grid ---------- */
.kg-service-item{
    background:#fff;border:1px solid var(--kg-border);border-radius:var(--kg-radius);
    text-align:center;padding:26px 16px;box-shadow:var(--kg-shadow);transition:.2s;
}
.kg-service-item:hover{box-shadow:var(--kg-shadow-hover);transform:translateY(-3px);}
.kg-service-icon{
    width:60px;height:60px;margin:0 auto 14px;border-radius:50%;background:var(--kg-primary);
    color:#fff;display:flex;align-items:center;justify-content:center;font-size:1.6rem;
}
.kg-service-item img.kg-service-icon-img{width:60px;height:60px;margin:0 auto 14px;border-radius:50%;object-fit:cover;}
.kg-service-item h3{font-size:1rem;margin-bottom:6px;}
.kg-service-item p{font-size:.85rem;color:var(--kg-text-light);}

/* ---------- Village Info Section ---------- */
.kg-village-info{display:grid;grid-template-columns:1.1fr .9fr;gap:30px;align-items:start;}
@media (max-width:860px){.kg-village-info{grid-template-columns:1fr;}}
.kg-village-info-text h3{font-size:1.15rem;color:var(--kg-primary);margin-top:20px;}
.kg-village-info-text h3:first-child{margin-top:0;}
.kg-map-wrap{border-radius:var(--kg-radius);overflow:hidden;box-shadow:var(--kg-shadow);}
.kg-map-wrap iframe{width:100%;height:340px;border:0;display:block;}

/* ---------- Emergency Contacts ---------- */
.kg-emergency{background:var(--kg-primary-dark);color:#fff;}
.kg-emergency .section-title{color:#fff;border-color:var(--kg-accent);}
.kg-emergency-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;}
@media (max-width:860px){.kg-emergency-grid{grid-template-columns:repeat(2,1fr);}}
@media (max-width:480px){.kg-emergency-grid{grid-template-columns:1fr;}}
.kg-emergency-item{background:rgba(255,255,255,.08);border-radius:8px;padding:16px;text-align:center;}
.kg-emergency-item .kg-emergency-num{font-size:1.3rem;font-weight:700;color:var(--kg-accent);display:block;margin-top:6px;}

/* ---------- Footer ---------- */
.kg-footer{background:#0d3c2b;color:#d9e5db;padding:40px 0 0;}
.kg-footer a{color:#d9e5db;}
.kg-footer a:hover{color:var(--kg-accent);}
.kg-footer-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:28px;}
@media (max-width:860px){.kg-footer-grid{grid-template-columns:repeat(2,1fr);}}
@media (max-width:480px){.kg-footer-grid{grid-template-columns:1fr;}}
.kg-footer h4{color:#fff;font-size:1rem;margin-bottom:14px;border-bottom:2px solid var(--kg-accent);padding-bottom:6px;display:inline-block;}
.kg-footer ul li{margin-bottom:8px;font-size:.9rem;}
.kg-footer-social{display:flex;gap:10px;margin-top:10px;}
.kg-footer-social a{
    width:36px;height:36px;border-radius:50%;background:rgba(255,255,255,.1);
    display:flex;align-items:center;justify-content:center;
}
.kg-footer-bottom{
    border-top:1px solid rgba(255,255,255,.12);margin-top:30px;padding:16px 0;
    text-align:center;font-size:.82rem;
}

/* ---------- Single Post / Page ---------- */
.kg-content-wrap{display:grid;grid-template-columns:2fr 1fr;gap:30px;padding:36px 0;}
@media (max-width:860px){.kg-content-wrap{grid-template-columns:1fr;}}
.kg-entry{background:#fff;border:1px solid var(--kg-border);border-radius:var(--kg-radius);padding:26px;box-shadow:var(--kg-shadow);}
.kg-entry-title{font-size:1.7rem;}
.kg-entry-meta{color:var(--kg-text-light);font-size:.85rem;margin-bottom:18px;}
.kg-entry-thumb{margin-bottom:20px;border-radius:var(--kg-radius);overflow:hidden;}
.kg-entry-content h2{font-size:1.3rem;}
.kg-entry-content h3{font-size:1.1rem;}
.kg-entry-content img{border-radius:8px;}
.kg-entry-content table{width:100%;border-collapse:collapse;}
.kg-entry-content table td,.kg-entry-content table th{border:1px solid var(--kg-border);padding:8px;}
.kg-pdf-download{
    display:inline-flex;align-items:center;gap:8px;background:var(--kg-primary);color:#fff;
    padding:10px 18px;border-radius:6px;margin-top:16px;font-weight:700;
}
.kg-pdf-download:hover{background:var(--kg-primary-dark);color:#fff;}
.kg-lang-note{
    background:#eef6ee;border-left:4px solid var(--kg-primary);padding:10px 14px;font-size:.85rem;
    margin-bottom:16px;border-radius:4px;
}

/* Sidebar */
.kg-sidebar .widget{
    background:#fff;border:1px solid var(--kg-border);border-radius:var(--kg-radius);
    padding:18px;margin-bottom:22px;box-shadow:var(--kg-shadow);
}
.kg-sidebar .widget-title{font-size:1.05rem;border-bottom:2px solid var(--kg-accent);padding-bottom:8px;margin-bottom:12px;}
.kg-sidebar ul li{padding:6px 0;border-bottom:1px dashed var(--kg-border);font-size:.9rem;}
.kg-sidebar ul li:last-child{border-bottom:none;}

/* Archive / Search */
.kg-archive-title{font-size:1.4rem;margin-bottom:6px;}
.kg-pagination{display:flex;gap:8px;justify-content:center;margin-top:30px;flex-wrap:wrap;}
.kg-pagination a,.kg-pagination span{
    padding:8px 14px;border:1px solid var(--kg-border);border-radius:6px;background:#fff;font-size:.9rem;
}
.kg-pagination .current{background:var(--kg-primary);color:#fff;border-color:var(--kg-primary);}

/* Search form */
.kg-search-form{position:relative;display:flex;}
.kg-search-form input[type="search"]{
    flex:1;padding:10px 14px;border:1px solid var(--kg-border);border-radius:6px 0 0 6px;
}
.kg-search-form button{
    border:none;background:var(--kg-primary);color:#fff;padding:0 16px;border-radius:0 6px 6px 0;cursor:pointer;
}
#kg-ajax-search-results{
    position:absolute;top:100%;left:0;right:0;background:#fff;border:1px solid var(--kg-border);
    box-shadow:var(--kg-shadow-hover);z-index:50;max-height:340px;overflow:auto;border-radius:0 0 8px 8px;
}
#kg-ajax-search-results a{display:block;padding:10px 14px;border-bottom:1px solid var(--kg-border);font-size:.88rem;color:var(--kg-text);}
#kg-ajax-search-results a:hover{background:var(--kg-bg);}

/* ---------- Notice Popup Modal ---------- */
.kg-popup-overlay{
    position:fixed;inset:0;background:rgba(10,20,10,.55);display:flex;align-items:center;justify-content:center;
    z-index:9999;padding:16px;
}
.kg-popup-box{
    background:#fff;border-radius:12px;max-width:480px;width:100%;padding:26px;position:relative;
    box-shadow:0 20px 50px rgba(0,0,0,.3);text-align:center;
}
.kg-popup-box .kg-popup-tag{
    background:var(--kg-danger);color:#fff;font-size:.75rem;padding:3px 12px;border-radius:20px;
    display:inline-block;margin-bottom:12px;
}
.kg-popup-close{
    position:absolute;top:10px;right:12px;background:none;border:none;font-size:1.4rem;cursor:pointer;color:var(--kg-text-light);
}

/* ---------- 404 ---------- */
.kg-404{text-align:center;padding:70px 20px;}
.kg-404 h1{font-size:5rem;color:var(--kg-accent);margin-bottom:0;}

/* ---------- Comments ---------- */
.kg-comments{margin-top:30px;}
.comment-list{list-style:none;margin:0;padding:0;}
.comment-list .comment-body{background:#fafbf8;border:1px solid var(--kg-border);border-radius:8px;padding:14px;margin-bottom:14px;}
.comment-form input,.comment-form textarea{
    width:100%;padding:10px;border:1px solid var(--kg-border);border-radius:6px;margin-bottom:10px;
}

/* Utility */
.text-center{text-align:center;}
.mt-0{margin-top:0;}
.kg-hidden{display:none!important;}
