/* ============================================================
   assets/css/style.css — GT Infra — Dark Terminal v2
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Share+Tech+Mono&family=Rajdhani:wght@300;400;500;600;700&family=Orbitron:wght@400;600;800&display=swap');

:root {
  --bg-deep:#050811;--bg-panel:#090f1e;--bg-card:#0d1428;--bg-input:#060d1c;
  --border:#1a2e52;--border-glow:#0d6efd;
  --accent:#00d4ff;--accent2:#00ff9d;--accent3:#ff4d6d;
  --text:#c8d8f0;--text-dim:#4a6a9a;--text-bright:#e8f4ff;
  --glow-blue:0 0 8px #00d4ff88,0 0 20px #00d4ff33;
  --glow-green:0 0 8px #00ff9d88,0 0 20px #00ff9d33;
  --glow-red:0 0 8px #ff4d6d88,0 0 20px #ff4d6d33;
  --font-mono:'Share Tech Mono',monospace;--font-ui:'Rajdhani',sans-serif;--font-head:'Orbitron',monospace;
  --transition:0.25s cubic-bezier(0.4,0,0.2,1);
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--font-ui);background:var(--bg-deep);color:var(--text);min-height:100vh;overflow-x:hidden;position:relative}
body::before{content:'';position:fixed;inset:0;background:repeating-linear-gradient(0deg,transparent,transparent 2px,rgba(0,0,0,.06) 2px,rgba(0,0,0,.06) 4px);pointer-events:none;z-index:9999}
body::after{content:'';position:fixed;inset:0;background-image:linear-gradient(rgba(0,212,255,.025) 1px,transparent 1px),linear-gradient(90deg,rgba(0,212,255,.025) 1px,transparent 1px);background-size:40px 40px;pointer-events:none;z-index:0}
::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:var(--bg-deep)}::-webkit-scrollbar-thumb{background:var(--border-glow);border-radius:3px}

/* ── FLOATING LOGOS ─────────────────────────────────────── */
.floating-logos{position:fixed;inset:0;pointer-events:none;z-index:0;overflow:hidden}
.fl-logo{position:absolute;font-family:var(--font-mono);font-size:.62rem;letter-spacing:.1em;font-weight:700;color:var(--fl-color,rgba(0,212,255,.08));border:1px solid var(--fl-color,rgba(0,212,255,.06));padding:3px 7px;border-radius:4px;white-space:nowrap;user-select:none;opacity:0;animation:floatLogo var(--fl-dur,20s) var(--fl-delay,0s) linear infinite}
@keyframes floatLogo{0%{opacity:0;transform:translateY(110vh) rotate(var(--fl-rot,0deg))}5%{opacity:1}90%{opacity:1}100%{opacity:0;transform:translateY(-20vh) rotate(var(--fl-rot,0deg))}}

/* ── NAVBAR ──────────────────────────────────────────────── */
.navbar{position:sticky;top:0;z-index:1000;background:rgba(5,8,17,.92);backdrop-filter:blur(16px);border-bottom:1px solid var(--border);padding:0 2rem;display:flex;align-items:center;justify-content:space-between;height:64px}
.navbar-brand{font-family:var(--font-head);font-size:1.05rem;font-weight:800;color:var(--accent);text-decoration:none;letter-spacing:.08em;display:flex;align-items:center;gap:.7rem}
.navbar-brand .brand-icon{width:32px;height:32px;background:linear-gradient(135deg,var(--accent),var(--accent2));border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:1rem;box-shadow:var(--glow-blue);flex-shrink:0}
.navbar-brand .dim{color:var(--text-dim)}
.nav-links{display:flex;align-items:center;gap:.4rem;list-style:none}
.nav-links a{font-family:var(--font-ui);font-weight:600;font-size:.82rem;letter-spacing:.07em;color:var(--text-dim);text-decoration:none;text-transform:uppercase;padding:.45rem .8rem;border-radius:4px;border:1px solid transparent;transition:var(--transition);position:relative}
.nav-links a:hover,.nav-links a.active{color:var(--accent);border-color:var(--border);background:rgba(0,212,255,.06);text-shadow:0 0 8px var(--accent)}
.nav-links a::after{content:'';position:absolute;bottom:-1px;left:50%;right:50%;height:2px;background:var(--accent);transition:var(--transition)}
.nav-links a:hover::after,.nav-links a.active::after{left:0;right:0}
.nav-badge{background:var(--accent);color:var(--bg-deep);font-family:var(--font-mono);font-size:.62rem;padding:2px 6px;border-radius:3px;font-weight:700;letter-spacing:.05em}
.nav-badge.admin{background:var(--accent3)}
.nav-dropdown{position:relative}
.nav-dropdown-menu{display:none;position:absolute;top:calc(100% + 8px);right:0;background:var(--bg-panel);border:1px solid var(--border);border-radius:8px;min-width:200px;padding:.5rem 0;box-shadow:0 8px 32px rgba(0,0,0,.6),var(--glow-blue);z-index:100}
.nav-dropdown:hover .nav-dropdown-menu,.nav-dropdown:focus-within .nav-dropdown-menu{display:block}
.nav-dropdown-menu a{display:flex;align-items:center;gap:.6rem;padding:.6rem 1rem;font-size:.82rem;color:var(--text);text-decoration:none;transition:var(--transition);letter-spacing:.03em}
.nav-dropdown-menu a:hover{background:rgba(0,212,255,.08);color:var(--accent);padding-left:1.3rem}
.nav-dropdown-menu hr{border:none;border-top:1px solid var(--border);margin:.4rem 0}
.nav-dropdown-menu a.danger:hover{color:var(--accent3);background:rgba(255,77,109,.08)}

