/* components.css — Composants réutilisables */

/* ── Boutons ── */

.lbtn {
  width: 100%;
  padding: 11px;
  border: none;
  border-radius: 8px;
  background: var(--pri);
  color: white;
  font-weight: 600;
  font-size: 14px;
  cursor: pointer;
  margin-top: 6px;
  transition: .15s
}

.lbtn:hover {
  background: var(--prl)
}

.bset {
  width: 32px;
  height: 32px;
  border-radius: 8px;
  border: 1px solid var(--bd);
  background: var(--wh);
  color: var(--tx3);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: .15s
}

.bset:hover {
  border-color: var(--pri);
  color: var(--pri)
}

.bset svg {
  width: 16px;
  height: 16px
}

.sbtn {
  width: 40px;
  height: 40px;
  border-radius: 10px;
  border: none;
  background: var(--pri);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: .15s;
  flex-shrink: 0
}

.sbtn:hover {
  background: var(--prl)
}

.sbtn:disabled {
  opacity: .35;
  cursor: not-allowed
}

.sbtn svg {
  width: 18px;
  height: 18px
}

.attach-btn {
  width: 36px;
  height: 36px;
  border-radius: 8px;
  border: 1px solid var(--bd);
  background: var(--wh);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: .15s;
  flex-shrink: 0;
  position: relative;
  padding: 0
}

.attach-btn:hover {
  border-color: var(--sec);
  background: var(--pbg)
}

.attach-btn svg {
  width: 16px;
  height: 16px;
  stroke: var(--tx2);
  fill: none;
  pointer-events: none
}

.attach-btn input[type=file] {
  position: absolute;
  inset: 0;
  opacity: 0;
  cursor: pointer;
  width: 100%;
  height: 100%
}

/* ── Formulaires ── */

.fd {
  margin-bottom: 14px;
  text-align: left
}

.fd label {
  display: block;
  font-size: 11px;
  font-weight: 600;
  color: var(--tx2);
  margin-bottom: 5px;
  text-transform: uppercase;
  letter-spacing: .3px
}

.fd input,
.fd select {
  width: 100%;
  padding: 10px 12px;
  background: var(--bg);
  border: 1px solid var(--bd);
  border-radius: 8px;
  color: var(--tx);
  font-size: 14px;
  outline: none;
  transition: .15s
}

.fd input:focus,
.fd select:focus {
  border-color: var(--pri);
  box-shadow: 0 0 0 3px rgba(88, 60, 110, .08)
}

.fd input::placeholder {
  color: var(--tx3)
}

/* ── Erreurs ── */

.lerr {
  color: var(--rd);
  font-size: 13px;
  margin-top: 10px;
  min-height: 16px
}

/* ── Lien reset ── */

.lreset {
  color: var(--pri);
  font-size: 12px;
  cursor: pointer;
  margin-top: 10px;
  text-decoration: underline;
  background: none;
  border: none
}

/* ── Info texte ── */

.linfo {
  color: var(--tx3);
  font-size: 12px;
  margin-top: 14px;
  line-height: 1.5
}

/* ── Badge statut ── */

.sbadge {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 13px;
  font-weight: 500;
  color: var(--gn)
}

.sbadge i {
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: var(--gn);
  display: inline-block
}

/* ── Zone upload ── */

.uz {
  border: 1.5px dashed var(--pbd);
  border-radius: 12px;
  padding: 20px;
  text-align: center;
  cursor: pointer;
  transition: .15s;
  margin-bottom: 14px;
  position: relative;
  background: var(--wh)
}

.uz:hover {
  border-color: var(--sec);
  background: var(--pbg)
}

.uz.dg {
  border-color: var(--pri);
  background: var(--pbg)
}

.uz input[type=file] {
  position: absolute;
  inset: 0;
  opacity: 0;
  cursor: pointer
}

.uz-icon svg {
  width: 24px;
  height: 24px;
  stroke: var(--pri);
  fill: none
}

.uz-text {
  font-size: 14px;
  color: var(--tx2)
}

.uz-text a {
  color: var(--pri);
  font-weight: 600
}

.uz-hint {
  font-size: 12px;
  color: var(--tx3);
  margin-top: 2px
}

/* ── Fichiers attachés ── */

.afiles {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-bottom: 10px
}

.af {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 6px 12px;
  background: var(--pbg);
  border: 1px solid var(--pbd);
  border-radius: 8px;
  font-size: 13px
}

.af .rm {
  width: 18px;
  height: 18px;
  border-radius: 50%;
  background: 0;
  border: none;
  color: var(--tx3);
  cursor: pointer;
  font-size: 14px
}

.af .rm:hover {
  color: var(--rd)
}

/* ── Modale ── */

