
:root {
  --gold: #C9A84C;
  --gold-light: #E8C97A;
  --gold-dim: #7A6330;
  --bg-deep: #0A0B0D;
  --bg-card: #111318;
  --bg-card2: #161820;
  --bg-overlay: rgba(10,11,13,0.97);
  --border: rgba(201,168,76,0.18);
  --border-bright: rgba(201,168,76,0.45);
  --text: #F0EBE0;
  --text-dim: #8A8070;
  --text-mid: #B8AE9C;
  --red: #C0392B;
  --green: #27AE60;
  --blue: #2980B9;
  --orange: #E67E22;
  --purple: #8E44AD;
  --sidebar-w: 240px;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{font-size:15px;}
body{font-family:'Outfit',sans-serif;background:var(--bg-deep);color:var(--text);min-height:100vh;overflow-x:hidden;}

/* ─── SCROLLBAR ─── */
::-webkit-scrollbar{width:6px;height:6px;}
::-webkit-scrollbar-track{background:var(--bg-deep);}
::-webkit-scrollbar-thumb{background:var(--gold-dim);border-radius:3px;}

/* ─── TYPOGRAPHY ─── */
h1,h2,h3,.serif{font-family:'Cormorant Garamond',serif;}

/* ─── NOISE OVERLAY ─── */
body::before{
  content:'';position:fixed;inset:0;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.04'/%3E%3C/svg%3E");
  pointer-events:none;z-index:9999;opacity:.4;
}

/* ═══════════════════════════
   VITRINE PUBLIQUE
═══════════════════════════ */
#vitrine{display:block;}
#app{display:none;}

/* NAV VITRINE */
.nav-vitrine{
  position:fixed;top:0;left:0;right:0;z-index:100;
  display:flex;align-items:center;justify-content:space-between;
  padding:0 60px;height:70px;
  background:rgba(10,11,13,0.85);
  backdrop-filter:blur(20px);
  border-bottom:1px solid var(--border);
}
.nav-logo{display:flex;align-items:center;gap:12px;text-decoration:none;}
.nav-logo img{height:42px;width:42px;object-fit:contain;border-radius:50%;border:1px solid var(--border-bright);}
.nav-logo-text{font-family:'Cormorant Garamond',serif;font-size:1.4rem;font-weight:600;color:var(--gold);letter-spacing:.08em;}
.nav-logo-sub{font-size:.65rem;color:var(--text-dim);letter-spacing:.2em;text-transform:uppercase;display:block;line-height:1;}
.nav-links{display:flex;align-items:center;gap:32px;}
.nav-links a{color:var(--text-mid);text-decoration:none;font-size:.85rem;letter-spacing:.06em;text-transform:uppercase;transition:.2s;position:relative;}
.nav-links a::after{content:'';position:absolute;bottom:-4px;left:0;width:0;height:1px;background:var(--gold);transition:.3s;}
.nav-links a:hover{color:var(--gold);}
.nav-links a:hover::after{width:100%;}
.btn-admin{
  background:transparent;border:1px solid var(--border-bright);
  color:var(--gold);padding:8px 20px;border-radius:2px;
  cursor:pointer;font-family:'Outfit',sans-serif;font-size:.8rem;
  letter-spacing:.1em;text-transform:uppercase;transition:.2s;
}
.btn-admin:hover{background:var(--gold);color:var(--bg-deep);}

/* HERO */
.hero{
  min-height:100vh;display:flex;align-items:center;justify-content:center;
  position:relative;overflow:hidden;
  background: radial-gradient(ellipse 80% 60% at 60% 40%, rgba(201,168,76,0.07) 0%, transparent 70%),
              radial-gradient(ellipse 50% 80% at 10% 80%, rgba(201,168,76,0.04) 0%, transparent 60%),
              var(--bg-deep);
}
.hero-grid{
  position:absolute;inset:0;
  background-image:
    linear-gradient(rgba(201,168,76,0.04) 1px,transparent 1px),
    linear-gradient(90deg,rgba(201,168,76,0.04) 1px,transparent 1px);
  background-size:60px 60px;
}
.hero-content{position:relative;text-align:center;padding:120px 40px 60px;max-width:800px;}
.hero-eyebrow{
  font-size:.7rem;letter-spacing:.35em;text-transform:uppercase;
  color:var(--gold);margin-bottom:24px;display:flex;align-items:center;justify-content:center;gap:12px;
}
.hero-eyebrow::before,.hero-eyebrow::after{content:'';width:40px;height:1px;background:var(--gold-dim);}
.hero-title{
  font-family:'Cormorant Garamond',serif;font-size:5.5rem;font-weight:300;
  line-height:.9;letter-spacing:-.02em;color:var(--text);margin-bottom:12px;
}
.hero-title span{color:var(--gold);font-style:italic;}
.hero-sub{
  font-family:'Cormorant Garamond',serif;font-size:1.5rem;font-weight:300;
  color:var(--text-mid);margin-bottom:40px;letter-spacing:.05em;
}
.hero-divider{width:80px;height:1px;background:linear-gradient(90deg,transparent,var(--gold),transparent);margin:0 auto 28px;}
.hero-cta{display:flex;gap:16px;justify-content:center;flex-wrap:wrap;}
.btn-gold{
  background:var(--gold);color:var(--bg-deep);
  padding:14px 36px;border:none;cursor:pointer;
  font-family:'Outfit',sans-serif;font-size:.85rem;font-weight:600;
  letter-spacing:.12em;text-transform:uppercase;transition:.25s;border-radius:2px;
}
.btn-gold:hover{background:var(--gold-light);transform:translateY(-2px);}
.btn-outline{
  background:transparent;color:var(--text-mid);
  padding:14px 36px;border:1px solid rgba(255,255,255,.15);cursor:pointer;
  font-family:'Outfit',sans-serif;font-size:.85rem;
  letter-spacing:.12em;text-transform:uppercase;transition:.25s;border-radius:2px;
}
.btn-outline:hover{border-color:var(--gold);color:var(--gold);}

/* SERVICES */
.section{padding:100px 60px;}
.section-title{
  font-family:'Cormorant Garamond',serif;font-size:3rem;font-weight:300;
  color:var(--text);margin-bottom:8px;
}
.section-line{width:60px;height:2px;background:var(--gold);margin-bottom:40px;}
.services-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1px;background:var(--border);}
.service-card{
  background:var(--bg-card);padding:40px 32px;transition:.25s;
  position:relative;overflow:hidden;
}
.service-card::before{
  content:'';position:absolute;top:0;left:0;right:0;height:2px;
  background:linear-gradient(90deg,transparent,var(--gold),transparent);
  transform:scaleX(0);transition:.3s;
}
.service-card:hover::before{transform:scaleX(1);}
.service-card:hover{background:var(--bg-card2);}
.service-icon{font-size:2rem;margin-bottom:20px;}
.service-icon-svg{width:40px;height:40px;color:var(--gold);margin-bottom:22px;opacity:.9;}
.service-title{
  font-family:'Cormorant Garamond',serif;font-size:1.5rem;
  color:var(--gold);margin-bottom:12px;
}
.service-desc{color:var(--text-dim);line-height:1.7;font-size:.88rem;}

