:root {
  --pink-primary: #e91e8c;
  --pink-light: #fce4f3;
  --pink-dark: #c0156f;
  --purple-mid: #9c27b0;
  --purple-dark: #6a0080;
  --bg-dark: #1a0a1e;
  --bg-mid: #2d0f3a;
  --card-bg: #3a1447;
  --text-light: #f8e8ff;
  --text-muted: #c9a8d8;
  --border-color: #5a2d6e;
}

body {
  background-color: var(--bg-dark);
  color: var(--text-light);
  font-family: 'Segoe UI', system-ui, sans-serif;
  min-height: 100vh;
}

/* ── Navbar ──────────────────────────────────────────── */
.navbar-blossom {
  background: linear-gradient(135deg, var(--bg-mid), var(--purple-dark));
  border-bottom: 1px solid var(--border-color);
  box-shadow: 0 2px 12px rgba(233,30,140,.25);
}

.navbar-blossom .navbar-brand {
  color: var(--pink-primary) !important;
  font-size: 1.4rem;
  letter-spacing: .5px;
}

.navbar-blossom .nav-link {
  color: var(--text-muted) !important;
  transition: color .2s;
}

.navbar-blossom .nav-link:hover,
.navbar-blossom .nav-link.active {
  color: var(--pink-primary) !important;
}

.navbar-blossom .dropdown-menu {
  background: var(--bg-mid);
  border: 1px solid var(--border-color);
}

.navbar-blossom .dropdown-item {
  color: var(--text-muted);
}

.navbar-blossom .dropdown-item:hover {
  background: var(--card-bg);
  color: var(--pink-primary);
}

.btn-outline-pink {
  border: 1px solid var(--pink-primary) !important;
  color: var(--pink-primary) !important;
  border-radius: 20px;
  padding: 4px 16px;
}

.btn-outline-pink:hover {
  background: var(--pink-primary) !important;
  color: #fff !important;
}

/* ── Cards ───────────────────────────────────────────── */
.card {
  background: var(--card-bg);
  border: 1px solid var(--border-color);
  color: var(--text-light);
}

.card-header {
  background: rgba(233,30,140,.15);
  border-bottom: 1px solid var(--border-color);
  font-weight: 600;
}

/* ── Buttons ─────────────────────────────────────────── */
.btn-pink {
  background: linear-gradient(135deg, var(--pink-primary), var(--purple-mid));
  color: #fff;
  border: none;
  border-radius: 6px;
  transition: opacity .2s;
}

.btn-pink:hover { opacity: .85; color: #fff; }

.bg-pink { background-color: var(--pink-primary) !important; }

.btn-outline-light { border-color: var(--border-color) !important; }

/* ── Forms ───────────────────────────────────────────── */
.form-control, .form-select {
  background: var(--bg-mid);
  border: 1px solid var(--border-color);
  color: var(--text-light);
}

.form-control:focus, .form-select:focus {
  background: var(--bg-mid);
  border-color: var(--pink-primary);
  color: var(--text-light);
  box-shadow: 0 0 0 .2rem rgba(233,30,140,.25);
}

.form-control::placeholder { color: var(--text-muted); }

.form-label { color: var(--text-muted); font-weight: 500; }

.form-check-input:checked {
  background-color: var(--pink-primary);
  border-color: var(--pink-primary);
}

/* ── Badges ──────────────────────────────────────────── */
.badge-pink {
  background: var(--pink-primary);
  color: #fff;
  border-radius: 12px;
  padding: 3px 10px;
  font-size: .75rem;
}

/* ── Gallery grid ────────────────────────────────────── */
.gallery-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
  gap: 12px;
}

.gallery-item {
  position: relative;
  border-radius: 8px;
  overflow: hidden;
  aspect-ratio: 1;
  background: var(--bg-mid);
  border: 1px solid var(--border-color);
}

.gallery-item img,
.gallery-item video {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform .3s;
}

.gallery-item:hover img,
.gallery-item:hover video { transform: scale(1.05); }

.gallery-item .overlay {
  position: absolute;
  bottom: 0; left: 0; right: 0;
  background: linear-gradient(transparent, rgba(0,0,0,.7));
  padding: 8px;
  opacity: 0;
  transition: opacity .2s;
  font-size: .8rem;
}

.gallery-item:hover .overlay { opacity: 1; }

/* ── Wardrobe item card ───────────────────────────────── */
.item-card {
  border-radius: 10px;
  overflow: hidden;
  transition: transform .2s, box-shadow .2s;
}

.item-card:hover {
  transform: translateY(-3px);
  box-shadow: 0 8px 25px rgba(233,30,140,.2);
}

.item-card .item-img {
  height: 200px;
  object-fit: cover;
  width: 100%;
  background: var(--bg-mid);
}

