*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
    font-family:'Inter',system-ui,-apple-system,sans-serif;
    background:#0a0e1a;color:#e5e7eb;
    min-height:100vh;line-height:1.6;
    font-weight:400;overflow-x:hidden;
    -webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none;transition:color .2s}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
input,textarea,select{font-family:inherit}

:root{
    --bg:#0a0e1a;--bg-card:#131826;--bg-elevated:#1a2033;--bg-input:#0f1422;
    --border:rgba(255,255,255,.08);--border-strong:rgba(255,255,255,.14);
    --text:#e5e7eb;--text-mute:#9ca3af;--text-dim:#6b7280;
    --blue:#3b82f6;--blue-2:#60a5fa;--blue-dim:rgba(59,130,246,.15);
    --orange:#f97316;--orange-2:#fb923c;--orange-dim:rgba(249,115,22,.15);
    --green:#10b981;--green-2:#22c55e;--green-dim:rgba(16,185,129,.15);
    --purple:#a855f7;--purple-2:#c084fc;--purple-dim:rgba(168,85,247,.15);
    --red:#ef4444;--red-2:#f87171;--red-dim:rgba(239,68,68,.15);
    --gold:#fbbf24;--gold-2:#fcd34d;--gold-dim:rgba(251,191,36,.15);
    --shadow:0 10px 40px -10px rgba(0,0,0,.5);
    --shadow-lg:0 20px 60px -15px rgba(0,0,0,.6);
    --radius:14px;--radius-lg:18px;
}

.blue{color:var(--blue-2)}
.orange{color:var(--orange-2)}
.purple{color:var(--purple-2)}
.green{color:var(--green-2)}
.red{color:var(--red-2)}
.gold{color:var(--gold-2)}

.container{max-width:1280px;margin:0 auto;padding:0 32px;width:100%}
.container-md{max-width:880px;margin:0 auto;padding:0 32px;width:100%}
.container-sm{max-width:520px;margin:0 auto;padding:0 32px;width:100%}

