:root{
  --bg1:#0f1020; --bg2:#182744; --accent:#80E1FF; --white:#f6f7fb;
  --card-bg: rgba(255,255,255,.06); --card-bd: rgba(255,255,255,.14);
  --danger:#ff6b6b; --success:#2ecc71; --warning:#f39c12;
  --logo-url: url("https://sagra-graviere.fr/wp-content/uploads/2024/06/sagra-blanc-mobile.png");
  --hero-img: url("/assets/hero-sagra.jpg");
  --hero-pos: 90% center;
  --hero-opacity: .36;
}

/* --- HERO BG --- */
.hero-bg::before{
  content:""; position:absolute; inset:0;
  background:
    linear-gradient(120deg,
      rgba(10,14,26,.6),
      rgba(10,14,26,.4) 38%,
      rgba(10,14,26,.4) 62%,
      rgba(10,14,26,.6)
    ) no-repeat center/cover,
    var(--hero-img) no-repeat var(--hero-pos)/cover;
  opacity: var(--hero-opacity);
  filter: saturate(1.05) contrast(1.05) brightness(1.02);
}

*{box-sizing:border-box}

/* IMPORTANT: ne fige pas la hauteur au viewport initial */
html,body{
  min-height:100%;
}

body{
  margin:0; color:var(--white);
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, "Helvetica Neue", Arial, "Noto Sans";
  background:
    radial-gradient(1200px 800px at 20% 20%, #243b55 0%, transparent 60%),
    radial-gradient(1000px 700px at 80% 30%, #141e30 0%, transparent 60%),
    linear-gradient(120deg,var(--bg1),var(--bg2));
  /* le scroll doit rester possible */
  overflow-y:auto;
  overscroll-behavior-y:none;
  background-attachment:scroll; /* évite les bugs iOS avec fixed */
}

body::before, body::after{
  content:""; position:fixed; inset:-20%;
  background:
    radial-gradient(closest-side at 20% 30%, rgba(128,225,255,.25), transparent 70%),
    radial-gradient(closest-side at 80% 60%, rgba(208,128,255,.22), transparent 70%),
    radial-gradient(closest-side at 40% 80%, rgba(255,199,128,.18), transparent 70%);
  filter: blur(60px);
  animation: floatBlob 24s ease-in-out infinite alternate;
  pointer-events:none;
}
body::after{ animation-duration: 28s; animation-delay: -6s; }
@keyframes floatBlob{
  0%{transform:translate3d(0,0,0) scale(1)}
  100%{transform:translate3d(-2.5rem,-1.5rem,0) scale(1.05)}
}

/* --- HEADER --- */
.header{
  position:fixed; top:12px; left:12px; z-index:6; display:flex; align-items:center; gap:.6rem;
  padding:.45rem .7rem; border-radius:999px; background: var(--card-bg); border:1px solid var(--card-bd);
  backdrop-filter: blur(6px); box-shadow: 0 10px 24px rgba(0,0,0,.35); opacity:0; transform: translateY(-6px); transition:.3s;
}
body.loaded .header{ opacity:1; transform:none; }
.avatar{ width:26px; height:26px; border-radius:999px; display:grid; place-items:center; background: linear-gradient(135deg, var(--accent), #C1A3FF); }
.role{ font-weight:700; font-size:.95rem; }
.logout{ cursor:pointer; border:none; background:transparent; color:var(--white); opacity:.8; }
.logout:hover{ opacity:1; }

/* --- APP WRAPPER --- */
/* Ne pas utiliser height:100% ici : cause de contenu coupé sur iOS */
.app{
  position:relative; z-index:2;
  min-height:100svh;     /* ou 100dvh, au choix */
  height:auto;
  display:flex;
  align-items:flex-start; /* on évite le centrage vertical sur mobile */
  justify-content:center;
  opacity:0; transform: translateY(8px);
  transition: opacity .6s ease, transform .6s ease;
  padding: 2rem 1rem calc(2rem + env(safe-area-inset-bottom));
  text-align:center;
  overflow:visible;
}
body.loaded .app{ opacity:1; transform: translateY(0); }

/* Centrer verticalement seulement sur grands écrans */
@media (min-width: 900px){
  .app{ align-items:center; padding: 2rem; }
}

/* --- LOADING --- */
.loading-screen{
  position:fixed; inset:0; z-index:5; display:flex; align-items:center; justify-content:center; background:
  radial-gradient(1000px 600px at 50% 30%, rgba(255,255,255,.06), transparent 70%),
  linear-gradient(120deg, #0b1224 0%, #15233f 100%); transition: opacity .6s ease, visibility .6s ease;
}
body.loaded .loading-screen{ opacity:0; visibility:hidden; }
.loading-card{ width:min(92vw, 520px); border-radius:24px; padding:2.2rem; background: var(--card-bg); border:1px solid var(--card-bd); backdrop-filter: blur(8px); box-shadow: 0 20px 60px rgba(0,0,0,.35); text-align:center; }
.brand{ display:flex; align-items:center; justify-content:center; gap:14px; margin-bottom:1.2rem;}
.logo{ width:52px; height:52px; border-radius:14px; background: linear-gradient(135deg, var(--accent), #C1A3FF); display:grid; place-items:center; box-shadow: 0 8px 20px rgba(128,225,255,.35); }
.brand h1{ margin:0; font-size:1.75rem; letter-spacing:.5px; font-weight:700; }
.spinner{ width:52px; height:52px; margin:0 auto 14px; border-radius:999px; border:4px solid rgba(255,255,255,.22); border-top-color: var(--accent); animation: spin 1.1s linear infinite; }
@keyframes spin{ to { transform: rotate(360deg); } }
.bar{ height:6px; width:100%; background: rgba(255,255,255,.12); border-radius:999px; overflow:hidden; }
.bar > i{ display:block; height:100%; width:0%; background: linear-gradient(90deg, var(--accent), #C1A3FF); animation: progress 5s ease-in-out forwards; }
@keyframes progress{ 0%{width:10%} 100%{width:100%} }

/* --- GATE --- */
.gate{ position:fixed; inset:0; z-index:7; display:flex; align-items:center; justify-content:center; background: linear-gradient(120deg, rgba(15,16,32,.92), rgba(24,39,68,.92)); transition: opacity .3s ease, visibility .3s ease; }
.gate.hidden{ opacity:0; visibility:hidden; }
.gate-card{ width:min(92vw, 420px); border-radius:24px; padding:2rem; background: var(--card-bg); border:1px solid var(--card-bd); backdrop-filter: blur(8px); box-shadow: 0 20px 60px rgba(0,0,0,.35); text-align:center; }
.gate h2{ margin:.2rem 0 1rem; }
.pin-input{ letter-spacing:.4rem; text-align:center; font-size:1.4rem; padding:0.9rem 1rem; border-radius:14px; border:1px solid var(--card-bd); background: rgba(255,255,255,.08); color:var(--white); width:100%; }
.btn{ display:inline-flex; align-items:center; justify-content:center; gap:.5rem; padding:0.9rem 1.2rem; border-radius:14px; border:1px solid var(--card-bd); background: linear-gradient(135deg, var(--accent), #C1A3FF); color:#0b0f1a; font-weight:700; cursor:pointer; box-shadow: 0 10px 24px rgba(0,0,0,.35); transition: transform .15s ease, filter .15s ease; }
.btn:hover{ transform: translateY(-2px); filter: brightness(1.03); }
.btn.secondary{ background: rgba(255,255,255,.08); color:var(--white); }
.error{ color:#ff9f9f; min-height:1.2rem; margin-top:.5rem; }

/* --- LAYOUT --- */
.container{ width:min(1100px, 96vw); margin-inline:auto; text-align:center; }
.title{ font-size:2.2rem; margin:0 0 .25rem; }
.subtitle{ opacity:.85; margin:0 0 1.5rem; }
.cards{ display:grid; grid-template-columns: repeat(auto-fit, minmax(260px,1fr)); gap:2rem; }
.card, .action-card{ background: var(--card-bg); border:1px solid var(--card-bd); border-radius:26px; box-shadow: 0 12px 32px rgba(0,0,0,.35); backdrop-filter: blur(6px); }
.action-card{ display:flex; flex-direction:column; align-items:center; justify-content:center; text-decoration:none; color:var(--white); padding:2rem; transition:.25s; }
.action-card:hover{ transform: translateY(-6px) scale(1.02); box-shadow: 0 20px 40px rgba(0,0,0,.45); border-color: var(--accent); }
.action-card .icon{ font-size:3rem; margin-bottom:1rem; }

.view{ display:none; text-align:left; }
.view.active{ display:block; }
.panel{ padding:2rem; }
.panel h2{ margin:0 0 1rem; text-align: center; font-size: 40px;}

.grid{ display:grid; grid-template-columns: repeat(auto-fit, minmax(240px,1fr)); gap:1rem; }
label{ font-weight:600; display:block; margin-bottom:.35rem; }
input, select, textarea{ width:100%; padding:0.9rem 1rem; border-radius:14px; border:1px solid var(--card-bd); background: rgba(255,255,255,.08); color:var(--white); outline:none; }
input::placeholder, textarea::placeholder{ color: rgba(255,255,255,.6); }
textarea{ min-height:90px; resize:vertical; }
.row{ margin-top:1rem; }

/* Lisibilité liste déroulante */
select option, select optgroup{ background:#fff; color:#0b0f1a; }
select option:checked{ background:#eaf3ff; color:#0b0f1a; }
select:focus{ outline:2px solid var(--accent); outline-offset:2px; }

/* Filtres + table compacte */
.filters{ display:flex; flex-wrap:wrap; gap:.5rem; margin:.5rem 0 1rem; }
.chip{ display:inline-flex; align-items:center; gap:.5rem; padding:.5rem .8rem; border-radius:999px; border:1px solid var(--card-bd); background: rgba(255,255,255,.08); cursor:pointer; user-select:none; }
.chip.active{ border-color: var(--accent); box-shadow: 0 0 0 2px rgba(128,225,255,.15) inset; }

.table{ width:100%; border-collapse: collapse; margin-top:1rem; font-size:.98rem; }
.table th, .table td{ padding:0.9rem 0.8rem; text-align:left; border-bottom:1px solid rgba(255,255,255,.12); }
.table th{ opacity:.85; font-weight:700; white-space:nowrap; }

.pill{ display:inline-block; padding:.25rem .6rem; border-radius:999px; border:1px solid var(--card-bd); }
.pill.devis{ background: rgba(255,255,255,.08); }
.pill.attente{ background: rgba(243,156,18,.2); border-color: rgba(243,156,18,.45); }
.pill.livree{ background: rgba(46,204,113,.2); border-color: rgba(46,204,113,.45); }

/* Ligne compacte + toggle */
.toggle-btn{
  width:32px; height:32px; border-radius:10px; border:1px solid rgba(255,255,255,.18);
  background: rgba(255,255,255,.06); display:grid; place-items:center; cursor:pointer;
  transition: transform .15s ease, box-shadow .15s ease, border .15s ease;
}
.toggle-btn:hover{ transform: translateY(-1px); box-shadow:0 10px 20px rgba(0,0,0,.25); border-color:var(--accent); }
.chev{ display:inline-block; transition: transform .2s ease; }
.chev.open{ transform: rotate(90deg); }

/* Détails repliables */
.details-row td{ padding:0 !important; border-bottom:none !important; }
.details{
  margin:.4rem 0 1rem; border-top:1px dashed rgba(255,255,255,.15);
  background: linear-gradient(180deg, rgba(255,255,255,.05), rgba(255,255,255,.03));
  border-radius:18px; overflow:hidden;
}
.details .inner{ padding:1rem 1rem 1.2rem; display:grid; gap:1rem;
  grid-template-columns: repeat(auto-fit, minmax(220px,1fr)); }
.detail-item b{ display:block; opacity:.8; font-size:.86rem; margin-bottom:.2rem; }
.detail-item span{ word-break:break-word; }

.del{ background: rgba(255,255,255,.08); color: var(--danger); border:1px solid rgba(255,255,255,.18); padding:.35rem .7rem; border-radius:10px; cursor:pointer; }
.mark{ background: rgba(46,204,113,.18); color:#ffffff; border:1px solid rgba(46,204,113,.45); padding:.35rem .7rem; border-radius:10px; cursor:pointer; }
.mark:hover{ filter:brightness(1.06); }

.conv-hint{ margin-top:.25rem; opacity:.75; font-size:.9rem; }

/* TOAST + safe area */
.toast{
  font-size: 30px; position:fixed;
  bottom: calc(18px + env(safe-area-inset-bottom));
  left:50%; transform:translateX(-50%);
  background: var(--card-bg); border:1px solid var(--card-bd); color:var(--white);
  padding:.75rem 1rem; border-radius:14px; box-shadow: 0 10px 30px rgba(0,0,0,.4);
  opacity:0; visibility:hidden; transition: opacity .2s ease, visibility .2s ease; z-index: 10;
}
.toast.show{ opacity:1; visibility:visible; }

@media (prefers-reduced-motion: reduce){
  * { animation:none !important; transition:none !important; }
}

/* --- LOGOS --- */
.logo-img{
  display:block; width:56px; height:56px; object-fit:contain;
  filter: drop-shadow(0 6px 18px rgba(128,225,255,.25));
}
.brand .logo-img{ width:56px; height:56px; padding:8px; border-radius:16px; background: rgba(255,255,255,.06); }

.header .header-logo{
  width:24px; height:24px; object-fit:contain; margin-right:.45rem;
  filter: drop-shadow(0 2px 8px rgba(128,225,255,.25));
}

.header .avatar{
  display:grid;
  place-items:center;
  width:26px; height:26px;
  border-radius:999px;
  background: linear-gradient(135deg, var(--accent), #C1A3FF);
  box-shadow: 0 2px 8px rgba(0,0,0,.25);
}

/* === Modal "Programmer la livraison" === */
#dlg-delivery{
  padding: 0;
  border: 1px solid var(--card-bd);
  border-radius: 22px;
  background: linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.04));
  color: var(--white);
  box-shadow: 0 30px 90px rgba(0,0,0,.55);
}
#dlg-delivery::backdrop{
  background: rgba(7,10,20,.65);
  -webkit-backdrop-filter: blur(4px);
  backdrop-filter: blur(4px);
}
#dlg-delivery .panel{
  background: transparent;
  padding: 1.2rem 1.4rem;
}
#dlg-delivery h3{ margin: 0 0 1rem; }

#dlg-delivery input[type="datetime-local"]{
  color-scheme: dark;
}
#dlg-delivery input[type="datetime-local"]::-webkit-calendar-picker-indicator{
  filter: invert(1) opacity(.85);
}

#dlg-delivery .row{
  display: flex;
  gap: .6rem;
  justify-content: flex-end;
  margin-top: 1rem;
}

/* Disposition JJ / MM / AAAA + heure dans le dialog */
.fr-date-time{
  display:flex; gap:.6rem; align-items:center; flex-wrap:wrap;
}
.fr-date-time select,
.fr-date-time input[type="time"]{
  background: rgba(255,255,255,.06);
  color: var(--white);
  border: 1px solid var(--card-bd);
  border-radius: 14px;
  padding: .6rem .75rem;
  font: inherit;
}

/* (doublons nettoyés) */
#dlg-delivery .panel{ background: transparent; padding: 1.2rem 1.4rem; }
#dlg-delivery h3{ margin: 0 0 1rem; }
#dlg-delivery .row{ display:flex; gap:.6rem; justify-content:flex-end; margin-top:1rem; }

/* --- MARQUE --- */
.brand-pin{
  position:fixed; left:14px;
  bottom: calc(14px + env(safe-area-inset-bottom));
  z-index:9;
  display:inline-flex; align-items:center; gap:.55rem;
  padding:.5rem .7rem; border-radius:999px;
  border:1px solid rgba(255,255,255,.16);
  background: rgba(255,255,255,.06);
  backdrop-filter: blur(6px);
  text-decoration:none; color:var(--white); opacity:.9;
  transition: transform .15s ease, box-shadow .15s ease, opacity .15s ease;
}
.brand-pin:hover{ transform: translateY(-2px); box-shadow:0 10px 26px rgba(0,0,0,.35); opacity:1; }
.brand-pin img{ width:22px; height:22px; object-fit:contain; }
.brand-pin b{ letter-spacing:.3px; }

/* FIX watermark SAGRA */
.brand-watermark{
  position:fixed; inset:0; pointer-events:none; z-index:1;
  background:
    radial-gradient(600px 400px at 20% 35%, rgba(128,225,255,.12), transparent 70%) no-repeat center/cover,
    var(--logo-url) no-repeat 92% 8%/100px auto;
  opacity:.70;
  mix-blend-mode:screen;
}
@media (max-width:700px){
  .brand-watermark{
    background:
      radial-gradient(600px 400px at 20% 35%, rgba(128,225,255,.12), transparent 70%) no-repeat center/cover,
      var(--logo-url) no-repeat 88% 6%/76px auto;
  }
}

/* === Pagination === */
.pagination{
  display:flex; gap:1rem; align-items:center; justify-content:space-between;
  margin-top:.8rem; padding:.6rem .8rem; border-radius:14px;
  background: var(--card-bg); border:1px solid var(--card-bd);
}
.pagination .left, .pagination .center, .pagination .right{ display:flex; align-items:center; gap:.6rem; }
.pagination label{ margin:0; font-weight:600; }
.pagination select{ width:auto; padding:.5rem .6rem; border-radius:10px; }
.page-info,.row-info{ opacity:.85; }
.pagination .btn.secondary{ padding:.5rem .7rem; border-radius:10px; }

/* Inputs time – format 24h */
#dlg-delivery input[type="time"]::-webkit-datetime-edit-ampm-field{ display:none; }
#dlg-delivery input[type="time"]{
  color-scheme: dark;
  width: 100%;
}

/* Badge pour le statut "Historique" */
.pill.hist{
  background: rgba(127,140,141,.22);
  border-color: rgba(127,140,141,.45);
}

/* Bouton Archiver (neutre/soft) */
.archive{
  background: rgba(255,255,255,.08);
  color: var(--white);
  border:1px solid rgba(255,255,255,.24);
  padding:.35rem .7rem;
  border-radius:10px;
  cursor:pointer;
}
.archive:hover{ filter: brightness(1.06); }

/* --- Corrections interface Utilisateurs --- */

/* Espacement des boutons d’action */
#users-tbody td:last-child {
  display: flex;
  flex-wrap: wrap;
  gap: 0.6rem;
  justify-content: flex-end;
}

/* Boutons de la ligne */
#users-tbody .btn.small {
  padding: 0.5rem 0.9rem;
  font-size: 0.9rem;
  border-radius: 10px;
  white-space: nowrap;
}

/* Empêcher le bouton Retour de déborder */
#view-users .grid > div:last-child {
  display: flex;
  align-items: flex-end;
  flex-wrap: wrap;
  gap: 0.6rem;
}

#view-users .grid .btn {
  min-width: 110px;
}

/* Centrage visuel des boutons en haut (Enregistrer / Nouveau / Retour) */
#view-users .grid {
  align-items: end;
}

/* Optionnel : limite la largeur de la table pour rester centrée */
#view-users .table-wrap {
  overflow-x: auto;
  margin-top: 1rem;
}
