/* =====================================================================
   ARTISAN PRO — Thème moderne & vif (clair, dynamique)
   Couleurs de marque : bleu navy + rouge damotic, accents vifs.
   ===================================================================== */
:root{
  --bg:        #eef2f9;
  --bg-2:      #e6ebf5;
  --surface:   #ffffff;
  --ink:       #0f1b2d;
  --ink-soft:  #33425a;
  --muted:     #6b7a93;
  --line:      #e3e9f3;
  --line-2:    #cfd8e8;

  --blue:      #2f6bff;
  --blue-700:  #1d4ed8;
  --blue-50:   #e8f0ff;
  --indigo:    #4f46e5;
  --red:       #ef2d4c;
  --red-700:   #c81e3a;
  --red-50:    #ffe9ed;
  --teal:      #06b6d4;
  --green:     #16b364;
  --green-50:  #e6f7ee;
  --amber:     #f59e0b;

  --grad:      linear-gradient(135deg,#2f6bff 0%,#4f46e5 100%);
  --grad-btn:  linear-gradient(135deg,#3b76ff 0%,#2f5cff 100%);
  --grad-red:  linear-gradient(135deg,#ff5a6e 0%,#ef2d4c 100%);

  --shadow:    0 6px 22px rgba(20,40,90,.10);
  --shadow-sm: 0 2px 8px rgba(20,40,90,.08);
  --radius:    16px;
  --radius-sm: 11px;
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  background:
    radial-gradient(1200px 500px at 100% -10%, #dbe6ff 0%, transparent 60%),
    radial-gradient(900px 500px at -10% 0%, #ffe3e8 0%, transparent 55%),
    var(--bg);
  color:var(--ink);
  font-family:'Inter',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  font-size:15px;line-height:1.55;
  -webkit-font-smoothing:antialiased;
  min-height:100vh;
}

/* ---------- Barre supérieure ---------- */
.topbar{
  display:flex;align-items:center;gap:18px;
  padding:12px 20px;
  background:var(--grad);
  box-shadow:var(--shadow);
  position:sticky;top:0;z-index:1000;
}
.brand{display:flex;align-items:center;gap:10px}
.brand-mark{
  color:#fff;font-size:1.35rem;line-height:1;
  background:rgba(255,255,255,.16);width:34px;height:34px;
  display:flex;align-items:center;justify-content:center;border-radius:10px;
}
.brand-name{
  font-family:'Poppins',sans-serif;font-weight:700;
  font-size:1.15rem;color:#fff;letter-spacing:.5px;
}
.burger{
  display:none;margin-left:auto;
  background:rgba(255,255,255,.15);border:none;color:#fff;
  font-size:1.2rem;border-radius:9px;padding:4px 12px;cursor:pointer;
}
.mainnav{display:flex;align-items:center;gap:4px;margin-left:auto;flex-wrap:wrap}
.mainnav a{
  color:rgba(255,255,255,.86);text-decoration:none;
  font-size:.9rem;font-weight:500;
  padding:8px 13px;border-radius:9px;transition:background .15s,color .15s;
}
.mainnav a:hover{background:rgba(255,255,255,.16);color:#fff}
.mainnav a.active{background:#fff;color:var(--blue-700);font-weight:600;box-shadow:var(--shadow-sm)}
.nav-user{color:#fff;font-weight:600;font-size:.85rem;padding-left:12px;margin-left:4px;border-left:1px solid rgba(255,255,255,.3)}
.nav-logout{color:#fff !important;background:rgba(255,255,255,.16);font-weight:600}
.nav-logout:hover{background:var(--grad-red) !important}

/* ---------- Conteneur ---------- */
.container{max-width:1080px;margin:0 auto;padding:26px 18px 70px}

/* ---------- Titres ---------- */
h1,h2,h3{font-family:'Poppins',sans-serif;color:var(--ink);margin:.1em 0 .5em;font-weight:600;line-height:1.25}
h1{font-size:1.7rem;display:inline-block;position:relative;padding-bottom:10px}
h1::after{content:"";position:absolute;left:0;bottom:0;width:62px;height:4px;border-radius:4px;background:var(--grad-red)}
h2{font-size:1.18rem}
h3{font-size:1.02rem}
.subtitle{color:var(--muted);font-size:.95rem;margin:-2px 0 18px}

/* ---------- Panneaux / cartes ---------- */
.panel{
  background:var(--surface);border:1px solid var(--line);
  border-radius:var(--radius);padding:20px;margin-bottom:22px;
  box-shadow:var(--shadow);
}
.cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(210px,1fr));gap:16px;margin-bottom:8px}
.card{
  background:var(--surface);border:1px solid var(--line);
  border-radius:var(--radius);padding:18px 18px 16px;
  box-shadow:var(--shadow);position:relative;overflow:hidden;
}
.card::before{content:"";position:absolute;left:0;top:0;bottom:0;width:5px;background:var(--grad)}
.card .num{font-family:'Poppins',sans-serif;font-weight:700;font-size:1.85rem;color:var(--blue-700);line-height:1.15}
.card .lbl{font-size:.82rem;color:var(--muted);font-weight:500;margin-top:2px}

/* ---------- Boutons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:7px;cursor:pointer;
  background:var(--grad-btn);color:#fff;border:none;
  font-family:'Inter',sans-serif;font-weight:600;font-size:.9rem;
  padding:10px 17px;border-radius:11px;text-decoration:none;
  box-shadow:0 4px 12px rgba(47,107,255,.32);
  transition:transform .08s,box-shadow .15s,filter .15s;
}
.btn:hover{filter:brightness(1.05);box-shadow:0 6px 18px rgba(47,107,255,.42)}
.btn:active{transform:translateY(1px)}
.btn:disabled{opacity:.5;cursor:not-allowed;box-shadow:none}
.btn.ghost{background:#fff;color:var(--blue-700);border:1.5px solid var(--line-2);box-shadow:none}
.btn.ghost:hover{border-color:var(--blue);background:var(--blue-50);filter:none}
.btn.danger{background:var(--grad-red);box-shadow:0 4px 12px rgba(239,45,76,.32)}
.btn.danger:hover{box-shadow:0 6px 18px rgba(239,45,76,.42)}
.btn.small{padding:6px 12px;font-size:.8rem;border-radius:9px}
.btn-row{display:flex;gap:10px;flex-wrap:wrap;align-items:center;margin:16px 0}

/* ---------- Formulaires ---------- */
label{display:block;font-size:.82rem;font-weight:600;color:var(--ink-soft);margin:14px 0 5px}
input,select,textarea{
  width:100%;background:#fff;color:var(--ink);
  border:1.5px solid var(--line-2);border-radius:11px;
  padding:11px 13px;font-family:'Inter',sans-serif;font-size:.95rem;
  transition:border-color .15s,box-shadow .15s;
}
input::placeholder,textarea::placeholder{color:#9aa7bd}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 3px rgba(47,107,255,.16)}
textarea{min-height:84px;resize:vertical}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:0 18px}
.grid3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:0 18px}
.hint{font-size:.8rem;color:var(--muted);margin-top:4px}

/* ---------- Tableaux ---------- */
.table-wrap{overflow-x:auto;border:1px solid var(--line);border-radius:var(--radius-sm)}
table{width:100%;border-collapse:collapse;min-width:560px;background:#fff}
th,td{padding:12px 14px;text-align:left;border-bottom:1px solid var(--line);font-size:.92rem}
thead th{
  background:#f4f7fd;color:var(--ink-soft);font-weight:600;
  font-size:.8rem;letter-spacing:.3px;
}
tbody tr:last-child td{border-bottom:none}
tbody tr:hover{background:#f7faff}
td.num,th.num{text-align:right;font-variant-numeric:tabular-nums}
tfoot td{font-weight:700;color:var(--ink);border-top:2px solid var(--line-2);background:#f4f7fd}

/* ---------- Badges ---------- */
.badge{display:inline-block;padding:3px 11px;border-radius:999px;font-size:.74rem;font-weight:600}
.badge.ok{color:#0b7a44;background:var(--green-50)}
.badge.no{color:var(--red-700);background:var(--red-50)}
.badge.nat{color:var(--blue-700);background:var(--blue-50)}

/* ---------- Messages ---------- */
.flash{padding:13px 16px;border-radius:12px;margin-bottom:18px;font-weight:500;border:1px solid}
.flash.ok{background:var(--green-50);border-color:#aee5c6;color:#0b7a44}
.flash.err{background:var(--red-50);border-color:#f6bcc6;color:var(--red-700)}

/* ---------- Photos ---------- */
.photo-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:12px;margin-top:12px}
.photo-grid figure{margin:0;position:relative;border-radius:12px;overflow:hidden;background:#000;box-shadow:var(--shadow-sm)}
.photo-grid img{width:100%;height:120px;object-fit:cover;display:block}
.photo-grid figcaption{font-size:.7rem;color:#fff;padding:5px 7px;background:linear-gradient(0deg,rgba(0,0,0,.7),transparent);position:absolute;bottom:0;left:0;right:0}
.photo-del{position:absolute;top:5px;right:5px;background:var(--red);color:#fff;border:none;border-radius:8px;cursor:pointer;font-size:.72rem;padding:3px 8px;box-shadow:var(--shadow-sm)}

/* ---------- Carte ---------- */
#map{height:70vh;min-height:380px;border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden}
.leaflet-popup-content{font-family:'Inter',sans-serif}

/* ---------- Connexion ---------- */
.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px;
  background:var(--grad);position:relative}
.login-card{
  width:100%;max-width:400px;background:#fff;
  border-radius:22px;padding:34px 30px;box-shadow:0 20px 50px rgba(15,27,45,.30);text-align:center;
}
.login-card .brand-mark{width:60px;height:60px;font-size:2rem;margin:0 auto 6px;background:var(--grad);border-radius:18px;color:#fff}
.login-card h1{font-size:1.5rem;text-align:center;padding-bottom:0}
.login-card h1::after{display:none}
.deco-rule{height:3px;width:60px;margin:14px auto 6px;border-radius:3px;background:var(--grad-red)}

/* ---------- Divers ---------- */
.toolbar{display:flex;gap:12px;flex-wrap:wrap;align-items:flex-end}
.toolbar .field{flex:1;min-width:150px}
.muted{color:var(--muted)}
.right{text-align:right}.center{text-align:center}
a.link{color:var(--blue-700);font-weight:500;text-decoration:none}
a.link:hover{text-decoration:underline}
.geo-status{font-size:.82rem;color:var(--muted)}

/* ---------- Pied de page + logo damotic ---------- */
.appfoot{
  display:flex;align-items:center;gap:14px;
  max-width:1080px;margin:0 auto;padding:16px 18px 26px;
  color:var(--muted);font-size:.82rem;
}
.damotic{display:inline-flex;align-items:center;gap:8px;color:var(--blue-700);
  text-decoration:none;font-weight:600;letter-spacing:.2px;font-size:.92rem}
.damotic:hover{color:var(--blue)}
.damotic-logo{height:22px;width:22px;border-radius:6px;display:block;box-shadow:var(--shadow-sm)}
.appver{color:var(--muted);font-size:.76rem;padding-left:10px;border-left:1px solid var(--line-2);
  font-family:ui-monospace,SFMono-Regular,Menlo,monospace}
.foot-right{margin-left:auto;font-weight:500;opacity:.8}
.login-foot{position:fixed;left:18px;bottom:16px;z-index:5;display:flex;align-items:center;gap:10px}
.login-foot .damotic{color:#fff}
.login-foot .damotic:hover{color:#fff;opacity:.85}
.login-foot .appver{color:rgba(255,255,255,.85);border-left-color:rgba(255,255,255,.35)}

/* ---------- Responsive ---------- */
@media (max-width:760px){
  .burger{display:block}
  .mainnav{
    display:none;flex-direction:column;align-items:stretch;
    position:absolute;top:100%;left:0;right:0;
    background:var(--blue-700);padding:10px;gap:6px;box-shadow:var(--shadow);
  }
  .mainnav.open{display:flex}
  .mainnav a{width:100%}
  .nav-user{border:none;padding-left:13px}
  .grid2,.grid3{grid-template-columns:1fr}
}
