/* ══════════════════════════════════════
   News Page — Professional Tech Magazine
   ══════════════════════════════════════ */

/* Hero */
.news-hero .page-hero-tag{margin-bottom:12px}
.news-single-cat-badge{
  display:inline-block;padding:4px 14px;border-radius:20px;
  background:rgba(37,99,235,.15);color:var(--accent);
  font-size:.78rem;font-weight:700;letter-spacing:.5px;margin-bottom:12px;
}
.news-single-h1{font-size:clamp(1.5rem,4vw,2.4rem);max-width:820px;line-height:1.25}
.news-single-meta-hero{
  display:flex;gap:18px;flex-wrap:wrap;margin-top:14px;
  font-size:.85rem;color:rgba(255,255,255,.7);
}

/* Filter bar */
.news-filter-bar{
  display:flex;gap:8px;flex-wrap:wrap;margin-bottom:28px;
  padding-bottom:20px;border-bottom:1px solid var(--border);
}
.news-filter-btn{
  padding:7px 18px;border-radius:24px;font-size:.84rem;font-weight:600;
  border:1.5px solid var(--border);color:var(--tx-2);
  text-decoration:none;transition:all .2s;background:var(--bg-2);
}
.news-filter-btn:hover,.news-filter-btn.active{
  background:var(--accent);color:#fff;border-color:var(--accent);
  transform:translateY(-1px);box-shadow:0 4px 12px rgba(37,99,235,.25);
}

