.planning-wrap{max-width:1100px;margin:0 auto;padding:36px 24px 80px}.session-bar{display:flex;justify-content:center;margin-bottom:52px}.session-bar select{border:1.5px solid #dde3ec;border-radius:6px;padding:8px 20px;font-size:0.9rem;color:#1a1a2e;background:#fff;cursor:pointer;min-width:240px}.stepper{position:relative;display:flex;align-items:flex-start;justify-content:space-between;gap:0}.stepper::before{content:'';position:absolute;top:28px;left:10%;right:10%;height:3px;background:linear-gradient(to right,var(--bleu),var(--bleu-clair),var(--bleu));z-index:0;border-radius:2px}.step{display:flex;flex-direction:column;align-items:center;flex:1;position:relative;z-index:1}.step-circle{width:56px;height:56px;border-radius:50%;background:#fff;border:3px solid var(--bleu);display:flex;align-items:center;justify-content:center;font-size:1.3rem;color:var(--bleu);box-shadow:0 4px 16px rgba(27,58,92,0.18);transition:transform 0.25s ease,background 0.25s ease,color 0.25s ease;flex-shrink:0}.step:hover .step-circle{transform:scale(1.12);background:var(--bleu);color:#fff}.step-connector{width:2px;height:32px;background:#c5cfe0;margin:0 auto;flex-shrink:0}.step-card{background:#fff;border:1.5px solid #dde3ec;border-top:3px solid var(--bleu);border-radius:8px;padding:16px 14px;text-align:center;width:100%;max-width:170px;box-shadow:0 2px 12px rgba(0,0,0,0.06);transition:box-shadow 0.25s ease,transform 0.25s ease}.step:hover .step-card{box-shadow:0 8px 28px rgba(27,58,92,0.14);transform:translateY(-3px)}.step-label{font-size:0.65rem;font-weight:800;letter-spacing:1.2px;text-transform:uppercase;color:var(--bleu);margin-bottom:8px}.step-date{font-size:1rem;font-weight:700;color:#1a1a2e;line-height:1.25;margin-bottom:2px}.step-year{font-size:0.75rem;color:#888;margin:0}.step-status{display:inline-block;font-size:0.6rem;font-weight:700;padding:2px 8px;border-radius:12px;letter-spacing:0.5px;text-transform:uppercase;margin-top:8px}.status-done{background:#dde8f5;color:var(--bleu)}.status-current{background:#fff3cd;color:#856404}.status-upcoming{background:#e8f0fe;color:#1a4fc4}@media (max-width:700px){.stepper{flex-direction:column;align-items:center;gap:0}.stepper::before{top:0;bottom:0;left:27px;right:auto;width:3px;height:auto}.step{flex-direction:row;align-items:flex-start;width:100%;gap:0;padding-bottom:32px}.step-circle{width:46px;height:46px;font-size:1.1rem;flex-shrink:0}.step-connector{display:none}.step-card{max-width:100%;text-align:left;margin-left:20px;border-top:1.5px solid #dde3ec;border-left:3px solid var(--bleu)}}.planning-empty{text-align:center;padding:80px 20px;color:#aaa}