/* ============================================================
   MOBILE MENU STYLES (ajouté à style.css ou chargé séparément)
   ============================================================ */

/* Menu mobile */
.mobile-menu {
  position: fixed;
  top: var(--header-h);
  left: 0;
  right: 0;
  bottom: 0;
  background: var(--color-white);
  z-index: 999;
  transform: translateX(100%);
  transition: transform .3s ease;
  overflow-y: auto;
  padding: 2rem 0;
  border-top: 1px solid var(--color-border);
}
.mobile-menu.is-open {
  transform: translateX(0);
}
.mobile-nav-list { display: flex; flex-direction: column; }
.mobile-nav-list li a {
  display: block;
  padding: 1rem 1.5rem;
  font-size: 1.1rem;
  font-weight: 600;
  color: var(--color-text);
  border-bottom: 1px solid var(--color-border);
  transition: color var(--transition), background var(--transition);
}
.mobile-nav-list li a:hover {
  color: var(--color-accent);
  background: var(--color-accent-soft);
}

/* Content styles */
.entry-content h2,
.entry-content h3,
.entry-content h4 {
  margin: 2rem 0 1rem;
  color: var(--color-primary);
}
.entry-content p { margin-bottom: 1.25rem; }
.entry-content ul,
.entry-content ol {
  list-style: disc;
  padding-left: 1.5rem;
  margin-bottom: 1.25rem;
}
.entry-content ol { list-style: decimal; }
.entry-content li { margin-bottom: .5rem; color: var(--color-muted); }
.entry-content a { color: var(--color-accent); text-decoration: underline; }
.entry-content blockquote {
  border-left: 4px solid var(--color-accent);
  padding: 1rem 1.5rem;
  background: var(--color-accent-soft);
  border-radius: 0 var(--radius-md) var(--radius-md) 0;
  margin: 1.5rem 0;
  font-style: italic;
}
.entry-content img {
  border-radius: var(--radius-lg);
  margin: 1.5rem 0;
}
.entry-content pre,
.entry-content code {
  font-family: var(--font-mono);
  background: var(--color-primary);
  color: #E2E8F0;
  padding: .2em .4em;
  border-radius: var(--radius-sm);
  font-size: .875em;
}
.entry-content pre {
  padding: 1.5rem;
  border-radius: var(--radius-lg);
  overflow-x: auto;
  margin: 1.5rem 0;
}
.entry-content pre code {
  background: transparent;
  padding: 0;
}
.entry-content table {
  width: 100%;
  border-collapse: collapse;
  margin: 1.5rem 0;
}
.entry-content th,
.entry-content td {
  padding: .75rem 1rem;
  border: 1px solid var(--color-border);
  text-align: left;
}
.entry-content th { background: var(--color-bg); font-weight: 700; color: var(--color-primary); }

/* Pagination */
.page-numbers {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  border-radius: var(--radius-md);
  border: 1px solid var(--color-border);
  color: var(--color-text);
  font-size: .875rem;
  margin: 0 2px;
  transition: all var(--transition);
}
.page-numbers:hover,
.page-numbers.current {
  background: var(--color-accent);
  border-color: var(--color-accent);
  color: var(--color-white);
}
.nav-links { display: flex; align-items: center; flex-wrap: wrap; gap: 4px; }

/* Widgets sidebar */
.widget { margin-bottom: 2rem; }
.widget-title {
  font-family: var(--font-heading);
  font-size: 1rem;
  font-weight: 700;
  color: var(--color-primary);
  margin-bottom: 1rem;
  padding-bottom: .75rem;
  border-bottom: 2px solid var(--color-accent);
  display: inline-block;
}

/* Search form */
.search-form { display: flex; gap: .5rem; }
.search-form input[type="search"] {
  flex: 1;
  padding: .75rem 1rem;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  font-family: var(--font-body);
  font-size: .9rem;
  outline: none;
  transition: border-color var(--transition);
}
.search-form input[type="search"]:focus { border-color: var(--color-accent); }
.search-form button {
  padding: .75rem 1.25rem;
  background: var(--color-accent);
  color: white;
  border: none;
  border-radius: var(--radius-md);
  cursor: pointer;
}

/* ============================================================
   COMPATIBILITÉ ELEMENTOR GRATUIT
   ============================================================ */

/* Pages construites avec Elementor : compenser le header fixe */
.netsec-elementor-page #page,
body.elementor-page #page {
  padding-top: 0;
}

/* Les sections Elementor full-width ne doivent pas être contraintes */
.elementor-section.elementor-section-full_width {
  max-width: 100% !important;
}

/* Premier élément Elementor : compenser le header fixe (72px) */
.netsec-elementor-page .elementor-section:first-child,
.elementor-page .elementor-section:first-child {
  scroll-margin-top: var(--header-h);
}

/* Template pleine largeur : retirer padding-top du main */
.elementor-page-main {
  padding-top: 0;
}

/* Template canvas : aucun décalage */
body.elementor-page-canvas {
  padding-top: 0 !important;
}
body.elementor-page-canvas .site-header,
body.elementor-page-canvas .site-footer {
  display: none !important;
}

/* Typo Elementor : forcer les polices du thème */
.elementor-widget-heading .elementor-heading-title {
  font-family: var(--font-heading) !important;
}
.elementor-widget-text-editor {
  font-family: var(--font-body) !important;
}

/* Boutons Elementor : intégration palette du thème */
.elementor-button.elementor-button-link,
.elementor-button {
  font-family: var(--font-body) !important;
  font-weight: 600 !important;
  border-radius: var(--radius-md) !important;
  transition: all var(--transition) !important;
}

/* Couleurs Elementor alignées sur le thème */
.elementor-color-primary   { color: var(--color-primary) !important; }
.elementor-color-accent    { color: var(--color-accent)  !important; }
.elementor-color-secondary { color: var(--color-muted)   !important; }
.elementor-color-text      { color: var(--color-text)    !important; }

/* Sections Elementor avec fond primaire */
.elementor-section[data-settings*='"background_color":"#0A2540"'] {
  color: var(--color-white);
}