/* ── HERO ────────────────────────────────────────────────── */
.hero{position:relative;z-index:1;padding:6rem 2rem 5rem;text-align:center;overflow:hidden}
.hero-glow{position:absolute;top:-60px;left:50%;transform:translateX(-50%);width:600px;height:400px;background:radial-gradient(ellipse at center,rgba(0,212,255,.12) 0%,transparent 70%);pointer-events:none}
.hero-label{font-family:var(--font-mono);font-size:.72rem;color:var(--accent2);letter-spacing:.3em;text-transform:uppercase;margin-bottom:1.2rem;display:inline-flex;align-items:center;gap:.5rem}
.hero-label::before,.hero-label::after{content:'';display:inline-block;width:30px;height:1px;background:var(--accent2);opacity:.5}
.hero h1{font-family:var(--font-head);font-size:clamp(2rem,5vw,3.8rem);font-weight:800;line-height:1.1;color:var(--text-bright);letter-spacing:.03em;margin-bottom:1.2rem;text-shadow:0 0 30px rgba(0,212,255,.3)}
.hero h1 .highlight{background:linear-gradient(90deg,var(--accent),var(--accent2));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.hero-subtitle{font-family:var(--font-mono);font-size:.9rem;color:var(--text-dim);max-width:500px;margin:0 auto 2.5rem;line-height:1.8}
.cursor{display:inline-block;width:10px;height:1.1em;background:var(--accent);vertical-align:text-bottom;animation:blink 1s step-end infinite}
@keyframes blink{0%,100%{opacity:1}50%{opacity:0}}
.status-bar{display:inline-flex;align-items:center;gap:1.5rem;background:var(--bg-panel);border:1px solid var(--border);border-radius:6px;padding:.6rem 1.4rem;font-family:var(--font-mono);font-size:.72rem;color:var(--text-dim);margin-top:1rem}
.status-dot{display:inline-block;width:6px;height:6px;border-radius:50%;background:var(--accent2);box-shadow:var(--glow-green);animation:pulse-dot 2s ease-in-out infinite}
@keyframes pulse-dot{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.6;transform:scale(.8)}}

/* ── SECTION & CARDS ─────────────────────────────────────── */
.section{position:relative;z-index:1;padding:3rem 2rem;max-width:1200px;margin:0 auto}
.section-title{font-family:var(--font-head);font-size:.72rem;letter-spacing:.3em;color:var(--text-dim);text-transform:uppercase;margin-bottom:2rem;display:flex;align-items:center;gap:1rem}
.section-title::after{content:'';flex:1;height:1px;background:linear-gradient(90deg,var(--border),transparent)}
.cat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(460px,1fr));gap:1.5rem}
.cat-card{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;padding:2rem;cursor:pointer;transition:var(--transition);position:relative;overflow:hidden;text-decoration:none;display:block}
.cat-card::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,var(--card-color,var(--accent)),transparent);transform:scaleX(0);transition:var(--transition)}
.cat-card:hover::before{transform:scaleX(1)}
.cat-card:hover{border-color:var(--card-color,var(--accent));transform:translateY(-3px);box-shadow:0 8px 32px rgba(0,0,0,.4)}
.cat-card.systeme{--card-color:var(--accent)}.cat-card.reseau{--card-color:var(--accent2)}
.cat-card-header{display:flex;align-items:center;gap:1rem;margin-bottom:1.2rem}
.cat-icon{width:52px;height:52px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:1.5rem;background:rgba(0,212,255,.08);border:1px solid rgba(0,212,255,.2);color:var(--card-color,var(--accent));transition:var(--transition)}
.cat-card:hover .cat-icon{background:rgba(0,212,255,.15)}
.cat-card.reseau .cat-icon{background:rgba(0,255,157,.08);border-color:rgba(0,255,157,.2)}
.cat-card.reseau:hover .cat-icon{background:rgba(0,255,157,.15)}
.cat-card-title{font-family:var(--font-head);font-size:1.1rem;font-weight:600;color:var(--text-bright);letter-spacing:.05em}
.cat-card-sub{font-family:var(--font-mono);font-size:.68rem;color:var(--card-color,var(--accent));letter-spacing:.15em;text-transform:uppercase;opacity:.7}
.cat-card-body{font-size:.88rem;color:var(--text-dim);line-height:1.7;margin-bottom:1.4rem}
.cat-card-footer{display:flex;align-items:center;justify-content:space-between;padding-top:1rem;border-top:1px solid var(--border)}
.cat-pill{font-family:var(--font-mono);font-size:.63rem;padding:3px 8px;border-radius:3px;background:rgba(0,212,255,.08);border:1px solid rgba(0,212,255,.2);color:var(--accent);letter-spacing:.08em}
.cat-card.reseau .cat-pill{background:rgba(0,255,157,.08);border-color:rgba(0,255,157,.2);color:var(--accent2)}
.cat-arrow{color:var(--text-dim);font-size:1.2rem;transition:var(--transition)}
.cat-card:hover .cat-arrow{color:var(--card-color,var(--accent));transform:translateX(4px)}
.empty-state{text-align:center;padding:4rem 2rem;border:1px dashed var(--border);border-radius:10px;background:rgba(0,212,255,.02)}
.empty-state-icon{font-size:3rem;margin-bottom:1rem;opacity:.4}
.empty-state p{font-family:var(--font-mono);font-size:.78rem;color:var(--text-dim);line-height:2}

