:root{
  --c-navy:#0B2540;--c-navy-2:#0F2C4D;--c-navy-3:#143358;--c-navy-soft:#1B3F6A;
  --c-gold:#D4A24C;--c-gold-light:#E8C57F;--c-gold-dark:#A87A28;
  --c-bg:#F7F5F0;--c-surface:#FFFFFF;--c-surface-2:#FBFAF6;
  --c-border:#E5E1D8;--c-border-soft:#EFECE5;
  --c-text:#0F1B2D;--c-text-2:#4A5468;--c-text-3:#7C8597;--c-text-muted:#A1A8B8;
  --c-success:#16A34A;--c-success-bg:#DCFCE7;--c-warning:#D97706;--c-warning-bg:#FEF3C7;
  --c-danger:#DC2626;--c-danger-bg:#FEE2E2;--c-info:#2563EB;--c-info-bg:#DBEAFE;
  --shadow-sm:0 1px 2px rgba(15,27,45,.05);--shadow-md:0 4px 12px rgba(15,27,45,.08);
  --shadow-lg:0 12px 32px rgba(15,27,45,.12);--shadow-card:0 1px 3px rgba(15,27,45,.06),0 1px 2px rgba(15,27,45,.04);
  --r-sm:6px;--r-md:10px;--r-lg:16px;--r-xl:24px;--r-full:999px;
  --f-display:'Bricolage Grotesque',system-ui,sans-serif;--f-body:'Geist',system-ui,sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%;font-family:var(--f-body);font-size:15px;line-height:1.5;color:var(--c-text);background:var(--c-bg);-webkit-font-smoothing:antialiased}