/* Formulaires Elementor Form (widget gratuit) */
.elementor-form .elementor-field-group .elementor-field {
  border-radius: var(--radius-md) !important;
  border: 1px solid var(--color-border) !important;
  font-family: var(--font-body) !important;
  padding: .75rem 1rem !important;
  transition: border-color var(--transition) !important;
}
.elementor-form .elementor-field-group .elementor-field:focus {
  border-color: var(--color-accent) !important;
  outline: none !important;
}
.elementor-form .elementor-button {
  background: var(--color-accent) !important;
  box-shadow: 0 4px 14px rgba(0,112,243,.35) !important;
}
.elementor-form .elementor-button:hover {
  background: var(--color-accent-hover) !important;
  transform: translateY(-1px) !important;
}

/* Image widget Elementor */
.elementor-widget-image img {
  border-radius: var(--radius-lg);
}

/* Divider Elementor */
.elementor-divider-separator {
  border-color: var(--color-border) !important;
}

/* Icônes Elementor */
.elementor-icon-box-icon .elementor-icon {
  color: var(--color-accent) !important;
}

/* Mode édition Elementor : afficher le header normalement */
body.elementor-editor-active .site-header {
  position: relative !important;
  top: auto !important;
}
body.elementor-editor-active #page {
  padding-top: 0 !important;
}

/* Réinitialisation des marges Elementor dans les colonnes */
.elementor-column .elementor-widget-wrap {
  padding: 0;
}

/* Fix : empêcher Elementor de masquer le contenu sous le header fixe */
.elementor-menu-anchor {
  margin-top: calc(-1 * var(--header-h));
  padding-top: var(--header-h);
}

/* Responsive Elementor */
@media (max-width: 1024px) {
  .elementor-section .elementor-container {
    padding-left: var(--space-lg) !important;
    padding-right: var(--space-lg) !important;
  }
}

@media (max-width: 767px) {
  .elementor-column {
    width: 100% !important;
  }
}

/* ============================================================
   TUTOR LMS — STYLES GLOBAUX
   ============================================================ */

/* ── Page de cours unique ── */
.course-hero {
  background: var(--color-primary);
  padding: 4rem 0 3rem;
  position: relative;
  overflow: hidden;
}
.course-hero::before {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse 60% 80% at 80% 50%, rgba(0,112,243,.18) 0%, transparent 70%);
  pointer-events: none;
}
.course-hero-inner {
  display: grid;
  grid-template-columns: 1fr 380px;
  gap: 3rem;
  align-items: start;
  position: relative;
}
.course-hero-title {
  color: var(--color-white);
  font-size: clamp(1.5rem, 2.5vw, 2.25rem);
  margin-bottom: 1rem;
}
.course-hero-excerpt {
  color: #94A3B8;
  font-size: 1rem;
  line-height: 1.7;
  margin-bottom: 1.25rem;
}
.course-hero-meta {
  display: flex;
  flex-wrap: wrap;
  gap: .75rem 1.25rem;
  margin-bottom: 1.25rem;
}
.course-meta-item {
  font-size: .875rem;
  color: #94A3B8;
  display: flex;
  align-items: center;
  gap: .3rem;
}
.course-hero-instructor {
  display: flex;
  align-items: center;
  gap: .75rem;
  font-size: .875rem;
  color: #64748B;
}
.course-hero-instructor a { color: #60A5FA; }
.instructor-avatar { border-radius: 50%; width: 32px; height: 32px; }

/* Carte d'inscription */
.course-enroll-card {
  background: var(--color-white);
  border-radius: var(--radius-xl);
  overflow: hidden;
  box-shadow: var(--shadow-xl);
  position: sticky;
  top: calc(var(--header-h) + 1rem);
}
.enroll-card-thumb {
  height: 200px;
  overflow: hidden;
  background: linear-gradient(135deg, var(--color-primary), var(--color-accent));
}
.enroll-card-body { padding: 1.5rem; }
.enroll-price { display: flex; align-items: baseline; gap: .75rem; margin-bottom: 1.25rem; }
.enroll-price-val { font-family: var(--font-heading); font-size: 1.75rem; font-weight: 800; color: var(--color-primary); }
.enroll-price-val.free { color: var(--color-success); }
.enroll-price-old { font-size: 1rem; color: var(--color-muted); text-decoration: line-through; }
.enroll-includes { margin-top: 1.25rem; padding-top: 1.25rem; border-top: 1px solid var(--color-border); }
.enroll-includes li {
  display: flex;
  align-items: center;
  gap: .6rem;
  font-size: .875rem;
  color: var(--color-text);
  padding: .3rem 0;
}

/* Layout contenu cours */
.course-content-layout {
  display: grid;
  grid-template-columns: 1fr 320px;
  gap: 2.5rem;
  align-items: start;
}
.course-sidebar-col { display: none; } /* En desktop, la enroll-card est déjà dans le hero */
.course-tabs {
  display: flex;
  gap: .25rem;
  border-bottom: 2px solid var(--color-border);
  margin-bottom: 2rem;
  overflow-x: auto;
}
.course-tab {
  padding: .75rem 1.25rem;
  font-size: .9rem;
  font-weight: 600;
  color: var(--color-muted);
  background: none;
  border: none;
  border-bottom: 2px solid transparent;
  margin-bottom: -2px;
  cursor: pointer;
  white-space: nowrap;
  transition: all .2s;
}
.course-tab:hover { color: var(--color-primary); }
.course-tab.active { color: var(--color-accent); border-bottom-color: var(--color-accent); }
.course-tab-pane { display: none; }
.course-tab-pane.active { display: block; }
.course-section-box {
  background: var(--color-white);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-xl);
  padding: 1.75rem;
  margin-bottom: 1.5rem;
}
.course-section-box h3 {
  font-size: 1.1rem;
  margin-bottom: 1.25rem;
  padding-bottom: .75rem;
  border-bottom: 1px solid var(--color-border);
}
.course-learn-list, .course-req-list {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: .5rem;
}
.course-learn-list li, .course-req-list li {
  display: flex;
  align-items: flex-start;
  gap: .5rem;
  font-size: .9rem;
  color: var(--color-text);
}
.course-req-list li { color: var(--color-muted); }
.instructor-avatar-lg { border-radius: 50%; width: 80px; height: 80px; flex-shrink: 0; }
.instructor-profile { display: flex; gap: 1.5rem; align-items: flex-start; }
.instructor-bio { font-size: .9rem; color: var(--color-muted); line-height: 1.7; }