/* ── PROJECT CARDS ───────────────────────────────────────── */
.project-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(290px,1fr));gap:1.2rem}
.project-card{background:var(--bg-card);border:1px solid var(--border);border-radius:10px;overflow:hidden;transition:var(--transition);text-decoration:none;display:flex;flex-direction:column;animation:slideUp .4s ease both}
.project-card:hover{border-color:var(--page-color,var(--accent));transform:translateY(-3px);box-shadow:0 6px 24px rgba(0,0,0,.3)}
@keyframes slideUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
.project-card-thumb{width:100%;height:150px;object-fit:cover;border-bottom:1px solid var(--border);filter:brightness(.8) saturate(.7);transition:var(--transition)}
.project-card:hover .project-card-thumb{filter:brightness(1) saturate(1)}
.project-card-thumb-placeholder{width:100%;height:90px;background:linear-gradient(135deg,var(--bg-panel),var(--bg-deep));border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:2rem;opacity:.25}
.project-card-body{padding:1rem;flex:1}
.project-card-title{font-family:var(--font-head);font-size:.86rem;color:var(--text-bright);margin-bottom:.4rem;letter-spacing:.04em}
.project-card-text{font-size:.8rem;color:var(--text-dim);line-height:1.6}
.project-card-footer{padding:.6rem 1rem;border-top:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;font-family:var(--font-mono);font-size:.63rem;color:var(--text-dim)}
.assigned-avatars{display:flex;gap:3px}
.assigned-avatar{width:20px;height:20px;border-radius:50%;background:linear-gradient(135deg,var(--accent),var(--accent2));display:flex;align-items:center;justify-content:center;font-family:var(--font-head);font-size:.5rem;font-weight:700;color:var(--bg-deep);border:1px solid var(--bg-card);text-transform:uppercase}

/* ── PROJECT DETAIL ──────────────────────────────────────── */
.projet-layout{display:grid;grid-template-columns:1fr 360px;gap:2rem;max-width:1200px;margin:0 auto;padding:0 2rem 4rem;position:relative;z-index:1}
@media(max-width:900px){.projet-layout{grid-template-columns:1fr}}
.projet-content{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;padding:2rem}
.projet-meta{display:flex;gap:1rem;flex-wrap:wrap;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:1px solid var(--border)}
.projet-meta-item{font-family:var(--font-mono);font-size:.68rem;color:var(--text-dim);display:flex;align-items:center;gap:.4rem;letter-spacing:.05em}
.projet-body{font-size:.92rem;color:var(--text);line-height:1.8;white-space:pre-wrap}
.projet-assignes{margin-top:1.5rem;padding-top:1rem;border-top:1px solid var(--border)}
.projet-assignes-title{font-family:var(--font-mono);font-size:.66rem;letter-spacing:.15em;color:var(--text-dim);text-transform:uppercase;margin-bottom:.7rem}
.projet-assignes-list{display:flex;gap:.6rem;flex-wrap:wrap}
.assignee-chip{font-family:var(--font-mono);font-size:.7rem;padding:4px 10px;border-radius:20px;background:rgba(0,212,255,.08);border:1px solid rgba(0,212,255,.2);color:var(--accent);letter-spacing:.05em;display:flex;align-items:center;gap:.4rem}
.projet-images-col{display:flex;flex-direction:column;gap:1rem;position:sticky;top:80px;max-height:calc(100vh - 100px);overflow-y:auto}
.projet-images-col::-webkit-scrollbar{width:4px}
.projet-images-col::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px}
.projet-image-item{position:relative;border-radius:8px;overflow:hidden;border:1px solid var(--border);cursor:pointer;transition:var(--transition);background:var(--bg-panel)}
.projet-image-item:hover{border-color:var(--accent);transform:scale(1.01)}
.projet-image-item img{width:100%;display:block;filter:brightness(.9);transition:var(--transition)}
.projet-image-item:hover img{filter:brightness(1)}
.projet-image-overlay{position:absolute;inset:0;background:rgba(0,0,0,.4);display:flex;align-items:center;justify-content:center;gap:1rem;opacity:0;transition:var(--transition)}
.projet-image-item:hover .projet-image-overlay{opacity:1}
.projet-image-overlay-btn{width:36px;height:36px;background:rgba(0,212,255,.9);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1rem;color:var(--bg-deep);text-decoration:none;transition:var(--transition);border:none;cursor:pointer}
.projet-image-overlay-btn:hover{transform:scale(1.1);background:var(--accent2)}
.projet-image-caption{padding:.45rem .7rem;font-family:var(--font-mono);font-size:.65rem;color:var(--text-dim);letter-spacing:.05em;border-top:1px solid var(--border);background:var(--bg-card)}
.projet-no-images{border:1px dashed var(--border);border-radius:8px;padding:3rem 1rem;text-align:center;font-family:var(--font-mono);font-size:.72rem;color:var(--text-dim);line-height:2}

