/* ── Styles spécifiques à evaluation.html uniquement ── */

/* Padding-top pour compenser le header fixed */
.eval-page-wrap { padding-top: 80px; }

/* Hero vert foncé — reprend .security-section */
.eval-hero {
    background: var(--forest-green);
    padding: 5rem 3rem 4rem;
    text-align: center;
    position: relative;
    overflow: hidden;
}
.eval-hero::before {
    content: '';
    position: absolute; inset: 0;
    background: radial-gradient(ellipse at 70% 40%, rgba(244,208,63,0.08) 0%, transparent 55%);
    pointer-events: none;
}
.eval-hero h1 {
    font-size: clamp(2rem, 4vw, 3.5rem);
    font-weight: 800; color: #fff;
    line-height: 1.2; margin-bottom: 1.25rem;
}
.eval-hero h1 .highlight { color: var(--primary); }
.eval-hero p {
    font-size: 1.125rem; color: rgba(255,255,255,0.82);
    max-width: 600px; margin: 0 auto 2rem; line-height: 1.7;
}
.eval-hero-meta {
    display: flex; justify-content: center;
    gap: 2rem; flex-wrap: wrap; margin-top: 2rem;
    font-size: 0.875rem; color: rgba(255,255,255,0.65);
}
.eval-hero-meta span { display: flex; align-items: center; gap: 0.4rem; }
.eval-hero-meta strong { color: #fff; }

/* Sections alternées */
.eval-section-white { background: white; padding: 5rem 3rem; }
.eval-section-grey  { background: #f9fafb; padding: 5rem 3rem; }

/* Centrage contenu */
.eval-container { max-width: 1100px; margin: 0 auto; }
.eval-container-sm { max-width: 720px; margin: 0 auto; }

/* En-têtes de section */
.eval-section-header { margin-bottom: 3rem; }
.eval-section-header h2 {
    font-size: clamp(1.75rem, 3vw, 2.5rem);
    font-weight: 800; color: var(--forest-green);
    margin-bottom: 0.75rem; line-height: 1.2;
}
.eval-section-header p {
    font-size: 1.125rem; color: var(--text-secondary); line-height: 1.7;
    max-width: 600px;
}
.eval-section-header.centered { text-align: center; }
.eval-section-header.centered p { margin: 0 auto; }

/* Grille modules — 5 colonnes sur desktop */
.eval-modules-grid {
    display: grid;
    grid-template-columns: repeat(5, 1fr);
    gap: 1rem;
    margin-top: 2.5rem;
}
@media (max-width: 1024px) { .eval-modules-grid { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 640px)  { .eval-modules-grid { grid-template-columns: repeat(2, 1fr); } }

/* Carte module — reprend floating-card */
.eval-module-card {
    background: rgba(255,255,255,0.95);
    border-radius: 1.25rem;
    border: 1px solid var(--border);
    padding: 1.25rem;
    box-shadow: 0 2px 8px rgba(0,0,0,0.05);
    transition: all 0.3s;
    text-align: center;
}
.eval-module-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 10px 30px rgba(0,0,0,0.1);
    border-color: var(--primary);
}
.eval-module-card .icon { font-size: 1.75rem; margin-bottom: 0.5rem; }
.eval-module-card h4 { font-size: 0.8rem; font-weight: 700; color: var(--forest-green); margin-bottom: 0.25rem; }
.eval-module-card p  { font-size: 0.7rem; color: var(--text-secondary); line-height: 1.4; }

/* Rapport preview — grille 2 colonnes */
.eval-report-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 4rem; align-items: center;
    margin-top: 2.5rem;
}
@media (max-width: 768px) { .eval-report-grid { grid-template-columns: 1fr; gap: 2rem; } }

.eval-checklist { list-style: none; padding: 0; }
.eval-checklist li {
    display: flex; align-items: flex-start; gap: 0.75rem;
    padding: 0.875rem 0;
    border-bottom: 1px solid var(--border);
    font-size: 0.9375rem; color: var(--text-secondary);
}
.eval-checklist li:last-child { border-bottom: none; }
.eval-checklist .check {
    width: 1.375rem; height: 1.375rem; border-radius: 50%;
    background: rgba(27,94,32,0.1); color: var(--forest-green);
    display: flex; align-items: center; justify-content: center;
    font-size: 0.75rem; font-weight: 700; flex-shrink: 0; margin-top: 1px;
}

/* Mockup rapport */
.eval-mockup {
    background: white;
    border-radius: 1.5rem;
    border: 1px solid var(--border);
    padding: 1.75rem;
    box-shadow: 0 10px 30px rgba(0,0,0,0.08);
}
.eval-mockup-header {
    display: flex; justify-content: space-between; align-items: flex-start;
    padding-bottom: 1rem; margin-bottom: 1rem;
    border-bottom: 1px solid var(--border);
}
.eval-mockup-title { font-size: 0.8rem; font-weight: 700; color: var(--forest-green); }
.eval-mockup-score { font-size: 1.5rem; font-weight: 800; color: #e67e22; }
.eval-bar-row { display: flex; flex-direction: column; gap: 0.6rem; }
.eval-bar-item { display: flex; flex-direction: column; gap: 0.2rem; }
.eval-bar-label {
    display: flex; justify-content: space-between;
    font-size: 0.7rem; color: var(--text-secondary);
}
.eval-bar-outer {
    height: 5px; background: #f3f4f6;
    border-radius: 10px; overflow: hidden;
}
.eval-bar-fill { height: 100%; border-radius: 10px; }
.eval-mockup-tag {
    margin-top: 1rem; padding: 0.625rem 0.875rem;
    background: #fff8e1; border-radius: 0.5rem;
    border-left: 3px solid var(--primary-dark);
    font-size: 0.7rem; color: #795548; line-height: 1.5;
}

/* Proof cards — reprend step-card style */
.eval-proof-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 2rem; margin-top: 2.5rem;
}
@media (max-width: 768px) { .eval-proof-grid { grid-template-columns: 1fr; } }
.eval-proof-card {
    background: linear-gradient(135deg, #FFFAEB 0%, #FFF7E0 100%);
    border-radius: 1.5rem; padding: 2rem;
    border: 2px solid var(--border);
    transition: all 0.3s;
}
.eval-proof-card:hover { border-color: var(--primary); transform: translateY(-4px); }
.eval-proof-num {
    font-size: 2.75rem; font-weight: 800;
    color: var(--forest-green); line-height: 1; margin-bottom: 0.5rem;
}
.eval-proof-label { font-size: 1rem; font-weight: 700; color: var(--forest-green); margin-bottom: 0.5rem; }
.eval-proof-desc { font-size: 0.875rem; color: var(--text-secondary); line-height: 1.5; }

/* ── QUIZ CARD ── */
.eval-quiz-wrap {
    background: white;
    border-radius: 2rem; padding: 3rem;
    border: 1px solid var(--border);
    box-shadow: 0 4px 24px rgba(0,0,0,0.07);
    max-width: 680px; margin: 0 auto;
}

/* Progress bar */
.eval-progress-track {
    height: 5px; background: #f3f4f6;
    border-radius: 10px; overflow: hidden; margin-bottom: 0.5rem;
}
.eval-progress-fill {
    height: 100%;
    background: linear-gradient(90deg, var(--forest-green), var(--primary));
    border-radius: 10px; transition: width 0.4s ease;
}
.eval-progress-label {
    font-size: 0.75rem; color: var(--text-secondary);
    text-align: right; margin-bottom: 1.75rem;
}

/* Category */
.eval-cat {
    display: flex; align-items: center; gap: 0.5rem; margin-bottom: 0.875rem;
}
.eval-cat-label {
    font-size: 0.7rem; font-weight: 700; color: var(--forest-green);
    text-transform: uppercase; letter-spacing: 0.08em;
}

/* Question */
.eval-question {
    font-size: 1.1875rem; font-weight: 700;
    color: var(--text-primary); line-height: 1.5; margin-bottom: 1.5rem;
}

/* Options */
.eval-options { display: flex; flex-direction: column; gap: 0.625rem; margin-bottom: 1.75rem; }
.eval-opt {
    display: flex; align-items: center; gap: 0.875rem;
    padding: 0.875rem 1.125rem;
    border: 1.5px solid var(--border);
    border-radius: 0.875rem; background: white;
    cursor: pointer; font-size: 0.9375rem;
    color: var(--text-primary); text-align: left;
    font-family: 'Inter', sans-serif; width: 100%;
    transition: border-color 0.15s, background 0.15s;
}
.eval-opt:hover  { border-color: var(--forest-green); background: rgba(27,94,32,0.04); }
.eval-opt.active { border-color: var(--forest-green); background: rgba(27,94,32,0.06); box-shadow: 0 0 0 3px rgba(27,94,32,0.08); }
.eval-radio {
    width: 1.125rem; height: 1.125rem; border-radius: 50%; flex-shrink: 0;
    border: 2px solid #d1d5db;
}
.eval-opt.active .eval-radio { border: 5px solid var(--forest-green); }

/* Bouton principal quiz — hérite de .btn-primary mais sans border-radius:50px */
.eval-btn {
    width: 100%; padding: 0.9375rem; background: var(--primary);
    color: var(--forest-green); border: none; border-radius: 0.75rem;
    font-size: 0.9375rem; font-weight: 700;
    font-family: 'Inter', sans-serif; cursor: pointer;
    display: flex; align-items: center; justify-content: center; gap: 0.5rem;
    transition: all 0.3s; box-shadow: 0 4px 16px rgba(244,208,63,0.35);
}
.eval-btn:hover:not(:disabled) { transform: translateY(-2px); box-shadow: 0 8px 24px rgba(244,208,63,0.45); }
.eval-btn:disabled { opacity: 0.4; cursor: not-allowed; }

/* Formulaire capture */
.eval-form-grid {
    display: grid; grid-template-columns: 1fr 1fr; gap: 0.875rem; margin-bottom: 1.25rem;
}
@media (max-width: 640px) { .eval-form-grid { grid-template-columns: 1fr; } }
.eval-form-group { display: flex; flex-direction: column; gap: 0.375rem; }
.eval-form-group label { font-size: 0.8125rem; font-weight: 600; color: var(--text-primary); }
.eval-form-group input {
    padding: 0.6875rem 0.875rem;
    border: 1.5px solid var(--border); border-radius: 0.5rem;
    font-size: 0.875rem; font-family: 'Inter', sans-serif;
    color: var(--text-primary); background: white; outline: none; width: 100%;
    box-sizing: border-box;
}
.eval-form-group input:focus { border-color: var(--forest-green); box-shadow: 0 0 0 3px rgba(27,94,32,0.08); }
.eval-form-note { font-size: 0.75rem; color: var(--text-secondary); text-align: center; margin-top: 0.75rem; }

/* Check icon */
.eval-check-icon {
    width: 3.5rem; height: 3.5rem; border-radius: 50%;
    background: rgba(27,94,32,0.1); color: var(--forest-green);
    display: flex; align-items: center; justify-content: center;
    font-size: 1.5rem; font-weight: 700; margin: 0 auto 1.125rem;
}

/* Pills intro */
.eval-pills { display: flex; flex-wrap: wrap; gap: 0.5rem; margin-bottom: 2rem; justify-content: center; }
.eval-pill {
    background: rgba(27,94,32,0.08); color: var(--forest-green);
    border: 1px solid rgba(27,94,32,0.2);
    padding: 0.3125rem 0.875rem; border-radius: 50px; font-size: 0.8125rem;
}

/* Résultats */
.eval-score-wrap { text-align: center; margin-bottom: 1.5rem; }
.eval-level-badge {
    display: inline-block; padding: 0.5625rem 1.5rem;
    border-radius: 50px; font-size: 0.875rem; font-weight: 700;
    margin-bottom: 1rem;
}
.eval-result-summary {
    font-size: 0.9375rem; color: var(--text-secondary);
    line-height: 1.7; text-align: center; margin-bottom: 1.75rem;
}
.eval-wins-box { border-radius: 0.875rem; padding: 1.375rem 1.625rem; margin-bottom: 1.75rem; }
.eval-wins-title { font-size: 0.8rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.05em; margin-bottom: 0.875rem; }
.eval-win-row { display: flex; align-items: flex-start; gap: 0.75rem; margin-bottom: 0.625rem; }
.eval-win-num {
    width: 1.375rem; height: 1.375rem; border-radius: 50%;
    background: rgba(255,255,255,0.6);
    display: flex; align-items: center; justify-content: center;
    font-size: 0.75rem; font-weight: 800; flex-shrink: 0;
}
.eval-win-text { font-size: 0.875rem; color: #374151; line-height: 1.5; }

.eval-breakdown-title { font-size: 0.7rem; font-weight: 700; color: var(--text-secondary); text-transform: uppercase; letter-spacing: 0.08em; margin-bottom: 0.875rem; }
.eval-breakdown { margin-bottom: 1.75rem; }
.eval-break-row { display: flex; align-items: center; gap: 0.625rem; margin-bottom: 0.5625rem; }
.eval-break-icon { font-size: 0.9rem; width: 1.25rem; flex-shrink: 0; }
.eval-break-cat { font-size: 0.75rem; color: var(--text-secondary); width: 9rem; flex-shrink: 0; }
.eval-break-bar-outer { flex: 1; height: 5px; background: #f3f4f6; border-radius: 10px; overflow: hidden; }
.eval-break-bar-fill { height: 100%; border-radius: 10px; }
.eval-break-score { font-size: 0.75rem; font-weight: 700; width: 1.75rem; text-align: right; flex-shrink: 0; }

/* CTA résultats — reprend .security-section style */
.eval-result-cta {
    background: var(--forest-green); border-radius: 1rem;
    padding: 1.75rem; text-align: center;
}
.eval-result-cta p { color: rgba(255,255,255,0.88); font-size: 0.9375rem; line-height: 1.6; margin-bottom: 1.125rem; }
.eval-result-cta .eval-btn { width: auto; display: inline-flex; padding: 0.8125rem 2rem; }

/* Steps */
.eval-step { display: none; }
.eval-step.active { display: block; }

/* FAQ */
.eval-faq-item {
    background: white; border: 1px solid var(--border);
    border-radius: 0.875rem; padding: 1.25rem 1.5rem; margin-top: 0.75rem;
}
.eval-faq-q { font-size: 0.9375rem; font-weight: 700; color: var(--text-primary); margin-bottom: 0.5rem; }
.eval-faq-a { font-size: 0.875rem; color: var(--text-secondary); line-height: 1.6; }

/* Utility classes to replace inline styles */
.primary-link {
    color: var(--primary);
    font-weight: 600;
}

.section-badge-spaced {
    margin-bottom: 1.5rem;
}

.section-badge-sm {
    margin-bottom: 1.25rem;
}

.btn-primary-eval {
    font-size: 1rem;
    padding: 0.9375rem 2.25rem;
    border-radius: 0.75rem;
}

.mockup-subtitle {
    font-weight: 400;
    color: var(--text-secondary);
    font-size: 0.7rem;
}

.bar-score-red {
    color: #e74c3c;
}

.bar-score-orange {
    color: #e67e22;
}

.bar-score-green {
    color: #27ae60;
}

.bar-fill-red-25 {
    width: 25%;
    background: #e74c3c;
}

.bar-fill-red-3 {
    width: 3%;
    background: #e74c3c;
}

.bar-fill-orange-50 {
    width: 50%;
    background: #e67e22;
}

.bar-fill-green-75 {
    width: 75%;
    background: #27ae60;
}

.bar-fill-initial {
    width: 0%;
}

.section-header-spaced {
    margin-bottom: 2.5rem;
}

.text-center {
    text-align: center;
}

.eval-intro-title {
    font-size: 1.375rem;
    font-weight: 800;
    color: var(--forest-green);
    margin-bottom: 0.75rem;
}

.eval-intro-subtitle {
    font-size: 0.9375rem;
    color: var(--text-secondary);
    line-height: 1.7;
    margin-bottom: 1.5rem;
}

.eval-complete-title {
    font-size: 1.375rem;
    font-weight: 800;
    color: var(--forest-green);
    margin-bottom: 0.625rem;
}

.eval-complete-subtitle {
    font-size: 0.9375rem;
    color: var(--text-secondary);
    line-height: 1.6;
}

.q-icon-size {
    font-size: 1.125rem;
}

.centered-content {
    text-align: center;
    margin-bottom: 1.5rem;
}

.form-grid-full {
    grid-column: 1 / -1;
}

.privacy-link {
    color: var(--primary-dark);
}

.result-svg {
    display: block;
    margin: 0 auto 1rem;
}

.result-arc-transition {
    transition: stroke-dasharray 1s ease;
}

.btn-no-underline {
    text-decoration: none;
}

.result-note-text {
    color: rgba(255, 255, 255, 0.55);
    font-size: 0.75rem;
    margin-top: 0.75rem;
}

.section-header-faq {
    margin-bottom: 2rem;
}

/* Dynamic result styling using CSS custom properties */
.badge-styled {
    background: var(--result-bg) !important;
    border: 1px solid var(--result-border) !important;
    color: var(--result-color) !important;
}

.wins-styled {
    background: var(--result-bg) !important;
    border: 1px solid var(--result-border) !important;
}

.title-styled {
    color: var(--result-color) !important;
}

.win-num-styled {
    color: var(--result-color) !important;
}

/* Score colors for breakdown */
.score-high {
    color: #27ae60;
}

.score-high.eval-break-bar-fill {
    background: #27ae60;
}

.score-medium {
    color: #2980b9;
}

.score-medium.eval-break-bar-fill {
    background: #2980b9;
}

.score-low {
    color: #e67e22;
}

.score-low.eval-break-bar-fill {
    background: #e67e22;
}

.score-none {
    color: #e74c3c;
}

.score-none.eval-break-bar-fill {
    background: #e74c3c;
}
