:root {
  --admin-blue: #0b448d;
  --admin-blue-dark: #081a38;
  --admin-blue-soft: #1565c0;
  --admin-gold: #ffcf40;
  --admin-bg: #eef3fb;
  --admin-card: rgba(255, 255, 255, 0.94);
  --admin-text: #1d2940;
  --admin-muted: #68748d;
  --admin-line: rgba(11, 68, 141, 0.09);
  --admin-shadow: 0 16px 44px rgba(11, 68, 141, 0.12);
  --admin-radius: 24px;
}

body.admin-body {
  background:
    radial-gradient(circle at top left, rgba(86, 163, 255, 0.12), transparent 25%),
    radial-gradient(circle at top right, rgba(11, 68, 141, 0.08), transparent 28%),
    linear-gradient(180deg, #f7faff 0%, var(--admin-bg) 100%);
  color: var(--admin-text);
}

body.admin-body,
body.admin-body .form-control,
body.admin-body .btn,
body.admin-body .table,
body.admin-body .dropdown-menu {
  font-family: 'Montserrat', Arial, sans-serif;
}

.admin-shell #content-wrapper { background: transparent; }

.admin-sidebar {
  background: linear-gradient(180deg, rgba(8, 26, 56, 0.98), rgba(11, 68, 141, 0.98)) !important;
  box-shadow: 12px 0 34px rgba(8, 26, 56, 0.12);
}

.admin-sidebar__brand {
  min-height: 96px;
  justify-content: flex-start !important;
  padding: 1.2rem 1rem !important;
  gap: 0.95rem;
}

.admin-sidebar__brand-logo {
  width: 54px;
  height: 54px;
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.12);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.18);
}