/* ── LIGHTBOX ─────────────────────────────────────────────── */
.lightbox{display:none;position:fixed;inset:0;z-index:9000;background:rgba(0,0,0,.93);backdrop-filter:blur(8px);align-items:center;justify-content:center;flex-direction:column}
.lightbox.open{display:flex}
.lightbox-inner{position:relative;max-width:90vw;max-height:80vh;display:flex;align-items:center;justify-content:center}
.lightbox img{max-width:90vw;max-height:80vh;object-fit:contain;border-radius:4px;box-shadow:0 0 60px rgba(0,212,255,.15);animation:lbIn .2s ease}
@keyframes lbIn{from{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}
.lightbox-toolbar{display:flex;align-items:center;gap:1rem;margin-top:1.2rem}
.lb-btn{display:flex;align-items:center;gap:.5rem;padding:.5rem 1.2rem;border-radius:6px;border:1px solid var(--border);background:var(--bg-panel);color:var(--text);font-family:var(--font-mono);font-size:.73rem;letter-spacing:.08em;cursor:pointer;text-decoration:none;transition:var(--transition)}
.lb-btn:hover{border-color:var(--accent);color:var(--accent)}
.lb-btn.lb-close{border-color:var(--accent3);color:var(--accent3)}
.lb-btn.lb-close:hover{background:rgba(255,77,109,.1)}
.lb-nav{position:absolute;top:50%;transform:translateY(-50%);width:44px;height:44px;background:rgba(0,0,0,.6);border:1px solid var(--border);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.2rem;color:var(--text);cursor:pointer;transition:var(--transition);z-index:10;user-select:none}
.lb-nav:hover{border-color:var(--accent);color:var(--accent);background:rgba(0,212,255,.1)}
.lb-prev{left:-60px}.lb-next{right:-60px}
.lb-caption{font-family:var(--font-mono);font-size:.7rem;color:var(--text-dim);text-align:center;margin-top:.6rem;letter-spacing:.08em}
.lb-counter{font-family:var(--font-mono);font-size:.66rem;color:var(--text-dim);letter-spacing:.12em}

/* ── ADMIN IMAGE MANAGER ─────────────────────────────────── */
.images-manager-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1rem;margin-top:1rem}
.img-manager-card{background:var(--bg-card);border:1px solid var(--border);border-radius:8px;overflow:hidden;transition:var(--transition)}
.img-manager-card:hover{border-color:var(--accent)}
.img-manager-thumb{width:100%;height:130px;object-fit:cover;display:block;filter:brightness(.85);transition:var(--transition)}
.img-manager-card:hover .img-manager-thumb{filter:brightness(1)}
.img-manager-body{padding:.7rem}
.img-order-input{width:55px;background:var(--bg-input);border:1px solid var(--border);border-radius:4px;padding:3px 6px;font-family:var(--font-mono);font-size:.73rem;color:var(--accent);text-align:center}
.img-caption-input{width:100%;background:var(--bg-input);border:1px solid var(--border);border-radius:4px;padding:4px 7px;font-family:var(--font-mono);font-size:.7rem;color:var(--text);margin-top:.4rem}
.img-caption-input:focus,.img-order-input:focus{outline:none;border-color:var(--accent)}
.img-manager-actions{display:flex;gap:.4rem;margin-top:.5rem}
.drop-zone{border:2px dashed var(--border);border-radius:10px;padding:2.5rem;text-align:center;transition:var(--transition);cursor:pointer;font-family:var(--font-mono);font-size:.78rem;color:var(--text-dim);line-height:2}
.drop-zone:hover,.drop-zone.drag-over{border-color:var(--accent);background:rgba(0,212,255,.04);color:var(--accent)}
.drop-zone .dz-icon{font-size:2.5rem;display:block;margin-bottom:.8rem;opacity:.5}

