/* =====================================================================
   JOVA AQUA / SOHA REEF — CSS trang công khai (SEO/tin tức)
   Dùng cho: tin-tuc.php, chuyen-muc.php, bai-viet.php
   ===================================================================== */
:root{
  --bg:#04101a;--bg2:#071a2b;--card:#0c2236;--card2:#102a42;--line:#1c3247;
  --aqua:#3fd0e8;--teal:#1bbf9c;--teal-d:#0f7a6a;--muted:#7b93a8;--text:#dce5ec;--amber:#ffb02e
}
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:'Be Vietnam Pro',sans-serif;background:var(--bg);color:var(--text);line-height:1.7;-webkit-font-smoothing:antialiased}
a{text-decoration:none}
.wrap{max-width:1100px;margin:0 auto;padding:0 22px}
img{max-width:100%}

/* ===== HEADER ===== */
.pub-head{background:rgba(7,22,38,.92);backdrop-filter:blur(12px);border-bottom:1px solid var(--line);position:sticky;top:0;z-index:100}
.pub-head-in{display:flex;align-items:center;gap:20px;padding:13px 22px;max-width:1100px;margin:0 auto}
.brand{display:flex;align-items:center;gap:10px;color:#fff}
.brand .lg{width:38px;height:38px;border-radius:11px;background:linear-gradient(135deg,var(--teal),var(--aqua));display:grid;place-items:center;font-size:20px;flex:none}
.brand-tx b{font-family:'Be Vietnam Pro';font-size:16px;display:block;line-height:1.1}
.brand-tx span{font-size:10.5px;color:var(--muted)}
.pub-nav{display:flex;gap:4px;margin-left:14px;flex:1}
.pub-nav a{color:#aebfce;font-size:14px;font-weight:500;padding:8px 13px;border-radius:9px;transition:all .15s}
.pub-nav a:hover{background:rgba(255,255,255,.06);color:#fff}
.openapp{background:linear-gradient(135deg,var(--teal-d),var(--teal));color:#fff;padding:9px 18px;border-radius:10px;font-size:13.5px;font-weight:600;white-space:nowrap}
.pub-burger{display:none;background:none;border:none;color:#fff;font-size:22px;cursor:pointer}
.pub-mnav{display:none;flex-direction:column;border-top:1px solid var(--line);padding:8px 22px 14px}
.pub-mnav a{color:#cdd9e5;padding:11px 4px;border-bottom:1px solid var(--line);font-size:14.5px}
body.mnav .pub-mnav{display:flex}

/* ===== MAIN ===== */
main{padding:30px 0 50px;min-height:60vh}
.crumb{font-size:12.5px;color:var(--muted);margin-bottom:20px}
.crumb a{color:var(--aqua)}

/* hero đầu trang blog */
.blog-hero-head{margin-bottom:24px}
.blog-hero-head h1{font-family:'Be Vietnam Pro';font-size:34px;font-weight:700;color:#fff;line-height:1.2;margin-bottom:10px}
.blog-hero-head p{font-size:15.5px;color:var(--muted);max-width:680px}

/* thanh category */
.cat-bar{display:flex;gap:9px;flex-wrap:wrap;margin-bottom:28px}
.cat-pill{background:var(--card);border:1px solid var(--line);color:#aebfce;padding:8px 16px;border-radius:11px;font-size:13.5px;font-weight:500;transition:all .15s}
.cat-pill:hover{border-color:var(--aqua);color:#fff}
.cat-pill.on{background:linear-gradient(135deg,var(--teal-d),var(--teal));color:#fff;border-color:transparent}

/* bài nổi bật */
.feat-card{display:grid;grid-template-columns:1.3fr 1fr;gap:0;background:var(--card);border:1px solid var(--line);border-radius:20px;overflow:hidden;margin-bottom:38px;transition:transform .2s,border-color .2s}
.feat-card:hover{transform:translateY(-3px);border-color:var(--aqua)}
.feat-thumb{background:linear-gradient(135deg,#0c2840,#0a3a4a);background-size:cover;background-position:center;min-height:280px}
.feat-body{padding:32px 30px;display:flex;flex-direction:column;justify-content:center}
.feat-body h2{font-family:'Be Vietnam Pro';font-size:25px;color:#fff;line-height:1.3;margin:12px 0}
.feat-body p{font-size:14.5px;color:var(--muted);line-height:1.6;margin-bottom:16px;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
.readmore{color:var(--aqua);font-weight:600;font-size:14px}
.cat-badge{display:inline-block;background:rgba(27,191,156,.15);color:var(--teal);padding:4px 12px;border-radius:8px;font-size:12px;font-weight:600;width:fit-content}

.sec-h{font-family:'Be Vietnam Pro';font-size:22px;color:#fff;margin-bottom:18px}

/* lưới bài viết */
.post-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.post-card{background:var(--card);border:1px solid var(--line);border-radius:16px;overflow:hidden;transition:transform .18s,border-color .18s}
.post-card:hover{transform:translateY(-4px);border-color:var(--aqua)}
.post-thumb{aspect-ratio:16/9;background:linear-gradient(135deg,#0c2840,#0a3a4a);background-size:cover;background-position:center}
.post-info{padding:15px 16px}
.post-cat{display:inline-block;font-size:11.5px;color:var(--teal);font-weight:600;margin-bottom:7px}
.post-info b{display:block;font-size:15.5px;color:#fff;line-height:1.4;margin-bottom:7px;font-family:'Be Vietnam Pro';font-weight:600}
.post-ex{font-size:13px;color:var(--muted);line-height:1.55;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}

/* ===== ARTICLE (bai-viet) ===== */
.art-wrap{max-width:760px;margin:0 auto}
article h1{font-family:'Be Vietnam Pro';font-size:31px;font-weight:700;line-height:1.25;margin-bottom:12px;color:#fff}
.art-meta{font-size:13px;color:var(--muted);margin-bottom:22px;border-bottom:1px solid var(--line);padding-bottom:18px}
.art-thumb{width:100%;border-radius:16px;margin-bottom:26px;aspect-ratio:16/9;object-fit:cover}
.content{font-size:16.5px}
.content h2{font-family:'Be Vietnam Pro';font-size:24px;color:#fff;margin:30px 0 13px}
.content h3{font-family:'Be Vietnam Pro';font-size:19.5px;color:var(--aqua);margin:24px 0 10px}
.content h4{font-size:17px;color:#fff;margin:18px 0 8px}
.content p{margin:0 0 17px}
.content ul,.content ol{margin:0 0 17px;padding-left:24px}
.content li{margin-bottom:8px}
.content img{max-width:100%;height:auto;border-radius:12px;margin:16px 0}
.content b,.content strong{color:#fff}
.content a{color:var(--aqua);text-decoration:none;border-bottom:1px solid rgba(63,208,232,.4);transition:border-color .15s}
.content a:hover{border-bottom-color:var(--aqua)}
.content a[data-param]{font-weight:600;border-bottom:1px dotted var(--aqua)}
.content blockquote{border-left:3px solid var(--teal);background:var(--card);padding:12px 18px;border-radius:0 10px 10px 0;margin:16px 0;color:#c3d2de}
.content table{width:100%;border-collapse:collapse;margin:16px 0;font-size:14.5px}
.content th,.content td{border:1px solid var(--line);padding:9px 12px;text-align:left}
.content th{background:var(--card);color:#fff}

/* bài liên quan */
.related{margin-top:44px;border-top:1px solid var(--line);padding-top:30px}
.rel-title{font-family:'Be Vietnam Pro';font-size:21px;color:#fff;margin-bottom:18px}
.rel-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}
.rel-card{background:var(--card);border:1px solid var(--line);border-radius:14px;overflow:hidden;transition:transform .15s,border-color .15s}
.rel-card:hover{transform:translateY(-3px);border-color:var(--aqua)}
.rel-thumb{aspect-ratio:16/9;background:linear-gradient(135deg,#0c2840,#0a3a4a);background-size:cover;background-position:center}
.rel-info{padding:13px 15px}
.rel-info b{display:block;font-size:14.5px;color:#fff;line-height:1.4;margin-bottom:6px}
.rel-info span{font-size:12.5px;color:var(--muted);line-height:1.5;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}

/* ===== FOOTER ===== */
.pub-foot{background:var(--bg2);border-top:1px solid var(--line);padding:38px 0 26px;margin-top:50px}
.pub-foot-top{display:grid;grid-template-columns:1.8fr 1fr 1fr 1.1fr;gap:28px;margin-bottom:26px}
.pub-foot-desc{font-size:13px;color:var(--muted);margin-top:12px;max-width:340px;line-height:1.6}
.pub-foot-links{display:flex;flex-direction:column;gap:9px}
.pub-foot-links b{color:#fff;font-size:14px;margin-bottom:4px;font-family:'Be Vietnam Pro'}
.pub-foot-links a{color:var(--muted);font-size:13.5px}
.pub-foot-links a:hover{color:var(--aqua)}
.pub-foot-cp{border-top:1px solid var(--line);padding-top:18px;font-size:12.5px;color:var(--muted);text-align:center}

/* ===== RESPONSIVE ===== */
@media(max-width:880px){
  .pub-nav{display:none}
  .pub-burger{display:block}
  .openapp{padding:8px 13px;font-size:12.5px}
  .post-grid{grid-template-columns:repeat(2,1fr)}
  .feat-card{grid-template-columns:1fr}
  .feat-thumb{min-height:200px}
  .pub-foot-top{grid-template-columns:1fr 1fr}
}
@media(max-width:560px){
  .pub-foot-top{grid-template-columns:1fr}
  .blog-hero-head h1{font-size:26px}
  .post-grid{grid-template-columns:1fr}
  .rel-grid{grid-template-columns:1fr}
  article h1{font-size:25px}
  .content{font-size:16px}
}

/* =====================================================================
   LANDING — trang chủ + trang tính năng
   ===================================================================== */
.btn-primary{display:inline-block;background:linear-gradient(135deg,var(--teal-d),var(--teal));color:#fff;padding:13px 26px;border-radius:12px;font-size:15px;font-weight:600;transition:transform .15s}
.btn-primary:hover{transform:translateY(-2px)}
.btn-ghost{display:inline-block;background:rgba(255,255,255,.06);color:#cdd9e5;padding:13px 22px;border-radius:12px;font-size:15px;font-weight:500;border:1px solid var(--line)}
.btn-ghost:hover{border-color:var(--aqua);color:#fff}
.lead{font-size:17px;color:#aebfce;line-height:1.65;margin-bottom:24px;max-width:560px}
.feat-cta{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:14px}
.feat-note{font-size:13px;color:var(--muted)}
.sec-h.center{text-align:center}

/* HERO trang chủ */
.home-hero{padding:46px 0 30px;background:radial-gradient(ellipse at top right,rgba(27,191,156,.1),transparent 60%)}
.home-hero-in,.feat-hero{display:grid;grid-template-columns:1.1fr .9fr;gap:40px;align-items:center}
.home-hero-tx h1{font-family:'Be Vietnam Pro';font-size:42px;font-weight:700;color:#fff;line-height:1.15;margin:14px 0}
.feat-hero{padding:30px 0 18px}
.feat-hero-tx h1{font-family:'Be Vietnam Pro';font-size:33px;font-weight:700;color:#fff;line-height:1.22;margin:12px 0}

/* phone mockup (vẽ bằng CSS) */
.phone-mock{width:300px;max-width:100%;margin:0 auto;background:linear-gradient(160deg,#0c2438,#081726);border:1px solid var(--line);border-radius:28px;padding:16px;box-shadow:0 24px 60px rgba(0,0,0,.5)}
.phone-screen{background:#04101a;border-radius:18px;padding:16px;min-height:300px}
.mk-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px;margin-bottom:12px}
.mk-cell{background:var(--card);border:1px solid var(--line);border-radius:11px;padding:10px 8px;font-size:11px;color:var(--muted);position:relative}
.mk-cell b{display:block;font-family:'Be Vietnam Pro';font-size:17px;color:#fff;margin-top:3px}
.mk-cell i{font-size:9px;color:var(--muted)}
.mk-dot{display:inline-block;width:7px;height:7px;border-radius:50%;margin-right:4px}
.mk-dot.ok{background:#2ecc8f}.mk-dot.warn{background:#ffb02e}.mk-dot.bad{background:#ff6b4a}
.mk-chart{background:var(--card);border:1px solid var(--line);border-radius:12px;padding:12px;height:90px}
.mk-chart svg{width:100%;height:100%}
.mk-icp-head{background:rgba(46,204,143,.12);color:#9fe8c8;border-radius:10px;padding:9px 12px;font-size:12px;margin-bottom:10px}
.mk-row{display:flex;align-items:center;gap:8px;background:var(--card);border:1px solid var(--line);border-radius:9px;padding:9px 12px;margin-bottom:7px;font-size:12.5px;color:#cdd9e5}
.mk-row b{color:#fff}
.mk-row.danger{border-color:rgba(255,80,60,.4);background:rgba(255,60,40,.08)}
.mk-bad{margin-left:auto;color:#ffb02e;font-weight:600;font-size:11.5px}
.mk-ok{margin-left:auto;color:#2ecc8f;font-weight:600;font-size:11.5px}
.mk-danger{margin-left:auto;color:#ff6b4a;font-weight:700;font-size:11.5px}
.mk-gauge{display:flex;align-items:center;gap:16px;background:var(--card);border:1px solid var(--line);border-radius:14px;padding:16px;margin-bottom:12px}
.mk-ring{width:84px;height:84px;border-radius:50%;background:conic-gradient(#ffb02e 0% 78%,rgba(255,255,255,.08) 78% 100%);display:grid;place-items:center;flex:none;position:relative}
.mk-ring::before{content:'';position:absolute;inset:9px;background:var(--card);border-radius:50%}
.mk-ring b{position:relative;font-family:'Be Vietnam Pro';font-size:20px;color:#fff;line-height:1}
.mk-ring span{position:relative;font-size:8.5px;color:var(--muted)}
.mk-badge{display:inline-block;padding:3px 11px;border-radius:8px;font-size:12px;font-weight:600;margin-bottom:6px}
.mk-badge.warn{background:rgba(255,176,46,.15);color:#ffb02e}
.mk-gtxt p{font-size:12px;color:var(--muted)}
.mk-warn{background:rgba(255,176,46,.1);color:#ffd591;border-radius:10px;padding:10px 12px;font-size:12px}
.mk-task{display:flex;align-items:center;gap:11px;background:var(--card);border:1px solid var(--line);border-radius:11px;padding:11px;margin-bottom:8px}
.mk-task span{font-size:18px}.mk-task b{display:block;font-size:13px;color:#fff}.mk-task i{font-size:11px;color:var(--muted)}
.mk-task.overdue{border-left:3px solid #ff6b4a}.mk-task.today{border-left:3px solid var(--teal)}

/* feature cards trang chủ */
.home-feats{padding:40px 0}
.feat-cards{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-top:24px}
.feat-card-home{background:var(--card);border:1px solid var(--line);border-radius:16px;padding:24px 20px;transition:transform .18s,border-color .18s;display:flex;flex-direction:column}
.feat-card-home:hover{transform:translateY(-4px);border-color:var(--aqua)}
.fc-ic{font-size:32px;margin-bottom:12px}
.feat-card-home b{font-family:'Be Vietnam Pro';font-size:17px;color:#fff;margin-bottom:8px}
.feat-card-home span{font-size:13.5px;color:var(--muted);line-height:1.55;flex:1}
.fc-more{color:var(--aqua);font-size:13.5px;font-weight:600;font-style:normal;margin-top:14px}

/* kiến thức trang chủ */
.home-kb{padding:30px 0}
.home-kb-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:18px}
.seeall{color:var(--aqua);font-weight:600;font-size:14px}

/* nội dung trang tính năng */
.feat-content{max-width:780px;margin:10px auto 0}
.feat-block{margin-bottom:28px}
.feat-block h2{font-family:'Be Vietnam Pro';font-size:23px;color:#fff;margin-bottom:10px}
.feat-block p{font-size:16px;color:#c3d2de;line-height:1.7}

/* CTA box */
.feat-cta-box{text-align:center;background:linear-gradient(135deg,#0c2840,#0a2a3a);border:1px solid var(--line);border-radius:22px;padding:44px 24px;margin:42px auto;max-width:880px}
.feat-cta-box h2{font-family:'Be Vietnam Pro';font-size:27px;color:#fff;margin-bottom:10px}
.feat-cta-box p{font-size:15px;color:var(--muted);margin-bottom:22px}

/* link tính năng khác */
.feat-others{margin-top:30px}
.feat-links{display:flex;flex-wrap:wrap;gap:12px}
.feat-links a{background:var(--card);border:1px solid var(--line);border-radius:11px;padding:11px 18px;color:#cdd9e5;font-size:14px;font-weight:500}
.feat-links a:hover{border-color:var(--aqua);color:#fff}

@media(max-width:880px){
  .home-hero-in,.feat-hero{grid-template-columns:1fr;gap:28px}
  .home-hero-demo,.feat-hero-demo{order:-1}
  .home-hero-tx h1{font-size:32px}
  .feat-hero-tx h1{font-size:26px}
  .feat-cards{grid-template-columns:1fr 1fr}
}
@media(max-width:560px){
  .home-hero-tx h1{font-size:27px}
  .feat-cards{grid-template-columns:1fr}
}

/* Be Vietnam Pro cho tiêu đề — weight đậm cho đẹp & rõ tiếng Việt */
h1,.home-hero-tx h1,.feat-hero-tx h1,.blog-hero-head h1{font-weight:800;letter-spacing:-.01em}
h2,.sec-h,.feat-block h2,.feat-cta-box h2,.feat-body h2,.feat-card-home b{font-weight:700}
.post-info b,.rel-info b,.brand-tx b{font-weight:700}
body{letter-spacing:.005em}

/* =====================================================================
   FIX MOBILE — tinh chỉnh giao diện điện thoại
   ===================================================================== */
@media(max-width:768px){
  .wrap{padding:0 16px}
  main{padding:20px 0 36px}

  /* HEADER thoáng hơn */
  .pub-head-in{padding:11px 16px;gap:10px}
  .brand .lg{width:34px;height:34px;font-size:18px}
  .brand-tx b{font-size:15px}
  .brand-tx span{font-size:9.5px}
  .openapp{padding:8px 14px;font-size:12.5px;margin-left:auto}
  .pub-burger{font-size:21px;padding:2px 4px}

  /* HERO: text trước, demo nhỏ lại ở dưới */
  .home-hero{padding:24px 0 18px}
  .home-hero-tx h1{font-size:25px;line-height:1.2}
  .feat-hero-tx h1{font-size:23px}
  .lead{font-size:14.5px;margin-bottom:18px}
  .phone-mock{width:240px;padding:12px;border-radius:22px}
  .phone-screen{min-height:auto;padding:13px;border-radius:15px}
  .mk-grid{gap:6px;margin-bottom:9px}
  .mk-cell{padding:8px 6px}
  .mk-cell b{font-size:15px}
  .feat-cta{gap:9px}
  .btn-primary,.btn-ghost{padding:11px 18px;font-size:14px}

  /* SECTION spacing đều lại */
  .home-feats{padding:26px 0}
  .home-kb{padding:20px 0}
  .sec-h{font-size:19px}
  .sec-h.center{font-size:20px;line-height:1.3}
  .feat-cards{gap:12px;margin-top:18px}

  /* FEATURE CARD: icon trái + nội dung phải (gọn) */
  .feat-card-home{display:grid;grid-template-columns:46px 1fr;grid-template-rows:auto auto auto;column-gap:14px;row-gap:4px;padding:16px 16px;align-items:start}
  .fc-ic{font-size:26px;margin:0;grid-row:1/3;align-self:center}
  .feat-card-home b{font-size:15.5px;margin:0;grid-column:2}
  .feat-card-home span{font-size:13px;grid-column:2;line-height:1.5}
  .fc-more{grid-column:2;margin-top:6px;font-size:13px}

  /* CARD KIẾN THỨC: ảnh thấp lại */
  .post-thumb{aspect-ratio:auto;height:140px}
  .post-grid{gap:14px}
  .post-info{padding:13px 14px}
  .post-info b{font-size:15px}

  /* feat nổi bật blog */
  .feat-thumb{min-height:170px}
  .feat-body{padding:20px 18px}
  .feat-body h2{font-size:20px}

  /* CTA box gọn */
  .feat-cta-box{padding:32px 20px;margin:30px auto;border-radius:18px}
  .feat-cta-box h2{font-size:22px}
  .feat-cta-box p{font-size:14px}

  /* blog hero head */
  .blog-hero-head h1{font-size:25px}
  .blog-hero-head p{font-size:14px}
  .cat-bar{gap:7px;margin-bottom:20px}
  .cat-pill{padding:7px 13px;font-size:12.5px}

  /* footer gọn */
  .pub-foot{padding:30px 0 22px}
  .pub-foot-top{gap:22px}
}

@media(max-width:560px){
  .home-hero-tx h1{font-size:23px}
  .feat-cards{grid-template-columns:1fr}
}

@media(max-width:768px){
  /* mobile nhỏ: text lên trước, demo xuống dưới cho gọn */
  .home-hero-demo,.feat-hero-demo{order:1}
}

/* Logo full thật trên header/footer */
.brand-logo-full{height:44px;width:auto;display:block}
@media(max-width:768px){.brand-logo-full{height:36px}}

/* ===================================================================== */
/* CỘNG ĐỒNG WEB — feed social đầy đủ (.cmw-*)                            */
/* ===================================================================== */
.cmw-shell{max-width:1080px;margin:0 auto;padding:20px 16px 40px}
/* hero */
.cmw-hero{text-align:center;padding:40px 20px 30px;background:linear-gradient(180deg,rgba(27,191,156,.1),rgba(46,127,212,.04),transparent);border-radius:20px;margin-bottom:24px}
.cmw-hero-badge{display:inline-block;background:rgba(27,191,156,.15);color:var(--teal,#1bbf9c);border:1px solid rgba(27,191,156,.3);padding:5px 15px;border-radius:20px;font-size:13px;font-weight:600;margin-bottom:14px}
.cmw-hero h1{font-size:32px;margin:0 0 10px;color:#fff;font-weight:800}
.cmw-hero p{color:var(--muted,#6b8299);max-width:560px;margin:0 auto 20px;line-height:1.6}
.cmw-hero-stats{display:flex;justify-content:center;gap:30px;margin-bottom:22px}
.cmw-stat b{display:block;font-size:26px;color:var(--aqua,#3fd0e8);font-weight:800}
.cmw-stat span{font-size:12px;color:var(--muted,#6b8299)}
.cmw-cta{display:inline-block;background:linear-gradient(135deg,#1bbf9c,#2e7fd4);color:#fff;padding:12px 26px;border-radius:12px;font-weight:600;text-decoration:none;font-size:15px;transition:transform .15s}
.cmw-cta:hover{transform:translateY(-2px)}
/* 2 cột */
.cmw-2col{display:grid;grid-template-columns:1fr 300px;gap:24px;align-items:start}
.cmw-main{min-width:0}
/* tabs */
.cmw-tabs{display:flex;gap:8px;margin-bottom:18px;flex-wrap:wrap}
.cmw-tab{padding:9px 18px;border-radius:20px;font-size:14px;background:var(--card,#0f2a45);border:1px solid var(--line,#1c3247);color:var(--muted,#6b8299);text-decoration:none;transition:all .15s}
.cmw-tab:hover{border-color:rgba(63,208,232,.4)}
.cmw-tab.on{background:rgba(27,191,156,.15);border-color:var(--teal,#1bbf9c);color:var(--teal,#1bbf9c);font-weight:600}
/* feed */
.cmw-feed{display:flex;flex-direction:column;gap:16px}
.cmw-post{background:var(--card,#0f2a45);border:1px solid var(--line,#1c3247);border-radius:16px;padding:16px 18px;transition:border-color .15s}
.cmw-post:hover{border-color:rgba(63,208,232,.3)}
.cmw-post-head{display:flex;align-items:center;gap:11px;margin-bottom:12px}
.cmw-avatar{width:42px;height:42px;border-radius:50%;background:linear-gradient(135deg,#1bbf9c,#0f7a6a);display:grid;place-items:center;color:#fff;font-weight:700;font-size:17px;flex:none;overflow:hidden}
.cmw-avatar.sm{width:34px;height:34px;font-size:14px;background:linear-gradient(135deg,#2e7fd4,#7b5cff)}
.cmw-avatar.has-img img{width:100%;height:100%;object-fit:cover;display:block}
.cmw-post-who{flex:1;min-width:0}
.cmw-post-name{font-size:14.5px;font-weight:700;color:#fff;display:flex;align-items:center;gap:6px;flex-wrap:wrap}
.cmw-verify{background:rgba(63,208,232,.15);color:var(--aqua,#3fd0e8);font-size:10px;padding:1px 7px;border-radius:8px;font-weight:600}
.cmw-post-meta{font-size:12px;color:var(--muted,#6b8299);margin-top:1px}
.cmw-type{font-size:11px;font-weight:700;padding:4px 11px;border-radius:9px;flex:none}
.cmw-type.frag{background:rgba(27,191,156,.18);color:var(--teal,#1bbf9c)}
.cmw-type.tank{background:rgba(123,92,255,.18);color:#9d85ff}
.cmw-type.gift{background:rgba(255,176,46,.18);color:var(--amber,#ffb02e)}
.cmw-type.swap{background:rgba(255,176,46,.18);color:var(--amber,#ffb02e)}
.cmw-post-link{text-decoration:none;color:inherit;display:block}
.cmw-post-title{font-size:17px;font-weight:700;color:#fff;margin:0 0 7px;line-height:1.4}
.cmw-post-body{font-size:14px;color:#c5d2dd;line-height:1.6;margin:0 0 12px}
.cmw-specs{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:12px}
.cmw-spec{background:rgba(46,204,143,.1);border:1px solid rgba(46,204,143,.28);color:var(--ok,#2ecc8f);font-size:12px;padding:3px 10px;border-radius:8px;font-weight:500}
/* ảnh feed */
.cmw-post-photo{display:grid;gap:4px;margin-bottom:12px;border-radius:12px;overflow:hidden}
.cmw-post-photo.multi{grid-template-columns:2fr 1fr 1fr}
.cmw-pimg{display:block;height:280px;background:#0a2740;position:relative;overflow:hidden}
.cmw-pimg>img{width:100%;height:100%;object-fit:cover;display:block}
.cmw-post-photo.multi .cmw-pimg{height:170px}
.cmw-pimg.cmw-noimg{background:linear-gradient(135deg,#13405e,#0a2740);display:grid;place-items:center;font-size:48px;color:#2d5876}
.cmw-pimg em{position:absolute;inset:0;background:rgba(4,16,26,.6);display:grid;place-items:center;color:#fff;font-size:22px;font-style:normal;font-weight:700}
/* foot */
.cmw-post-foot{display:flex;justify-content:space-between;align-items:center;gap:10px;flex-wrap:wrap;padding-top:11px;border-top:1px solid rgba(255,255,255,.06);margin-bottom:10px}
.cmw-react{display:flex;gap:14px;font-size:12.5px;color:var(--muted,#6b8299)}
.cmw-price-locked{font-size:12px;color:#d8c08a;white-space:nowrap}
.cmw-post-cta{display:block;text-align:center;background:rgba(63,208,232,.1);border:1px solid rgba(63,208,232,.25);color:var(--aqua,#3fd0e8);padding:9px;border-radius:10px;text-decoration:none;font-size:13.5px;font-weight:600}
.cmw-post-cta:hover{background:rgba(63,208,232,.18)}
/* sidebar phải */
.cmw-side{display:flex;flex-direction:column;gap:16px;position:sticky;top:16px}
.cmw-side-card{background:var(--card,#0f2a45);border:1px solid var(--line,#1c3247);border-radius:14px;padding:16px 17px}
.cmw-side-card h3{font-size:15px;margin:0 0 9px;color:#fff}
.cmw-side-card p{font-size:13px;color:#aebccb;line-height:1.6;margin:0 0 12px}
.cmw-side-btn{display:block;text-align:center;background:linear-gradient(135deg,#1bbf9c,#2e7fd4);color:#fff;padding:10px;border-radius:10px;text-decoration:none;font-weight:600;font-size:14px}
.cmw-side-list{margin:0;padding:0;list-style:none}
.cmw-side-list li{font-size:13px;color:#c5d2dd;line-height:1.5;padding:7px 0 7px 22px;position:relative;border-bottom:1px solid rgba(255,255,255,.05)}
.cmw-side-list li:before{content:"✓";position:absolute;left:0;color:var(--teal,#1bbf9c);font-weight:700}
.cmw-side-list li:last-child{border:none}
.cmw-side-note{font-size:12px;color:var(--muted,#6b8299);line-height:1.6;background:rgba(255,176,46,.06);border-color:rgba(255,176,46,.2)}
.cmw-side-note b{color:var(--amber,#ffb02e)}
/* empty */
.cmw-empty{text-align:center;padding:50px 20px;color:var(--muted,#6b8299);background:var(--card,#0f2a45);border:1px solid var(--line,#1c3247);border-radius:16px}
.cmw-empty p{margin:14px 0 18px;font-size:15px}
/* ===== CHI TIẾT BÀI ===== */
.cmw-detail{max-width:760px}
.cmw-back{display:inline-block;color:var(--aqua,#3fd0e8);text-decoration:none;font-size:14px;margin-bottom:16px}
.cmw-post-full{padding:22px 24px}
.cmw-detail-title{font-size:24px;font-weight:800;color:#fff;margin:4px 0 12px;line-height:1.35}
.cmw-detail-body{font-size:15px;color:#d2dde6;line-height:1.7;margin-bottom:16px}
.cmw-detail-specs{background:rgba(46,204,143,.06);border:1px solid rgba(46,204,143,.2);border-radius:12px;padding:13px 15px;margin-bottom:16px}
.cmw-specs-label{font-size:12px;color:var(--ok,#2ecc8f);font-weight:600;margin-bottom:8px}
.cmw-detail-imgs{display:flex;flex-direction:column;gap:10px;margin-bottom:18px}
.cmw-detail-img{background:#06141f;border-radius:14px;overflow:hidden;display:flex;justify-content:center;align-items:center;max-height:560px}
.cmw-detail-img img{max-width:100%;max-height:560px;width:auto;height:auto;object-fit:contain;display:block}
.cmw-gated{display:flex;gap:14px;align-items:flex-start;background:linear-gradient(135deg,rgba(255,176,46,.08),rgba(27,191,156,.04));border:1px solid rgba(255,176,46,.25);border-radius:14px;padding:18px 20px;margin-bottom:18px}
.cmw-gated-ic{font-size:30px;flex:none}
.cmw-gated b{color:#fff;font-size:15px}
.cmw-gated p{color:#c5d2dd;font-size:13.5px;line-height:1.6;margin:6px 0 12px}
.cmw-detail-stats{font-size:13.5px;color:var(--muted,#6b8299);padding-top:14px;border-top:1px solid rgba(255,255,255,.07)}
/* comment section */
.cmw-comments-sec{background:var(--card,#0f2a45);border:1px solid var(--line,#1c3247);border-radius:16px;padding:20px 22px;margin-top:18px}
.cmw-comments-h{font-size:17px;color:#fff;margin:0 0 16px}
.cmw-no-comment{color:var(--muted,#6b8299);font-size:14px;text-align:center;padding:20px}
.cmw-comment{display:flex;gap:11px;margin-bottom:14px}
.cmw-comment-bub{background:rgba(255,255,255,.03);border-radius:14px;padding:10px 14px;flex:1;font-size:14px;color:#d2dde6;line-height:1.55}
.cmw-comment-bub b{display:flex;align-items:center;gap:6px;font-size:13.5px;color:#fff;margin-bottom:3px}
.cmw-comment-time{display:block;font-size:11px;color:var(--muted,#6b8299);margin-top:5px}
.cmw-comment-cta{text-align:center;margin-top:18px;padding-top:16px;border-top:1px solid rgba(255,255,255,.06)}
/* responsive */
@media(max-width:880px){.cmw-2col{grid-template-columns:1fr}.cmw-side{position:static;flex-direction:row;overflow-x:auto}.cmw-side-card{min-width:240px}.cmw-side-note{display:none}}
@media(max-width:600px){.cmw-hero h1{font-size:25px}.cmw-hero-stats{gap:20px}.cmw-pimg{height:220px}.cmw-detail-img{max-height:360px}.cmw-detail-img img{max-height:360px}.cmw-side{flex-direction:column}.cmw-side-card{min-width:0}}

/* ============ TRANG HỒ SƠ NGƯỜI CHƠI (public SEO) ============ */
.pf-pub{max-width:760px;margin:0 auto;padding:18px 16px 60px}
.pf-pub-head{display:flex;gap:16px;align-items:center;margin-bottom:24px}
.pf-pub-av{width:84px;height:84px;border-radius:50%;object-fit:cover;border:2px solid var(--teal,#1bbf9c)}
.pf-pub-av.noimg{width:84px;height:84px;border-radius:50%;display:grid;place-items:center;font-size:34px;font-weight:700;color:#fff;background:linear-gradient(135deg,#1bbf9c,#0f7a6a)}
.pf-pub-name{font-size:24px;margin:0 0 4px}
.pf-pub-badge{display:inline-block;font-size:12px;color:var(--teal,#1bbf9c);background:rgba(27,191,156,.12);padding:3px 11px;border-radius:12px;font-weight:600}
.pf-pub-area{font-size:13px;color:var(--muted,#6b8299);margin-top:5px}
.pf-pub-sec{margin-bottom:30px}
.pf-pub-sec h2{font-size:17px;margin:0 0 12px;padding-bottom:8px;border-bottom:1px solid rgba(255,255,255,.07)}
.pf-pub-note{font-size:12.5px;color:var(--muted,#6b8299);margin:-4px 0 12px}
.pf-pub-tankname{font-size:14px;color:var(--text,#e6eef5);margin-bottom:10px}
.pf-pub-specs{display:flex;gap:7px;flex-wrap:wrap}
.pf-pub-spec{background:rgba(46,204,143,.1);border:1px solid rgba(46,204,143,.25);color:#2ecc8f;font-size:12px;padding:4px 11px;border-radius:9px}
.pf-pub-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:12px}
.pf-pub-card{display:block;background:var(--card,#0c1c2b);border:1px solid var(--line,#1c3247);border-radius:12px;overflow:hidden;text-decoration:none;color:inherit}
.pf-pub-card img{width:100%;height:120px;object-fit:cover;display:block}
.pf-pub-card-noimg{height:120px;display:grid;place-items:center;font-size:32px;background:#0a2740}
.pf-pub-card-body{padding:9px 11px}
.pf-pub-card-title{font-size:13px;font-weight:600;line-height:1.35;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.pf-pub-card-price{font-size:12.5px;color:var(--aqua,#3fd0e8);margin-top:5px;font-weight:600}
.pf-pub-corals{display:grid;grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:12px}
.pf-pub-coral{display:block;background:var(--card,#0c1c2b);border:1px solid var(--line,#1c3247);border-radius:12px;overflow:hidden;text-decoration:none;color:inherit}
.pf-pub-coral img{width:100%;height:100px;object-fit:cover;display:block}
.pf-pub-coral-noimg{height:100px;display:grid;place-items:center;font-size:30px;background:#0a2740}
.pf-pub-coral-name{padding:8px 10px;font-size:12.5px;font-weight:600}
.pf-pub-coral-name span{display:inline-block;font-size:9.5px;color:var(--aqua,#3fd0e8);background:rgba(63,208,232,.14);padding:1px 6px;border-radius:7px;margin-left:4px;font-weight:600}
.pf-pub-cta{text-align:center;margin-top:36px}
.pf-pub-cta-btn{display:inline-block;background:linear-gradient(135deg,#1bbf9c,#0f7a6a);color:#fff;text-decoration:none;font-weight:700;padding:13px 26px;border-radius:13px;font-size:15px}
.cmw-author-link{color:inherit;text-decoration:none}
.cmw-author-link:hover{text-decoration:underline}

/* breadcrumb (SEO + điều hướng) */
.cmw-breadcrumb{display:flex;align-items:center;gap:8px;flex-wrap:wrap;font-size:13px;margin-bottom:18px;color:var(--muted,#6b8299)}
.cmw-breadcrumb a{color:var(--teal,#1bbf9c);text-decoration:none}
.cmw-breadcrumb a:hover{text-decoration:underline}
.cmw-breadcrumb span{color:var(--muted,#6b8299)}
.cmw-bc-current{color:var(--text,#e6eef5);font-weight:500}

/* ============ KHỐI CỘNG ĐỒNG TRÊN TRANG CHỦ (home-comm) ============ */
.home-comm-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-top:18px}
.home-comm-card{display:block;background:var(--card,#0c1c2b);border:1px solid var(--line,#1c3247);border-radius:14px;overflow:hidden;text-decoration:none;color:inherit;transition:transform .15s,border-color .15s}
.home-comm-card:hover{transform:translateY(-3px);border-color:var(--teal,#1bbf9c)}
.hc-photo{position:relative;height:150px;background:#0a2740 center/cover no-repeat;display:flex;align-items:center;justify-content:center}
.hc-photo.hc-noimg{font-size:42px;color:#2d5876}
.hc-photo .cmw-type{position:absolute;top:8px;left:8px;font-size:10.5px;font-weight:600;padding:3px 9px;border-radius:8px}
.hc-body{padding:11px 13px}
.hc-body b{display:block;font-size:14px;line-height:1.4;margin-bottom:6px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.hc-meta{font-size:12px;color:var(--muted,#6b8299)}
.cmw-type.frag{background:rgba(27,191,156,.15);color:var(--teal,#1bbf9c)}
.cmw-type.tank{background:rgba(123,92,255,.15);color:#9d86ff}
.cmw-type.gift{background:rgba(255,176,46,.15);color:#ffb02e}
@media(max-width:900px){.home-comm-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:520px){.home-comm-grid{grid-template-columns:1fr}}

/* nút chia sẻ trên trang chi tiết web */
.cmw-share{display:flex;align-items:center;gap:9px;flex-wrap:wrap;margin-top:14px;padding-top:14px;border-top:1px solid rgba(255,255,255,.06)}
.cmw-share-lbl{font-size:13px;color:var(--muted,#6b8299);font-weight:500}
.cmw-share-btn{display:inline-flex;align-items:center;gap:5px;padding:8px 14px;border-radius:9px;font-size:13px;font-weight:600;text-decoration:none;color:#fff;border:none;cursor:pointer;font-family:inherit}
.cmw-share-btn.fb{background:#1877f2}
.cmw-share-btn.mess{background:linear-gradient(135deg,#0a7cff,#a033ff)}
.cmw-share-btn.copy{background:var(--card,#0c1c2b);border:1px solid var(--line,#1c3247);color:var(--text,#e6eef5)}

.cmw-share-btn.zalo{background:linear-gradient(135deg,#0098e5,#0068c9)}

/* badge frag/quan tâm trên card coral ở trang người chơi + journey timeline trang san hô */
.pf-pub-coral{position:relative}
.pf-pub-coral-frag{position:absolute;top:6px;left:6px;background:rgba(46,204,143,.92);width:24px;height:24px;border-radius:7px;display:flex;align-items:center;justify-content:center;font-size:13px}
.pf-pub-coral-int{font-size:11px;color:#2ecc8f;padding:0 8px 7px}
.cmw-coral-badges{display:flex;flex-wrap:wrap;gap:7px;margin:10px 0}
.cmw-cbadge{font-size:12.5px;font-weight:600;padding:4px 11px;border-radius:9px;background:rgba(63,208,232,.1);color:#3fd0e8}
.cmw-cbadge.green{background:rgba(46,204,143,.13);color:#2ecc8f}
.cmw-journey{margin-top:22px;border-top:1px solid rgba(255,255,255,.08);padding-top:18px}
.cmw-journey-h{font-size:17px;margin:0 0 14px}
.cmw-timeline{display:flex;flex-direction:column;gap:0}
.cmw-tl-item{display:flex;gap:12px;position:relative;padding-bottom:18px}
.cmw-tl-item:not(:last-child)::before{content:'';position:absolute;left:15px;top:32px;bottom:0;width:2px;background:rgba(255,255,255,.08)}
.cmw-tl-dot{width:32px;height:32px;border-radius:50%;background:rgba(46,204,143,.15);display:flex;align-items:center;justify-content:center;font-size:15px;flex:none;z-index:1}
.cmw-tl-body{flex:1;min-width:0}
.cmw-tl-title{font-weight:700;font-size:14.5px}
.cmw-tl-text{font-size:13.5px;color:#9fb2c2;margin-top:3px;white-space:pre-line}
.cmw-tl-img{margin-top:8px;border-radius:12px;overflow:hidden;max-width:340px}
.cmw-tl-img img{width:100%;display:block}
.cmw-tl-date{font-size:11.5px;color:#6b8299;margin-top:5px}
.cmw-cta-ghost{display:inline-block;padding:11px 18px;border-radius:12px;border:1px solid rgba(63,208,232,.3);color:#3fd0e8;text-decoration:none;font-weight:600;font-size:14px}

/* ===== Web cộng đồng: like + comment + login thật (dot183) ===== */
.cmw-like-btn{background:none;border:1px solid #d4dde6;border-radius:20px;padding:6px 14px;font:inherit;font-size:14px;color:#48606f;cursor:pointer}
.cmw-like-btn.on{background:#ffe9ec;border-color:#ffb3bf;color:#e23},.cmw-like-btn:hover{border-color:#9fb4c8}
.cmw-comment-box{display:flex;gap:9px;align-items:center;margin-top:16px;padding-top:14px;border-top:1px solid #e8eef3}
.cmw-comment-box input{flex:1;border:1px solid #d4dde6;border-radius:22px;padding:11px 16px;font:inherit;font-size:14px;outline:none}
.cmw-comment-box input:focus{border-color:#1bbf9c}
.cmw-send{background:#1bbf9c;color:#fff;border:none;border-radius:22px;padding:11px 20px;font:inherit;font-weight:600;font-size:14px;cursor:pointer}
.cmw-login-box{margin-top:18px;padding:18px;background:#f4f8fb;border:1px solid #e2ebf2;border-radius:14px;text-align:center}
.cmw-login-box b{font-size:16px;color:#0c2030}
.cmw-login-box p{font-size:13.5px;color:#5e7384;margin:6px 0 14px}
.cmw-login-fields{display:flex;gap:9px;max-width:420px;margin:0 auto 10px}
.cmw-login-fields input{flex:1;border:1px solid #d4dde6;border-radius:10px;padding:11px 13px;font:inherit;font-size:14px;outline:none}
.cmw-login-fields input:focus{border-color:#1bbf9c}
.cmw-login-btns{display:flex;gap:10px;justify-content:center;align-items:center;flex-wrap:wrap}
.cmw-cta.ghost{background:none;border:1px solid #1bbf9c;color:#1bbf9c}
#cmw-login-msg{font-size:13px;margin-bottom:8px;min-height:18px}
@media(max-width:520px){.cmw-login-fields{flex-direction:column}}