.nav{
    position:sticky;top:0;z-index:100;
    background:rgba(10,14,26,.85);
    backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
    border-bottom:1px solid var(--border);
}
.nav-inner{
    max-width:1440px;margin:0 auto;padding:14px 32px;
    display:flex;align-items:center;gap:24px;
}
.nav-brand{
    display:flex;align-items:center;gap:12px;
    font-family:'Russo One',sans-serif;
    font-size:1.1rem;letter-spacing:1.5px;color:#fff;
}
.nav-brand-logo{
    width:44px;height:44px;
    background:linear-gradient(135deg,#1e40af,#3b82f6);
    border-radius:10px;
    display:flex;align-items:center;justify-content:center;
    box-shadow:0 4px 14px rgba(59,130,246,.4);
    padding:4px;flex-shrink:0;
}
.nav-brand-logo img{width:100%;height:100%;object-fit:contain}
.nav-brand-text{font-family:'Russo One',sans-serif;letter-spacing:2px}

.nav-links{
    display:flex;align-items:center;gap:4px;
    margin-left:auto;
}
.nav-link{
    display:flex;align-items:center;gap:8px;
    padding:10px 16px;border-radius:10px;
    font-size:.92rem;font-weight:500;
    color:var(--text-mute);transition:all .2s;
}
.nav-link svg{width:16px;height:16px}
.nav-link:hover{color:#fff;background:var(--bg-elevated)}
.nav-link.active{
    color:var(--blue-2);background:var(--blue-dim);
    box-shadow:inset 0 0 0 1px rgba(59,130,246,.3);
}

.nav-right{display:flex;align-items:center;gap:12px}
.nav-user{
    display:flex;align-items:center;gap:10px;
    padding:6px 14px 6px 6px;
    background:var(--bg-elevated);border:1px solid var(--border);
    border-radius:999px;
}
.nav-user-avatar{
    width:32px;height:32px;border-radius:50%;
    background:linear-gradient(135deg,var(--blue),var(--purple));
    display:flex;align-items:center;justify-content:center;
    font-weight:700;font-size:.85rem;color:#fff;
}
.nav-user-info{display:flex;flex-direction:column;line-height:1.1}
.nav-user-name{font-size:.85rem;font-weight:600;color:#fff}
.nav-user-role{font-size:.7rem;color:var(--text-mute);text-transform:uppercase;letter-spacing:.5px}

.nav-burger{
    display:none;width:42px;height:42px;
    flex-direction:column;justify-content:center;align-items:center;gap:5px;
    background:var(--bg-elevated);border:1px solid var(--border);border-radius:10px;
}
.nav-burger span{width:18px;height:2px;background:#fff;border-radius:2px;transition:all .25s}
.nav-burger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-burger.open span:nth-child(2){opacity:0}
.nav-burger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

.btn{
    display:inline-flex;align-items:center;justify-content:center;gap:8px;
    padding:11px 20px;border-radius:10px;
    font-weight:600;font-size:.92rem;font-family:inherit;
    transition:all .2s;cursor:pointer;white-space:nowrap;line-height:1;
}
.btn-sm{padding:8px 14px;font-size:.85rem;border-radius:8px}
.btn-lg{padding:15px 28px;font-size:1rem;border-radius:12px}
.btn-full{width:100%;justify-content:center}
.btn-primary{
    background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;
    box-shadow:0 6px 20px -6px rgba(59,130,246,.6);
}
.btn-primary:hover{transform:translateY(-1px);box-shadow:0 10px 24px -6px rgba(59,130,246,.7)}
.btn-dark{background:var(--bg-elevated);color:#fff;border:1px solid var(--border-strong)}
.btn-dark:hover{background:#222a3d;border-color:rgba(255,255,255,.2)}
.btn-ghost{background:transparent;color:var(--text-mute);border:1px solid var(--border)}
.btn-ghost:hover{color:#fff;background:var(--bg-elevated);border-color:var(--border-strong)}
.btn-danger{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff}
.btn-success{background:linear-gradient(135deg,#10b981,#059669);color:#fff}
.btn-warning{background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff}

.hero{
    position:relative;min-height:calc(100vh - 73px);
    display:flex;align-items:center;justify-content:center;
    padding:60px 32px 100px;overflow:hidden;isolation:isolate;
}

.hero-slideshow{
    position:absolute;inset:0;z-index:-2;
}

.hero-slide{
    position:absolute;inset:0;
    background-size:cover;background-position:center;
    filter:brightness(.42) saturate(1.15);
    opacity:0;
    transition:opacity 1.6s cubic-bezier(.4,0,.2,1);
    will-change:opacity,transform;
}

.hero-slide.active{
    opacity:1;
    animation:heroKenBurns 14s ease-in-out forwards;
}

.hero-slide::after{
    content:"";position:absolute;inset:0;
    background:
        linear-gradient(180deg,rgba(10,14,26,.35) 0%,rgba(10,14,26,.15) 40%,rgba(10,14,26,.7) 100%),
        linear-gradient(90deg,rgba(10,14,26,.3) 0%,transparent 50%,rgba(10,14,26,.3) 100%);
}

@keyframes heroKenBurns{
    from{transform:scale(1) translate(0,0)}
    to{transform:scale(1.08) translate(-1%,.5%)}
}

.hero-dots{
    position:absolute;
    bottom:40px;left:50%;
    transform:translateX(-50%);
    z-index:5;
    display:flex;gap:10px;align-items:center;
}

.hero-dot{
    width:8px;height:8px;
    border-radius:50%;
    background:rgba(255,255,255,.28);
    border:1px solid rgba(255,255,255,.18);
    cursor:pointer;padding:0;
    transition:all .4s cubic-bezier(.16,1,.3,1);
    flex-shrink:0;
}

.hero-dot:hover{
    background:rgba(255,255,255,.55);
    transform:scale(1.2);
}

.hero-dot.active{
    width:32px;
    border-radius:4px;
    background:rgba(255,255,255,.92);
    border-color:transparent;
    transform:scale(1);
}

.hero-storm{
    position:absolute;inset:0;z-index:-1;
    background:
        radial-gradient(ellipse 80% 60% at 50% 40%,rgba(59,130,246,.08),transparent 70%),
        radial-gradient(ellipse 60% 50% at 20% 30%,rgba(168,85,247,.05),transparent 60%);
}
.hero-storm::before{
    content:"";position:absolute;inset:0;
    background:
        radial-gradient(2px 80px at 20% 20%,rgba(255,255,255,.4),transparent),
        radial-gradient(1px 60px at 70% 35%,rgba(255,255,255,.3),transparent),
        radial-gradient(1.5px 100px at 50% 10%,rgba(255,255,255,.35),transparent),
        radial-gradient(1px 40px at 85% 50%,rgba(255,255,255,.25),transparent),
        radial-gradient(2px 70px at 30% 60%,rgba(255,255,255,.2),transparent);
    opacity:.5;animation:lightning 8s ease-in-out infinite;
}
.hero-storm::after{
    content:"";position:absolute;inset:0;
    background:radial-gradient(ellipse 100% 50% at 50% 100%,rgba(10,14,26,.9),transparent 80%);
}
@keyframes lightning{0%,90%,100%{opacity:.5}92%{opacity:.9}94%{opacity:.3}96%{opacity:.8}}

.hero-content{text-align:center;max-width:880px;position:relative;z-index:1}

.status-pill{
    display:inline-flex;align-items:center;gap:8px;
    padding:7px 16px;
    background:rgba(16,185,129,.1);border:1px solid rgba(16,185,129,.3);
    border-radius:999px;font-size:.78rem;font-weight:600;
    color:var(--green-2);letter-spacing:1.5px;margin-bottom:30px;
}
.status-dot{
    width:7px;height:7px;border-radius:50%;
    background:var(--green-2);box-shadow:0 0 12px var(--green-2);
    animation:pulse 1.8s ease-in-out infinite;
}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.6;transform:scale(1.2)}}

.hero-title{
    font-family:'Russo One',sans-serif;
    font-size:clamp(2.8rem,8vw,6rem);
    font-weight:400;line-height:.95;letter-spacing:2px;
    margin-bottom:24px;color:#fff;
    text-shadow:0 4px 30px rgba(59,130,246,.3);
}
.hero-tagline{
    font-size:clamp(1rem,2vw,1.2rem);
    color:var(--text-mute);margin-bottom:40px;line-height:1.7;
    max-width:640px;margin-left:auto;margin-right:auto;
}
.hero-cta{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}

.reveal{
    opacity:0;transform:translateY(20px);
    animation:reveal .9s cubic-bezier(.16,1,.3,1) forwards;
    animation-delay:var(--d,0s);
}
@keyframes reveal{to{opacity:1;transform:translateY(0)}}

.stats-section{padding:60px 0 80px}
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.stat-card{
    position:relative;background:var(--bg-card);
    border:1px solid var(--border);border-radius:var(--radius-lg);
    padding:28px;transition:all .25s;overflow:hidden;
}
.stat-card:hover{transform:translateY(-3px);border-color:var(--border-strong)}
.stat-card::before{
    content:"";position:absolute;inset:0;
    background:linear-gradient(135deg,transparent 60%,rgba(255,255,255,.02));
    pointer-events:none;
}
.stat-icon{
    width:42px;height:42px;border-radius:10px;
    display:flex;align-items:center;justify-content:center;margin-bottom:24px;
}
.stat-icon svg{width:20px;height:20px}
.stat-bar{width:40px;height:4px;border-radius:2px;margin-bottom:16px}
.stat-val{
    font-family:'Russo One',sans-serif;
    font-size:2.2rem;line-height:1;margin-bottom:6px;color:#fff;
}
.stat-lbl{color:var(--text-mute);font-size:.88rem;font-weight:500}
.stat-blue{background:linear-gradient(135deg,rgba(59,130,246,.12),rgba(59,130,246,.02))}
.stat-blue .stat-icon{background:var(--blue-dim);color:var(--blue-2)}
.stat-blue .stat-bar{background:var(--blue-2)}
.stat-green{background:linear-gradient(135deg,rgba(16,185,129,.12),rgba(16,185,129,.02))}
.stat-green .stat-icon{background:var(--green-dim);color:var(--green-2)}
.stat-green .stat-bar{background:var(--green-2)}
.stat-orange{background:linear-gradient(135deg,rgba(249,115,22,.12),rgba(249,115,22,.02))}
.stat-orange .stat-icon{background:var(--orange-dim);color:var(--orange-2)}
.stat-orange .stat-bar{background:var(--orange-2)}
.stat-purple{background:linear-gradient(135deg,rgba(168,85,247,.12),rgba(168,85,247,.02))}
.stat-purple .stat-icon{background:var(--purple-dim);color:var(--purple-2)}
.stat-purple .stat-bar{background:var(--purple-2)}
.stat-purple .stat-val{color:var(--purple-2)}

.section-header{text-align:center;margin-bottom:48px}
.section-title{
    font-family:'Russo One',sans-serif;
    font-size:clamp(2rem,5vw,3.2rem);
    letter-spacing:3px;color:#fff;margin-bottom:12px;
}
.section-sub{
    color:var(--text-mute);font-size:1.05rem;
    max-width:640px;margin:0 auto;
}

.services-section{padding:60px 0 100px}
.services-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}

.service-card{
    background:var(--bg-card);
    border:1px solid var(--border);
    border-radius:var(--radius-lg);
    overflow:hidden;
    transition:all .3s;
    display:flex !important;
    flex-direction:column !important;
    position:relative;
    cursor:pointer;
    padding:0;
}
.service-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-lg)}

.service-card > *{
    position:static !important;
    transform:none !important;
}

.service-card img{
    order:-100 !important;
    position:static !important;
    display:block !important;
    margin:24px auto 8px !important;
    padding:0 !important;
    width:140px !important;
    height:140px !important;
    max-width:140px !important;
    max-height:140px !important;
    object-fit:contain !important;
    transform:none !important;
    top:auto !important;left:auto !important;right:auto !important;bottom:auto !important;
    filter:drop-shadow(0 6px 16px rgba(0,0,0,.4));
    z-index:auto !important;
    flex:none !important;
    align-self:center !important;
}

.service-logo-bg{display:none !important}
.service-logo{
    order:-100 !important;
    display:block !important;
    margin:24px auto 8px !important;
    width:140px !important;
    height:140px !important;
    max-width:140px !important;
    max-height:140px !important;
    object-fit:contain !important;
    align-self:center !important;
}

.service-body{
    padding:8px 24px 24px;
    display:flex;
    flex-direction:column;
    flex:1;
}
.service-eyebrow{
    font-size:.72rem;font-weight:700;letter-spacing:2px;
    color:var(--text-mute);margin-bottom:8px;
    text-align:center;
}
.service-name{
    font-family:'Russo One',sans-serif;
    font-size:1.4rem;letter-spacing:1px;
    margin-bottom:14px;line-height:1.1;
    text-align:center;
}
.service-desc{
    color:var(--text-mute);font-size:.92rem;line-height:1.6;
    margin-bottom:24px;min-height:80px;flex:1;
    text-align:center;
}
.service-cta{
    display:flex;align-items:center;justify-content:center;gap:8px;
    padding:11px 0;border-radius:10px;
    background:var(--bg-elevated);
    font-weight:600;font-size:.9rem;
    transition:all .25s;border:1px solid var(--border);
    margin:0 24px 24px;
}
.service-cta:hover{transform:translateX(2px)}

.service-police{border-color:rgba(59,130,246,.2)}
.service-police .service-name{color:var(--blue-2)}
.service-police .service-cta{color:var(--blue-2);border-color:rgba(59,130,246,.3)}
.service-police .service-cta:hover{background:var(--blue-dim);border-color:var(--blue-2)}

.service-sheriff{border-color:rgba(251,191,36,.2)}
.service-sheriff .service-name{color:var(--gold-2)}
.service-sheriff .service-cta{color:var(--gold-2);border-color:rgba(251,191,36,.3)}
.service-sheriff .service-cta:hover{background:var(--gold-dim);border-color:var(--gold-2)}

.service-pompiers{border-color:rgba(239,68,68,.2)}
.service-pompiers .service-name{color:var(--red-2)}
.service-pompiers .service-cta{color:var(--red-2);border-color:rgba(239,68,68,.3)}
.service-pompiers .service-cta:hover{background:var(--red-dim);border-color:var(--red-2)}

.service-staff{border-color:rgba(168,85,247,.2)}
.service-staff .service-name{color:var(--purple-2)}
.service-staff .service-cta{color:var(--purple-2);border-color:rgba(168,85,247,.3)}
.service-staff .service-cta:hover{background:var(--purple-dim);border-color:var(--purple-2)}

.cand-form-head{
    text-align:center;padding:60px 32px 40px;
    border-bottom:1px solid var(--border);
}
.cand-form-icon{
    width:90px;height:90px;margin:0 auto 22px;
    border-radius:18px;
    display:flex;align-items:center;justify-content:center;
    background:var(--bg-card);border:1px solid var(--border);
    padding:14px;
}
.cand-form-icon svg{width:100%;height:100%}
.cand-form-icon.icon-police{border-color:rgba(59,130,246,.3);background:linear-gradient(135deg,#0c1426,#1e293b)}
.cand-form-icon.icon-sheriff{border-color:rgba(251,191,36,.3);background:linear-gradient(135deg,#1a1408,#2a2010)}
.cand-form-icon.icon-pompiers{border-color:rgba(239,68,68,.3);background:linear-gradient(135deg,#1a0a0a,#2a1414)}
.cand-form-icon.icon-staff{border-color:rgba(168,85,247,.3);background:linear-gradient(135deg,#1a0a26,#2a1438)}

.page-header{
    padding:80px 32px 60px;text-align:center;
    border-bottom:1px solid var(--border);
}
.page-title{
    font-family:'Russo One',sans-serif;
    font-size:clamp(2.4rem,6vw,4rem);
    letter-spacing:3px;color:#fff;margin-bottom:14px;line-height:1;
}
.page-sub{
    color:var(--text-mute);font-size:1.05rem;
    max-width:680px;margin:0 auto;
}

.page{display:none;padding-bottom:80px}
.page.active{display:block}

.card{
    background:var(--bg-card);border:1px solid var(--border);
    border-radius:var(--radius-lg);padding:32px;margin:40px 0;
}

.form-group{margin-bottom:18px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.field-label{
    display:block;font-size:.85rem;font-weight:600;
    color:#fff;margin-bottom:8px;letter-spacing:.3px;
}
.field-label .req{color:var(--red-2);margin-left:4px}
.field{
    width:100%;padding:12px 14px;
    background:var(--bg-input);border:1px solid var(--border);
    border-radius:10px;color:#fff;font-size:.95rem;
    transition:all .2s;outline:none;
}
.field::placeholder{color:var(--text-dim)}
.field:focus{border-color:var(--blue);box-shadow:0 0 0 3px var(--blue-dim)}
textarea.field{resize:vertical;min-height:110px;line-height:1.5}
select.field{
    cursor:pointer;appearance:none;
    background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%239ca3af' stroke-width='2.5'><polyline points='6 9 12 15 18 9'/></svg>");
    background-repeat:no-repeat;background-position:right 14px center;padding-right:38px;
}

.form-disclaimer{
    background:var(--bg-elevated);border:1px solid var(--border);
    border-radius:10px;padding:14px 16px;
    color:var(--text-mute);font-size:.88rem;margin-bottom:24px;
}
.form-disclaimer strong{color:var(--blue-2)}

#auth-error, #force-pw-error, #form-error{
    background:rgba(239,68,68,.1);border:1px solid rgba(239,68,68,.3);
    color:var(--red-2);padding:11px 14px;border-radius:10px;
    font-size:.9rem;margin-bottom:16px;
}

.modal-backdrop{
    position:fixed;inset:0;z-index:200;
    background:rgba(5,8,16,.8);
    backdrop-filter:blur(8px);
    display:none;align-items:center;justify-content:center;
    padding:24px;animation:fadeIn .2s ease;
}
.modal-backdrop.open{display:flex}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
.modal{
    background:var(--bg-card);border:1px solid var(--border);
    border-radius:var(--radius-lg);
    width:100%;max-width:480px;overflow:hidden;
    box-shadow:var(--shadow-lg);
    animation:modalUp .3s cubic-bezier(.16,1,.3,1);
}
@keyframes modalUp{from{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}
.modal-head{padding:24px 28px 20px;border-bottom:1px solid var(--border)}
.modal-title{font-family:'Russo One',sans-serif;font-size:1.4rem;color:#fff;letter-spacing:1px;margin-bottom:6px}
.modal-sub{color:var(--text-mute);font-size:.9rem}
.modal-body{padding:24px 28px}
.modal-foot{padding:14px 28px 22px;border-top:1px solid var(--border);text-align:center}
.modal-foot a{color:var(--text-mute);font-size:.88rem;cursor:pointer}
.modal-foot a:hover{color:#fff}

.auth-tabs{
    display:flex;gap:4px;
    background:var(--bg-input);padding:4px;border-radius:10px;margin-bottom:20px;
}
.auth-tab{
    flex:1;padding:9px;border-radius:8px;
    font-size:.88rem;font-weight:600;color:var(--text-mute);
    transition:all .2s;
}
.auth-tab.active{background:var(--bg-elevated);color:#fff;box-shadow:inset 0 0 0 1px var(--border-strong)}

.success-block{
    text-align:center;padding:50px 30px;
    background:var(--bg-card);border:1px solid rgba(16,185,129,.3);
    border-radius:var(--radius-lg);margin:40px auto;max-width:560px;
}
.success-icon{
    width:70px;height:70px;margin:0 auto 22px;
    background:var(--green-dim);border-radius:50%;
    display:flex;align-items:center;justify-content:center;color:var(--green-2);
    font-size:2rem;font-weight:700;
}
.success-icon svg{width:34px;height:34px}
.success-block h3{font-family:'Russo One',sans-serif;font-size:1.5rem;color:#fff;margin-bottom:10px;letter-spacing:1px}
.success-block p{color:var(--text-mute);margin-bottom:8px}
.success-block .ref{
    display:inline-block;font-family:'JetBrains Mono',monospace;
    background:var(--bg-input);padding:6px 14px;border-radius:8px;
    color:var(--blue-2);border:1px solid var(--border);margin:14px 0 22px;
}
.spec-tag{
    display:inline-block;background:var(--bg-elevated);
    padding:5px 12px;border-radius:999px;
    font-size:.8rem;font-weight:600;color:var(--text-mute);
    border:1px solid var(--border);margin-bottom:16px;
}

.empty-state{text-align:center;color:var(--text-mute);padding:40px 20px;font-style:italic}

.cand-list{display:flex;flex-direction:column;gap:14px;margin-top:30px}
.cand-item{
    display:flex;align-items:center;gap:18px;
    padding:18px 22px;background:var(--bg-card);
    border:1px solid var(--border);border-radius:var(--radius);
    transition:all .2s;
}
.cand-item:hover{border-color:var(--border-strong)}
.cand-item-info{flex:1}
.cand-item-metier{
    font-family:'Russo One',sans-serif;font-size:1.1rem;
    color:#fff;letter-spacing:1px;margin-bottom:4px;
}
.cand-item-meta{font-size:.85rem;color:var(--text-mute)}

.status-badge{
    display:inline-flex;align-items:center;gap:6px;
    padding:5px 12px;border-radius:999px;
    font-size:.75rem;font-weight:700;
    text-transform:uppercase;letter-spacing:1px;
}
.status-PENDING,.status-en_attente{background:rgba(251,191,36,.15);color:var(--gold-2);border:1px solid rgba(251,191,36,.3)}
.status-ACCEPTED,.status-acceptee{background:rgba(16,185,129,.15);color:var(--green-2);border:1px solid rgba(16,185,129,.3)}
.status-REJECTED,.status-refusee{background:rgba(239,68,68,.15);color:var(--red-2);border:1px solid rgba(239,68,68,.3)}

.guide-layout{
    display:grid;grid-template-columns:280px 1fr;gap:32px;
    max-width:1280px;margin:40px auto 0;padding:0 32px;
}
.guide-sidebar{
    background:var(--bg-card);border:1px solid var(--border);
    border-radius:var(--radius-lg);padding:20px;
    position:sticky;top:90px;align-self:flex-start;
    max-height:calc(100vh - 110px);overflow-y:auto;
}
.guide-cat{margin-bottom:18px}
.guide-cat-title{
    font-size:.78rem;font-weight:700;
    color:var(--text-mute);letter-spacing:1.5px;
    margin-bottom:8px;padding:0 8px;
}
.guide-article-link{
    display:block;padding:8px 12px;border-radius:8px;
    color:var(--text);font-size:.92rem;
    transition:all .2s;cursor:pointer;
}
.guide-article-link:hover{background:var(--bg-elevated)}
.guide-article-link.active{background:var(--blue-dim);color:var(--blue-2)}
.guide-content{
    background:var(--bg-card);border:1px solid var(--border);
    border-radius:var(--radius-lg);padding:40px;
    min-height:400px;line-height:1.7;
}
.guide-content h1,.guide-content h2,.guide-content h3{
    font-family:'Russo One',sans-serif;color:#fff;
    margin:24px 0 14px;letter-spacing:1px;
}
.guide-content h1{font-size:1.8rem}
.guide-content h2{font-size:1.4rem}
.guide-content h3{font-size:1.15rem}
.guide-content p{margin-bottom:14px;color:var(--text)}
.guide-content ul,.guide-content ol{margin:14px 0 14px 24px;color:var(--text)}
.guide-content li{margin-bottom:6px}
.guide-content code{
    background:var(--bg-input);padding:2px 6px;border-radius:4px;
    font-family:'JetBrains Mono',monospace;font-size:.88em;color:var(--blue-2);
}
.guide-content pre{
    background:var(--bg-input);padding:16px;border-radius:10px;
    overflow-x:auto;margin:14px 0;border:1px solid var(--border);
}
.guide-content pre code{background:none;padding:0}
.guide-content a{color:var(--blue-2);text-decoration:underline}
.guide-content blockquote{
    border-left:3px solid var(--blue);padding:8px 18px;margin:14px 0;
    background:var(--bg-input);border-radius:0 8px 8px 0;color:var(--text-mute);
}

.reglement-block{margin-top:30px}
.reglement-head{
    display:flex;align-items:center;gap:14px;
    margin-bottom:18px;padding-bottom:14px;
    border-bottom:1px solid var(--border);
}
.reglement-num{font-family:'Russo One',sans-serif;font-size:2rem;color:var(--blue-2);line-height:1}
.reglement-title{font-family:'Russo One',sans-serif;font-size:1.3rem;color:#fff;letter-spacing:1px}
.reglement-list{list-style:none;padding:0}
.reglement-line{
    padding:10px 0;color:var(--text);
    display:flex;gap:12px;
    border-bottom:1px solid rgba(255,255,255,.04);
}
.reglement-line::before{content:"→";color:var(--blue-2);flex-shrink:0}
.reglement-line:last-child{border-bottom:none}
.ref{display:inline-block;color:var(--text-dim);font-family:'JetBrains Mono',monospace;font-size:.85em;margin-right:8px}

.team-grid{
    display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));
    gap:20px;margin-top:30px;
}
.team-card{
    background:var(--bg-card);border:1px solid var(--border);
    border-radius:var(--radius-lg);padding:24px;
    text-align:center;transition:all .25s;
}
.team-card:hover{transform:translateY(-3px);border-color:var(--border-strong)}
.team-avatar{
    width:80px;height:80px;margin:0 auto 16px;border-radius:50%;
    background:linear-gradient(135deg,var(--blue),var(--purple));
    display:flex;align-items:center;justify-content:center;
    font-family:'Russo One',sans-serif;font-size:1.8rem;color:#fff;
}
.team-name{font-family:'Russo One',sans-serif;font-size:1.1rem;color:#fff;margin-bottom:4px;letter-spacing:.5px}
.team-role{
    display:inline-block;font-size:.72rem;font-weight:700;
    letter-spacing:1.5px;text-transform:uppercase;
    padding:3px 10px;border-radius:999px;margin-bottom:12px;
    background:var(--blue-dim);color:var(--blue-2);
}
.team-bio{color:var(--text-mute);font-size:.88rem;line-height:1.5}

.footer{
    background:#070a14;border-top:1px solid var(--border);
    margin-top:auto;padding:60px 0 0;
}
.footer-inner{
    max-width:1280px;margin:0 auto;padding:0 32px;
    display:grid;grid-template-columns:2fr 1fr 1fr;gap:40px;
}
.footer-brand-row{display:flex;align-items:center;gap:12px;margin-bottom:16px}
.footer-brand-text{font-family:'Russo One',sans-serif;font-size:1.2rem;color:#fff;letter-spacing:2px}
.footer-text{color:var(--text-mute);font-size:.92rem;line-height:1.6;max-width:380px}
.footer-title{
    font-size:.78rem;font-weight:700;color:#fff;
    letter-spacing:2px;margin-bottom:16px;text-transform:uppercase;
}
.footer-list{list-style:none;padding:0}
.footer-list li{margin-bottom:10px}
.footer-list a{color:var(--text-mute);font-size:.92rem;transition:color .2s}
.footer-list a:hover{color:var(--blue-2)}
.footer-bottom{
    margin-top:50px;padding:24px 32px;
    border-top:1px solid var(--border);
    display:flex;justify-content:space-between;
    color:var(--text-dim);font-size:.85rem;
    max-width:1280px;margin-left:auto;margin-right:auto;
}

/* ---- Avatar dans la nav ---- */
.nav-user-avatar img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    border-radius: 50%;
}
.nav-user-avatar.has-img { padding: 0; overflow: hidden; }

/* ---- Page Mon compte ---- */
.account-page { max-width: 720px; margin: 0 auto; padding: 0 24px; }
.account-card {
    background: var(--surface, #161b27);
    border: 1px solid var(--border);
    border-radius: 14px;
    padding: 24px;
    margin-bottom: 18px;
}
.account-card h3 {
    margin: 0 0 14px;
    font-family: 'Russo One', sans-serif;
    font-size: 1.05rem;
    letter-spacing: 1px;
    color: var(--text);
    display: flex;
    align-items: center;
    gap: 10px;
}
.account-avatar-wrap {
    display: flex;
    align-items: center;
    gap: 24px;
    flex-wrap: wrap;
}
.account-avatar-big {
    width: 120px;
    height: 120px;
    border-radius: 50%;
    background: linear-gradient(135deg, #2563eb, #7c3aed);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 2.4rem;
    font-weight: 800;
    color: #fff;
    overflow: hidden;
    border: 3px solid rgba(255,255,255,.08);
    flex-shrink: 0;
}
.account-avatar-big img { width: 100%; height: 100%; object-fit: cover; }
.account-avatar-actions {
    display: flex;
    flex-direction: column;
    gap: 8px;
    flex: 1;
    min-width: 220px;
}
.account-avatar-actions .file-row {
    display: flex; gap: 8px; align-items: center;
    padding: 10px 12px;
    background: rgba(255,255,255,.04);
    border: 1px dashed rgba(255,255,255,.15);
    border-radius: 10px;
}
.account-avatar-actions .file-row input[type=file] {
    flex: 1; min-width: 0;
    color: var(--text-mute);
    font-size: .85rem;
}
.account-info-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
    gap: 12px;
    margin-top: 10px;
}
.account-info-cell {
    padding: 10px 14px;
    background: rgba(255,255,255,.03);
    border: 1px solid var(--border);
    border-radius: 10px;
}
.account-info-label {
    font-size: .7rem;
    color: var(--text-dim);
    text-transform: uppercase;
    letter-spacing: .04em;
    margin-bottom: 4px;
}
.account-info-value {
    color: var(--text);
    font-weight: 600;
    word-break: break-word;
}

/* ---- Bannière d'annonce ---- */
.site-banner {
    display: none;
    padding: 10px 24px;
    font-size: .92rem;
    font-weight: 500;
    text-align: center;
    border-bottom: 1px solid transparent;
    line-height: 1.4;
    position: relative;
    z-index: 100;
}
.site-banner.show { display: block; }
.site-banner-icon { display: inline-block; margin-right: 8px; font-size: 1.05rem; vertical-align: middle; }
.site-banner-info {
    background: linear-gradient(90deg, rgba(59,130,246,.15), rgba(59,130,246,.08));
    border-bottom-color: rgba(59,130,246,.35);
    color: #93c5fd;
}
.site-banner-warning {
    background: linear-gradient(90deg, rgba(245,158,11,.18), rgba(245,158,11,.08));
    border-bottom-color: rgba(245,158,11,.4);
    color: #fcd34d;
}
.site-banner-danger {
    background: linear-gradient(90deg, rgba(239,68,68,.18), rgba(239,68,68,.08));
    border-bottom-color: rgba(239,68,68,.4);
    color: #fca5a5;
    animation: bannerPulse 2.5s ease-in-out infinite;
}
@keyframes bannerPulse {
    0%, 100% { background: linear-gradient(90deg, rgba(239,68,68,.18), rgba(239,68,68,.08)); }
    50%       { background: linear-gradient(90deg, rgba(239,68,68,.28), rgba(239,68,68,.14)); }
}

/* ---- Chat Candidature ---- */
.chat-wrap {
    background: var(--surface, #161b27);
    border: 1px solid var(--border);
    border-radius: 12px;
    overflow: hidden;
    display: flex;
    flex-direction: column;
    max-height: 460px;
}
.chat-header {
    padding: 10px 14px;
    background: rgba(255,255,255,.03);
    border-bottom: 1px solid var(--border);
    font-size: .85rem;
    color: var(--text-mute);
    display: flex;
    align-items: center;
    gap: 10px;
}
.chat-header .chat-status {
    margin-left: auto;
    font-size: .72rem;
    padding: 3px 8px;
    border-radius: 999px;
}
.chat-status.open { background: rgba(34,197,94,.15); color: #4ade80; }
.chat-status.locked { background: rgba(239,68,68,.15); color: #f87171; }
.chat-messages {
    padding: 14px;
    overflow-y: auto;
    flex: 1;
    display: flex;
    flex-direction: column;
    gap: 10px;
    min-height: 200px;
    background: linear-gradient(to bottom, rgba(0,0,0,.1), transparent);
}
.chat-msg {
    max-width: 75%;
    padding: 9px 13px;
    border-radius: 14px;
    font-size: .92rem;
    line-height: 1.4;
    word-wrap: break-word;
    white-space: pre-wrap;
}
.chat-msg-meta {
    font-size: .7rem;
    color: var(--text-dim);
    margin-bottom: 3px;
    padding: 0 4px;
}
.chat-msg-row { display: flex; flex-direction: column; }
.chat-msg-row.from-self { align-items: flex-end; }
.chat-msg-row.from-other { align-items: flex-start; }
.chat-msg-row.from-self .chat-msg {
    background: linear-gradient(135deg, #2563eb, #3b82f6);
    color: #fff;
    border-bottom-right-radius: 4px;
}
.chat-msg-row.from-other .chat-msg {
    background: rgba(255,255,255,.06);
    color: var(--text);
    border: 1px solid var(--border);
    border-bottom-left-radius: 4px;
}
.chat-msg-row.from-system { align-items: center; max-width: 100%; }
.chat-msg-row.from-system .chat-msg {
    background: rgba(245,158,11,.1);
    border: 1px dashed rgba(245,158,11,.4);
    color: #fcd34d;
    font-size: .85rem;
    max-width: 90%;
    text-align: center;
    border-radius: 10px;
}
.chat-empty {
    text-align: center;
    color: var(--text-dim);
    padding: 30px 10px;
    font-size: .88rem;
    font-style: italic;
}
.chat-input-bar {
    border-top: 1px solid var(--border);
    padding: 10px;
    display: flex;
    gap: 8px;
    background: rgba(255,255,255,.02);
}
.chat-input-bar textarea {
    flex: 1;
    resize: none;
    padding: 9px 12px;
    background: rgba(255,255,255,.04);
    border: 1px solid var(--border);
    border-radius: 8px;
    color: #fff;
    font-family: inherit;
    font-size: .92rem;
    min-height: 40px;
    max-height: 120px;
    outline: none;
}
.chat-input-bar textarea:focus { border-color: rgba(59,130,246,.5); }
.chat-input-bar button {
    padding: 0 16px;
    background: linear-gradient(135deg, #2563eb, #3b82f6);
    color: #fff;
    border: none;
    border-radius: 8px;
    font-weight: 600;
    cursor: pointer;
    transition: opacity .15s;
}
.chat-input-bar button:hover { opacity: .9; }
.chat-input-bar button:disabled { opacity: .4; cursor: not-allowed; }
.chat-locked-notice {
    padding: 10px 14px;
    background: rgba(239,68,68,.08);
    border-top: 1px solid rgba(239,68,68,.2);
    color: #f87171;
    font-size: .85rem;
    text-align: center;
}

@media (max-width:1024px){
    .stats-grid{grid-template-columns:repeat(2,1fr)}
    .services-grid{grid-template-columns:repeat(2,1fr)}
    .footer-inner{grid-template-columns:1fr 1fr;gap:30px}
    .guide-layout{grid-template-columns:1fr}
    .guide-sidebar{position:static;max-height:none}
}

@media (max-width:768px){
    .nav-inner{padding:12px 20px;gap:14px}
    .nav-brand-text{font-size:.95rem;letter-spacing:1.5px}
    .nav-brand-logo{width:38px;height:38px}
    .nav-links{
        position:fixed;top:69px;left:0;right:0;
        flex-direction:column;
        background:rgba(10,14,26,.98);
        backdrop-filter:blur(14px);
        padding:14px;border-bottom:1px solid var(--border);
        gap:4px;align-items:stretch;
        max-height:0;overflow:hidden;
        transition:max-height .3s ease;margin:0;
    }
    .nav-links.open{max-height:500px;padding:14px}
    .nav-link{padding:12px 16px}
    .nav-burger{display:flex}
    .nav-user{display:none}
    .container,.container-md,.container-sm{padding:0 20px}
    .hero{padding:40px 20px 70px;min-height:auto}
    .hero-cta{flex-direction:column;width:100%;max-width:320px;margin:0 auto}
    .hero-cta .btn{width:100%}
    .hero-dots{bottom:24px;gap:8px}
    .stats-grid{grid-template-columns:1fr 1fr;gap:14px}
    .stat-card{padding:22px}
    .stat-val{font-size:1.8rem}
    .services-grid{grid-template-columns:1fr;gap:18px}
    .service-logo-bg{height:200px}
    .form-row{grid-template-columns:1fr}
    .footer-inner{grid-template-columns:1fr;text-align:center}
    .footer-brand-row{justify-content:center}
    .footer-text{margin:0 auto}
    .footer-bottom{flex-direction:column;gap:8px;text-align:center;padding:20px}
    .page-header{padding:50px 20px 40px}
    .card{padding:24px 20px;margin:24px 0}
    .modal{margin:0;max-width:100%}
}

@media (max-width:480px){
    .stats-grid{grid-template-columns:1fr}
    .nav-brand-text{display:none}
    .hero-title{letter-spacing:1px}
    .section-title{letter-spacing:2px}
    .hero-dot.active{width:24px}
}

::-webkit-scrollbar{width:10px;height:10px}
::-webkit-scrollbar-track{background:var(--bg)}
::-webkit-scrollbar-thumb{background:var(--bg-elevated);border-radius:5px;border:2px solid var(--bg)}
::-webkit-scrollbar-thumb:hover{background:#2a3349}
::selection{background:var(--blue-dim);color:#fff}