/* css/main.css — Styles partagés CRG Pro */
@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:wght@500;600;700&family=Outfit:wght@300;400;500;600&display=swap');

:root {
  --ink:#16181C;--ink2:#4A4E57;--ink3:#9198A4;
  --paper:#F7F6F3;--sheet:#FFFFFF;--rule:#E4E2DD;--rule2:#EEECEA;
  --navy:#1B2A4A;--navy-l:#EBF0F9;
  --gold:#B8912A;--gold-l:#FBF5E6;
  --green:#1A6644;--green-l:#E8F5EE;
  --red:#B52A2A;--red-l:#FCEAEA;
  --amber:#9A5E14;--amber-l:#FDF3E3;
  --r:10px;
  --sh:0 1px 4px rgba(0,0,0,.06),0 4px 16px rgba(0,0,0,.07);
  --sh-lg:0 8px 40px rgba(0,0,0,.14);
}
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:'Outfit',sans-serif;background:var(--paper);color:var(--ink);font-size:14px}

/* ── AUTH PAGES ── */
.auth-body{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px;background:var(--paper)}
.auth-shell{width:100%;max-width:460px}
.auth-logo{text-align:center;margin-bottom:26px}
.auth-logo h1{font-family:'Playfair Display',serif;font-size:26px;color:var(--navy)}
.auth-logo p{font-size:11px;color:var(--ink3);text-transform:uppercase;letter-spacing:.6px;margin-top:3px}
.auth-card{background:var(--sheet);border-radius:14px;box-shadow:var(--sh-lg);padding:34px}
.auth-card h2{font-family:'Playfair Display',serif;font-size:20px;color:var(--ink);margin-bottom:20px}

/* ── FORMS ── */
.fg{display:flex;flex-direction:column;gap:5px;margin-bottom:13px}
.fg.full{grid-column:1/-1}
label{font-size:10.5px;font-weight:600;color:var(--ink2);text-transform:uppercase;letter-spacing:.4px}
input,select,textarea{font-family:'Outfit',sans-serif;font-size:13.5px;padding:9px 12px;border:1.5px solid var(--rule);border-radius:8px;background:var(--paper);color:var(--ink);outline:none;transition:border-color .14s;width:100%}
input:focus,select:focus,textarea:focus{border-color:var(--navy);background:#fff}
input.err-input{border-color:var(--red)}
textarea{resize:vertical;min-height:70px}
.fgrid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.err-msg{font-size:11.5px;color:var(--red);margin-top:2px;display:none}
.err-msg.show{display:block}
.fsec-title{font-size:10.5px;font-weight:700;color:var(--navy);text-transform:uppercase;letter-spacing:.5px;padding-bottom:7px;border-bottom:1.5px solid var(--rule);margin-bottom:12px;margin-top:18px}
.fsec-title:first-child{margin-top:0}

/* ── BUTTONS ── */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:9px 16px;border-radius:8px;font-size:13px;font-weight:500;cursor:pointer;border:none;transition:all .14s;font-family:'Outfit',sans-serif;white-space:nowrap;text-decoration:none}
.btn-primary{background:var(--navy);color:#fff}.btn-primary:hover{background:#243662}
.btn-ghost{background:var(--sheet);color:var(--ink2);border:1.5px solid var(--rule)}.btn-ghost:hover{border-color:var(--navy);color:var(--navy)}
.btn-gold{background:var(--gold);color:#fff}.btn-gold:hover{background:#9a7820}
.btn-green{background:var(--green);color:#fff}.btn-green:hover{background:#114d33}
.btn-danger{background:var(--red);color:#fff}
.btn-sm{padding:6px 11px;font-size:12px}
.btn-full{width:100%}
.btn:disabled{opacity:.6;cursor:not-allowed}

/* ── ALERTS ── */
.alert{padding:11px 15px;border-radius:8px;font-size:13px;display:flex;gap:8px;align-items:flex-start;margin-bottom:14px}
.al-e{background:var(--red-l);border:1px solid #efc5c5;color:var(--red)}
.al-ok{background:var(--green-l);border:1px solid #b0d9c2;color:var(--green)}
.al-w{background:var(--amber-l);border:1px solid #f0cc90;color:var(--amber)}
.al-i{background:var(--navy-l);border:1px solid #b8cef0;color:var(--navy)}

/* ── PASSWORD ── */
.pwd-wrap{position:relative}
.pwd-wrap input{padding-right:40px}
.pwd-eye{position:absolute;right:12px;top:50%;transform:translateY(-50%);cursor:pointer;color:var(--ink3);font-size:16px;line-height:1;user-select:none;background:none;border:none}
.pwd-bar{height:3px;border-radius:2px;margin-top:5px;width:0;transition:all .3s}
.pwd-hint{font-size:11px;color:var(--ink3);margin-top:3px}

/* ── TABS ── */
.tabs{display:flex;gap:2px;background:var(--rule2);border-radius:9px;padding:3px;margin-bottom:18px}
.tab{padding:7px 14px;border-radius:7px;cursor:pointer;font-size:12.5px;font-weight:500;color:var(--ink2);transition:all .14s}
.tab.active{background:var(--sheet);color:var(--ink);box-shadow:0 1px 4px rgba(0,0,0,.07)}

/* ── STEP DOTS ── */
.step-bar{display:flex;gap:6px;margin-bottom:22px}
.step-dot{flex:1;height:4px;border-radius:2px;background:var(--rule);transition:background .25s}
.step-dot.done{background:var(--navy)}.step-dot.active{background:var(--gold)}

/* ── LINKS ── */
.link-row{text-align:center;margin-top:16px;font-size:13px;color:var(--ink3)}
.link-row a{color:var(--navy);font-weight:500;text-decoration:none}

/* ── TOAST ── */
#toast{position:fixed;bottom:22px;right:22px;background:var(--ink);color:#fff;padding:10px 17px;border-radius:9px;font-size:13px;z-index:9999;box-shadow:var(--sh-lg);display:none;animation:slideUp .22s ease;max-width:360px}
@keyframes slideUp{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}

/* ── SPINNER ── */
.spinner{width:44px;height:44px;border:4px solid var(--rule);border-top-color:var(--navy);border-radius:50%;animation:spin .8s linear infinite;margin:0 auto 18px}
@keyframes spin{to{transform:rotate(360deg)}}
