/* Base tokens (global defaults) */
:root {
  --brand: #6c5ce7;         /* original primary */
  --brand-contrast: #ffffff;
  --accent: #00c2ff;
  --glass-bg: rgba(255,255,255,0.08);
  --glass-border: rgba(255,255,255,0.18);
  --hero-from: #201f3a;
  --hero-to: #0f0e1b;
}

div.p-10 {
    padding: 1rem;
}

/* Also scope variables under dashboard container for legacy selectors */
.dashboard-modern {
  --brand: var(--brand);
  --brand-contrast: var(--brand-contrast);
  --accent: var(--accent);
  --glass-bg: var(--glass-bg);
  --glass-border: var(--glass-border);
  --hero-from: var(--hero-from);
  --hero-to: var(--hero-to);
}

/* Motifs override tokens */
/* Motifs apply globally when set on body, and locally on dashboard */
body.motif-original,
.dashboard-modern.motif-original {
  /* Pastel Violet */
  --brand: #c4b5fd; /* violet-300 */
  --brand-contrast: #081018;
  --accent: #93c5fd; /* blue-300 */
  --hero-from: #c4b5fd;
  --hero-to: #b39afc;
}

body.motif-red,
.dashboard-modern.motif-red {
  /* Pastel Rose */
  --brand: #fda4af; /* rose-300 */
  --brand-contrast: #081018;
  --accent: #fbcfe8; /* pink-200 */
  --hero-from: #fda4af;
  --hero-to: #f58b98;
}

body.motif-blue,
.dashboard-modern.motif-blue {
  /* Pastel Blue */
  --brand: #93c5fd; /* blue-300 */
  --brand-contrast: #081018;
  --accent: #a7f3d0; /* emerald-200 */
  --hero-from: #93c5fd;
  --hero-to: #7fb4fc;
}

body.motif-green,
.dashboard-modern.motif-green {
  /* Pastel Green */
  --brand: #86efac; /* green-300 */
  --brand-contrast: #081018;
  --accent: #a5f3fc; /* cyan-200 */
  --hero-from: #86efac;
  --hero-to: #6ee7a8;
}

/* Rainbow motif */
body.motif-rainbow,
.dashboard-modern.motif-rainbow {
  /* Use a complementary brand/accent for UI elements, but override hero separately */
  --brand: #9b5de5; /* lilac */
  --brand-contrast: #ffffff;
  --accent: #f7b267; /* pastel orange */
  --hero-from: #ff6b6b;
  --hero-to: #9b5de5;
}

/* Rainbow Blue motif (blue-dominant rainbow) */
body.motif-rainbow-blue,
.dashboard-modern.motif-rainbow-blue {
  --brand: #7fb4fc; /* light blue */
  --brand-contrast: #081018;
  --accent: #86efac; /* pastel green */
  --hero-from: #7fb4fc;
  --hero-to: #a5f3fc;
}

/* Custom6 motif (provided palette) */
/* Colors: #CADEED #D5EDCA #EDCAEB #EDDFCA #995F96 #31556E */
body.motif-custom6,
.dashboard-modern.motif-custom6 {
  --brand: #31556E;     /* deep teal */
  --brand-contrast: #ffffff;
  --accent: #995F96;    /* rich purple */
  --hero-from: #CADEED; /* soft blue */
  --hero-to:   #D5EDCA; /* soft green */
}

/* Sepia/Warm motif (dashboard look from mock) */
body.motif-sepia,
.dashboard-modern.motif-sepia {
  --brand: #f7efe7;           /* warm light background for hero */
  --brand-contrast: #3f261a;  /* deep sepia for text/icons */
  --accent: #d19a66;          /* warm tan for primary actions */
  --hero-from: #f7efe7;
  --hero-to:   #f3e3d2;
  /* Warmer glass treatment for light theme */
  --glass-bg: rgba(255, 255, 255, 0.85);
  --glass-border: rgba(63, 38, 26, 0.15);
}