/* Featured */
.news-featured{
  display:grid;grid-template-columns:1.1fr 1fr;
  border-radius:var(--r-xl);overflow:hidden;
  box-shadow:var(--shadow-lg);margin-bottom:32px;
  border:1px solid var(--border);text-decoration:none;
  transition:transform .3s,box-shadow .3s;
}
.news-featured:hover{transform:translateY(-4px);box-shadow:0 24px 64px rgba(37,99,235,.18)}
.news-featured-img{
  min-height:340px;position:relative;
  background:linear-gradient(135deg,var(--accent),#0891b2);
  background-size:cover;background-position:center;
}
.news-placeholder-icon{
  position:absolute;top:50%;left:50%;
  transform:translate(-50%,-50%);font-size:4rem;color:rgba(255,255,255,.5);
}
.news-featured-label{
  position:absolute;top:20px;left:20px;
  background:rgba(0,0,0,.75);color:#fff;
  font-size:.7rem;font-weight:700;letter-spacing:1.2px;
  padding:5px 12px;border-radius:20px;text-transform:uppercase;
  backdrop-filter:blur(10px);
}
.news-img-count{
  position:absolute;bottom:14px;right:14px;
  background:rgba(0,0,0,.7);color:#fff;
  font-size:.72rem;font-weight:600;
  padding:4px 10px;border-radius:14px;
  backdrop-filter:blur(10px);
}
.news-featured-body{
  background:var(--bg-1);padding:36px;
  display:flex;flex-direction:column;justify-content:center;
}
.news-featured-top{display:flex;align-items:center;gap:12px;margin-bottom:16px}
.news-featured-title{
  font-family:var(--f-head);font-size:1.5rem;font-weight:700;
  color:var(--tx-1);margin-bottom:14px;line-height:1.3;
}
.news-featured-excerpt{color:var(--tx-2);font-size:.95rem;line-height:1.7;margin-bottom:20px}
.news-featured-footer{display:flex;justify-content:space-between;align-items:center;margin-top:auto}
.news-read-more{color:var(--accent);font-weight:700;font-size:.9rem;letter-spacing:.3px}
.news-read-time{font-size:.78rem;color:var(--tx-3)}

/* Grid */
.news-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-bottom:40px}
.news-card{
  background:var(--bg-1);border-radius:var(--r-lg);
  border:1px solid var(--border);overflow:hidden;
  box-shadow:var(--shadow-sm);text-decoration:none;
  display:flex;flex-direction:column;
  transition:transform .25s,box-shadow .25s;
}
.news-card:hover{transform:translateY(-5px);box-shadow:0 16px 40px rgba(37,99,235,.12)}
.news-card-img{
  height:180px;position:relative;
  background:linear-gradient(135deg,var(--accent),#0891b2);
  background-size:cover;background-position:center;
}
.news-card-body{padding:18px;flex:1;display:flex;flex-direction:column;gap:8px}
.news-card-top{display:flex;justify-content:space-between;align-items:center}
.news-card-title{
  font-family:var(--f-head);font-size:.97rem;font-weight:700;
  color:var(--tx-1);line-height:1.4;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;
}
.news-card-excerpt{
  font-size:.83rem;color:var(--tx-2);line-height:1.6;flex:1;
  display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;
}
.news-card-footer{margin-top:auto;padding-top:8px;border-top:1px solid var(--border)}

/* Cat & date */
.news-cat{
  display:inline-block;padding:3px 10px;border-radius:20px;
  background:rgba(37,99,235,.1);color:var(--accent);
  font-size:.72rem;font-weight:700;letter-spacing:.3px;
}
.news-date{font-size:.78rem;color:var(--tx-3)}
.news-empty{text-align:center;padding:80px 20px;color:var(--tx-3)}
.news-empty h3{font-size:1.15rem;margin-bottom:8px;color:var(--tx-2)}

/* ── Single Post Layout ── */
.news-single-wrap{
  display:grid;grid-template-columns:1fr 320px;
  gap:32px;align-items:flex-start;margin-bottom:40px;
}
.news-single-main{min-width:0}
.news-back{
  display:inline-flex;align-items:center;gap:6px;
  color:var(--accent);font-weight:600;font-size:.9rem;
  text-decoration:none;margin-bottom:24px;
}
.news-back:hover{color:var(--accent-light);transform:translateX(-3px);transition:transform .2s}

/* ── Image Slider ── */
.news-slider{
  position:relative;width:100%;
  border-radius:var(--r-xl);overflow:hidden;
  box-shadow:var(--shadow-lg);margin-bottom:28px;
  background:#0a1628;
}
.news-slider-track{
  display:flex;transition:transform .5s cubic-bezier(.4,0,.2,1);
  will-change:transform;
}
.news-slide{
  flex:0 0 100%;height:480px;position:relative;
  display:flex;align-items:center;justify-content:center;
  background:#0a1628;
}
.news-slide img{
  width:100%;height:100%;object-fit:cover;display:block;
}
.news-slider.single-image .news-slide{height:auto;max-height:520px}
.news-slider.single-image .news-slide img{height:auto;max-height:520px;object-fit:contain;background:#0a1628}

/* Slider buttons */
.news-slider-btn{
  position:absolute;top:50%;transform:translateY(-50%);
  width:48px;height:48px;border-radius:50%;
  background:rgba(255,255,255,.95);border:none;
  font-size:1.6rem;font-weight:700;color:var(--accent);
  cursor:pointer;z-index:5;
  box-shadow:0 4px 16px rgba(0,0,0,.25);
  transition:all .2s;display:flex;align-items:center;justify-content:center;
  padding:0;line-height:1;
}
.news-slider-btn:hover{background:#fff;transform:translateY(-50%) scale(1.1)}
.news-slider-prev{left:16px}
.news-slider-next{right:16px}

/* Counter */
.news-slider-counter{
  position:absolute;top:16px;right:16px;
  background:rgba(0,0,0,.7);color:#fff;
  padding:6px 14px;border-radius:20px;
  font-size:.82rem;font-weight:600;
  backdrop-filter:blur(10px);z-index:5;
}

/* Dots */
.news-slider-dots{
  position:absolute;bottom:18px;left:50%;
  transform:translateX(-50%);display:flex;gap:8px;z-index:5;
}
.news-slider-dot{
  width:9px;height:9px;border-radius:50%;
  background:rgba(255,255,255,.4);border:none;cursor:pointer;
  transition:all .3s;padding:0;
}
.news-slider-dot.active{background:#fff;width:28px;border-radius:5px}
.news-slider-dot:hover{background:rgba(255,255,255,.7)}

/* ── Article Body — Pro Magazine Style ── */
.news-single-body{
  font-size:1.05rem;color:var(--tx-2);line-height:1.85;
  padding:32px 36px;background:var(--bg-1);
  border-radius:var(--r-xl);border:1px solid var(--border);
  box-shadow:var(--shadow-sm);margin-bottom:24px;
  font-family:'Inter',serif;
}
.news-single-body p{margin-bottom:18px}
.news-single-body p:last-child{margin-bottom:0}
.news-single-body h1,.news-single-body h2{
  font-family:var(--f-head);font-weight:700;color:var(--tx-1);
  margin:28px 0 14px;line-height:1.3;
}
.news-single-body h1{font-size:1.6rem}
.news-single-body h2{font-size:1.4rem;padding-bottom:6px;border-bottom:2px solid var(--border)}
.news-single-body h3{font-family:var(--f-head);font-size:1.2rem;font-weight:700;color:var(--tx-1);margin:22px 0 10px}
.news-single-body h4{font-family:var(--f-head);font-size:1.05rem;font-weight:700;color:var(--tx-1);margin:18px 0 8px}

.news-single-body strong,.news-single-body b{color:var(--tx-1);font-weight:700}
.news-single-body a{color:var(--accent);text-decoration:underline;text-decoration-thickness:1.5px;text-underline-offset:3px}
.news-single-body a:hover{color:var(--accent-light)}

.news-single-body ul,.news-single-body ol{margin:14px 0 18px 24px}
.news-single-body li{margin-bottom:8px;padding-left:4px}

.news-single-body blockquote{
  margin:24px 0;padding:18px 24px;
  background:var(--bg-2);border-left:4px solid var(--accent);
  border-radius:0 var(--r-md) var(--r-md) 0;
  font-style:italic;color:var(--tx-2);font-size:1.08rem;
  position:relative;
}
.news-single-body blockquote::before{
  content:'"';position:absolute;top:-10px;left:8px;
  font-size:3rem;color:var(--accent);opacity:.25;font-family:Georgia,serif;
}

.news-single-body code{
  background:var(--bg-3);color:var(--accent);
  padding:2px 8px;border-radius:4px;
  font-family:Monaco,'Courier New',monospace;
  font-size:.92em;border:1px solid var(--border);
}
.news-single-body pre{
  background:#0a1628;color:#a5d6ff;
  padding:18px 22px;border-radius:var(--r-md);
  margin:18px 0;overflow-x:auto;
  font-family:Monaco,'Courier New',monospace;
  font-size:.9rem;line-height:1.6;
}
.news-single-body pre code{background:none;color:inherit;padding:0;border:none}

.news-single-body img{
  max-width:100%;height:auto;
  border-radius:var(--r-md);margin:18px 0;
  display:block;box-shadow:var(--shadow-md);
}

.news-single-body table{
  width:100%;border-collapse:collapse;margin:20px 0;
  border-radius:var(--r-md);overflow:hidden;
  box-shadow:var(--shadow-sm);
}
.news-single-body th{
  background:var(--bg-3);color:var(--tx-1);
  padding:12px 16px;font-weight:700;text-align:left;
  font-size:.92rem;border:1px solid var(--border);
}
.news-single-body td{
  padding:12px 16px;border:1px solid var(--border);font-size:.95rem;
}
.news-single-body tr:nth-child(even) td{background:var(--bg-2)}

.news-single-body iframe{
  max-width:100%;width:100%;
  border-radius:var(--r-md);margin:20px 0;
  display:block;border:none;aspect-ratio:16/9;
}
.news-single-body video{
  max-width:100%;border-radius:var(--r-md);margin:18px 0;
  box-shadow:var(--shadow-md);display:block;
}
.news-single-body hr{
  border:none;height:1px;background:var(--border);margin:28px 0;
}

/* Tags */
.news-tags{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:24px}
.news-tag{
  padding:5px 14px;border-radius:20px;font-size:.78rem;font-weight:600;
  background:var(--bg-3);color:var(--tx-2);text-decoration:none;
  border:1px solid var(--border);transition:all .2s;
}
.news-tag:hover{background:var(--accent);color:#fff;border-color:var(--accent);transform:translateY(-1px)}

/* Share bar */
.news-share-bar{
  padding:22px;background:var(--bg-2);
  border-radius:var(--r-lg);border:1px solid var(--border);
  margin-bottom:32px;
}
.news-share-label{font-weight:700;font-size:.92rem;color:var(--tx-1);display:block;margin-bottom:14px}
.news-share-btns{display:flex;flex-wrap:wrap;gap:10px}
.share-btn{
  padding:9px 16px;border-radius:8px;font-size:.83rem;font-weight:600;
  text-decoration:none;border:none;cursor:pointer;transition:all .2s;
  display:inline-flex;align-items:center;gap:6px;
}
.share-wa{background:#25d366;color:#fff}
.share-tw{background:#1da1f2;color:#fff}
.share-li{background:#0a66c2;color:#fff}
.share-fb{background:#1877f2;color:#fff}
.share-copy{background:var(--bg-3);color:var(--tx-1);border:1px solid var(--border)}
.share-btn:hover{transform:translateY(-2px);box-shadow:0 6px 16px rgba(0,0,0,.15)}

/* Sidebar */
.news-sidebar{display:flex;flex-direction:column;gap:18px;position:sticky;top:80px}
.news-sidebar-card{
  background:var(--bg-1);border-radius:var(--r-lg);
  border:1px solid var(--border);padding:20px;
  box-shadow:var(--shadow-sm);
}
.news-sidebar-title{
  font-weight:700;font-size:.95rem;color:var(--tx-1);
  margin-bottom:14px;padding-bottom:10px;
  border-bottom:2px solid var(--accent);display:inline-block;
}
.news-sidebar-cats{display:flex;flex-direction:column;gap:4px}
.news-sidebar-cat{
  padding:8px 12px;border-radius:8px;font-size:.86rem;
  color:var(--tx-2);text-decoration:none;transition:all .2s;
}
.news-sidebar-cat:hover,.news-sidebar-cat.active{
  background:rgba(37,99,235,.1);color:var(--accent);font-weight:600;
}

.news-sidebar-recent{
  display:flex;gap:10px;padding:10px 0;
  border-bottom:1px solid var(--border);text-decoration:none;
}
.news-sidebar-recent:last-child{border-bottom:none}
.news-sidebar-recent-img{
  width:60px;height:60px;border-radius:8px;flex-shrink:0;
  background:linear-gradient(135deg,var(--accent),#0891b2);
  background-size:cover;background-position:center;
}
.news-sidebar-recent-info{flex:1;min-width:0}
.news-sidebar-recent-title{
  font-size:.85rem;font-weight:600;color:var(--tx-1);
  margin-bottom:4px;line-height:1.4;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;
}
.news-sidebar-recent-date{font-size:.74rem;color:var(--tx-3)}

.news-cta-card{
  text-align:center;
  background:linear-gradient(135deg,rgba(37,99,235,.06),rgba(6,182,212,.06));
}
.news-cta-card h4{font-weight:700;color:var(--tx-1);margin-bottom:6px}
.news-cta-card p{font-size:.84rem;color:var(--tx-2);margin-bottom:14px}

/* Related posts */
.news-related{margin-top:48px;padding-top:32px;border-top:2px solid var(--border)}
.news-related-title{
  font-family:var(--f-head);font-size:1.4rem;font-weight:700;
  color:var(--tx-1);margin-bottom:24px;
}

/* Mobile */
@media(max-width:768px){
  .news-featured{grid-template-columns:1fr}
  .news-featured-img{min-height:240px}
  .news-featured-body{padding:24px}
  .news-grid{grid-template-columns:1fr}
  .news-single-wrap{grid-template-columns:1fr;gap:20px}
  .news-sidebar{position:static}
  .news-slide{height:280px}
  .news-slider.single-image .news-slide img{max-height:340px}
  .news-slider-btn{width:40px;height:40px;font-size:1.3rem}
  .news-slider-prev{left:10px}
  .news-slider-next{right:10px}
  .news-single-body{padding:22px 20px;font-size:1rem}
  .news-single-body iframe{aspect-ratio:16/9}
  .news-share-btns{gap:6px}
  .share-btn{padding:8px 12px;font-size:.78rem}
}
@media(min-width:769px) and (max-width:1024px){
  .news-grid{grid-template-columns:repeat(2,1fr)}
  .news-single-wrap{grid-template-columns:1fr 280px}
  .news-slide{height:380px}
}

/* ══════════════════════════════════════
   Phase 3: Search, Progress, Like, Comments, Newsletter
   ══════════════════════════════════════ */

/* ── Reading Progress Bar ── */
.reading-progress{
  position:fixed;
  top:0;
  left:0;
  height:3px;
  width:0;
  background:linear-gradient(90deg,var(--accent),#06b6d4);
  z-index:9999;
  transition:width 0.1s linear;
  box-shadow:0 0 10px rgba(37,99,235,0.5);
}

/* ── Search Bar ── */
.news-search-wrap{
  margin-bottom:24px;
}
.news-search-box{
  display:flex;
  align-items:center;
  gap:8px;
  background:var(--bg-1);
  border:1.5px solid var(--border);
  border-radius:var(--r-lg);
  padding:4px 16px 4px 18px;
  transition:all 0.2s;
  box-shadow:var(--shadow-sm);
}
.news-search-box:focus-within{
  border-color:var(--accent);
  box-shadow:0 4px 16px rgba(37,99,235,0.12);
}
.news-search-icon{font-size:1.05rem;color:var(--tx-3)}
.news-search-box input{
  flex:1;
  border:none;
  outline:none;
  padding:14px 0;
  font-size:0.95rem;
  background:transparent;
  color:var(--tx-1);
  font-family:'Inter',sans-serif;
}
.news-search-clear{
  width:32px;
  height:32px;
  border-radius:50%;
  border:none;
  background:var(--bg-2);
  color:var(--tx-3);
  font-size:0.9rem;
  cursor:pointer;
  display:flex;
  align-items:center;
  justify-content:center;
  transition:all 0.15s;
}
.news-search-clear:hover{background:var(--danger);color:#fff}
.news-search-results{
  margin-top:8px;
  font-size:0.82rem;
  color:var(--tx-3);
  padding:0 4px;
}

/* ── Like Button ── */
.news-like-bar{
  display:flex;
  align-items:center;
  gap:16px;
  padding:18px 22px;
  background:var(--bg-1);
  border:1px solid var(--border);
  border-radius:var(--r-lg);
  margin-bottom:24px;
  flex-wrap:wrap;
}
.news-like-btn{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:9px 20px;
  background:var(--bg-2);
  border:1.5px solid var(--border);
  border-radius:24px;
  font-size:0.92rem;
  font-weight:600;
  color:var(--tx-2);
  cursor:pointer;
  transition:all 0.2s;
}
.news-like-btn:hover{
  border-color:var(--danger);
  color:var(--danger);
  transform:translateY(-1px);
}
.news-like-btn.liked{
  background:rgba(239,68,68,0.08);
  border-color:var(--danger);
  color:var(--danger);
}
.news-like-btn .like-icon{
  font-size:1.1rem;
  transition:transform 0.3s;
}
.news-like-btn.liked .like-icon{
  transform:scale(1.15);
  filter:saturate(1.5);
}
.news-like-btn.pulse .like-icon{
  animation:likePulse 0.5s ease;
}
@keyframes likePulse{
  0%{transform:scale(1)}
  50%{transform:scale(1.5)}
  100%{transform:scale(1.15)}
}
.news-like-btn .like-count{
  background:rgba(0,0,0,0.08);
  padding:2px 10px;
  border-radius:14px;
  font-size:0.82rem;
  font-weight:700;
  margin-left:4px;
}
.news-like-btn.liked .like-count{
  background:rgba(239,68,68,0.15);
  color:var(--danger);
}
.news-views-display{
  margin-left:auto;
  color:var(--tx-3);
  font-size:0.86rem;
  font-weight:500;
}

/* ── Comments ── */
.news-comments{
  background:var(--bg-1);
  border:1px solid var(--border);
  border-radius:var(--r-lg);
  padding:28px;
  margin-bottom:32px;
}
.news-comments-title{
  font-family:var(--f-head);
  font-size:1.15rem;
  font-weight:700;
  color:var(--tx-1);
  margin-bottom:18px;
  padding-bottom:12px;
  border-bottom:2px solid var(--border);
}
.news-comments-title span{
  color:var(--tx-3);
  font-weight:500;
  font-size:0.95rem;
}

/* Comment Form */
.comment-form{
  background:var(--bg-2);
  padding:18px;
  border-radius:var(--r-md);
  margin-bottom:24px;
}
.comment-form-row{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:10px;
  margin-bottom:10px;
}
.comment-form input,.comment-form textarea{
  width:100%;
  padding:10px 14px;
  border:1.5px solid var(--border);
  border-radius:8px;
  font-size:0.9rem;
  font-family:'Inter',sans-serif;
  background:var(--bg-1);
  color:var(--tx-1);
  outline:none;
  transition:border 0.2s;
}
.comment-form input:focus,.comment-form textarea:focus{
  border-color:var(--accent);
  background:var(--bg-1);
}
.comment-form textarea{
  resize:vertical;
  min-height:90px;
  line-height:1.6;
}
.comment-form-footer{
  display:flex;
  justify-content:space-between;
  align-items:center;
  margin-top:12px;
  flex-wrap:wrap;
  gap:10px;
}
.comment-form-note{
  font-size:0.78rem;
  color:var(--tx-3);
}
.comment-form-msg{
  margin-top:10px;
  padding:10px 14px;
  border-radius:8px;
  font-size:0.84rem;
  display:none;
}
.comment-form-msg:not(:empty){display:block}
.comment-form-msg.ok{background:rgba(16,185,129,0.1);color:#059669;border:1px solid rgba(16,185,129,0.2)}
.comment-form-msg.err{background:rgba(239,68,68,0.08);color:var(--danger);border:1px solid rgba(239,68,68,0.2)}

/* Comment List */
.comment-list{display:flex;flex-direction:column;gap:14px}
.comment-loading,.comment-empty{
  text-align:center;
  padding:24px;
  color:var(--tx-3);
  font-size:0.9rem;
}
.comment-item{
  display:flex;
  gap:12px;
  padding:14px;
  background:var(--bg-2);
  border-radius:var(--r-md);
}
.comment-avatar{
  width:42px;
  height:42px;
  border-radius:50%;
  background:linear-gradient(135deg,var(--accent),#06b6d4);
  color:#fff;
  display:flex;
  align-items:center;
  justify-content:center;
  font-weight:700;
  font-size:0.88rem;
  flex-shrink:0;
}
.comment-body{flex:1;min-width:0}
.comment-head{
  display:flex;
  align-items:center;
  gap:10px;
  margin-bottom:4px;
  flex-wrap:wrap;
}
.comment-head strong{
  font-size:0.92rem;
  color:var(--tx-1);
  font-weight:700;
}
.comment-time{
  font-size:0.74rem;
  color:var(--tx-3);
}
.comment-text{
  font-size:0.9rem;
  color:var(--tx-2);
  line-height:1.6;
  word-break:break-word;
}

/* ── Newsletter ── */
.newsletter-section{
  margin-top:48px;
  padding:36px 32px;
  background:linear-gradient(135deg,rgba(37,99,235,0.06),rgba(6,182,212,0.06));
  border:1px solid rgba(37,99,235,0.15);
  border-radius:var(--r-xl);
  text-align:center;
}
.newsletter-content{max-width:520px;margin:0 auto}
.newsletter-icon{font-size:2.2rem;margin-bottom:10px}
.newsletter-section h3{
  font-family:var(--f-head);
  font-size:1.4rem;
  font-weight:700;
  color:var(--tx-1);
  margin-bottom:8px;
}
.newsletter-section p{
  color:var(--tx-2);
  font-size:0.92rem;
  margin-bottom:20px;
  line-height:1.6;
}
.newsletter-form{
  display:flex;
  gap:10px;
  max-width:440px;
  margin:0 auto;
}
.newsletter-form input{
  flex:1;
  padding:13px 18px;
  border:1.5px solid var(--border);
  border-radius:10px;
  font-size:0.95rem;
  background:var(--bg-1);
  color:var(--tx-1);
  outline:none;
  font-family:'Inter',sans-serif;
}
.newsletter-form input:focus{border-color:var(--accent)}
.newsletter-form button{
  padding:13px 26px;
  white-space:nowrap;
  font-size:0.92rem;
}
.newsletter-msg{
  margin-top:14px;
  padding:10px 14px;
  border-radius:8px;
  font-size:0.85rem;
  display:none;
}
.newsletter-msg:not(:empty){display:inline-block}
.newsletter-msg.ok{background:rgba(16,185,129,0.1);color:#059669}
.newsletter-msg.err{background:rgba(239,68,68,0.08);color:var(--danger)}

/* Mobile responsive */
@media(max-width:640px){
  .news-like-bar{padding:14px 16px}
  .news-views-display{margin-left:0;width:100%;text-align:center;padding-top:6px;border-top:1px solid var(--border)}
  .comment-form-row{grid-template-columns:1fr}
  .comment-form{padding:14px}
  .news-comments{padding:20px}
  .newsletter-section{padding:28px 20px;margin-top:32px}
  .newsletter-section h3{font-size:1.2rem}
  .newsletter-form{flex-direction:column}
  .newsletter-form button{width:100%}
  .news-search-box input{padding:12px 0;font-size:0.92rem}
}

/* ══════════════════════════════════════
   Phase 4: Author, Pagination, Featured Pin
   ══════════════════════════════════════ */

/* ── Author Banner ── */
.news-author-banner{
  display:flex;
  align-items:center;
  gap:18px;
  background:linear-gradient(135deg,rgba(37,99,235,0.06),rgba(6,182,212,0.04));
  border:1px solid rgba(37,99,235,0.15);
  border-radius:var(--r-lg);
  padding:18px 24px;
  margin-bottom:28px;
}
.news-author-banner-icon{
  font-size:2rem;
  width:56px;
  height:56px;
  border-radius:50%;
  background:linear-gradient(135deg,var(--accent),#06b6d4);
  display:flex;
  align-items:center;
  justify-content:center;
  flex-shrink:0;
}
.news-author-banner-label{
  font-size:0.78rem;
  color:var(--tx-3);
  font-weight:500;
}
.news-author-banner-name{
  font-family:var(--f-head);
  font-size:1.3rem;
  font-weight:700;
  color:var(--tx-1);
  margin:2px 0;
}
.news-author-banner-count{
  font-size:0.84rem;
  color:var(--accent);
  font-weight:600;
}
.news-author-banner-clear{
  margin-left:auto;
  padding:8px 16px;
  background:var(--bg-1);
  border:1px solid var(--border);
  border-radius:8px;
  color:var(--tx-2);
  font-size:0.84rem;
  font-weight:600;
  text-decoration:none;
  transition:all 0.2s;
  white-space:nowrap;
}
.news-author-banner-clear:hover{background:var(--danger);color:#fff;border-color:var(--danger)}

/* ── Card pin badge ── */
.news-card-pin{
  position:absolute;
  top:10px;
  left:10px;
  width:28px;
  height:28px;
  border-radius:50%;
  background:var(--gold,#f59e0b);
  color:#fff;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:0.85rem;
  box-shadow:0 4px 10px rgba(245,158,11,0.4);
  z-index:2;
}

/* ── Card author link ── */
.news-card-footer{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:8px;
  flex-wrap:wrap;
}
.news-card-author{
  font-size:0.74rem;
  color:var(--tx-3);
  text-decoration:none;
  padding:3px 8px;
  border-radius:8px;
  transition:all 0.15s;
}
.news-card-author:hover{
  background:rgba(37,99,235,0.08);
  color:var(--accent);
}

/* ── Pagination ── */
.news-pagination{
  display:flex;
  flex-wrap:wrap;
  align-items:center;
  justify-content:center;
  gap:6px;
  margin-top:36px;
  padding:24px;
  border-top:1px solid var(--border);
}
.news-page-btn{
  min-width:38px;
  height:38px;
  padding:0 12px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  background:var(--bg-1);
  border:1.5px solid var(--border);
  border-radius:8px;
  color:var(--tx-2);
  font-size:0.88rem;
  font-weight:600;
  text-decoration:none;
  transition:all 0.15s;
}
.news-page-btn:hover{
  background:var(--accent);
  color:#fff;
  border-color:var(--accent);
  transform:translateY(-1px);
}
.news-page-btn.active{
  background:var(--accent);
  color:#fff;
  border-color:var(--accent);
}
.news-page-gap{
  padding:0 4px;
  color:var(--tx-3);
  font-weight:600;
}
.news-page-info{
  margin-left:auto;
  font-size:0.82rem;
  color:var(--tx-3);
  padding:0 8px;
}

/* Mobile */
@media(max-width:640px){
  .news-author-banner{flex-wrap:wrap;padding:14px 16px}
  .news-author-banner-clear{margin-left:0;width:100%;text-align:center;margin-top:10px}
  .news-pagination{padding:18px 12px}
  .news-page-btn{min-width:34px;height:34px;font-size:0.82rem}
  .news-page-info{width:100%;text-align:center;margin:8px 0 0}
}

/* ══════════════════════════════════════
   Night Mode Fix + Image Sizing + Lightbox
   ══════════════════════════════════════ */

/* ── Night mode: HTML content force visible ── */
[data-theme="dark"] .news-single-body,
[data-theme="dark"] .news-single-body p,
[data-theme="dark"] .news-single-body span,
[data-theme="dark"] .news-single-body div,
[data-theme="dark"] .news-single-body li,
[data-theme="dark"] .news-single-body td {
  color: var(--tx-2) !important;
}

[data-theme="dark"] .news-single-body h1,
[data-theme="dark"] .news-single-body h2,
[data-theme="dark"] .news-single-body h3,
[data-theme="dark"] .news-single-body h4,
[data-theme="dark"] .news-single-body h5,
[data-theme="dark"] .news-single-body h6,
[data-theme="dark"] .news-single-body strong,
[data-theme="dark"] .news-single-body b {
  color: var(--tx-1) !important;
}

[data-theme="dark"] .news-single-body a {
  color: var(--accent-light, #60a5fa) !important;
}

[data-theme="dark"] .news-single-body blockquote {
  background: var(--bg-2) !important;
  color: var(--tx-2) !important;
}

[data-theme="dark"] .news-single-body code {
  background: var(--bg-3) !important;
  color: #93c5fd !important;
}

[data-theme="dark"] .news-single-body th {
  background: var(--bg-3) !important;
  color: var(--tx-1) !important;
}

[data-theme="dark"] .news-single-body td {
  border-color: var(--border) !important;
}

[data-theme="dark"] .news-single-body tr:nth-child(even) td {
  background: var(--bg-2) !important;
}

/* ── Image Slider — Fixed aspect ratio, no crop ── */
.news-slider {
  position: relative;
  width: 100%;
  aspect-ratio: 16 / 9;
  background: linear-gradient(135deg, #0a1628, #1e293b);
  border-radius: var(--r-xl);
  overflow: hidden;
  box-shadow: var(--shadow-lg);
  margin-bottom: 28px;
}

.news-slider-track {
  display: flex;
  width: 100%;
  height: 100%;
  transition: transform .5s cubic-bezier(.4, 0, .2, 1);
  will-change: transform;
}

.news-slide {
  flex: 0 0 100%;
  width: 100%;
  height: 100%;
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: zoom-in;
}

.news-slide img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  display: block;
  background: #0a1628;
}

/* Single image — same fixed ratio */
.news-slider.single-image {
  aspect-ratio: 16 / 9;
}
.news-slider.single-image .news-slide,
.news-slider.single-image .news-slide img {
  height: 100%;
  max-height: none;
  object-fit: contain;
}

/* ── News Card Image — Fixed ratio, uniform ── */
.news-card-img {
  height: 0;
  padding-bottom: 62.5%; /* 16:10 ratio */
  position: relative;
  background: linear-gradient(135deg, var(--accent), #0891b2);
  background-size: cover;
  background-position: center;
  overflow: hidden;
}

/* If using <img> tag inside card (future-proof) */
.news-card-img img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

/* News card uniform height */
.news-card {
  display: flex;
  flex-direction: column;
}
.news-card-body {
  flex: 1;
}

/* Featured image — wider ratio */
.news-featured-img {
  position: relative;
  min-height: 0;
  height: auto;
  aspect-ratio: 4 / 3;
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
}

/* ── Article body images — better defaults ── */
.news-single-body img {
  max-width: 100%;
  height: auto;
  border-radius: var(--r-md);
  margin: 18px auto;
  display: block;
  box-shadow: var(--shadow-md);
  cursor: zoom-in;
  transition: transform .2s;
}
.news-single-body img:hover {
  transform: scale(1.01);
}

/* ── Lightbox ── */
.lightbox-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.95);
  display: none;
  align-items: center;
  justify-content: center;
  z-index: 99999;
  cursor: zoom-out;
  animation: lbFadeIn .2s ease;
}
.lightbox-overlay.open { display: flex; }

@keyframes lbFadeIn {
  from { opacity: 0; }
  to   { opacity: 1; }
}

.lightbox-img {
  max-width: 95vw;
  max-height: 95vh;
  object-fit: contain;
  border-radius: 8px;
  box-shadow: 0 20px 80px rgba(0, 0, 0, 0.6);
  animation: lbZoomIn .25s ease;
}

@keyframes lbZoomIn {
  from { transform: scale(0.92); opacity: 0; }
  to   { transform: scale(1); opacity: 1; }
}

.lightbox-close {
  position: fixed;
  top: 20px;
  right: 24px;
  width: 44px;
  height: 44px;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.15);
  backdrop-filter: blur(10px);
  border: none;
  color: #fff;
  font-size: 1.4rem;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background .2s;
}
.lightbox-close:hover {
  background: rgba(255, 255, 255, 0.25);
}

.lightbox-counter {
  position: fixed;
  bottom: 24px;
  left: 50%;
  transform: translateX(-50%);
  background: rgba(0, 0, 0, 0.6);
  backdrop-filter: blur(10px);
  color: #fff;
  padding: 8px 16px;
  border-radius: 20px;
  font-size: 0.85rem;
  font-weight: 600;
}

/* Mobile responsive */
@media(max-width: 640px) {
  .news-slider { aspect-ratio: 4 / 3; }
  .news-card-img { padding-bottom: 56.25%; } /* 16:9 on mobile */
  .lightbox-close {
    top: 12px;
    right: 12px;
    width: 38px;
    height: 38px;
  }
}

/* ══════════════════════════════════════
   Phase 7: Skeleton Loaders + Read Next + Trending Tags
   ══════════════════════════════════════ */

/* ── Skeleton Loader ── */
@keyframes skeletonShimmer {
  0%   { background-position: -200% 0; }
  100% { background-position: 200% 0; }
}

.skeleton {
  background: linear-gradient(
    90deg,
    var(--bg-2) 25%,
    var(--bg-1) 50%,
    var(--bg-2) 75%
  );
  background-size: 200% 100%;
  animation: skeletonShimmer 1.5s infinite linear;
  border-radius: 4px;
  display: block;
}

.skeleton-text { height: 14px; margin-bottom: 8px; }
.skeleton-text.lg { height: 18px; }
.skeleton-text.xl { height: 24px; }
.skeleton-text.short { width: 60%; }
.skeleton-text.medium { width: 80%; }
.skeleton-text.full { width: 100%; }

.skeleton-img {
  width: 100%;
  padding-bottom: 62.5%;
  border-radius: var(--r-md);
  margin-bottom: 12px;
}

.skeleton-card {
  background: var(--bg-1);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  padding: 14px;
}

/* ── Smooth page transitions ── */
.news-fade-in {
  animation: newsFadeIn 0.4s ease-out;
}
@keyframes newsFadeIn {
  from {
    opacity: 0;
    transform: translateY(8px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

/* Smooth scroll behavior */
html { scroll-behavior: smooth; }

/* ── Read Next Section ── */
.read-next-section {
  background: var(--bg-1);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  padding: 26px 28px;
  margin-bottom: 24px;
  position: relative;
  overflow: hidden;
}

.read-next-section::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 3px;
  background: linear-gradient(90deg, var(--accent), #06b6d4, #8b5cf6);
}

.read-next-title {
  font-family: var(--f-head);
  font-size: 1.15rem;
  font-weight: 700;
  color: var(--tx-1);
  margin-bottom: 18px;
  display: flex;
  align-items: center;
  gap: 10px;
}

.read-next-icon {
  width: 36px;
  height: 36px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--accent), #06b6d4);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 1rem;
}

.read-next-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 12px;
}

.read-next-card {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 14px;
  background: var(--bg-2);
  border-radius: var(--r-md);
  text-decoration: none;
  transition: all 0.25s ease;
  position: relative;
  overflow: hidden;
}

.read-next-card:hover {
  transform: translateX(4px);
  background: var(--bg-3, var(--bg-1));
  box-shadow: var(--shadow-md);
}

.read-next-num {
  width: 36px;
  height: 36px;
  border-radius: 50%;
  background: rgba(37, 99, 235, 0.1);
  color: var(--accent);
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 700;
  font-size: 1rem;
  flex-shrink: 0;
  font-family: var(--f-head);
}

.read-next-card:hover .read-next-num {
  background: var(--accent);
  color: #fff;
}

.read-next-content {
  flex: 1;
  min-width: 0;
}

.read-next-cat {
  display: inline-block;
  font-size: 0.72rem;
  color: var(--accent);
  font-weight: 600;
  background: rgba(37, 99, 235, 0.08);
  padding: 2px 8px;
  border-radius: 10px;
  margin-bottom: 6px;
}

.read-next-card-title {
  font-family: var(--f-head);
  font-size: 0.96rem;
  font-weight: 600;
  color: var(--tx-1);
  margin: 0 0 6px;
  line-height: 1.4;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.read-next-meta {
  display: flex;
  gap: 14px;
  font-size: 0.78rem;
  color: var(--tx-3);
}

.read-next-thumb {
  width: 70px;
  height: 70px;
  border-radius: 8px;
  background-size: cover;
  background-position: center;
  background-color: var(--bg-3, var(--bg-1));
  flex-shrink: 0;
}

/* ── Trending Tags Section ── */
.trending-tags-section {
  background: linear-gradient(
    135deg,
    rgba(245, 158, 11, 0.04),
    rgba(239, 68, 68, 0.03)
  );
  border: 1px solid rgba(245, 158, 11, 0.15);
  border-radius: var(--r-lg);
  padding: 20px 24px;
  margin-bottom: 28px;
}

.trending-tags-title {
  font-family: var(--f-head);
  font-size: 1.02rem;
  font-weight: 700;
  color: var(--tx-1);
  margin-bottom: 14px;
  display: flex;
  align-items: center;
  gap: 8px;
}

.trending-tags-icon {
  font-size: 1.2rem;
  filter: drop-shadow(0 0 6px rgba(245, 158, 11, 0.4));
}

.trending-tags-cloud {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
}

.trending-tag {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 6px 14px;
  background: var(--bg-1);
  border: 1px solid var(--border);
  border-radius: 24px;
  color: var(--tx-2);
  font-weight: 600;
  text-decoration: none;
  transition: all 0.2s ease;
  white-space: nowrap;
}

.trending-tag:hover {
  background: linear-gradient(135deg, #f59e0b, #ef4444);
  color: #fff;
  border-color: transparent;
  transform: translateY(-2px);
  box-shadow: 0 4px 12px rgba(245, 158, 11, 0.25);
}

.trending-tag.tag-sm  { font-size: 0.78rem; padding: 4px 12px; }
.trending-tag.tag-md  { font-size: 0.85rem; padding: 6px 14px; }
.trending-tag.tag-lg  { font-size: 0.95rem; padding: 7px 16px; font-weight: 700; }
.trending-tag.tag-xl  { font-size: 1.05rem; padding: 8px 18px; font-weight: 700; }

.trending-tag-count {
  background: rgba(0, 0, 0, 0.06);
  padding: 1px 7px;
  border-radius: 10px;
  font-size: 0.72rem;
  font-weight: 700;
}

.trending-tag:hover .trending-tag-count {
  background: rgba(255, 255, 255, 0.25);
}

/* ── Tag Banner (filter view) ── */
.news-tag-banner {
  display: flex;
  align-items: center;
  gap: 18px;
  background: linear-gradient(
    135deg,
    rgba(245, 158, 11, 0.06),
    rgba(239, 68, 68, 0.04)
  );
  border: 1px solid rgba(245, 158, 11, 0.2);
  border-radius: var(--r-lg);
  padding: 18px 24px;
  margin-bottom: 28px;
}

.news-tag-banner-icon {
  font-size: 2rem;
  width: 56px;
  height: 56px;
  border-radius: 50%;
  background: linear-gradient(135deg, #f59e0b, #ef4444);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.news-tag-banner-label {
  font-size: 0.78rem;
  color: var(--tx-3);
  font-weight: 500;
}

.news-tag-banner-name {
  font-family: var(--f-head);
  font-size: 1.3rem;
  font-weight: 700;
  color: var(--tx-1);
  margin: 2px 0;
}

.news-tag-banner-count {
  font-size: 0.84rem;
  color: #d97706;
  font-weight: 600;
}

/* Mobile responsive */
@media(max-width: 640px) {
  .read-next-section { padding: 20px 18px; }
  .read-next-card { padding: 12px; gap: 10px; }
  .read-next-thumb { width: 60px; height: 60px; }
  .read-next-num { width: 32px; height: 32px; font-size: 0.9rem; }
  .read-next-card-title { font-size: 0.9rem; }

  .trending-tags-section { padding: 16px 18px; }
  .trending-tag.tag-xl { font-size: 0.95rem; }
  .trending-tag.tag-lg { font-size: 0.88rem; }

  .news-tag-banner { flex-wrap: wrap; padding: 14px 16px; }
  .news-tag-banner-icon { width: 48px; height: 48px; font-size: 1.6rem; }
}

/* ══════════════════════════════════════
   Phase 8: RSS Button
   ══════════════════════════════════════ */

.news-rss-btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 6px 12px;
  background: linear-gradient(135deg, #f97316, #ea580c);
  color: #fff !important;
  border-radius: 8px;
  text-decoration: none;
  font-size: 0.78rem;
  font-weight: 700;
  transition: all 0.2s ease;
  white-space: nowrap;
  margin-left: 6px;
  flex-shrink: 0;
}

.news-rss-btn:hover {
  transform: translateY(-1px);
  box-shadow: 0 4px 12px rgba(249, 115, 22, 0.35);
  color: #fff !important;
}

@media(max-width: 640px) {
  .news-rss-label { display: none; }
  .news-rss-btn { padding: 6px 9px; }
}
