body.devis-body{
  background:#050505;
  color:white;
}

.devis-topbar{
  position:sticky;
  top:0;
  z-index:50;
  display:flex;
  justify-content:space-between;
  align-items:center;
  padding:18px 8%;
  background:rgba(0,0,0,.78);
  backdrop-filter:blur(18px);
  border-bottom:1px solid rgba(255,255,255,.08);
}

.devis-brand img{
  width:120px;
  filter:invert(1);
}

.devis-actions-top{
  display:flex;
  gap:12px;
  align-items:center;
}

.small-btn,.main-btn{
  border:1px solid rgba(255,255,255,.14);
  background:rgba(255,255,255,.06);
  color:#fff;
  border-radius:999px;
  padding:12px 18px;
  font-weight:800;
  cursor:pointer;
  transition:.25s;
  display:inline-flex;
  align-items:center;
  justify-content:center;
}

.small-btn:hover,.main-btn:hover{
  transform:translateY(-2px);
  border-color:rgba(255,255,255,.28);
}

.white-btn,.main-btn{
  background:#fff;
  color:#000;
}

.devis-app{
  padding:70px 8% 100px;
}

.devis-hero-panel{
  padding:42px;
  border-radius:32px;
  background:radial-gradient(circle at 30% 20%,rgba(255,255,255,.14),transparent 34%),linear-gradient(180deg,rgba(255,255,255,.08),rgba(255,255,255,.025));
  border:1px solid rgba(255,255,255,.1);
  margin-bottom:24px;
}

.devis-hero-panel h1{
  font-size:clamp(38px,6vw,76px);
  line-height:.95;
  letter-spacing:-.06em;
  max-width:950px;
}

.devis-hero-panel p:not(.label){
  max-width:850px;
  margin-top:18px;
  color:rgba(255,255,255,.68);
  line-height:1.7;
  font-size:18px;
}

.stats-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:16px;
  margin-bottom:24px;
}

.stat-card,.quote-list-panel,.quote-editor{
  border:1px solid rgba(255,255,255,.1);
  background:linear-gradient(180deg,rgba(255,255,255,.08),rgba(255,255,255,.025));
  border-radius:28px;
  box-shadow:0 24px 90px rgba(0,0,0,.3);
}

.stat-card{
  padding:24px;
}

.stat-card span{
  display:block;
  font-size:38px;
  font-weight:900;
  letter-spacing:-.04em;
}

.stat-card p{
  color:rgba(255,255,255,.62);
}

.devis-layout{
  display:grid;
  grid-template-columns:360px 1fr;
  gap:20px;
  align-items:start;
}

.quote-list-panel,.quote-editor{
  padding:24px;
}

.panel-head{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:16px;
  margin-bottom:22px;
}

.panel-head h2{
  font-size:28px;
  margin:0;
}

#quoteNumberBadge{
  padding:10px 14px;
  border-radius:999px;
  background:rgba(255,255,255,.08);
  color:rgba(255,255,255,.78);
  font-weight:900;
}

#searchQuote{
  width:100%;
  padding:13px 14px;
  border-radius:16px;
  border:1px solid rgba(255,255,255,.12);
  background:rgba(0,0,0,.34);
  color:white;
  outline:none;
}

.quote-list{
  display:flex;
  flex-direction:column;
  gap:10px;
  max-height:760px;
  overflow:auto;
  padding-right:4px;
}

.quote-item{
  padding:15px;
  border-radius:18px;
  border:1px solid rgba(255,255,255,.08);
  background:rgba(255,255,255,.04);
  cursor:pointer;
  transition:.25s;
}

.quote-item:hover,.quote-item.active{
  background:rgba(255,255,255,.1);
  transform:translateX(4px);
}

.quote-item strong{
  display:block;
  margin-bottom:6px;
}

.quote-item span{
  color:rgba(255,255,255,.58);
  font-size:13px;
}

.quote-editor h3{
  margin:28px 0 14px;
  font-size:22px;
}

.form-grid{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:14px;
}

label{
  display:flex;
  flex-direction:column;
  gap:8px;
  color:rgba(255,255,255,.72);
  font-weight:700;
  font-size:14px;
}

.full{
  grid-column:1/-1;
}

input,select,textarea{
  width:100%;
  padding:15px 16px;
  border-radius:16px;
  border:1px solid rgba(255,255,255,.12);
  background:rgba(0,0,0,.34);
  color:white;
  outline:none;
  font-size:15px;
}

