/* DanceConnect - UI helpers */

/* Base tweaks */
html,
body {
  background-color: var(--bs-body-bg);
  color: var(--bs-body-color);
}
body { min-height: 100vh; }
.dc-theme-toggle .form-check-input { cursor: pointer; }
.dc-theme-auto {
  padding: .1rem .4rem;
  line-height: 1;
}
.dc-theme-auto.active {
  background-color: rgba(255,255,255,.18);
  border-color: rgba(255,255,255,.35);
}

:root {
  --dc-border-soft-color: rgba(0,0,0,.12);
  --dc-border-dash-color: rgba(0,0,0,.2);
}
[data-bs-theme="dark"] {
  --dc-border-soft-color: rgba(255,255,255,.22);
  --dc-border-dash-color: rgba(255,255,255,.35);
}
.dc-border-soft { border: 1px solid var(--dc-border-soft-color); }
.dc-border-dash { border: 1px dashed var(--dc-border-dash-color); }

[data-bs-theme="dark"] .text-bg-light {
  color: var(--bs-body-color) !important;
  background-color: var(--bs-secondary-bg) !important;
}

/* Cards */
.dc-card {
  border-radius: 0.75rem;
  box-shadow: 0 6px 16px rgba(0,0,0,0.06);
}
.dc-muted { color: var(--bs-secondary-color); }

.dc-help-content {
  line-height: 1.6;
}
.dc-help-content h1,
.dc-help-content h2,
.dc-help-content h3,
.dc-help-content h4,
.dc-help-content h5,
.dc-help-content h6 {
  margin-top: 1.2rem;
  margin-bottom: 0.6rem;
  font-weight: 700;
}
.dc-help-content ul,
.dc-help-content ol {
  padding-left: 1.25rem;
  margin-bottom: 1rem;
}
.dc-help-content li + li {
  margin-top: 0.25rem;
}
.dc-help-content a {
  text-decoration: underline;
}
.dc-help-content blockquote {
  margin: 1rem 0;
  padding-left: 0.9rem;
  border-left: 3px solid rgba(148, 163, 184, 0.6);
  color: var(--bs-secondary-color);
}
.dc-help-content code {
  background: var(--bs-secondary-bg);
  padding: 0.15rem 0.35rem;
  border-radius: 0.35rem;
}
.dc-help-content pre {
  background: var(--bs-secondary-bg);
  padding: 0.9rem;
  border-radius: 0.6rem;
  overflow: auto;
}
.dc-help-content p:last-child {
  margin-bottom: 0;
}

.dc-help-fab {
  position: fixed;
  right: 24px;
  bottom: 24px;
  z-index: 1030;
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.6rem 0.95rem;
  border-radius: 999px;
  background: #111827;
  color: #ffffff;
  text-decoration: none;
  font-weight: 600;
  border: 1px solid rgba(255, 255, 255, 0.18);
  box-shadow: 0 12px 28px rgba(15, 23, 42, 0.28);
  transition: transform 0.15s ease, box-shadow 0.15s ease;
}
.dc-help-fab:hover {
  color: #ffffff;
  transform: translateY(-1px);
  box-shadow: 0 16px 32px rgba(15, 23, 42, 0.3);
}
.dc-help-fab:focus-visible {
  outline: 3px solid rgba(59, 130, 246, 0.45);
  outline-offset: 2px;
}
[data-bs-theme="dark"] .dc-help-fab {
  background: #e2e8f0;
  color: #0f172a;
  border-color: rgba(15, 23, 42, 0.2);
}
[data-bs-theme="dark"] .dc-help-fab:hover {
  color: #0f172a;
}
.dc-feedback-fab {
  position: fixed;
  left: 50%;
  bottom: 24px;
  z-index: 1030;
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.6rem 1.05rem;
  border-radius: 999px;
  background: #111827;
  color: #ffffff;
  font-weight: 600;
  border: 1px solid rgba(255, 255, 255, 0.18);
  box-shadow: 0 12px 28px rgba(15, 23, 42, 0.28);
  text-decoration: none;
  cursor: pointer;
  transform: translate(-50%, 0);
  transition: transform 0.15s ease, box-shadow 0.15s ease;
}
.dc-feedback-fab:hover {
  color: #ffffff;
  transform: translate(-50%, -1px);
  box-shadow: 0 16px 32px rgba(15, 23, 42, 0.3);
}
.dc-feedback-fab:focus-visible {
  outline: 3px solid rgba(59, 130, 246, 0.45);
  outline-offset: 2px;
}
[data-bs-theme="dark"] .dc-feedback-fab {
  background: #e2e8f0;
  color: #0f172a;
  border-color: rgba(15, 23, 42, 0.2);
}
[data-bs-theme="dark"] .dc-feedback-fab:hover {
  color: #0f172a;
}
@media (max-width: 576px) {
  .dc-help-fab {
    right: 16px;
    bottom: 16px;
    padding: 0.55rem 0.75rem;
  }
  .dc-help-fab span {
    display: none;
  }
  .dc-feedback-fab {
    bottom: 16px;
    padding: 0.55rem 0.9rem;
  }
}

