.bip-page,.bip-page *{box-sizing:border-box}
.bip-page{display:flex;flex-direction:column;gap:18px;color:rgba(255,255,255,.94);min-height:100%;padding:4px}
.bip-header{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;flex-wrap:wrap}.bip-header h1{margin:0;font-size:30px;font-weight:800}.bip-header p{margin:6px 0 0;opacity:.72}
.bip-header-actions{display:flex;gap:10px;align-items:center;flex-wrap:wrap}.bip-search-inline{min-width:280px;flex:1}.bip-header-actions .input{min-width:180px}
.bip-stats{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px}.bip-stat-card,.bip-panel,.bip-modal-card{background:linear-gradient(180deg,rgba(255,255,255,.05),rgba(255,255,255,.03));border:1px solid rgba(255,255,255,.08);border-radius:18px;box-shadow:0 18px 45px rgba(0,0,0,.26)}
.bip-stat-card{padding:16px;display:flex;flex-direction:column;gap:8px}.bip-stat-card span{font-size:13px;opacity:.75}.bip-stat-card strong{font-size:30px;font-weight:800}.bip-stat-card small{opacity:.6}
.bip-layout{display:grid;grid-template-columns:minmax(0,1.6fr) minmax(360px,.95fr);gap:16px;min-height:0}.bip-panel{padding:16px;display:flex;flex-direction:column;gap:14px}.bip-panel-header h3{margin:0;font-size:18px}.bip-panel-header p{margin:4px 0 0;opacity:.66}
.bip-table-wrap{overflow:auto;border-radius:14px;border:1px solid rgba(255,255,255,.06)}.bip-table{width:100%;border-collapse:collapse;min-width:980px}.bip-table th,.bip-table td{padding:13px 14px;text-align:left;border-bottom:1px solid rgba(255,255,255,.06);vertical-align:middle}.bip-table thead th{font-size:12px;text-transform:uppercase;letter-spacing:.08em;opacity:.65;background:rgba(255,255,255,.03)}.sub-info{font-size:12px;opacity:.66;margin-top:4px}.actions-cell{display:flex;gap:8px;flex-wrap:wrap}
.bip-status{display:inline-flex;align-items:center;justify-content:center;padding:7px 10px;border-radius:999px;font-size:12px;font-weight:800;letter-spacing:.04em}.bip-status.active{background:rgba(52,211,153,.16);color:#9ff7ce}.bip-status.closed{background:rgba(148,163,184,.16);color:#d8e0ea}.bip-status.draft{background:rgba(251,191,36,.16);color:#f6d370}
.discord-preview-shell{border-radius:18px;padding:10px;background:radial-gradient(circle at top left,rgba(61,88,255,.12),transparent 36%),rgba(5,6,20,.46);border:1px solid rgba(255,255,255,.06);min-height:420px}.discord-preview-card{background:linear-gradient(180deg,rgba(27,28,43,.98),rgba(18,19,32,.98));border-left:4px solid #ef4444;border-radius:14px;padding:14px 14px 12px;display:flex;flex-direction:column;gap:12px}.discord-preview-card.warning{border-left-color:#f59e0b}.discord-preview-card.success{border-left-color:#22c55e}.discord-preview-card.info{border-left-color:#3b82f6}.discord-preview-title{font-size:23px;font-weight:900}.discord-preview-fields{display:grid;grid-template-columns:1fr 1fr;gap:10px}.discord-preview-fields div{display:flex;flex-direction:column;gap:4px;padding:10px;border-radius:12px;background:rgba(255,255,255,.03)}.discord-preview-fields strong{font-size:12px;color:#d8d9ff}.discord-preview-targets{display:flex;flex-wrap:wrap;gap:8px}.discord-preview-footer{opacity:.7;font-size:12px}.subtle{opacity:.56}
.bip-quick-help{display:flex;flex-wrap:wrap;gap:8px}.bip-help-chip,.target-chip{border-radius:999px;padding:8px 12px;border:1px solid rgba(255,255,255,.08);background:rgba(255,255,255,.05)}.target-chip{display:inline-flex;gap:8px;align-items:center;cursor:pointer;color:#fff}.target-chip.static,.target-chip.preview{cursor:default}.target-chip span{opacity:.7}
.bip-modal{display:none;position:fixed;inset:0;z-index:1200;background:rgba(2,4,12,.58);backdrop-filter:blur(8px);padding:24px}.bip-modal.active{display:flex;align-items:center;justify-content:center}.bip-modal-card{width:min(1260px,95vw);max-height:90vh;overflow:hidden}.bip-modal-card.big{width:min(1380px,96vw)}.bip-modal-body,.bip-view-body{overflow:auto;padding:18px}.bip-form-grid{display:grid;grid-template-columns:1.05fr 1.1fr .95fr;gap:14px;align-items:start}.bip-form-section{padding:14px;border-radius:16px;background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.06);display:flex;flex-direction:column;gap:12px}.bip-section-title{font-weight:800;font-size:13px;letter-spacing:.08em;text-transform:uppercase;opacity:.72}.bip-grid{display:grid;gap:12px}.bip-grid.two{grid-template-columns:repeat(2,minmax(0,1fr))}.bip-grid.three{grid-template-columns:repeat(3,minmax(0,1fr))}.field{display:flex;flex-direction:column;gap:7px}.field span{font-size:13px;opacity:.78}.inline-with-button{display:flex;gap:8px;align-items:center}.inline-with-button .input{flex:1}.bip-target-toolbar{display:flex;gap:8px;flex-wrap:wrap}.bip-target-chips{display:flex;flex-wrap:wrap;gap:8px;min-height:44px}
.bip-view-grid{display:grid;grid-template-columns:minmax(360px,1fr) minmax(320px,.9fr);gap:16px}.bip-view-right{display:flex;flex-direction:column;gap:10px}.kv{display:flex;justify-content:space-between;gap:16px;padding:12px;border-radius:14px;background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.05)}.kv.block{display:block}.kv span{opacity:.65}.kv p{margin:10px 0 0;white-space:pre-wrap}.target-chip-wrap{display:flex;flex-wrap:wrap;gap:8px;margin-top:10px}
@media (max-width:1200px){.bip-layout,.bip-form-grid,.bip-view-grid{grid-template-columns:1fr}.bip-stats{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media (max-width:720px){.bip-stats,.bip-grid.two,.bip-grid.three{grid-template-columns:1fr}.bip-header-actions{width:100%}.bip-search-inline{min-width:100%}}

/* =========================================================
   SCROLLBARS
========================================================= */

.bip-page ::-webkit-scrollbar,
.bip-modal ::-webkit-scrollbar,
.bip-table-wrap::-webkit-scrollbar,
.bip-modal-body::-webkit-scrollbar {
  width: 10px;
  height: 10px;
}

.bip-page ::-webkit-scrollbar-track,
.bip-modal ::-webkit-scrollbar-track,
.bip-table-wrap::-webkit-scrollbar-track,
.bip-modal-body::-webkit-scrollbar-track {
  background: rgba(255,255,255,.05);
  border-radius: 999px;
}

.bip-page ::-webkit-scrollbar-thumb,
.bip-modal ::-webkit-scrollbar-thumb,
.bip-table-wrap::-webkit-scrollbar-thumb,
.bip-modal-body::-webkit-scrollbar-thumb {
  background: linear-gradient(180deg, rgba(90,140,255,.95), rgba(52,102,235,.95));
  border-radius: 999px;
  border: 2px solid rgba(10,18,38,.45);
}

.bip-page ::-webkit-scrollbar-thumb:hover,
.bip-modal ::-webkit-scrollbar-thumb:hover,
.bip-table-wrap::-webkit-scrollbar-thumb:hover,
.bip-modal-body::-webkit-scrollbar-thumb:hover {
  background: linear-gradient(180deg, rgba(120,164,255,1), rgba(70,116,240,1));
}

.bip-page,
.bip-modal-body,
.bip-table-wrap {
  scrollbar-width: thin;
  scrollbar-color: rgba(90,140,255,.9) rgba(255,255,255,.06);
}

/* =========================================================
   SEARCH BAR
========================================================= */

.bip-toolbar,
.bip-filters,
.bip-header-actions {
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
}

.bip-search,
.bip-search-wrap {
  position: relative;
  min-width: 280px;
  flex: 1 1 320px;
}

.bip-search input,
.bip-search-wrap input,
#bipSearchInput {
  width: 100%;
  height: 44px;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,.10);
  background:
    linear-gradient(180deg, rgba(255,255,255,.05), rgba(255,255,255,.025)),
    rgba(9,18,38,.88);
  color: rgba(255,255,255,.95);
  padding: 0 14px;
  outline: none;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.04),
    0 10px 26px rgba(0,0,0,.18);
  transition: border-color .15s ease, box-shadow .15s ease, transform .15s ease;
}

