/**
 * Design Moderne pour TLS Parcours
 * Inspiré du design fourni avec sidebar et système de verrouillage
 */

:root{
  --tls-blue:#55A1B4;
  --tls-orange:#EB7724;
  --tls-yellow:#F8B044;
  --tls-salmon:#F49A76;
  --tls-text:#333;
  --border:#E7EFF2;
  --sidebar-w:260px;
  --header-h:65px;
  --radius:14px;
  --muted:#5b6b71;
  --container:1200px;
  --ok:#20a05b;
  --gray:#94a3ab;
}

/* Reset pour le parcours */
.tls-pc-parcours-wrapper *{box-sizing:border-box}

/* Hero plein largeur */
.tls-pc-hero-wrap{position:relative;background:var(--tls-blue);color:#fff;margin:0 0 30px}
.tls-pc-hero-wrap::after{
  content:""; position:absolute; inset:0;
  background: radial-gradient(ellipse at 20% 10%, rgba(255,255,255,.18), transparent 45%),
              radial-gradient(ellipse at 80% 90%, rgba(255,255,255,.12), transparent 50%);
  pointer-events:none;
}
.tls-pc-hero-inner{
  max-width:var(--container); margin:0 auto; padding:40px 24px 36px;
  text-align:center;position:relative;z-index:1;
}
.tls-pc-course-title{margin:0 0 6px;font-family:"League Spartan",sans-serif;font-weight:800;font-size:clamp(30px,4.5vw,44px);color:#fff}
.tls-pc-course-sub{margin:0 16px 18px 0;font-family:"Oswald",sans-serif;letter-spacing:.3px;color:#E9F7FB;font-size:clamp(16px,2.2vw,20px)}

/* Layout sans sidebar */
.tls-pc-layout{max-width:var(--container);margin:0 auto}

/* Système d'onglets pour les étapes */
.tls-pc-tabs-nav{
  display:flex;
  gap:8px;
  margin:0 24px 24px;
  border-bottom:2px solid var(--border);
  overflow-x:auto;
}
.tls-pc-tab{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:12px 20px;
  border:none;
  background:none;
  border-bottom:3px solid transparent;
  font-family:"League Spartan",sans-serif;
  font-weight:800;
  font-size:15px;
  color:var(--muted);
  cursor:pointer;
  white-space:nowrap;
  transition:all .2s;
}
.tls-pc-tab:hover{color:var(--tls-blue);background:#f6fbfd}
.tls-pc-tab.active{color:var(--tls-blue);border-bottom-color:var(--tls-blue)}
.tls-pc-tab.completed{color:var(--ok)}
.tls-pc-tab.locked{opacity:.5;cursor:not-allowed}
.tls-pc-tab-icon{width:20px;height:20px}

/* Contenu des onglets */
.tls-pc-tab-content{display:none}
.tls-pc-tab-content.active{display:block}

/* Contenu principal */
.tls-pc-content{min-width:0;padding:18px 24px 96px}

/* Message de verrouillage */
.tls-pc-locked-message{
  text-align:center;padding:80px 20px;background:#f9fcfd;border:2px dashed var(--border);border-radius:14px;
}
.tls-pc-locked-message .icon{font-size:60px;display:block;margin-bottom:16px}
.tls-pc-locked-message h3{font-family:"League Spartan",sans-serif;font-weight:800;color:#12343c;margin:0 0 8px}
.tls-pc-locked-message p{color:var(--muted);margin:0}

/* Aperçu rapide - Meta du parcours */
.tls-pc-quick{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin:0 0 20px}
.tls-pc-qcard{display:flex;align-items:center;gap:10px;border:1px solid var(--border);background:#fff;border-radius:14px;padding:14px}
.tls-pc-qico{
  width:40px;height:40px;border-radius:11px;display:inline-flex;align-items:center;justify-content:center;
  background:#FFF8EF;border:1px solid #fde8c7;color:var(--tls-yellow);flex:0 0 auto;
}
.tls-pc-qmeta b{display:block;font-family:"Oswald",sans-serif;color:#12343c;letter-spacing:.2px}
.tls-pc-qmeta small{color:#63737a}

/* Bloc standard */
.tls-pc-block{border:1px solid var(--border);border-radius:14px;padding:16px;background:#fff;margin-bottom:16px}
.tls-pc-block h2{margin:0 0 8px;font-family:"Oswald",sans-serif;color:#12343c;letter-spacing:.2px;font-size:22px}
.tls-pc-lead{margin:0 0 8px;color:#4a5559}

/* Compétences/Objectifs */
.tls-pc-skills{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:12px;margin-top:10px}
.tls-pc-skill{display:flex;gap:10px;border:1px solid #E7EFF2;border-radius:12px;padding:12px;background:#fcfdfd;align-items:flex-start}
.tls-pc-sico{
  width:34px;height:34px;border-radius:10px;display:inline-flex;align-items:center;justify-content:center;
  background:#FFF8EF;border:1px solid #fde8c7;color:var(--tls-yellow);flex:0 0 auto;
}
.tls-pc-skill h3{margin:0 4px 2px 0;font-family:"Oswald",sans-serif;font-size:16px;color:#12343c;letter-spacing:.2px}
.tls-pc-skill p{margin:0;color:#4a5559;font-size:14px}

/* Barre de progression */
.tls-pc-progress-wrap{display:flex;align-items:center;gap:10px;margin:6px 0 12px}
.tls-pc-bar{flex:1;height:10px;border-radius:999px;background:#eef6f8;overflow:hidden;border:1px solid #d9e9ee}
.tls-pc-bar > span{display:block;height:100%;background:linear-gradient(90deg,var(--tls-orange),#f8b77a)}
.tls-pc-percent{font-family:"League Spartan";font-weight:800;color:#12343c}

/* Liste des leçons (étapes) */
.tls-pc-lesson-list{display:flex;flex-direction:column;gap:10px;margin-top:10px}
.tls-pc-lesson{
  display:grid;
  grid-template-columns:auto 1fr auto;
  gap:12px;
  align-items:center;
  border:1px solid var(--border);
  border-radius:12px;
  background:#fff;
  padding:12px;
  text-decoration:none;
  color:inherit;
  transition:all .2s;
}
.tls-pc-lesson:hover:not(.locked){background:#f9fcfd}
.tls-pc-lesson.locked{opacity:.6;cursor:not-allowed}

.tls-pc-status{
  width:26px;height:26px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;
  border:2px solid #cfe0e6;color:#9bb1b8;flex:0 0 auto;
}
.tls-pc-status.done{background:#e8f7ef;border-color:#bfe8cf;color:#1e8a54}
.tls-pc-status.current{border-color:var(--tls-orange);color:var(--tls-orange)}
.tls-pc-status.locked{border-color:#e0e0e0;color:#ccc}

.tls-pc-ltitle{margin:0 0 2px 0;font-family:"Nunito",sans-serif;font-weight:800;color:#12343c;font-size:16px}
.tls-pc-ldur{display:inline-block;margin:0 0 6px 0;font-family:"Oswald",sans-serif;font-size:14px;color:#0e4a56}
.tls-pc-ldesc{margin:0;color:#617177;font-size:14px}

.tls-pc-action{justify-self:end}
.tls-pc-btn-action{
  font-family:"League Spartan",sans-serif;font-weight:800;
  display:inline-flex;align-items:center;justify-content:center;
  padding:10px 14px;border-radius:10px;border:1px solid transparent;
  text-decoration:none;cursor:pointer;font-size:14px;min-width:132px;
  transition:all .2s;
}
.tls-pc-btn-action.is-current{background:var(--tls-orange);border-color:var(--tls-orange);color:#fff}
.tls-pc-btn-action.is-done{background:#e8f7ef;border-color:#bfe8cf;color:var(--ok)}
.tls-pc-btn-action.is-next{background:#f1f4f6;border-color:#d9e1e6;color:var(--gray)}
.tls-pc-btn-action.is-locked{background:#f5f5f5;border-color:#e0e0e0;color:#999;cursor:not-allowed}

/* Message de verrouillage */
.tls-pc-locked-message{
  background:#FFF8EF;
  border:2px solid #fde8c7;
  border-radius:12px;
  padding:20px;
  text-align:center;
  margin:20px 0;
}
.tls-pc-locked-message .icon{font-size:48px;margin-bottom:10px;display:block}
.tls-pc-locked-message h3{
  margin:10px 0;
  font-family:"League Spartan",sans-serif;
  font-weight:800;
  color:var(--tls-orange);
  font-size:20px;
}
.tls-pc-locked-message p{
  margin:10px 0 0;
  color:#5b6b71;
  font-size:15px;
}

/* Contenus complémentaires - Cartes */
.tls-pc-extras-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:16px;margin-top:16px}
.tls-pc-extra-card{
  display:flex;flex-direction:column;border:1px solid var(--border);
  border-radius:12px;background:#fff;overflow:hidden;transition:all .2s;
}
.tls-pc-extra-card:hover{box-shadow:0 4px 12px rgba(0,0,0,.08)}
.tls-pc-extra-thumb{position:relative;aspect-ratio:16/9;background:#F6FBFD;border-bottom:1px solid var(--border)}
.tls-pc-extra-tag{
  position:absolute;left:10px;top:10px;padding:6px 10px;border-radius:999px;
  background:#FFF8EF;border:1px solid #fde8c7;color:var(--tls-yellow);
  font-family:"League Spartan",sans-serif;font-weight:800;font-size:12px;letter-spacing:.2px;
}
.tls-pc-extra-body{padding:12px}
.tls-pc-extra-title{margin:0 0 6px;font-family:"Nunito",sans-serif;font-weight:800;color:#12343c;font-size:16px}
.tls-pc-extra-meta{display:flex;gap:10px;align-items:center;color:#617177;font-size:13px}
.tls-pc-extra-meta svg{width:16px;height:16px}
.tls-pc-extra-foot{display:flex;gap:8px;padding:12px;border-top:1px solid var(--border)}
.tls-pc-extra-btn{
  flex:1;display:inline-flex;align-items:center;justify-content:center;gap:8px;
  padding:10px 12px;border-radius:10px;border:1px solid #d9e1e6;background:#f6f8f9;
  font-family:"League Spartan",sans-serif;font-weight:800;font-size:14px;
  color:#12343c;text-decoration:none;transition:all .2s;
}
.tls-pc-extra-btn:hover{background:#e8eef1}
.tls-pc-extra-btn.primary{background:var(--tls-orange);border-color:var(--tls-orange);color:#fff}
.tls-pc-extra-btn.primary:hover{filter:brightness(1.05)}

/* Contenus complémentaires - Carrousel simple (1 carte) */
.tls-pc-single-carousel-container{
  position:relative;display:flex;align-items:stretch;gap:16px;
}
.tls-pc-single-carousel-wrapper{
  position:relative;flex:1;min-height:120px;
}
.tls-pc-single-card{
  position:absolute;top:0;left:0;width:100%;
  padding:18px 20px;border:2px solid #e0e6eb;border-radius:10px;background:#fff;
  transition:all .4s cubic-bezier(.4,0,.2,1);
  opacity:0;transform:translateX(30px);pointer-events:none;
}
.tls-pc-single-card.active{
  opacity:1;transform:translateX(0);pointer-events:auto;
}
.tls-pc-single-card:hover{
  border-color:#55A1B4;box-shadow:0 4px 12px rgba(85,161,180,.12);
}
.tls-pc-single-card-link{
  text-decoration:none;display:block;color:inherit;
}
.tls-pc-single-card-link:hover h4{color:var(--tls-orange)}
.tls-pc-single-carousel-btn{
  flex-shrink:0;display:flex;align-items:center;justify-content:center;
  width:48px;height:48px;border-radius:10px;border:2px solid #d9e1e6;
  background:#fff;cursor:pointer;transition:all .25s;color:#617177;
  align-self:center;
}
.tls-pc-single-carousel-btn:hover{
  background:#55A1B4;border-color:#55A1B4;color:#fff;
  transform:translateX(3px);
}
.tls-pc-type-badge{
  background:#E8F4F8;color:#1B7A9E;padding:5px 12px;border-radius:14px;
  font-size:11px;font-weight:700;white-space:nowrap;margin-left:10px;
  font-family:"League Spartan",sans-serif;letter-spacing:.4px;text-transform:uppercase;
}

/* Navigation étapes (précédente/suivante) */
.tls-pc-step-nav{
  display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:24px;padding-top:24px;
  border-top:2px solid var(--border);
}
.tls-pc-step-btn{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  padding:14px 16px;border-radius:12px;border:1px solid var(--border);background:#fff;
  font-family:"League Spartan",sans-serif;font-weight:800;font-size:16px;
  color:#12343c;text-decoration:none;transition:all .2s;
}
.tls-pc-step-btn:hover:not(.disabled){background:#f6f8f9;transform:translateY(-2px)}
.tls-pc-step-btn.prev{justify-self:start}
.tls-pc-step-btn.next{justify-self:end;background:var(--tls-orange);border-color:var(--tls-orange);color:#fff}
.tls-pc-step-btn.next:hover:not(.disabled){background:#d66820}
.tls-pc-step-btn.disabled{opacity:.5;cursor:not-allowed}
.tls-pc-step-btn svg{width:18px;height:18px}

/* Responsive */
@media (max-width:900px){
  .tls-pc-quick{grid-template-columns:1fr 1fr}
  .tls-pc-skills{grid-template-columns:repeat(2,1fr)}
  .tls-pc-extras-grid{grid-template-columns:repeat(2,1fr)}
}

@media (max-width:720px){
  .tls-pc-lesson{grid-template-columns:1fr;align-items:flex-start}
  .tls-pc-action{justify-self:start;width:100%}
  .tls-pc-btn-action{width:100%}
}

@media (max-width:560px){
  .tls-pc-quick{grid-template-columns:1fr}
  .tls-pc-skills{grid-template-columns:1fr}
  .tls-pc-extras-grid{grid-template-columns:1fr}
  .tls-pc-step-nav{grid-template-columns:1fr}
  .tls-pc-step-btn.prev,.tls-pc-step-btn.next{justify-self:stretch}
  .tls-pc-single-carousel-btn{width:40px;height:40px}
}

