/* ============================================================
   DEPCB — Charte DAMOTIC × esthétique Apple Classic Mac
   Marine #1F3A5F · Rouge framboise #DC143C · Ivoire
   ============================================================ */

:root {
  --marine:   #1F3A5F;
  --marine-d: #142841;
  --framboise:#DC143C;
  --ivoire:   #ECECE4;
  --gris-mac: #DDDDD5;
  --blanc:    #FFFFFF;
  --noir:     #1A1A1A;
  --ombre:    rgba(0,0,0,.35);
}

* { box-sizing: border-box; margin: 0; padding: 0; -webkit-tap-highlight-color: transparent; }

html, body {
  height: 100%;
  font-family: "Chicago", "Geneva", "Lucida Grande", -apple-system, "Segoe UI", sans-serif;
  background: var(--gris-mac);
  background-image:
    repeating-linear-gradient(0deg, rgba(0,0,0,.025) 0 1px, transparent 1px 3px);
  color: var(--noir);
  -webkit-font-smoothing: none;
}

/* ---------- Fenêtre Classic Mac ---------- */
.mac-window {
  max-width: 760px;
  margin: 20px auto;
  background: var(--blanc);
  border: 2px solid var(--noir);
  border-radius: 4px;
  box-shadow: 4px 4px 0 var(--ombre);
}

.title-bar {
  display: flex;
  align-items: center;
  gap: 8px;
  background: var(--marine);
  background-image: repeating-linear-gradient(
    0deg, rgba(255,255,255,.18) 0 1px, transparent 1px 2px);
  border-bottom: 2px solid var(--noir);
  padding: 5px 10px;
  color: var(--blanc);
  user-select: none;
}
.title-bar .dot {
  width: 13px; height: 13px;
  border: 2px solid var(--noir);
  border-radius: 50%;
  background: var(--blanc);
  flex: 0 0 auto;
}
.title-bar .dot.red { background: var(--framboise); }
.title-bar h1 {
  flex: 1;
  font-size: 14px;
  letter-spacing: .5px;
  text-align: center;
  text-transform: uppercase;
}

.window-body { padding: 18px; }

/* ---------- Logo DAMOTIC ---------- */
.brand {
  display: flex; align-items: center; gap: 10px;
  margin-bottom: 14px;
}
.brand .logo-d {
  width: 38px; height: 38px;
  background: var(--marine);
  border: 2px solid var(--noir);
  border-radius: 6px;
  display: flex; align-items: center; justify-content: center;
  font-weight: bold; font-size: 22px;
  color: var(--blanc);
  position: relative;
}
.brand .logo-d::after {
  content: ""; position: absolute;
  right: 0; top: 0; bottom: 0; width: 46%;
  background: var(--framboise);
  border-left: 2px solid var(--noir);
  border-radius: 0 4px 4px 0;
}
.brand .logo-d span { position: relative; z-index: 2; }
.brand .wordmark { line-height: 1.1; }
.brand .wordmark b { font-size: 15px; color: var(--marine); letter-spacing: .5px; }
.brand .wordmark small { font-size: 10px; color: var(--framboise); letter-spacing: 1px; }

/* ---------- Titres ---------- */
h2.section {
  font-size: 13px;
  background: var(--ivoire);
  border: 2px solid var(--noir);
  padding: 5px 9px;
  margin: 16px 0 10px;
  text-transform: uppercase;
  letter-spacing: .5px;
}

/* ---------- Formulaires ---------- */
label.fld { display: block; margin: 12px 0 4px; font-size: 12px; font-weight: bold; }

input[type=text], input[type=number], input[type=password],
input[type=file], textarea, select {
  width: 100%;
  font-family: inherit;
  font-size: 13px;
  padding: 8px;
  border: 2px solid var(--noir);
  border-radius: 3px;
  background: var(--blanc);
}
textarea { resize: vertical; min-height: 60px; }

