/* Force Nationale · Auth (register + login) */
:root{
  --fn-black:#0b1411; --fn-black-2:#152521;
  --fn-green:#3bbc7a; --fn-green-soft:#2a9a5f; --fn-green-ghost:#e7f6ee;
  --fn-bg:#fafaf7; --fn-border:#e6ebe6; --fn-border-strong:#d2dad4;
  --fn-text:#0b1411; --fn-text-muted:#6b7e78;
}
body.fn-portal-page{margin:0;font-family:'Inter',system-ui,sans-serif;color:var(--fn-text);background:var(--fn-bg);font-size:14px;line-height:1.55}

.fn-auth{display:grid;height:100vh;overflow:hidden}
.fn-auth *{box-sizing:border-box}
.fn-auth a{color:inherit;text-decoration:none}
.fn-auth button{font-family:inherit;cursor:pointer;border:0;background:none}

.fn-auth-register{grid-template-columns:320px 1fr}
.fn-auth-sidebar{background:var(--fn-black);color:#c7d0cc;padding:36px 32px;display:flex;flex-direction:column;border-radius:0 24px 24px 0;height:100%;overflow-y:auto}
.fn-auth-sidebar-logo{display:flex;flex-direction:column;align-items:center;gap:10px;margin-bottom:40px;padding-bottom:24px;border-bottom:1px solid rgba(255,255,255,.08)}
.fn-auth-caption{font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--fn-green);font-weight:700}
.fn-steps-aside{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:6px}
.fn-steps-aside li{display:flex;align-items:center;gap:14px;padding:10px 0;color:#b5c4bf;font-size:14px}
.fn-steps-aside li.is-active{color:#fff;font-weight:700}
.fn-steps-aside .num{width:30px;height:30px;border-radius:50%;border:1.5px solid rgba(255,255,255,.25);display:grid;place-items:center;font-size:13px;font-weight:600;flex:none}
.fn-steps-aside li.is-active .num{background:var(--fn-green);color:var(--fn-black);border-color:var(--fn-green)}
.fn-auth-sidebar-bottom{margin-top:auto;padding-top:20px;border-top:1px solid rgba(255,255,255,.06)}
.fn-auth-sidebar-bottom p{margin:0;color:#b5c4bf;font-size:13.5px;line-height:1.5}
.fn-auth-sidebar-bottom a{color:#fff;font-weight:600}

.fn-auth-main{padding:32px 48px;overflow-y:auto;height:100%;background:radial-gradient(700px 400px at 80% 0%,#eaf3ee 0%,transparent 70%),var(--fn-bg)}
.fn-auth-card{background:#fff;border-radius:18px;padding:36px 48px;box-shadow:0 18px 40px rgba(11,20,17,.05);max-width:820px;width:100%;margin:0 auto;border:1px solid var(--fn-border)}
.fn-auth-card .fn-card-head h1{font-family:'Playfair Display',Georgia,serif;font-size:28px;font-weight:600;margin:0 0 6px;letter-spacing:-.015em}
.fn-auth-card .fn-card-head p{color:var(--fn-text-muted);margin:0 auto 18px;font-size:14.5px;max-width:56ch}
.fn-section-banner{background:var(--fn-green-ghost);border-radius:10px;padding:12px 18px;font-weight:700;font-size:13px;color:var(--fn-green-soft);letter-spacing:.04em;text-transform:uppercase;margin:18px 0 16px}
.fn-row{display:grid;gap:14px}
.fn-row-2{grid-template-columns:1fr 1fr}
.fn-field{margin-bottom:14px}
.fn-field label{display:block;font-size:13px;font-weight:600;color:var(--fn-text);margin-bottom:6px}
.fn-field input,.fn-field select{width:100%;padding:12px 14px;border:1px solid var(--fn-border-strong);border-radius:10px;background:#fff;font:inherit;font-size:14.5px}
.fn-field input:focus,.fn-field select:focus{outline:none;border-color:var(--fn-green);box-shadow:0 0 0 4px rgba(59,188,122,.1)}
.fn-rules{background:var(--fn-green-ghost);border-radius:10px;padding:12px 14px;margin-top:8px}
.fn-rules li{color:var(--fn-text-muted);transition:color .15s}
.fn-rules li.is-ok{color:var(--fn-green-soft);font-weight:600}
.fn-form-error{background:#fbe9e9;color:#8a2424;border-radius:10px;padding:12px 16px;margin:8px 0;font-size:13.5px}
.fn-form-ok{background:var(--fn-green-ghost);color:var(--fn-green-soft);border-radius:10px;padding:12px 16px;margin:8px 0;font-size:13.5px}
.fn-submit{width:100%;padding:15px 24px;background:var(--fn-black);color:var(--fn-green);border-radius:12px;font-weight:700;font-size:15px;font-family:inherit;margin-top:12px;cursor:pointer;border:0;transition:all .15s;letter-spacing:.02em}
.fn-submit:hover{background:var(--fn-black-2)}
.fn-submit:disabled{opacity:.6;cursor:not-allowed}
.fn-alt a{color:var(--fn-green-soft);font-weight:600}

/* Login */
.fn-auth-login{grid-template-columns:1fr 1fr;padding:28px;gap:0}
.fn-auth-hero{position:relative;border-radius:18px;overflow:hidden;display:flex;flex-direction:column;justify-content:flex-end;padding:44px;color:#fff;min-height:100%;background-color:#0b1411}
.fn-hero-overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(11,20,17,.15) 0%,rgba(11,20,17,.55) 55%,rgba(11,20,17,.85) 100%),radial-gradient(circle at 30% 85%,rgba(59,188,122,.22) 0%,transparent 55%);z-index:1}
.fn-hero-logo-tl{position:absolute;top:36px;left:40px;z-index:2}
.fn-hero-logo-tl img{display:block;filter:drop-shadow(0 2px 18px rgba(11,20,17,.45))}
.fn-hero-quote{position:relative;z-index:2;max-width:460px}
.fn-mark{font-size:60px;font-family:Georgia,serif;line-height:.6;color:var(--fn-green);margin-bottom:10px;display:block}
.fn-hero-quote p{font-family:'Playfair Display',serif;font-size:28px;line-height:1.3;margin:0 0 14px;font-weight:500;color:#fff;font-style:italic;letter-spacing:-.01em}
.fn-hero-author{display:block;font-family:'Inter',sans-serif;font-size:12px;letter-spacing:.22em;text-transform:uppercase;color:var(--fn-green);font-weight:700;font-style:normal}
.fn-auth-panel{background:#fff;border-radius:18px;display:flex;flex-direction:column;padding:48px 56px;box-shadow:0 18px 40px rgba(11,20,17,.05);overflow-y:auto}

/* Responsive */
@media (max-width:960px){.fn-auth{height:auto;overflow:visible}.fn-auth-register{grid-template-columns:1fr}.fn-auth-sidebar{border-radius:0 0 24px 24px;height:auto}.fn-steps-aside{flex-direction:row;flex-wrap:wrap}.fn-auth-main{height:auto;padding:20px}.fn-auth-card{padding:24px 20px}.fn-row-2{grid-template-columns:1fr}.fn-auth-login{grid-template-columns:1fr;height:auto}.fn-auth-hero{min-height:200px}.fn-auth-panel{padding:32px 24px}}