/* Admin dashboard */
body.dc-admin-dashboard {
  --dc-admin-bg: #e7f1ff;
  --dc-admin-surface: #ffffff;
  --dc-admin-border: #cfd9ec;
  --dc-admin-accent: #1e6fff;
  --dc-admin-accent-light: #7ab5ff;
  --dc-admin-accent-border: #94baff;
  --dc-admin-accent-soft: rgba(30, 111, 255, 0.08);
  --dc-admin-text: #1b2a44;
  --dc-admin-muted: #55627a;
  --dc-admin-secondary-border: #b5c2d7;
  --dc-admin-secondary-text: #46556b;
  --dc-admin-secondary-soft: rgba(70, 85, 107, 0.04);
  background-color: var(--dc-admin-bg);
  background-image:
    radial-gradient(circle at 12% 10%, rgba(255,255,255,0.7), transparent 45%),
    radial-gradient(circle at 88% 0%, rgba(255,255,255,0.6), transparent 38%);
}

[data-bs-theme="dark"] body.dc-admin-dashboard {
  --dc-admin-bg: #0f1826;
  --dc-admin-surface: #141f33;
  --dc-admin-border: #25324b;
  --dc-admin-accent: #5da7ff;
  --dc-admin-accent-light: #8cc3ff;
  --dc-admin-accent-border: #5da7ff;
  --dc-admin-accent-soft: rgba(93, 167, 255, 0.14);
  --dc-admin-text: #e2e8f0;
  --dc-admin-muted: #93a4c3;
  --dc-admin-secondary-border: #3a4b66;
  --dc-admin-secondary-text: #b3c0d6;
  --dc-admin-secondary-soft: rgba(179, 192, 214, 0.08);
  background-image:
    radial-gradient(circle at 12% 10%, rgba(93,167,255,0.12), transparent 50%),
    radial-gradient(circle at 88% 0%, rgba(93,167,255,0.08), transparent 45%);
}

[data-bs-theme="dark"] body.dc-admin-dashboard .table-light {
  --bs-table-bg: #162136;
  --bs-table-color: #b7c6e0;
  --bs-table-border-color: #24344d;
}

body.dc-admin-dashboard .container {
  padding-bottom: 2rem;
}

body.dc-admin-dashboard .dc-admin-header,
body.dc-admin-dashboard .dc-page-header {
  border-radius: 0;
  background: var(--dc-admin-surface);
  border: 1px solid var(--dc-admin-border);
  box-shadow: 0 8px 20px rgba(16, 34, 68, 0.06);
  padding: 1rem 1.25rem;
}

body.dc-admin-dashboard h1.h3 {
  font-size: 1.85rem;
  font-weight: 700;
  color: var(--dc-admin-text);
}

body.dc-admin-dashboard .dc-muted {
  color: var(--dc-admin-muted);
}

body.dc-admin-dashboard .row.g-3 {
  --bs-gutter-x: 1.5rem;
  --bs-gutter-y: 1.5rem;
}

body.dc-admin-dashboard .dc-card {
  border-radius: 0;
  border: 1px solid var(--dc-admin-border);
  background: var(--dc-admin-surface);
  box-shadow: 0 10px 22px rgba(15, 32, 64, 0.08);
  position: relative;
  overflow: hidden;
  transition: transform 0.15s ease, box-shadow 0.15s ease;
}

body.dc-admin-dashboard .dc-card::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 3px;
  background: linear-gradient(90deg, var(--dc-admin-accent), var(--dc-admin-accent-light, var(--dc-admin-accent)));
}

body.dc-admin-dashboard .dc-card--eleves {
  --dc-admin-accent: #2563eb;
  --dc-admin-accent-light: #60a5fa;
  --dc-admin-accent-border: #93c5fd;
  --dc-admin-accent-soft: rgba(37, 99, 235, 0.12);
}

