
@import url('https://fonts.googleapis.com/css2?family=Rajdhani:wght@400;500;600;700&family=Share+Tech+Mono&display=swap');

*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}
:root{
  --gold:#C9960A;--gold2:#E8B930;--gold3:#F5D060;
  --dark:#F5F7FA;--dark2:#102E50;--dark3:#1A3F66;--dark4:#1E4A75;
  --border:#2A5A8A;--text:#FFFFFF;--muted:#B0C4D8;
  --green:#2CB67D;--amber:#E8A020;--red:#E85555;--blue:#3A8EE8;--purple:#A855F7;
  --r:12px;--font:'Rajdhani',sans-serif;--mono:'Share Tech Mono',monospace;
  --sidebar-width:250px;--card-shadow:0 2px 8px rgba(0,0,0,.08);
}
html{font-size:15px;scroll-behavior:smooth}
body{background:var(--dark);color:var(--text);font-family:var(--font);min-height:100vh;overflow-x:hidden}
a{color:inherit;text-decoration:none}
button{cursor:pointer;font-family:var(--font)}

/* ── Layout ── */
#app{display:flex;flex-direction:column;min-height:100vh}
.screen{display:none;flex:1;flex-direction:column;animation:fadeIn .2s ease}
.screen.active{display:flex}
@keyframes fadeIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}