/* PROJETS VITRINE */
.projects-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:2px;background:var(--border);}
.project-card{
  background:var(--bg-card);padding:0;overflow:hidden;
  transition:.25s;cursor:pointer;
}
.public-portfolio-card{
  border:0;text-align:left;color:inherit;font-family:inherit;
}
.project-card:hover{transform:scale(1.01);z-index:2;}
.project-img{
  width:100%;height:200px;
  background:linear-gradient(135deg,var(--bg-card2),rgba(201,168,76,.1));
  display:flex;align-items:center;justify-content:center;
  font-size:3rem;color:var(--gold-dim);
  overflow:hidden;position:relative;
}
.project-img img{width:100%;height:100%;object-fit:cover;}
.project-info{padding:24px;}
.project-name{font-family:'Cormorant Garamond',serif;font-size:1.3rem;color:var(--text);margin-bottom:6px;}
.project-type{font-size:.75rem;color:var(--gold);letter-spacing:.1em;text-transform:uppercase;}
.portfolio-price{color:var(--gold);font-size:.88rem;font-weight:600;margin-top:10px;}
.portfolio-photo-count{
  position:absolute;right:10px;bottom:10px;background:rgba(0,0,0,.65);
  border:1px solid rgba(255,255,255,.12);color:var(--text);
  padding:4px 9px;border-radius:20px;font-size:.68rem;font-weight:600;
  letter-spacing:.06em;text-transform:uppercase;
}
.portfolio-page{background:var(--bg-deep);border-top:1px solid var(--border);}
.portfolio-public-grid{
  display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));
  gap:18px;
}
.portfolio-public-grid .project-card{border:1px solid var(--border);border-radius:4px;}
.public-detail-modal{padding:24px;overflow-y:auto;}
.public-detail{
  width:min(1040px,96vw);max-height:92vh;overflow:auto;background:var(--bg-card);
  border:1px solid var(--border-bright);border-radius:4px;position:relative;
}
.public-detail-media{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));
  gap:2px;background:var(--border);
}
.public-detail-media img{
  width:100%;height:320px;object-fit:cover;background:var(--bg-card2);
}
.public-detail-empty{
  min-height:260px;display:flex;align-items:center;justify-content:center;
  color:var(--text-dim);background:var(--bg-card2);
}
.public-detail-body{padding:34px 38px;}
.public-detail-body h2{
  font-family:'Cormorant Garamond',serif;font-size:2.4rem;font-weight:300;
  color:var(--text);margin:8px 0 14px;
}
.public-detail-body p{color:var(--text-dim);line-height:1.8;}
.public-detail-price{
  display:inline-flex;margin-bottom:18px;color:var(--gold);font-size:1.15rem;
  font-weight:600;border:1px solid var(--border-bright);padding:8px 14px;
  border-radius:3px;
}