.bip-search input::placeholder,
.bip-search-wrap input::placeholder,
#bipSearchInput::placeholder {
  color: rgba(255,255,255,.42);
}

.bip-search input:focus,
.bip-search-wrap input:focus,
#bipSearchInput:focus {
  border-color: rgba(93,136,255,.55);
  box-shadow:
    0 0 0 3px rgba(74,118,255,.16),
    inset 0 1px 0 rgba(255,255,255,.04),
    0 12px 28px rgba(0,0,0,.22);
}

/* =========================================================
   TABLE / REGISTRE
========================================================= */

.bip-table-card {
  background:
    radial-gradient(circle at top left, rgba(70,110,210,.15), transparent 35%),
    linear-gradient(180deg, rgba(20,34,68,.95), rgba(10,21,44,.96));
  border: 1px solid rgba(255,255,255,.06);
  border-radius: 20px;
  overflow: hidden;
  box-shadow: 0 18px 50px rgba(0,0,0,.22);
}

.bip-table-wrap {
  width: 100%;
  overflow: auto;
  border-top: 1px solid rgba(255,255,255,.06);
}

.bip-table {
  width: 100%;
  min-width: 980px;
  border-collapse: collapse;
}

.bip-table thead th {
  text-align: left;
  padding: 16px 18px;
  font-size: 12px;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: rgba(255,255,255,.62);
  background: rgba(255,255,255,.025);
  border-bottom: 1px solid rgba(255,255,255,.06);
}