textarea{
  min-height:110px;
  resize:vertical;
}

.items-head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
}

.item-row{
  display:grid;
  grid-template-columns:1fr 90px 130px 44px;
  gap:10px;
  margin-bottom:10px;
}

.remove-line{
  border:1px solid rgba(255,255,255,.12);
  background:rgba(255,255,255,.06);
  color:white;
  border-radius:14px;
  cursor:pointer;
}

.totals-box{
  margin-top:24px;
  margin-left:auto;
  max-width:430px;
  display:grid;
  gap:10px;
}

.totals-box div{
  display:flex;
  justify-content:space-between;
  padding:14px 16px;
  border-radius:16px;
  background:rgba(255,255,255,.06);
  color:rgba(255,255,255,.72);
}

.totals-box .grand-total{
  background:#fff;
  color:#000;
  font-size:22px;
  font-weight:900;
}

.editor-buttons{
  display:flex;
  flex-wrap:wrap;
  gap:12px;
  margin-top:24px;
}

.dark-main{
  background:rgba(255,255,255,.06);
  color:#fff;
}

.danger-main{
  background:rgba(239,68,68,.12);
  color:#fff;
  border-color:rgba(239,68,68,.35);
}

.toast{
  position:fixed;
  right:28px;
  bottom:28px;
  padding:16px 20px;
  border-radius:18px;
  background:#fff;
  color:#000;
  font-weight:900;
  box-shadow:0 20px 80px rgba(0,0,0,.45);
  transform:translateY(30px);
  opacity:0;
  pointer-events:none;
  transition:.35s;
  z-index:200;
}

.toast.show{
  transform:translateY(0);
  opacity:1;
}

.print-area{
  display:none;
}

@media(max-width:1050px){
  .stats-grid,.devis-layout{
    grid-template-columns:1fr;
  }
  .form-grid,.item-row{
    grid-template-columns:1fr;
  }
  .devis-app,.devis-topbar{
    padding-left:5%;
    padding-right:5%;
  }
  .panel-head,.items-head{
    flex-direction:column;
    align-items:flex-start;
  }
}

@media print{
  .no-print,.devis-app,.devis-topbar,.toast{
    display:none!important;
  }
  body{
    background:#fff!important;
    color:#000!important;
  }
  .print-area{
    display:block!important;
  }
  .print-page{
    width:210mm;
    min-height:297mm;
    padding:18mm;
    background:white;
    color:#000;
    font-family:Arial,sans-serif;
  }
  .print-header{
    display:flex;
    justify-content:space-between;
    align-items:flex-start;
    border-bottom:2px solid #000;
    padding-bottom:18px;
    margin-bottom:26px;
  }
  .print-header img{
    width:155px;
    filter:invert(1);
  }
  .print-header p,.print-parties p,.print-project p,.print-notes p,.print-footer p{
    color:#222!important;
    line-height:1.5;
  }
  .print-meta{
    text-align:right;
  }
  .print-meta h2{
    font-size:42px;
    margin:0 0 8px;
    letter-spacing:-.04em;
  }
  .print-parties{
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:20px;
    margin-bottom:26px;
  }
  .print-parties div,.print-project,.print-notes{
    border:1px solid #ddd;
    border-radius:12px;
    padding:14px;
  }
  .print-table{
    width:100%;
    border-collapse:collapse;
    margin:24px 0;
  }
  .print-table th,.print-table td{
    border-bottom:1px solid #ddd;
    padding:12px;
    text-align:left;
  }
  .print-table th{
    background:#f4f4f4;
  }
  .print-total{
    margin-left:auto;
    width:270px;
    text-align:right;
  }
  .print-total h3{
    font-size:26px;
    margin-top:8px;
  }
  .print-footer{
    margin-top:34px;
    border-top:1px solid #ddd;
    padding-top:14px;
    font-size:13px;
  }
}

/* Admin login + backup */
body.locked .devis-topbar,
body.locked .devis-app,
body.locked .print-area,
body.locked .toast{
  display:none!important;
}