/* ── Archive cours ── */
.archive-hero {
  background: var(--color-primary);
  padding: 3.5rem 0 3rem;
}
.archive-layout {
  display: grid;
  grid-template-columns: 240px 1fr;
  gap: 2.5rem;
  align-items: start;
}
.archive-filters { position: sticky; top: calc(var(--header-h) + 1rem); }
.filter-box {
  background: var(--color-white);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-xl);
  padding: 1.25rem;
  margin-bottom: 1rem;
}
.filter-box-title {
  font-size: .875rem;
  font-weight: 700;
  color: var(--color-primary);
  margin-bottom: .75rem;
  padding-bottom: .5rem;
  border-bottom: 1px solid var(--color-border);
}
.filter-list { display: flex; flex-direction: column; gap: .25rem; }
.filter-link {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: .4rem .6rem;
  border-radius: var(--radius-md);
  font-size: .875rem;
  color: var(--color-muted);
  text-decoration: none;
  transition: all .15s;
}
.filter-link:hover, .filter-link.active {
  background: var(--color-accent-soft);
  color: var(--color-accent);
}
.filter-count {
  background: var(--color-bg);
  color: var(--color-muted);
  font-size: .72rem;
  padding: 1px 7px;
  border-radius: 99px;
}
.filter-checkbox { display: flex; align-items: center; gap: .5rem; font-size: .875rem; color: var(--color-muted); cursor: pointer; padding: .3rem; }
.filter-checkbox input { accent-color: var(--color-accent); width: 15px; height: 15px; }
.archive-topbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  margin-bottom: 1.5rem;
  flex-wrap: wrap;
}
.archive-search-form { display: flex; gap: .5rem; flex: 1; min-width: 200px; }
.archive-search-input {
  flex: 1;
  padding: .65rem 1rem;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  font-family: var(--font-body);
  font-size: .9rem;
  outline: none;
}
.archive-search-input:focus { border-color: var(--color-accent); }
.archive-sort { display: flex; align-items: center; gap: .5rem; }
.archive-sort-select {
  padding: .6rem .75rem;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  font-family: var(--font-body);
  font-size: .875rem;
  color: var(--color-text);
  outline: none;
  cursor: pointer;
}

/* ── Dashboard ── */
.dashboard-layout {
  display: grid;
  grid-template-columns: 220px 1fr;
  gap: 2rem;
  align-items: start;
}
.dashboard-nav {
  background: var(--color-white);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-xl);
  padding: .75rem;
  position: sticky;
  top: calc(var(--header-h) + 1rem);
}
.dashboard-nav-link {
  display: flex;
  align-items: center;
  gap: .75rem;
  padding: .65rem .9rem;
  border-radius: var(--radius-md);
  font-size: .9rem;
  font-weight: 500;
  color: var(--color-muted);
  text-decoration: none;
  transition: all .15s;
}
.dashboard-nav-link:hover { background: var(--color-bg); color: var(--color-primary); }
.dashboard-nav-link.active { background: var(--color-accent-soft); color: var(--color-accent); font-weight: 600; }
.dashboard-stats {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1rem;
  margin-bottom: 2rem;
}
.dashboard-stat-card {
  background: var(--color-white);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-xl);
  padding: 1.25rem;
  display: flex;
  align-items: center;
  gap: 1rem;
}
.dashboard-stat-icon { font-size: 1.5rem; }
.dashboard-stat-val { display: block; font-family: var(--font-heading); font-size: 1.75rem; font-weight: 800; color: var(--color-primary); line-height: 1; }
.dashboard-stat-lbl { display: block; font-size: .78rem; color: var(--color-muted); text-transform: uppercase; letter-spacing: .04em; margin-top: 4px; }
.dashboard-body {
  background: var(--color-white);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-xl);
  padding: 1.75rem;
}

/* ── TutorLMS overrides natifs ── */
.tutor-course-topics-wrap { border: none !important; }
.tutor-course-topic > .tutor-course-topic-header {
  background: var(--color-bg) !important;
  border-radius: var(--radius-md) !important;
  padding: .75rem 1rem !important;
  font-weight: 600 !important;
  color: var(--color-primary) !important;
  cursor: pointer !important;
}
.tutor-course-topic-content li {
  border-bottom: 1px solid var(--color-border) !important;
  padding: .6rem 1rem !important;
}
.tutor-course-topic-content li a { color: var(--color-text) !important; }
.tutor-course-topic-content li a:hover { color: var(--color-accent) !important; }
.tutor-btn-primary,
.tutor-button-primary,
button.tutor-btn.tutor-btn-primary {
  background: var(--color-accent) !important;
  border-color: var(--color-accent) !important;
  font-family: var(--font-body) !important;
  font-weight: 600 !important;
  border-radius: var(--radius-md) !important;
}
.tutor-btn-primary:hover { background: var(--color-accent-hover) !important; }
.tutor-course-single-rating .tutor-star-rating-value { color: var(--color-accent) !important; }
.tutor-price { color: var(--color-success) !important; font-weight: 700 !important; font-family: var(--font-heading) !important; }

/* ── Responsive TutorLMS ── */
@media (max-width: 1024px) {
  .course-hero-inner { grid-template-columns: 1fr; }
  .course-enroll-card { position: static; max-width: 480px; }
  .course-content-layout { grid-template-columns: 1fr; }
  .archive-layout { grid-template-columns: 1fr; }
  .archive-filters { position: static; display: grid; grid-template-columns: repeat(3,1fr); gap: 1rem; }
  .dashboard-layout { grid-template-columns: 1fr; }
  .dashboard-nav { position: static; display: flex; flex-wrap: wrap; gap: .25rem; }
  .dashboard-stats { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 640px) {
  .course-learn-list { grid-template-columns: 1fr; }
  .archive-filters { grid-template-columns: 1fr; }
  .dashboard-stats { grid-template-columns: 1fr; }
}

/* ============================================================
   INSTRUCTEURS — STYLES
   ============================================================ */
.instructors-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-xl);
}
.instructor-card {
  background: var(--color-white);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-xl);
  padding: 1.75rem;
  text-align: center;
  transition: all var(--transition-slow);
}
.instructor-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-lg);
  border-color: rgba(0,112,243,.2);
}
.instructor-card-avatar { margin-bottom: 1rem; }
.instructor-card-img {
  width: 80px !important;
  height: 80px !important;
  border-radius: 50% !important;
  border: 3px solid var(--color-accent-soft) !important;
  margin: 0 auto !important;
  display: block !important;
}
.instructor-card-name {
  font-size: 1.05rem;
  margin-bottom: .25rem;
}
.instructor-card-name a { color: var(--color-primary); }
.instructor-card-name a:hover { color: var(--color-accent); }
.instructor-card-title {
  font-size: .8rem;
  color: var(--color-accent);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .05em;
  margin-bottom: .75rem;
}
.instructor-card-bio {
  font-size: .85rem;
  color: var(--color-muted);
  line-height: 1.6;
  margin-bottom: 1rem;
}
.instructor-card-stats {
  display: flex;
  justify-content: center;
  gap: 1rem;
  font-size: .8rem;
  color: var(--color-muted);
  flex-wrap: wrap;
  padding-top: 1rem;
  border-top: 1px solid var(--color-border);
}

