
:root {
  --pink:#e91e63;
  --soft:#fff0f5;
  --card:#ffffff;
  --text:#333;
  --muted:#777;
  --radius:16px;
  --shadow:0 8px 20px rgba(0,0,0,.08);
}
*{box-sizing:border-box}

.stories-container{max-width:1100px;margin:80px auto 40px;padding:0 16px}
.stories-header{display:flex;justify-content:space-between;align-items:center;gap:12px}
.stories-headAer h1{margin:0;color:var(--pink)}
.stories-search input{width:280px;max-width:100%;padding:10px 14px;border:1px solid #eee;border-radius:12px;outline:none}
.stories-filters{display:flex;gap:10px;margin:16px 0}
.stories-filters select{padding:8px 12px;border:1px solid #eee;border-radius:12px}

.manga-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:16px}
.manga-card{background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden;cursor:pointer;display:flex;flex-direction:column}
.manga-card img{width:100%;height:240px;object-fit:cover;display:block}
.manga-card .manga-info{padding:10px 12px}
.manga-title{font-weight:700;margin:0 0 4px}
.manga-meta{font-size:13px;color:var(--muted)}

.manga-detail{display:grid;grid-template-columns:160px 1fr;gap:16px;background:var(--card);padding:16px;border-radius:var(--radius);box-shadow:var(--shadow);margin-top:20px}
.manga-detail img{width:160px;height:220px;object-fit:cover;border-radius:12px}
.manga-detail .title{font-size:22px;margin:0;color:var(--pink)}
.badges{display:flex;flex-wrap:wrap;gap:8px;margin:8px 0}
.badge{background:#ffe4ef;color:#b3004b;padding:4px 8px;border-radius:999px;font-size:12px}

.chapter-list-wrapper{margin-top:20px}
.chapter-item{background:var(--card);padding:12px;border-radius:12px;box-shadow:var(--shadow);display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}
.chapter-item a{color:var(--text);text-decoration:none}
.chapter-item .time{font-size:12px;color:var(--muted)}

.reader-topbar,.reader-bottomnav{position:sticky;top:0;background:rgba(255,255,255,.9);backdrop-filter:saturate(1.2) blur(6px);display:flex;gap:8px;justify-content:center;padding:8px;border-bottom:1px solid #eee;z-index:3}
.reader-bottomnav{top:auto;bottom:0;border-top:1px solid #eee;border-bottom:0}
.reader-btn{border:0;background:#ffc1d6;border-radius:999px;padding:8px 14px;font-weight:700;cursor:pointer}
.reader-btn:hover{background:#ff98bb}

.reader-container{max-width:980px;margin:60px auto;padding:16px}
.reader-images img{width:100%;height:auto;display:block;margin:0 auto 12px;border-radius:12px;background:#f5f5f7}
.reader-meta{margin-bottom:12px;color:var(--muted)}

.reader-comments{margin-top:32px;background:var(--card);padding:16px;border-radius:12px;box-shadow:var(--shadow)}

.dashboard-container{max-width:900px;margin:40px auto;padding:0 16px}
.card{background:var(--card);padding:16px;border-radius:var(--radius);box-shadow:var(--shadow)}
.form-row{display:flex;flex-direction:column;margin-bottom:12px}
.form-row input{padding:10px;border:1px solid #eee;border-radius:12px}
.primary{background:var(--pink);color:#fff;border:0;padding:10px 16px;border-radius:12px;cursor:pointer}
.status{margin-left:8px;color:var(--muted)}
.preview-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:8px;margin:12px 0}
.preview-grid img{width:100%;height:160px;object-fit:cover;border-radius:8px}
.hint{color:var(--muted);font-size:12px}

/* SLIDER khung vừa tầm */
.featured-slider {
  width: 90%;          /* gần full màn hình */
  max-width: 1600px;   /* không quá to trên màn hình lớn */
  margin: 0 auto;      /* căn giữa */
  border-radius: 16px;
  overflow: hidden;
  position: relative;
  box-shadow: 0 6px 18px rgba(0,0,0,0.25);
}

.featured-slider .slides {
  display: flex;
  transition: transform 0.5s ease;
}
.featured-slider .slide {
  min-width: 100%;
}
.featured-slider .slide img {
  width: 100%;
  height: auto;
  display: block;
  object-fit: cover;
  border-radius: 16px;
}

/* nút */
.featured-slider .nav {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  background: rgba(0,0,0,0.4);
  border: none;
  color: #fff;
  font-size: 28px;
  cursor: pointer;
  padding: 6px 12px;
  border-radius: 50%;
  z-index: 2;
}
.featured-slider .nav.prev { left: 10px; }
.featured-slider .nav.next { right: 10px; }
.featured-slider .nav:hover { background: rgba(0,0,0,0.7); }

/* progress bar */
.progress-bar {
  position: absolute;
  bottom: 16px;
  left: 50%;
  transform: translateX(-50%);
  width: 70%;
  height: 8px;
  background: rgba(255,255,255,0.3);
  border-radius: 4px;
  overflow: hidden;
}
.progress-bar .track {
  position: absolute;
  left: 0; top: 0; bottom: 0;
  width: 100%;
  background: rgba(255,255,255,0.3);
}
.progress-bar .fill {
  position: absolute;
  left: 0; top: 0; bottom: 0;
  width: 0%;
  background: var(--pink, #ff4081);
  transition: width 0.5s ease;
}
.progress-bar .handle {
  position: absolute;
  top: 50%;
  transform: translate(-50%, -50%);
  width: 16px; height: 16px;
  background: white;
  border-radius: 50%;
  box-shadow: 0 0 6px rgba(0,0,0,0.4);
  transition: left 0.5s ease;
}
@keyframes waterWaveInside {
  0%   { background-position: 0 0, 0 0; }
  100% { background-position: 200% 0, 0 0; }
}

.featured-slider .dots {
  position: absolute;
  bottom: 12px;
  left: 50%;
  transform: translateX(-50%);
  display: flex;
  align-items: center;
  gap: 20px;
  padding: 6px 12px;
  border: 1px solid rgba(255,255,255,0.35);
  border-radius: 999px;
  overflow: hidden;
  z-index: 5;

  /* nền gốc tối mờ */
  background-color: rgba(15,15,15,0.45);

  /* lớp sóng sáng chạy bên trong */
  background-image: linear-gradient(
    120deg,
    transparent 25%,
    rgba(255,255,255,0.25) 50%,
    transparent 75%
  );
  background-repeat: no-repeat;
  background-size: 200% 100%;

  animation: waterWaveInside 4s linear infinite;
}

@keyframes wobble {
  0%, 100% { transform: rotate(0deg); }
  25% { transform: rotate(-6deg); }
  50% { transform: rotate(6deg); }
  75% { transform: rotate(-4deg); }
}

.featured-slider .dot {
  width: 38px;
  height: 28px;
  display: flex; 
  align-items: center; 
  justify-content: center;
  font-size: 22px;
  cursor: pointer;
  transition: transform 0.3s;
  animation: wobble 2.5s infinite ease-in-out;  /* 👈 thêm lắc lư */
}

.featured-slider .dot:hover {
  transform: scale(1.2); /* hover phóng to thêm */
}

.featured-slider .dot.active {
  opacity: 0; /* ẩn emoji khi incense xuất hiện */
}

.featured-slider .dot.active {
  opacity: 0; /* ẩn icon khi incense xuất hiện */
  transform: scale(0.8);
}

/* incense */
.featured-slider .incense {
  position: absolute;
  max-width: 38px;
  max-height: 28px;
  width: auto;
  height: auto;
  object-fit: contain;
  pointer-events: none;
  transition: left 0.5s ease, top 0.5s ease;
  z-index: 6;

  /* 👇 chỉ áp dụng wobble qua rotate */
  animation: wobbleRotate 2.5s infinite ease-in-out;
}

@keyframes shrinkWobble {
  0%   { transform: scale(1) rotate(0deg); opacity: 1; }
  30%  { transform: scale(0.8) rotate(-10deg); }
  60%  { transform: scale(0.8) rotate(10deg); }
  80%  { transform: scale(0.6) rotate(-5deg); }
  100% { transform: scale(0) rotate(0deg); opacity: 0; }
}

.featured-slider .dot.active {
  animation: shrinkWobble 0.6s forwards; /* chạy 1 lần */
}

/* vẫn giữ flip khi đi ngược */
.featured-slider .incense.flipped {
  transform: scaleX(-1);
}

.featured-slider .dot.used {
  filter: grayscale(100%);
  opacity: 0.6;
}


/* ================= DASHBOARD APP ================== */
#dashboardApp {
  display: flex;
  flex-direction: column;
  gap: 24px;
}

/* danh sách manga */
.dashboard-manga-list {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap: 16px;
}
.dashboard-manga-card {
  background: var(--card);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  padding: 12px;
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.dashboard-manga-card img {
  width: 100%;
  height: 200px;
  object-fit: cover;
  border-radius: 12px;
}
.dashboard-manga-card h3 {
  margin: 4px 0;
  font-size: 18px;
  color: var(--pink);
}
.dashboard-manga-card .actions {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}
.dashboard-manga-card .actions button {
  flex: 1;
  padding: 6px 10px;
  border-radius: 8px;
  border: none;
  cursor: pointer;
  font-size: 13px;
  background: #f0f0f0;
}
.dashboard-manga-card .actions button.edit { background: #ffe0eb; color: #b3004b; }
.dashboard-manga-card .actions button.delete { background: #ffdddd; color: #a00; }
.dashboard-manga-card .actions button.chapter { background: #e0f7fa; color: #006064; }

/* form thêm/sửa */
.dashboard-form {
  background: var(--card);
  padding: 20px;
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.dashboard-form input, 
.dashboard-form textarea, 
.dashboard-form select {
  padding: 10px;
  border: 1px solid #ddd;
  border-radius: 10px;
}
.dashboard-form button {
  align-self: flex-start;
  background: var(--pink);
  color: #fff;
  border: none;
  padding: 10px 16px;
  border-radius: 10px;
  cursor: pointer;
}
.dashboard-form button:hover {
  background: #d81b60;
}

/* thống kê */
.dashboard-stats {
  display: flex;
  gap: 16px;
  flex-wrap: wrap;
}
.dashboard-stat {
  flex: 1;
  min-width: 200px;
  background: var(--card);
  padding: 16px;
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  text-align: center;
}
.dashboard-stat h4 {
  margin: 0;
  font-size: 16px;
  color: var(--muted);
}
.dashboard-stat p {
  margin: 4px 0 0;
  font-size: 22px;
  font-weight: 700;
  color: var(--pink);
}

/* ========= INPUTS đẹp cho dashboard ========== */
.dashboard-form input,
.dashboard-form textarea,
.dashboard-form select {
  padding: 12px 14px;
  border: 1px solid #e2e2e2;
  border-radius: 12px;
  font-size: 14px;
  outline: none;
  transition: all 0.25s ease;
  background: #fafafa;
}

.dashboard-form input:focus,
.dashboard-form textarea:focus,
.dashboard-form select:focus {
  border-color: var(--pink);
  background: #fff;
  box-shadow: 0 0 0 3px rgba(233,30,99,0.15);
}

.dashboard-form textarea {
  min-height: 90px;
  resize: vertical;
}

.dashboard-form label {
  font-weight: 600;
  color: var(--text);
  margin-bottom: 4px;
}

.dashboard-form .form-row {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

/* nút chính */
.dashboard-form button.primary {
  background: var(--pink);
  color: #fff;
  font-weight: 600;
  border: none;
  padding: 12px 18px;
  border-radius: 12px;
  cursor: pointer;
  transition: background 0.25s ease, transform 0.15s ease;
}
.dashboard-form button.primary:hover {
  background: #d81b60;
  transform: translateY(-1px);
}
.dashboard-form button.primary:active {
  transform: translateY(1px);
}
