:root{
  --black:#0A0A0A; --ink:#141414; --ink-2:#1E1E1E; --panel:#161514;
  --cream:#F3EFE9; --beige:#B9B3A9; --muted:#8B867D;
  --line:rgba(255,255,255,.08); --line-2:rgba(255,255,255,.14);
  --red:#E8843A; --red-soft:#FF9E52; --gold:#E0A24C;
  --ok:#52c98a; --ok-bg:rgba(82,201,138,.14);
  --warn:#e0a24c; --warn-bg:rgba(224,162,76,.16);
  --bad:#f06d4f; --bad-bg:rgba(240,109,79,.16);
  --info:#FF9E52; --info-bg:rgba(255,158,82,.15);
  --neutral-bg:rgba(255,255,255,.07);
  --radius:18px; --shadow:0 18px 50px -28px rgba(0,0,0,.8);
  --font-sans:'Space Grotesk',system-ui,-apple-system,"Segoe UI",Roboto,sans-serif;
  --font-disp:'Fraunces',Georgia,"Times New Roman",serif;
}
*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
body{margin:0;font-family:var(--font-sans);background:var(--black);color:var(--cream);
  line-height:1.6;font-size:16px;-webkit-font-smoothing:antialiased;overflow-x:hidden}
a{color:inherit;text-decoration:none}
::selection{background:var(--red);color:#fff}
:focus-visible{outline:2px solid var(--red-soft);outline-offset:3px;border-radius:4px}
h1,h2,h3{font-family:var(--font-disp);font-weight:600;line-height:1.1;letter-spacing:-.01em;margin:0}
h1{font-size:1.7rem}h2{font-size:1.15rem}h3{font-size:1rem}
.muted{color:var(--muted)}
.small{font-size:.82rem}
.hint{font-weight:400;color:var(--muted);font-size:.75rem}
.count{display:inline-block;min-width:1.5em;padding:0 .45em;font-size:.7em;font-weight:700;
  font-family:var(--font-sans);background:var(--neutral-bg);color:var(--beige);border-radius:999px;
  text-align:center;vertical-align:middle}

/* ---------- Top bar ---------- */
.topbar{position:sticky;top:0;z-index:30;display:flex;align-items:center;gap:20px;
  padding:12px 22px;background:rgba(12,12,12,.86);backdrop-filter:blur(14px);
  border-bottom:1px solid var(--line)}
.brand{display:flex;align-items:center;gap:12px;font-family:var(--font-disp);font-weight:600}
.brand .mark{width:40px;height:40px;border-radius:11px;flex:0 0 auto;display:grid;place-items:center;
  font-family:var(--font-sans);font-weight:700;font-size:.78rem;letter-spacing:-.5px;color:var(--cream);
  background:linear-gradient(145deg,#1d1d1d,#0c0c0c);border:1px solid var(--line);
  box-shadow:inset 0 0 0 1px rgba(224,162,76,.2)}
.brand-txt{display:flex;flex-direction:column;font-size:1.05rem;line-height:1.1}
.brand-txt small{font-family:var(--font-sans);font-size:.54rem;letter-spacing:.3em;color:var(--muted);
  text-transform:uppercase;margin-top:2px;font-weight:500}
.nav{display:flex;gap:4px;margin-left:8px}
.nav a{color:var(--beige);padding:8px 13px;border-radius:999px;font-size:.88rem;font-weight:500;transition:.2s}
.nav a:hover{color:var(--cream);background:rgba(255,255,255,.05)}
.nav a.active{background:var(--red);color:#fff}
.user-zone{margin-left:auto;display:flex;align-items:center;gap:12px}
.who{color:var(--beige);font-size:.88rem}

/* ---------- Layout ---------- */
.container{max-width:1100px;margin:0 auto;padding:26px 18px 96px}
.page-head{display:flex;justify-content:space-between;align-items:flex-start;gap:14px;margin-bottom:22px;flex-wrap:wrap}
.subtitle{margin:.25em 0 0;color:var(--beige)}
.back{font-size:.82rem;color:var(--muted)}
.back:hover{color:var(--cream)}
.head-actions{display:flex;gap:8px}

/* ---------- Buttons (pilule) ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;cursor:pointer;
  padding:11px 20px;border:1px solid var(--line-2);border-radius:999px;background:rgba(255,255,255,.03);
  color:var(--cream);font-family:var(--font-sans);font-size:.88rem;font-weight:600;line-height:1;
  transition:transform .2s,box-shadow .2s,background .2s,border-color .2s}
.btn:hover{border-color:var(--beige);background:rgba(255,255,255,.07)}
.btn-sm{padding:8px 13px;font-size:.8rem}
.btn-block{width:100%}
.btn-primary{background:var(--red);border-color:var(--red);color:#fff;box-shadow:0 8px 26px -12px rgba(232,130,58,.7)}
.btn-primary:hover{transform:translateY(-2px);background:var(--red);border-color:var(--red);box-shadow:0 14px 34px -12px rgba(232,130,58,.85)}
.btn-danger{background:transparent;border-color:rgba(240,109,79,.5);color:#fca5a5}
.btn-danger:hover{background:rgba(240,109,79,.12);border-color:var(--bad)}
.btn-ok{background:rgba(82,201,138,.15);border-color:rgba(82,201,138,.45);color:#8ee7b3}
.btn-ok:hover{background:rgba(82,201,138,.25)}
.btn-ghost{background:transparent;border-color:transparent;color:var(--beige)}
.btn-ghost:hover{background:rgba(255,255,255,.06);color:var(--cream)}

/* ---------- Flash ---------- */
.flashes{margin-bottom:16px;display:flex;flex-direction:column;gap:8px}
.flash{padding:11px 15px;border-radius:12px;font-size:.9rem;border:1px solid}
.flash-success{background:var(--ok-bg);border-color:rgba(82,201,138,.35);color:#9ae7c0}
.flash-danger{background:var(--bad-bg);border-color:rgba(240,109,79,.4);color:#f7b4a3}
.flash-warning{background:var(--warn-bg);border-color:rgba(224,162,76,.4);color:#f0cd95}
.flash-info{background:var(--info-bg);border-color:rgba(255,158,82,.4);color:#ffc79b}

/* ---------- Stats ---------- */
.stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:13px;margin-bottom:22px}
.stat{background:linear-gradient(165deg,rgba(255,255,255,.04),rgba(255,255,255,.01));
  border:1px solid var(--line);border-radius:var(--radius);padding:18px;border-left:3px solid var(--muted);
  transition:transform .25s,border-color .25s}
.stat:hover{transform:translateY(-3px);border-left-color:var(--red)}
.stat-num{font-family:var(--font-disp);font-size:1.9rem;font-weight:600}
.stat-lbl{color:var(--beige);font-size:.82rem}
.stat-ok{border-left-color:var(--ok)}.stat-warn{border-left-color:var(--warn)}
.stat-bad{border-left-color:var(--bad)}.stat-info{border-left-color:var(--info)}
.stat-neutral{border-left-color:var(--muted)}

/* ---------- Cards ---------- */
.card{background:linear-gradient(165deg,rgba(255,255,255,.035),rgba(255,255,255,.008));
  border:1px solid var(--line);border-radius:var(--radius);padding:18px;margin-bottom:16px}
.card-head{display:flex;justify-content:space-between;align-items:center;gap:10px;margin-bottom:14px}
.empty{color:var(--muted);text-align:center;padding:20px}

/* ---------- Detail ---------- */
.detail-grid{display:grid;grid-template-columns:2fr 1fr;gap:16px;align-items:start}
.specs{display:grid;grid-template-columns:1fr 1fr;gap:12px 20px;margin:0}
.specs>div{display:flex;flex-direction:column;border-top:1px solid var(--line);padding-top:8px}
.specs dt{font-size:.68rem;text-transform:uppercase;letter-spacing:.12em;color:var(--muted)}
.specs dd{margin:0;font-weight:600;color:var(--cream)}
.notes{margin-top:16px;padding-top:14px;border-top:1px solid var(--line);font-size:.92rem;color:var(--beige)}
.qr-card{text-align:center}
.qr{width:100%;max-width:230px;height:auto;border-radius:12px;padding:10px;background:#fff;margin:0 auto}

/* ---------- Grid of screens ---------- */
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:14px}
.screen-card{display:flex;flex-direction:column;gap:7px;border:1px solid var(--line);border-radius:var(--radius);
  padding:16px;color:var(--cream);position:relative;overflow:hidden;
  background:linear-gradient(165deg,rgba(255,255,255,.04),rgba(255,255,255,.01));
  transition:transform .3s,border-color .3s,box-shadow .3s}
.screen-card:hover{transform:translateY(-5px);border-color:rgba(255,158,82,.4);box-shadow:0 20px 50px -26px rgba(255,158,82,.4)}
.screen-card-top{display:flex;justify-content:space-between;align-items:center}
.screen-card-top .code{font-weight:700;letter-spacing:.02em;color:var(--red-soft)}
.screen-card-name{font-family:var(--font-disp);font-weight:600;font-size:1.1rem}
.screen-card-foot{display:flex;justify-content:space-between;align-items:center;gap:8px;margin-top:4px;flex-wrap:wrap}
.loc{font-size:.82rem;color:var(--muted)}

/* ---------- Badges / tags ---------- */
.badge{display:inline-block;padding:3px 10px;border-radius:999px;font-size:.7rem;font-weight:700;
  white-space:nowrap;font-family:var(--font-sans)}
.badge-ok{background:var(--ok-bg);color:#8ee7b3}.badge-warn{background:var(--warn-bg);color:#f0cd95}
.badge-bad{background:var(--bad-bg);color:#f7b4a3}.badge-info{background:var(--info-bg);color:#ffc79b}
.badge-neutral{background:var(--neutral-bg);color:var(--beige)}
.tag{font-size:.66rem;padding:2px 8px;border-radius:6px;font-weight:700;letter-spacing:.04em;text-transform:uppercase}
.tag-admin{background:rgba(224,162,76,.18);color:var(--gold)}.tag-tech{background:rgba(255,158,82,.16);color:var(--red-soft)}

/* ---------- Lists / timeline ---------- */
.list{list-style:none;margin:0;padding:0}
.list>li{display:flex;justify-content:space-between;align-items:center;gap:12px;
  padding:12px 0;border-bottom:1px solid var(--line);flex-wrap:wrap}
.list>li:last-child{border-bottom:none}
.list-main{display:flex;flex-direction:column;gap:2px;flex:1;min-width:0;color:var(--cream)}
.when{font-size:.78rem;white-space:nowrap;color:var(--muted)}
.timeline{list-style:none;margin:8px 0 0;padding:0}
.timeline>li{padding:13px 0 13px 15px;border-left:2px solid var(--line);margin-left:4px}
.timeline>li.open{border-left-color:var(--bad)}
.timeline>li.resolved{border-left-color:var(--ok)}
.tl-head{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.tl-desc{margin:6px 0;color:var(--beige)}
.tl-actions{display:flex;gap:8px;align-items:center;flex-wrap:wrap;margin-top:8px}
.thumbs{display:flex;gap:8px;flex-wrap:wrap;margin:10px 0}
.thumbs img{width:76px;height:76px;object-fit:cover;border-radius:10px;border:1px solid var(--line)}

/* ---------- Forms ---------- */
label{display:flex;flex-direction:column;gap:6px;font-size:.84rem;font-weight:600;color:var(--beige);flex:1}
input,select,textarea{font:inherit;font-size:.95rem;padding:11px 13px;border:1px solid var(--line-2);border-radius:11px;
  background:var(--ink-2);color:var(--cream);width:100%}
input::placeholder,textarea::placeholder{color:#6b665e}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--red);box-shadow:0 0 0 3px rgba(232,132,58,.18)}
input[type=date]{color-scheme:dark}
select{appearance:none;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%238B867D' stroke-width='3'><path d='M6 9l6 6 6-6'/></svg>");
  background-repeat:no-repeat;background-position:right 13px center;padding-right:34px}
.row{display:flex;gap:13px;flex-wrap:wrap}
.form-section{margin:20px 0 6px;padding-top:14px;border-top:1px solid var(--line);color:var(--gold);
  font-family:var(--font-sans);font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;font-weight:600}
.form-card{max-width:740px}
.form-actions{display:flex;gap:10px;margin-top:20px}
.filters{display:flex;gap:10px;margin-bottom:18px;flex-wrap:wrap}
.filters input[type=search]{flex:1;min-width:190px}
.filters select{width:auto}
.inline-form{display:none;flex-direction:column;gap:11px;padding:15px;margin-bottom:12px;
  background:rgba(255,255,255,.03);border:1px dashed var(--line-2);border-radius:13px}
.inline-form.open{display:flex}
.pw-form{display:flex;gap:6px}
.pw-form input{width:auto}

/* ---------- Pointage ---------- */
.pointage-form{display:flex;flex-direction:column;gap:13px;margin:6px 0 4px}
.pointage-actions{display:flex;gap:10px;flex-wrap:wrap}
.pointage-actions .btn{flex:1;min-width:170px}
.btn-gps{font-size:1rem;padding:14px 18px}
.pos-current{display:flex;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap;
  background:var(--info-bg);border:1px solid rgba(255,158,82,.3);border-radius:12px;padding:11px 14px;margin-bottom:14px}
.pos-where{font-weight:600;color:var(--cream)}
.pos-nav{display:flex;gap:8px;flex-wrap:wrap}
.pos-link{font-weight:700;color:var(--red-soft)}
.btn-waze{background:#33ccff;border-color:#33ccff;color:#04323f}
.btn-waze:hover{filter:brightness(.95);background:#33ccff;border-color:#33ccff;transform:translateY(-2px)}
.gps-feedback{min-height:1.1em;margin:0}

/* ---------- Cartes (Leaflet / navire) ---------- */
.map{height:360px;width:100%;border-radius:12px;border:1px solid var(--line);z-index:0}
.leaflet-popup-content{font-family:var(--font-sans)}
.vessel-map iframe{display:block}
.ship-banner{display:flex;align-items:center;gap:14px;padding:14px 18px;margin-bottom:18px;
  border-radius:var(--radius);color:var(--cream);text-decoration:none;
  background:linear-gradient(120deg,rgba(232,132,58,.18),rgba(255,158,82,.06));
  border:1px solid rgba(255,158,82,.35);transition:transform .2s,border-color .2s}
.ship-banner:hover{transform:translateY(-2px);border-color:var(--red)}
.ship-ico{font-size:1.6rem}
.ship-txt{display:flex;flex-direction:column;flex:1}
.ship-go{font-size:1.6rem;color:var(--red-soft)}

/* ---------- Scan (menu d'actions) ---------- */
.scan-wrap{max-width:460px;margin:10px auto;text-align:center}
.scan-head{display:flex;justify-content:center;align-items:center;gap:10px;margin-bottom:4px}
.scan-head .code{font-weight:800;font-size:1.2rem;color:var(--red-soft)}
.scan-name{font-size:1.6rem;margin:.1em 0}
.scan-actions{display:flex;flex-direction:column;gap:12px;margin-top:24px}
.btn-big{padding:16px 18px;font-size:1.05rem}

/* ---------- Rappels / factures ---------- */
.reminder{display:block;padding:13px 16px;margin-bottom:16px;border-radius:12px;
  background:var(--bad-bg);border:1px solid rgba(240,109,79,.45);color:#f7b4a3}
.reminder-link{text-decoration:none}
.reminder-link:hover{filter:brightness(1.08)}

/* ---------- Accès rapides admin ---------- */
.quicklinks{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:10px;margin-bottom:18px}
.quicklinks a{padding:13px 14px;border:1px solid var(--line);border-radius:12px;color:var(--cream);
  background:rgba(255,255,255,.03);font-weight:600;font-size:.9rem;transition:.2s}
.quicklinks a:hover{border-color:var(--beige);background:rgba(255,255,255,.07)}

/* ---------- Locations ---------- */
.rentals{display:flex;flex-direction:column;gap:12px}
.rental-card{display:flex;justify-content:space-between;gap:14px;flex-wrap:wrap;
  border:1px solid var(--line);border-radius:var(--radius);padding:14px;
  background:linear-gradient(165deg,rgba(255,255,255,.035),rgba(255,255,255,.008))}
.rental-card.is-late{border-color:rgba(240,109,79,.5);background:var(--bad-bg)}
.rental-main{flex:1;min-width:0;display:flex;flex-direction:column;gap:4px}
.rental-top{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.rental-client{font-family:var(--font-disp);font-size:1.1rem}
.rental-prix{font-weight:700;color:var(--gold)}
.rental-actions{display:flex;gap:8px;align-items:flex-start;flex-wrap:wrap}
.checkbox-line{flex-direction:row;align-items:center;gap:10px;font-weight:600}
.checkbox-line input{width:auto}

/* ---------- Agenda (calendrier) ---------- */
.month-total{display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap;
  margin-bottom:14px;padding:14px 18px;border-radius:var(--radius);
  background:linear-gradient(120deg,rgba(224,162,76,.16),rgba(255,158,82,.05));
  border:1px solid rgba(224,162,76,.35)}
.mt-main{display:flex;flex-direction:column}
.mt-label{font-size:.72rem;text-transform:uppercase;letter-spacing:.1em;color:var(--muted)}
.mt-amount{font-family:var(--font-disp);font-size:2rem;font-weight:600;color:var(--gold)}
.mt-split{display:flex;gap:8px;align-items:center;flex-wrap:wrap}
.agenda-bar{display:flex;gap:8px;align-items:center;flex-wrap:wrap;margin-bottom:14px}
.agenda-filter{margin-left:auto}
.agenda-filter select{width:auto}
.cal{border:1px solid var(--line);border-radius:var(--radius);overflow:hidden}
.cal-head{display:grid;grid-template-columns:repeat(7,1fr);background:rgba(255,255,255,.04);
  font-size:.72rem;text-transform:uppercase;letter-spacing:.06em;color:var(--muted)}
.cal-head div{padding:8px;text-align:center}
.cal-row{display:grid;grid-template-columns:repeat(7,1fr)}
.cal-cell{min-height:84px;border-top:1px solid var(--line);border-left:1px solid var(--line);padding:5px 6px;overflow:hidden}
.cal-cell:nth-child(7n+1){border-left:none}
.cal-cell.out{opacity:.4}
.cal-cell.today{background:rgba(232,132,58,.1)}
.cal-day{font-size:.78rem;color:var(--muted);margin-bottom:3px}
.cal-cell.today .cal-day{color:var(--red-soft);font-weight:700}
.cal-ev{display:block;font-size:.66rem;line-height:1.25;background:var(--info-bg);color:#ffc79b;
  border-radius:5px;padding:2px 5px;margin-bottom:3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
@media(max-width:600px){
  .cal-cell{min-height:58px}
  .cal-ev{font-size:.56rem}
}

/* ---------- NFC ---------- */
.nfc-input{font-family:ui-monospace,monospace;font-size:.74rem;text-align:center;
  background:var(--ink-2);border:1px dashed var(--line-2);color:var(--beige);margin-top:6px}

/* ---------- Login ---------- */
.login-body{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:20px;
  background:radial-gradient(120% 80% at 50% -10%,rgba(255,158,82,.1),transparent 55%),var(--black)}
.login-card{background:linear-gradient(165deg,rgba(255,255,255,.05),rgba(255,255,255,.012));
  border:1px solid var(--line);border-radius:22px;padding:36px 30px;width:100%;max-width:370px;
  box-shadow:var(--shadow);text-align:center}
.login-card h1{margin:.3em 0 0;font-size:1.9rem}
.login-logo{width:64px;height:64px;margin:0 auto 6px;border-radius:16px;display:grid;place-items:center;
  font-family:var(--font-sans);font-weight:700;font-size:1.15rem;color:var(--cream);
  background:linear-gradient(145deg,#1d1d1d,#0c0c0c);border:1px solid var(--line);box-shadow:inset 0 0 0 1px rgba(224,162,76,.22)}
.login-card form{display:flex;flex-direction:column;gap:14px;margin-top:20px;text-align:left}

/* ---------- Tab bar (mobile) ---------- */
.tabbar{display:none}
.error-page{text-align:center;padding:60px 0}
.error-code{font-family:var(--font-disp);font-size:3.4rem;font-weight:600;color:var(--red)}

/* ---------- Responsive ---------- */
@media (max-width:760px){
  .nav{display:none}
  .brand-txt{display:none}
  .detail-grid{grid-template-columns:1fr}
  .container{padding-bottom:88px}
  .tabbar{display:flex;position:fixed;bottom:0;left:0;right:0;z-index:40;
    background:rgba(14,14,14,.94);backdrop-filter:blur(14px);border-top:1px solid var(--line);
    padding:7px 4px env(safe-area-inset-bottom)}
  .tabbar a{flex:1;display:flex;flex-direction:column;align-items:center;gap:3px;
    font-size:.66rem;color:var(--muted);padding:6px 0;font-weight:500}
  .tabbar a span{font-size:1.2rem;line-height:1}
  .tabbar a.active{color:var(--red-soft)}
}
@media (max-width:420px){
  .specs{grid-template-columns:1fr}
  .row{flex-direction:column;gap:11px}
}