/* Profil instructeur pleine page */
.instructor-hero {
  background: var(--color-primary);
  padding: 4rem 0 3rem;
  position: relative;
  overflow: hidden;
}
.instructor-hero::before {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse 60% 80% at 80% 50%, rgba(0,112,243,.18) 0%, transparent 70%);
  pointer-events: none;
}
.instructor-hero-inner {
  display: flex;
  align-items: center;
  gap: 2.5rem;
  position: relative;
}
.instructor-hero-img {
  width: 120px !important;
  height: 120px !important;
  border-radius: 50% !important;
  border: 4px solid rgba(255,255,255,.2) !important;
  flex-shrink: 0;
}
.instructor-hero-name {
  color: var(--color-white);
  font-size: clamp(1.5rem, 2.5vw, 2rem);
  margin-bottom: .4rem;
}
.instructor-hero-title {
  color: #60A5FA;
  font-size: .9rem;
  font-weight: 600;
  margin-bottom: 1.25rem;
}
.instructor-hero-stats {
  display: flex;
  gap: 2rem;
  flex-wrap: wrap;
  margin-bottom: 1.25rem;
}
.instructor-stat { text-align: center; }
.instructor-stat-val {
  display: block;
  font-family: var(--font-heading);
  font-size: 1.5rem;
  font-weight: 800;
  color: var(--color-white);
  line-height: 1;
}
.instructor-stat-lbl {
  display: block;
  font-size: .72rem;
  color: #64748B;
  text-transform: uppercase;
  letter-spacing: .06em;
  margin-top: 3px;
}
.instructor-socials { display: flex; gap: .5rem; }
.instructor-profile-layout {
  display: grid;
  grid-template-columns: 1fr 260px;
  gap: 2rem;
  align-items: start;
}
.instructor-profile-sidebar { position: sticky; top: calc(var(--header-h) + 1rem); }

/* ============================================================
   QUIZ RÉSULTATS — STYLES
   ============================================================ */
.quiz-result-card {
  background: var(--color-primary);
  border-radius: var(--radius-xl);
  padding: 3rem 2rem 2.5rem;
  text-align: center;
  margin-bottom: 1.5rem;
  position: relative;
  overflow: hidden;
}
.quiz-result-card::before {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse 70% 70% at 50% 0%, rgba(0,112,243,.2) 0%, transparent 70%);
  pointer-events: none;
}
.quiz-result-circle {
  width: 140px;
  height: 140px;
  margin: 0 auto 1.5rem;
  position: relative;
}
.quiz-result-svg { width: 100%; height: 100%; position: absolute; top: 0; left: 0; }
.quiz-result-pct {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-heading);
  font-size: 1.75rem;
  font-weight: 800;
  color: var(--color-white);
}
.quiz-result-verdict { position: relative; }
.quiz-stats-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1rem;
  margin-bottom: 1.5rem;
}
.quiz-stat-item {
  background: var(--color-white);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-xl);
  padding: 1.25rem;
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: .3rem;
}
.quiz-stat-icon { font-size: 1.25rem; }
.quiz-stat-val {
  font-family: var(--font-heading);
  font-size: 1.4rem;
  font-weight: 800;
  color: var(--color-primary);
  line-height: 1;
}
.quiz-stat-lbl { font-size: .75rem; color: var(--color-muted); text-transform: uppercase; letter-spacing: .04em; }

/* ============================================================
   WOOCOMMERCE — INTÉGRATION COURS PAYANTS
   ============================================================ */