.mov {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, .3);
  z-index: 100;
  display: none;
  align-items: center;
  justify-content: center
}

.mov.on {
  display: flex
}

.mod {
  background: var(--wh);
  border: 1px solid var(--bd);
  border-radius: 16px;
  padding: 28px;
  width: 400px;
  max-width: 92vw;
  box-shadow: 0 4px 24px rgba(0, 0, 0, .08)
}

.mod h2 {
  font-size: 16px;
  font-weight: 600;
  margin-bottom: 18px
}

.mact {
  display: flex;
  gap: 8px;
  margin-top: 20px
}

.mact button {
  flex: 1;
  padding: 10px;
  border-radius: 8px;
  font-size: 13px;
  font-weight: 500;
  cursor: pointer;
  transition: .15s
}

.mact .mc {
  background: var(--bg);
  border: 1px solid var(--bd);
  color: var(--tx2)
}

.mact .md {
  background: #FEE2E2;
  border: 1px solid #FECACA;
  color: var(--rd)
}

/* ── Typing indicator ── */

.typing {
  display: flex;
  gap: 5px;
  padding: 16px 20px
}

.typing span {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--sec);
  animation: bl 1.2s infinite
}

.typing span:nth-child(2) {
  animation-delay: .2s
}

.typing span:nth-child(3) {
  animation-delay: .4s
}

@keyframes bl {
  0%,
  60%,
  100% {
    opacity: .25
  }
  30% {
    opacity: .8
  }
}

/* ── Config par module ── */

.mod {
  max-height: 88vh;
  overflow-y: auto
}

.adv-section {
  border: 1px solid var(--bd);
  border-radius: 10px;
  padding: 12px;
  margin-bottom: 14px;
  background: var(--bg)
}

.adv-toggle {
  display: flex;
  align-items: center;
  justify-content: space-between;
  cursor: pointer;
  user-select: none;
  margin-bottom: 0
}

.adv-toggle label {
  cursor: pointer;
  margin: 0
}

.adv-arr {
  font-size: 10px;
  color: var(--tx3);
  transition: transform .2s
}

.cu-row + .cu-row {
  margin-top: 8px;
  border-top: 1px solid var(--bd);
  padding-top: 8px
}

.cu-row-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  cursor: pointer;
  color: var(--tx2);
  font-size: 13px;
  font-weight: 500;
  user-select: none;
  padding: 2px 0
}

.cu-row-head:hover { color: var(--pri) }

.cu-row-arr {
  font-size: 10px;
  color: var(--tx3);
  transition: transform .2s
}

.cu-row-body {
  display: flex;
  flex-direction: column;
  gap: 6px;
  padding-top: 10px
}

.cu-row-body input,
.cu-row-body select {
  width: 100%;
  padding: 8px 10px;
  border: 1px solid var(--bd);
  border-radius: 7px;
  font-size: 13px;
  color: var(--tx);
  background: var(--wh);
  outline: none;
  box-sizing: border-box;
  transition: .15s
}

.cu-row-body input:focus,
.cu-row-body select:focus {
  border-color: var(--pri)
}

.cu-row-body input::placeholder { color: var(--tx3) }

.cu-key-badge {
  display: inline-block;
  font-size: 11px;
  font-weight: 600;
  padding: 2px 8px;
  border-radius: 99px;
  letter-spacing: .2px
}

.cu-key-own { background: var(--gn2); color: var(--gn3) }
.cu-key-global { background: var(--gy2); color: var(--gy) }

.cu-row-head-right {
  display: flex;
  align-items: center;
  gap: 8px
}

/* Éditeur de clé */
.key-editor {
  border-top: 1px solid var(--bd);
  margin-top: 14px;
  padding-top: 14px
}

.key-editor .fd { margin-bottom: 8px }

.s-key-msg {
  font-size: 13px;
  min-height: 18px;
  margin-top: 4px
}

/* ── Barre toggle Base ARIA (CU3) ── */
.aria-notif-bar {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 4px 6px 4px 12px;
  background: var(--wh);
  border: 1px solid var(--bd);
  border-radius: 8px;
  box-shadow: 0 1px 5px rgba(0, 0, 0, .07);
  width: fit-content;
  max-width: 100%;
  margin-bottom: 8px;
}
.aria-notif-text {
  font-size: 11px;
  color: var(--tx3);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.aria-notif-btn {
  padding: 2px 10px;
  font-size: 11px;
  font-weight: 700;
  border: 1.5px solid var(--bd);
  border-radius: 5px;
  background: transparent;
  color: var(--tx);
  cursor: pointer;
  white-space: nowrap;
  flex-shrink: 0;
  transition: background .15s, border-color .15s, color .15s;
}
.aria-notif-btn.active {
  background: var(--pri);
  border-color: var(--pri);
  color: #fff;
}