body.dc-admin-dashboard .dc-card--profs {
  --dc-admin-accent: #0ea5e9;
  --dc-admin-accent-light: #7dd3fc;
  --dc-admin-accent-border: #bae6fd;
  --dc-admin-accent-soft: rgba(14, 165, 233, 0.12);
}

body.dc-admin-dashboard .dc-card--pool {
  --dc-admin-accent: #e11d48;
  --dc-admin-accent-light: #fb7185;
  --dc-admin-accent-border: #fda4af;
  --dc-admin-accent-soft: rgba(225, 29, 72, 0.12);
}

body.dc-admin-dashboard .dc-card--cours {
  --dc-admin-accent: #14b8a6;
  --dc-admin-accent-light: #5eead4;
  --dc-admin-accent-border: #99f6e4;
  --dc-admin-accent-soft: rgba(20, 184, 166, 0.12);
}

body.dc-admin-dashboard .dc-card--inscriptions {
  --dc-admin-accent: #22c55e;
  --dc-admin-accent-light: #86efac;
  --dc-admin-accent-border: #bbf7d0;
  --dc-admin-accent-soft: rgba(34, 197, 94, 0.12);
}

body.dc-admin-dashboard .dc-card--remplacements {
  --dc-admin-accent: #65a30d;
  --dc-admin-accent-light: #a3e635;
  --dc-admin-accent-border: #bef264;
  --dc-admin-accent-soft: rgba(101, 163, 13, 0.12);
}

body.dc-admin-dashboard .dc-card--evenements {
  --dc-admin-accent: #f97316;
  --dc-admin-accent-light: #fdba74;
  --dc-admin-accent-border: #fed7aa;
  --dc-admin-accent-soft: rgba(249, 115, 22, 0.12);
}

body.dc-admin-dashboard .dc-card--medias {
  --dc-admin-accent: #ef4444;
  --dc-admin-accent-light: #fca5a5;
  --dc-admin-accent-border: #fecaca;
  --dc-admin-accent-soft: rgba(239, 68, 68, 0.12);
}

body.dc-admin-dashboard .dc-card--inbox {
  --dc-admin-accent: #f59e0b;
  --dc-admin-accent-light: #fcd34d;
  --dc-admin-accent-border: #fde68a;
  --dc-admin-accent-soft: rgba(245, 158, 11, 0.12);
}

/* Admin theme variants (match dashboard tiles) */
body.dc-admin-dashboard.dc-admin-theme-eleves {
  --dc-admin-accent: #2563eb;
  --dc-admin-accent-light: #60a5fa;
  --dc-admin-accent-border: #93c5fd;
  --dc-admin-accent-soft: rgba(37, 99, 235, 0.12);
}

body.dc-admin-dashboard.dc-admin-theme-profs {
  --dc-admin-accent: #0ea5e9;
  --dc-admin-accent-light: #7dd3fc;
  --dc-admin-accent-border: #bae6fd;
  --dc-admin-accent-soft: rgba(14, 165, 233, 0.12);
}

body.dc-admin-dashboard.dc-admin-theme-remplacants {
  --dc-admin-accent: #e11d48;
  --dc-admin-accent-light: #fb7185;
  --dc-admin-accent-border: #fda4af;
  --dc-admin-accent-soft: rgba(225, 29, 72, 0.12);
}

body.dc-admin-dashboard.dc-admin-theme-remplacements {
  --dc-admin-accent: #65a30d;
  --dc-admin-accent-light: #a3e635;
  --dc-admin-accent-border: #bef264;
  --dc-admin-accent-soft: rgba(101, 163, 13, 0.12);
}

body.dc-admin-dashboard.dc-admin-theme-cours {
  --dc-admin-accent: #14b8a6;
  --dc-admin-accent-light: #5eead4;
  --dc-admin-accent-border: #99f6e4;
  --dc-admin-accent-soft: rgba(20, 184, 166, 0.12);
}

body.dc-admin-dashboard.dc-admin-theme-inscriptions {
  --dc-admin-accent: #22c55e;
  --dc-admin-accent-light: #86efac;
  --dc-admin-accent-border: #bbf7d0;
  --dc-admin-accent-soft: rgba(34, 197, 94, 0.12);
}

body.dc-admin-dashboard.dc-admin-theme-evenements {
  --dc-admin-accent: #f97316;
  --dc-admin-accent-light: #fdba74;
  --dc-admin-accent-border: #fed7aa;
  --dc-admin-accent-soft: rgba(249, 115, 22, 0.12);
}