.woocommerce-page .woocommerce {
  max-width: 100%;
}
/* Bouton d'ajout au panier WooCommerce stylisé thème */
.woocommerce .button,
.woocommerce button.button,
.woocommerce input.button,
.woocommerce a.button {
  background: var(--color-accent) !important;
  color: var(--color-white) !important;
  font-family: var(--font-body) !important;
  font-weight: 600 !important;
  border-radius: var(--radius-md) !important;
  padding: 12px 24px !important;
  border: none !important;
  box-shadow: 0 4px 14px rgba(0,112,243,.3) !important;
  transition: all var(--transition) !important;
  font-size: .95rem !important;
  cursor: pointer !important;
}
.woocommerce .button:hover { background: var(--color-accent-hover) !important; transform: translateY(-1px) !important; }
.woocommerce .button.alt { background: var(--color-primary) !important; }
/* Prix WooCommerce */
.woocommerce .price, .woocommerce .price ins {
  color: var(--color-primary) !important;
  font-family: var(--font-heading) !important;
  font-weight: 800 !important;
}
.woocommerce .price del { color: var(--color-muted) !important; font-weight: 400 !important; }
/* Formulaire checkout */
.woocommerce-checkout .form-row label { font-weight: 600; font-size: .875rem; color: var(--color-text); }
.woocommerce-checkout .form-row input,
.woocommerce-checkout .form-row select,
.woocommerce-checkout .form-row textarea {
  border: 1px solid var(--color-border) !important;
  border-radius: var(--radius-md) !important;
  padding: .75rem 1rem !important;
  font-family: var(--font-body) !important;
  font-size: .9rem !important;
  width: 100% !important;
  transition: border-color var(--transition) !important;
}
.woocommerce-checkout .form-row input:focus,
.woocommerce-checkout .form-row select:focus { border-color: var(--color-accent) !important; outline: none !important; }
/* Récapitulatif commande */
.woocommerce-order-details,
.woocommerce-customer-details { margin-top: 2rem; }
.woocommerce-table { width: 100%; border-collapse: collapse; }
.woocommerce-table th, .woocommerce-table td {
  padding: .75rem 1rem;
  border-bottom: 1px solid var(--color-border);
  font-size: .9rem;
}
.woocommerce-table th { font-weight: 700; color: var(--color-primary); background: var(--color-bg); }
/* Badge de prix sur les cartes de cours (libre/payant) */
.course-card .price-badge-free  { background: #D1FAE5; color: #065F46; }
.course-card .price-badge-paid  { background: #EFF6FF; color: #1D4ED8; }

/* ============================================================
   RESPONSIVE — INSTRUCTEURS / QUIZ / WOOCOMMERCE
   ============================================================ */
@media (max-width: 900px) {
  .instructors-grid { grid-template-columns: repeat(2,1fr); }
  .instructor-hero-inner { flex-direction: column; text-align: center; }
  .instructor-socials { justify-content: center; }
  .instructor-hero-stats { justify-content: center; }
  .instructor-profile-layout { grid-template-columns: 1fr; }
  .instructor-profile-sidebar { position: static; }
  .quiz-stats-grid { grid-template-columns: repeat(2,1fr); }
}
@media (max-width: 640px) {
  .instructors-grid { grid-template-columns: 1fr; }
  .quiz-stats-grid { grid-template-columns: repeat(2,1fr); }
}

/* ============================================================
   PAGE BLOG — DESIGN COMPLET
   ============================================================ */

/* ── Hero ── */
.blog-hero {
  background: var(--color-primary);
  padding: 4rem 0 3rem;
  position: relative;
  overflow: hidden;
}
.blog-hero::before {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse 70% 80% at 80% 50%, rgba(0,112,243,.18) 0%, transparent 65%);
  pointer-events: none;
}
.blog-hero-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 2rem;
  flex-wrap: wrap;
  position: relative;
}
.blog-hero-title {
  color: var(--color-white);
  font-size: clamp(1.8rem, 3vw, 2.5rem);
  margin: .5rem 0 .75rem;
}
.blog-hero-desc {
  color: #94A3B8;
  font-size: 1rem;
  margin: 0;
  max-width: 500px;
  line-height: 1.65;
}
.blog-hero-search {
  display: flex;
  gap: .5rem;
  align-items: center;
  flex-shrink: 0;
}
.blog-search-input {
  padding: .75rem 1.1rem;
  border: 1px solid rgba(255,255,255,.15);
  border-radius: var(--radius-md);
  background: rgba(255,255,255,.08);
  color: var(--color-white);
  font-family: var(--font-body);
  font-size: .9rem;
  width: 260px;
  outline: none;
  transition: border-color var(--transition), background var(--transition);
}
.blog-search-input::placeholder { color: #64748B; }
.blog-search-input:focus {
  border-color: rgba(0,112,243,.6);
  background: rgba(255,255,255,.12);
}

/* ── Filtres catégories ── */
.blog-filter-bar {
  background: var(--color-white);
  border-bottom: 1px solid var(--color-border);
  padding: .75rem 0;
  position: sticky;
  top: var(--header-h);
  z-index: 90;
}
body.admin-bar .blog-filter-bar { top: calc(var(--header-h) + 32px); }
@media (max-width: 782px) { body.admin-bar .blog-filter-bar { top: calc(var(--header-h) + 46px); } }

.blog-filter-inner {
  display: flex;
  gap: .4rem;
  flex-wrap: wrap;
  align-items: center;
}
.blog-filter-pill {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 6px 14px;
  border-radius: var(--radius-full);
  font-size: .8rem;
  font-weight: 600;
  color: var(--color-muted);
  text-decoration: none;
  border: 1.5px solid var(--color-border);
  background: transparent;
  transition: all var(--transition);
  white-space: nowrap;
}
.blog-filter-pill:hover {
  border-color: var(--color-accent);
  color: var(--color-accent);
  background: var(--color-accent-soft);
}
.blog-filter-pill.active {
  background: var(--color-primary);
  border-color: var(--color-primary);
  color: var(--color-white);
}
.blog-filter-count {
  background: rgba(0,0,0,.08);
  border-radius: 999px;
  padding: 1px 7px;
  font-size: .7rem;
}
.blog-filter-pill.active .blog-filter-count { background: rgba(255,255,255,.2); }

/* ── Layout conteneur ── */
.blog-container {
  padding-top: 3rem;
  padding-bottom: 5rem;
}

/* ── Article featured ── */
.blog-card-featured {
  display: grid;
  grid-template-columns: 1.1fr 1fr;
  gap: 0;
  background: var(--color-white);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-xl);
  overflow: hidden;
  margin-bottom: 3rem;
  transition: box-shadow var(--transition-slow);
}
.blog-card-featured:hover {
  box-shadow: var(--shadow-xl);
}
.blog-featured-thumb {
  position: relative;
  overflow: hidden;
  min-height: 320px;
  background: linear-gradient(135deg, var(--color-primary), var(--color-primary-light));
}
.blog-featured-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform var(--transition-slow);
}
.blog-card-featured:hover .blog-featured-thumb img { transform: scale(1.04); }
.blog-featured-cat {
  position: absolute;
  top: 1rem;
  left: 1rem;
  background: var(--color-accent);
  color: var(--color-white);
  font-size: .72rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .07em;
  padding: 4px 12px;
  border-radius: var(--radius-full);
}
.blog-featured-body {
  padding: 2.5rem;
  display: flex;
  flex-direction: column;
  justify-content: center;
}
.blog-featured-title {
  font-size: clamp(1.25rem, 2vw, 1.6rem);
  font-weight: 800;
  color: var(--color-primary);
  line-height: 1.25;
  margin: .75rem 0 1rem;
}
.blog-featured-title a { color: inherit; }
.blog-featured-title a:hover { color: var(--color-accent); }
.blog-featured-excerpt {
  font-size: .95rem;
  color: var(--color-muted);
  line-height: 1.7;
  margin-bottom: 1.75rem;
}

/* ── Titre section grille ── */
.blog-grid-heading {
  font-size: 1.15rem;
  font-weight: 700;
  color: var(--color-primary);
  margin-bottom: 1.5rem;
  display: flex;
  align-items: center;
  gap: .75rem;
}
.blog-grid-heading::after {
  content: '';
  flex: 1;
  height: 1px;
  background: var(--color-border);
}