/* CONTACT SECTION */
.contact-section{background:var(--bg-card);border-top:1px solid var(--border);border-bottom:1px solid var(--border);}
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:start;}
.contact-info h2{font-family:'Cormorant Garamond',serif;font-size:2.5rem;font-weight:300;margin-bottom:20px;}
.contact-info p{color:var(--text-dim);line-height:1.8;margin-bottom:32px;}
.contact-detail{display:flex;align-items:center;gap:14px;margin-bottom:16px;color:var(--text-mid);font-size:.9rem;}
.contact-detail-icon{color:var(--gold);font-size:1.1rem;width:20px;text-align:center;}
.contact-form{display:flex;flex-direction:column;gap:14px;}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px;}
.form-group{display:flex;flex-direction:column;gap:6px;}
.form-label{font-size:.75rem;letter-spacing:.1em;text-transform:uppercase;color:var(--text-dim);}
.form-input,.form-textarea,.form-select{
  background:var(--bg-deep);border:1px solid var(--border);
  color:var(--text);padding:12px 16px;border-radius:2px;
  font-family:'Outfit',sans-serif;font-size:.9rem;
  transition:.2s;outline:none;
}
.form-input:focus,.form-textarea:focus,.form-select:focus{border-color:var(--gold-dim);}
.form-textarea{resize:vertical;min-height:120px;}
.form-select{cursor:pointer;}
option{background:var(--bg-card);}

/* FOOTER */
.footer{
  padding:40px 60px;display:flex;align-items:center;justify-content:space-between;
  border-top:1px solid var(--border);
}
.footer-copy{color:var(--text-dim);font-size:.8rem;}
.footer-brand{font-family:'Cormorant Garamond',serif;font-size:1.2rem;color:var(--gold);}

