/* ============================================================
   CDF SOLDIER – Page soldat, header, patch
============================================================ */

.soldier-info-page {
    width: min(1200px,95vw);
    background: var(--cdf-surface); border-radius: var(--cdf-radius);
    box-shadow: 0 0 25px var(--cdf-shadow);
    margin-left: auto !important; margin-right: auto !important;
}
.soldier-info-page.animate-appear { animation: tacticalAppear .9s ease-out; }
@keyframes tacticalAppear {
    0% { opacity: 0; transform: scale(.97) translateY(18px) }
    100% { opacity: 1; transform: scale(1) translateY(0) }
}
.soldier-info-page > header h1 { font-size: 46px; text-align: center; color: #fff; text-shadow: 2px 2px 8px #000; margin: 0 0 22px; }
.soldier-main-info { display: flex; align-items: center; gap: 24px; margin: 10px auto 40px; justify-content: center; }
.soldier-rank-insignia { width: 100px; height: 100px; filter: drop-shadow(0 0 6px #000); transition: .25s; }
.soldier-rank-insignia:hover { transform: scale(1.12) rotate(2deg); filter: drop-shadow(0 0 10px #b9ff7f) }
.soldier-avatar { width: 120px; height: 120px; border-radius: 8px; border: 2px solid #333; object-fit: cover; }
.soldier-text-info { text-align: left; }
.soldier-name, .soldier-rank { font-size: 24px; font-weight: 700; color: white; }
.soldier-date { color: #000; font-size: 14px; }
.soldier-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 35px; }
.soldier-grid-duo { display: grid; grid-template-columns: repeat(2, 1fr); gap: 35px; margin-top: 40px; align-items: start; }
@media (max-width: 992px) { .soldier-grid-duo { grid-template-columns: 1fr; gap: 25px; } }
.soldier-section { text-align: center; padding: 14px 10px; border-radius: 8px; transition: .25s; }
.soldier-section.hover-tactical:hover { background: rgba(100,150,70,.15); box-shadow: 0 0 12px #8fff60a8; }
.soldier-section h3 { font-size: 24px; text-transform: uppercase; font-family: 'BlackOpsOne'; color: var(--cdf-accent-2); letter-spacing: 1px; text-shadow: 0 0 6px #000; margin-bottom: 12px; position: relative; }
.soldier-section h3::after { content: ""; display: block; width: 60%; height: 3px; margin: 6px auto 0; background: linear-gradient(to right, transparent, var(--cdf-accent), transparent); }
.soldier-section ul { list-style: none; margin: 0; padding: 0; font-family: 'BlackOpsOne'; }
.soldier-section li { display: flex; align-items: center; justify-content: center; gap: 8px; margin: 8px 0; color: var(--cdf-text-dim); }
.medal-icon, .role-image { width: 30px; height: 30px; transition: .25s; }
.medal-icon:hover, .role-image:hover { transform: scale(1.2) rotate(3deg); filter: drop-shadow(0 0 8px #b9ff7f); }
.btn-pdf { font-family: 'BlackOpsOne'; background: #7fa64b; border: 2px solid #394622; color: #000; padding: 10px 24px; border-radius: 8px; cursor: pointer; box-shadow: 0 4px 8px var(--cdf-shadow); }
.btn-pdf:hover { background: #c7ff7c; }

/* Soldier Header Patch */
.soldier-header {
    width: 100%; height: 95px; margin: 0 auto 30px; position: relative;
    border-radius: 12px; border: 3px solid #2e2e2e;
    box-shadow: inset 0 0 18px rgba(0,0,0,.65), 0 6px 15px rgba(0,0,0,.6);
    display: flex; justify-content: center; align-items: center;
    background-blend-mode: overlay; background-color: rgba(0,0,0,.2);
    background: linear-gradient(180deg, rgba(10, 15, 10, .72), rgba(10, 15, 10, .92)), url(/css/camo.jpg) center / cover no-repeat;
    outline: 3px dashed rgba(255,255,255,.08); outline-offset: -10px;
}
.soldier-title { font-family: 'BlackOpsOne'; font-size: 42px; color: #fff; text-shadow: 4px 4px 8px #000, -2px -2px 6px rgba(255,255,255,.12); letter-spacing: 1px; }
.soldier-header::before, .soldier-header::after {
    content: ""; position: absolute; top: 50%; width: 16px; height: 16px;
    background: linear-gradient(145deg,#292929,#656565); border-radius: 50%;
    border: 2px solid #000; box-shadow: inset 1px 1px 4px rgba(0,0,0,.7), 0 0 4px rgba(255,255,255,.3);
    transform: translateY(-50%);
}
.soldier-header::before { left: 10px; }
.soldier-header::after { right: 10px; }
.soldier-header:hover { transform: translateY(-2px); box-shadow: inset 0 0 25px rgba(0,0,0,.6), 0 10px 18px rgba(0,0,0,.65); transition: .25s ease-out; }

/* Responsive */
@media(max-width: 1200px) { .soldier-text-info, .soldier-main-info, .soldier-grid { text-align: center !important; justify-content: center !important; } }
@media(max-width:992px) { .soldier-grid { grid-template-columns: repeat(2,1fr); } .soldier-header { height: 70px; } .soldier-title { font-size: 30px !important; line-height: 70px !important; } }
@media(max-width:992px), (orientation: portrait) {
    .soldier-info-page { width: 95vw !important; padding: 20px 16px !important; }
    .soldier-avatar, .soldier-rank-insignia { width: 85px !important; height: 85px !important; }
    .soldier-main-info { flex-direction: column !important; gap: 12px !important; text-align: center !important; }
    .soldier-grid { grid-template-columns: 1fr !important; gap: 25px !important; width: 100% !important; }
    .soldier-section { padding: 12px 10px !important; font-size: 14px; }
    .soldier-section h3 { font-size: 20px !important; }
}
@media(max-width:700px) { .soldier-grid { grid-template-columns: 1fr; } .soldier-main-info { flex-direction: column; } .soldier-text-info { text-align: center; } }
@media(max-width: 450px) {
    .soldier-title { font-size: 26px !important; }
    .soldier-avatar, .soldier-rank-insignia { width: 70px !important; height: 70px !important; }
    p, li { font-size: 12px !important; }
    .capacity-bar span { font-size: 9px !important; }
}