/* ── Grille 3 colonnes ── */
.blog-grid-3 {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.75rem;
  margin-bottom: 3rem;
}

/* ── Carte blog (grille) ── */
.blog-card {
  background: var(--color-white);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-xl);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  transition: all var(--transition-slow);
}
.blog-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-lg);
  border-color: rgba(0,112,243,.2);
}
.blog-card-thumb-link { display: block; overflow: hidden; }
.blog-card-thumb {
  position: relative;
  aspect-ratio: 16/9;
  overflow: hidden;
  background: linear-gradient(135deg, var(--color-primary), var(--color-primary-light));
}
.blog-card-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform var(--transition-slow);
  display: block;
}
.blog-card:hover .blog-card-thumb img { transform: scale(1.05); }
.blog-thumb-placeholder {
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 2.5rem;
  min-height: 160px;
}
.blog-card-cat-badge {
  position: absolute;
  top: .75rem;
  left: .75rem;
  background: var(--color-accent);
  color: var(--color-white);
  font-size: .68rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .07em;
  padding: 3px 10px;
  border-radius: var(--radius-full);
}
.blog-card-body {
  padding: 1.25rem;
  flex: 1;
  display: flex;
  flex-direction: column;
}
.blog-card-meta {
  display: flex;
  align-items: center;
  gap: .4rem;
  font-size: .75rem;
  color: var(--color-muted);
  margin-bottom: .6rem;
  flex-wrap: wrap;
}
.blog-meta-dot { color: var(--color-light); }
.blog-card-title {
  font-size: 1rem;
  font-weight: 700;
  color: var(--color-primary);
  line-height: 1.35;
  margin-bottom: .6rem;
  flex: 1;
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.blog-card-title a { color: inherit; }
.blog-card-title a:hover { color: var(--color-accent); }
.blog-card-excerpt {
  font-size: .8rem;
  color: var(--color-muted);
  line-height: 1.6;
  margin-bottom: 1rem;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.blog-card-footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding-top: .9rem;
  border-top: 1px solid var(--color-border);
  margin-top: auto;
}
.blog-card-author {
  display: flex;
  align-items: center;
  gap: .5rem;
  font-size: .78rem;
  color: var(--color-muted);
}
.blog-author-avatar {
  width: 24px !important;
  height: 24px !important;
  border-radius: 50% !important;
}
.blog-card-read-more {
  font-size: .78rem;
  font-weight: 700;
  color: var(--color-accent);
  text-decoration: none;
  transition: gap var(--transition);
  white-space: nowrap;
}
.blog-card-read-more:hover { color: var(--color-accent-hover); }

/* ── Aucun article ── */
.blog-empty {
  text-align: center;
  padding: 5rem 0;
}
.blog-empty-icon {
  font-size: 3.5rem;
  margin-bottom: 1rem;
}
.blog-empty h2 { margin-bottom: .75rem; }
.blog-empty p  { margin-bottom: 2rem; }

/* ── Pagination ── */
.blog-pagination {
  display: flex;
  justify-content: center;
  padding-top: 1rem;
}
.blog-pagination .nav-links {
  display: flex;
  align-items: center;
  gap: .4rem;
  flex-wrap: wrap;
  justify-content: center;
}
.blog-pagination .page-numbers {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 40px;
  height: 40px;
  padding: 0 .75rem;
  border-radius: var(--radius-md);
  border: 1.5px solid var(--color-border);
  color: var(--color-text);
  font-size: .875rem;
  font-weight: 600;
  text-decoration: none;
  transition: all var(--transition);
  background: var(--color-white);
}
.blog-pagination .page-numbers:hover {
  border-color: var(--color-accent);
  color: var(--color-accent);
  background: var(--color-accent-soft);
}
.blog-pagination .page-numbers.current {
  background: var(--color-accent);
  border-color: var(--color-accent);
  color: var(--color-white);
}
.blog-pagination .page-numbers.dots {
  border-color: transparent;
  background: transparent;
}

/* ── Responsive ── */
@media (max-width: 1024px) {
  .blog-grid-3 { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 768px) {
  .blog-hero-inner { flex-direction: column; align-items: flex-start; }
  .blog-hero-search { width: 100%; }
  .blog-search-input { flex: 1; width: auto; }
  .blog-card-featured { grid-template-columns: 1fr; }
  .blog-featured-thumb { min-height: 220px; }
  .blog-featured-body { padding: 1.5rem; }
}
@media (max-width: 640px) {
  .blog-grid-3 { grid-template-columns: 1fr; }
  .blog-filter-inner { gap: .3rem; }
}

/* ============================================================
   PAGE CONTACT — STYLES NATIFS
   ============================================================ */

/* ── Hero ── */
.contact-hero {
  background: var(--color-primary);
  padding: 4rem 0 3rem;
  position: relative;
  overflow: hidden;
}
.contact-hero::before {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse 60% 80% at 80% 50%, rgba(0,112,243,.18) 0%, transparent 70%);
  pointer-events: none;
}
.contact-hero-title {
  color: var(--color-white);
  margin: .5rem 0 .75rem;
}
.contact-hero-desc {
  color: #94A3B8;
  max-width: 520px;
  font-size: 1rem;
  margin: 0;
  line-height: 1.65;
}

/* ── Layout ── */
.contact-container {
  padding-top: 3.5rem;
  padding-bottom: 5rem;
}
.contact-layout {
  display: grid;
  grid-template-columns: 1fr 2fr;
  gap: 2.5rem;
  align-items: start;
}

/* ── Colonne infos ── */
.contact-info-col {
  display: flex;
  flex-direction: column;
  gap: 1.25rem;
  position: sticky;
  top: calc(var(--header-h) + 1rem);
}
body.admin-bar .contact-info-col { top: calc(var(--header-h) + 32px + 1rem); }

.contact-info-item {
  display: flex;
  align-items: flex-start;
  gap: 1rem;
  background: var(--color-white);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-xl);
  padding: 1.25rem;
  transition: box-shadow var(--transition), border-color var(--transition);
}
.contact-info-item:hover {
  border-color: rgba(0,112,243,.2);
  box-shadow: var(--shadow-sm);
}
.contact-info-icon {
  width: 42px;
  height: 42px;
  background: var(--color-accent-soft);
  color: var(--color-accent);
  border-radius: var(--radius-lg);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.contact-info-label {
  font-size: .72rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .08em;
  color: var(--color-muted);
  margin-bottom: 3px;
}
.contact-info-value {
  font-size: .9rem;
  color: var(--color-text);
  font-weight: 500;
}
.contact-info-link {
  color: var(--color-accent);
  text-decoration: none;
}
.contact-info-link:hover { color: var(--color-accent-hover); text-decoration: underline; }
.contact-socials {
  background: var(--color-white);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-xl);
  padding: 1.25rem;
}

