.knq-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(220px,1fr));
  gap:18px;
}

.knq-card img{
  width:100%;
  border-radius:12px;
}

.knq-day{
  min-height:120px;
  background:#f6f6f6;
  padding:12px;
  border-radius:10px;
  margin-bottom:12px;
}
.knq-save-btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;

  padding:8px 30px;          /* 🔥 tăng chiều cao */
  border-radius:999px;       /* pill thật */

  background:#8fcba7;
  border:none;

  font-size:12px;
  font-weight:600;
  line-height:1;

  letter-spacing:.3px;       /* 🔥 giúp chữ thoáng */
  text-transform:uppercase;  /* nếu muốn in hoa */

  white-space:nowrap;
  cursor:pointer;
  transition:.2s;
}

.knq-save-btn.saved{
background: #05804c;
  color: #fff;
  display: inline-block;
  width: auto;
  white-space: nowrap;
  font-size: 11px;
	padding:9px 18px;
}
.knq-card{
  background:#fff;
  padding:12px;
  border-radius:14px;
  box-shadow:0 6px 18px rgba(0,0,0,.08);
  text-align:center;
}

.knq-thumb img{
  width:100%;
  border-radius:12px;
  transition:.25s;
}

.knq-thumb:hover img{
  transform:scale(1.03);
}

.knq-status{
  margin:8px 0;
  font-weight:600;
}

.knq-status.visited{ color:#2ecc71; }
.knq-status.not-visited{ color:#f39c12; }

.knq-visited-btn{
  padding:8px 14px;
  border:none;
  border-radius:20px;
  background:#eee;
  cursor:pointer;
  font-weight:600;
}

.knq-visited-btn.done{
  background:#2ecc71;
  color:#fff;
}
.knq-region{
  margin-bottom:42px;
}

.knq-region-title{
  font-size:26px;
  font-weight:800;
  margin-bottom:14px;
}

.knq-type-title{
  font-size:20px;
  margin:10px 0;
  color:#777;
  font-weight:600;
}

.knq-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(220px,1fr));
  gap:18px;
}
.knq-hidden{ display:none }

.knq-toggle{
  cursor:pointer;
  font-weight:700;
  margin:12px 0;
}

.knq-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(200px,1fr));
  gap:16px;
}

.knq-card{
  background:#fff;
  padding:12px;
  border-radius:14px;

  border:1px solid #eee;

  box-shadow:
    0 4px 14px rgba(0,0,0,.06),
    0 1px 2px rgba(0,0,0,.04);

  transition:
    transform .2s ease,
    box-shadow .2s ease;

  overflow:hidden;
}
.knq-card:hover{
  transform:translateY(-4px);

  box-shadow:
    0 12px 28px rgba(0,0,0,.12),
    0 2px 6px rgba(0,0,0,.06);
}
.knq-card img{
  width:100%;
  border-radius:12px;
  display:block;
  object-fit:cover;
}
.knq-card .knq-title{
  font-weight:600;
  margin-top:8px;
  line-height:1.35;

  display:-webkit-box;
  -webkit-line-clamp:2;
  -webkit-box-orient:vertical;
  overflow:hidden;
}
.knq-status{
  margin-top:6px;
  font-size:14px;
  font-weight:600;
}
@media (max-width:549px){

  .knq-card{
    padding:10px;
    border-radius:12px;
  }

}
.knq-planner{
  display:grid;
  grid-template-columns:2fr 1fr;
  gap:30px;
}

.knq-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(160px,1fr));
  gap:15px;
}

.knq-card{
  border:1px solid #ddd;
  border-radius:12px;
  padding:10px;
  text-align:center;
  cursor:pointer;
  background:#fff;
  transition:.2s;
}

.knq-card.selected{
  border-color:#ff4d4f;
  box-shadow:0 0 0 2px #ff4d4f33;
}

.knq-summary{
  background:#fafafa;
  padding:20px;
  border-radius:12px;
}
.knq-timeline{
  border-left:4px solid #ff6b35;
  padding-left:20px;
}

.knq-slot{
  background:#fff;
  padding:12px;
  margin-bottom:14px;
  border-radius:12px;
  box-shadow:0 4px 12px rgba(0,0,0,.08);
}