/* Adjust navbar/footer balance for sepia */
body.motif-sepia .navbar.navbar {
  background-color: color-mix(in srgb, var(--brand) 90%, var(--brand-contrast) 10%) !important;
}
body.motif-sepia footer.bg-dark.text-light {
  background-color: color-mix(in srgb, var(--brand-contrast) 20%, var(--brand) 80%) !important;
  color: var(--brand-contrast) !important;
}

/* Example usage of tokens in your existing classes */
.dashboard-modern .hero-gradient {
  /* Use solid theme brand color for clearer, consistent hero */
  background: var(--brand);
  color: var(--brand-contrast);
}
.dashboard-modern.motif-rainbow .hero-gradient {
  background: linear-gradient(90deg,
    #ff6b6b 0%,
    #f7b267 16%,
    #ffd166 33%,
    #06d6a0 50%,
    #118ab2 66%,
    #9b5de5 83%,
    #ff6b6b 100%
  );
}
.dashboard-modern.motif-rainbow-blue .hero-gradient {
  background: linear-gradient(90deg,
    #a5f3fc 0%,     /* cyan */
    #93c5fd 10%,    /* blue */
    #86efac 22%,    /* green */
    #7dd3fc 34%,    /* sky */
    #a7f3d0 44%,    /* mint */
    #86efac 54%,    /* green */
    #93c5fd 64%,    /* blue */
    #86efac 74%,    /* green */
    #fecaca 84%,    /* red (rose) */
    #fbcfe8 92%,    /* pink */
    #93c5fd 100%    /* blue */
  );
}
.dashboard-modern.motif-custom6 .hero-gradient {
  background: linear-gradient(90deg,
    #CADEED 0%,  /* soft blue */
    #D5EDCA 25%, /* soft green */
    #EDCAEB 50%, /* soft pink */
    #EDDFCA 75%, /* soft sand */
    #31556E 87%, /* deep teal accent */
    #995F96 100% /* purple accent */
  );
}
.dashboard-modern .hero-gradient .display-6,
.dashboard-modern .hero-gradient h1,
.dashboard-modern .hero-gradient p,
.dashboard-modern .hero-gradient .btn {
  color: var(--brand-contrast);
}
.dashboard-modern .text-hero-muted {
  /* Fallback first for older browsers */
  color: rgba(255, 255, 255, 0.85);
  /* Prefer dynamic based on contrast token */
  color: color-mix(in srgb, var(--brand-contrast) 85%, transparent);
}
.dashboard-modern .hero-action-strip {
  display: none; /* hidden for dashboard layout resembling mock */
}

