/* ============================================================
   EXOCETH — Accueil Sécurité · Styles principaux
   ============================================================ */
:root {
  --green-dark:   #2E5339;
  --green-mid:    #4A7C59;
  --green-light:  #7AB648;
  --green-pale:   #EAF2EC;
  --bg:           #F4F4F2;
  --white:        #FFFFFF;
  --grey-dark:    #3A3A3A;
  --grey-mid:     #6B7280;
  --grey-light:   #E5E7EB;
  --grey-subtle:  #F9F9F7;
  --danger:       #C0392B;
  --danger-pale:  #FDECEA;
  --warn:         #D97706;
  --warn-pale:    #FEF3C7;
  --success:      #2E7D32;
  --success-pale: #E8F5E9;
  --shadow-sm:    0 2px 8px rgba(46,83,57,0.10);
  --shadow-md:    0 6px 24px rgba(46,83,57,0.13);
  --radius:       10px;
  --radius-lg:    16px;
}
*{margin:0;padding:0;box-sizing:border-box;}
body{font-family:'Open Sans',sans-serif;background:var(--bg);color:var(--grey-dark);min-height:100vh;font-size:15px;line-height:1.6;}
a{text-decoration:none;color:inherit;}

/* ── Header ── */
header{background:var(--green-dark);padding:0 32px;display:flex;align-items:center;justify-content:space-between;height:64px;position:sticky;top:0;z-index:100;box-shadow:0 2px 12px rgba(0,0,0,0.25);}
.logo-area{display:flex;align-items:center;gap:14px;}
.logo-svg{height:36px;}
.header-divider{width:1px;height:30px;background:rgba(255,255,255,0.2);}
.header-title{font-family:'Raleway',sans-serif;font-weight:600;font-size:0.9rem;color:rgba(255,255,255,0.8);}
.header-right{display:flex;align-items:center;gap:12px;}
.header-tag{background:var(--green-light);color:#fff;font-family:'Raleway',sans-serif;font-weight:700;font-size:0.68rem;letter-spacing:0.12em;text-transform:uppercase;padding:4px 12px;border-radius:20px;}
.nav-user{font-size:0.8rem;color:rgba(255,255,255,0.6);}

/* ── Views ── */
.view{display:none;animation:fadeUp 0.4s ease;}
.view.active{display:block;}
@keyframes fadeUp{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}

/* ── Buttons ── */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:11px 24px;border-radius:var(--radius);font-family:'Raleway',sans-serif;font-weight:700;font-size:0.9rem;letter-spacing:0.02em;cursor:pointer;border:none;transition:all 0.2s;text-decoration:none;}
.btn-primary{background:var(--green-dark);color:#fff;}
.btn-primary:hover{background:var(--green-mid);box-shadow:var(--shadow-md);transform:translateY(-1px);}
.btn-outline{background:transparent;color:var(--green-dark);border:2px solid var(--green-dark);}
.btn-outline:hover{background:var(--green-pale);}
.btn-ghost{background:rgba(255,255,255,0.12);color:#fff;border:1px solid rgba(255,255,255,0.25);font-size:0.82rem;}
.btn-ghost:hover{background:rgba(255,255,255,0.2);}
.btn-light{background:var(--white);color:var(--green-dark);border:1px solid var(--grey-light);}
.btn-success{background:var(--success);color:#fff;}
.btn-full{width:100%;}
.btn-link{background:none;border:none;color:var(--green-dark);font-size:0.82rem;font-weight:600;cursor:pointer;text-decoration:underline;font-family:'Open Sans',sans-serif;padding:0;}

/* ── Form ── */
.field{margin-bottom:16px;}
.field label{display:block;font-size:0.76rem;font-weight:600;color:var(--grey-mid);text-transform:uppercase;letter-spacing:0.07em;margin-bottom:6px;}
.field input,.field select,.field textarea{width:100%;background:var(--grey-subtle);border:1.5px solid var(--grey-light);border-radius:var(--radius);padding:11px 14px;font-family:'Open Sans',sans-serif;font-size:0.93rem;color:var(--grey-dark);outline:none;transition:border-color 0.2s,box-shadow 0.2s;}
.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--green-mid);box-shadow:0 0 0 3px rgba(74,124,89,0.12);background:#fff;}
.field textarea{resize:vertical;height:100px;}

/* ── Cards ── */
.card{background:var(--white);border-radius:var(--radius-lg);border:1px solid var(--grey-light);box-shadow:var(--shadow-sm);}

/* ── Badges ── */
.badge{display:inline-flex;align-items:center;gap:5px;padding:4px 10px;border-radius:20px;font-size:0.72rem;font-weight:700;white-space:nowrap;letter-spacing:0.03em;}
.badge-pass{background:var(--success-pale);color:var(--success);}
.badge-fail{background:var(--danger-pale);color:var(--danger);}
.badge-pending{background:var(--warn-pale);color:var(--warn);}

/* ── Alerts ── */
.alert{padding:12px 16px;border-radius:8px;font-size:0.88rem;margin-bottom:16px;}
.alert-error{background:var(--danger-pale);color:var(--danger);border:1px solid rgba(192,57,43,0.2);}
.alert-success{background:var(--success-pale);color:var(--success);border:1px solid rgba(46,125,50,0.2);}

/* ── Landing ── */
.landing-wrap{min-height:calc(100vh - 64px);display:grid;grid-template-columns:1fr 1fr;}
.landing-left{background:var(--green-dark);padding:64px 56px;display:flex;flex-direction:column;justify-content:center;position:relative;overflow:hidden;}
.landing-left::before{content:'';position:absolute;bottom:-80px;right:-80px;width:320px;height:320px;border-radius:50%;background:rgba(122,182,72,0.12);}
.landing-kicker{display:inline-flex;align-items:center;gap:8px;background:rgba(122,182,72,0.2);border:1px solid rgba(122,182,72,0.4);border-radius:20px;padding:5px 14px;font-size:0.76rem;font-weight:600;letter-spacing:0.1em;text-transform:uppercase;color:var(--green-light);margin-bottom:28px;width:fit-content;}
.landing-h1{font-family:'Raleway',sans-serif;font-size:clamp(1.8rem,3vw,2.6rem);font-weight:800;color:#fff;line-height:1.15;margin-bottom:18px;letter-spacing:-0.02em;}
.landing-h1 em{font-style:normal;color:var(--green-light);}
.landing-desc{color:rgba(255,255,255,0.72);font-size:0.97rem;line-height:1.7;margin-bottom:40px;}
.info-pills{display:flex;flex-direction:column;gap:12px;}
.info-pill{display:flex;align-items:center;gap:12px;background:rgba(255,255,255,0.07);border:1px solid rgba(255,255,255,0.12);border-radius:10px;padding:12px 16px;font-size:0.88rem;color:rgba(255,255,255,0.85);}
.pill-icon{width:34px;height:34px;background:rgba(122,182,72,0.25);border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:1.1rem;flex-shrink:0;}
.pill-text strong{display:block;color:#fff;font-size:0.9rem;margin-bottom:1px;}
.pill-text span{color:rgba(255,255,255,0.55);font-size:0.78rem;}
.landing-right{display:flex;align-items:center;justify-content:center;padding:56px 48px;}
.form-panel{width:100%;max-width:440px;}
.form-panel-title{font-family:'Raleway',sans-serif;font-size:1.2rem;font-weight:800;color:var(--green-dark);margin-bottom:4px;}
.form-panel-sub{color:var(--grey-mid);font-size:0.87rem;margin-bottom:20px;}
.required-note{font-size:0.76rem;color:var(--grey-mid);margin-top:14px;text-align:center;line-height:1.5;}

/* ── Slides ── */
.slides-header{background:var(--white);border-bottom:1px solid var(--grey-light);padding:16px 32px;display:flex;align-items:center;gap:20px;flex-wrap:wrap;}
.slides-meta{font-size:0.84rem;color:var(--grey-mid);font-weight:500;white-space:nowrap;}
.progress-track{flex:1;max-width:400px;background:var(--grey-light);border-radius:4px;height:5px;overflow:hidden;}
.progress-fill{height:100%;background:linear-gradient(90deg,var(--green-dark),var(--green-light));border-radius:4px;transition:width 0.4s ease;}
.timer-chip{background:var(--green-pale);color:var(--green-dark);font-weight:700;font-size:0.82rem;padding:5px 14px;border-radius:20px;border:1px solid rgba(46,83,57,0.2);font-family:'Raleway',sans-serif;min-width:70px;text-align:center;}
.slide-wrap{max-width:780px;margin:0 auto;padding:40px 24px;}
.slide-card{overflow:hidden;}
.slide-banner{background:var(--green-dark);padding:28px 36px;display:flex;align-items:center;gap:18px;position:relative;overflow:hidden;}
.slide-banner::after{content:'';position:absolute;right:-40px;top:-40px;width:180px;height:180px;border-radius:50%;background:rgba(122,182,72,0.1);}
.slide-num-badge{width:50px;height:50px;background:var(--green-light);border-radius:12px;display:flex;align-items:center;justify-content:center;font-family:'Raleway',sans-serif;font-weight:800;font-size:1.2rem;color:#fff;flex-shrink:0;}
.slide-banner-label{font-size:0.7rem;text-transform:uppercase;letter-spacing:0.1em;color:rgba(255,255,255,0.5);font-weight:600;margin-bottom:3px;}
.slide-banner-title{font-family:'Raleway',sans-serif;font-size:1.18rem;font-weight:700;color:#fff;}
.slide-body-inner{padding:32px 36px;}
.slide-icon-block{background:var(--green-pale);border-radius:var(--radius);height:120px;display:flex;align-items:center;justify-content:center;font-size:3rem;margin-bottom:24px;border:1px solid rgba(46,83,57,0.08);}
.slide-text{font-size:0.95rem;line-height:1.75;color:var(--grey-dark);margin-bottom:20px;}
.rule-list{list-style:none;display:flex;flex-direction:column;gap:2px;}
.rule-item{display:flex;align-items:flex-start;gap:12px;padding:11px 16px;border-radius:8px;font-size:0.9rem;line-height:1.5;}
.rule-item.ok{background:var(--success-pale);color:#1B5E20;}
.rule-item.warn{background:var(--warn-pale);color:#78350F;}
.rule-item.bad{background:var(--danger-pale);color:#7F1D1D;}
.rule-icon{font-size:0.95rem;margin-top:1px;flex-shrink:0;}
.slide-footer{display:flex;align-items:center;justify-content:space-between;margin-top:28px;flex-wrap:wrap;gap:12px;}

/* ── Quiz ── */
.quiz-wrap{max-width:720px;margin:0 auto;padding:40px 24px;}
.quiz-top{margin-bottom:24px;}
.quiz-top h2{font-family:'Raleway',sans-serif;font-size:1.5rem;font-weight:800;color:var(--green-dark);margin-bottom:4px;}
.quiz-top p{color:var(--grey-mid);font-size:0.88rem;}
.score-dots{display:flex;gap:5px;margin-bottom:24px;flex-wrap:wrap;}
.dot{height:6px;border-radius:3px;background:var(--grey-light);flex:1;min-width:20px;transition:background 0.3s;}
.dot.answered{background:rgba(46,83,57,0.3);}
.dot.correct{background:var(--success);}
.dot.wrong{background:var(--danger);}
.q-card{overflow:hidden;}
.q-banner{background:var(--green-dark);padding:24px 32px;display:flex;align-items:flex-start;gap:14px;}
.q-index{background:var(--green-light);color:#fff;border-radius:8px;padding:4px 12px;font-family:'Raleway',sans-serif;font-weight:700;font-size:0.82rem;white-space:nowrap;flex-shrink:0;margin-top:2px;}
.q-text{font-family:'Raleway',sans-serif;font-size:1.05rem;font-weight:600;color:#fff;line-height:1.45;}
.q-body{padding:28px 32px;}
.options-grid{display:flex;flex-direction:column;gap:10px;margin-bottom:20px;}
.opt{display:flex;align-items:center;gap:14px;padding:14px 18px;background:var(--grey-subtle);border:2px solid var(--grey-light);border-radius:var(--radius);cursor:pointer;transition:all 0.18s;font-size:0.93rem;}
.opt:hover{border-color:var(--green-mid);background:var(--green-pale);}
.opt.selected{border-color:var(--green-dark);background:var(--green-pale);}
.opt.correct{border-color:var(--success);background:var(--success-pale);}
.opt.wrong{border-color:var(--danger);background:var(--danger-pale);}
.opt-letter{width:30px;height:30px;border-radius:7px;background:var(--white);border:1.5px solid var(--grey-light);display:flex;align-items:center;justify-content:center;font-family:'Raleway',sans-serif;font-weight:700;font-size:0.85rem;flex-shrink:0;transition:all 0.18s;color:var(--grey-dark);}
.opt.selected .opt-letter{background:var(--green-dark);color:#fff;border-color:var(--green-dark);}
.opt.correct .opt-letter{background:var(--success);color:#fff;border-color:var(--success);}
.opt.wrong .opt-letter{background:var(--danger);color:#fff;border-color:var(--danger);}
.feedback{border-radius:var(--radius);padding:13px 18px;font-size:0.88rem;line-height:1.5;display:none;align-items:center;gap:10px;margin-bottom:18px;}
.feedback.show{display:flex;}
.feedback.ok{background:var(--success-pale);color:var(--success);border:1px solid rgba(46,125,50,0.2);}
.feedback.ko{background:var(--danger-pale);color:var(--danger);border:1px solid rgba(192,57,43,0.2);}
.q-footer{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:10px;}

/* ── Résultat ── */
.result-wrap{max-width:600px;margin:0 auto;padding:60px 24px;text-align:center;}
.result-badge{width:110px;height:110px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:3rem;margin:0 auto 28px;font-family:'Raleway',sans-serif;font-weight:800;animation:pop 0.55s cubic-bezier(0.175,0.885,0.32,1.275);}
@keyframes pop{from{transform:scale(0);opacity:0}to{transform:scale(1);opacity:1}}
.result-badge.pass{background:var(--success-pale);border:3px solid var(--success);color:var(--success);}
.result-badge.fail{background:var(--danger-pale);border:3px solid var(--danger);color:var(--danger);}
.result-score{font-family:'Raleway',sans-serif;font-size:5rem;font-weight:800;line-height:1;margin-bottom:6px;}
.result-score.pass{color:var(--success);}
.result-score.fail{color:var(--danger);}
.result-score-label{font-size:0.85rem;color:var(--grey-mid);margin-bottom:16px;}
.result-h{font-family:'Raleway',sans-serif;font-size:1.7rem;font-weight:800;color:var(--green-dark);margin-bottom:10px;}
.result-p{color:var(--grey-mid);font-size:0.93rem;margin-bottom:28px;line-height:1.6;}
.cert-panel{text-align:left;margin-bottom:20px;}
.cert-panel-title{font-size:0.75rem;text-transform:uppercase;letter-spacing:0.09em;color:var(--grey-mid);font-weight:600;padding:16px 24px 12px;border-bottom:1px solid var(--grey-light);display:flex;align-items:center;gap:8px;}
.cert-body{padding:0 24px 12px;}
.cert-row{display:flex;justify-content:space-between;align-items:center;padding:10px 0;border-bottom:1px solid var(--grey-light);font-size:0.88rem;}
.cert-row:last-child{border:none;}
.cert-row .lbl{color:var(--grey-mid);}
.cert-row .val{font-weight:600;color:var(--green-dark);}
.cert-id{font-size:0.75rem;color:var(--grey-mid);text-align:center;padding:10px 24px 16px;font-family:'Raleway',sans-serif;}

/* ── Misc ── */
.search-box{background:var(--grey-subtle);border:1.5px solid var(--grey-light);border-radius:8px;padding:8px 14px;font-family:'Open Sans',sans-serif;font-size:0.85rem;color:var(--grey-dark);outline:none;}
.search-box:focus{border-color:var(--green-mid);}
table{width:100%;border-collapse:collapse;font-size:0.85rem;}
thead th{background:var(--grey-subtle);padding:12px 18px;text-align:left;font-size:0.72rem;text-transform:uppercase;letter-spacing:0.07em;color:var(--grey-mid);font-weight:600;white-space:nowrap;border-bottom:1px solid var(--grey-light);}
tbody td{padding:13px 18px;border-bottom:1px solid var(--grey-light);vertical-align:middle;}
tbody tr:last-child td{border:none;}
tbody tr:hover td{background:var(--grey-subtle);}
.table-wrap{overflow-x:auto;border-radius:var(--radius-lg);border:1px solid var(--grey-light);box-shadow:var(--shadow-sm);}

/* Responsive */
@media(max-width:768px){
  header{padding:0 16px;}
  .landing-wrap{grid-template-columns:1fr;}
  .landing-left{padding:40px 24px;}
  .landing-right{padding:32px 20px;}
  .slide-body-inner{padding:20px;}
  .slide-banner{padding:18px 20px;}
  .q-body{padding:20px;}
  .q-banner{padding:18px 20px;}
}