.admin-login{
  min-height:100vh;
  display:grid;
  place-items:center;
  padding:24px;
  background:
    radial-gradient(circle at 50% 15%,rgba(255,255,255,.14),transparent 28%),
    linear-gradient(180deg,#101010,#050505 72%);
}

.admin-login-card{
  width:min(520px,100%);
  padding:42px;
  border-radius:34px;
  text-align:center;
  border:1px solid rgba(255,255,255,.12);
  background:linear-gradient(180deg,rgba(255,255,255,.1),rgba(255,255,255,.03));
  box-shadow:0 30px 120px rgba(0,0,0,.45);
}

.admin-login-card img{
  width:190px;
  filter:invert(1);
  margin-bottom:24px;
}

.admin-login-card h1{
  font-size:clamp(38px,6vw,62px);
  line-height:1;
  letter-spacing:-.06em;
  margin-bottom:16px;
}

.admin-login-card p:not(.label){
  color:rgba(255,255,255,.68);
  line-height:1.7;
  margin-bottom:24px;
}

.admin-login-card input{
  text-align:center;
  margin-bottom:14px;
}

.admin-login-card button{
  width:100%;
  border:0;
  padding:16px 20px;
  border-radius:999px;
  background:#fff;
  color:#000;
  font-weight:900;
  cursor:pointer;
  transition:.25s;
}

.admin-login-card button:hover{
  transform:translateY(-3px);
}

#loginError{
  display:block;
  min-height:22px;
  margin-top:14px;
  color:#ff7777;
  font-weight:800;
}

.import-label{
  position:relative;
  overflow:hidden;
}

.import-label input{
  position:absolute;
  inset:0;
  opacity:0;
  cursor:pointer;
}

.backup-note{
  margin-top:16px;
  color:rgba(255,255,255,.58);
  font-size:14px;
}


/* V8 fixes */
body:not(.locked) .admin-login{
  display:none!important;
}

body.locked{
  overflow:hidden;
}

.devis-actions-top{
  flex-wrap:wrap;
}

@media print{
  body.printing-invoice #printQuote{
    display:none!important;
  }
  body.printing-quote #printInvoice{
    display:none!important;
  }
}


/* V9 invoice storage tabs */
.admin-tabs{
  display:flex;
  gap:12px;
  margin:0 0 24px;
}

.admin-tab{
  border:1px solid rgba(255,255,255,.14);
  background:rgba(255,255,255,.05);
  color:white;
  padding:13px 20px;
  border-radius:999px;
  font-weight:900;
  cursor:pointer;
  transition:.25s;
}

.admin-tab:hover{
  transform:translateY(-2px);
  border-color:rgba(255,255,255,.28);
}

.admin-tab.active{
  background:white;
  color:black;
}

.admin-view{
  display:none;
}

.admin-view.active-view{
  display:grid;
}

.invoices-view.active-view{
  display:block;
}

.invoice-panel{
  border:1px solid rgba(255,255,255,.1);
  background:linear-gradient(180deg,rgba(255,255,255,.08),rgba(255,255,255,.025));
  border-radius:28px;
  padding:24px;
  box-shadow:0 24px 90px rgba(0,0,0,.3);
}

.invoice-help{
  color:rgba(255,255,255,.62);
  line-height:1.7;
  margin:-8px 0 22px;
}

.invoice-list{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:16px;
}

.invoice-item{
  border:1px solid rgba(255,255,255,.09);
  background:rgba(255,255,255,.045);
  border-radius:24px;
  padding:20px;
  transition:.25s;
}

.invoice-item:hover{
  transform:translateY(-5px);
  border-color:rgba(255,255,255,.24);
}

.invoice-item strong{
  display:block;
  font-size:20px;
  margin-bottom:8px;
}

.invoice-item span{
  display:block;
  color:rgba(255,255,255,.62);
  line-height:1.6;
  font-size:14px;
}

.invoice-buttons{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  margin-top:16px;
}

.invoice-buttons button{
  border:1px solid rgba(255,255,255,.14);
  background:rgba(255,255,255,.06);
  color:#fff;
  border-radius:999px;
  padding:10px 14px;
  font-weight:800;
  cursor:pointer;
}

.invoice-buttons button:hover{
  background:#fff;
  color:#000;
}

.invoice-buttons .delete-invoice:hover{
  background:#ef4444;
  color:#fff;
}

@media(max-width:1050px){
  .invoice-list{
    grid-template-columns:1fr;
  }
}


/* V10 simplified admin + client access */
.devis-layout{
  grid-template-columns:320px 1fr;
}

.devis-hero-panel{
  padding:34px;
}

.devis-hero-panel h1{
  font-size:clamp(34px,5vw,60px);
}

.stats-grid{
  grid-template-columns:repeat(4,1fr);
}