.bip-table tbody td {
  padding: 16px 18px;
  color: rgba(255,255,255,.92);
  border-bottom: 1px solid rgba(255,255,255,.05);
  vertical-align: middle;
}

.bip-table tbody tr:hover {
  background: rgba(255,255,255,.025);
}

/* =========================================================
   MODALE CREATE / EDIT
========================================================= */

.bip-modal {
  background: rgba(2, 8, 20, .72);
  backdrop-filter: blur(8px);
}

.bip-modal-panel {
  width: min(1380px, 92vw);
  max-height: 88vh;
  overflow: hidden;
  border-radius: 24px;
  border: 1px solid rgba(255,255,255,.08);
  background:
    radial-gradient(circle at top left, rgba(64,108,255,.13), transparent 28%),
    linear-gradient(180deg, rgba(17,29,56,.97), rgba(9,18,38,.985));
  box-shadow:
    0 30px 80px rgba(0,0,0,.42),
    inset 0 1px 0 rgba(255,255,255,.04);
}

.bip-modal-header,
.bip-modal-footer {
  padding: 22px 28px;
  border-bottom: 1px solid rgba(255,255,255,.06);
}

.bip-modal-footer {
  border-bottom: 0;
  border-top: 1px solid rgba(255,255,255,.06);
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 14px;
  flex-wrap: wrap;
}

.bip-modal-body {
  padding: 18px 20px 22px;
  max-height: calc(88vh - 170px);
  overflow: auto;
}

.bip-modal-grid {
  display: grid;
  grid-template-columns: 1.05fr 1.15fr .95fr;
  gap: 16px;
  align-items: start;
}

@media (max-width: 1220px) {
  .bip-modal-grid {
    grid-template-columns: 1fr;
  }
}

/* =========================================================
   SECTIONS / CARDS
========================================================= */

.bip-section,
.bip-create-card,
.bip-form-card {
  background:
    linear-gradient(180deg, rgba(255,255,255,.035), rgba(255,255,255,.018)),
    rgba(255,255,255,.02);
  border: 1px solid rgba(255,255,255,.07);
  border-radius: 18px;
  padding: 16px;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.03),
    0 10px 24px rgba(0,0,0,.16);
}

.bip-section-title,
.bip-create-card h3,
.bip-form-card h3 {
  margin: 0 0 14px;
  color: rgba(255,255,255,.92);
  font-size: 13px;
  font-weight: 900;
  letter-spacing: .08em;
  text-transform: uppercase;
}

/* =========================================================
   FORM FIELDS
========================================================= */

.bip-form-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
}

.bip-form-grid--single {
  grid-template-columns: 1fr;
}