/* ── Carte formulaire ── */
.contact-form-card {
  background: var(--color-white);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-xl);
  overflow: hidden;
}
.contact-form-header {
  padding: 2rem 2rem 0;
  margin-bottom: 1.75rem;
}
.contact-form-title {
  font-size: 1.3rem;
  font-weight: 800;
  color: var(--color-primary);
  margin: 0 0 .35rem;
}
.contact-form-subtitle {
  font-size: .85rem;
  color: var(--color-muted);
  margin: 0;
}

/* ── Erreurs ── */
.contact-errors {
  margin: 0 2rem 1.25rem;
  background: #FEF2F2;
  border: 1px solid #FECACA;
  border-radius: var(--radius-lg);
  padding: 1rem 1.25rem;
  display: flex;
  flex-direction: column;
  gap: .5rem;
}
.contact-error-item {
  display: flex;
  align-items: center;
  gap: .5rem;
  font-size: .875rem;
  color: #B91C1C;
}

/* ── Formulaire ── */
.contact-form {
  padding: 0 2rem 2rem;
  display: flex;
  flex-direction: column;
  gap: 0;
}
.contact-form-row {
  margin-bottom: 1.1rem;
}
.contact-form-row-2 {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1rem;
  margin-bottom: 1.1rem;
}
.contact-field {
  display: flex;
  flex-direction: column;
  gap: .4rem;
}
.contact-label {
  font-size: .8rem;
  font-weight: 700;
  color: var(--color-text);
  letter-spacing: .01em;
}
.contact-required { color: var(--color-accent); }

.contact-input,
.contact-textarea,
.contact-select {
  width: 100%;
  padding: .75rem 1rem;
  border: 1.5px solid var(--color-border);
  border-radius: var(--radius-md);
  font-family: var(--font-body);
  font-size: .9rem;
  color: var(--color-text);
  background: var(--color-bg);
  outline: none;
  transition: border-color var(--transition), background var(--transition), box-shadow var(--transition);
  -webkit-appearance: none;
  appearance: none;
}
.contact-input:focus,
.contact-textarea:focus,
.contact-select:focus {
  border-color: var(--color-accent);
  background: var(--color-white);
  box-shadow: 0 0 0 3px rgba(0,112,243,.12);
}
.contact-input::placeholder,
.contact-textarea::placeholder { color: var(--color-light); }
.contact-textarea { resize: vertical; min-height: 140px; line-height: 1.6; }

/* Select avec flèche custom */
.contact-select-wrap {
  position: relative;
}
.contact-select {
  cursor: pointer;
  padding-right: 2.5rem;
}
.contact-select-arrow {
  position: absolute;
  right: .9rem;
  top: 50%;
  transform: translateY(-50%);
  pointer-events: none;
  color: var(--color-muted);
}

/* Checkbox RGPD */
.contact-checkbox-label {
  display: flex;
  align-items: flex-start;
  gap: .65rem;
  font-size: .825rem;
  color: var(--color-muted);
  cursor: pointer;
  line-height: 1.55;
}
.contact-checkbox {
  width: 16px;
  height: 16px;
  accent-color: var(--color-accent);
  flex-shrink: 0;
  margin-top: 2px;
  cursor: pointer;
}
.contact-checkbox-label a { color: var(--color-accent); }

/* Bouton submit */
.contact-submit {
  width: 100%;
  justify-content: center;
  gap: .6rem;
  font-size: 1rem;
  padding: .875rem 1.5rem;
}

/* ── Succès ── */
.contact-success {
  background: var(--color-white);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-xl);
  padding: 4rem 2rem;
  text-align: center;
}
.contact-success-icon {
  width: 64px;
  height: 64px;
  background: #D1FAE5;
  color: #065F46;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto 1.5rem;
}
.contact-success h2 { margin-bottom: .75rem; }
.contact-success p  { color: var(--color-muted); margin-bottom: 2rem; }

/* ── Responsive ── */
@media (max-width: 900px) {
  .contact-layout { grid-template-columns: 1fr; }
  .contact-info-col { position: static; flex-direction: row; flex-wrap: wrap; }
  .contact-info-item { flex: 1 1 200px; }
}
@media (max-width: 600px) {
  .contact-form-row-2 { grid-template-columns: 1fr; }
  .contact-form-header,
  .contact-form { padding-left: 1.25rem; padding-right: 1.25rem; }
  .contact-errors { margin-left: 1.25rem; margin-right: 1.25rem; }
  .contact-info-col { flex-direction: column; }
}

/* ============================================================
   TUTOR LMS — DASHBOARD INJECTÉ VIA HOOKS
   ============================================================ */

/* Bannière de bienvenue */
.netsec-dashboard-header {
  background: var(--color-primary);
  border-radius: var(--radius-xl);
  padding: 1.75rem 2rem;
  margin-bottom: 1.75rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1.5rem;
  flex-wrap: wrap;
  position: relative;
  overflow: hidden;
}
.netsec-dashboard-header::before {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse 60% 100% at 100% 50%, rgba(0,112,243,.2) 0%, transparent 65%);
  pointer-events: none;
}
.netsec-dashboard-welcome {
  display: flex;
  align-items: center;
  gap: 1rem;
  position: relative;
}
.netsec-dash-avatar {
  width: 52px !important;
  height: 52px !important;
  border-radius: 50% !important;
  border: 3px solid rgba(255,255,255,.2) !important;
  flex-shrink: 0;
}
.netsec-dash-greeting {
  color: var(--color-white);
  font-size: 1.25rem;
  margin: 0 0 .2rem;
  font-weight: 700;
}
.netsec-dash-sub {
  color: #94A3B8;
  font-size: .85rem;
  margin: 0;
}
.netsec-dashboard-stats {
  display: flex;
  gap: 1.5rem;
  position: relative;
  flex-wrap: wrap;
}
.netsec-dash-stat {
  text-align: center;
  padding: .75rem 1.25rem;
  background: rgba(255,255,255,.08);
  border: 1px solid rgba(255,255,255,.1);
  border-radius: var(--radius-lg);
  min-width: 90px;
}
.netsec-dash-stat-icon {
  display: block;
  font-size: 1.2rem;
  margin-bottom: .2rem;
}
.netsec-dash-stat-val {
  display: block;
  font-family: var(--font-heading);
  font-size: 1.5rem;
  font-weight: 800;
  color: var(--color-white);
  line-height: 1;
}
.netsec-dash-stat-lbl {
  display: block;
  font-size: .68rem;
  color: #64748B;
  text-transform: uppercase;
  letter-spacing: .06em;
  margin-top: 3px;
}