/* Action tiles (right column on Dashboard) */
.action-tiles .action-tile {
  display: block;
  border-radius: 12px;
  padding: 1rem 1.25rem;
  text-decoration: none;
  font-weight: 600;
  box-shadow: 0 2px 10px rgba(0,0,0,.06);
}
.action-tiles .action-tile .tile-title { color: var(--brand-contrast); }
.action-tiles .tile-soft {
  background: color-mix(in srgb, var(--brand) 18%, #ffffff 82%);
  border: 1px solid color-mix(in srgb, var(--brand-contrast) 10%, transparent);
  color: var(--brand-contrast);
}

/* Side navigation (left) */
.side-nav { border-radius: 12px; }
.side-nav .nav-link {
  color: color-mix(in srgb, var(--brand-contrast) 80%, transparent);
  padding: .5rem .25rem;
  border-radius: 8px;
}
.side-nav .nav-link:hover {
  background: color-mix(in srgb, var(--brand) 15%, #ffffff 85%);
  color: var(--brand-contrast);
}
.action-tiles .tile-accent { background: var(--accent); color: #081018; }
.action-tiles .tile-strong {
  background: color-mix(in srgb, var(--brand-contrast) 85%, var(--brand) 15%);
  color: #fff;
}
.dashboard-modern .btn-accent {
  background: var(--accent);
  border-color: var(--accent);
  color: #081018;
}
.dashboard-modern .btn-outline-accent {
  border-color: var(--accent);
  color: var(--accent);
}
.dashboard-modern .badge-soft-accent {
  background: color-mix(in srgb, var(--accent) 20%, transparent);
  color: var(--accent);
}
.dashboard-modern .glass-card {
  background: var(--glass-bg);
  border: 1px solid var(--glass-border);
  backdrop-filter: blur(8px);
}

/* Solid modals for better readability (override glass) */
.dashboard-modern .modal-content.glass-card {
  background: #ffffff;
  border: 1px solid #eaded2;
  backdrop-filter: none;
}
.dashboard-modern .modal-header .modal-title { color: inherit; }
.dashboard-modern .modal-backdrop.show { background: rgba(0,0,0,0.35); }

/* Avatar */
.avatar-circle {
  width: 48px;
  height: 48px;
  border-radius: 50%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-weight: 700;
  letter-spacing: .5px;
  user-select: none;
  /* Soft pastel bubble from brand color */
  background: color-mix(in srgb, var(--brand) 35%, #ffffff 65%);
  color: var(--brand-contrast);
  box-shadow: 0 2px 8px rgba(0,0,0,.08);
}

/* Subtle separators and frames */
.soft-divider { height: 1px; background: var(--glass-border); opacity: .9; }
.soft-bordered-top { border-top: 1px solid var(--glass-border) !important; }
.soft-bordered-bottom { border-bottom: 1px solid var(--glass-border) !important; }
.topic-header { border-bottom: 1px solid var(--glass-border); }

/* Optional subtle timeline separators */
.timeline { margin: 0; padding: 0; }
.timeline-item + .timeline-item { border-top: 1px dashed var(--glass-border); padding-top: .75rem; margin-top: .75rem; }

/* Motif selector visuals */
.motif-option { cursor: pointer; transition: border-color .2s, box-shadow .2s; }
.motif-option:hover { box-shadow: 0 0.25rem 1rem rgba(0,0,0,.08); }
.motif-option.active { border-color: var(--brand); box-shadow: 0 0 0 .25rem color-mix(in srgb, var(--brand) 20%, transparent); }
.motif-dot { width: 1.25rem; height: 1.25rem; border-radius: 9999px; border: 2px solid #fff; box-shadow: 0 0 0 2px rgba(0,0,0,.1) inset; }
.motif-dot.motif-original { background: #c4b5fd; }
.motif-dot.motif-red { background: #fda4af; }
.motif-dot.motif-blue { background: #93c5fd; }
.motif-dot.motif-green { background: #86efac; }
.motif-dot.motif-rainbow {
  background: conic-gradient(
    #ff6b6b, #f7b267, #ffd166, #06d6a0, #118ab2, #9b5de5, #ff6b6b
  );
}
.motif-dot.motif-rainbow-blue {
  background: conic-gradient(
    #93c5fd, #7dd3fc, #a5f3fc,
    #86efac, #a7f3d0, #86efac,
    #93c5fd, #7dd3fc,
    #fecaca, #fbcfe8,
    #93c5fd
  );
}
.motif-dot.motif-custom6 {
  background: conic-gradient(
    #CADEED, #D5EDCA, #EDCAEB, #EDDFCA, #31556E, #995F96
  );
}
.motif-dot.motif-sepia { background: #d19a66; }

/* Balance navbar/footer for rainbow-blue: blend brand with greener accent */
body.motif-rainbow-blue .navbar.navbar {
  background-color: color-mix(in srgb, var(--brand) 55%, var(--accent) 45%) !important;
}
body.motif-rainbow-blue footer.bg-dark.text-light {
  background-color: color-mix(in srgb, var(--accent) 60%, var(--brand) 40%) !important;
}

/* Ensure body doesn't scroll when modal open (we toggle this class in JS) */
body.modal-open { overflow: hidden; }

/* Button strip in dashboard hero */
.dashboard-modern .button-strip {
  background: color-mix(in srgb, var(--brand) 18%, transparent);
  border: 1px solid var(--glass-border);
  border-radius: 9999px;
  padding: .5rem .75rem;
}

/* Navbar and footer adapt to current motif (derived from brand/accent) */
.navbar.navbar {
  /* Slightly deeper than brand to improve contrast */
  background-color: color-mix(in srgb, var(--brand) 80%, #000 20%) !important;
}
.navbar .navbar-brand,
.navbar .nav-link,
.navbar .navbar-text {
  color: var(--brand-contrast) !important;
}
.navbar .navbar-toggler { border-color: color-mix(in srgb, var(--brand-contrast) 60%, transparent); }
.navbar .navbar-toggler:focus { box-shadow: 0 0 0 .1rem color-mix(in srgb, var(--brand-contrast) 40%, transparent); }

footer.bg-dark.text-light {
  /* Harmonious blend of brand and accent */
  background-color: color-mix(in srgb, var(--brand) 65%, var(--accent) 35%) !important;
  color: var(--brand-contrast) !important;
}

/* === Demo-like Dashboard Layout (namespaced) === */
.dashboard-modern {
  /* Demo palette variables derived from current motif tokens */
  /* This makes the dashboard adapt to selected motif instead of staying sepia */
  --ml-bg: color-mix(in srgb, var(--brand) 8%, #ffffff 92%);
  --ml-sidebar: color-mix(in srgb, var(--brand) 12%, #ffffff 88%);
  --ml-accent: var(--accent);
  --ml-accent-dark: color-mix(in srgb, var(--brand-contrast) 80%, #000 20%);
  --ml-accent-light: color-mix(in srgb, var(--accent) 20%, #ffffff 80%);
  --ml-text: color-mix(in srgb, var(--brand-contrast) 85%, #000 15%);
  --ml-shadow: rgba(0,0,0,0.08);
  font-family: "Poppins", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
}

.dashboard-modern .layout {
  display: grid;
  grid-template-columns: 240px 1fr 240px;
  min-height: 100vh;
  background: var(--ml-bg);
  color: var(--ml-text);
}

/* Sidebar */
.dashboard-modern .sidebar {
  background: var(--ml-sidebar);
  padding: 2rem 1.5rem;
  border-right: 1px solid #eaded2;
}
.dashboard-modern .logo {
  font-size: 1.5rem;
  font-weight: 700;
  margin-bottom: 2rem;
  color: var(--ml-accent-dark);
}
.dashboard-modern .sidebar nav {
  display: flex;
  flex-direction: column;
  gap: .5rem;
}
.dashboard-modern .sidebar nav a {
  display: block;
  padding: .75rem 1rem;
  border-radius: 12px;
  color: var(--ml-text);
  text-decoration: none;
  font-weight: 500;
}
.dashboard-modern .sidebar nav a:hover {
  background: var(--ml-accent-light);
}
.dashboard-modern .sidebar nav i {
  margin-right: .6rem;
  color: var(--ml-accent-dark);
}
.dashboard-modern .sidebar .submenu {
  padding-left: 1.25rem;
  display: flex;
  flex-direction: column;
  gap: .25rem;
}
.dashboard-modern .sidebar .submenu a {
  padding: .5rem .75rem;
  border-radius: 10px;
  background: transparent;
}

/* Topbar */
.dashboard-modern .topbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 1rem 1.5rem;
  border-bottom: 1px solid #eaded2;
  background: #fff;
}
.dashboard-modern .topbar .nav-links a {
  margin-right: 1rem;
  color: var(--ml-accent-dark);
  text-decoration: none;
  font-weight: 600;
}
.dashboard-modern .topbar .user { display:flex; align-items:center; gap:.5rem; font-weight:600; }

/* Content */
.dashboard-modern .content { padding: 2rem; }
.dashboard-modern .content h1 { font-size: 2rem; line-height:1.3; margin-bottom:2rem; font-weight:700; }
.dashboard-modern .wave { font-size: 1.5rem; }

/* Cards & Shadows */
.dashboard-modern .ml-shadow { box-shadow: 0 6px 16px var(--ml-shadow); }
.dashboard-modern .ml-progress-card,
.dashboard-modern .ml-activity {
  background: #fff;
  border-radius: 16px;
  padding: 1.5rem;
  margin-bottom: 2rem;
  border: 1px solid #eaded2;
}
.dashboard-modern .card-title { font-weight: 600; margin-bottom: .5rem; }

/* Progress */
.dashboard-modern .ml-progress-bar { background: var(--ml-accent-light); border-radius:999px; overflow:hidden; height:14px; margin:.75rem 0; }
.dashboard-modern .ml-progress-bar .fill { background: var(--ml-accent); height:100%; border-radius:999px; }
.dashboard-modern .progress-info { display:flex; justify-content:space-between; font-size:.9rem; color: var(--ml-accent-dark); }

/* Activity */
.dashboard-modern .ml-activity h3 { margin-bottom: 1rem; }
.dashboard-modern .ml-activity ul { list-style:none; }
.dashboard-modern .ml-activity li { margin-bottom:.75rem; display:flex; align-items:center; }
.dashboard-modern .ml-activity .dot { width:12px; height:12px; background: var(--ml-accent); border-radius:50%; margin-right:.6rem; }

/* Right panel */
.dashboard-modern .right-panel {
  background: var(--ml-sidebar);
  padding: 2rem 1.2rem;
  display: flex;
  flex-direction: column;
  gap: 1.5rem;
  border-left: 1px solid #eaded2;
}
.dashboard-modern .ml-btn {
  width: 100%;
  padding: 1.5rem 1.2rem;
  border-radius: 20px;
  border: none;
  font-size: 1.1rem;
  cursor: pointer;
  font-weight: 600;
  transition: all .25s ease;
  letter-spacing: .2px;
  box-shadow: 0 4px 10px var(--ml-shadow);
  display:flex; align-items:center; justify-content:center; gap:.6rem;
  text-decoration: none;
}
.dashboard-modern .ml-btn.light { background: var(--ml-accent-light); color: var(--ml-accent-dark); }
.dashboard-modern .ml-btn.light:hover { background:#e5c7a7; transform: translateY(-2px); }
.dashboard-modern .ml-btn.medium { background: var(--ml-accent); color:#fff; }
.dashboard-modern .ml-btn.medium:hover { background:#9e6539; transform: translateY(-2px); }
.dashboard-modern .ml-btn.dark { background: var(--ml-accent-dark); color:#fff; }
.dashboard-modern .ml-btn.dark:hover { background:#4a2e1e; transform: translateY(-2px); }

/* Responsive */
@media (max-width: 992px) {
  .dashboard-modern .layout { grid-template-columns: 80px 1fr; }
  .dashboard-modern .sidebar nav a span { display:none; }
  .dashboard-modern .right-panel {
    grid-column: 1 / -1; flex-direction: row; flex-wrap: wrap; justify-content: center; gap: 1rem;
    border-left: none; border-top: 1px solid #eaded2;
  }
  .dashboard-modern .ml-btn { flex:1 1 45%; max-width: 240px; }
}
@media (max-width: 600px) {
  .dashboard-modern .layout { grid-template-columns: 1fr; }
  .dashboard-modern .sidebar { position: fixed; top:0; left:-240px; width:220px; height:100%; background: var(--ml-sidebar); transition: left .3s ease; z-index:1000; }
  .dashboard-modern .sidebar.active { left:0; }
  .dashboard-modern .topbar { position: sticky; top:0; z-index:1100; background:#fff; }
  .dashboard-modern .topbar .menu-toggle { display:inline-block; cursor:pointer; font-size:1.5rem; margin-right:1rem; }
  .dashboard-modern .topbar .nav-links { display:none; }
  .dashboard-modern .right-panel { grid-column:1; flex-direction: column; }
  .dashboard-modern .ml-btn { width:100%; max-width:none; }
}