.quote-editor,.quote-list-panel,.invoice-panel{
  border-radius:24px;
}

.client-access-box{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:16px;
  padding:18px;
  border-radius:20px;
  border:1px solid rgba(255,255,255,.1);
  background:rgba(255,255,255,.045);
  margin-bottom:18px;
}

.client-access-box strong{
  display:block;
  margin-bottom:8px;
}

.client-access-box p{
  color:rgba(255,255,255,.65);
  line-height:1.6;
}

.client-access-box span{
  color:#fff;
  font-weight:900;
}

.clients-view.active-view{
  display:block;
}

.manual-client-box{
  margin-bottom:22px;
  padding:20px;
  border:1px solid rgba(255,255,255,.1);
  border-radius:22px;
  background:rgba(255,255,255,.04);
}

.manual-client-box h3{
  margin-bottom:14px;
}

.manual-client-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:12px;
}

.manual-client-grid button{
  border:0;
  border-radius:16px;
  background:#fff;
  color:#000;
  font-weight:900;
  cursor:pointer;
}

.client-badge{
  display:inline-flex!important;
  width:max-content;
  margin-top:10px;
  padding:7px 10px;
  border-radius:999px;
  background:rgba(255,255,255,.08);
  color:white!important;
  font-weight:900;
}

.credentials-box{
  margin-top:14px;
  padding:12px;
  border-radius:16px;
  background:rgba(0,0,0,.28);
  border:1px solid rgba(255,255,255,.08);
}

.credentials-box span{
  font-size:13px;
  color:rgba(255,255,255,.72);
}

.signature-block{
  display:flex;
  justify-content:space-between;
  align-items:flex-end;
  gap:30px;
  margin-top:34px;
  padding-top:18px;
}

.signature-block p{
  margin:0 0 6px!important;
  color:#222!important;
}

.signature-line{
  min-width:190px;
  text-align:center;
  padding-top:22px;
  border-top:1px solid #111;
  font-family:cursive;
  font-size:24px;
  color:#111;
}

@media(max-width:1050px){
  .manual-client-grid{
    grid-template-columns:1fr;
  }
  .client-access-box{
    flex-direction:column;
    align-items:flex-start;
  }
}