/* ── Auth screen ── */
#screen-login{align-items:center;justify-content:center;padding:24px;background:radial-gradient(ellipse at 50% 0%,#4A4A4A 0%,var(--dark) 60%)}
.login-card{width:100%;max-width:420px;background:var(--dark2);border:1px solid var(--border);border-top:2px solid var(--gold);border-radius:var(--r);padding:32px;box-shadow:var(--card-shadow)}
.login-logo{text-align:center;margin-bottom:28px}
.login-logo .icon{font-size:40px;margin-bottom:8px}
.login-logo h1{font-size:26px;font-weight:700;color:var(--gold2);letter-spacing:.5px}
.login-logo p{font-size:12px;color:var(--muted);margin-top:4px}
.form-group{margin-bottom:16px}
.form-group label{display:block;font-size:11px;text-transform:uppercase;letter-spacing:.5px;color:var(--muted);margin-bottom:6px}
.form-group input,.form-group select,.form-group textarea{width:100%;background:var(--dark3);border:1px solid var(--border);border-radius:8px;padding:11px 14px;color:var(--text);font-family:var(--font);font-size:14px;outline:none;transition:border-color .2s;-webkit-appearance:none}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--gold)}
.form-group textarea{resize:vertical;min-height:72px}
.form-group select option{background:var(--dark3)}
.btn{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:12px 20px;border:none;border-radius:8px;font-family:var(--font);font-size:15px;font-weight:600;letter-spacing:.3px;transition:opacity .15s,transform .1s}
.btn:active{transform:scale(.97)}
.btn-gold{background:linear-gradient(135deg,var(--gold),var(--gold2));color:#000}
.btn-gold:hover{opacity:.9}
.btn-outline{background:transparent;border:1px solid var(--border);color:var(--text)}
.btn-outline:hover{background:var(--dark3)}
.btn-danger{background:#FEF2F2;border:1px solid var(--red);color:var(--red)}
.btn-success{background:#ECFDF5;border:1px solid var(--green);color:var(--green)}
.btn-sm{padding:8px 14px;font-size:13px;width:auto}
.btn-icon{width:36px;height:36px;padding:0;border-radius:8px}
.login-err{display:none;background:#FEF2F2;border:1px solid var(--red);border-radius:8px;padding:10px 14px;font-size:13px;color:var(--red);margin-bottom:14px}

/* ── Top nav ── */
.topnav{background:var(--dark2);border-bottom:1px solid var(--border);padding:0 16px;height:56px;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:200}
.topnav-brand{display:flex;align-items:center;gap:10px}
.topnav-brand .icon{width:44px;height:44px;background:transparent;border-radius:7px;display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0;overflow:hidden}
.topnav-brand .icon img{width:100%;height:100%;object-fit:cover;border-radius:7px}
.topnav-brand h1{font-size:18px;font-weight:700;color:#FFFFFF}
.topnav-brand .company-sub{font-size:11px;color:var(--muted);line-height:1}
.topnav-right{display:flex;align-items:center;gap:8px}
.user-chip{background:var(--dark3);border:1px solid var(--border);border-radius:20px;padding:5px 12px 5px 8px;display:flex;align-items:center;gap:7px;font-size:12px}
.user-avatar{width:22px;height:22px;border-radius:50%;background:rgba(255,255,255,.2);color:#fff;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;flex-shrink:0}

/* ── Role badge ── */
.role-badge{display:inline-flex;align-items:center;font-size:9px;padding:2px 7px;border-radius:10px;font-weight:700;text-transform:uppercase;letter-spacing:.5px}
.role-badge.super_admin{background:#2A0A3A;color:var(--purple);border:1px solid #5A1A7A}
.role-badge.admin{background:#1A1505;color:var(--amber);border:1px solid #3A3010}
.role-badge.adjoint{background:#1A0F00;color:#F97316;border:1px solid #7C3900}
.role-badge.superviseur{background:#050F1A;color:var(--blue);border:1px solid #0E2040}
.role-badge.operateur{background:#0A1A0E;color:var(--green);border:1px solid #1A4A2A}
.role-badge.agent_bssm{background:#2A1A08;color:#CD7F32;border:1px solid #6B4010}
.role-badge.admin_bssm{background:#1F1206;color:#E8A84C;border:1px solid #8B5A2B}

/* ── Bottom nav ── */
.bottomnav{background:var(--dark2);border-top:1px solid var(--border);display:flex;position:sticky;bottom:0;z-index:100}
.bn-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:10px 4px 8px;gap:3px;cursor:pointer;color:var(--muted);font-size:10px;letter-spacing:.3px;transition:color .2s;border:none;background:none}
.bn-item .icon{font-size:20px;line-height:1}
.bn-item.active{color:#FFFFFF}
.bn-item.active .icon{filter:drop-shadow(0 0 4px rgba(255,255,255,.5))}

/* ── Sidebar ── */
.sidenav{display:none;flex-direction:column;width:var(--sidebar-width);background:var(--dark2);border-right:1px solid var(--border);position:fixed;top:56px;left:0;bottom:0;overflow-y:auto;z-index:150;padding:16px 0;transition:transform .25s ease}
.sidenav.open{display:flex}
#nav-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.6);z-index:140;backdrop-filter:blur(2px)}
#nav-overlay.show{display:block}
#btn-hamburger{display:flex}
.sidenav-item{display:flex;align-items:center;gap:12px;padding:12px 20px 12px 16px;cursor:pointer;color:var(--muted);font-size:15px;font-weight:500;letter-spacing:.3px;line-height:1.5;min-height:45px;border:none;background:none;width:100%;transition:color .2s,background .2s;border-left:3px solid transparent}
.sidenav-item:hover{background:var(--dark3);color:var(--text)}
.sidenav-item.active{background:rgba(255,255,255,.12);color:#F5A623!important;border-left-color:#F5A623;font-weight:700}
.sidenav-item .sn-icon{font-size:20px;width:24px;text-align:center;flex-shrink:0}
.sidenav-item .sn-label{flex:1}
.sidenav-sep{height:1px;background:var(--border);margin:10px 16px}

/* ── Main layout with sidebar ── */
.main-with-sidebar{margin-left:0;transition:margin-left .3s}

@media(min-width:1024px){
  .sidenav{display:flex!important}
  .main-with-sidebar{margin-left:var(--sidebar-width)}
  .bottomnav{display:none!important}
  #btn-hamburger{display:none!important}
  #nav-overlay{display:none!important}
}

/* ── Scrollable content ── */
.scroll-content{flex:1;overflow-y:auto;padding:16px;-webkit-overflow-scrolling:touch}

/* ── Dashboard ── */
.stats-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:20px}
.stat-card{background:var(--dark2);border:1px solid var(--border);border-radius:14px;padding:16px;text-align:center;box-shadow:var(--card-shadow);position:relative;overflow:hidden}
.stat-card::before{content:"";position:absolute;top:0;left:0;right:0;height:3px}
.stat-card.gold::before{background:linear-gradient(90deg,var(--gold),var(--gold2))}
.stat-card.amber::before{background:linear-gradient(90deg,var(--amber),#F5A028)}
.stat-card.blue::before{background:linear-gradient(90deg,var(--blue),#60AFFF)}
.stat-card.green::before{background:linear-gradient(90deg,var(--green),#4ADFAD)}
.stat-card.purple::before{background:linear-gradient(90deg,var(--purple),#CC80FF)}
.stat-card.red::before{background:linear-gradient(90deg,var(--red),#FF8080)}
.stat-card .val{font-size:28px;font-weight:700;font-family:var(--mono);color:#F5A623;margin-top:4px}
.stat-card .lbl{font-size:11px;color:#B0C4D8;margin-top:3px;text-transform:uppercase;letter-spacing:.5px}
.section-title{font-size:12px;text-transform:uppercase;letter-spacing:1px;color:#B0C4D8;font-weight:700;margin-bottom:10px;display:flex;align-items:center;gap:6px}

/* ── Admin section ── */
.admin-section{background:var(--dark2);border:1px solid var(--border);border-radius:14px;padding:20px;margin-bottom:20px;box-shadow:var(--card-shadow)}
.admin-section-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}
.admin-section-head h2{font-size:16px;font-weight:600;color:#F5A623}

/* ── Company card ── */
.company-card{background:var(--dark3);border:1px solid var(--border);border-radius:12px;padding:16px;margin-bottom:10px;cursor:pointer;transition:border-color .2s,transform .15s;display:flex;align-items:center;gap:14px;box-shadow:var(--card-shadow)}
.company-card:hover{border-color:var(--gold);transform:translateY(-1px)}
.company-logo{width:48px;height:48px;border-radius:10px;background:linear-gradient(135deg,var(--gold),var(--gold3));display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0;overflow:hidden;border:1px solid var(--border)}
.company-logo img{width:100%;height:100%;object-fit:cover}
.company-info{flex:1;min-width:0}
.company-name{font-size:15px;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.company-code{font-size:11px;font-family:var(--mono);color:var(--gold2);margin-top:2px}
.company-stats{font-size:11px;color:var(--muted);margin-top:4px}
.company-active{display:inline-block;width:8px;height:8px;border-radius:50%;background:var(--green);margin-left:6px;vertical-align:middle}
.company-inactive{background:var(--red)}

/* ── User card ── */
.user-card{background:var(--dark3);border:1px solid var(--border);border-radius:12px;padding:14px 16px;margin-bottom:8px;display:flex;align-items:center;gap:12px;box-shadow:var(--card-shadow)}
.user-card-avatar{width:40px;height:40px;border-radius:50%;background:var(--dark4);display:flex;align-items:center;justify-content:center;font-size:16px;font-weight:700;color:var(--gold2);flex-shrink:0;border:1px solid var(--border)}
.user-card-info{flex:1;min-width:0}
.user-card-name{font-size:14px;font-weight:600;color:var(--text)}
.user-card-email{font-size:11px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.user-card-meta{display:flex;gap:6px;margin-top:4px;flex-wrap:wrap;align-items:center}
.user-card-actions{display:flex;gap:6px;flex-shrink:0}

/* ── Pipeline steps ── */
.pipeline{display:flex;gap:6px;overflow-x:auto;padding-bottom:4px;margin-bottom:20px;scrollbar-width:none}
.pipeline::-webkit-scrollbar{display:none}
.pip-step{flex:0 0 90px;background:var(--dark2);border:1px solid var(--border);border-radius:10px;padding:10px 8px;text-align:center;cursor:pointer;transition:border-color .2s,background .2s,transform .15s}
.pip-step:hover{transform:translateY(-1px)}
.pip-step.active{border-color:var(--gold);background:var(--dark3);box-shadow:0 0 12px rgba(201,150,10,.15)}
.pip-step.done{border-color:var(--green);background:#ECFDF5}
.pip-step .pip-icon{font-size:20px;margin-bottom:4px}
.pip-step .pip-name{font-size:11px;font-weight:600}
.pip-step.done .pip-name{color:var(--green)}
.pip-step.active .pip-name{color:var(--gold2)}

/* ── Operation form ── */
.form-card{background:var(--dark2);border:1px solid var(--border);border-radius:14px;overflow:hidden;margin-bottom:16px;box-shadow:var(--card-shadow)}
.form-card-head{padding:12px 16px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:10px}
.form-card-head h3{font-size:15px;font-weight:600;color:var(--gold2)}
.step-badge{background:var(--gold);color:#000;font-size:10px;font-weight:700;padding:3px 8px;border-radius:12px}
.form-card-body{padding:16px}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:10px}

/* ── GPS widget ── */
.gps-widget{display:flex;align-items:center;gap:10px;background:var(--dark3);border:1px solid var(--border);border-radius:8px;padding:10px 14px;margin-bottom:14px}
.gps-dot{width:10px;height:10px;border-radius:50%;background:var(--green);flex-shrink:0;animation:gpsPulse 1.5s ease-in-out infinite}
@keyframes gpsPulse{0%,100%{box-shadow:0 0 0 0 rgba(44,182,125,.4)}50%{box-shadow:0 0 0 6px rgba(44,182,125,0)}}
.gps-text{flex:1;font-size:12px;font-family:var(--mono);color:var(--green);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.gps-dot.acquiring{background:var(--amber);animation:gpsPulse2 1s ease-in-out infinite}
@keyframes gpsPulse2{0%,100%{opacity:1}50%{opacity:.4}}
.gps-acc{font-size:10px;color:var(--muted);margin-top:2px}

/* ── Photo upload ── */
.photo-upload-zone{border:2px dashed var(--border);border-radius:10px;padding:20px;text-align:center;cursor:pointer;transition:all .2s;background:var(--dark3)}
.photo-upload-zone:hover,.photo-upload-zone.dragover{border-color:var(--gold);background:var(--dark4)}
.photo-upload-zone .up-icon{font-size:28px;margin-bottom:8px}
.photo-upload-zone p{font-size:12px;color:var(--muted)}
.photos-preview{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-top:12px}
.photo-preview-item{position:relative;aspect-ratio:1;border-radius:8px;overflow:hidden;border:1px solid var(--border)}
.photo-preview-item img{width:100%;height:100%;object-fit:cover}
.photo-remove{position:absolute;top:4px;right:4px;background:rgba(0,0,0,.7);border:none;color:white;width:22px;height:22px;border-radius:50%;font-size:12px;display:flex;align-items:center;justify-content:center;cursor:pointer}

/* ── Cards / Lists ── */
.lot-card{background:var(--dark2);border:1px solid var(--border);border-radius:14px;padding:14px 16px;margin-bottom:10px;cursor:pointer;transition:border-color .2s,transform .15s;box-shadow:var(--card-shadow)}
.lot-card:hover{border-color:var(--gold);transform:translateY(-1px)}
.lot-card-head{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:8px}
.lot-number{font-size:13px;font-weight:700;font-family:var(--mono);color:var(--gold2)}
.badge{display:inline-flex;align-items:center;font-size:10px;padding:3px 8px;border-radius:12px;font-weight:600}
.badge-green{background:#D6F5E8;color:#1A7A45;border:1px solid #A0DFC0}
.badge-amber{background:#FEF3D8;color:#8B5E00;border:1px solid #F5D080}
.badge-blue{background:#DDE8FF;color:#1A3A9A;border:1px solid #A8C0F0}
.badge-red{background:#FFE0E0;color:#9A1A1A;border:1px solid #F5A8A8}
.badge-purple{background:#F0E0FF;color:#6A1AAA;border:1px solid #D0A8F5}
.lot-meta{font-size:12px;color:var(--muted);line-height:1.7}
.lot-meta span{color:var(--text)}

/* ── Timeline ── */
.timeline{position:relative;padding-left:28px}
.timeline::before{content:"";position:absolute;left:10px;top:0;bottom:0;width:1px;background:var(--border)}
.tl-item{position:relative;margin-bottom:16px}
.tl-item::before{content:"";position:absolute;left:-22px;top:14px;width:12px;height:12px;border-radius:50%;border:2px solid var(--border);background:var(--dark)}
.tl-item.done::before{background:var(--green);border-color:var(--green)}
.tl-item.active::before{background:var(--gold);border-color:var(--gold);box-shadow:0 0 8px var(--gold)}
.tl-card{background:var(--dark3);border:1px solid var(--border);border-radius:10px;padding:12px 14px}
.tl-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px}
.tl-title{font-size:13px;font-weight:600}
.tl-time{font-size:10px;font-family:var(--mono);color:var(--muted)}
.tl-meta{font-size:12px;color:var(--muted);line-height:1.6}
.tl-meta span{color:var(--text)}
.tl-geo{font-size:10px;font-family:var(--mono);color:var(--blue);margin-top:4px}
.tl-photos{display:flex;gap:6px;margin-top:8px;flex-wrap:wrap}
.tl-photo{width:48px;height:48px;border-radius:6px;object-fit:cover;border:1px solid var(--border);cursor:pointer}

/* ── Map ── */
#map{width:100%;height:300px;border-radius:var(--r);border:1px solid var(--border);overflow:hidden;background:var(--dark2)}

/* ── Alerts / Notifications ── */
.alert{display:flex;align-items:center;gap:10px;padding:12px 14px;border-radius:10px;font-size:13px;margin-bottom:12px}
.alert-info{background:#EBF4FF;border:1px solid var(--blue);color:#1A3A9A}
.alert-warn{background:#FFFBEB;border:1px solid var(--amber);color:#8B5E00}
.alert-ok{background:#ECFDF5;border:1px solid var(--green);color:#1A7A45}
.alert-err{background:#FEF2F2;border:1px solid var(--red);color:#9A1A1A}

/* ── Toast ── */
#toast{position:fixed;top:16px;left:50%;transform:translateX(-50%) translateY(-80px);background:var(--dark2);border:1px solid var(--border);border-radius:10px;padding:12px 20px;font-size:13px;z-index:9999;transition:transform .3s ease;white-space:nowrap;box-shadow:0 8px 32px rgba(0,0,0,.4);min-width:240px;text-align:center}
#toast.show{transform:translateX(-50%) translateY(0)}
#toast.success{border-color:var(--green);color:var(--green)}
#toast.error{border-color:var(--red);color:var(--red)}
#toast.warning{border-color:var(--amber);color:var(--amber)}

/* ── Loading ── */
.spinner{width:20px;height:20px;border:2px solid var(--border);border-top-color:var(--gold);border-radius:50%;animation:spin .6s linear infinite;flex-shrink:0}
@keyframes spin{to{transform:rotate(360deg)}}
.loading-overlay{position:fixed;inset:0;background:rgba(0,10,20,.55);display:flex;align-items:center;justify-content:center;z-index:9998;backdrop-filter:blur(2px)}
.loading-box{background:var(--dark2);border:1px solid var(--border);border-radius:var(--r);padding:24px 32px;text-align:center;display:flex;flex-direction:column;align-items:center;gap:12px}
.loading-box .spinner{width:32px;height:32px}

/* ── Modal ── */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.7);z-index:500;display:flex;align-items:flex-end;justify-content:center;backdrop-filter:blur(2px)}
.modal{background:var(--dark2);border:1px solid var(--border);border-radius:var(--r) var(--r) 0 0;width:100%;max-width:600px;max-height:92vh;overflow-y:auto;animation:slideUp .3s ease}
@keyframes slideUp{from{transform:translateY(100%)}to{transform:none}}
.modal-head{padding:16px 20px;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:center;position:sticky;top:0;background:var(--dark2);z-index:1}
.modal-head h3{font-size:16px;font-weight:600;color:var(--gold2)}
.modal-body{padding:20px}
.modal-close{background:none;border:none;color:var(--muted);font-size:20px;cursor:pointer;line-height:1;padding:4px}
.modal-footer{padding:16px 20px;border-top:1px solid var(--border);display:flex;gap:10px}

/* ── Audit log (legacy row style — kept for compatibility) ── */
.audit-row{display:flex;gap:10px;padding:10px 0;border-bottom:1px solid var(--border);font-size:12px;align-items:flex-start}
.audit-row:last-child{border-bottom:none}
.audit-meta{flex:1;color:var(--muted);line-height:1.5}
.audit-time{flex-shrink:0;font-size:10px;font-family:var(--mono);color:var(--muted)}

/* ── Empty state ── */
.empty-state{text-align:center;padding:40px 20px;color:var(--muted)}
.empty-state .empty-icon{font-size:40px;margin-bottom:12px;opacity:.5}
.empty-state p{font-size:13px}

/* ── Responsive ── */
@media(max-width:639px){
  /* Topnav compact : cache le nom, garde avatar + badge */
  #user-name{display:none}
  .user-chip{padding:5px 8px}
  .topnav-brand h1{font-size:15px}
  /* grid2 en 1 colonne sur très petits écrans */
  .grid2{grid-template-columns:1fr}
  /* Company/user cards : boutons sous les infos si trop étroit */
  .company-card{flex-wrap:wrap}
  .user-card{flex-wrap:wrap}
  .user-card-actions{margin-left:52px}
}

@media(min-width:640px){
  .grid2{grid-template-columns:1fr 1fr}
}

@media(min-width:768px){
  .stats-grid{grid-template-columns:repeat(4,1fr)}
  .scroll-content{padding:24px;max-width:960px;margin:0 auto;width:100%}
  .modal{border-radius:var(--r);max-height:85vh;align-self:center}
  .modal-overlay{align-items:center}
}

@media(min-width:1024px){
  .scroll-content{padding:28px;max-width:none}
}

/* ── Rapports ── */
.report-preview-table{width:100%;border-collapse:collapse;font-size:12px}
.report-preview-table th{background:var(--dark3);color:var(--muted);padding:6px 10px;text-align:left;border-bottom:1px solid var(--border)}
.report-preview-table td{padding:6px 10px;border-bottom:1px solid var(--border);color:var(--text)}
.alert-err{background:#FFE8E8;border:1px solid var(--red);border-radius:8px;padding:10px 14px;font-size:13px;color:#9A1A1A;margin-bottom:10px}

/* ── Audit table ── */
.audit-table{width:100%;border-collapse:collapse;font-size:12px;min-width:600px}
.audit-table th{background:var(--dark3);color:var(--muted);padding:8px 10px;text-align:left;border-bottom:1px solid var(--border);font-size:11px;white-space:nowrap}
.audit-table td{padding:8px 10px;border-bottom:1px solid var(--border);vertical-align:middle}
.audit-table tr:hover td{background:var(--dark2)}
.audit-action{display:inline-block;padding:2px 8px;border-radius:4px;font-size:11px;font-weight:500;white-space:nowrap}
.audit-action-create{background:rgba(34,197,94,.15);color:#22C55E}
.audit-action-update{background:rgba(59,130,246,.15);color:#60A5FA}
.audit-action-delete{background:rgba(239,68,68,.15);color:#EF4444}
.audit-action-login{background:rgba(201,150,10,.15);color:var(--gold)}
.audit-action-other{background:var(--dark3);color:var(--muted)}

/* ── Fiche identifiants ── */
.cred-card{border:2px solid var(--gold);border-radius:var(--r);overflow:hidden;margin-bottom:4px}
.cred-header{background:linear-gradient(135deg,var(--dark3),var(--dark4));padding:16px 20px}
.cred-company{font-size:18px;font-weight:700;color:var(--gold2)}
.cred-app{font-size:11px;color:var(--muted);margin-top:2px}
.cred-body{padding:16px 20px;background:var(--dark2)}
.cred-row{display:flex;justify-content:space-between;align-items:center;padding:7px 0;border-bottom:1px solid var(--border);font-size:13px}
.cred-row:last-child{border-bottom:none}
.cred-lbl{color:var(--muted);font-size:11px;text-transform:uppercase;letter-spacing:.5px;flex-shrink:0;margin-right:12px}
.cred-val{font-weight:600;text-align:right;word-break:break-all}
.cred-mono{font-family:var(--mono);letter-spacing:.5px;font-size:12px}
.cred-highlight{background:rgba(201,150,10,.15);border:1px solid var(--gold);padding:3px 10px;border-radius:6px;color:var(--gold2)}
.cred-pwd-row{background:rgba(201,150,10,.05)}
.cred-footer{padding:12px 20px;background:rgba(201,150,10,.08);font-size:11px;color:var(--amber);line-height:1.6;border-top:1px solid rgba(201,150,10,.2)}

/* ── Boutons rapport Word / Excel ── */
.btn-report {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 12px 22px;
  border-radius: 10px;
  font-weight: 600;
  font-size: 14px;
  cursor: pointer;
  border: 2px solid transparent;
  transition: transform 0.2s ease, box-shadow 0.2s ease, border-color 0.2s ease, background 0.2s ease;
  position: relative;
  min-width: 155px;
  justify-content: center;
  user-select: none;
  -webkit-tap-highlight-color: transparent;
}
.btn-report:disabled {
  opacity: 0.72;
  cursor: not-allowed;
  transform: none !important;
  box-shadow: none !important;
}
.btn-report-word {
  background: #1a4a9f;
  color: #fff;
  border-color: #1a4a9f;
}
.btn-report-word:not(:disabled):hover {
  background: #1640a8;
  border-color: #4CAF50;
  box-shadow: 0 4px 18px rgba(26,74,159,0.55), 0 0 0 1px #4CAF50;
  transform: translateY(-2px);
}
.btn-report-excel {
  background: #1a5c32;
  color: #fff;
  border-color: #1a5c32;
}
.btn-report-excel:not(:disabled):hover {
  background: #165228;
  border-color: #2e7d32;
  box-shadow: 0 4px 18px rgba(26,92,50,0.55), 0 0 0 1px #2e7d32;
  transform: translateY(-2px);
}
@keyframes btn-report-bounce {
  0%   { transform: scale(1); }
  30%  { transform: scale(0.95); }
  60%  { transform: scale(1.05); }
  100% { transform: scale(1); }
}
.btn-report-bounce {
  animation: btn-report-bounce 0.3s ease forwards;
}
.btn-report-spinner {
  width: 16px;
  height: 16px;
  border: 2px solid rgba(255,255,255,0.35);
  border-top-color: #fff;
  border-radius: 50%;
  animation: spin 0.75s linear infinite;
  flex-shrink: 0;
}

/* ── Temps réel — lots & connexion ── */
@keyframes blink-dot {
  0%, 100% { opacity: 1; }
  50%       { opacity: 0.25; }
}
.lot-active-dot {
  display: inline-block;
  width: 8px;
  height: 8px;
  background: #22C55E;
  border-radius: 50%;
  margin-right: 5px;
  vertical-align: middle;
  animation: blink-dot 1.4s ease-in-out infinite;
  box-shadow: 0 0 5px rgba(34,197,94,.8);
  flex-shrink: 0;
}
#connection-status {
  cursor: help;
  transition: background .4s, box-shadow .4s;
}
.lot-live-badge {
  font-size: 10px;
  font-weight: 700;
  color: #22C55E;
  letter-spacing: 1px;
  vertical-align: middle;
  margin-left: 6px;
  animation: blink-dot 2s ease-in-out infinite;
}
.tl-geo {
  font-size: 11px;
  color: var(--muted);
  margin-top: 3px;
}

/* ══════════════════════════════════════════════
   MENU HAMBURGER MOBILE — max-width 1023px
   ══════════════════════════════════════════════ */

/* Profil utilisateur en haut du sidenav */
.sidenav-profile{padding:20px 16px 14px;display:flex;flex-direction:column;align-items:center;gap:6px;text-align:center;border-bottom:1px solid var(--border);background:linear-gradient(180deg,var(--dark3) 0%,var(--dark2) 100%)}
.sidenav-profile-avatar{width:68px;height:68px;border-radius:50%;background:var(--dark4);border:2px solid var(--gold);display:flex;align-items:center;justify-content:center;font-size:24px;font-weight:700;color:var(--gold2);overflow:hidden;flex-shrink:0;margin-bottom:4px}
.sidenav-profile-avatar img{width:100%;height:100%;object-fit:cover}
.sidenav-profile-name{font-size:15px;font-weight:700;color:var(--text);line-height:1.2}
.sidenav-profile-company{font-size:11px;color:var(--muted);margin-top:2px}

/* Bouton hamburger animé */
#btn-hamburger{font-size:22px;color:var(--gold2);width:44px;height:44px;border-radius:8px;transition:background .2s,transform .2s;display:flex;align-items:center;justify-content:center;border:1px solid var(--border)}
#btn-hamburger:hover{background:var(--dark3)}
#btn-hamburger.is-open{transform:rotate(90deg)}

@media(max-width:1023px){
  /* 1. Masquer la bottom nav */
  .bottomnav{display:none!important}

  /* 2. Header fixe 60px */
  .topnav{position:fixed;top:0;left:0;right:0;height:60px;z-index:9999}

  /* 3. Décaler tout le contenu sous le header */
  #app{padding-top:60px}

  /* 4. Sidenav : slide depuis la gauche */
  .sidenav{
    display:flex!important;
    top:0!important;
    height:100vh!important;
    width:280px!important;
    transform:translateX(-100%);
    transition:transform .3s cubic-bezier(.4,0,.2,1);
    z-index:9000!important;
    padding-top:0!important;
    border-right:1px solid var(--gold)!important;
    box-shadow:4px 0 24px rgba(0,0,0,.6);
  }
  .sidenav.open{transform:translateX(0)}

  /* 5. Overlay derrière le menu */
  #nav-overlay{z-index:8999;background:rgba(0,0,0,.7)}

  /* 6. Bouton hamburger visible */
  #btn-hamburger{display:flex!important}
}

@media(min-width:1024px){
  /* Desktop : sidenav normal sans transform */
  .sidenav{transform:translateX(0)!important;top:56px!important;height:auto!important}
  #btn-hamburger{display:none!important}
  .sidenav-profile{display:none}
}

/* ── Collapsible sidebar (desktop ≥1024px) ── */
.sn-collapse-header{display:none;align-items:center;justify-content:flex-end;padding:8px 10px;border-bottom:1px solid var(--border);flex-shrink:0}
.sn-collapse-btn{display:none;align-items:center;justify-content:center;width:28px;height:28px;background:var(--dark3);border:1px solid var(--border);border-radius:6px;color:var(--muted);font-size:11px;cursor:pointer;transition:background .2s,color .2s,border-color .2s}
.sn-collapse-btn:hover{background:var(--gold);color:#000;border-color:var(--gold)}

@media(min-width:1024px){
  .sn-collapse-header{display:flex}
  .sn-collapse-btn{display:flex}

  /* Transition fluide largeur */
  .sidenav{transition:width .3s ease,transform .25s ease!important}
  .main-with-sidebar{transition:margin-left .3s ease}
  .main-with-sidebar.sn-collapsed{margin-left:60px!important}

  /* Etat réduit */
  .sidenav.sn-collapsed{width:60px!important;overflow:visible!important}
  .sidenav.sn-collapsed .sn-label,
  .sidenav.sn-collapsed .sn-chevron,
  .sidenav.sn-collapsed .sidenav-profile-name,
  .sidenav.sn-collapsed .sidenav-profile-company,
  .sidenav.sn-collapsed .sn-group-children,
  .sidenav.sn-collapsed .sidenav-sep{display:none!important}

  .sidenav.sn-collapsed .sidenav-profile{padding:10px 0;align-items:center;justify-content:center}
  .sidenav.sn-collapsed .sidenav-profile-avatar{width:36px;height:36px;font-size:12px;margin:0}
  .sidenav.sn-collapsed .role-badge{display:none}
  .sidenav.sn-collapsed .sn-collapse-header{justify-content:center;padding:8px 0}
  .sidenav.sn-collapsed #sn-items-container{overflow:visible!important}

  /* Items réduits : centrer l'icône */
  .sidenav.sn-collapsed .sidenav-item{padding:12px 0;justify-content:center;gap:0;border-left:3px solid transparent;position:relative}
  .sidenav.sn-collapsed .sidenav-item.active{background:rgba(255,255,255,.12);border-left-color:#F5A623}
  .sidenav.sn-collapsed .sn-icon{font-size:20px;width:auto}

  /* Tooltip au survol quand réduit */
  .sidenav.sn-collapsed .sidenav-item[data-label]:hover::after,
  .sidenav.sn-collapsed .sn-group-btn[data-label]:hover::after{
    content:attr(data-label);
    position:fixed;
    left:68px;
    background:var(--dark4);
    color:var(--text);
    padding:6px 10px;
    border-radius:6px;
    font-size:12px;
    white-space:nowrap;
    border:1px solid var(--border);
    z-index:9999;
    pointer-events:none;
    box-shadow:0 2px 10px rgba(0,0,0,.5);
    font-family:var(--font);
    font-weight:500;
  }
}

/* ── Thème clair : sidebar et bottomnav restent sombres ── */
.sidenav{background:#102E50!important}
.sidenav-item{color:rgba(255,255,255,.72)!important}
.sidenav-item:hover{background:rgba(255,255,255,.08)!important;color:#fff!important}
.sidenav-item.active{background:rgba(255,255,255,.12)!important;color:#F5A623!important;border-left-color:#F5A623!important}
.sn-group-btn{color:rgba(255,255,255,.72)!important}
.sn-group-btn:hover{background:rgba(255,255,255,.08)!important;color:#fff!important}
.sn-group-children{background:#0A1F38!important}
.sidenav-sep{background:rgba(255,255,255,.12)!important}
.sidenav-profile-name{color:#fff!important}
.sidenav-profile-company{color:rgba(255,255,255,.6)!important}
.sn-collapse-header{border-bottom:1px solid rgba(255,255,255,.12)!important}
.sn-collapse-btn{background:#0A1F38!important;border-color:rgba(255,255,255,.2)!important;color:rgba(255,255,255,.7)!important}
.sn-collapse-btn:hover{background:rgba(255,255,255,.2)!important;color:#fff!important;border-color:rgba(255,255,255,.4)!important}
.sidenav.sn-collapsed .sn-collapse-header{border-bottom:1px solid rgba(255,255,255,.12)!important}
.sidenav.sn-collapsed .sidenav-item[data-label]:hover::after,
.sidenav.sn-collapsed .sn-group-btn[data-label]:hover::after{
  background:#102E50!important;color:#fff!important;border-color:rgba(255,255,255,.15)!important}
.bottomnav{background:#102E50!important}
.bn-item{color:rgba(255,255,255,.6)!important}
.bn-item.active,.bn-item:hover{color:#FFFFFF!important}

/* ── Taille police menu ── */
.sidenav-item.sn-child{font-size:14px;font-weight:400;min-height:40px;padding-left:48px}

/* ── Thème corporate : overrides spécifiques ── */

/* Topnav : reste marine */
.topnav{background:#102E50!important;border-bottom:1px solid rgba(255,255,255,.08)!important}
.topnav .topnav-brand h1{color:#FFFFFF!important}
.topnav .company-sub{color:rgba(255,255,255,.6)!important}
.topnav .user-chip{background:rgba(255,255,255,.1)!important;border-color:rgba(255,255,255,.15)!important}
.topnav .user-chip *{color:#fff!important}
.topnav .btn-outline,.topnav #btn-hamburger,.topnav #btn-logout{
  border-color:rgba(255,255,255,.25)!important;color:#fff!important}

/* Sidenav profile : reste marine */
.sidenav-profile{background:linear-gradient(180deg,#1A3F66 0%,#102E50 100%)!important;
  border-bottom:1px solid rgba(255,255,255,.1)!important}
.sidenav-profile-avatar{background:rgba(255,255,255,.12)!important;color:#F5A623!important;
  border-color:rgba(255,255,255,.2)!important}

/* Stat cards : bordure gauche dorée */
.stat-card{border:none!important;border-left:4px solid var(--gold)!important;
  box-shadow:0 2px 8px rgba(0,0,0,.08)!important;border-radius:10px!important}
.stat-card::before{display:none!important}

/* Cartes et sections : ombre légère + bordure subtile */
.admin-section{box-shadow:0 4px 16px rgba(0,0,0,.2)!important;
  border:1px solid rgba(255,255,255,.08)!important;border-radius:12px!important}
.form-card{box-shadow:0 4px 16px rgba(0,0,0,.2)!important;border-color:rgba(255,255,255,.08)!important}
.lot-card{box-shadow:0 2px 8px rgba(0,0,0,.15)!important;border-color:rgba(255,255,255,.08)!important}
.company-card{box-shadow:0 2px 8px rgba(0,0,0,.15)!important;border-color:rgba(255,255,255,.08)!important}

/* Inputs : blanc + bordure douce */
.form-group input,.form-group select,.form-group textarea{
  background:#FFFFFF!important;border-color:#CBD5E0!important;color:#1A202C!important}
.form-group select option{background:#FFFFFF!important;color:#1A202C!important}

/* Bottom nav active : doré */
.bn-item.active,.bn-item:hover{color:#F5A623!important}

/* Connection dot reste vert */
#connection-status{background:var(--green)!important}

/* ── Texte blanc dans les cartes marines ── */
.stat-card,.admin-section,.form-card,.lot-card,.company-card,.user-card,.tl-card,.pip-step,.modal,.loading-box{color:#FFFFFF}
.user-card-name{color:#FFFFFF!important}
.user-card-email{color:#B0C4D8!important}
.company-card .company-name{color:#FFFFFF!important}
.lot-number{color:#F5A623!important}
.lot-meta{color:#B0C4D8!important}
.lot-meta span{color:#FFFFFF!important}
/* Inputs dans les cartes : garder blanc */
.form-group input,.form-group select,.form-group textarea{background:#FFFFFF!important;border-color:#CBD5E0!important;color:#1A202C!important}
.form-group label{color:#B0C4D8!important}


/* ── Texte hors cartes : foncé sur fond clair ── */
body{color:#1A202C}
.scroll-content{color:#1A202C}
/* Inputs toujours foncés (fond blanc) */
.form-group input,.form-group select,.form-group textarea{color:#1A202C!important}
.form-group select option{color:#1A202C!important}

/* ── Graphique cours de l'or : point clignotant ── */
@keyframes gpBlink {
  0%, 100% { opacity: 1; transform: scale(1); }
  50%       { opacity: 0.3; transform: scale(0.7); }
}
.gp-blink {
  animation: gpBlink 1.8s ease-in-out infinite;
}