/* ── Progress bars ───────────────────────────────────── */
.progress {
  background: var(--bg-mid);
  border-radius: 10px;
  height: 10px;
}

.progress-bar { background: linear-gradient(90deg, var(--pink-primary), var(--purple-mid)); }

/* ── Stat cards ──────────────────────────────────────── */
.stat-card {
  background: linear-gradient(135deg, var(--card-bg), var(--bg-mid));
  border: 1px solid var(--border-color);
  border-radius: 12px;
  padding: 20px;
  text-align: center;
  transition: border-color .2s;
}

.stat-card:hover { border-color: var(--pink-primary); }

.stat-card .stat-value {
  font-size: 2rem;
  font-weight: 700;
  color: var(--pink-primary);
}

.stat-card .stat-label { color: var(--text-muted); font-size: .85rem; }

/* ── Chastity timer ──────────────────────────────────── */
.chastity-display {
  font-size: 3rem;
  font-weight: 700;
  color: var(--pink-primary);
  text-shadow: 0 0 20px rgba(233,30,140,.5);
}

.lock-icon { font-size: 4rem; }

/* ── RPG ─────────────────────────────────────────────── */
.rpg-stage-badge {
  background: linear-gradient(135deg, var(--pink-primary), var(--purple-dark));
  color: #fff;
  padding: 6px 18px;
  border-radius: 20px;
  font-weight: 600;
}

.npc-portrait {
  width: 120px;
  height: 120px;
  border-radius: 50%;
  border: 3px solid var(--pink-primary);
  object-fit: cover;
  background: var(--bg-mid);
}

/* ── Game wheel ──────────────────────────────────────── */
#wheel-result {
  min-height: 80px;
  background: var(--bg-mid);
  border: 1px solid var(--pink-primary);
  border-radius: 10px;
  padding: 20px;
  font-size: 1.1rem;
  text-align: center;
}

/* ── Task checklist ──────────────────────────────────── */
.task-item {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 12px;
  border-radius: 8px;
  border: 1px solid var(--border-color);
  margin-bottom: 8px;
  background: var(--card-bg);
  transition: border-color .2s;
}

.task-item.completed {
  opacity: .65;
  border-color: #2ea043;
}

.task-item.completed .task-name { text-decoration: line-through; }

/* ── Fund table ──────────────────────────────────────── */
.fund-positive { color: #4caf50; }
.fund-negative { color: #f44336; }

/* ── Footer ──────────────────────────────────────────── */
.footer-blossom {
  background: var(--bg-mid);
  border-top: 1px solid var(--border-color);
  font-size: .9rem;
}

.footer-blossom a {
  color: var(--text-muted);
  text-decoration: none;
}

.footer-blossom a:hover { color: var(--pink-primary); }

/* ── Alerts ──────────────────────────────────────────── */
.alert { border-radius: 8px; }

/* ── Tables ──────────────────────────────────────────── */
.table { color: var(--text-light); }
.table thead th { border-color: var(--border-color); color: var(--text-muted); }
.table td, .table th { border-color: var(--border-color); }
.table-hover tbody tr:hover { background: rgba(233,30,140,.08); }

/* ── Pagination ──────────────────────────────────────── */
.page-link {
  background: var(--card-bg);
  border-color: var(--border-color);
  color: var(--text-muted);
}

.page-link:hover { background: var(--pink-primary); border-color: var(--pink-primary); color: #fff; }
.page-item.active .page-link { background: var(--pink-primary); border-color: var(--pink-primary); }

/* ── Dropzone ────────────────────────────────────────── */
.dropzone {
  border: 2px dashed var(--border-color);
  border-radius: 10px;
  padding: 40px;
  text-align: center;
  cursor: pointer;
  transition: border-color .2s;
}

.dropzone:hover { border-color: var(--pink-primary); }

/* ── Scrollbar ───────────────────────────────────────── */
::-webkit-scrollbar { width: 8px; }
::-webkit-scrollbar-track { background: var(--bg-dark); }
::-webkit-scrollbar-thumb { background: var(--border-color); border-radius: 4px; }
::-webkit-scrollbar-thumb:hover { background: var(--pink-primary); }

/* ── Utility ─────────────────────────────────────────── */
.text-pink { color: var(--pink-primary) !important; }
.bg-card { background: var(--card-bg) !important; }
.border-pink { border-color: var(--pink-primary) !important; }

hr { border-color: var(--border-color); }
a { color: var(--pink-primary); }
a:hover { color: var(--pink-dark); }

.text-muted { color: var(--text-muted) !important; }

.btn-sm { font-size: .8rem; }

/* ── Mobile ──────────────────────────────────────────── */
@media (max-width: 576px) {
  .gallery-grid { grid-template-columns: repeat(2, 1fr); }
  .chastity-display { font-size: 2rem; }
  .stat-card .stat-value { font-size: 1.5rem; }
}