/* V11 admin simplifié + signatures + paiements */
.admin-dashboard{
  display:flex;
  justify-content:space-between;
  gap:24px;
  align-items:flex-end;
  padding:34px;
  border-radius:30px;
  border:1px solid rgba(255,255,255,.1);
  background:radial-gradient(circle at 20% 15%,rgba(255,255,255,.13),transparent 34%),linear-gradient(180deg,rgba(255,255,255,.08),rgba(255,255,255,.025));
  margin-bottom:22px;
}
.admin-dashboard h1{font-size:clamp(36px,6vw,66px);line-height:.95;letter-spacing:-.06em;margin-bottom:14px}
.admin-dashboard p:not(.label){color:rgba(255,255,255,.68);line-height:1.7;max-width:720px}
.quick-actions{display:flex;gap:12px;flex-wrap:wrap}
.quick-actions button,.mini-switch{
  border:1px solid rgba(255,255,255,.14);
  background:#fff;color:#000;border-radius:999px;padding:13px 18px;font-weight:900;cursor:pointer
}
.recent-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:24px}
.recent-card{border:1px solid rgba(255,255,255,.1);background:linear-gradient(180deg,rgba(255,255,255,.08),rgba(255,255,255,.025));border-radius:24px;padding:22px}
.recent-line{display:flex;justify-content:space-between;gap:12px;padding:14px 0;border-bottom:1px solid rgba(255,255,255,.08)}
.recent-line:last-child{border-bottom:0}.recent-line strong{display:block}.recent-line span{color:rgba(255,255,255,.58);font-size:13px}
.signature-admin-box{display:grid;grid-template-columns:1fr 260px auto;gap:16px;align-items:center;padding:18px;border-radius:22px;border:1px solid rgba(255,255,255,.1);background:rgba(255,255,255,.045)}
.signature-admin-box p{color:rgba(255,255,255,.65);line-height:1.6}
.signature-preview{min-height:80px;display:grid;place-items:center;border-radius:16px;border:1px dashed rgba(255,255,255,.18);background:rgba(0,0,0,.22);font-family:cursive;font-size:26px;color:rgba(255,255,255,.8);padding:12px;text-align:center}
.payment-row{display:grid;grid-template-columns:1fr auto auto;gap:12px;align-items:center}
.payment-paid{color:#22c55e!important}.payment-pending{color:#f59e0b!important}
.signature-client-print{margin-top:28px}.signature-client-print p{color:#222!important;margin-bottom:8px!important}
.client-signature-print{min-height:62px;border:1px solid #ddd;border-radius:10px;padding:16px;font-family:cursive;font-size:24px;color:#111}
@media(max-width:1050px){.admin-dashboard,.recent-grid,.signature-admin-box{grid-template-columns:1fr;display:grid}.payment-row{grid-template-columns:1fr}}

/* V12 final admin/payments/factures */
.status-pill{
  display:inline-flex;
  padding:7px 11px;
  border-radius:999px;
  font-size:12px;
  font-weight:900;
  width:max-content;
}
.status-paid{background:rgba(34,197,94,.16);color:#22c55e!important;border:1px solid rgba(34,197,94,.28)}
.status-unpaid{background:rgba(239,68,68,.14);color:#ff6b6b!important;border:1px solid rgba(239,68,68,.25)}
.status-wait{background:rgba(245,158,11,.15);color:#fbbf24!important;border:1px solid rgba(245,158,11,.25)}

.invoice-item .invoice-buttons select{
  border:1px solid rgba(255,255,255,.14);
  background:rgba(0,0,0,.32);
  color:#fff;
  border-radius:999px;
  padding:10px 12px;
  font-weight:800;
}

.payment-admin-form{
  display:grid;
  grid-template-columns:1.2fr 160px 160px auto;
  gap:12px;
  margin-bottom:22px;
  padding:18px;
  border-radius:22px;
  border:1px solid rgba(255,255,255,.1);
  background:rgba(255,255,255,.04);
}
.payment-admin-form input,.payment-admin-form select{
  padding:14px 15px;
  border-radius:16px;
  border:1px solid rgba(255,255,255,.12);
  background:rgba(0,0,0,.34);
  color:#fff;
}
.payment-admin-form button{
  border:0;
  border-radius:16px;
  background:#fff;
  color:#000;
  font-weight:900;
  cursor:pointer;
}

.admin-view.active-view{
  animation:adminIn .35s ease;
}
@keyframes adminIn{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}

@media(max-width:1050px){
  .payment-admin-form{grid-template-columns:1fr}
}

@media print{
  .print-page{
    width:210mm!important;
    min-height:auto!important;
    padding:10mm!important;
    font-size:11px!important;
  }
  .print-header{
    padding-bottom:8px!important;
    margin-bottom:10px!important;
  }
  .print-header img{width:105px!important}
  .print-meta h2{font-size:30px!important}
  .print-parties{
    gap:10px!important;
    margin-bottom:10px!important;
  }
  .print-parties div,.print-project,.print-notes{
    padding:8px!important;
    border-radius:8px!important;
  }
  .print-project{margin-bottom:8px!important}
  .print-table{margin:10px 0!important}
  .print-table th,.print-table td{padding:7px!important}
  .print-total{width:230px!important}
  .print-total h3{font-size:20px!important}
  .signature-block{
    margin-top:12px!important;
    padding-top:8px!important;
  }
  .signature-line{
    min-width:150px!important;
    padding-top:12px!important;
    font-size:18px!important;
  }
  .signature-client-print{margin-top:12px!important}
  .client-signature-print{
    min-height:38px!important;
    padding:8px!important;
    font-size:18px!important;
  }
  .print-footer{
    margin-top:10px!important;
    padding-top:8px!important;
    font-size:10px!important;
  }
  .print-notes p,#pProjectDescription,#iDescription{
    line-height:1.25!important;
  }
}

/* V13 abonnements */
.subscription-form{
  display:grid;
  grid-template-columns:1.4fr 140px 160px 140px auto;
  gap:12px;
  margin-bottom:22px;
  padding:18px;
  border-radius:22px;
  border:1px solid rgba(255,255,255,.1);
  background:rgba(255,255,255,.04);
}
.subscription-form input,.subscription-form select{
  padding:14px 15px;
  border-radius:16px;
  border:1px solid rgba(255,255,255,.12);
  background:rgba(0,0,0,.34);
  color:#fff;
}
.subscription-form button{
  border:0;
  border-radius:16px;
  background:#fff;
  color:#000;
  font-weight:900;
  cursor:pointer;
}
@media(max-width:1050px){.subscription-form{grid-template-columns:1fr}}