/* ═══════════════════════════
   LOGIN MODAL
═══════════════════════════ */
.modal-overlay{
  position:fixed;inset:0;background:rgba(0,0,0,.85);
  display:none;align-items:center;justify-content:center;z-index:1000;
  backdrop-filter:blur(8px);
}
.modal-overlay.active{display:flex;}
.modal{
  background:var(--bg-card);border:1px solid var(--border-bright);
  padding:48px;width:420px;position:relative;border-radius:4px;
}
.modal-close{
  position:absolute;top:16px;right:16px;background:none;border:none;
  color:var(--text-dim);cursor:pointer;font-size:1.3rem;transition:.2s;
}
.modal-close:hover{color:var(--gold);}
.modal-logo{display:flex;align-items:center;justify-content:center;margin-bottom:32px;}
.modal-logo img{height:56px;border-radius:50%;border:1px solid var(--border-bright);}
.modal-title{font-family:'Cormorant Garamond',serif;font-size:1.8rem;text-align:center;margin-bottom:6px;}
.modal-sub{font-size:.8rem;color:var(--text-dim);text-align:center;margin-bottom:32px;letter-spacing:.05em;}
.modal-btn-discord{
  width:100%;padding:14px;
  background:linear-gradient(135deg,#5865F2,#4752C4);
  border:none;color:white;cursor:pointer;border-radius:3px;
  font-family:'Outfit',sans-serif;font-size:.9rem;font-weight:600;
  letter-spacing:.05em;display:flex;align-items:center;justify-content:center;gap:10px;
  transition:.2s;
}
.modal-btn-discord:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(88,101,242,.4);}
.modal-divider{display:flex;align-items:center;gap:12px;margin:20px 0;}
.modal-divider::before,.modal-divider::after{content:'';flex:1;height:1px;background:var(--border);}
.modal-divider span{color:var(--text-dim);font-size:.75rem;text-transform:uppercase;letter-spacing:.1em;}
.modal-form{display:flex;flex-direction:column;gap:12px;}
.modal-err{background:rgba(192,57,43,.15);border:1px solid rgba(192,57,43,.3);color:#e74c3c;padding:10px 14px;border-radius:2px;font-size:.82rem;display:none;}

/* ═══════════════════════════
   APP DASHBOARD
═══════════════════════════ */
.app-layout{display:flex;height:100vh;overflow:hidden;}

/* SIDEBAR */
.sidebar{
  width:var(--sidebar-w);min-width:var(--sidebar-w);
  background:var(--bg-card);border-right:1px solid var(--border);
  display:flex;flex-direction:column;overflow-y:auto;
}
.sidebar-header{
  padding:24px 20px;border-bottom:1px solid var(--border);
  display:flex;align-items:center;gap:12px;
}
.sidebar-header img{height:36px;width:36px;object-fit:contain;border-radius:50%;border:1px solid var(--border-bright);}
.sidebar-brand{font-family:'Cormorant Garamond',serif;color:var(--gold);font-size:1.1rem;font-weight:600;}
.sidebar-nav{padding:16px 0;flex:1;}
.nav-section{margin-bottom:8px;}
.nav-section-label{
  font-size:.65rem;letter-spacing:.2em;text-transform:uppercase;
  color:var(--text-dim);padding:8px 20px 4px;
}
.nav-item{
  display:flex;align-items:center;gap:12px;
  padding:10px 20px;cursor:pointer;transition:.15s;
  color:var(--text-dim);font-size:.88rem;
  border-left:2px solid transparent;
}
.nav-item:hover{background:rgba(201,168,76,.05);color:var(--text-mid);}
.nav-item.active{
  background:rgba(201,168,76,.08);color:var(--gold);
  border-left-color:var(--gold);
}
.nav-item-icon{width:18px;text-align:center;font-size:.95rem;}
.sidebar-footer{
  padding:16px 20px;border-top:1px solid var(--border);
}
.user-info{display:flex;align-items:center;gap:10px;}
.user-avatar{
  width:32px;height:32px;border-radius:50%;
  background:linear-gradient(135deg,var(--gold-dim),var(--gold));
  display:flex;align-items:center;justify-content:center;
  font-size:.8rem;font-weight:700;color:var(--bg-deep);
}
.user-name{font-size:.82rem;color:var(--text-mid);}
.user-role{font-size:.7rem;color:var(--text-dim);}
.btn-logout{
  margin-top:10px;width:100%;padding:8px;background:none;
  border:1px solid rgba(192,57,43,.3);color:#c0392b;
  cursor:pointer;border-radius:2px;font-size:.78rem;
  transition:.2s;font-family:'Outfit',sans-serif;
}
.btn-logout:hover{background:rgba(192,57,43,.1);}

/* MAIN CONTENT */
.main-content{flex:1;overflow-y:auto;display:flex;flex-direction:column;}
.topbar{
  padding:0 32px;height:60px;display:flex;align-items:center;
  justify-content:space-between;border-bottom:1px solid var(--border);
  background:var(--bg-card);position:sticky;top:0;z-index:10;
}
.topbar-title{font-family:'Cormorant Garamond',serif;font-size:1.5rem;font-weight:300;color:var(--text);}
.topbar-actions{display:flex;gap:10px;align-items:center;}
.page-content{padding:28px 32px;flex:1;}

/* ─── DASHBOARD ─── */
.dash-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:28px;}
.stat-card{
  background:var(--bg-card);border:1px solid var(--border);
  padding:22px 24px;border-radius:4px;position:relative;overflow:hidden;
}
.stat-card::before{
  content:'';position:absolute;top:0;left:0;right:0;height:2px;
}
.stat-card.gold::before{background:linear-gradient(90deg,var(--gold-dim),var(--gold));}
.stat-card.green::before{background:linear-gradient(90deg,#1a5c35,var(--green));}
.stat-card.blue::before{background:linear-gradient(90deg,#1a3a5c,var(--blue));}
.stat-card.orange::before{background:linear-gradient(90deg,#5c3010,var(--orange));}
.stat-label{font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;color:var(--text-dim);margin-bottom:8px;}
.stat-value{font-family:'Cormorant Garamond',serif;font-size:2.2rem;color:var(--text);font-weight:300;}
.stat-delta{font-size:.75rem;margin-top:6px;}
.stat-delta.pos{color:var(--green);}
.stat-delta.neg{color:var(--red);}
.dash-row{display:grid;grid-template-columns:1.5fr 1fr;gap:16px;}
.dash-panel{background:var(--bg-card);border:1px solid var(--border);border-radius:4px;overflow:hidden;}
.dash-panel-header{
  padding:16px 20px;border-bottom:1px solid var(--border);
  display:flex;align-items:center;justify-content:space-between;
}
.dash-panel-title{font-size:.82rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--text-mid);}
.dash-panel-body{padding:16px 20px;}
.recent-item{
  display:flex;align-items:center;justify-content:space-between;
  padding:10px 0;border-bottom:1px solid var(--border);font-size:.85rem;
}
.recent-item:last-child{border-bottom:none;}
.recent-name{color:var(--text);}
.recent-meta{color:var(--text-dim);font-size:.78rem;}

/* ─── ÉTIQUETTES ─── */
.tag{
  display:inline-flex;align-items:center;gap:4px;
  padding:3px 10px;border-radius:20px;font-size:.7rem;
  font-weight:600;letter-spacing:.05em;text-transform:uppercase;white-space:nowrap;
}
.tag-urgent{background:rgba(192,57,43,.2);color:#e74c3c;border:1px solid rgba(192,57,43,.3);}
.tag-en-cours{background:rgba(41,128,185,.2);color:#3498db;border:1px solid rgba(41,128,185,.3);}
.tag-fini{background:rgba(39,174,96,.2);color:#2ecc71;border:1px solid rgba(39,174,96,.3);}
.tag-pas-commence{background:rgba(127,140,141,.2);color:#95a5a6;border:1px solid rgba(127,140,141,.3);}
.tag-admin{background:rgba(142,68,173,.2);color:#9b59b6;border:1px solid rgba(142,68,173,.3);}
.tag-joueur{background:rgba(201,168,76,.2);color:var(--gold);border:1px solid var(--border-bright);}
.tag-pause{background:rgba(230,126,34,.2);color:#e67e22;border:1px solid rgba(230,126,34,.3);}

/* ─── PROJETS ─── */
.toolbar{display:flex;align-items:center;gap:12px;margin-bottom:22px;flex-wrap:wrap;}
.view-toggle{display:flex;border:1px solid var(--border);border-radius:3px;overflow:hidden;}
.view-btn{
  background:none;border:none;color:var(--text-dim);
  padding:7px 14px;cursor:pointer;font-size:.8rem;transition:.15s;
  font-family:'Outfit',sans-serif;letter-spacing:.05em;
}
.view-btn.active{background:var(--gold);color:var(--bg-deep);font-weight:600;}
.filter-select{
  background:var(--bg-card);border:1px solid var(--border);
  color:var(--text-mid);padding:7px 14px;border-radius:3px;
  font-family:'Outfit',sans-serif;font-size:.82rem;outline:none;cursor:pointer;
}
.btn-sm{
  padding:7px 16px;border:1px solid var(--border-bright);background:none;
  color:var(--gold);border-radius:3px;cursor:pointer;font-size:.8rem;
  font-family:'Outfit',sans-serif;letter-spacing:.06em;transition:.2s;
}
.btn-sm:hover{background:var(--gold);color:var(--bg-deep);}
.btn-sm.danger{border-color:rgba(192,57,43,.4);color:#e74c3c;}
.btn-sm.danger:hover{background:#c0392b;color:white;}

/* Liste projets */
.projects-list{display:flex;flex-direction:column;gap:10px;}
.project-row{
  background:var(--bg-card);border:1px solid var(--border);
  border-radius:4px;padding:16px 20px;
  display:flex;align-items:center;gap:16px;
  transition:.2s;cursor:pointer;
}
.project-row:hover{border-color:var(--border-bright);}
.project-row.finished{opacity:.45;filter:grayscale(40%);}
.project-row-name{flex:1;font-size:.92rem;color:var(--text);}
.project-row-type{font-size:.78rem;color:var(--text-dim);width:150px;}
.project-row-date{font-size:.78rem;color:var(--text-dim);width:100px;}
.project-row-price{font-size:.88rem;color:var(--gold);width:100px;text-align:right;}
.project-row-tags{display:flex;gap:6px;flex-wrap:wrap;width:200px;}

/* Cards projets */
.projects-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:16px;}
.project-card-admin{
  background:var(--bg-card);border:1px solid var(--border);
  border-radius:4px;overflow:hidden;transition:.2s;cursor:pointer;
}
.project-card-admin:hover{border-color:var(--border-bright);transform:translateY(-2px);}
.project-card-admin.finished{opacity:.45;filter:grayscale(40%);}
.pca-img{
  height:140px;background:linear-gradient(135deg,var(--bg-card2),rgba(201,168,76,.08));
  display:flex;align-items:center;justify-content:center;font-size:2.5rem;color:var(--gold-dim);
  overflow:hidden;
}
.pca-img img{width:100%;height:100%;object-fit:cover;}
.pca-body{padding:16px;}
.pca-name{font-family:'Cormorant Garamond',serif;font-size:1.15rem;margin-bottom:4px;}
.pca-meta{font-size:.75rem;color:var(--text-dim);margin-bottom:10px;}
.pca-tags{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:10px;}
.pca-footer{display:flex;align-items:center;justify-content:space-between;margin-top:8px;}
.pca-price{color:var(--gold);font-size:.9rem;font-weight:600;}
.pca-date{font-size:.75rem;color:var(--text-dim);}

/* Gantt */
.gantt-wrapper{overflow-x:auto;}
.gantt-table{min-width:900px;border-collapse:collapse;}
.gantt-table th{
  font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;
  color:var(--text-dim);padding:8px 10px;border-bottom:1px solid var(--border);
  font-weight:500;background:var(--bg-card);position:sticky;top:0;
}
.gantt-table td{padding:8px 10px;border-bottom:1px solid rgba(201,168,76,.06);}
.gantt-name{font-size:.85rem;color:var(--text);white-space:nowrap;}
.gantt-bar-cell{min-width:500px;position:relative;height:36px;}
.gantt-bar{
  position:absolute;height:22px;top:7px;
  background:linear-gradient(90deg,var(--gold-dim),var(--gold));
  border-radius:3px;display:flex;align-items:center;padding:0 8px;
  font-size:.72rem;color:var(--bg-deep);font-weight:600;white-space:nowrap;
  overflow:hidden;min-width:4px;transition:.3s;
}
.gantt-bar:hover{filter:brightness(1.15);}

/* ─── COMPTABILITÉ ─── */
.compta-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:24px;}
.months-list{display:flex;flex-direction:column;gap:10px;}
.month-row{
  background:var(--bg-card);border:1px solid var(--border);border-radius:4px;
  overflow:hidden;
}
.month-header{
  padding:14px 20px;display:flex;align-items:center;justify-content:space-between;
  cursor:pointer;transition:.15s;
}
.month-header:hover{background:var(--bg-card2);}
.month-title{font-family:'Cormorant Garamond',serif;font-size:1.1rem;}
.month-summary{display:flex;gap:20px;align-items:center;}
.month-rec{color:var(--green);font-size:.85rem;}
.month-dep{color:var(--red);font-size:.85rem;}
.month-bal{font-weight:600;font-size:.9rem;}
.month-body{padding:16px 20px;border-top:1px solid var(--border);display:none;}
.month-body.open{display:block;}
.entries-table{width:100%;border-collapse:collapse;margin-bottom:14px;}
.entries-table th{
  font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;
  color:var(--text-dim);padding:6px 10px;border-bottom:1px solid var(--border);
  text-align:left;font-weight:500;
}
.entries-table td{padding:8px 10px;border-bottom:1px solid rgba(201,168,76,.05);font-size:.85rem;}
.entries-table tr:hover td{background:rgba(201,168,76,.03);}
.entry-link{color:var(--gold);cursor:pointer;text-decoration:underline;text-decoration-color:transparent;transition:.2s;}
.entry-link:hover{text-decoration-color:var(--gold);}
.entry-plus{color:var(--green);}
.entry-minus{color:var(--red);}
.add-entry-btn{
  display:inline-flex;align-items:center;gap:6px;
  background:none;border:1px dashed var(--border-bright);
  color:var(--gold);padding:7px 16px;cursor:pointer;border-radius:3px;
  font-size:.8rem;font-family:'Outfit',sans-serif;transition:.2s;
}
.add-entry-btn:hover{background:rgba(201,168,76,.08);}

/* ─── DEVIS ─── */
.devis-tabs{display:flex;gap:0;border-bottom:1px solid var(--border);margin-bottom:24px;}
.devis-tab{
  padding:10px 24px;cursor:pointer;font-size:.85rem;
  color:var(--text-dim);border-bottom:2px solid transparent;transition:.2s;
}
.devis-tab.active{color:var(--gold);border-bottom-color:var(--gold);}
.devis-list{display:flex;flex-direction:column;gap:10px;}
.devis-row{
  background:var(--bg-card);border:1px solid var(--border);
  border-radius:4px;padding:16px 20px;
  display:flex;align-items:center;justify-content:space-between;gap:16px;
}
.devis-row-info{flex:1;}
.devis-row-name{font-size:.92rem;color:var(--text);margin-bottom:3px;}
.devis-row-meta{font-size:.76rem;color:var(--text-dim);}
.devis-row-amount{color:var(--gold);font-size:.9rem;font-weight:600;margin-right:16px;}
.devis-status{padding:3px 12px;border-radius:20px;font-size:.7rem;font-weight:600;}
.status-attente{background:rgba(230,126,34,.15);color:#e67e22;border:1px solid rgba(230,126,34,.3);}
.status-accepte{background:rgba(39,174,96,.15);color:#2ecc71;border:1px solid rgba(39,174,96,.3);}
.status-refuse{background:rgba(192,57,43,.15);color:#e74c3c;border:1px solid rgba(192,57,43,.3);}

/* Formulaire devis */
.devis-form-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px;max-width:900px;}
.devis-form-full{grid-column:1/-1;}
.lignes-header{
  display:grid;grid-template-columns:1fr 80px 110px 110px 40px;gap:8px;
  font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;color:var(--text-dim);
  padding:0 0 8px;border-bottom:1px solid var(--border);
}
.ligne-row{display:grid;grid-template-columns:1fr 80px 110px 110px 40px;gap:8px;margin-bottom:8px;align-items:center;}
.ligne-input{
  background:var(--bg-deep);border:1px solid var(--border);
  color:var(--text);padding:9px 12px;border-radius:2px;
  font-family:'Outfit',sans-serif;font-size:.85rem;outline:none;width:100%;
  transition:.2s;
}
.ligne-input:focus{border-color:var(--gold-dim);}
.btn-remove-ligne{
  background:none;border:1px solid rgba(192,57,43,.3);color:#e74c3c;
  width:32px;height:32px;border-radius:2px;cursor:pointer;font-size:1rem;
  display:flex;align-items:center;justify-content:center;transition:.2s;
}
.btn-remove-ligne:hover{background:rgba(192,57,43,.15);}
.devis-total-row{
  display:flex;align-items:center;justify-content:flex-end;gap:16px;
  margin-top:12px;padding-top:12px;border-top:1px solid var(--border);
}
.devis-total-label{font-size:.85rem;color:var(--text-dim);letter-spacing:.08em;text-transform:uppercase;}
.devis-total-value{font-family:'Cormorant Garamond',serif;font-size:2rem;color:var(--gold);}

/* ─── PARAMÈTRES ─── */
.params-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px;max-width:860px;}
.param-card{background:var(--bg-card);border:1px solid var(--border);border-radius:4px;padding:24px;}
.param-card-title{font-size:.82rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--text-mid);margin-bottom:18px;padding-bottom:12px;border-bottom:1px solid var(--border);}
.param-row{display:flex;justify-content:space-between;align-items:center;padding:10px 0;border-bottom:1px solid rgba(201,168,76,.06);}
.param-row:last-child{border-bottom:none;}
.param-label{font-size:.85rem;color:var(--text-mid);}
.param-value{font-size:.85rem;color:var(--text-dim);}
.param-users-list{display:flex;flex-direction:column;gap:8px;}
.param-user-row{display:flex;align-items:center;gap:10px;padding:8px 0;}
.param-user-avatar{width:28px;height:28px;border-radius:50%;background:linear-gradient(135deg,var(--gold-dim),var(--gold));display:flex;align-items:center;justify-content:center;font-size:.72rem;font-weight:700;color:var(--bg-deep);}

/* ─── MODAL PROJET ─── */
.project-modal-overlay{
  position:fixed;inset:0;background:rgba(0,0,0,.8);
  display:none;align-items:center;justify-content:center;z-index:500;
  backdrop-filter:blur(6px);overflow-y:auto;padding:20px;
}
.project-modal-overlay.active{display:flex;}
.project-modal{
  background:var(--bg-card);border:1px solid var(--border-bright);
  border-radius:6px;width:100%;max-width:680px;padding:36px;
  position:relative;max-height:90vh;overflow-y:auto;
}
.pm-title{font-family:'Cormorant Garamond',serif;font-size:1.8rem;margin-bottom:24px;color:var(--text);}
.pm-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;}
.pm-full{grid-column:1/-1;}
.pm-section{margin-top:18px;}
.pm-section-title{font-size:.75rem;letter-spacing:.15em;text-transform:uppercase;color:var(--gold);margin-bottom:10px;}
.etapes-list{display:flex;flex-direction:column;gap:6px;margin-bottom:10px;}
.etape-row{display:flex;align-items:center;gap:8px;}
.etape-input{
  flex:1;background:var(--bg-deep);border:1px solid var(--border);
  color:var(--text);padding:8px 12px;border-radius:2px;
  font-family:'Outfit',sans-serif;font-size:.85rem;outline:none;
}
.etape-check{width:16px;height:16px;cursor:pointer;accent-color:var(--gold);}
.tags-selector{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:8px;}
.tag-option{cursor:pointer;opacity:.5;transition:.15s;user-select:none;}
.tag-option.selected{opacity:1;}
.tag-option:hover{opacity:.8;}

/* ─── DETAIL PROJET ─── */
.detail-overlay{
  position:fixed;inset:0;background:rgba(0,0,0,.8);
  display:none;align-items:flex-start;justify-content:center;z-index:400;
  backdrop-filter:blur(6px);overflow-y:auto;padding:20px;
}
.detail-overlay.active{display:flex;}
.detail-modal{
  background:var(--bg-card);border:1px solid var(--border-bright);
  border-radius:6px;width:100%;max-width:760px;padding:36px;
  position:relative;margin:auto;
}
.detail-close{
  position:absolute;top:16px;right:16px;
  background:none;border:none;color:var(--text-dim);cursor:pointer;font-size:1.4rem;
  transition:.2s;
}
.detail-close:hover{color:var(--gold);}
.detail-title{font-family:'Cormorant Garamond',serif;font-size:2.2rem;margin-bottom:6px;}
.detail-meta{font-size:.82rem;color:var(--text-dim);margin-bottom:20px;}
.detail-tags{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:24px;}
.detail-grid{display:grid;grid-template-columns:1.2fr 1fr;gap:24px;}
.detail-section-title{font-size:.72rem;letter-spacing:.15em;text-transform:uppercase;color:var(--gold);margin-bottom:12px;}
.detail-desc{font-size:.88rem;color:var(--text-mid);line-height:1.7;}
.detail-img{width:100%;border-radius:4px;border:1px solid var(--border);}
.detail-price{font-family:'Cormorant Garamond',serif;font-size:2.5rem;color:var(--gold);margin-bottom:4px;}
.etape-item{display:flex;align-items:center;gap:10px;padding:8px 0;border-bottom:1px solid rgba(201,168,76,.06);}
.etape-item:last-child{border-bottom:none;}
.etape-check-display{width:16px;height:16px;border:1px solid var(--border-bright);border-radius:2px;display:flex;align-items:center;justify-content:center;font-size:.65rem;color:var(--gold);}
.etape-check-display.done{background:var(--gold);color:var(--bg-deep);}
.etape-text{font-size:.85rem;color:var(--text-mid);}
.etape-text.done{text-decoration:line-through;color:var(--text-dim);}

/* ─── MINI TOAST ─── */
.toast{
  position:fixed;bottom:30px;right:30px;
  background:var(--bg-card);border:1px solid var(--border-bright);
  padding:14px 20px;border-radius:4px;font-size:.85rem;
  color:var(--text);z-index:9000;opacity:0;transform:translateY(10px);
  transition:.3s;pointer-events:none;
}
.toast.show{opacity:1;transform:translateY(0);}
.toast.success{border-left:3px solid var(--green);}
.toast.error{border-left:3px solid var(--red);}

/* ─── RESPONSIVE ─── */
@media(max-width:768px){
  .nav-vitrine{padding:0 20px;}
  .section{padding:60px 20px;}
  .contact-grid{grid-template-columns:1fr;}
  .dash-grid{grid-template-columns:1fr 1fr;}
  .dash-row{grid-template-columns:1fr;}
  .sidebar{width:200px;min-width:200px;}
  .hero-title{font-size:3rem;}
  .devis-form-grid{grid-template-columns:1fr;}
  .params-grid{grid-template-columns:1fr;}
  .public-detail{max-height:94vh;}
  .public-detail-media{grid-template-columns:1fr;}
  .public-detail-media img{height:230px;}
  .public-detail-body{padding:26px 22px;}
  .public-detail-body h2{font-size:1.9rem;}
}

/* ─── ANIMATIONS ─── */
@keyframes fadeUp{from{opacity:0;transform:translateY(20px);}to{opacity:1;transform:translateY(0);}}
.fade-up{animation:fadeUp .5s ease forwards;}
.fade-up-1{animation-delay:.1s;opacity:0;}
.fade-up-2{animation-delay:.2s;opacity:0;}
.fade-up-3{animation-delay:.35s;opacity:0;}
.fade-up-4{animation-delay:.5s;opacity:0;}

/* ─── EMPTY STATE ─── */
.empty-state{
  text-align:center;padding:60px 20px;
  color:var(--text-dim);
}
.empty-icon{font-size:3rem;margin-bottom:16px;opacity:.4;}
.empty-text{font-family:'Cormorant Garamond',serif;font-size:1.4rem;color:var(--text-mid);}
.empty-sub{font-size:.82rem;margin-top:6px;}