.bip-field {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.bip-field label {
  font-size: 13px;
  font-weight: 700;
  color: rgba(255,255,255,.78);
}

.bip-field input,
.bip-field select,
.bip-field textarea,
.bip-input,
.bip-select,
.bip-textarea {
  width: 100%;
  min-width: 0;
  border-radius: 12px;
  border: 1px solid rgba(255,255,255,.10);
  background:
    linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.02)),
    rgba(7,15,31,.92);
  color: rgba(255,255,255,.96);
  padding: 12px 13px;
  outline: none;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.025);
  transition: border-color .15s ease, box-shadow .15s ease, transform .15s ease;
}

.bip-field input::placeholder,
.bip-field textarea::placeholder,
.bip-input::placeholder,
.bip-textarea::placeholder {
  color: rgba(255,255,255,.42);
}

.bip-field textarea,
.bip-textarea {
  min-height: 96px;
  resize: vertical;
}

.bip-field select,
.bip-select {
  appearance: none;
  cursor: pointer;
}

.bip-field input:focus,
.bip-field select:focus,
.bip-field textarea:focus,
.bip-input:focus,
.bip-select:focus,
.bip-textarea:focus {
  border-color: rgba(93,136,255,.58);
  box-shadow:
    0 0 0 3px rgba(74,118,255,.16),
    inset 0 1px 0 rgba(255,255,255,.025);
}

.bip-field input:hover,
.bip-field select:hover,
.bip-field textarea:hover,
.bip-input:hover,
.bip-select:hover,
.bip-textarea:hover {
  border-color: rgba(255,255,255,.16);
}

/* =========================================================
   TARGETS / TAGS
========================================================= */

.bip-target-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-bottom: 14px;
}

.bip-target-list,
.bip-chip-list {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.bip-chip,
.bip-target-chip {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  min-height: 34px;
  padding: 0 12px;
  border-radius: 999px;
  background: rgba(78,121,255,.16);
  border: 1px solid rgba(94,134,255,.26);
  color: rgba(255,255,255,.92);
  font-size: 13px;
  font-weight: 700;
}

.bip-chip button,
.bip-target-chip button {
  border: 0;
  background: transparent;
  color: rgba(255,255,255,.74);
  cursor: pointer;
  font-size: 14px;
}

.bip-chip button:hover,
.bip-target-chip button:hover {
  color: #fff;
}

/* =========================================================
   BUTTONS
========================================================= */

.bip-page .btn,
.bip-page button,
.bip-modal button {
  -webkit-tap-highlight-color: transparent;
}

.bip-page .btn-secondary,
.bip-page .btn-ghost,
.bip-modal .btn-secondary,
.bip-modal .btn-ghost {
  border: 1px solid rgba(255,255,255,.08);
  background: rgba(255,255,255,.05);
  color: rgba(255,255,255,.92);
  border-radius: 14px;
  transition: .15s ease;
}

.bip-page .btn-secondary:hover,
.bip-page .btn-ghost:hover,
.bip-modal .btn-secondary:hover,
.bip-modal .btn-ghost:hover {
  background: rgba(255,255,255,.09);
  border-color: rgba(255,255,255,.14);
}

.bip-page .btn-primary,
.bip-modal .btn-primary {
  border: 0;
  border-radius: 14px;
  color: #fff;
  background: linear-gradient(180deg, #3f7bff, #2459e5);
  box-shadow: 0 14px 30px rgba(36,89,229,.30);
  transition: transform .15s ease, box-shadow .15s ease, filter .15s ease;
}

.bip-page .btn-primary:hover,
.bip-modal .btn-primary:hover {
  transform: translateY(-1px);
  filter: brightness(1.04);
  box-shadow: 0 18px 34px rgba(36,89,229,.38);
}

.bip-modal-panel,
.bip-modal-body,
.bip-modal-grid,
.bip-section,
.bip-create-card,
.bip-form-card {
  min-width: 0;
}

.bip-modal-body * {
  max-width: 100%;
}

.bip-field,
.bip-field input,
.bip-field select,
.bip-field textarea {
  min-width: 0;
}

/* =========================================================
   FORCE STYLE CHAMPS FORMULAIRE BIP
   À mettre tout en bas du fichier
========================================================= */

#bipCreateModal input,
#bipCreateModal select,
#bipCreateModal textarea,
#bipCreateModal .input,
#bipCreateModal .select,
#bipCreateModal .textarea,
.bip-modal input,
.bip-modal select,
.bip-modal textarea,
.bip-modal .input,
.bip-modal .select,
.bip-modal .textarea,
.bip-page input,
.bip-page select,
.bip-page textarea {
  appearance: none;
  -webkit-appearance: none;
  width: 100%;
  min-width: 0;
  height: 42px;
  padding: 0 12px;
  border-radius: 12px;
  border: 1px solid rgba(255,255,255,.10) !important;
  background:
    linear-gradient(180deg, rgba(255,255,255,.05), rgba(255,255,255,.025)),
    rgba(8, 16, 32, .94) !important;
  color: rgba(255,255,255,.96) !important;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.03),
    0 8px 18px rgba(0,0,0,.16) !important;
  outline: none;
  transition:
    border-color .15s ease,
    box-shadow .15s ease,
    background .15s ease;
}

#bipCreateModal textarea,
.bip-modal textarea,
.bip-page textarea {
  min-height: 96px;
  height: auto;
  padding: 12px;
  resize: vertical;
  line-height: 1.45;
}

#bipCreateModal select,
.bip-modal select,
.bip-page select {
  padding-right: 38px;
  cursor: pointer;
  background-image:
    linear-gradient(180deg, rgba(255,255,255,.05), rgba(255,255,255,.025)),
    linear-gradient(45deg, transparent 50%, rgba(255,255,255,.72) 50%),
    linear-gradient(135deg, rgba(255,255,255,.72) 50%, transparent 50%);
  background-repeat: no-repeat, no-repeat, no-repeat;
  background-position:
    0 0,
    calc(100% - 18px) 17px,
    calc(100% - 12px) 17px;
  background-size:
    100% 100%,
    6px 6px,
    6px 6px;
  background-color: rgba(8, 16, 32, .94) !important;
}

#bipCreateModal input::placeholder,
#bipCreateModal textarea::placeholder,
.bip-modal input::placeholder,
.bip-modal textarea::placeholder,
.bip-page input::placeholder,
.bip-page textarea::placeholder {
  color: rgba(255,255,255,.42) !important;
}

#bipCreateModal input:hover,
#bipCreateModal select:hover,
#bipCreateModal textarea:hover,
.bip-modal input:hover,
.bip-modal select:hover,
.bip-modal textarea:hover,
.bip-page input:hover,
.bip-page select:hover,
.bip-page textarea:hover {
  border-color: rgba(255,255,255,.16) !important;
  background:
    linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.03)),
    rgba(10, 18, 36, .96) !important;
}

