/* ============================================================
   modern-list.css — CSS overlay ปรับหน้ารายการ (list) ให้ทันสมัย
   ใช้กับ markup .single-post-box / .title-post / .list-posts / .post-tags
   (หน้า category_list, list ของ procure ฯลฯ) — ไม่แก้ HTML/logic
   โทนสีเขียว อบต. ให้เข้าชุดกับหน้าหลัก (modern-home.css)
   ============================================================ */

:root{
    --ml-green-1:#5e7d1a;
    --ml-green-2:#3d5200;
    --ml-green-soft:#f3f7e9;
    --ml-ink:#1f2937;
    --ml-muted:#7a8694;
    --ml-line:#eef1f4;
    --ml-card-shadow:0 2px 10px rgba(20,40,10,.06);
    --ml-radius:14px;
}

.block-wrapper{ background:#f5f7f2; padding:24px 0 34px; -webkit-font-smoothing:antialiased; }

/* ---------- กล่องเนื้อหาหลัก ---------- */
.block-wrapper .single-post-box{
    background:#fff; border:1px solid var(--ml-line);
    border-radius:var(--ml-radius); box-shadow:var(--ml-card-shadow);
    padding:8px 22px 18px; margin-bottom:20px;
}

/* ---------- หัวข้อหมวด ---------- */
.block-wrapper .title-post{ margin:8px 0 6px; }
.block-wrapper .title-post h3{
    position:relative; font-size:21px; font-weight:800; color:var(--ml-ink) !important;
    margin:0; padding:8px 0 14px 0; line-height:1.4;
}
.block-wrapper .title-post h3 font{ color:var(--ml-ink) !important; }
.block-wrapper .title-post h3::after{
    content:""; position:absolute; left:0; bottom:0;
    width:60px; height:3px; border-radius:3px;
    background:linear-gradient(135deg, var(--ml-green-1), var(--ml-green-2));
}

/* ---------- รายการประกาศ ---------- */
.block-wrapper .list-posts{ margin:14px 0 0; padding:0; list-style:none; }
.block-wrapper .list-posts > li{
    position:relative;
    border:1px solid var(--ml-line);
    border-radius:11px;
    padding:13px 16px 13px 18px;
    margin-bottom:11px;
    background:#fff;
    transition:background .18s ease, box-shadow .18s ease, transform .18s ease, border-color .18s ease;
}
.block-wrapper .list-posts > li::before{
    content:""; position:absolute; left:0; top:12px; bottom:12px; width:4px;
    border-radius:0 4px 4px 0; background:linear-gradient(180deg, var(--ml-green-1), var(--ml-green-2));
    opacity:0; transition:opacity .18s ease;
}
.block-wrapper .list-posts > li:hover{
    background:var(--ml-green-soft); border-color:#dbe7c2;
    box-shadow:var(--ml-card-shadow); transform:translateX(2px);
}
.block-wrapper .list-posts > li:hover::before{ opacity:1; }

.block-wrapper .list-posts .post-content{ padding:0; }
.block-wrapper .list-posts .post-content h2{
    font-size:15.5px; line-height:1.55; margin:0 0 6px; font-weight:600;
}
.block-wrapper .list-posts .post-content h2 a{
    color:var(--ml-ink); display:flex; align-items:flex-start; gap:9px;
    transition:color .15s ease;
}
.block-wrapper .list-posts .post-content h2 a:hover{ color:var(--ml-green-1); text-decoration:none; }
/* ไอคอนนำหน้าหัวข้อ → ชิปวงกลมเขียว */
.block-wrapper .list-posts .post-content h2 a .fa-play-circle-o{
    flex:0 0 auto; margin-top:1px;
    width:22px; height:22px; line-height:22px; text-align:center;
    background:var(--ml-green-soft); color:var(--ml-green-1);
    border-radius:50%; font-size:12px;
}

/* meta วันที่ */
.block-wrapper .list-posts .post-tags{ margin:0; padding:0; list-style:none; }
.block-wrapper .list-posts .post-tags > li{
    display:inline-flex; align-items:center; gap:6px;
    color:var(--ml-muted); font-size:12.5px;
}
.block-wrapper .list-posts .post-tags > li .fa-clock-o{ color:var(--ml-green-1); }

/* ---------- pagination ---------- */
.block-wrapper .dataTables_paginate .pagination > li > a,
.block-wrapper .dataTables_paginate .pagination > li > span{
    color:var(--ml-green-2); border-radius:8px !important; margin:0 3px;
    border:1px solid var(--ml-line); padding:7px 13px;
}
.block-wrapper .dataTables_paginate .pagination > .active > a,
.block-wrapper .dataTables_paginate .pagination > .active > span,
.block-wrapper .dataTables_paginate .pagination > li > a:hover{
    background:linear-gradient(135deg, var(--ml-green-1), var(--ml-green-2));
    border-color:var(--ml-green-2); color:#fff;
}

/* ============================================================
   การ์ดเอกสาร (procure category_view) — ดีไซน์เต็มรูป
   ============================================================ */
.block-wrapper .proc-box{ padding:0; overflow:hidden; border:0; background:transparent; box-shadow:none; }

/* hero หัวหมวด */
.proc-hero{
    display:flex; align-items:center; gap:16px;
    background:linear-gradient(135deg, var(--ml-green-1), var(--ml-green-2));
    border-radius:var(--ml-radius); padding:20px 24px; margin-bottom:18px;
    box-shadow:0 8px 22px rgba(61,82,0,.22);
}
.proc-hero-ic{
    flex:0 0 auto; width:54px; height:54px; border-radius:14px;
    background:rgba(255,255,255,.18); color:#fff; font-size:24px;
    display:flex; align-items:center; justify-content:center;
}
.proc-hero-tx h3{ margin:0 0 4px; color:#fff; font-size:21px; font-weight:800; line-height:1.35; }
.proc-hero-count{ color:#eaf3d6; font-size:13.5px; font-weight:600; }
.proc-hero-count i{ margin-right:5px; }

/* รายการการ์ด */
.proc-list{ list-style:none; margin:0; padding:0; }
.proc-list > li{ margin-bottom:12px; }
.proc-card{
    display:flex; align-items:stretch; gap:0;
    background:#fff; border:1px solid var(--ml-line); border-radius:13px;
    overflow:hidden; box-shadow:var(--ml-card-shadow);
    transition:transform .2s ease, box-shadow .2s ease, border-color .2s ease;
    text-decoration:none;
}
.proc-card:hover{
    transform:translateY(-3px); border-color:#cfe08a;
    box-shadow:0 12px 26px rgba(61,82,0,.16); text-decoration:none;
}

/* date badge */
.proc-date{
    flex:0 0 78px; display:flex; flex-direction:column; align-items:center; justify-content:center;
    background:linear-gradient(160deg, var(--ml-green-soft), #e9f1d4);
    border-right:1px solid #e4ecd0; padding:12px 6px; text-align:center;
}
.proc-card:hover .proc-date{ background:linear-gradient(160deg, var(--ml-green-1), var(--ml-green-2)); }
.proc-date .d{ font-size:26px; font-weight:800; color:var(--ml-green-2); line-height:1; }
.proc-date .m{ font-size:13px; font-weight:700; color:var(--ml-green-1); margin-top:3px; }
.proc-date .y{ font-size:11px; color:#8a9a6a; margin-top:2px; }
.proc-card:hover .proc-date .d,
.proc-card:hover .proc-date .m{ color:#fff; }
.proc-card:hover .proc-date .y{ color:#dbe7bd; }

/* เนื้อหา */
.proc-main{ flex:1; min-width:0; padding:14px 16px; display:flex; flex-direction:column; justify-content:center; }
.proc-title{
    font-size:15.5px; font-weight:600; color:var(--ml-ink); margin:0 0 7px; line-height:1.55;
    display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden;
}
.proc-card:hover .proc-title{ color:var(--ml-green-2); }
.proc-meta{ font-size:12.5px; color:var(--ml-muted); }
.proc-meta i{ color:var(--ml-green-1); margin-right:5px; }

/* ปุ่มดูประกาศ */
.proc-go{
    flex:0 0 auto; display:flex; flex-direction:column; align-items:center; justify-content:center; gap:6px;
    padding:0 18px; border-left:1px dashed #e4ecd0; color:var(--ml-green-1);
}
.proc-go-tx{ font-size:12px; font-weight:700; white-space:nowrap; }
.proc-go-tx i{ margin-right:4px; }
.proc-go-arr{ font-size:20px; transition:transform .2s ease; }
.proc-card:hover .proc-go{ color:var(--ml-green-2); }
.proc-card:hover .proc-go-arr{ transform:translateX(4px); }

/* ============================================================
   การ์ดข่าวมีรูป (news category_view)
   ============================================================ */
.block-wrapper .news-grid{ margin-left:-8px; margin-right:-8px; }
.block-wrapper .news-grid > div{ padding:8px; margin-bottom:6px; }
.news-card{
    display:flex; flex-direction:column; height:100%;
    background:#fff; border:1px solid var(--ml-line); border-radius:14px; overflow:hidden;
    box-shadow:var(--ml-card-shadow); text-decoration:none;
    transition:transform .2s ease, box-shadow .2s ease, border-color .2s ease;
}
.news-card:hover{
    transform:translateY(-4px); border-color:#cfe08a;
    box-shadow:0 14px 28px rgba(61,82,0,.16); text-decoration:none;
}
.news-thumb{ position:relative; height:200px; overflow:hidden; background:#eef3e6; }
.news-thumb img{ width:100%; height:100%; object-fit:cover; transition:transform .45s ease; }
.news-card:hover .news-thumb img{ transform:scale(1.06); }
.news-cat{
    position:absolute; left:12px; top:12px;
    background:linear-gradient(135deg, var(--ml-green-1), var(--ml-green-2)); color:#fff;
    font-size:12px; font-weight:700; padding:4px 13px; border-radius:20px;
    box-shadow:0 3px 8px rgba(0,0,0,.22); max-width:80%; white-space:nowrap; overflow:hidden; text-overflow:ellipsis;
}
.news-body{ padding:15px 16px 4px; flex:1; }
.news-title{
    font-size:16px; font-weight:700; color:var(--ml-ink); line-height:1.5; margin:0 0 11px;
    display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden; min-height:48px;
}
.news-card:hover .news-title{ color:var(--ml-green-2); }
.news-meta{ display:flex; flex-wrap:wrap; gap:14px; font-size:12.5px; color:var(--ml-muted); }
.news-meta span{ display:inline-flex; align-items:center; }
.news-meta i{ color:var(--ml-green-1); margin-right:5px; }
.news-more{
    display:inline-flex; align-items:center; gap:6px; margin:8px 16px 16px;
    color:var(--ml-green-1); font-size:13px; font-weight:700;
}
.news-more i{ transition:transform .2s ease; }
.news-card:hover .news-more i{ transform:translateX(4px); }

@media (max-width:767px){
    .block-wrapper{ padding:14px 0 24px; }
    .block-wrapper .single-post-box{ padding:6px 14px 14px; }
    .block-wrapper .title-post h3{ font-size:18px; }
    .block-wrapper .list-posts .post-content h2{ font-size:14.5px; }
    .proc-hero{ padding:16px; gap:12px; }
    .proc-hero-tx h3{ font-size:18px; }
    .proc-date{ flex-basis:64px; }
    .proc-date .d{ font-size:22px; }
    .proc-go-tx{ display:none; }
    .proc-go{ padding:0 14px; }
    .news-thumb{ height:175px; }
    .news-title{ font-size:15px; min-height:0; }
}

/* ============================================================
   อัลบั้มภาพ (gallery list_view) — grid การ์ดปก
   ============================================================ */
.block-wrapper .gal-grid{ margin-left:-7px; margin-right:-7px; }
.block-wrapper .gal-grid > div{ padding:7px; margin-bottom:6px; }
.gal-card{
    display:block; height:100%; background:#fff; border:1px solid var(--ml-line);
    border-radius:14px; overflow:hidden; box-shadow:var(--ml-card-shadow); text-decoration:none;
    transition:transform .2s ease, box-shadow .2s ease, border-color .2s ease;
}
.gal-card:hover{
    transform:translateY(-4px); border-color:#cfe08a;
    box-shadow:0 14px 28px rgba(61,82,0,.18); text-decoration:none;
}
.gal-thumb{ position:relative; height:185px; overflow:hidden; background:#eef3e6; }
.gal-thumb img{ width:100%; height:100%; object-fit:cover; transition:transform .45s ease; }
.gal-card:hover .gal-thumb img{ transform:scale(1.07); }
.gal-thumb::after{
    content:""; position:absolute; left:0; right:0; bottom:0; height:46%;
    background:linear-gradient(to top, rgba(0,0,0,.45), rgba(0,0,0,0));
    opacity:0; transition:opacity .2s ease;
}
.gal-card:hover .gal-thumb::after{ opacity:1; }
.gal-count{
    position:absolute; right:10px; top:10px; z-index:2;
    background:rgba(15,23,42,.62); color:#fff; font-size:12px; font-weight:700;
    padding:4px 11px; border-radius:20px; backdrop-filter:blur(2px);
}
.gal-count i{ margin-right:5px; }
.gal-body{ padding:13px 15px 15px; }
.gal-title{
    font-size:15.5px; font-weight:700; color:var(--ml-ink); line-height:1.5; margin:0 0 8px;
    display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden; min-height:46px;
}
.gal-card:hover .gal-title{ color:var(--ml-green-2); }
.gal-meta{ font-size:12.5px; color:var(--ml-muted); }
.gal-meta i{ color:var(--ml-green-1); margin-right:5px; }
@media (max-width:767px){ .gal-thumb{ height:160px; } .gal-title{ font-size:14.5px; min-height:0; } }

/* ============================================================
   การ์ดวิดีโอ (video list_view) — thumbnail + play -> modal
   ============================================================ */
.block-wrapper .vid-grid{ margin-left:-8px; margin-right:-8px; }
.block-wrapper .vid-grid > div{ padding:8px; margin-bottom:6px; }
.vid-card{
    background:#fff; border:1px solid var(--ml-line); border-radius:14px; overflow:hidden;
    box-shadow:var(--ml-card-shadow); cursor:pointer; height:100%;
    transition:transform .2s ease, box-shadow .2s ease, border-color .2s ease;
}
.vid-card:hover{ transform:translateY(-4px); border-color:#cfe08a; box-shadow:0 14px 28px rgba(61,82,0,.16); }
.vid-thumb{ position:relative; padding-top:56.25%; overflow:hidden; background:#000; }
.vid-thumb img{ position:absolute; top:0; left:0; width:100%; height:100%; object-fit:cover; transition:transform .45s ease, opacity .2s ease; }
.vid-card:hover .vid-thumb img{ transform:scale(1.06); opacity:.82; }
.vid-play{
    position:absolute; top:50%; left:50%; transform:translate(-50%,-50%);
    width:58px; height:58px; border-radius:50%; background:rgba(220,38,38,.92); color:#fff;
    display:flex; align-items:center; justify-content:center; font-size:24px; padding-left:4px;
    box-shadow:0 4px 16px rgba(0,0,0,.4); transition:transform .2s ease, background .2s ease;
}
.vid-card:hover .vid-play{ transform:translate(-50%,-50%) scale(1.12); background:#dc2626; }
.vid-body{ padding:13px 15px 15px; }
.vid-title{
    font-size:15.5px; font-weight:700; color:var(--ml-ink); line-height:1.5; margin:0 0 8px;
    display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden; min-height:46px;
}
.vid-card:hover .vid-title{ color:var(--ml-green-2); }
.vid-meta{ font-size:12.5px; color:var(--ml-muted); }
.vid-meta i{ color:var(--ml-green-1); margin-right:5px; }

/* modal player */
.vidf-modal{ display:none; position:fixed; inset:0; width:100%; height:100%; background:rgba(8,12,20,.92); z-index:2147483600; }
.vidf-modal.open{ display:block; }
.vidf-box{ position:absolute; top:50%; left:50%; transform:translate(-50%,-50%); width:90%; max-width:900px; }
.vidf-close{ position:absolute; top:-46px; right:0; background:rgba(255,255,255,.14); border:0; color:#fff;
    width:40px; height:40px; border-radius:50%; font-size:24px; line-height:38px; cursor:pointer; }
.vidf-close:hover{ background:rgba(255,255,255,.28); }
.vidf-frame{ position:relative; padding-top:56.25%; background:#000; border-radius:12px; overflow:hidden; box-shadow:0 16px 50px rgba(0,0,0,.6); }
.vidf-frame iframe{ position:absolute; top:0; left:0; width:100%; height:100%; border:0; }
.vidf-cap{ color:#fff; font-size:15px; font-weight:600; margin-top:14px; text-align:center; line-height:1.5; }
@media (max-width:767px){ .vid-title{ font-size:14.5px; min-height:0; } .vid-play{ width:48px; height:48px; font-size:20px; } }

/* ============================================================
   หน้ารายละเอียดเอกสาร (procure/report/plan preview)
   ============================================================ */
.detail-head{
    background:linear-gradient(135deg, #ffffff, #f3f7e9);
    border:1px solid #e4ecd0; border-radius:14px; padding:20px 22px; margin-bottom:18px;
    box-shadow:var(--ml-card-shadow); position:relative;
}
.detail-back{
    display:inline-flex; align-items:center; gap:6px; font-size:13px; font-weight:700;
    color:var(--ml-green-2); background:#fff; border:1px solid #d9e8bf; border-radius:20px;
    padding:5px 14px; margin-bottom:12px; transition:background .15s, color .15s;
}
.detail-back:hover{ background:var(--ml-green-1); color:#fff; text-decoration:none; }
.detail-cat{
    display:inline-block; margin-left:8px; font-size:12.5px; font-weight:700; color:var(--ml-green-1);
    background:var(--ml-green-soft); border-radius:20px; padding:5px 13px;
}
.detail-cat i{ margin-right:5px; }
.detail-title{
    font-size:22px; font-weight:800; color:var(--ml-ink); line-height:1.5; margin:6px 0 12px;
}
.detail-meta{ display:flex; flex-wrap:wrap; gap:8px 18px; font-size:13px; color:var(--ml-muted); margin-bottom:4px; }
.detail-meta span{ display:inline-flex; align-items:center; }
.detail-meta i{ color:var(--ml-green-1); margin-right:6px; }
.detail-dl{ margin-top:14px; display:flex; flex-wrap:wrap; gap:10px; align-items:center; }
.detail-dl:empty{ display:none; }
.detail-dl img{ transition:transform .15s; }
.detail-dl a:hover img{ transform:scale(1.08); }

.detail-body{ background:#fff; border:1px solid var(--ml-line); border-radius:14px; padding:14px; box-shadow:var(--ml-card-shadow); }
.detail-body p{ margin:0; }

/* แถบเครื่องมือเอกสาร */
.detail-doc-bar{
    display:flex; flex-wrap:wrap; align-items:center; justify-content:space-between; gap:10px;
    padding:4px 4px 12px; margin-bottom:12px; border-bottom:1px solid var(--ml-line);
}
.detail-doc-pages{ font-size:13.5px; font-weight:700; color:var(--ml-green-2); }
.detail-doc-pages i{ color:#dc2626; margin-right:6px; }
.detail-doc-actions{ display:flex; gap:8px; }
.detail-doc-btn{
    display:inline-flex; align-items:center; gap:6px; font-size:12.5px; font-weight:600;
    color:var(--ml-green-2); background:var(--ml-green-soft); border:1px solid #d9e8bf;
    border-radius:8px; padding:6px 13px; transition:background .15s, color .15s;
}
.detail-doc-btn:hover{ background:var(--ml-green-1); color:#fff; text-decoration:none; }
.detail-doc-btn.dl{ color:#0369a1; background:#e8f4fb; border-color:#bfe0f2; }
.detail-doc-btn.dl:hover{ background:#0369a1; color:#fff; }

#pdfviewer{
    width:100% !important; min-height:420px; height:600px;
    border:1px solid var(--ml-line); border-radius:10px; display:block; background:#f8fafc;
}
/* เนื้อหาบทความ (กรณีเป็น HTML ไม่ใช่ PDF เช่นข่าว) */
.detail-doc.is-article{ font-size:15.5px; color:#374151; line-height:1.9; padding:4px 4px 8px; }
.detail-doc.is-article img{ max-width:100% !important; height:auto !important; border-radius:10px; margin:10px auto; display:block; box-shadow:0 2px 10px rgba(20,40,10,.08); }
.detail-doc.is-article p{ margin:0 0 15px; }
.detail-doc.is-article h1,.detail-doc.is-article h2,.detail-doc.is-article h3,.detail-doc.is-article h4{ color:var(--ml-ink); line-height:1.5; margin:20px 0 10px; font-weight:700; }
.detail-doc.is-article a{ color:var(--ml-green-1); text-decoration:underline; }
.detail-doc.is-article table{ max-width:100%; border-collapse:collapse; margin:10px 0; }
.detail-doc.is-article iframe{ max-width:100%; border-radius:10px; }
.detail-empty{ text-align:center; padding:50px 0; color:#94a3b8; }
.detail-empty i{ font-size:40px; }
@media (max-width:767px){
    .detail-title{ font-size:18px; }
    .detail-doc-bar{ justify-content:flex-start; }
}