/* ── LOGIN ────────────────────────────────────────────────── */
.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:2rem;position:relative;z-index:1}
.login-card{background:var(--bg-card);border:1px solid var(--border);border-radius:16px;padding:3rem 2.8rem;width:100%;max-width:400px;position:relative;animation:loginAppear .6s ease both}
@keyframes loginAppear{from{opacity:0;transform:translateY(30px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}
.login-card::before{content:'';position:absolute;top:0;left:20%;right:20%;height:1px;background:linear-gradient(90deg,transparent,var(--accent),transparent)}
.login-logo{text-align:center;margin-bottom:2rem}
.login-logo-icon{width:64px;height:64px;background:linear-gradient(135deg,rgba(0,212,255,.15),rgba(0,255,157,.08));border:1px solid var(--border);border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:1.8rem;margin:0 auto 1rem;box-shadow:var(--glow-blue)}
.login-logo h2{font-family:var(--font-head);font-size:1.2rem;color:var(--accent);letter-spacing:.1em}
.login-logo p{font-family:var(--font-mono);font-size:.68rem;color:var(--text-dim);letter-spacing:.15em;text-transform:uppercase;margin-top:.3rem}
.boot-sequence{font-family:var(--font-mono);font-size:.7rem;color:var(--text-dim);margin-bottom:1.8rem;line-height:1.9}
.boot-line .ok{color:var(--accent2)}.boot-line .err{color:var(--accent3)}.boot-line .tag{color:var(--accent)}

/* ── FORMS ────────────────────────────────────────────────── */
.form-group{margin-bottom:1.3rem}
.form-label{display:block;font-family:var(--font-mono);font-size:.7rem;letter-spacing:.15em;color:var(--text-dim);text-transform:uppercase;margin-bottom:.5rem}
.form-control{width:100%;background:var(--bg-input);border:1px solid var(--border);border-radius:6px;padding:.7rem 1rem;font-family:var(--font-mono);font-size:.86rem;color:var(--text-bright);outline:none;transition:var(--transition)}
.form-control:focus{border-color:var(--accent);box-shadow:0 0 0 2px rgba(0,212,255,.12);background:var(--bg-panel)}
.form-control::placeholder{color:var(--text-dim);opacity:.5}
select.form-control option{background:var(--bg-panel)}
textarea.form-control{resize:vertical}
select[multiple].form-control{height:auto;min-height:100px;padding:.4rem}
select[multiple].form-control option{padding:.4rem .6rem;border-radius:3px}
select[multiple].form-control option:checked{background:rgba(0,212,255,.15);color:var(--accent)}
.form-hint{font-family:var(--font-mono);font-size:.66rem;color:var(--text-dim);margin-top:.35rem;letter-spacing:.05em}
.pw-strength-bar{height:4px;background:var(--border);border-radius:2px;margin-top:6px;overflow:hidden}
.pw-strength-fill{height:100%;width:0%;transition:width .3s,background .3s;border-radius:2px}

/* ── BUTTONS ─────────────────────────────────────────────── */
.btn{display:inline-flex;align-items:center;gap:.5rem;padding:.7rem 1.4rem;border-radius:6px;border:1px solid transparent;font-family:var(--font-ui);font-weight:600;font-size:.83rem;letter-spacing:.07em;text-transform:uppercase;cursor:pointer;transition:var(--transition);text-decoration:none}
.btn-primary{background:linear-gradient(135deg,rgba(0,212,255,.15),rgba(0,212,255,.05));border-color:var(--accent);color:var(--accent);justify-content:center}
.btn-primary:hover{background:rgba(0,212,255,.2);box-shadow:var(--glow-blue);transform:translateY(-1px)}
.btn-success{background:linear-gradient(135deg,rgba(0,255,157,.15),rgba(0,255,157,.05));border-color:var(--accent2);color:var(--accent2)}
.btn-success:hover{background:rgba(0,255,157,.2);box-shadow:var(--glow-green)}
.btn-danger{background:linear-gradient(135deg,rgba(255,77,109,.15),rgba(255,77,109,.05));border-color:var(--accent3);color:var(--accent3)}
.btn-danger:hover{background:rgba(255,77,109,.2);box-shadow:var(--glow-red)}
.btn-secondary{background:transparent;border-color:var(--border);color:var(--text-dim)}
.btn-secondary:hover{border-color:var(--text-dim);color:var(--text)}
.btn-accent{background:linear-gradient(135deg,rgba(0,212,255,.2),rgba(0,255,157,.1));border-color:var(--accent);color:var(--accent)}
.btn-accent:hover{background:rgba(0,212,255,.25);box-shadow:var(--glow-blue)}
.btn-sm{padding:.38rem .85rem;font-size:.73rem}.btn-xs{padding:.25rem .6rem;font-size:.65rem}

/* ── ALERTS ──────────────────────────────────────────────── */
.alert{padding:.8rem 1rem;border-radius:6px;font-family:var(--font-mono);font-size:.78rem;margin-bottom:1.2rem;display:flex;align-items:center;gap:.6rem;letter-spacing:.03em;animation:fadeIn .3s ease}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
.alert-error{background:rgba(255,77,109,.08);border:1px solid rgba(255,77,109,.3);color:var(--accent3)}
.alert-success{background:rgba(0,255,157,.08);border:1px solid rgba(0,255,157,.3);color:var(--accent2)}
.alert-info{background:rgba(0,212,255,.08);border:1px solid rgba(0,212,255,.3);color:var(--accent)}
.terminal-line{font-family:var(--font-mono);font-size:.72rem;color:var(--text-dim);text-align:center;margin-top:1.5rem;letter-spacing:.05em}
.terminal-line .ok{color:var(--accent2)}.terminal-line .err{color:var(--accent3)}.terminal-line .ip{color:var(--accent)}

/* ── DASHBOARD ────────────────────────────────────────────── */
.dash-layout{display:grid;grid-template-columns:230px 1fr;min-height:calc(100vh - 64px);position:relative;z-index:1}
.dash-sidebar{background:var(--bg-panel);border-right:1px solid var(--border);padding:1.5rem 1rem}
.sidebar-section{margin-bottom:1.8rem}
.sidebar-label{font-family:var(--font-mono);font-size:.6rem;letter-spacing:.25em;text-transform:uppercase;color:var(--text-dim);padding:0 .5rem;margin-bottom:.6rem}
.sidebar-link{display:flex;align-items:center;gap:.7rem;padding:.55rem .7rem;border-radius:6px;font-size:.83rem;font-weight:500;color:var(--text-dim);text-decoration:none;transition:var(--transition);border:1px solid transparent}
.sidebar-link:hover,.sidebar-link.active{background:rgba(0,212,255,.06);border-color:var(--border);color:var(--accent)}
.sidebar-link .icon{width:20px;text-align:center;font-size:.88rem}
.dash-main{padding:2rem;overflow-y:auto}
.dash-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:2rem;padding-bottom:1rem;border-bottom:1px solid var(--border)}
.dash-title{font-family:var(--font-head);font-size:1.3rem;color:var(--text-bright);letter-spacing:.05em}
.dash-subtitle{font-family:var(--font-mono);font-size:.7rem;color:var(--text-dim);margin-top:.2rem;letter-spacing:.1em}
.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:1rem;margin-bottom:2rem}
.stat-card{background:var(--bg-card);border:1px solid var(--border);border-radius:10px;padding:1.3rem;position:relative;overflow:hidden;transition:var(--transition)}
.stat-card:hover{border-color:var(--stat-color,var(--accent))}
.stat-card::after{content:'';position:absolute;bottom:0;left:0;right:0;height:2px;background:var(--stat-color,var(--accent));opacity:.4}
.stat-value{font-family:var(--font-head);font-size:1.8rem;font-weight:800;color:var(--stat-color,var(--accent));line-height:1;margin-bottom:.3rem;text-shadow:0 0 10px var(--stat-color,var(--accent))}
.stat-label{font-family:var(--font-mono);font-size:.66rem;color:var(--text-dim);letter-spacing:.15em;text-transform:uppercase}
.data-table{width:100%;border-collapse:collapse;font-size:.83rem}
.data-table th{font-family:var(--font-mono);font-size:.66rem;letter-spacing:.15em;text-transform:uppercase;color:var(--text-dim);padding:.7rem 1rem;text-align:left;border-bottom:1px solid var(--border)}
.data-table td{padding:.75rem 1rem;border-bottom:1px solid rgba(26,46,82,.5);color:var(--text);vertical-align:middle}
.data-table tr:hover td{background:rgba(0,212,255,.025)}
.data-table .mono{font-family:var(--font-mono);font-size:.78rem}
.role-badge{font-family:var(--font-mono);font-size:.63rem;padding:2px 8px;border-radius:3px;letter-spacing:.08em;text-transform:uppercase}
.role-badge.superadmin{background:rgba(0,212,255,.12);border:1px solid rgba(0,212,255,.3);color:var(--accent)}
.role-badge.admin{background:rgba(0,255,157,.08);border:1px solid rgba(0,255,157,.2);color:var(--accent2)}
.panel{background:var(--bg-card);border:1px solid var(--border);border-radius:10px;padding:1.5rem;margin-bottom:1.5rem}
.panel-title{font-family:var(--font-head);font-size:.83rem;color:var(--text-bright);letter-spacing:.08em;margin-bottom:1.2rem;display:flex;align-items:center;gap:.6rem}
.panel-title .icon{color:var(--accent)}