.admin-sidebar__brand-logo img { width: 34px; height: auto; }
.admin-sidebar__brand-kicker { color: rgba(255,255,255,0.66); font-size: 0.72rem; letter-spacing: 0.12em; text-transform: uppercase; font-weight: 800; }
.admin-sidebar__brand-title { color: #fff; font-family: 'Bebas Neue', sans-serif; letter-spacing: 0.05em; font-size: 1.75rem; line-height: 1; }
.admin-sidebar__section-title { padding: 0.95rem 1.4rem 0.55rem; color: rgba(255,255,255,0.52); font-size: 0.72rem; font-weight: 800; text-transform: uppercase; letter-spacing: 0.14em; }
.admin-sidebar .nav-item { margin: 0.1rem 0.75rem; }
.admin-sidebar .nav-item .nav-link { display: flex; align-items: center; gap: 0.85rem; border-radius: 16px; padding: 0.9rem 1rem; color: rgba(255,255,255,0.82); font-weight: 700; }
.admin-sidebar .nav-item .nav-link i { min-width: 18px; text-align: center; }
.admin-sidebar .nav-item.active .nav-link,
.admin-sidebar .nav-item .nav-link:hover,
.admin-sidebar .nav-item .nav-link:focus { color: #fff; background: rgba(255,255,255,0.11); }
.admin-sidebar__spacer { flex: 1 1 auto; }

.admin-topbar {
  min-height: 78px;
  padding: 0.85rem 1.5rem;
  background: rgba(255,255,255,0.72) !important;
  backdrop-filter: blur(14px);
  border-bottom: 1px solid rgba(11, 68, 141, 0.08);
  box-shadow: none !important;
}

.admin-topbar__title-wrap { display: flex; flex-direction: column; gap: 0.1rem; }
.admin-topbar__eyebrow, .admin-page-header__eyebrow, .admin-section-kicker { display: inline-block; font-size: 0.72rem; font-weight: 800; letter-spacing: 0.14em; text-transform: uppercase; color: var(--admin-blue-soft); }
.admin-topbar__title { color: var(--admin-text); }
.admin-topbar__icon { width: 46px; height: 46px; border-radius: 14px; display: inline-flex; align-items: center; justify-content: center; background: rgba(11, 68, 141, 0.06); color: var(--admin-blue); }
.admin-topbar__icon:hover { color: var(--admin-blue); background: rgba(11, 68, 141, 0.1); }
.admin-user-chip { display: flex; align-items: center; gap: 0.85rem; }
.admin-user-chip__meta { flex-direction: column; align-items: flex-end; gap: 0.1rem; }
.admin-user-chip__eyebrow { font-size: 0.72rem; color: var(--admin-muted); }
.admin-user-chip .img-profile { width: 44px; height: 44px; object-fit: cover; box-shadow: 0 10px 20px rgba(11, 68, 141, 0.12); }
.admin-page-wrap { padding-top: 1.5rem; padding-bottom: 2rem; }
.admin-page-header { display: flex; align-items: flex-start; justify-content: space-between; gap: 1rem; flex-wrap: wrap; margin-bottom: 1.4rem; }
.admin-page-header__title { margin: 0.25rem 0 0.45rem; font-family: 'Bebas Neue', sans-serif; letter-spacing: 0.04em; text-transform: uppercase; color: var(--admin-blue); font-size: clamp(2.1rem, 4vw, 3.6rem); line-height: 0.95; }
.admin-page-header__text { max-width: 820px; margin: 0; color: var(--admin-muted); }
.admin-page-header__actions { display: flex; flex-wrap: wrap; gap: 0.75rem; }

.admin-card { position: relative; background: var(--admin-card); border: 1px solid var(--admin-line); border-radius: var(--admin-radius); box-shadow: var(--admin-shadow); overflow: hidden; }
.admin-card::before, .modal-content::before { content: ''; position: absolute; inset: 0 auto auto 0; width: 100%; height: 4px; background: linear-gradient(90deg, var(--admin-gold), var(--admin-blue-soft)); }
.admin-card--padded { padding: 1.4rem; }
.admin-card__header { display: flex; align-items: center; justify-content: space-between; gap: 1rem; margin-bottom: 1.15rem; }
.admin-card__title { margin: 0.2rem 0 0; font-family: 'Bebas Neue', sans-serif; letter-spacing: 0.04em; text-transform: uppercase; color: var(--admin-blue); font-size: 1.75rem; }
.admin-alert { border: 0; border-radius: 18px; box-shadow: var(--admin-shadow); }
.admin-btn-pill, .btn.admin-btn-pill { border-radius: 999px; padding: 0.8rem 1.15rem; font-weight: 800; letter-spacing: 0.02em; }
.admin-stat-card { height: 100%; display: flex; justify-content: space-between; gap: 1rem; padding: 1.35rem 1.4rem; border-radius: 24px; color: #fff; box-shadow: var(--admin-shadow); }
.admin-stat-card--blue { background: linear-gradient(135deg, #0b448d, #1565c0); }
.admin-stat-card--green { background: linear-gradient(135deg, #12795b, #18a772); }
.admin-stat-card--gold { background: linear-gradient(135deg, #db9f05, #f3bf2e); color: #1e1b10; }
.admin-stat-card--dark { background: linear-gradient(135deg, #081a38, #163a6c); }
.admin-stat-card__label { font-size: 0.78rem; text-transform: uppercase; letter-spacing: 0.12em; font-weight: 800; opacity: 0.88; }
.admin-stat-card__value { margin-top: 0.45rem; font-size: clamp(2rem, 4vw, 3rem); font-family: 'Bebas Neue', sans-serif; line-height: 1; letter-spacing: 0.04em; }
.admin-stat-card__text { margin-top: 0.45rem; opacity: 0.84; }
.admin-stat-card__icon { width: 60px; height: 60px; border-radius: 20px; display: inline-flex; align-items: center; justify-content: center; background: rgba(255,255,255,0.14); font-size: 1.35rem; flex-shrink: 0; }
.admin-quick-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 0.95rem; }
.admin-quick-link { display: flex; align-items: center; gap: 0.8rem; min-height: 80px; padding: 1rem; border-radius: 20px; background: rgba(11, 68, 141, 0.05); border: 1px solid rgba(11, 68, 141, 0.08); color: var(--admin-blue); font-weight: 700; }
.admin-quick-link i { width: 42px; height: 42px; border-radius: 14px; display: inline-flex; align-items: center; justify-content: center; background: linear-gradient(135deg, var(--admin-blue), var(--admin-blue-soft)); color: #fff; }
.admin-quick-link:hover { transform: translateY(-2px); color: var(--admin-blue); }
.admin-status-list { list-style: none; padding: 0; margin: 0; display: grid; gap: 0.8rem; }
.admin-status-list li { display: flex; align-items: center; justify-content: space-between; gap: 1rem; padding: 0.95rem 1rem; border-radius: 18px; background: rgba(11, 68, 141, 0.05); }
.admin-status-list li span { color: var(--admin-muted); }
.admin-status-list li strong { color: var(--admin-blue); }
.admin-table-wrap { overflow-x: auto; }
.admin-list-table { margin-bottom: 0 !important; }
.admin-list-table thead th { border: 0 !important; background: linear-gradient(180deg, #0b448d, #0b3874); color: #fff; text-transform: uppercase; letter-spacing: 0.08em; font-size: 0.74rem; font-weight: 800; padding-top: 1rem; padding-bottom: 1rem; white-space: nowrap; }
.admin-list-table tbody td { vertical-align: middle; border-color: rgba(11, 68, 141, 0.06); }
.admin-title-cell { font-weight: 700; color: var(--admin-text); }
.table-row-muted { background: rgba(224, 91, 67, 0.08) !important; }
.admin-table-actions { display: flex; align-items: center; gap: 0.45rem; flex-wrap: wrap; }
.admin-badge { display: inline-flex; align-items: center; justify-content: center; padding: 0.45rem 0.75rem; border-radius: 999px; font-size: 0.76rem; font-weight: 800; letter-spacing: 0.04em; }
.admin-badge--green { background: rgba(18, 121, 91, 0.12); color: #12795b; }
.admin-badge--gold { background: rgba(219, 159, 5, 0.14); color: #b07e05; }
.admin-badge--dark { background: rgba(8, 26, 56, 0.1); color: #081a38; }
.admin-badge--neutral { background: rgba(11, 68, 141, 0.08); color: var(--admin-blue); }
.admin-legend { display: flex; flex-wrap: wrap; gap: 0.75rem; }
.admin-form-shell { max-width: 1100px; }
.admin-label { display: block; margin-bottom: 0.55rem; font-weight: 800; color: var(--admin-blue); }
.admin-input, .admin-form-shell .form-control, .admin-login-card .form-control { min-height: 54px; border-radius: 16px; border: 1px solid rgba(11, 68, 141, 0.14); background: rgba(255,255,255,0.92); box-shadow: none; }
.admin-input:focus, .admin-form-shell .form-control:focus, .admin-login-card .form-control:focus { border-color: rgba(21, 101, 192, 0.45); box-shadow: 0 0 0 0.2rem rgba(21, 101, 192, 0.12); }
.admin-form-actions { display: flex; flex-wrap: wrap; gap: 0.8rem; }
.admin-footer { background: transparent; }
.admin-footer .copyright { color: var(--admin-muted); }
.modal-content { border: 0; border-radius: 24px; overflow: hidden; box-shadow: var(--admin-shadow); }
.modal-header, .modal-footer { border-color: rgba(11, 68, 141, 0.08); }
.dropdown-menu { border: 1px solid rgba(11, 68, 141, 0.08); border-radius: 18px; box-shadow: var(--admin-shadow); }
.dataTables_wrapper .dataTables_filter input, .dataTables_wrapper .dataTables_length select { border-radius: 12px; border: 1px solid rgba(11, 68, 141, 0.14); padding: 0.45rem 0.7rem; margin-left: 0.35rem; }
.dataTables_wrapper .dataTables_info, .dataTables_wrapper .dataTables_length, .dataTables_wrapper .dataTables_filter, .dataTables_wrapper .dataTables_paginate { color: var(--admin-muted); margin-top: 1rem; }
.dataTables_wrapper .paginate_button { border-radius: 12px !important; }
.admin-login-body { min-height: 100vh; display: flex; align-items: center; justify-content: center; }
.admin-login-shell { width: 100%; max-width: 1180px; padding: 2rem 1rem; margin: 0 auto; }
.admin-login-card { display: grid; grid-template-columns: minmax(0, 1fr) minmax(360px, 480px); background: rgba(255,255,255,0.96); border-radius: 32px; overflow: hidden; box-shadow: 0 30px 80px rgba(11, 68, 141, 0.18); }
.admin-login-card__visual { padding: 2.5rem; background: linear-gradient(135deg, rgba(8, 26, 56, 0.96), rgba(11, 68, 141, 0.94)), url('/extra-images/logo-jumilla.png') right -40px bottom -30px / 260px no-repeat; color: #fff; align-items: flex-end; }
.admin-login-card__eyebrow { display: inline-block; color: var(--admin-gold); font-size: 0.76rem; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; }
.admin-login-card__title { margin: 0.85rem 0 0.8rem; font-family: 'Bebas Neue', sans-serif; font-size: clamp(2.5rem, 4vw, 4rem); line-height: 0.96; letter-spacing: 0.04em; text-transform: uppercase; }
.admin-login-card__text { max-width: 480px; color: rgba(255,255,255,0.82); }
.admin-login-card__form { padding: 2.35rem 2rem; }
.admin-login-card__brand { display: flex; align-items: center; gap: 0.9rem; }
.admin-login-card__brand img { width: 58px; height: 58px; object-fit: contain; border-radius: 18px; background: rgba(11, 68, 141, 0.06); padding: 0.6rem; }
.admin-login-card__brand h2 { margin: 0.2rem 0 0; font-family: 'Bebas Neue', sans-serif; font-size: 2rem; line-height: 1; text-transform: uppercase; color: var(--admin-blue); }
.admin-login-card__links { display: flex; flex-direction: column; gap: 0.75rem; margin-top: 1.4rem; }
.admin-login-card__links a { color: var(--admin-blue); font-weight: 700; }
.btn-circle.btn-sm { width: 36px; height: 36px; border-radius: 12px; display: inline-flex; align-items: center; justify-content: center; }
#wrapper #content-wrapper #content { flex: 1 0 auto; }
#sidebarToggle, #sidebarToggleTop { outline: none; }
@media (max-width: 1199.98px) { .admin-quick-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); } }
@media (max-width: 991.98px) { .admin-login-card { grid-template-columns: 1fr; } .admin-page-header, .admin-card__header { flex-direction: column; align-items: flex-start; } .admin-quick-grid { grid-template-columns: 1fr; } .admin-page-wrap { padding-top: 1rem; } }
@media (max-width: 767.98px) { .admin-topbar { padding: 0.75rem 1rem; } .admin-page-header__title { font-size: 2.4rem; } .admin-card--padded { padding: 1rem; } .admin-btn-pill, .btn.admin-btn-pill { width: 100%; justify-content: center; } .admin-page-header__actions { width: 100%; } .admin-page-header__actions > * { width: 100%; } .admin-table-actions { justify-content: flex-start !important; } }


/* ===== Admin post editor refinements ===== */
.admin-page-shell {
  padding-bottom: 2rem;
}

.admin-page-heading {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 1rem;
  flex-wrap: wrap;
  margin-bottom: 1.5rem;
}

.admin-page-heading__eyebrow {
  display: inline-block;
  font-size: 0.72rem;
  font-weight: 800;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--admin-blue-soft);
}

.admin-page-heading__title {
  margin: 0.25rem 0 0.45rem;
  font-family: 'Bebas Neue', sans-serif;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--admin-blue);
  font-size: clamp(2.1rem, 4vw, 3.6rem);
  line-height: 0.95;
}

.admin-page-heading__text {
  max-width: 840px;
  margin: 0;
  color: var(--admin-muted);
}

.admin-page-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
}

.admin-form-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.35fr) minmax(320px, 0.65fr);
  gap: 1.5rem;
  align-items: start;
}

.admin-form-stack {
  display: grid;
  gap: 1.5rem;
}

.admin-form-card {
  position: relative;
  background: rgba(255,255,255,0.95);
  border: 1px solid rgba(11,68,141,0.1);
  border-radius: 28px;
  box-shadow: var(--admin-shadow);
  overflow: hidden;
}

.admin-form-card::before {
  content: '';
  position: absolute;
  inset: 0 auto auto 0;
  width: 100%;
  height: 4px;
  background: linear-gradient(90deg, var(--admin-gold), var(--admin-blue-soft));
}

.admin-form-section {
  padding: 1.45rem;
}

.admin-form-section__title {
  margin: 0;
  font-family: 'Bebas Neue', sans-serif;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--admin-blue);
  font-size: 1.8rem;
}

.admin-form-section__text {
  margin: 0.35rem 0 1.1rem;
  color: var(--admin-muted);
}

.admin-field-group {
  display: grid;
  gap: 1rem;
}

.admin-field-group--2 {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.admin-field {
  margin-bottom: 1rem;
}

.admin-field:last-child {
  margin-bottom: 0;
}

.admin-field label {
  display: block;
  margin-bottom: 0.55rem;
  font-weight: 800;
  color: var(--admin-blue);
}

.admin-inline-grid {
  display: grid;
  gap: 1rem;
}

.admin-panel-card {
  padding: 1rem;
  border-radius: 20px;
  background: rgba(11,68,141,0.04);
  border: 1px solid rgba(11,68,141,0.08);
}

.admin-media-card {
  padding: 1.45rem;
}

.admin-media-preview {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 260px;
  max-height: 380px;
  margin-bottom: 1rem;
  padding: 1rem;
  border-radius: 24px;
  background: linear-gradient(180deg, rgba(11,68,141,0.05), rgba(11,68,141,0.02));
  border: 1px solid rgba(11,68,141,0.08);
  overflow: hidden;
}

.admin-media-preview img {
  width: auto;
  max-width: 100%;
  max-height: 320px;
  object-fit: contain;
  border-radius: 18px;
  box-shadow: 0 14px 36px rgba(11,68,141,0.14);
}

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

.preview-item {
  position: relative;
  padding: 0.65rem;
  border-radius: 18px;
  background: rgba(11,68,141,0.04);
  border: 1px solid rgba(11,68,141,0.08);
}

.preview-item img {
  width: 100%;
  height: 140px;
  object-fit: cover;
  border-radius: 14px;
}

.remove-btn {
  position: absolute;
  top: 0.95rem;
  right: 0.95rem;
  width: 36px;
  height: 36px;
  border: 0;
  border-radius: 12px;
  background: rgba(220,53,69,0.92);
  color: #fff;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.dropzone {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 180px;
  border-radius: 22px;
  border: 2px dashed rgba(11,68,141,0.22);
  background: rgba(11,68,141,0.03);
  color: var(--admin-blue);
  font-weight: 700;
  text-align: center;
  cursor: pointer;
  transition: background 0.2s ease, border-color 0.2s ease, transform 0.2s ease;
}

.dropzone:hover {
  background: rgba(11,68,141,0.06);
  border-color: rgba(11,68,141,0.36);
  transform: translateY(-1px);
}

.preview-container {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(140px, 1fr));
  gap: 0.9rem;
}

.preview-container img {
  width: 100%;
  height: 130px;
  object-fit: cover;
  border-radius: 16px;
  border: 1px solid rgba(11,68,141,0.08);
}

.admin-stat-strip {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0.85rem;
  margin-bottom: 1rem;
}

.admin-stat-strip .admin-stat-card {
  height: auto;
  flex-direction: column;
  justify-content: flex-start;
  gap: 0.45rem;
  padding: 1rem;
  border-radius: 20px;
  background: rgba(11,68,141,0.06);
  color: var(--admin-text);
  box-shadow: none;
  border: 1px solid rgba(11,68,141,0.08);
}

.admin-stat-strip .admin-stat-card__label {
  color: var(--admin-muted);
  font-size: 0.74rem;
  letter-spacing: 0.1em;
}

.admin-stat-strip .admin-stat-card__value {
  margin-top: 0;
  color: var(--admin-blue);
  font-size: 1.5rem;
  line-height: 1.05;
  word-break: break-word;
}

.admin-status-toggle {
  display: flex;
  align-items: center;
  gap: 0.8rem;
  padding: 1rem 1.05rem;
  border-radius: 18px;
  background: rgba(11,68,141,0.05);
  border: 1px solid rgba(11,68,141,0.08);
}

.admin-status-toggle .form-check-input {
  position: static;
  margin: 0;
  width: 20px;
  height: 20px;
}

.admin-status-toggle .form-check-label {
  color: var(--admin-text);
  font-weight: 700;
}

.admin-submit-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  flex-wrap: wrap;
}

.admin-helper {
  color: var(--admin-muted);
}

#audio_description\[0\],
.btn-audio,
#image,
#image_source,
#category_combo,
#match_info_combo,
#category,
#subtitle,
#title,
#date {
  width: 100%;
}

#toolbar-container,
#editor-container {
  border-color: rgba(11,68,141,0.12) !important;
}

#editor-container {
  min-height: 360px;
  border-radius: 0 0 18px 18px;
  overflow: hidden;
}

#toolbar-container {
  border-radius: 18px 18px 0 0;
  overflow: hidden;
}

@media (max-width: 1199.98px) {
  .admin-form-grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 767.98px) {
  .admin-field-group--2,
  .admin-stat-strip {
    grid-template-columns: 1fr;
  }

  .admin-form-section,
  .admin-media-card {
    padding: 1rem;
  }

  .admin-media-preview {
    min-height: 220px;
    max-height: none;
  }

  .admin-media-preview img {
    max-height: 240px;
  }

  .admin-submit-row {
    flex-direction: column;
    align-items: stretch;
  }
}