#bipCreateModal input:focus,
#bipCreateModal select:focus,
#bipCreateModal textarea:focus,
.bip-modal input:focus,
.bip-modal select:focus,
.bip-modal textarea:focus,
.bip-page input:focus,
.bip-page select:focus,
.bip-page textarea:focus {
  border-color: rgba(83,129,255,.60) !important;
  background:
    linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.03)),
    rgba(10, 18, 36, .98) !important;
  box-shadow:
    0 0 0 3px rgba(74,118,255,.16),
    inset 0 1px 0 rgba(255,255,255,.03),
    0 10px 22px rgba(0,0,0,.18) !important;
}

#bipCreateModal option,
.bip-modal option,
.bip-page option {
  background: #0d1830;
  color: #fff;
}

/* labels */
#bipCreateModal label,
.bip-modal label,
.bip-page label {
  display: block;
  margin-bottom: 7px;
  font-size: 13px;
  font-weight: 700;
  color: rgba(255,255,255,.78);
}

/* groupes de champs */
#bipCreateModal .bip-field,
#bipCreateModal .form-group,
#bipCreateModal .field,
.bip-modal .bip-field,
.bip-modal .form-group,
.bip-modal .field {
  display: flex;
  flex-direction: column;
  gap: 0;
}

/* lignes de 2 champs */
#bipCreateModal .bip-form-grid,
#bipCreateModal .form-row,
.bip-modal .bip-form-grid,
.bip-modal .form-row {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
}

@media (max-width: 900px) {
  #bipCreateModal .bip-form-grid,
  #bipCreateModal .form-row,
  .bip-modal .bip-form-grid,
  .bip-modal .form-row {
    grid-template-columns: 1fr;
  }
}

/* fix champs trop larges */
#bipCreateModal *,
.bip-modal * {
  box-sizing: border-box;
}

/* empêche le blanc hérité d'un style global */
#bipCreateModal input:not([type="checkbox"]):not([type="radio"]),
#bipCreateModal select,
#bipCreateModal textarea,
.bip-modal input:not([type="checkbox"]):not([type="radio"]),
.bip-modal select,
.bip-modal textarea {
  color-scheme: dark;
}