*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

:root {
  --navy:#1B2A4A; --blue:#2D5FA8; --teal:#028090; --purple:#534AB7;
  --coral:#D85A30; --green:#2E7D32; --amber:#BA7517; --red:#C62828;
  --grey:#F7F8FA; --border:#E0E0E0; --text:#1A1A1A; --muted:#6B6B6B;
  --white:#FFFFFF; --sidebar-w:220px;
}

body { font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif; background:var(--grey); color:var(--text); }

/* Auth */
#login-screen { min-height:100vh; display:flex; align-items:center; justify-content:center; background:var(--navy); }
.login-card { background:var(--white); border-radius:16px; padding:48px 40px; width:380px; box-shadow:0 8px 40px rgba(0,0,0,0.2); }
.login-logo { text-align:center; margin-bottom:32px; }
.login-logo h1 { font-size:22px; color:var(--navy); font-weight:700; }
.login-logo span { font-size:13px; color:var(--muted); }
.login-field { margin-bottom:16px; }
.login-field label { display:block; font-size:13px; font-weight:600; margin-bottom:6px; }
.login-field input { width:100%; padding:10px 14px; border:1px solid var(--border); border-radius:8px; font-size:14px; }
.login-field input:focus { outline:none; border-color:var(--blue); }
.login-error { color:var(--coral); font-size:13px; margin-bottom:12px; display:none; }
.btn-login { width:100%; padding:12px; background:var(--blue); color:var(--white); border:none; border-radius:8px; font-size:15px; font-weight:600; cursor:pointer; }
.btn-login:hover { background:#1B4A8A; }

/* App shell */
#app { display:none; min-height:100vh; }
.app-header { background:var(--navy); height:52px; display:flex; align-items:center; padding:0 20px; position:fixed; top:0; left:0; right:0; z-index:100; gap:12px; }
.app-header h1 { color:var(--white); font-size:16px; font-weight:700; flex:1; }
.header-user { color:#A8C4E8; font-size:13px; }
.btn-logout { background:none; border:1px solid #A8C4E8; color:#A8C4E8; padding:5px 12px; border-radius:6px; font-size:12px; cursor:pointer; }
.btn-logout:hover { background:rgba(255,255,255,0.1); }

/* Sidebar */
.app-sidebar { position:fixed; top:52px; left:0; bottom:0; width:var(--sidebar-w); background:var(--white); border-right:1px solid var(--border); padding:16px 0; overflow-y:auto; }
.sidebar-section { padding:8px 16px 4px; font-size:10px; font-weight:700; color:var(--muted); text-transform:uppercase; letter-spacing:0.08em; }
.sidebar-link { display:flex; align-items:center; gap:8px; padding:9px 16px; font-size:13px; color:var(--text); cursor:pointer; border-left:3px solid transparent; transition:all 0.12s; }
.sidebar-link:hover { background:var(--grey); }
.sidebar-link.active { background:#E6F1FB; color:var(--blue); border-left-color:var(--blue); font-weight:600; }

/* Main */
.app-main { margin-top:52px; margin-left:var(--sidebar-w); padding:24px; min-height:calc(100vh - 52px); }

/* Toolbar */
.toolbar { display:flex; align-items:center; gap:10px; margin-bottom:16px; flex-wrap:wrap; }
.toolbar h2 { font-size:20px; font-weight:700; color:var(--navy); flex:1; }

/* Barre sélection */
#selection-bar {
  display:flex; align-items:center; gap:10px; flex-wrap:wrap;
  background:var(--navy); color:var(--white);
  padding:10px 16px; border-radius:10px; margin-bottom:12px;
}
#selection-count { font-size:13px; font-weight:600; flex:1; }

/* Filtres */
.filters { display:flex; gap:8px; flex-wrap:wrap; margin-bottom:10px; }
.filter-chip { padding:5px 14px; border-radius:99px; border:1px solid var(--border); font-size:12px; cursor:pointer; color:var(--muted); background:var(--white); transition:all 0.12s; }
.filter-chip.active { background:var(--navy); color:var(--white); border-color:var(--navy); font-weight:600; }

/* List actions */
.list-actions { display:flex; gap:8px; margin-bottom:12px; }

/* Cards liste */
.spec-list { display:flex; flex-direction:column; gap:10px; }
.spec-card { background:var(--white); border:1px solid var(--border); border-radius:10px; padding:14px 16px; cursor:pointer; transition:all 0.12s; display:flex; align-items:flex-start; gap:12px; }
.spec-card:hover { border-color:var(--blue); box-shadow:0 2px 8px rgba(45,95,168,0.1); }
.spec-card.selected { border-color:var(--blue); background:#F0F6FF; }
.spec-checkbox { width:18px; height:18px; cursor:pointer; flex-shrink:0; margin-top:2px; accent-color:var(--blue); }
.spec-type-badge { padding:3px 10px; border-radius:6px; font-size:11px; font-weight:700; flex-shrink:0; margin-top:2px; }
.type-US { background:#E6F1FB; color:var(--blue); }
.type-MOD { background:#E8F5E9; color:var(--green); }
.spec-body { flex:1; min-width:0; }
.spec-titre-row { display:flex; align-items:center; gap:8px; margin-bottom:4px; flex-wrap:wrap; }
.spec-titre { font-size:14px; font-weight:600; color:var(--text); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.spec-meta { font-size:12px; color:var(--muted); display:flex; gap:12px; flex-wrap:wrap; }
.spec-statut { flex-shrink:0; }

/* Projet badge */
.projet-badge { padding:2px 10px; border-radius:99px; background:var(--navy); color:var(--white); font-size:11px; font-weight:600; flex-shrink:0; white-space:nowrap; }

/* Statut badge */
.statut-badge { padding:3px 10px; border-radius:6px; font-size:11px; font-weight:600; }
.statut-BROUILLON { background:#F5F5F5; color:#666; }
.statut-EN_COURS_CC { background:#FFF3E0; color:#E65100; }
.statut-A_VALIDER { background:#EDE7F6; color:var(--purple); }
.statut-VALIDEE { background:#E8F5E9; color:var(--green); }
.statut-ENVOYEE_GITLAB { background:#E3F2FD; color:var(--blue); }

/* Boutons */
.btn { padding:9px 20px; border-radius:8px; font-size:13px; font-weight:600; cursor:pointer; border:none; transition:all 0.12s; }
.btn-primary { background:var(--blue); color:var(--white); }
.btn-primary:hover { background:#1B4A8A; }
.btn-primary:disabled { background:#AAA; cursor:not-allowed; }
.btn-secondary { background:var(--white); color:var(--text); border:1px solid var(--border); }
.btn-secondary:hover { background:var(--grey); }
.btn-success { background:var(--green); color:var(--white); }
.btn-success:hover { background:#1B5E20; }
.btn-danger { background:var(--red); color:var(--white); }
.btn-sm { padding:5px 12px; font-size:12px; }
.btn-claude { background:var(--purple); color:var(--white); padding:7px 16px; border-radius:8px; font-size:12px; font-weight:600; border:none; cursor:pointer; display:inline-flex; align-items:center; gap:6px; }
.btn-claude:hover { background:#3C3489; }
.btn-claude::before { content:'⎘'; font-size:13px; }

/* Éditeur */
.editor-header { display:flex; align-items:center; gap:12px; margin-bottom:16px; }
.editor-header h2 { font-size:18px; font-weight:700; color:var(--navy); flex:1; }
.card { background:var(--white); border:1px solid var(--border); border-radius:10px; padding:20px; margin-bottom:14px; }
.card-title { font-size:11px; font-weight:700; color:var(--muted); text-transform:uppercase; letter-spacing:0.07em; margin-bottom:14px; }
.field { margin-bottom:16px; }
.field:last-child { margin-bottom:0; }
.field label { display:block; font-size:13px; font-weight:600; color:var(--text); margin-bottom:6px; }
.field label .req { color:var(--coral); margin-left:2px; }
.field label .hint { font-weight:400; color:var(--muted); font-size:12px; margin-left:6px; }
.field input[type=text], .field textarea, .field select { width:100%; padding:9px 12px; border:1px solid var(--border); border-radius:8px; font-size:14px; font-family:inherit; color:var(--text); background:var(--white); resize:vertical; }
.field input:focus, .field textarea:focus, .field select:focus { outline:none; border-color:var(--blue); box-shadow:0 0 0 3px rgba(45,95,168,0.1); }
.field textarea { min-height:80px; line-height:1.5; }
.chips { display:flex; flex-wrap:wrap; gap:8px; margin-top:6px; }
.chip { padding:5px 14px; border-radius:99px; border:1px solid var(--border); font-size:12px; cursor:pointer; color:var(--muted); background:var(--white); transition:all 0.12s; user-select:none; }
.chip.active { background:#E6F1FB; color:var(--blue); border-color:var(--blue); font-weight:600; }
.toggles { display:flex; flex-direction:column; }
.toggle-row { display:flex; align-items:center; justify-content:space-between; padding:9px 0; border-bottom:1px solid #F0F0F0; }
.toggle-row:last-child { border-bottom:none; }
.toggle-label { font-size:13px; color:var(--text); }
.toggle-btns { display:flex; gap:6px; }
.toggle-btn { padding:4px 12px; border-radius:6px; border:1px solid var(--border); background:var(--white); cursor:pointer; font-size:12px; color:var(--muted); }
.toggle-btn.sel-oui { background:#E8F5E9; color:var(--green); border-color:var(--green); }
.toggle-btn.sel-non { background:#F5F5F5; color:var(--muted); }
.toggle-btn.sel-nsp { background:#FFF8E1; color:var(--amber); border-color:var(--amber); }
.criteria-list { display:flex; flex-direction:column; gap:8px; }
.criteria-item { display:flex; gap:8px; align-items:flex-start; }
.criteria-item textarea { min-height:52px; flex:1; }
.del-btn { background:none; border:none; cursor:pointer; color:var(--muted); font-size:18px; padding:6px 4px; }
.del-btn:hover { color:var(--coral); }
.add-link { font-size:13px; color:var(--blue); background:none; border:none; cursor:pointer; padding:6px 0; font-weight:500; }
.add-link:hover { text-decoration:underline; }
.labels-grid { display:flex; flex-wrap:wrap; gap:8px; margin-top:8px; }
.label-chip { display:flex; align-items:center; gap:6px; padding:4px 12px; border-radius:99px; border:2px solid transparent; cursor:pointer; font-size:12px; font-weight:600; opacity:0.75; transition:all 0.12s; }
.label-chip.selected { opacity:1; border-color:rgba(0,0,0,0.3); }
.label-dot { width:8px; height:8px; border-radius:50%; flex-shrink:0; }

/* Workflow */
.workflow-bar { display:flex; align-items:center; margin-bottom:16px; background:var(--white); border:1px solid var(--border); border-radius:10px; overflow:hidden; }
.wf-step { flex:1; padding:10px 8px; text-align:center; font-size:11px; font-weight:600; color:var(--muted); border-right:1px solid var(--border); background:var(--white); }
.wf-step:last-child { border-right:none; }
.wf-step.current { background:var(--navy); color:var(--white); }
.wf-step.done { background:#E8F5E9; color:var(--green); }

/* Actions */
.action-bar { display:flex; gap:10px; margin-top:16px; flex-wrap:wrap; align-items:center; }
.gitlab-link { display:inline-flex; align-items:center; gap:6px; color:var(--blue); font-size:13px; font-weight:600; text-decoration:none; }
.gitlab-link:hover { text-decoration:underline; }

/* Export */
.export-spec-item { background:var(--white); border:1px solid var(--border); border-radius:8px; padding:12px 16px; display:flex; align-items:center; gap:12px; }
.export-spec-item.selected { border-color:var(--blue); background:#F0F6FF; }
.export-spec-item .spec-titre { font-size:13px; font-weight:600; flex:1; }

/* Toast */
.toast { position:fixed; bottom:28px; right:28px; background:var(--navy); color:var(--white); padding:14px 22px; border-radius:10px; font-size:14px; max-width:360px; z-index:1000; display:none; box-shadow:0 4px 20px rgba(0,0,0,0.2); }
.toast.success { background:var(--green); }
.toast.error { background:var(--coral); }
.toast a { color:#A8F0C0; }

/* Empty state */
.empty-state { text-align:center; padding:60px 20px; color:var(--muted); }
.empty-state p { font-size:15px; margin-top:8px; }

.spinner { display:inline-block; width:14px; height:14px; border:2px solid rgba(255,255,255,0.4); border-top-color:white; border-radius:50%; animation:spin 0.7s linear infinite; vertical-align:middle; margin-right:6px; }
@keyframes spin { to { transform:rotate(360deg); } }

/* ── Custom select projet ────────────────────────────────────────── */
.custom-select { position:relative; }
.custom-select-trigger {
  display:flex; align-items:center; justify-content:space-between;
  padding:9px 12px; border:1px solid var(--border); border-radius:8px;
  background:var(--white); cursor:pointer; font-size:14px; color:var(--text);
  min-height:38px; user-select:none;
}
.custom-select-trigger:hover { border-color:var(--blue); }
.custom-select-arrow { font-size:11px; color:var(--muted); margin-left:8px; flex-shrink:0; }
.custom-select-dropdown {
  position:absolute; top:calc(100% + 4px); left:0; right:0;
  background:var(--white); border:1px solid var(--border); border-radius:8px;
  box-shadow:0 4px 16px rgba(0,0,0,0.1); z-index:200;
  max-height:280px; overflow-y:auto;
}
.custom-select-option {
  display:flex; align-items:center; gap:10px;
  padding:9px 14px; cursor:pointer; font-size:13px; color:var(--text);
  transition:background 0.1s;
}
.custom-select-option:hover { background:var(--grey); }
.custom-select-option.selected { background:#E6F1FB; font-weight:600; }
.custom-select-option .option-dot {
  width:12px; height:12px; border-radius:50%; flex-shrink:0;
}
.custom-select-option .option-none { color:var(--muted); font-style:italic; }

/* ── Feature cards ───────────────────────────────────────────────── */
.feature-card {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 16px 20px;
  cursor: pointer;
  transition: all 0.12s;
  display: flex;
  align-items: flex-start;
  gap: 14px;
}
.feature-card:hover { border-color: var(--blue); box-shadow: 0 2px 8px rgba(45,95,168,0.1); }
.feature-code {
  padding: 4px 12px;
  border-radius: 8px;
  font-size: 12px;
  font-weight: 700;
  background: var(--navy);
  color: var(--white);
  flex-shrink: 0;
  font-family: monospace;
}
.feature-body { flex: 1; min-width: 0; }
.feature-nom { font-size: 14px; font-weight: 600; color: var(--text); margin-bottom: 4px; }
.feature-meta { font-size: 12px; color: var(--muted); display: flex; gap: 12px; flex-wrap: wrap; }
.feature-statut-badge {
  padding: 3px 10px; border-radius: 6px; font-size: 11px; font-weight: 600;
}
.statut-feature-EN_COURS { background: #E3F2FD; color: var(--blue); }
.statut-feature-TERMINEE { background: #E8F5E9; color: var(--green); }
.statut-feature-ARCHIVEE { background: #F5F5F5; color: #666; }
.feature-infos {
  font-size: 11px;
  color: var(--muted);
  font-family: monospace;
  margin-top: 4px;
}
.feature-spec-count {
  display: inline-flex; align-items: center; gap: 4px;
  padding: 2px 10px; border-radius: 99px;
  background: var(--grey); color: var(--muted);
  font-size: 11px; font-weight: 600;
}