body.dc-admin-dashboard.dc-admin-theme-medias {
  --dc-admin-accent: #ef4444;
  --dc-admin-accent-light: #fca5a5;
  --dc-admin-accent-border: #fecaca;
  --dc-admin-accent-soft: rgba(239, 68, 68, 0.12);
}

body.dc-admin-dashboard.dc-admin-theme-inbox {
  --dc-admin-accent: #f59e0b;
  --dc-admin-accent-light: #fcd34d;
  --dc-admin-accent-border: #fde68a;
  --dc-admin-accent-soft: rgba(245, 158, 11, 0.12);
}

body.dc-admin-dashboard .dc-card:hover {
  transform: translateY(-2px);
  box-shadow: 0 14px 28px rgba(15, 32, 64, 0.14);
}

body.dc-admin-dashboard .dc-row-lift > td {
  position: relative;
  transition: transform 0.15s ease, box-shadow 0.15s ease, background-color 0.15s ease;
}

body.dc-admin-dashboard .dc-row-lift:hover > td {
  transform: translateY(-2px);
  box-shadow: 0 14px 28px rgba(15, 32, 64, 0.14);
  background-color: var(--dc-admin-surface);
  z-index: 1;
}

body.dc-admin-dashboard .card-body {
  display: flex;
  flex-direction: column;
  gap: 0.6rem;
}

body.dc-admin-dashboard .dc-card-title {
  display: flex;
  align-items: center;
  gap: 0.6rem;
  font-weight: 700;
  color: var(--dc-admin-text);
}

body.dc-admin-dashboard .dc-card-title i {
  width: 32px;
  height: 32px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 1px solid var(--dc-admin-accent-border);
  background: var(--dc-admin-accent-soft);
  color: var(--dc-admin-accent);
  font-size: 1rem;
}

body.dc-admin-dashboard .card-body p {
  color: var(--dc-admin-muted);
  line-height: 1.5;
}

body.dc-admin-dashboard .btn {
  font-weight: 600;
}

body.dc-admin-dashboard .btn-primary {
  --bs-btn-bg: var(--dc-admin-accent);
  --bs-btn-border-color: var(--dc-admin-accent);
  --bs-btn-hover-bg: var(--dc-admin-accent);
  --bs-btn-hover-border-color: var(--dc-admin-accent);
  --bs-btn-active-bg: var(--dc-admin-accent);
  --bs-btn-active-border-color: var(--dc-admin-accent);
}

body.dc-admin-dashboard .btn-outline-primary {
  border-color: var(--dc-admin-accent-border);
  color: var(--dc-admin-accent);
  background-color: var(--dc-admin-accent-soft);
}

body.dc-admin-dashboard .btn-outline-primary:hover,
body.dc-admin-dashboard .btn-outline-primary:focus {
  background-color: var(--dc-admin-accent);
  border-color: var(--dc-admin-accent);
  color: #fff;
}

body.dc-admin-dashboard .btn-outline-secondary {
  border-color: var(--dc-admin-secondary-border);
  color: var(--dc-admin-secondary-text);
  background-color: var(--dc-admin-secondary-soft);
}

body.dc-admin-dashboard .btn-outline-secondary:hover,
body.dc-admin-dashboard .btn-outline-secondary:focus {
  background-color: var(--dc-admin-secondary-text);
  border-color: var(--dc-admin-secondary-text);
  color: var(--dc-admin-surface);
}

/* Mobile improvements */
@media (max-width: 767.98px) {
  /* Reduce container padding slightly on phones */
  .container { padding-left: 14px; padding-right: 14px; }

  /* Buttons full width on mobile when desired */
  .dc-btn-block { width: 100%; }

  /* Table readability */
  .table td, .table th { padding: .65rem .6rem; }

  /* Avoid big badges wrapping weirdly */
  .badge { white-space: nowrap; }

  /* Action buttons stack nicely */
  .dc-actions {
    display: grid;
    grid-template-columns: 1fr;
    gap: .5rem;
    justify-items: stretch;
  }
  .dc-actions .btn { width: 100%; }

  /* Long strings (emails) should wrap */
  .dc-wrap {
    word-break: break-word;
    overflow-wrap: anywhere;
  }

  /* “app-like”: smoother taps */
  a, button {
    -webkit-tap-highlight-color: transparent;
  }
}