/* ── PAGE HEADERS ─────────────────────────────────────────── */
.cat-page-header{position:relative;z-index:1;padding:3rem 2rem 2rem;max-width:1200px;margin:0 auto}
.breadcrumb{font-family:var(--font-mono);font-size:.7rem;color:var(--text-dim);margin-bottom:1rem;letter-spacing:.08em}
.breadcrumb a{color:var(--accent);text-decoration:none}
.breadcrumb a:hover{text-decoration:underline}
.breadcrumb .sep{margin:0 .5rem}
.cat-page-title{font-family:var(--font-head);font-size:clamp(1.6rem,3vw,2.5rem);color:var(--text-bright);letter-spacing:.04em;margin-bottom:.5rem}
.cat-page-title span{color:var(--page-color,var(--accent))}
.cat-page-desc{font-family:var(--font-mono);font-size:.8rem;color:var(--text-dim);line-height:1.8}
.content-section{max-width:1200px;margin:0 auto;padding:0 2rem 4rem;position:relative;z-index:1}

/* ── FOOTER ──────────────────────────────────────────────── */
.site-footer{position:relative;z-index:1;border-top:1px solid var(--border);padding:1.5rem 2rem;text-align:center;font-family:var(--font-mono);font-size:.7rem;color:var(--text-dim);letter-spacing:.08em}
.site-footer .accent{color:var(--accent)}