/* Cases à cocher style Mac */
.check-row { display: flex; flex-wrap: wrap; gap: 8px; margin: 8px 0; }
.check {
  display: flex; align-items: center; gap: 7px;
  border: 2px solid var(--noir);
  background: var(--ivoire);
  padding: 7px 11px;
  border-radius: 3px;
  font-size: 12px; font-weight: bold;
  cursor: pointer;
  flex: 1 1 auto;
}
.check input { width: 16px; height: 16px; accent-color: var(--framboise); }
.check.on { background: var(--marine); color: var(--blanc); }

/* ---------- Boutons ---------- */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 6px;
  font-family: inherit; font-size: 13px; font-weight: bold;
  padding: 9px 16px;
  border: 2px solid var(--noir);
  border-radius: 4px;
  background: var(--ivoire);
  cursor: pointer;
  box-shadow: 2px 2px 0 var(--ombre);
  text-decoration: none; color: var(--noir);
}
.btn:active { transform: translate(2px,2px); box-shadow: none; }
.btn.primary { background: var(--marine); color: var(--blanc); }
.btn.danger  { background: var(--framboise); color: var(--blanc); }
.btn.full    { width: 100%; }
.btn[disabled] { opacity: .5; cursor: not-allowed; }

/* ---------- Boîte info / géoloc ---------- */
.geo-box {
  border: 2px dashed var(--marine);
  background: var(--ivoire);
  padding: 10px; border-radius: 3px;
  font-size: 12px; margin: 8px 0;
}
.geo-box b { color: var(--framboise); }

.alert {
  border: 2px solid var(--noir);
  padding: 9px 11px; border-radius: 3px;
  font-size: 12px; margin: 10px 0;
}
.alert.ok   { background: #E3F2E3; }
.alert.err  { background: #FBE3E3; }
.alert.note { background: #FFF6D6; }

/* ---------- Tableau frais ---------- */
table.frais {
  width: 100%; border-collapse: collapse; font-size: 11px; margin-top: 8px;
}
table.frais th, table.frais td {
  border: 1px solid var(--noir); padding: 5px 6px; text-align: left;
}
table.frais th { background: var(--marine); color: var(--blanc); }
table.frais tr:nth-child(even) td { background: var(--ivoire); }
.badge {
  display: inline-block; font-size: 9px; font-weight: bold;
  padding: 2px 5px; border: 1px solid var(--noir); border-radius: 3px;
}
.badge.bnp { background: #2E7D32; color:#fff; }
.badge.cic { background: #1565C0; color:#fff; }
.badge.perso { background: var(--framboise); color:#fff; }

/* ---------- Code d'accès ---------- */
.login-wrap { max-width: 360px; }
.code-input {
  text-align: center; font-size: 28px; letter-spacing: 12px;
}

/* ---------- Pied / version ---------- */
.app-version {
  position: fixed; right: 8px; bottom: 6px;
  font-size: 10px; font-weight: bold;
  background: var(--marine); color: var(--blanc);
  border: 1px solid var(--noir);
  padding: 2px 7px; border-radius: 3px;
  z-index: 999;
}

/* ---------- Onglets ---------- */
.tabs { display: flex; gap: 4px; margin-bottom: -2px; }
.tab {
  font-size: 12px; font-weight: bold;
  padding: 7px 12px;
  border: 2px solid var(--noir);
  border-bottom: none;
  border-radius: 5px 5px 0 0;
  background: var(--gris-mac);
  cursor: pointer; text-decoration: none; color: var(--noir);
}
.tab.active { background: var(--blanc); }

.lot-item {
  border: 2px solid var(--noir); border-radius: 3px;
  padding: 8px; margin: 6px 0; background: var(--ivoire);
  font-size: 11px;
}

/* ---------- Responsive ---------- */
@media (max-width: 640px) {
  .mac-window { margin: 0; border-radius: 0; box-shadow: none; min-height: 100vh; }
  .window-body { padding: 12px; }
  .check { flex: 1 1 100%; }
  .code-input { letter-spacing: 8px; font-size: 22px; }
  table.frais { font-size: 10px; }
}