button{font-family:inherit;cursor:pointer;border:none;background:none}
input,select,textarea{font-family:inherit;font-size:inherit}
img{max-width:100%;display:block}
.hidden{display:none!important}
h1,h2,h3,h4{font-family:var(--f-display);letter-spacing:-.01em;line-height:1.15}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:11px 18px;border-radius:var(--r-md);font-weight:600;font-size:14px;transition:.15s;white-space:nowrap}
.btn-primary{background:var(--c-navy);color:#fff}.btn-primary:hover{background:var(--c-navy-3)}
.btn-gold{background:var(--c-gold);color:var(--c-navy)}.btn-gold:hover{background:var(--c-gold-light)}
.btn-ghost{background:transparent;color:var(--c-text-2);border:1px solid var(--c-border)}.btn-ghost:hover{background:var(--c-surface-2);color:var(--c-text)}
.btn-danger{background:var(--c-danger-bg);color:var(--c-danger)}.btn-danger:hover{background:#FBD5D5}
.btn-full{width:100%}.btn-sm{padding:7px 12px;font-size:13px}
.brand-mark{width:44px;height:44px;display:grid;place-items:center;background:var(--c-navy);color:var(--c-gold);font-family:var(--f-display);font-weight:700;font-size:22px;border-radius:12px}
.brand-mark.sm{width:36px;height:36px;font-size:18px;border-radius:10px}

/* role switcher */
.role-bar{position:fixed;top:0;left:0;right:0;height:46px;background:#06192e;color:#fff;display:flex;align-items:center;justify-content:center;gap:6px;z-index:90;font-size:13px}
.role-bar .lbl{color:rgba(255,255,255,.55);margin-right:6px}
.role-bar button{color:rgba(255,255,255,.7);font-weight:600;padding:6px 16px;border-radius:var(--r-full);font-size:13px}
.role-bar button.active{background:var(--c-gold);color:var(--c-navy)}
.shifted{padding-top:46px}

/* app shell */
.app-screen{min-height:100vh;display:grid;grid-template-columns:240px 1fr}
.sidebar{background:var(--c-navy);color:#fff;display:flex;flex-direction:column;padding:20px 14px;position:sticky;top:46px;height:calc(100vh - 46px)}
.sidebar-brand{display:flex;align-items:center;gap:10px;padding:6px 8px 22px}
.brand-name{font-family:var(--f-display);font-weight:700;font-size:18px;line-height:1;color:#fff}
.brand-sub{font-size:11px;color:rgba(255,255,255,.55);margin-top:3px}
.sidebar-nav{display:flex;flex-direction:column;gap:4px;flex:1}
.nav-item{display:flex;align-items:center;gap:12px;padding:11px 12px;border-radius:var(--r-md);color:rgba(255,255,255,.7);font-size:14px;font-weight:500;transition:.15s;text-align:left;width:100%}
.nav-item:hover{background:rgba(255,255,255,.07);color:#fff}
.nav-item.active{background:var(--c-gold);color:var(--c-navy);font-weight:600}
.sidebar-user{display:flex;align-items:center;gap:10px;padding:12px;border-radius:var(--r-md);background:rgba(255,255,255,.05);margin-top:8px}
.user-avatar{width:36px;height:36px;border-radius:50%;background:var(--c-gold);color:var(--c-navy);display:grid;place-items:center;font-weight:700;font-size:14px;flex-shrink:0}
.user-info{flex:1;min-width:0}
.user-name{font-size:13px;font-weight:600;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.user-meta{font-size:11px;color:rgba(255,255,255,.55)}
.main-area{display:flex;flex-direction:column;min-width:0}
.topbar{height:62px;background:var(--c-surface);border-bottom:1px solid var(--c-border);display:flex;align-items:center;justify-content:space-between;padding:0 28px;position:sticky;top:0;z-index:10}
.topbar-title{font-family:var(--f-display);font-weight:600;font-size:18px}
.page{padding:28px;max-width:1180px;width:100%;margin:0 auto}

/* shared bits */
.sub-banner{display:flex;align-items:center;gap:14px;padding:14px 18px;border-radius:var(--r-lg);margin-bottom:24px;font-size:14px}
.sub-banner.ok{background:var(--c-success-bg);color:#14532D}
.sub-banner.warn{background:var(--c-warning-bg);color:#7C2D12}
.sub-banner.expired{background:var(--c-danger-bg);color:#7F1D1D}
.sub-banner .grow{flex:1}
.cat-head{display:flex;align-items:flex-end;justify-content:space-between;flex-wrap:wrap;gap:16px;margin-bottom:22px}
.cat-head h1{font-size:26px}.cat-head p{color:var(--c-text-2);font-size:14px;margin-top:4px}
.search{display:flex;align-items:center;gap:10px;background:var(--c-surface);border:1px solid var(--c-border);border-radius:var(--r-md);padding:9px 14px;min-width:240px}
.search input{border:none;background:none;width:100%}.search input:focus{outline:none}
.chips{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:24px}
.chip{padding:7px 14px;border-radius:var(--r-full);border:1px solid var(--c-border);background:var(--c-surface);font-size:13px;font-weight:500;color:var(--c-text-2);transition:.15s}
.chip:hover{border-color:var(--c-gold)}.chip.active{background:var(--c-navy);color:#fff;border-color:var(--c-navy)}

/* catalogue user */
.book-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(178px,1fr));gap:22px}
.book{background:var(--c-surface);border:1px solid var(--c-border-soft);border-radius:var(--r-lg);overflow:hidden;transition:.18s;cursor:pointer;box-shadow:var(--shadow-card)}
.book:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.book-cover{aspect-ratio:3/4;display:flex;flex-direction:column;justify-content:space-between;padding:18px;color:#fff;position:relative;overflow:hidden}
.book-cover::after{content:"";position:absolute;inset:0;background:radial-gradient(circle at 80% 10%,rgba(255,255,255,.12),transparent 50%)}
.book-cat{font-size:11px;font-weight:600;letter-spacing:.04em;text-transform:uppercase;opacity:.85;position:relative}
.book-cover h3{font-size:17px;position:relative;z-index:1}
.book-info{padding:14px 16px}.book-info .t{font-weight:600;font-size:14px;line-height:1.3}
.book-info .a{color:var(--c-text-3);font-size:12.5px;margin-top:3px}
.book-meta{display:flex;align-items:center;gap:8px;margin-top:10px;font-size:11.5px;color:var(--c-text-muted)}
.tag-pdf{display:inline-flex;align-items:center;gap:4px;background:var(--c-surface-2);border:1px solid var(--c-border);padding:2px 7px;border-radius:var(--r-sm);font-weight:600;color:var(--c-danger)}

/* pricing */
.pricing{display:grid;grid-template-columns:1fr 1fr;gap:24px;max-width:760px;margin:0 auto}
.plan{background:var(--c-surface);border:1.5px solid var(--c-border);border-radius:var(--r-xl);padding:32px 28px;position:relative;display:flex;flex-direction:column}
.plan.featured{border-color:var(--c-gold);box-shadow:0 0 0 4px rgba(212,162,76,.12)}
.plan-badge{position:absolute;top:-12px;left:50%;transform:translateX(-50%);background:var(--c-gold);color:var(--c-navy);font-size:12px;font-weight:700;padding:4px 14px;border-radius:var(--r-full)}
.plan h3{font-size:20px}.plan .price{font-family:var(--f-display);font-size:38px;font-weight:700;margin:14px 0 2px}
.plan .price small{font-size:15px;font-weight:500;color:var(--c-text-3)}
.plan .per{color:var(--c-text-3);font-size:13px;margin-bottom:20px}
.plan ul{list-style:none;display:flex;flex-direction:column;gap:11px;margin-bottom:24px;flex:1}
.plan li{display:flex;gap:10px;font-size:14px;color:var(--c-text-2)}
.plan li svg{color:var(--c-success);flex-shrink:0;margin-top:2px}
.save-tag{display:inline-block;background:var(--c-success-bg);color:#14532D;font-size:12px;font-weight:600;padding:2px 9px;border-radius:var(--r-full);margin-left:8px}

/* account */
.acct{max-width:640px}
.acct-card{background:var(--c-surface);border:1px solid var(--c-border);border-radius:var(--r-lg);padding:24px;margin-bottom:20px}
.acct-row{display:flex;justify-content:space-between;align-items:center;padding:12px 0;border-bottom:1px solid var(--c-border-soft);font-size:14px}
.acct-row:last-child{border:none}.acct-row .k{color:var(--c-text-3)}.acct-row .v{font-weight:600}
.badge{font-size:12px;font-weight:600;padding:3px 10px;border-radius:var(--r-full)}
.badge.ok{background:var(--c-success-bg);color:#14532D}.badge.expired{background:var(--c-danger-bg);color:#7F1D1D}
.badge.warn{background:var(--c-warning-bg);color:#7C2D12}
.progress{height:8px;background:var(--c-border);border-radius:var(--r-full);overflow:hidden;margin-top:8px}
.progress span{display:block;height:100%;background:var(--c-gold)}

/* admin */
.stat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:18px;margin-bottom:28px}
.stat{background:var(--c-surface);border:1px solid var(--c-border-soft);border-radius:var(--r-lg);padding:20px;box-shadow:var(--shadow-card)}
.stat .n{font-family:var(--f-display);font-size:30px;font-weight:700}
.stat .l{color:var(--c-text-3);font-size:13px;margin-top:2px}
.stat .ic{width:38px;height:38px;border-radius:10px;display:grid;place-items:center;background:var(--c-navy);color:var(--c-gold);margin-bottom:14px}
.panel{background:var(--c-surface);border:1px solid var(--c-border-soft);border-radius:var(--r-lg);box-shadow:var(--shadow-card);overflow:hidden;margin-bottom:24px}
.panel-head{display:flex;align-items:center;justify-content:space-between;padding:18px 22px;border-bottom:1px solid var(--c-border-soft)}
.panel-head h3{font-size:17px}
table{width:100%;border-collapse:collapse}
th{text-align:left;font-size:12px;text-transform:uppercase;letter-spacing:.03em;color:var(--c-text-3);font-weight:600;padding:12px 22px;background:var(--c-surface-2)}
td{padding:14px 22px;border-top:1px solid var(--c-border-soft);font-size:14px;vertical-align:middle}
tr:hover td{background:var(--c-surface-2)}
.minicover{width:34px;height:46px;border-radius:5px;flex-shrink:0}
.tcell{display:flex;align-items:center;gap:12px}
.field{margin-bottom:16px}
.field label{display:block;font-size:13px;font-weight:600;color:var(--c-text-2);margin-bottom:6px}
.field input,.field select{width:100%;padding:11px 14px;border:1px solid var(--c-border);border-radius:var(--r-md);background:var(--c-surface-2)}
.field input:focus,.field select:focus{outline:none;border-color:var(--c-gold);background:#fff;box-shadow:0 0 0 3px rgba(212,162,76,.15)}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.drop{border:2px dashed var(--c-border);border-radius:var(--r-md);padding:26px;text-align:center;color:var(--c-text-3);cursor:pointer;transition:.15s;background:var(--c-surface-2)}
.drop:hover{border-color:var(--c-gold);color:var(--c-text-2)}
.drop b{color:var(--c-navy)}

/* modal */
.modal-overlay{position:fixed;inset:0;background:rgba(11,37,64,.55);z-index:120;display:flex;align-items:center;justify-content:center;padding:16px}
.modal{background:var(--c-surface);border-radius:var(--r-xl);width:100%;max-width:520px;box-shadow:var(--shadow-lg);max-height:90vh;overflow:auto}
.modal-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid var(--c-border-soft)}
.modal-header h3{font-size:18px}.modal-body{padding:24px}
.modal-footer{padding:16px 24px;border-top:1px solid var(--c-border-soft);display:flex;justify-content:flex-end;gap:10px}

/* reader */
.reader{position:fixed;inset:0;background:var(--c-navy);z-index:150;display:flex;flex-direction:column;user-select:none;-webkit-user-select:none}
.reader-bar{height:58px;background:var(--c-navy-2);border-bottom:1px solid rgba(255,255,255,.08);display:flex;align-items:center;justify-content:space-between;padding:0 18px;color:#fff;flex-shrink:0}
.reader-bar .t{font-family:var(--f-display);font-weight:600;font-size:15px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.reader-bar .l{display:flex;align-items:center;gap:12px;min-width:0}
.icon-btn{width:34px;height:34px;display:grid;place-items:center;border-radius:var(--r-md);color:rgba(255,255,255,.65);transition:.15s}
.icon-btn:hover{background:rgba(255,255,255,.1);color:#fff}
.lock-pill{display:inline-flex;align-items:center;gap:6px;font-size:12px;color:var(--c-gold);border:1px solid rgba(212,162,76,.35);padding:5px 10px;border-radius:var(--r-full)}
.reader-stage{flex:1;overflow:auto;display:flex;flex-direction:column;align-items:center;padding:28px 16px}
.page-sheet{width:min(760px,100%);background:#fff;color:#1a1a1a;border-radius:6px;box-shadow:0 10px 40px rgba(0,0,0,.4);margin-bottom:24px;position:relative;overflow:visible}
.page-sheet.text{padding:54px 60px;font-size:15.5px;line-height:1.75;min-height:560px;overflow:hidden}
.page-sheet.text h2{font-family:var(--f-display);color:var(--c-navy);margin-bottom:18px;font-size:24px}
.page-sheet.text p{margin-bottom:16px;color:#2b2b2b}
.page-sheet canvas{display:block;width:100%;height:auto;border-radius:6px}
.watermark{position:absolute;inset:0;pointer-events:none;overflow:hidden;opacity:.13;display:flex;flex-wrap:wrap;align-content:center;justify-content:center;gap:46px 30px;transform:rotate(-28deg) scale(1.5);z-index:5}
.watermark .wm-cell{font-size:11px;font-weight:600;color:var(--c-navy);white-space:nowrap;text-align:center;line-height:1.35}
.trace-foot{position:absolute;left:0;right:0;bottom:0;z-index:6;background:rgba(11,37,64,.92);color:#fff;font-size:11px;letter-spacing:.02em;padding:6px 14px;display:flex;align-items:center;justify-content:center;gap:8px}
.trace-foot svg{flex-shrink:0}
.trace-foot b{color:var(--c-gold)}
.reader-foot{height:54px;background:var(--c-navy-2);border-top:1px solid rgba(255,255,255,.08);display:flex;align-items:center;justify-content:center;gap:18px;color:#fff;flex-shrink:0}
.reader-foot button{color:#fff;font-weight:600;font-size:14px;padding:8px 14px;border-radius:var(--r-md)}
.reader-foot button:hover{background:rgba(255,255,255,.1)}
.reader-foot .pageno{font-size:13px;color:rgba(255,255,255,.7);min-width:90px;text-align:center}
.blur-shield{position:fixed;inset:0;background:var(--c-navy);z-index:200;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;color:#fff;text-align:center;padding:20px}
.blur-shield svg{color:var(--c-gold)}
.blur-shield .h{font-family:var(--f-display);font-weight:600;font-size:18px}
.blur-shield .s{color:rgba(255,255,255,.6);font-size:14px;max-width:340px}

.toast{position:fixed;bottom:24px;left:50%;transform:translateX(-50%);background:var(--c-navy);color:#fff;padding:12px 20px;border-radius:var(--r-md);font-size:14px;box-shadow:var(--shadow-lg);z-index:300;opacity:0;transition:.25s;pointer-events:none}
.toast.show{opacity:1;transform:translateX(-50%) translateY(-4px)}
.empty{text-align:center;color:var(--c-text-3);padding:40px}
@media(max-width:860px){.app-screen{grid-template-columns:1fr}.sidebar{display:none}.pricing{grid-template-columns:1fr}.grid-2{grid-template-columns:1fr}.page-sheet.text{padding:32px 24px}}

/* ===== Ajouts GSIMEL Cyber Library : indicateurs des 5 priorités ===== */
.quota-bar{display:flex;align-items:center;gap:18px;flex-wrap:wrap;background:var(--c-surface);border:1px solid var(--c-border-soft);border-radius:var(--r-lg);padding:14px 18px;margin-bottom:22px;box-shadow:var(--shadow-card)}
.quota-item{display:flex;align-items:center;gap:9px;font-size:13px;color:var(--c-text-2)}
.quota-item svg{color:var(--c-gold)}
.quota-item b{color:var(--c-text)}
.quota-sep{width:1px;height:24px;background:var(--c-border)}
.mini-prog{width:90px;height:6px;background:var(--c-border);border-radius:var(--r-full);overflow:hidden}
.mini-prog span{display:block;height:100%;background:var(--c-gold)}
.anomaly{background:var(--c-danger-bg);color:#7F1D1D;border-radius:var(--r-lg);padding:14px 18px;margin-bottom:22px;display:flex;gap:12px;align-items:center;font-size:14px}
.anomaly svg{flex-shrink:0;color:var(--c-danger)}
.book.locked{opacity:.55}
.book .lock-badge{position:absolute;top:10px;right:10px;background:rgba(11,37,64,.85);color:#fff;font-size:11px;font-weight:600;padding:3px 9px;border-radius:var(--r-full);display:inline-flex;gap:4px;align-items:center;z-index:2}
.ver-badge{display:inline-block;background:var(--c-info-bg);color:var(--c-info);font-size:10.5px;font-weight:700;padding:1px 6px;border-radius:var(--r-sm);margin-left:6px}
.new-badge{position:absolute;top:10px;left:10px;background:var(--c-gold);color:var(--c-navy);font-size:10.5px;font-weight:700;padding:2px 8px;border-radius:var(--r-full);z-index:2}
.tier-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.tier-card{background:var(--c-surface);border:1.5px solid var(--c-border);border-radius:var(--r-lg);padding:22px 18px;display:flex;flex-direction:column;position:relative}
.tier-card.cur{border-color:var(--c-gold);box-shadow:0 0 0 4px rgba(212,162,76,.12)}
.tier-card h3{font-size:17px}.tier-card .lvl{font-size:11px;font-weight:700;color:var(--c-gold);text-transform:uppercase;letter-spacing:.05em}
.tier-card .pm{font-family:var(--f-display);font-size:26px;font-weight:700;margin:10px 0 0}
.tier-card .py{color:var(--c-text-3);font-size:12.5px;margin-bottom:14px}
.tier-card ul{list-style:none;display:flex;flex-direction:column;gap:7px;font-size:12.5px;color:var(--c-text-2);margin-bottom:16px;flex:1}
.living{background:linear-gradient(160deg,var(--c-navy),var(--c-navy-soft));color:#fff;border-radius:var(--r-lg);padding:22px 24px;margin-bottom:24px}
.living h3{color:#fff;font-size:17px;margin-bottom:6px}
.living p{color:rgba(255,255,255,.72);font-size:13.5px;margin-bottom:14px}
.living-tags{display:flex;flex-wrap:wrap;gap:8px}
.living-tags span{background:rgba(255,255,255,.1);border:1px solid rgba(212,162,76,.3);color:var(--c-gold-light);font-size:12px;padding:5px 11px;border-radius:var(--r-full)}
@media(max-width:860px){.tier-grid{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.tier-grid{grid-template-columns:1fr}}

/* ===== Quiz / examens / CTF / hors ligne ===== */
.card-list{display:flex;flex-direction:column;gap:12px}
.row-card{display:flex;align-items:center;gap:14px;background:var(--c-surface);border:1px solid var(--c-border-soft);border-radius:var(--r-lg);padding:14px 18px;box-shadow:var(--shadow-card)}
.row-card.locked{opacity:.6}
.row-ic{width:42px;height:42px;border-radius:10px;display:grid;place-items:center;background:var(--c-surface-2);border:1px solid var(--c-border);font-size:20px;flex-shrink:0}
.row-ic.gold{background:var(--c-navy);border-color:var(--c-navy)}
.row-main{flex:1;min-width:0}
.row-title{font-weight:600;font-size:14.5px}
.row-sub{color:var(--c-text-3);font-size:12.5px;margin-top:2px}
.ctf-hero{background:linear-gradient(150deg,var(--c-navy),var(--c-navy-soft));color:#fff;border-radius:var(--r-xl);padding:30px 28px;position:relative;overflow:hidden}
.ctf-hero::after{content:"";position:absolute;right:-50px;top:-50px;width:200px;height:200px;border-radius:50%;background:radial-gradient(circle,rgba(212,162,76,.3),transparent 70%)}
.ctf-hero h1{font-size:28px;margin:8px 0;position:relative}
.ctf-hero p{color:rgba(255,255,255,.8);position:relative}
.ctf-badge{display:inline-block;background:var(--c-gold);color:var(--c-navy);font-size:12px;font-weight:700;padding:4px 12px;border-radius:var(--r-full);position:relative}
.ctf-score{margin-top:14px;font-size:15px;position:relative}
.ctf-score b{color:var(--c-gold-light);font-size:20px}

/* ===== Auth screen ===== */
.auth-error{background:var(--c-danger-bg);color:#7F1D1D;border-radius:var(--r-md);padding:10px 14px;font-size:13px;margin-bottom:14px}
.auth-switch{margin-top:18px;font-size:13.5px;color:var(--c-text-2);text-align:center}
.auth-switch a{color:var(--c-gold-dark);font-weight:600;text-decoration:none;margin-left:6px}
.auth-switch a:hover{text-decoration:underline}

/* ===== Ecran de connexion (login) ===== */
.auth-screen{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--c-navy) 0%,var(--c-navy-3) 100%);position:relative;overflow:hidden;padding:16px}
.auth-bg-grid{position:absolute;inset:0;background-image:radial-gradient(circle at 20% 30%,rgba(212,162,76,.15),transparent 50%),radial-gradient(circle at 80% 70%,rgba(212,162,76,.08),transparent 40%);pointer-events:none}
.auth-wrap{position:relative;display:grid;grid-template-columns:1fr 1fr;max-width:980px;width:100%;background:var(--c-surface);border-radius:var(--r-xl);box-shadow:var(--shadow-lg);overflow:hidden}
.auth-card{padding:44px 38px;display:flex;flex-direction:column}
.auth-card .brand{display:flex;align-items:center;gap:12px;margin-bottom:30px}
.auth-title{font-size:25px;margin-bottom:6px}
.auth-sub{color:var(--c-text-2);font-size:14px;margin-bottom:24px}
.auth-side{background:linear-gradient(160deg,var(--c-navy) 0%,var(--c-navy-soft) 100%);color:#fff;padding:44px 38px;display:flex;align-items:center;position:relative;overflow:hidden}
.auth-side::after{content:"";position:absolute;right:-60px;bottom:-60px;width:220px;height:220px;border-radius:50%;background:radial-gradient(circle,rgba(212,162,76,.25),transparent 70%)}
.auth-side-tag{display:inline-block;font-size:12px;font-weight:600;color:var(--c-gold);border:1px solid rgba(212,162,76,.4);padding:5px 12px;border-radius:var(--r-full);margin-bottom:18px}
.auth-side h2{font-size:27px;margin-bottom:12px;line-height:1.12}
.auth-side p{color:rgba(255,255,255,.7);font-size:14px;margin-bottom:22px}
.auth-features{list-style:none;display:flex;flex-direction:column;gap:11px}
.auth-features li{display:flex;align-items:center;gap:10px;font-size:14px;color:rgba(255,255,255,.92)}
.dot{width:7px;height:7px;border-radius:50%;background:var(--c-gold);flex-shrink:0}
@media(max-width:820px){.auth-wrap{grid-template-columns:1fr}.auth-side{display:none}}

/* badge de notification sur la nav (paiements en attente) */
.nav-badge{margin-left:auto;background:#DC2626;color:#fff;font-size:11px;font-weight:700;min-width:20px;height:20px;border-radius:10px;display:inline-flex;align-items:center;justify-content:center;padding:0 6px}

/* Bloc contact GSIMEL (page Mon compte) */
.contact-cta{margin-top:18px;background:linear-gradient(150deg,var(--c-navy),var(--c-navy-soft));color:#fff;border-radius:var(--r-lg);padding:26px 22px;text-align:center;box-shadow:var(--shadow-card)}
.contact-cta .cta-label{font-size:13px;letter-spacing:.04em;text-transform:uppercase;color:var(--c-gold);font-weight:600;margin-bottom:8px}
.contact-cta .cta-num{display:inline-block;font-family:var(--f-display);font-weight:700;font-size:30px;color:#fff;text-decoration:none;margin-bottom:14px}
.contact-cta .cta-num:hover{color:var(--c-gold)}
.contact-cta .cta-actions{display:flex;gap:10px;justify-content:center;flex-wrap:wrap}
.contact-cta .cta-sub{margin-top:12px;font-size:13px;color:rgba(255,255,255,.7)}

/* Avertissement legal (page abonnement) */
.legal-warn{background:#FEF3C7;border:1px solid #F0C66B;color:#7A4F09;border-radius:var(--r-md);padding:14px 18px;font-size:13.5px;line-height:1.55;margin-bottom:8px}