/* ── ANIMATIONS ──────────────────────────────────────────── */
.anim-up{opacity:0;transform:translateY(24px);transition:opacity .6s ease,transform .6s ease}
.anim-up.visible{opacity:1;transform:translateY(0)}

/* ── RESPONSIVE (MOBILES) ────────────────────────────────── */
@media(max-width:768px){
  /* 1. Règles générales */
  .cat-grid{grid-template-columns:1fr}
  .dash-layout{grid-template-columns:1fr}
  .dash-sidebar{display:none}
  .hero{padding:4rem 1.5rem 3rem}
  .lb-prev{left:-10px}.lb-next{right:-10px}

  /* 2. Menu de navigation public */
  .navbar { height: auto; flex-direction: column; padding: 1rem; gap: 1rem; }
  .nav-links { flex-wrap: wrap; justify-content: center; gap: 0.8rem; }
  .floating-logos { display: none; }
  #matrix-bg { opacity: 0.05; }
  .cat-page-title { font-size: 1.8rem; }
  .cat-page-header, .section { padding: 2rem 1rem; }

  /* 3. Ajustement des marges et formulaires */
  .dash-main { padding: 1rem; }
  .stats-grid { grid-template-columns: 1fr 1fr; gap: 0.8rem; }
  .field-group-row { grid-template-columns: 1fr !important; gap: 1rem; }

  /* =======================================================
     4. CORRECTION ABSOLUE DES TABLEAUX
     ======================================================= */
  .panel {
    overflow-x: auto;
    padding: 1.2rem 1rem;
  }
  
  /* L'astuce "Sticky" : le titre reste figé à gauche quand on scrolle */
  .panel-title {
    position: sticky;
    left: 0;
    width: max-content; 
  }
  
  .data-table {
    min-width: 750px; /* On donne encore plus d'espace au tableau */
  }
  
  /* Interdiction formelle d'écraser le texte ou de le passer à la ligne */
  .data-table th, .data-table td {
    white-space: nowrap; 
  }
}

/* ============================================================
   ICÔNES LUCIDE 3D — v4
   ============================================================ */

/* Base icon */
.ico,
svg.lucide {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  vertical-align: middle;
  flex-shrink: 0;
  stroke: currentColor;
  fill: none;
  stroke-width: 1.5;
  stroke-linecap: round;
  stroke-linejoin: round;
}

/* 3D glow effect — icons héritent la couleur parent */
.ico,
.sidebar-link svg.lucide,
.btn svg.lucide,
.panel-title svg.lucide {
  filter: drop-shadow(0 1px 2px rgba(0,0,0,.6))
          drop-shadow(0 0 5px currentColor);
  transition: filter var(--transition);
}

/* Accentuation au hover */
.sidebar-link:hover svg.lucide,
.btn:hover svg.lucide,
a:hover .ico {
  filter: drop-shadow(0 1px 3px rgba(0,0,0,.8))
          drop-shadow(0 0 10px currentColor)
          drop-shadow(0 0 20px currentColor);
}

/* Icônes dans les boutons */
.btn .ico { width: 15px; height: 15px; }
.btn-sm .ico { width: 14px; height: 14px; }

/* Icônes sidebar */
.sidebar-link .ico { width: 17px; height: 17px; flex-shrink: 0; }

/* Icônes panel-title */
.panel-title .ico { width: 17px; height: 17px; color: var(--accent); }

/* Navbar icons */
.nav-links .ico { width: 15px; height: 15px; }

/* Brand icon */
.brand-icon .ico { width: 18px; height: 18px; color: var(--bg-deep); filter: none; }

/* Stat cards */
.stat-card .ico { width: 24px; height: 24px; opacity: 0.5; margin-bottom: .5rem; }

/* Tables */
.data-table .ico { width: 14px; height: 14px; }

/* ============================================================
   ADMIN PICKER — Sélecteur d'assignation avec avatars
   ============================================================ */

.admin-picker-label {
  display: block;
  font-family: var(--font-mono);
  font-size: .7rem;
  letter-spacing: .15em;
  color: var(--text-dim);
  text-transform: uppercase;
  margin-bottom: .6rem;
}