/* Stylisation du dashboard TutorLMS natif */
.tutor-dashboard-wrapper {
  display: grid !important;
  grid-template-columns: 220px 1fr !important;
  gap: 1.75rem !important;
  align-items: start !important;
}

/* Menu latéral TutorLMS */
.tutor-dashboard-permalinks {
  background: var(--color-white) !important;
  border: 1px solid var(--color-border) !important;
  border-radius: var(--radius-xl) !important;
  padding: .6rem !important;
  position: sticky !important;
  top: calc(var(--header-h) + 1rem) !important;
}
body.admin-bar .tutor-dashboard-permalinks {
  top: calc(var(--header-h) + 32px + 1rem) !important;
}
.tutor-dashboard-permalinks li a {
  display: flex !important;
  align-items: center !important;
  gap: .65rem !important;
  padding: .6rem .85rem !important;
  border-radius: var(--radius-md) !important;
  font-size: .875rem !important;
  font-weight: 500 !important;
  color: var(--color-muted) !important;
  text-decoration: none !important;
  transition: all var(--transition) !important;
}
.tutor-dashboard-permalinks li a:hover {
  background: var(--color-bg) !important;
  color: var(--color-primary) !important;
}
.tutor-dashboard-permalinks li.active a,
.tutor-dashboard-permalinks li a.active,
.tutor-dashboard-permalinks li.tutor-is-active a {
  background: var(--color-accent-soft) !important;
  color: var(--color-accent) !important;
  font-weight: 600 !important;
}

/* Zone de contenu TutorLMS */
.tutor-dashboard-content-area {
  background: var(--color-white) !important;
  border: 1px solid var(--color-border) !important;
  border-radius: var(--radius-xl) !important;
  padding: 1.75rem !important;
  min-height: 400px !important;
}

/* Cards de cours dans le dashboard */
.tutor-dashboard-content-area .tutor-course-list {
  display: grid !important;
  grid-template-columns: repeat(2, 1fr) !important;
  gap: 1.25rem !important;
}
.tutor-dashboard-content-area .tutor-course-card {
  border-radius: var(--radius-xl) !important;
  border: 1px solid var(--color-border) !important;
  overflow: hidden !important;
  transition: box-shadow var(--transition-slow), transform var(--transition-slow) !important;
}
.tutor-dashboard-content-area .tutor-course-card:hover {
  box-shadow: var(--shadow-md) !important;
  transform: translateY(-2px) !important;
}

/* Barre de progression dans le dashboard */
.tutor-progress-bar {
  background: var(--color-bg) !important;
  border-radius: 99px !important;
  overflow: hidden !important;
  height: 6px !important;
}
.tutor-progress-bar .tutor-progress-filled {
  background: var(--color-accent) !important;
  border-radius: 99px !important;
  transition: width .4s ease !important;
}

/* Titres de sections dashboard */
.tutor-dashboard-content-area h2,
.tutor-dashboard-content-area .tutor-segment-title {
  font-family: var(--font-heading) !important;
  font-size: 1.1rem !important;
  font-weight: 700 !important;
  color: var(--color-primary) !important;
  margin-bottom: 1.25rem !important;
  padding-bottom: .75rem !important;
  border-bottom: 1px solid var(--color-border) !important;
}

/* Tableau quiz/achats */
.tutor-dashboard-content-area table {
  width: 100% !important;
  border-collapse: collapse !important;
}
.tutor-dashboard-content-area th {
  font-size: .75rem !important;
  font-weight: 700 !important;
  text-transform: uppercase !important;
  letter-spacing: .06em !important;
  color: var(--color-muted) !important;
  padding: .6rem 1rem !important;
  border-bottom: 2px solid var(--color-border) !important;
  background: var(--color-bg) !important;
  text-align: left !important;
}
.tutor-dashboard-content-area td {
  font-size: .875rem !important;
  padding: .75rem 1rem !important;
  border-bottom: 1px solid var(--color-border) !important;
  color: var(--color-text) !important;
  vertical-align: middle !important;
}
.tutor-dashboard-content-area tr:last-child td { border-bottom: none !important; }

/* Formulaire settings dans dashboard */
.tutor-dashboard-content-area .tutor-form-group label {
  font-size: .8rem !important;
  font-weight: 700 !important;
  color: var(--color-text) !important;
  margin-bottom: .35rem !important;
}
.tutor-dashboard-content-area .tutor-form-control {
  border: 1.5px solid var(--color-border) !important;
  border-radius: var(--radius-md) !important;
  padding: .7rem 1rem !important;
  font-family: var(--font-body) !important;
  transition: border-color var(--transition) !important;
}
.tutor-dashboard-content-area .tutor-form-control:focus {
  border-color: var(--color-accent) !important;
  outline: none !important;
  box-shadow: 0 0 0 3px rgba(0,112,243,.1) !important;
}

/* Responsive dashboard */
@media (max-width: 900px) {
  .tutor-dashboard-wrapper {
    grid-template-columns: 1fr !important;
  }
  .tutor-dashboard-permalinks {
    position: static !important;
    display: flex !important;
    flex-wrap: wrap !important;
    gap: .25rem !important;
  }
  .netsec-dashboard-header {
    flex-direction: column;
    align-items: flex-start;
  }
  .netsec-dashboard-stats {
    width: 100%;
  }
  .netsec-dash-stat {
    flex: 1;
    min-width: 80px;
  }
  .tutor-dashboard-content-area .tutor-course-list {
    grid-template-columns: 1fr !important;
  }
}