.admin-picker-wrap {
  background: var(--bg-input);
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: .8rem;
  min-height: 64px;
  transition: var(--transition);
}
.admin-picker-wrap:focus-within {
  border-color: var(--accent);
  box-shadow: 0 0 0 2px rgba(0,212,255,.1);
}

.admin-picker {
  display: flex;
  flex-wrap: wrap;
  gap: .5rem;
}

.admin-chip {
  display: inline-flex;
  align-items: center;
  gap: .5rem;
  padding: .35rem .75rem .35rem .35rem;
  border-radius: 30px;
  border: 1px solid var(--border);
  background: var(--bg-card);
  cursor: pointer;
  transition: var(--transition);
  user-select: none;
  position: relative;
}
.admin-chip:hover {
  border-color: var(--accent);
  background: rgba(0,212,255,.06);
  transform: translateY(-1px);
}
.admin-chip.selected {
  border-color: var(--accent);
  background: rgba(0,212,255,.14);
  box-shadow: 0 0 8px rgba(0,212,255,.2);
}
.admin-chip.selected .admin-chip-name { color: var(--accent); }
.admin-chip.selected .admin-chip-check { opacity: 1; }

.admin-chip-avatar {
  width: 26px; height: 26px;
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-family: var(--font-head);
  font-size: .6rem;
  font-weight: 800;
  color: var(--bg-deep);
  flex-shrink: 0;
  border: 1px solid rgba(255,255,255,.15);
  box-shadow: 0 1px 4px rgba(0,0,0,.4), 0 0 6px currentColor;
  letter-spacing: 0;
}

.admin-chip-info {
  display: flex;
  flex-direction: column;
  line-height: 1.2;
}
.admin-chip-name {
  font-family: var(--font-mono);
  font-size: .75rem;
  color: var(--text);
  transition: color var(--transition);
}
.admin-chip-role {
  font-family: var(--font-mono);
  font-size: .58rem;
  color: var(--text-dim);
  letter-spacing: .05em;
}
.admin-chip-check {
  width: 14px; height: 14px;
  opacity: 0;
  transition: opacity var(--transition);
  color: var(--accent);
  flex-shrink: 0;
  pointer-events: none; /* évite interception du clic par le SVG Lucide */
}
/* Tous les enfants du chip ne captent pas les clics */
.admin-chip > *,
.admin-chip svg,
.admin-chip .admin-chip-avatar,
.admin-chip .admin-chip-info,
.admin-chip .admin-chip-name,
.admin-chip .admin-chip-role {
  pointer-events: none;
}

.admin-picker-hint {
  font-family: var(--font-mono);
  font-size: .65rem;
  color: var(--text-dim);
  margin-top: .5rem;
  letter-spacing: .05em;
}

/* ============================================================
   CHAMP DESCRIPTION — séparé du contenu projet
   ============================================================ */
.field-group {
  display: flex;
  flex-direction: column;
  gap: .35rem;
  margin-bottom: 1.2rem;
}
.field-group-row {
  display: grid;
  gap: 1rem;
}
.field-badge {
  display: inline-flex;
  align-items: center;
  gap: .35rem;
  font-family: var(--font-mono);
  font-size: .62rem;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--accent2);
  background: rgba(0,255,157,.08);
  border: 1px solid rgba(0,255,157,.2);
  border-radius: 3px;
  padding: 2px 6px;
}
.field-badge.accent { color: var(--accent); background: rgba(0,212,255,.08); border-color: rgba(0,212,255,.2); }

/* ============================================================
   TOGGLE BUTTONS — États visible / masqué avec lueur
   ============================================================ */

/* Projet visible → bouton masquer (œil barré) en orange/ambre */
.btn-toggle-visible {
  background: rgba(255,183,0,.12);
  border-color: #ffb700;
  color: #ffb700;
}
.btn-toggle-visible:hover {
  background: rgba(255,183,0,.22);
  box-shadow: 0 0 8px rgba(255,183,0,.6), 0 0 18px rgba(255,183,0,.25);
  border-color: #ffb700;
}

/* Projet masqué → bouton rendre visible (œil) en vert/cyan pulsant */
.btn-toggle-hidden {
  background: rgba(0,212,255,.1);
  border-color: var(--accent);
  color: var(--accent);
  animation: pulse-toggle .9s ease-in-out infinite;
}
.btn-toggle-hidden:hover {
  background: rgba(0,212,255,.22);
  box-shadow: var(--glow-blue);
}
@keyframes pulse-toggle {
  0%,100% { box-shadow: 0 0 4px rgba(0,212,255,.4); }
  50%      { box-shadow: 0 0 12px rgba(0,212,255,.8), 0 0 24px rgba(0,212,255,.3); }
}

/* ── Table layout overrides for content page ─────────────── */
.data-table td { vertical-align: middle; }
.data-table td[style*="white-space:nowrap"] { padding: .5rem .6rem; }
