/* ── Reset & design tokens ───────────────────────────────────────────────── */
:root {
  --blue:          #818CF8;
  --blue-dark:     #6366f1;
  --blue-light:    #e0e7ff;
  --blue-pale:     #f0f4ff;
  --navy:          #0f172a;
  --navy-mid:      #1e293b;
  --slate:         #64748b;
  --slate-light:   #94a3b8;
  --border:        #e2e8f0;
  --border-soft:   #f1f5f9;
  --bg:            #f8faff;
  --surface:       #ffffff;
  --success:       #16a34a;
  --success-bg:    #dcfce7;
  --error:         #dc2626;
  --error-bg:      #fee2e2;
  --warning:       #d97706;
  --warning-bg:    #fef3c7;
  --gold:          #f59e0b;
  --radius-xl:     32px;
  --radius-lg:     24px;
  --radius-md:     16px;
  --radius-sm:     10px;
  --shadow-sm:     0 2px 8px rgba(15,23,42,.06);
  --shadow:        0 8px 28px rgba(15,23,42,.09);
  --shadow-lg:     0 20px 56px rgba(15,23,42,.13);
  font-family: Inter, ui-sans-serif, system-ui, -apple-system, "Segoe UI", sans-serif;
  color: var(--navy);
  background: var(--bg);
  line-height: 1.6;
  color-scheme: light;
}
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { overflow-x: hidden; }
body { min-height: 100dvh; overflow-x: hidden; }
h1,h2,h3,h4 { line-height: 1.2; }
p { color: var(--slate); }
a { color: var(--blue); text-decoration: none; }
a:hover { text-decoration: underline; }
img { max-width: 100%; }

/* ── Utilities ───────────────────────────────────────────────────────────── */
.hidden  { display: none !important; }
.muted   { color: var(--slate); }
.tag {
  display: inline-block;
  padding: 3px 12px;
  border-radius: 999px;
  font-size: .72rem;
  font-weight: 700;
  letter-spacing: .05em;
  text-transform: uppercase;
}

/* ── Inputs & selects ────────────────────────────────────────────────────── */
input, select, textarea {
  width: 100%;
  padding: 12px 16px;
  border: 1.5px solid var(--border);
  border-radius: var(--radius-md);
  background: var(--surface);
  color: var(--navy);
  font: inherit;
  font-size: .925rem;
  outline: none;
  transition: border-color .15s, box-shadow .15s;
}
input:focus, select:focus, textarea:focus {
  border-color: var(--blue);
  box-shadow: 0 0 0 3px rgba(37,99,235,.12);
}
input:disabled, select:disabled, textarea:disabled { opacity: .55; cursor: not-allowed; }
textarea { resize: vertical; min-height: 80px; }

/* ── Buttons ─────────────────────────────────────────────────────────────── */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  min-height: 46px;
  padding: 0 24px;
  border: none;
  border-radius: var(--radius-md);
  font: 600 .925rem/1 inherit;
  cursor: pointer;
  white-space: nowrap;
  transition: background .15s, box-shadow .15s, transform .1s;
  text-decoration: none;
}
.btn:active:not(:disabled) { transform: translateY(1px); }
.btn:disabled { opacity: .55; cursor: not-allowed; }

.btn-primary   { background: linear-gradient(135deg, #818CF8 0%, #6366f1 100%); color: #fff; box-shadow: 0 6px 20px rgba(99,102,241,.38); }
.btn-primary:hover:not(:disabled)  { background: linear-gradient(135deg, #6366f1 0%, #4f46e5 100%); box-shadow: 0 8px 24px rgba(99,102,241,.48); }
.btn-dark      { background: linear-gradient(135deg, #1e293b 0%, #0f172a 100%); color: #fff; box-shadow: 0 6px 20px rgba(15,23,42,.28); }
.btn-dark:hover:not(:disabled)    { background: linear-gradient(135deg, #334155 0%, #1e293b 100%); }
.btn-outline   { background: transparent; color: var(--navy); border: 1.5px solid var(--border); }
.btn-outline:hover:not(:disabled) { background: var(--blue-pale); border-color: var(--blue); color: var(--blue); }
.btn-ghost     { background: transparent; color: var(--slate); border: none; box-shadow: none; }
.btn-ghost:hover:not(:disabled)   { background: var(--blue-pale); color: var(--blue); }
.btn-sm        { min-height: 36px; padding: 0 16px; font-size: .82rem; }
.btn-xs        { min-height: 26px; padding: 0 10px; font-size: .74rem; }
.btn-lg        { min-height: 54px; padding: 0 32px; font-size: 1.05rem; }

button[type="submit"] { @extend .btn; @extend .btn-primary; width: 100%; }

/* ════════════════════════════════════════════════════════════════════════════
   LANDING PAGE
   ════════════════════════════════════════════════════════════════════════════ */

/* ── Landing nav ─────────────────────────────────────────────────────────── */
.land-nav {
  position: sticky;
  top: 0;
  z-index: 200;
  display: flex;
  align-items: center;
  gap: 32px;
  padding: 0 40px;
  height: 64px;
  background: rgba(255,255,255,.92);
  backdrop-filter: blur(12px);
  border-bottom: 1px solid var(--border);
}
.land-nav-links {
  display: flex;
  gap: 28px;
  flex: 1;
}
.land-nav-links a {
  font-size: .88rem;
  font-weight: 600;
  color: var(--slate);
  transition: color .15s;
}
.land-nav-links a:hover { color: var(--blue); text-decoration: none; }
.land-nav-cta { display: flex; gap: 10px; align-items: center; }

/* ── Hero slider ─────────────────────────────────────────────────────────── */
.hero {
  position: relative;
  overflow: hidden;
  padding: 96px 40px 80px;
  min-height: 580px;
  color: #fff;
  background: #1e1b4b;
}

/* Slides images */
.hero-slide {
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: center top;
  opacity: 0;
  transition: opacity 1.6s ease;
  will-change: opacity;
}
.hero-slide.active { opacity: 1; }

/* Overlay gradient pour lisibilité du texte */
.hero-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(
    135deg,
    rgba(30, 27, 75, .84) 0%,
    rgba(67, 56, 202, .70) 60%,
    rgba(129, 140, 248, .45) 100%
  );
  z-index: 1;
}

/* Navigation dots */
.slide-nav {
  position: absolute;
  bottom: 28px;
  left: 50%;
  transform: translateX(-50%);
  display: flex;
  gap: 10px;
  z-index: 3;
}
.slide-dot {
  width: 9px; height: 9px;
  border-radius: 50%;
  border: 2px solid rgba(255,255,255,.6);
  background: transparent;
  cursor: pointer;
  box-shadow: none;
  min-height: auto;
  padding: 0;
  transition: background .3s, transform .3s, border-color .3s;
}
.slide-dot.active {
  background: #fff;
  border-color: #fff;
  transform: scale(1.25);
}
.hero-inner {
  position: relative;
  z-index: 2;
  max-width: 1080px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 460px;
  gap: 64px;
  align-items: center;
}
.hero-eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 6px 14px;
  border-radius: 999px;
  background: rgba(255,255,255,.12);
  border: 1px solid rgba(255,255,255,.2);
  color: #bfdbfe;
  font-size: .78rem;
  font-weight: 700;
  letter-spacing: .06em;
  text-transform: uppercase;
  margin-bottom: 24px;
}
.hero-eyebrow span { width: 6px; height: 6px; border-radius: 50%; background: #818CF8; display: block; }
.hero h1 {
  font-size: clamp(2.4rem, 5vw, 3.8rem);
  font-weight: 800;
  color: #fff;
  margin-bottom: 20px;
  line-height: 1.1;
}
.hero h1 em { color: #818CF8; font-style: normal; }
.hero-sub {
  font-size: 1.1rem;
  color: #cbd5e1;
  margin-bottom: 36px;
  max-width: 520px;
}
.hero-actions { display: flex; gap: 14px; flex-wrap: wrap; margin-bottom: 40px; }
.hero-trust {
  display: flex;
  align-items: center;
  gap: 10px;
  color: #94a3b8;
  font-size: .83rem;
}
.hero-trust span {
  padding: 3px 10px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.15);
  font-weight: 600;
  font-size: .75rem;
  color: #cbd5e1;
}

/* ── Dashboard preview (CSS) ─────────────────────────────────────────────── */
.hero-visual {
  position: relative;
}
.dash-preview {
  background: #fff;
  border-radius: var(--radius-lg);
  box-shadow: 0 40px 80px rgba(0,0,0,.4), 0 0 0 1px rgba(255,255,255,.1);
  overflow: hidden;
  transform: perspective(1000px) rotateY(-6deg) rotateX(2deg);
  transition: transform .4s;
}
.dash-preview:hover { transform: perspective(1000px) rotateY(-2deg) rotateX(1deg); }
.dash-bar {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 10px 14px;
  background: #f8fafc;
  border-bottom: 1px solid #e2e8f0;
}
.dash-dot { width: 8px; height: 8px; border-radius: 50%; }
.dash-body { padding: 16px; display: flex; flex-direction: column; gap: 8px; }
.dash-msg {
  padding: 10px 12px;
  border-radius: 10px;
  font-size: .78rem;
  line-height: 1.4;
  color: #1e293b;
}
.dash-msg.q  { background: #2563eb; color: #fff; align-self: flex-end; max-width: 75%; }
.dash-msg.a  { background: #f1f5f9; max-width: 88%; }
.dash-msg.src { background: #eff6ff; border: 1px solid #bfdbfe; max-width: 88%; }
.dash-typing { display: flex; gap: 4px; padding: 8px 12px; }
.dash-typing span {
  width: 6px; height: 6px; border-radius: 50%; background: #94a3b8;
  animation: blink 1.2s ease-in-out infinite;
}
.dash-typing span:nth-child(2) { animation-delay: .2s; }
.dash-typing span:nth-child(3) { animation-delay: .4s; }
@keyframes blink { 0%,100% { opacity: .3 } 50% { opacity: 1 } }

/* ── Connector logos strip ───────────────────────────────────────────────── */
.connectors-strip {
  padding: 28px 40px;
  background: var(--surface);
  border-bottom: 1px solid var(--border);
}
.connectors-strip-inner {
  max-width: 1080px;
  margin: 0 auto;
  display: flex;
  align-items: center;
  gap: 32px;
  flex-wrap: wrap;
  justify-content: center;
}
.connectors-strip p {
  font-size: .78rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .08em;
  color: var(--slate-light);
  white-space: nowrap;
}
.conn-pill {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 6px 16px;
  border-radius: 999px;
  border: 1px solid var(--border);
  font-size: .82rem;
  font-weight: 600;
  color: var(--navy-mid);
}
.conn-icon {
  width: 20px; height: 20px;
  border-radius: 5px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: .65rem;
  font-weight: 800;
  color: #fff;
}

/* ── Features section ────────────────────────────────────────────────────── */
.features {
  padding: 96px 40px;
  background: var(--bg);
}
.section-center {
  max-width: 1080px;
  margin: 0 auto;
}
.section-label {
  display: inline-block;
  margin-bottom: 16px;
  padding: 4px 14px;
  border-radius: 999px;
  background: var(--blue-light);
  color: var(--blue);
  font-size: .72rem;
  font-weight: 800;
  letter-spacing: .08em;
  text-transform: uppercase;
}
.section-title {
  font-size: clamp(1.8rem, 4vw, 2.8rem);
  font-weight: 800;
  margin-bottom: 12px;
  color: var(--navy);
}
.section-sub { font-size: 1.05rem; margin: 0 auto 56px; max-width: 560px; text-align: center; }
.features-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
}
.feat-card {
  padding: 0;
  border-radius: var(--radius-lg);
  border: 1px solid var(--border);
  background: var(--surface);
  box-shadow: var(--shadow-sm);
  transition: box-shadow .2s, transform .2s;
  overflow: hidden;
}
.feat-card:hover { box-shadow: var(--shadow); transform: translateY(-3px); }
.feat-img {
  width: 100%;
  height: 180px;
  overflow: hidden;
}
.feat-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform .4s ease;
  display: block;
}
.feat-card:hover .feat-img img { transform: scale(1.05); }
.feat-card h3 { font-size: 1.02rem; margin: 20px 22px 6px; color: var(--navy); font-weight: 700; }
.feat-card p  { font-size: .87rem; line-height: 1.65; margin: 0 22px 22px; color: var(--muted); }

/* ── Lang button ─────────────────────────────────────────────────────────── */
.lang-btn {
  border: 1px solid var(--border);
  background: transparent;
  color: var(--navy);
  border-radius: 6px;
  padding: 4px 10px;
  font-size: .8rem;
  font-weight: 700;
  cursor: pointer;
  letter-spacing: .04em;
  transition: background .15s, color .15s;
}
.lang-btn:hover { background: var(--blue-light); color: var(--blue-dark); border-color: var(--blue); }
.topnav .lang-btn { color: #fff; border-color: rgba(255,255,255,.3); }
.topnav .lang-btn:hover { background: rgba(255,255,255,.12); color: #fff; }

/* ── Lang switcher (EN | FR | ES compact group) ─────────────────────────── */
.lang-switcher {
  display: flex;
  align-items: center;
  gap: 0;
  background: var(--blue-pale);
  border: 1.5px solid var(--blue-light);
  border-radius: 8px;
  padding: 2px 4px;
  white-space: nowrap;
  flex-shrink: 0;
}
.lang-sw-btn {
  font-size: .76rem;
  font-weight: 700;
  color: var(--slate);
  background: transparent;
  border: none;
  box-shadow: none;
  padding: 4px 8px;
  min-height: auto;
  min-width: 32px;
  cursor: pointer;
  border-radius: 5px;
  transition: background .15s, color .15s;
  letter-spacing: .04em;
  line-height: 1;
}
.lang-sw-btn:hover { color: var(--blue); }
.lang-sw-btn.lang-sw-active { background: var(--blue); color: #fff; }
.lang-sw-pipe { color: var(--blue-light); font-size: .65rem; user-select: none; padding: 0 1px; }

/* ── Pricing section ─────────────────────────────────────────────────────── */
.pricing {
  padding: 96px 40px;
  background: linear-gradient(180deg, var(--surface) 0%, var(--blue-pale) 100%);
}
.trial-banner {
  max-width: 680px;
  margin: 0 auto 56px;
  padding: 20px 28px;
  border-radius: var(--radius-lg);
  background: linear-gradient(135deg, #fef3c7, #fde68a);
  border: 1px solid #fbbf24;
  display: flex;
  align-items: center;
  gap: 16px;
  font-weight: 600;
  color: #78350f;
}
.trial-banner .trial-icon { font-size: 1.6rem; flex-shrink: 0; }
.pricing-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 320px));
  gap: 24px;
  justify-content: center;
  margin-top: 0;
}
.price-card {
  padding: 36px;
  border-radius: var(--radius-xl);
  border: 2px solid var(--border);
  background: var(--surface);
  box-shadow: var(--shadow);
  position: relative;
  display: flex;
  flex-direction: column;
  gap: 24px;
}
.price-card.featured {
  border-color: var(--blue);
  background: linear-gradient(145deg, #fff, #eef4ff);
  box-shadow: var(--shadow-lg), 0 0 0 4px rgba(37,99,235,.08);
}
.price-badge {
  position: absolute;
  top: -14px;
  left: 50%;
  transform: translateX(-50%);
  padding: 4px 16px;
  border-radius: 999px;
  background: var(--blue);
  color: #fff;
  font-size: .75rem;
  font-weight: 800;
  letter-spacing: .06em;
  text-transform: uppercase;
  white-space: nowrap;
}
.price-period { font-size: .85rem; font-weight: 600; color: var(--slate); margin-bottom: 6px; }
.price-amount { font-size: 3rem; font-weight: 800; color: var(--navy); line-height: 1; }
.price-amount sup { font-size: 1.2rem; vertical-align: top; margin-top: 10px; }
.price-amount sub { font-size: 1rem; font-weight: 500; color: var(--slate); }
.price-saving { font-size: .8rem; font-weight: 600; color: var(--success); margin-top: 6px; }
.price-features { display: flex; flex-direction: column; gap: 10px; }
.price-feat {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  font-size: .9rem;
  color: var(--navy-mid);
}
.price-feat::before { content: "✓"; color: var(--success); font-weight: 800; flex-shrink: 0; }
.price-trial { font-size: .82rem; color: var(--slate); text-align: center; }
.price-target { font-size: .78rem; color: var(--slate); font-weight: 500; margin-bottom: 6px; }
.price-nofeat { display:flex; align-items:flex-start; gap:10px; font-size:.88rem; color:#94a3b8; }
.price-nofeat::before { content:"✕"; color:#cbd5e1; font-weight:800; flex-shrink:0; }
.price-card.enterprise { background:linear-gradient(145deg,#1e1b4b,#312e81); border-color:#4338ca; }
.price-card.enterprise .price-feat { color:rgba(255,255,255,.88); }
.price-card.enterprise .price-feat::before { color:#a5b4fc; }
.price-card.enterprise .price-nofeat { color:rgba(255,255,255,.35); }
.price-card.enterprise .price-trial { color:rgba(255,255,255,.45); }

/* ── Footer ──────────────────────────────────────────────────────────────── */
footer {
  padding: 64px 40px 40px;
  background: var(--navy);
  color: #94a3b8;
}
.footer-inner {
  max-width: 1080px;
  margin: 0 auto;
}
.footer-top {
  display: grid;
  grid-template-columns: 1.4fr repeat(3, 1fr);
  gap: 48px;
  padding-bottom: 48px;
  border-bottom: 1px solid #1e293b;
}
.footer-brand p { font-size: .9rem; margin-top: 12px; max-width: 260px; line-height: 1.6; }
.footer-col h4 {
  color: #e2e8f0;
  font-size: .82rem;
  font-weight: 700;
  letter-spacing: .06em;
  text-transform: uppercase;
  margin-bottom: 16px;
}
.footer-col ul { list-style: none; display: flex; flex-direction: column; gap: 10px; }
.footer-col a { color: #94a3b8; font-size: .88rem; transition: color .15s; }
.footer-col a:hover { color: #fff; text-decoration: none; }
.footer-bottom {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding-top: 32px;
  font-size: .82rem;
  flex-wrap: wrap;
  gap: 12px;
}
.footer-bottom a { color: #64748b; }
.footer-bottom a:hover { color: #94a3b8; }

/* ── EIP Badge ───────────────────────────────────────────────────────────── */
.eip-badge {
  display: inline-block;
  background: linear-gradient(135deg,#818CF8,#6366f1);
  color: #fff;
  font-size: .58rem;
  font-weight: 800;
  letter-spacing: .08em;
  padding: 2px 7px;
  border-radius: 4px;
  vertical-align: middle;
  margin-left: 4px;
}

/* ── Executive Intelligence Banner ──────────────────────────────────────── */
.eip-stats-banner {
  background: linear-gradient(135deg, #0f172a 0%, #1e293b 100%);
  padding: 40px 40px 28px;
  text-align: center;
}
.eip-stats-inner {
  max-width: 900px;
  margin: 0 auto;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0;
  flex-wrap: wrap;
}
.eip-stat-item {
  padding: 12px 36px;
  text-align: center;
}
.eip-stat-value {
  font-size: clamp(1.6rem, 3vw, 2.4rem);
  font-weight: 900;
  color: #fff;
  letter-spacing: -.02em;
  line-height: 1;
}
.eip-stat-label {
  font-size: .72rem;
  color: #94a3b8;
  font-weight: 600;
  letter-spacing: .06em;
  text-transform: uppercase;
  margin-top: 6px;
}
.eip-stat-risk .eip-stat-value { color: #ef4444; }
.eip-stat-divider {
  width: 1px;
  height: 48px;
  background: #334155;
}
.eip-stats-tagline {
  margin: 20px auto 0;
  color: #64748b;
  font-size: .88rem;
  max-width: 500px;
}
.eip-stats-tagline strong { color: #818CF8; }

/* ── What EIP Sees (flow) ────────────────────────────────────────────────── */
.eip-flow-section {
  padding: 80px 40px;
  background: #f8faff;
}
.eip-flow-grid {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 24px;
  margin-top: 56px;
  flex-wrap: wrap;
}
.eip-flow-sources,
.eip-flow-outputs {
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.eip-flow-source,
.eip-flow-output {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 16px;
  border-radius: var(--radius-md);
  font-size: .88rem;
  font-weight: 600;
  background: #fff;
  border: 1.5px solid var(--border);
  box-shadow: var(--shadow-sm);
  min-width: 170px;
  color: var(--navy);
}
.eip-flow-output {
  border-width: 1.5px;
  font-size: .85rem;
}
.eip-flow-output span:first-child { font-size: 1.1rem; }
.eip-conn-icon {
  width: 28px;
  height: 28px;
  border-radius: 6px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: .65rem;
  font-weight: 800;
  color: #fff;
  flex-shrink: 0;
}
.eip-flow-center {
  display: flex;
  align-items: center;
  gap: 0;
}
.eip-flow-connectors {
  display: flex;
  flex-direction: column;
  gap: 8px;
  padding: 0 4px;
}
.eip-flow-line {
  width: 40px;
  height: 2px;
  background: linear-gradient(90deg, #818CF8, #e0e7ff);
  border-radius: 2px;
}
.eip-line-right {
  background: linear-gradient(90deg, #e0e7ff, #818CF8);
}
.eip-engine-box {
  position: relative;
  background: linear-gradient(135deg, #818CF8 0%, #6366f1 100%);
  border-radius: var(--radius-lg);
  padding: 28px 24px;
  text-align: center;
  box-shadow: 0 16px 40px rgba(99,102,241,.35);
  min-width: 160px;
}
.eip-engine-glow {
  position: absolute;
  inset: -12px;
  background: radial-gradient(circle, rgba(129,140,248,.2) 0%, transparent 70%);
  border-radius: var(--radius-xl);
  pointer-events: none;
}
.eip-engine-icon { font-size: 2rem; margin-bottom: 8px; }
.eip-engine-label {
  color: #fff;
  font-size: .8rem;
  font-weight: 700;
  letter-spacing: .02em;
  line-height: 1.3;
}

/* ── Executive Dashboard Demo ────────────────────────────────────────────── */
.exec-demo-section {
  padding: 80px 40px;
  background: linear-gradient(180deg, #fff 0%, #f8faff 100%);
}
.exec-demo-wrap {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 32px;
  margin-top: 48px;
  background: #fff;
  border: 1px solid var(--border);
  border-radius: var(--radius-xl);
  padding: 36px;
  box-shadow: var(--shadow);
}
.exec-kpi-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
}
.exec-kpi-card {
  background: var(--bg);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  padding: 20px;
}
.exec-kpi-green-card { background: #f0fdf4; border-color: #bbf7d0; }
.exec-kpi-label { font-size: .72rem; font-weight: 700; color: var(--slate); text-transform: uppercase; letter-spacing: .06em; margin-bottom: 8px; }
.exec-kpi-value { font-size: 1.6rem; font-weight: 900; color: var(--navy); letter-spacing: -.02em; line-height: 1; }
.exec-kpi-bar { height: 4px; background: var(--border); border-radius: 2px; margin: 10px 0 6px; overflow: hidden; }
.exec-kpi-fill { height: 100%; background: var(--blue); border-radius: 2px; }
.exec-kpi-sub { font-size: .72rem; color: var(--slate); margin-top: 4px; }
.exec-recommendations {
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.exec-rec-title {
  font-size: .75rem;
  font-weight: 800;
  color: var(--slate);
  text-transform: uppercase;
  letter-spacing: .08em;
  margin-bottom: 12px;
}
.exec-rec-item {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  padding: 14px 16px;
  border-radius: var(--radius-sm);
  background: #f8faff;
  border: 1px solid var(--border-soft);
  font-size: .85rem;
}
.exec-rec-item strong { color: var(--navy); }
.exec-rec-item span:last-child { color: var(--slate); }
.exec-rec-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  flex-shrink: 0;
  margin-top: 5px;
}

/* ── Workspaces ──────────────────────────────────────────────────────────── */
.eip-workspaces-section {
  padding: 80px 40px;
  background: #f8faff;
}
.workspaces-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 24px;
  margin-top: 48px;
}
.workspace-card {
  position: relative;
  background: #fff;
  border: 1px solid var(--border);
  border-radius: var(--radius-xl);
  padding: 32px 24px;
  transition: box-shadow .2s, transform .2s;
}
.workspace-card:hover {
  box-shadow: var(--shadow);
  transform: translateY(-3px);
}
.workspace-featured {
  border-color: #818CF8;
  box-shadow: 0 0 0 3px rgba(129,140,248,.15);
}
.workspace-badge {
  position: absolute;
  top: -11px;
  left: 50%;
  transform: translateX(-50%);
  background: var(--blue);
  color: #fff;
  font-size: .66rem;
  font-weight: 700;
  letter-spacing: .06em;
  text-transform: uppercase;
  padding: 3px 12px;
  border-radius: 20px;
  white-space: nowrap;
}
.workspace-icon {
  width: 52px;
  height: 52px;
  border-radius: var(--radius-md);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.5rem;
  margin-bottom: 16px;
}
.workspace-card h3 { font-size: 1rem; margin-bottom: 14px; }
.workspace-list {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.workspace-list li {
  font-size: .83rem;
  color: var(--slate);
  padding-left: 14px;
  position: relative;
}
.workspace-list li::before {
  content: '→';
  position: absolute;
  left: 0;
  color: var(--blue);
  font-size: .78rem;
}

/* ── Use Cases ───────────────────────────────────────────────────────────── */
.use-cases-section {
  padding: 80px 40px;
  background: #fff;
}
.use-cases-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 24px;
  margin-top: 48px;
}
.use-case-card {
  background: var(--bg);
  border: 1px solid var(--border);
  border-radius: var(--radius-xl);
  padding: 28px 24px;
  transition: box-shadow .2s, transform .2s;
}
.use-case-card:hover { box-shadow: var(--shadow); transform: translateY(-3px); }
.use-case-role {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(135deg, #0f172a, #1e293b);
  color: #fff;
  font-size: .75rem;
  font-weight: 800;
  letter-spacing: .04em;
  padding: 5px 14px;
  border-radius: 20px;
  margin-bottom: 16px;
}
.use-case-q {
  font-size: .95rem;
  font-weight: 700;
  color: var(--navy);
  line-height: 1.4;
  font-style: italic;
  margin-bottom: 14px;
}
.use-case-systems {
  font-size: .75rem;
  color: var(--slate-light);
  font-weight: 600;
}

/* ── Integrations ────────────────────────────────────────────────────────── */
.integrations-section {
  padding: 80px 40px;
  background: var(--bg);
}
.integrations-tagline {
  display: flex;
  gap: 32px;
  justify-content: center;
  flex-wrap: wrap;
  margin: 16px 0 48px;
}
.integrations-tagline span {
  font-size: .88rem;
  color: var(--slate);
  font-weight: 600;
  padding-left: 18px;
  position: relative;
}
.integrations-tagline span::before {
  content: '✓';
  position: absolute;
  left: 0;
  color: #16a34a;
  font-weight: 700;
}
.integrations-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 14px;
  max-width: 860px;
  margin: 0 auto;
}
.integration-item {
  display: flex;
  align-items: center;
  gap: 10px;
  background: #fff;
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  padding: 12px 16px;
  font-size: .85rem;
  font-weight: 600;
  color: var(--navy);
  transition: box-shadow .15s;
}
.integration-item:hover { box-shadow: var(--shadow-sm); }
.integration-check {
  color: #16a34a;
  font-weight: 800;
  font-size: .8rem;
  flex-shrink: 0;
}

/* ── Enterprise Security ─────────────────────────────────────────────────── */
.security-section {
  padding: 80px 40px;
  background: linear-gradient(135deg, #0f172a 0%, #1a2744 100%);
}
.security-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
  margin-top: 0;
  max-width: 900px;
  margin-left: auto;
  margin-right: auto;
}
.security-item {
  display: flex;
  align-items: flex-start;
  gap: 14px;
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.08);
  border-radius: var(--radius-md);
  padding: 20px;
}
.security-check {
  flex-shrink: 0;
  width: 28px;
  height: 28px;
  background: rgba(129,140,248,.2);
  color: #818CF8;
  font-weight: 800;
  font-size: .88rem;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-top: 1px;
}
.security-item strong { color: #e2e8f0; font-size: .9rem; display: block; margin-bottom: 4px; }
.security-item p { color: #64748b; font-size: .8rem; margin: 0; line-height: 1.5; }

/* ── ROI Calculator ──────────────────────────────────────────────────────── */
.roi-section {
  padding: 80px 40px;
  background: linear-gradient(180deg, #f8faff 0%, #fff 100%);
}
.roi-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 20px;
  max-width: 900px;
  margin: 0 auto;
}
.roi-card {
  background: #fff;
  border: 1px solid var(--border);
  border-radius: var(--radius-xl);
  padding: 32px 20px;
  text-align: center;
  box-shadow: var(--shadow-sm);
  transition: box-shadow .2s, transform .2s;
}
.roi-card:hover { box-shadow: var(--shadow); transform: translateY(-3px); }
.roi-card-green { border-color: #bbf7d0; background: #f0fdf4; }
.roi-card-gold  { border-color: #fde68a; background: linear-gradient(135deg,#fffbeb,#fef3c7); box-shadow: 0 8px 24px rgba(245,158,11,.15); }
.roi-card-icon  { font-size: 1.8rem; margin-bottom: 12px; }
.roi-card-label { font-size: .72rem; font-weight: 700; color: var(--slate); text-transform: uppercase; letter-spacing: .06em; margin-bottom: 12px; }
.roi-card-value { font-size: 1.5rem; font-weight: 900; color: var(--navy); letter-spacing: -.02em; }
.roi-card-value span { font-size: .85rem; font-weight: 600; color: var(--slate); }

/* ── Demo Player ─────────────────────────────────────────────────────────── */
.demo-section { padding: 80px 40px; background: #f8faff; }
.demo-player {
  max-width: 860px;
  margin: 0 auto;
  background: #080d1a;
  border-radius: 20px;
  overflow: hidden;
  box-shadow: 0 32px 80px rgba(0,0,0,.5), 0 0 0 1px rgba(255,255,255,.06);
}
.demo-chrome {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 12px 20px;
  background: #0f1628;
  border-bottom: 1px solid rgba(255,255,255,.06);
}
.demo-chrome-dots { display: flex; gap: 7px; }
.demo-cdot { width: 12px; height: 12px; border-radius: 50%; }
.demo-chrome-title { font-size: .78rem; color: #64748b; font-weight: 600; letter-spacing: .02em; }

.demo-stage { min-height: 380px; display: flex; align-items: center; justify-content: center; padding: 32px 40px; position: relative; overflow: hidden; }

.demo-slide {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding: 32px 48px;
  opacity: 1;
  transition: opacity .6s ease, transform .6s ease;
}
.demo-slide-hidden { opacity: 0; pointer-events: none; transform: translateY(12px); }

.demo-slide-num { font-size: .68rem; color: #334155; font-weight: 700; letter-spacing: .12em; text-transform: uppercase; margin-bottom: 16px; }
.demo-big-icon { font-size: 3rem; margin-bottom: 16px; }
.demo-icon-red { filter: grayscale(0); }
.demo-slide-headline { font-size: clamp(1.4rem, 2.5vw, 2rem); font-weight: 900; color: #e2e8f0; letter-spacing: -.02em; line-height: 1.2; margin-bottom: 12px; }
.demo-slide-sub { font-size: .92rem; color: #64748b; line-height: 1.6; max-width: 600px; }

.demo-pill-row { display: flex; gap: 8px; flex-wrap: wrap; justify-content: center; margin-top: 20px; }
.demo-pill-row span { background: rgba(129,140,248,.15); color: #818CF8; font-size: .75rem; font-weight: 700; padding: 4px 12px; border-radius: 20px; border: 1px solid rgba(129,140,248,.25); }

.demo-silos-row { display: flex; align-items: center; gap: 4px; flex-wrap: wrap; justify-content: center; margin-top: 20px; }
.demo-silo { background: rgba(239,68,68,.12); border: 1px solid rgba(239,68,68,.25); color: #fca5a5; font-size: .78rem; font-weight: 700; padding: 6px 12px; border-radius: 8px; }
.demo-silo-sep { color: #334155; font-size: .78rem; }
.demo-silo-more { background: rgba(100,116,139,.12); border-color: rgba(100,116,139,.25); color: #64748b; }

.demo-check-list { display: flex; flex-direction: column; gap: 10px; margin-top: 20px; text-align: left; }
.demo-check-row { flex-direction: row; flex-wrap: wrap; justify-content: center; gap: 12px; }
.demo-check-item { display: flex; align-items: center; gap: 10px; font-size: .88rem; color: #94a3b8; }
.demo-check-green { color: #10b981; font-weight: 800; font-size: 1rem; }
.demo-check-blue  { color: #818CF8; font-weight: 800; font-size: 1rem; }

.demo-kpi-hero { margin: 8px 0 4px; }
.demo-kpi-num { font-size: clamp(2.4rem,5vw,3.6rem); font-weight: 900; letter-spacing: -.03em; line-height: 1; }
.demo-kpi-green { color: #10b981; }
.demo-kpi-gold  { color: #f59e0b; }
.demo-kpi-label { font-size: .78rem; color: #475569; font-weight: 700; text-transform: uppercase; letter-spacing: .08em; margin-top: 8px; }

.demo-license-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; margin-top: 20px; width: 100%; max-width: 400px; }
.demo-license-card { background: rgba(255,255,255,.04); border: 1px solid rgba(255,255,255,.08); border-radius: 12px; padding: 16px; }
.demo-license-green  { border-color: rgba(16,185,129,.3); background: rgba(16,185,129,.08); }
.demo-license-purple { border-color: rgba(129,140,248,.3); background: rgba(129,140,248,.08); }
.demo-lic-num { font-size: 1.6rem; font-weight: 900; color: #e2e8f0; }
.demo-license-green .demo-lic-num  { color: #10b981; }
.demo-license-purple .demo-lic-num { color: #818CF8; }
.demo-lic-label { font-size: .7rem; color: #64748b; margin-top: 4px; font-weight: 600; }

.demo-exec-grid { display: grid; grid-template-columns: repeat(4,1fr); gap: 12px; margin-top: 20px; width: 100%; max-width: 500px; }
.demo-exec-kpi { background: rgba(255,255,255,.04); border: 1px solid rgba(255,255,255,.07); border-radius: 10px; padding: 14px 8px; }
.demo-exec-val { font-size: 1.2rem; font-weight: 900; color: #e2e8f0; }
.demo-exec-lab { font-size: .62rem; color: #475569; font-weight: 700; text-transform: uppercase; letter-spacing: .06em; margin-top: 4px; }

.demo-rec-list { display: flex; flex-direction: column; gap: 10px; margin-top: 20px; text-align: left; max-width: 460px; width: 100%; }
.demo-rec-item { display: flex; align-items: flex-start; gap: 10px; font-size: .9rem; color: #94a3b8; background: rgba(255,255,255,.03); border: 1px solid rgba(255,255,255,.06); border-radius: 8px; padding: 10px 14px; }
.demo-rec-item span { color: #818CF8; font-weight: 800; flex-shrink: 0; }
.demo-rec-item strong { color: #c7d2fe; }

.demo-roi-grid { display: flex; align-items: center; gap: 16px; margin-top: 20px; flex-wrap: wrap; justify-content: center; }
.demo-roi-item { background: rgba(255,255,255,.04); border: 1px solid rgba(255,255,255,.08); border-radius: 12px; padding: 16px 24px; text-align: center; }
.demo-roi-green { border-color: rgba(16,185,129,.3); background: rgba(16,185,129,.08); }
.demo-roi-item span { display: block; font-size: .68rem; color: #475569; font-weight: 700; text-transform: uppercase; letter-spacing: .08em; margin-bottom: 6px; }
.demo-roi-item strong { font-size: 1.3rem; color: #e2e8f0; font-weight: 900; }
.demo-roi-green strong { color: #10b981; }
.demo-roi-sep { font-size: 1.4rem; color: #334155; }

.demo-vision-logo { font-size: 1.3rem; font-weight: 900; color: #818CF8; margin-bottom: 16px; letter-spacing: -.01em; }
.demo-vision-headline { font-size: clamp(1.3rem,2.5vw,1.8rem); font-weight: 900; color: #e2e8f0; max-width: 560px; margin-bottom: 12px; line-height: 1.3; }

.demo-controls { background: #0a1120; border-top: 1px solid rgba(255,255,255,.06); padding: 12px 20px 16px; }
.demo-progress-track { height: 3px; background: rgba(255,255,255,.08); border-radius: 2px; overflow: hidden; margin-bottom: 10px; cursor: pointer; }
.demo-progress-fill { height: 100%; background: linear-gradient(90deg,#818CF8,#6366f1); border-radius: 2px; width: 0%; transition: width .3s linear; }
.demo-controls-row { display: flex; align-items: center; gap: 12px; }
.demo-ctrl-btn { background: rgba(255,255,255,.07); border: 1px solid rgba(255,255,255,.1); color: #94a3b8; font-size: .85rem; border-radius: 6px; padding: 4px 10px; cursor: pointer; transition: background .15s; min-height: auto; box-shadow: none; }
.demo-ctrl-btn:hover { background: rgba(255,255,255,.12); color: #fff; }
.demo-ctrl-play { background: rgba(129,140,248,.2); border-color: rgba(129,140,248,.4); color: #818CF8; }
.demo-time-label { font-size: .72rem; color: #475569; font-weight: 600; margin-left: 4px; }
.demo-slide-dots { display: flex; gap: 4px; margin-left: auto; }
.demo-sdot { width: 6px; height: 6px; border-radius: 50%; background: rgba(255,255,255,.15); transition: background .2s, transform .2s; cursor: pointer; }
.demo-sdot.active { background: #818CF8; transform: scale(1.3); }

/* ── Contact Section ─────────────────────────────────────────────────────── */
.contact-section {
  padding: 80px 40px;
  background: linear-gradient(135deg, #0f172a 0%, #1a2744 100%);
}
.contact-inner {
  max-width: 1080px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 64px;
  align-items: center;
}
.contact-benefits { display: flex; flex-direction: column; gap: 16px; }
.contact-benefit { display: flex; align-items: flex-start; gap: 12px; font-size: .9rem; color: #94a3b8; line-height: 1.5; }
.contact-benefit span:first-child { font-size: 1.1rem; flex-shrink: 0; margin-top: 1px; }
.contact-form-card { background: #fff; border-radius: 20px; padding: 36px; box-shadow: 0 20px 60px rgba(0,0,0,.3); display: flex; flex-direction: column; gap: 16px; }
.contact-row { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }

/* ════════════════════════════════════════════════════════════════════════════
   AUTH PAGES — Layout deux panneaux (institution)
   ════════════════════════════════════════════════════════════════════════════ */
.auth-screen {
  min-height: 100dvh;
  display: grid;
  grid-template-columns: 1fr 1fr;
}

/* ── Panneau gauche ── */
.auth-left {
  background: #0f172a;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 60px 48px;
  position: relative;
  overflow: hidden;
}
.auth-left::before {
  content: '';
  position: absolute;
  top: -160px; left: -160px;
  width: 480px; height: 480px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(99,102,241,.18) 0%, transparent 70%);
  pointer-events: none;
}
.auth-left::after {
  content: '';
  position: absolute;
  bottom: -120px; right: -120px;
  width: 360px; height: 360px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(129,140,248,.12) 0%, transparent 70%);
  pointer-events: none;
}
.auth-left-inner {
  position: relative;
  z-index: 1;
  max-width: 380px;
}
.auth-left-logo {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 48px;
}
.auth-left-logo-icon {
  width: 44px; height: 44px;
  border-radius: 10px;
  background: linear-gradient(135deg, #818CF8, #6366f1);
  display: flex; align-items: center; justify-content: center;
  font-size: 1.4rem; font-weight: 900; color: #fff;
  letter-spacing: -1px;
  box-shadow: 0 4px 16px rgba(99,102,241,.4);
}
.auth-left-logo-text {
  font-size: 1.15rem; font-weight: 800; color: #fff; letter-spacing: -.3px;
}
.auth-left-logo-text span { color: #818CF8; }
.auth-left-headline {
  font-size: 2rem; font-weight: 800; color: #fff;
  line-height: 1.25; margin-bottom: 16px; letter-spacing: -.5px;
}
.auth-left-sub {
  font-size: .95rem; color: #94a3b8; line-height: 1.6; margin-bottom: 36px;
}
.auth-left-features {
  list-style: none; padding: 0; margin: 0 0 48px; display: flex; flex-direction: column; gap: 14px;
}
.auth-left-features li {
  display: flex; align-items: center; gap: 12px;
  font-size: .88rem; color: #cbd5e1; font-weight: 500;
}
.auth-feat-dot {
  flex-shrink: 0; width: 6px; height: 6px; border-radius: 50%;
  background: #818CF8;
  box-shadow: 0 0 8px rgba(129,140,248,.6);
}
.auth-left-footer {
  display: flex; align-items: center; gap: 8px;
  font-size: .78rem; color: #475569; font-weight: 500;
  padding-top: 24px;
  border-top: 1px solid rgba(255,255,255,.07);
}

/* ── Lang bar sur la page auth ── */
.auth-lang-bar {
  position: absolute;
  top: 16px;
  right: 20px;
  display: flex;
  align-items: center;
  gap: 0;
  z-index: 10;
}

/* ── Panneau droit ── */
.auth-right {
  background: #f8fafc;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 48px 40px;
  position: relative;
  overflow-y: auto;
}
.auth-card {
  width: 100%;
  max-width: 420px;
}
.auth-back {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  margin-bottom: 32px;
  font-size: .83rem;
  color: #64748b;
  cursor: pointer;
  font-weight: 600;
  background: none;
  border: none;
  box-shadow: none;
  padding: 0;
  min-height: auto;
  transition: color .15s;
}
.auth-back:hover { color: var(--blue); }
.auth-title {
  font-size: 1.65rem; font-weight: 800;
  margin-bottom: 6px; color: #0f172a; letter-spacing: -.4px;
}
.auth-sub { font-size: .88rem; color: #64748b; margin-bottom: 32px; }
.auth-form { display: flex; flex-direction: column; gap: 18px; }
.auth-label {
  display: flex; flex-direction: column; gap: 7px;
  font-size: .82rem; font-weight: 600; color: #374151; letter-spacing: .01em;
}
.auth-label input {
  padding: 11px 14px;
  border: 1.5px solid #e2e8f0;
  border-radius: 8px;
  font-size: .93rem;
  font-family: inherit;
  color: #0f172a;
  background: #fff;
  outline: none;
  transition: border-color .15s, box-shadow .15s;
}
.auth-label input:focus {
  border-color: #818CF8;
  box-shadow: 0 0 0 3px rgba(129,140,248,.15);
}
.auth-submit {
  width: 100%; min-height: 50px;
  background: #4F46E5;
  color: #fff; border: none; border-radius: 8px;
  font-size: .97rem; font-weight: 700;
  cursor: pointer; letter-spacing: .01em;
  box-shadow: 0 4px 14px rgba(79,70,229,.35);
  transition: background .15s, box-shadow .15s, transform .1s;
}
.auth-submit:hover:not(:disabled) {
  background: #4338CA;
  box-shadow: 0 6px 20px rgba(79,70,229,.45);
  transform: translateY(-1px);
}
.auth-submit:active:not(:disabled) { transform: translateY(0); }
.auth-submit:disabled { opacity: .55; cursor: not-allowed; }
.sso-btn {
  background: #0f172a; box-shadow: none; margin-top: 8px;
  display: flex; align-items: center; justify-content: center;
  font-size: .88rem; gap: 6px;
}
.sso-btn:hover:not(:disabled) { background: #1e293b; box-shadow: none; transform: none; }
.sso-divider { display: flex; align-items: center; gap: 12px; margin: 20px 0 14px; }
.sso-divider::before, .sso-divider::after { content: ''; flex: 1; height: 1px; background: #e2e8f0; }
.sso-divider span { font-size: .75rem; color: #94a3b8; font-weight: 600; text-transform: uppercase; letter-spacing: .06em; }
.auth-input-plain {
  width: 100%; padding: 11px 14px;
  border: 1.5px solid #e2e8f0; border-radius: 8px;
  font-size: .88rem; font-family: inherit;
  color: #0f172a; background: #fff; outline: none;
  transition: border-color .15s, box-shadow .15s;
  box-sizing: border-box;
}
.auth-input-plain:focus { border-color: #818CF8; box-shadow: 0 0 0 3px rgba(129,140,248,.15); }
.auth-switch {
  text-align: center; font-size: .855rem; color: #64748b; margin-top: 8px;
}
.auth-switch a { font-weight: 700; color: #4F46E5; }
.auth-switch a:hover { color: #4338CA; }

/* Checkbox CGU — ligne horizontale simple */
.auth-cgu {
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: 8px;
  cursor: pointer;
  font-size: .82rem;
  color: #374151;
  line-height: 1.4;
}
.auth-cgu input[type="checkbox"] {
  flex-shrink: 0;
  width: 15px;
  height: 15px;
  accent-color: #4F46E5;
  cursor: pointer;
}
.auth-cgu a {
  color: #4F46E5;
  font-weight: 600;
  text-decoration: none;
}
.auth-cgu a:hover { text-decoration: underline; }

/* Illustration dashboard (panneau gauche) */
.auth-illustration {
  width: 100%;
  margin: 24px 0 8px;
  opacity: .92;
}
.auth-illus-svg {
  width: 100%;
  height: auto;
  display: block;
  border-radius: 12px;
  filter: drop-shadow(0 8px 24px rgba(0,0,0,.4));
}
.form-error {
  padding: 10px 14px;
  border-radius: var(--radius-sm);
  background: var(--error-bg);
  color: var(--error);
  font-size: .85rem;
  font-weight: 500;
}
.form-success {
  padding: 10px 14px;
  border-radius: var(--radius-sm);
  background: var(--success-bg);
  color: var(--success);
  font-size: .85rem;
  font-weight: 500;
}
.input-row { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }

/* ════════════════════════════════════════════════════════════════════════════
   APP (authenticated)
   ════════════════════════════════════════════════════════════════════════════ */

/* ── Top nav ─────────────────────────────────────────────────────────────── */
.topnav {
  position: sticky;
  top: 0;
  z-index: 100;
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 0 24px;
  height: 60px;
  background: linear-gradient(90deg, #0f172a 0%, #1e293b 60%, #1a1f3a 100%);
  backdrop-filter: blur(12px);
  border-bottom: 1px solid rgba(129,140,248,.18);
  box-shadow: 0 2px 16px rgba(15,23,42,.22);
  overflow: visible;   /* laisser le dropdown sortir de la barre */
}
.nav-brand {
  display: flex;
  align-items: center;
  gap: 9px;
  font-weight: 800;
  font-size: .98rem;
  white-space: nowrap;
  flex-shrink: 0;
  margin-right: 8px;
}
.land-nav .nav-brand,
.topnav .nav-brand {
  background: var(--navy);
  border-radius: 10px;
  padding: 3px 12px 3px 3px;
  color: #fff;
}
.org-logo-sep {
  color: rgba(255,255,255,.35);
  font-weight: 300;
  font-size: 1.1rem;
  margin: 0 2px;
}
.org-logo-topnav {
  max-height: 26px;
  max-width: 100px;
  object-fit: contain;
  border-radius: 4px;
  background: #fff;
  padding: 2px 4px;
}
.brand-mark {
  width: 30px; height: 30px;
  border-radius: 8px;
  background: linear-gradient(135deg, #818CF8, #6366f1);
  display: flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  font-size: .8rem;
  font-weight: 900;
  letter-spacing: -.5px;
}
.nav-tabs {
  display: flex;
  gap: 2px;
  flex: 1;
  min-width: 0;          /* permet à flex de comprimer les onglets */
  overflow-x: auto;      /* scroll horizontal si trop d'onglets */
  overflow-y: visible;   /* laisse passer le dropdown */
  scrollbar-width: none; /* cache scrollbar Firefox */
}
.nav-tabs::-webkit-scrollbar { display: none; }
.nav-right {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-left: auto;
  flex-shrink: 0;        /* ne jamais compresser la zone utilisateur */
}
.tab-btn {
  min-height: 34px;
  padding: 0 14px;
  border: none;
  border-radius: var(--radius-sm);
  background: transparent;
  color: rgba(255,255,255,.55);
  font-size: .85rem;
  font-weight: 600;
  cursor: pointer;
  box-shadow: none;
  transition: background .15s, color .15s;
  white-space: nowrap;
  position: relative;
}
.tab-btn:hover { background: rgba(255,255,255,.08); color: rgba(255,255,255,.9); }
.tab-btn.active {
  background: rgba(129,140,248,.18);
  color: #a5b4fc;
  font-weight: 700;
}
.tab-btn.active::after {
  content: '';
  position: absolute;
  bottom: -2px;
  left: 12px;
  right: 12px;
  height: 2px;
  background: linear-gradient(90deg, #818CF8, #a5b4fc);
  border-radius: 2px;
}

/* Notification bell */
.notif-wrap { position: relative; }
.notif-btn {
  width: 36px; height: 36px;
  border-radius: var(--radius-sm);
  background: transparent;
  border: none;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.1rem;
  box-shadow: none;
  color: var(--slate);
  transition: background .15s;
  position: relative;
}
.notif-btn:hover { background: var(--blue-pale); color: var(--blue); }
.notif-dot {
  position: absolute;
  top: 6px; right: 6px;
  width: 8px; height: 8px;
  border-radius: 50%;
  background: #ef4444;
  border: 2px solid #fff;
}
.notif-dropdown {
  position: absolute;
  top: calc(100% + 8px);
  right: 0;
  width: 320px;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-lg);
  z-index: 200;
  overflow: hidden;
}
.notif-header {
  padding: 12px 16px;
  font-size: .82rem;
  font-weight: 700;
  color: var(--slate);
  border-bottom: 1px solid var(--border);
  text-transform: uppercase;
  letter-spacing: .05em;
}
.notif-item {
  padding: 12px 16px;
  border-bottom: 1px solid var(--border-soft);
  display: flex;
  gap: 12px;
  font-size: .87rem;
}
.notif-item:last-child { border-bottom: none; }
.notif-item-icon { font-size: 1.1rem; flex-shrink: 0; margin-top: 1px; }
.notif-item-body { color: var(--navy-mid); line-height: 1.45; }
.notif-item-body strong { font-weight: 700; display: block; margin-bottom: 2px; }
.notif-item-body span  { font-size: .78rem; color: var(--slate); }

/* ── User menu dropdown ─────────────────────────────────────────────────── */
.user-menu-wrap { position: relative; }

.user-chip {
  display: flex;
  align-items: center;
  gap: 7px;
  padding: 4px 10px 4px 4px;
  border-radius: 999px;
  border: 1px solid var(--border);
  background: var(--surface);
  cursor: pointer;
  box-shadow: none;
  transition: background .15s, box-shadow .15s;
}
.user-chip:hover { background: var(--blue-pale); box-shadow: 0 1px 4px rgba(99,102,241,.12); }

.user-menu-chevron { color: var(--slate); transition: transform .2s; flex-shrink: 0; }
.user-menu-wrap.open .user-menu-chevron { transform: rotate(180deg); }

.user-avatar {
  width: 28px; height: 28px;
  border-radius: 50%;
  background: linear-gradient(135deg, #818CF8, #6366f1);
  display: flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  font-size: .72rem;
  font-weight: 800;
  flex-shrink: 0;
}
.user-avatar-lg { width: 36px; height: 36px; font-size: .85rem; }

.user-email-nav {
  font-size: .78rem;
  color: var(--slate);
  max-width: 140px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.user-menu-dropdown {
  position: fixed;      /* fixed pour ne jamais être clippé par la nav */
  top: 60px;            /* juste sous la topnav */
  right: 16px;          /* marge à droite */
  min-width: 230px;
  background: #fff;
  border: 1px solid var(--border);
  border-radius: 12px;
  box-shadow: 0 8px 30px rgba(15,23,42,.12);
  z-index: 500;
  overflow: hidden;
  animation: menuIn .12s ease;
}
@keyframes menuIn { from { opacity:0; transform:translateY(-6px); } to { opacity:1; transform:translateY(0); } }

.user-menu-header {
  display: flex; align-items: center; gap: 10px;
  padding: 14px 16px 12px;
  background: linear-gradient(135deg, #f0f1ff, #f8fafc);
}
.user-menu-email { font-size: .82rem; font-weight: 700; color: var(--navy); max-width: 150px; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }

.user-menu-divider { height: 1px; background: var(--border); margin: 4px 0; }

.user-menu-item {
  display: flex; align-items: center; gap: 10px;
  width: 100%; padding: 9px 16px;
  background: transparent; border: none; cursor: pointer;
  font-size: .85rem; color: var(--navy); font-weight: 500;
  text-align: left; box-shadow: none; border-radius: 0;
  transition: background .1s;
}
.user-menu-item:hover         { background: var(--blue-pale); color: var(--blue); }
.user-menu-item-danger        { color: #dc2626; }
.user-menu-item-danger:hover  { background: #fef2f2; color: #dc2626; }
.role-badge {
  padding: 2px 8px;
  border-radius: 999px;
  font-size: .68rem;
  font-weight: 800;
  text-transform: uppercase;
  background: var(--blue-light);
  color: var(--blue);
}

/* ── Trial banner (in-app) ───────────────────────────────────────────────── */
.trial-app-banner {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 12px 24px;
  background: linear-gradient(90deg, #fef3c7, #fde68a);
  border-bottom: 1px solid #fbbf24;
  font-size: .88rem;
  font-weight: 600;
  color: #78350f;
  flex-wrap: wrap;
}
.trial-app-banner .btn { min-height: 32px; padding: 0 16px; font-size: .82rem; }
.trial-app-banner .dismiss { margin-left: auto; background: none; border: none; cursor: pointer; color: #92400e; font-size: 1rem; box-shadow: none; min-height: auto; }

/* ── Setup readiness banner ─────────────────────────────────────────────── */
.setup-app-banner {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 12px 24px;
  background: linear-gradient(90deg, #fef2f2, #fee2e2);
  border-bottom: 1px solid #fca5a5;
  font-size: .88rem;
  font-weight: 600;
  color: #7f1d1d;
  flex-wrap: wrap;
}
.setup-app-banner .btn-warning { background:#ef4444;color:#fff;border-color:#ef4444;min-height:32px;padding:0 14px;font-size:.82rem }
.setup-app-banner .btn-warning:hover { background:#dc2626 }
.setup-app-banner .dismiss { margin-left:auto;background:none;border:none;cursor:pointer;color:#991b1b;font-size:1rem;box-shadow:none;min-height:auto }

/* ── Workspace bar ───────────────────────────────────────────────────────── */
.workspace-bar {
  background: #f8fafc;
  border-bottom: 1px solid var(--border);
  padding: 0 24px;
  height: 40px;
  display: flex;
  align-items: center;
}
.workspace-bar-inner {
  display: flex;
  align-items: center;
  gap: 12px;
  width: 100%;
  overflow: hidden;
}
.workspace-current {
  display: flex;
  align-items: center;
  gap: 7px;
  flex-shrink: 0;
  font-size: .82rem;
  font-weight: 700;
  color: var(--navy);
  white-space: nowrap;
}
.workspace-dot {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: var(--blue);
  flex-shrink: 0;
}
.workspace-chips {
  display: flex;
  gap: 6px;
  overflow-x: auto;
  scrollbar-width: none;
  flex: 1;
  min-width: 0;
}
.workspace-chips::-webkit-scrollbar { display: none; }
.ws-chip {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 2px 10px;
  border-radius: 20px;
  font-size: .75rem;
  font-weight: 600;
  cursor: pointer;
  border: 1.5px solid transparent;
  white-space: nowrap;
  transition: opacity .15s, border-color .15s;
  color: #fff;
  opacity: .75;
  background: var(--chip-color, #64748b);
}
.ws-chip:hover { opacity: 1; }
.ws-chip.active { opacity: 1; border-color: rgba(0,0,0,.18); }
.ws-marketplace-btn {
  margin-left: auto;
  flex-shrink: 0;
  font-size: .78rem;
  padding: 2px 10px;
  min-height: 26px;
  border-radius: 20px;
}

/* ── Marketplace ─────────────────────────────────────────────────────────── */
.marketplace-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 20px;
  margin-top: 24px;
}
.marketplace-card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 22px;
  display: flex;
  flex-direction: column;
  gap: 12px;
  transition: box-shadow .15s, transform .15s;
}
.marketplace-card:hover { box-shadow: var(--shadow-lg); transform: translateY(-2px); }
.marketplace-card-header {
  display: flex;
  align-items: center;
  gap: 12px;
}
.marketplace-icon {
  width: 44px; height: 44px;
  border-radius: 12px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.3rem;
  flex-shrink: 0;
}
.marketplace-card-title { font-size: .95rem; font-weight: 700; color: var(--navy); }
.marketplace-card-badge {
  font-size: .68rem;
  font-weight: 700;
  padding: 2px 7px;
  border-radius: 20px;
  background: #e0f2fe;
  color: #0369a1;
  width: fit-content;
}
.marketplace-card-desc { font-size: .82rem; color: var(--slate); line-height: 1.5; flex: 1; }
.marketplace-connectors {
  display: flex;
  flex-wrap: wrap;
  gap: 5px;
}
.marketplace-conn-badge {
  font-size: .72rem;
  padding: 2px 8px;
  border-radius: 20px;
  background: var(--blue-pale);
  color: var(--blue);
  font-weight: 600;
}
.marketplace-card-footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-top: 4px;
}
.marketplace-installed {
  font-size: .78rem;
  font-weight: 700;
  color: #16a34a;
  display: flex;
  align-items: center;
  gap: 4px;
}

/* ── App main ────────────────────────────────────────────────────────────── */
.app-main {
  width: min(1100px, 100%);
  margin: 0 auto;
  padding: 32px 20px 80px;
}
.tab-content { animation: fadeIn .18s ease; }
@keyframes fadeIn { from { opacity: 0; transform: translateY(4px); } to { opacity: 1; } }

/* ── Section header ──────────────────────────────────────────────────────── */
.section-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 8px;
  flex-wrap: wrap;
}
.section-header h2 { font-size: 1.35rem; font-weight: 700; }
.section-desc { font-size: .9rem; margin-bottom: 24px; }

/* ── Agent tab ───────────────────────────────────────────────────────────── */
.controls-inline { display: flex; gap: 8px; flex-wrap: wrap; }
.controls-inline select { width: auto; min-height: 36px; padding: 6px 12px; font-size: .85rem; }

.prompt-shortcuts { display: flex; flex-wrap: wrap; gap: 8px; margin: 16px 0; }
.prompt-chip {
  padding: 8px 16px;
  border: 1.5px solid var(--border);
  border-radius: 999px;
  background: var(--surface);
  color: var(--navy-mid);
  font-size: .82rem;
  font-weight: 600;
  cursor: pointer;
  box-shadow: none;
  min-height: auto;
  transition: background .15s, border-color .15s, color .15s;
}
.prompt-chip:hover { background: var(--blue-light); border-color: #93b4ff; color: var(--blue); }

.agent-form { display: grid; gap: 10px; }
.agent-form textarea { min-height: 90px; font-size: 1rem; }
.agent-form button {
  width: 100%;
  min-height: 46px;
  background: var(--blue);
  color: #fff;
  border: none;
  border-radius: var(--radius-md);
  font-size: .95rem;
  font-weight: 700;
  cursor: pointer;
  box-shadow: 0 6px 18px rgba(129,140,248,.30);
  transition: background .15s;
}
.agent-form button:hover:not(:disabled) { background: var(--blue-dark); }
.agent-form button:disabled { opacity: .55; cursor: not-allowed; box-shadow: none; }

.agent-result {
  margin-top: 20px;
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  background: var(--surface);
  box-shadow: var(--shadow);
  overflow: hidden;
}
.agent-sources {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
  padding: 10px 16px;
  background: var(--blue-pale);
  border-bottom: 1px solid var(--border);
  font-size: .8rem;
  color: var(--slate);
  font-weight: 600;
}
.source-chip {
  padding: 3px 12px;
  border-radius: 999px;
  background: var(--blue-light);
  color: var(--blue);
  font-size: .75rem;
  font-weight: 700;
}
.agent-answer {
  padding: 20px 24px;
  font-size: .95rem;
  line-height: 1.78;
  color: var(--navy-mid);
}
.agent-answer h3, .agent-answer h4 { color: var(--navy); margin: 14px 0 6px; font-size: 1rem; }
.agent-answer ul, .agent-answer ol { padding-left: 22px; margin: 8px 0; }
.agent-answer li { margin-bottom: 4px; }
.agent-answer p  { margin: 4px 0; }
.agent-answer strong { color: var(--navy); }
.agent-answer code { background: var(--blue-pale); border-radius: 4px; padding: 1px 5px; font-size: .88em; }
.agent-answer .num-highlight { color: var(--blue); font-weight: 700; }

/* ── Export bar ──────────────────────────────────────────────────────────── */
.export-bar {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 10px 20px;
  border-top: 1px solid var(--border-soft);
  background: var(--blue-pale);
  flex-wrap: wrap;
}
.export-label { font-size: .82rem; color: var(--slate); font-weight: 600; white-space: nowrap; }
.export-btn {
  border: 1px solid var(--blue);
  background: #fff;
  color: var(--blue-dark);
  border-radius: 6px;
  padding: 5px 12px;
  font-size: .82rem;
  font-weight: 600;
  cursor: pointer;
  transition: background .15s, color .15s;
}
.export-btn:hover { background: var(--blue); color: #fff; }
.export-btn:disabled { opacity: .5; cursor: not-allowed; }

/* ── Idle warning banner ─────────────────────────────────────────────────── */
#idle-warn-banner {
  position: fixed;
  bottom: -120px;
  left: 50%;
  transform: translateX(-50%);
  background: var(--navy);
  color: #fff;
  border-radius: 12px;
  padding: 14px 20px;
  display: flex;
  align-items: center;
  gap: 14px;
  font-size: .9rem;
  box-shadow: 0 8px 30px rgba(15,23,42,.4);
  z-index: 9999;
  transition: bottom .35s ease;
  white-space: nowrap;
}
#idle-warn-banner.visible { bottom: 28px; }
#idle-warn-banner .btn { flex-shrink: 0; }
.tools-detail {
  border-top: 1px solid var(--border-soft);
  padding: 10px 16px;
  font-size: .82rem;
  color: var(--slate);
}
.tools-detail summary { cursor: pointer; user-select: none; }
.tools-detail pre {
  margin-top: 10px;
  padding: 12px;
  border-radius: var(--radius-sm);
  background: #f8f9fb;
  overflow-x: auto;
  font-size: .75rem;
  white-space: pre-wrap;
}
.loading-bar {
  margin-top: 16px;
  padding: 14px 18px;
  border-radius: var(--radius-md);
  background: var(--blue-pale);
  color: var(--blue);
  font-weight: 600;
  font-size: .9rem;
  animation: pulse 1.4s ease-in-out infinite;
}
@keyframes pulse { 0%,100% { opacity: 1 } 50% { opacity: .5 } }
.error-text { color: var(--error); font-size: .875rem; margin-top: 8px; }

/* ── Rating widget ───────────────────────────────────────────────────────── */
.rating-bar {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 10px 20px;
  background: var(--bg);
  border-top: 1px solid var(--border-soft);
  flex-wrap: wrap;
}
.rating-label { font-size: .82rem; color: var(--slate); font-weight: 600; }
.star-row { display: flex; gap: 4px; }
.star-btn {
  background: none;
  border: none;
  font-size: 1.5rem;
  color: var(--border);
  cursor: pointer;
  transition: color .12s, transform .1s;
  line-height: 1;
  padding: 0 2px;
}
.star-btn.hovered, .star-btn.selected { color: var(--gold); transform: scale(1.15); }
.star-btn.faded  { color: var(--border); }
.rating-thanks   { font-size: .82rem; color: var(--success); font-weight: 600; }

/* ── KPI / Statistiques ──────────────────────────────────────────────────── */
.kpi-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
  gap: 16px;
  margin-bottom: 24px;
}
.kpi-card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-top: 3px solid var(--blue);
  border-radius: var(--radius-md);
  padding: 20px;
  text-align: center;
  box-shadow: var(--shadow-sm);
  transition: box-shadow .2s, transform .2s;
}
.kpi-card:hover { box-shadow: var(--shadow); transform: translateY(-2px); }
.kpi-val   { font-size: 1.9rem; font-weight: 800; background: linear-gradient(135deg, #6366f1, #818CF8); -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text; line-height: 1.1; }
.kpi-label { font-size: .78rem; color: var(--slate); font-weight: 600; margin-top: 6px; text-transform: uppercase; letter-spacing: .04em; }

.stats-charts {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 20px;
  margin-bottom: 20px;
}
@media (max-width: 700px) {
  .stats-charts { grid-template-columns: 1fr; }
}
.chart-panel {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  padding: 20px;
  box-shadow: var(--shadow-sm);
}
.chart-panel h3 { font-size: .95rem; color: var(--navy); margin: 0 0 16px; font-weight: 700; }

/* Satisfaction dist */
.sat-dist { display: flex; flex-direction: column; gap: 8px; }
.sat-row  { display: flex; align-items: center; gap: 10px; }
.sat-stars { font-size: .9rem; color: var(--gold); white-space: nowrap; min-width: 80px; }
.sat-bar-wrap { flex: 1; background: var(--blue-pale); border-radius: 99px; height: 10px; overflow: hidden; }
.sat-bar      { height: 100%; background: linear-gradient(90deg, var(--blue), var(--blue-dark)); border-radius: 99px; transition: width .5s ease; }
.sat-count    { font-size: .82rem; color: var(--slate); min-width: 28px; text-align: right; }

/* ══════════════════════════════════════════════════════════════════════════
   RESPONSIVE — Mobile first adjustments
═══════════════════════════════════════════════════════════════════════════ */

@media (max-width: 860px) {
  /* Landing nav: collapse to stacked/scrollable */
  .land-nav { flex-wrap: wrap; gap: 8px; padding: 12px 16px; }
  .land-nav-links { display: none; }
  .land-nav-cta { gap: 6px; flex-wrap: wrap; }
  .land-nav-cta .btn { font-size: .78rem; padding: 6px 12px; }
  .land-nav-cta .lang-btn { font-size: .78rem; }

  /* Hero */
  .hero-inner { flex-direction: column; padding: 100px 20px 40px; gap: 24px; text-align: center; }
  .hero-inner h1 { font-size: clamp(1.6rem, 5vw, 3rem); }
  .hero-actions { justify-content: center; flex-wrap: wrap; gap: 10px; }
  .hero-trust { justify-content: center; flex-wrap: wrap; gap: 10px; }
  .hero-visual { width: 100%; max-width: 340px; margin: 0 auto; }
  .dash-preview { font-size: .78rem; }

  /* Features grid: 1 column */
  .features-grid { grid-template-columns: 1fr !important; }

  /* Pricing */
  .pricing-grid { grid-template-columns: repeat(2, 1fr) !important; }
  .pricing-grid .price-card.enterprise { grid-column: 1 / -1; max-width: 420px; margin: 0 auto; }

  /* App top nav — tablette */
  .topnav { flex-wrap: wrap; gap: 6px; padding: 8px 12px; height: auto; min-height: 56px; }
  .nav-brand { order: 1; }
  .nav-right  { order: 2; margin-left: auto; gap: 6px; }
  .nav-tabs   { order: 3; width: 100%; overflow-x: auto; -webkit-overflow-scrolling: touch; padding-bottom: 4px; flex: none; }
  .nav-tabs::-webkit-scrollbar { height: 3px; }
  .nav-tabs::-webkit-scrollbar-thumb { background: var(--blue-light); border-radius: 99px; }
  .tab-btn { font-size: .78rem; padding: 6px 12px; white-space: nowrap; }
  .nav-right { gap: 6px; }
  .user-email-nav { display: none; }
  .app-main { padding-top: 8px; }

  /* App main */
  .app-main { padding: 16px; }

  /* Agent form */
  #agent-question { font-size: .9rem; }

  /* Connector grid: 1 column */
  .connector-grid-inner { grid-template-columns: 1fr !important; }

  /* Doc grid */
  .doc-grid { grid-template-columns: 1fr !important; }

  /* Export bar */
  .export-bar { padding: 10px 12px; gap: 6px; }
  .export-btn { font-size: .75rem; padding: 5px 8px; }

  /* Idle banner */
  #idle-warn-banner { white-space: normal; text-align: center; flex-direction: column; padding: 14px 16px; width: calc(100% - 32px); }
}

@media (max-width: 480px) {
  .hero-inner h1 { font-size: 1.6rem; }
  .kpi-grid { grid-template-columns: 1fr 1fr; }
  .auth-screen { grid-template-columns: 1fr; }
  .auth-left { display: none; }
  .auth-right { padding: 32px 20px; background: #fff; }
  .auth-card { max-width: 100%; }
  .section-header { flex-direction: column; align-items: flex-start; gap: 8px; }
  .settings-grid { grid-template-columns: 1fr !important; }
}

@media (max-width: 640px) {
  /* Landing — réduire padding horizontal pour éviter overflow */
  .eip-stats-banner       { padding: 32px 16px 24px; }
  .eip-stat-item          { padding: 10px 16px; }
  .eip-stat-divider       { display: none; }
  .eip-flow-section,
  .exec-demo-section,
  .eip-workspaces-section,
  .use-cases-section,
  .integrations-section,
  .security-section,
  .roi-section,
  .demo-section           { padding-left: 16px; padding-right: 16px; }

  /* Executive Dashboard — 1 colonne */
  .exec-demo-wrap         { grid-template-columns: 1fr; padding: 20px 16px; gap: 24px; }
  .exec-kpi-grid          { grid-template-columns: 1fr 1fr; }
  .exec-recommendations   { width: 100%; }
  .exec-rec-item          { font-size: .8rem; padding: 12px 12px; flex-wrap: wrap; }

  /* Workspaces — 2 colonnes puis 1 */
  .workspaces-grid        { grid-template-columns: 1fr 1fr; gap: 16px; }

  /* Use Cases — 2 colonnes */
  .use-cases-grid         { grid-template-columns: 1fr 1fr; gap: 16px; }

  /* Integrations — 2 colonnes */
  .integrations-grid      { grid-template-columns: 1fr 1fr; gap: 10px; }
  .integration-item       { padding: 10px 12px; font-size: .8rem; }
  .integrations-tagline   { flex-direction: column; gap: 8px; align-items: center; }

  /* Security — 2 colonnes */
  .security-grid          { grid-template-columns: 1fr 1fr; gap: 16px; }

  /* ROI — 2 colonnes */
  .roi-grid               { grid-template-columns: 1fr 1fr; gap: 16px; }

  /* Demo player */
  .demo-stage             { padding: 24px 16px; }
  .demo-exec-grid         { grid-template-columns: 1fr 1fr; }

  /* Contact */
  .contact-section        { padding: 60px 16px; }
  .contact-inner          { grid-template-columns: 1fr; gap: 32px; }
  .contact-row            { grid-template-columns: 1fr; }
  .contact-form-card      { padding: 24px 16px; }

  .land-nav               { padding: 10px 12px; }
}

@media (max-width: 400px) {
  .workspaces-grid        { grid-template-columns: 1fr; }
  .roi-grid               { grid-template-columns: 1fr; }
  .exec-kpi-grid          { grid-template-columns: 1fr; }
  .use-cases-grid         { grid-template-columns: 1fr; }
  .integrations-grid      { grid-template-columns: 1fr 1fr; }
  .security-grid          { grid-template-columns: 1fr; }
}

/* ── Quota pill ──────────────────────────────────────────────────────────── */
.quota-pill {
  display: flex;
  align-items: center;
  gap: 7px;
  background: rgba(255,255,255,.08);
  border: 1px solid rgba(255,255,255,.15);
  border-radius: 99px;
  padding: 4px 12px 4px 8px;
  font-size: .75rem;
  color: rgba(255,255,255,.85);
  cursor: default;
  transition: background .2s;
}
.quota-bar-wrap {
  width: 42px; height: 5px;
  background: rgba(255,255,255,.2);
  border-radius: 99px; overflow: hidden;
}
.quota-bar { height: 100%; border-radius: 99px; transition: width .4s ease; }
.quota-ok       { background: #22c55e; }
.quota-warn     { background: #f59e0b; }
.quota-critical { background: #ef4444; }
.quota-pill-warn     { border-color: rgba(245,158,11,.5);  background: rgba(245,158,11,.1); }
.quota-pill-critical { border-color: rgba(239,68,68,.5);   background: rgba(239,68,68,.15); }

/* ── Parc IT ─────────────────────────────────────────────────────────────── */
.parc-tabs {
  display: flex; gap: 4px; border-bottom: 2px solid #e2e8f0;
  margin-bottom: 20px; overflow-x: auto;
}
.parc-tab-btn {
  padding: 8px 18px; border: none; background: none; border-radius: 6px 6px 0 0;
  font-size: .85rem; font-weight: 600; color: var(--navy-light);
  cursor: pointer; white-space: nowrap; transition: all .15s;
  border-bottom: 2px solid transparent; margin-bottom: -2px;
}
.parc-tab-btn.active { color: var(--indigo); border-bottom-color: var(--indigo); background: rgba(129,140,248,.08); }
.parc-tab-btn:hover:not(.active) { background: rgba(129,140,248,.05); }
.parc-content { /* shown/hidden by JS */ }

/* ── Parc IT — barre de recherche département ─────────────────────────────── */
.parc-filter-bar {
  display: flex; align-items: center; gap: 10px;
  padding: 10px 0 14px;
  border-bottom: 1px solid #e2e8f0;
  margin-bottom: 18px;
}
.dept-search-wrap {
  position: relative; display: flex; align-items: center;
  background: #f8fafc; border: 1.5px solid #e2e8f0; border-radius: 8px;
  padding: 0 10px; gap: 6px; min-width: 260px; max-width: 360px;
  transition: border-color .15s, box-shadow .15s;
}
.dept-search-wrap:focus-within {
  border-color: var(--indigo); box-shadow: 0 0 0 3px rgba(129,140,248,.15);
  background: #fff;
}
.dept-search-icon { font-size: .9rem; flex-shrink: 0; opacity: .6; }
.dept-search-input {
  flex: 1; border: none; background: transparent; outline: none;
  font-size: .86rem; padding: 7px 0; color: var(--navy);
  min-width: 0;
}
.dept-search-input::placeholder { color: #94a3b8; }
.dept-search-clear {
  background: none; border: none; cursor: pointer; color: #94a3b8;
  font-size: .8rem; padding: 0 2px; line-height: 1; flex-shrink: 0;
}
.dept-search-clear:hover { color: #475569; }
.dept-search-dropdown {
  position: absolute; top: calc(100% + 4px); left: 0; right: 0; z-index: 200;
  background: #fff; border: 1.5px solid #e2e8f0; border-radius: 8px;
  box-shadow: 0 8px 24px rgba(30,41,59,.12);
  max-height: 240px; overflow-y: auto;
}
.dept-search-dropdown.hidden { display: none; }
.dept-dd-item {
  padding: 9px 14px; font-size: .86rem; cursor: pointer;
  color: var(--navy); transition: background .1s;
  display: flex; align-items: center; gap: 8px;
}
.dept-dd-item:hover, .dept-dd-item.focused { background: #f1f5f9; }
.dept-dd-item.all-item { color: #64748b; font-style: italic; }
.dept-dd-item strong { color: var(--indigo); }
.dept-dd-empty { padding: 10px 14px; font-size: .84rem; color: #94a3b8; }
.dept-search-active-tag {
  display: inline-flex; align-items: center; gap: 6px;
  background: rgba(129,140,248,.12); color: var(--indigo);
  border: 1px solid rgba(129,140,248,.3); border-radius: 99px;
  padding: 4px 10px; font-size: .8rem; font-weight: 600;
}
.dept-search-active-tag.hidden { display: none; }

/* ── Stat cards (Identités & Accès, Sécurité…) ──────────────────────────────── */
.stat-card {
  background: #fff; border: 1px solid #e2e8f0; border-radius: 12px;
  padding: 16px 18px; display: flex; flex-direction: column; gap: 3px;
}
.stat-num {
  font-size: 2rem; font-weight: 800; line-height: 1; letter-spacing: -.02em;
}
.stat-label {
  font-size: .78rem; font-weight: 700; color: #475569;
  text-transform: uppercase; letter-spacing: .04em;
}
.stat-value { font-size: 1.6rem; font-weight: 800; color: var(--navy); }
.stat-sub {
  font-size: .76rem; color: #94a3b8; margin-top: 4px; line-height: 1.4;
}

/* ── Command Palette ─────────────────────────────────────────────────────────── */
.cmd-palette-btn {
  display: flex; align-items: center; gap: 6px;
  background: rgba(255,255,255,.08); border: 1px solid rgba(255,255,255,.15);
  border-radius: 7px; padding: 5px 10px; color: rgba(255,255,255,.75);
  cursor: pointer; font-size: .78rem; transition: all .15s;
}
.cmd-palette-btn:hover { background: rgba(255,255,255,.14); color: #fff; }
.cmd-palette-btn svg { flex-shrink: 0; stroke: currentColor; }
.cmd-palette-hint { font-size: .72rem; color: rgba(255,255,255,.45); letter-spacing: .02em; }
.cmd-overlay {
  position: fixed; inset: 0; background: rgba(15,23,42,.55);
  backdrop-filter: blur(3px); z-index: 9000;
  display: flex; align-items: flex-start; justify-content: center;
  padding-top: 12vh;
}
.cmd-overlay.hidden { display: none; }
.cmd-modal {
  background: #fff; border-radius: 14px; width: 540px; max-width: calc(100vw - 32px);
  box-shadow: 0 24px 60px rgba(15,23,42,.25), 0 0 0 1px rgba(15,23,42,.08);
  overflow: hidden;
}
.cmd-search-row {
  display: flex; align-items: center; gap: 10px;
  padding: 14px 18px; border-bottom: 1px solid #e2e8f0;
}
.cmd-input {
  flex: 1; border: none; outline: none; font-size: 1rem;
  color: var(--navy); background: transparent;
}
.cmd-input::placeholder { color: #94a3b8; }
.cmd-esc-hint {
  background: #f1f5f9; color: #64748b; border: 1px solid #e2e8f0;
  border-radius: 5px; padding: 2px 7px; font-size: .72rem; font-family: inherit;
}
.cmd-results { padding: 8px 0; max-height: 340px; overflow-y: auto; }
.cmd-group-label {
  padding: 6px 18px 4px; font-size: .72rem; font-weight: 700;
  text-transform: uppercase; letter-spacing: .06em; color: #94a3b8;
}
.cmd-item {
  display: flex; align-items: center; gap: 12px;
  padding: 10px 18px; cursor: pointer; transition: background .1s;
  font-size: .9rem; color: var(--navy);
}
.cmd-item:hover, .cmd-item.focused { background: #f1f5f9; }
.cmd-item-icon { font-size: 1.1rem; flex-shrink: 0; width: 22px; text-align: center; }
.cmd-item-label { flex: 1; }
.cmd-item-label strong { color: var(--indigo); }
.cmd-item-parent { font-size: .75rem; color: #94a3b8; }
.cmd-empty { padding: 24px 18px; color: #94a3b8; font-size: .88rem; text-align: center; }
.cmd-footer {
  padding: 8px 18px; border-top: 1px solid #e2e8f0;
  font-size: .72rem; color: #94a3b8; text-align: center; letter-spacing: .02em;
}

/* ── Filtres inline tables ───────────────────────────────────────────────────── */
.table-toolbar {
  display: flex; justify-content: space-between; align-items: center;
  gap: 10px; margin-bottom: 16px; flex-wrap: wrap;
}
.table-search-wrap {
  display: flex; align-items: center; gap: 6px;
  background: #f8fafc; border: 1.5px solid #e2e8f0; border-radius: 7px;
  padding: 0 10px; transition: border-color .15s;
}
.table-search-wrap:focus-within { border-color: var(--indigo); background: #fff; }
.table-search-input {
  border: none; background: transparent; outline: none;
  font-size: .84rem; padding: 7px 0; color: var(--navy); width: 220px;
}
.table-search-input::placeholder { color: #94a3b8; }

/* Status badges */
.badge {
  display: inline-flex; align-items: center; gap: 4px;
  padding: 3px 10px; border-radius: 99px;
  font-size: .72rem; font-weight: 700; letter-spacing: .02em;
  border: 1px solid transparent;
}
.badge-active   { background: #dcfce7; color: #15803d; border-color: #bbf7d0; }
.badge-expiring { background: #fef9c3; color: #92400e; border-color: #fde68a; }
.badge-expired  { background: #fee2e2; color: #991b1b; border-color: #fecaca; }
.badge-idle     { background: #f1f5f9; color: #475569; border-color: #cbd5e1; }
.badge-decom    { background: #fce7f3; color: #9d174d; border-color: #fbcfe8; }
.badge-unused   { background: #fff7ed; color: #9a3412; border-color: #fed7aa; }

/* Parc KPI cards */
.parc-kpi .kpi-val { color: var(--indigo); }

/* Budget summary bar */
.budget-summary-row {
  display: flex; align-items: center; gap: 12px; padding: 10px 0;
  border-bottom: 1px solid #f1f5f9; font-size: .87rem;
}
.budget-summary-row:last-child { border-bottom: none; }
.budget-cat-label { width: 120px; font-weight: 600; color: var(--navy); }
.budget-bar-outer { flex: 1; height: 8px; background: #e2e8f0; border-radius: 99px; overflow: hidden; }
.budget-bar-inner { height: 100%; border-radius: 99px; background: var(--indigo); transition: width .5s; }
.budget-bar-inner.over { background: #ef4444; }
.budget-bar-inner.warn { background: #f59e0b; }
.budget-amounts { width: 160px; text-align: right; color: var(--navy-light); font-size: .8rem; }
.budget-amounts strong { color: var(--navy); }

/* Forecast pills */
.forecast-row {
  display: flex; gap: 12px; flex-wrap: wrap; margin-top: 16px; padding-top: 16px;
  border-top: 1px solid #e2e8f0;
}
.forecast-pill {
  background: rgba(129,140,248,.1); border: 1px solid rgba(129,140,248,.3);
  border-radius: 8px; padding: 8px 14px; text-align: center;
}
.forecast-pill-period { font-size: .72rem; color: var(--navy-light); }
.forecast-pill-val { font-size: 1.05rem; font-weight: 700; color: var(--indigo); }

/* Dept cards in team tab */
.dept-card {
  display: flex; align-items: center; gap: 12px;
  padding: 12px 16px; background: #f8fafc; border: 1px solid #e2e8f0;
  border-radius: 10px; margin-bottom: 8px;
}
.dept-card-name { flex: 1; font-weight: 700; color: var(--navy); font-size: .9rem; }
.dept-card-meta { font-size: .8rem; color: var(--navy-light); }
.dept-actions { display: flex; gap: 6px; }

/* Sector cards (modal init départements) */
.sector-card {
  border: 2px solid #e2e8f0; border-radius: 12px; padding: 16px;
  cursor: pointer; text-align: center; transition: all .15s;
  background: #f8fafc;
}
.sector-card:hover          { border-color: var(--indigo); background: #f0f1ff; }
.sector-card.selected       { border-color: var(--indigo); background: #eef2ff; box-shadow: 0 0 0 3px rgba(99,102,241,.15); }
.sector-card-icon           { font-size: 2rem; margin-bottom: 6px; }
.sector-card-label          { font-weight: 700; color: var(--navy); font-size: .88rem; margin-bottom: 4px; }
.sector-card-count          { font-size: .78rem; color: var(--navy-light); }
.sector-badge               { display:inline-flex;align-items:center;gap:5px;padding:3px 10px;border-radius:99px;font-size:.78rem;font-weight:600;background:#eef2ff;color:var(--indigo); }

/* SA (service account) list */
.sa-row {
  display: flex; align-items: center; gap: 12px; padding: 10px 0;
  border-bottom: 1px solid #f1f5f9; font-size: .85rem;
}
.sa-row:last-child { border-bottom: none; }
.sa-name { flex: 1; font-weight: 600; color: var(--navy); }
.sa-prefix { font-family: monospace; font-size: .8rem; color: var(--indigo); background: rgba(129,140,248,.1); padding: 2px 8px; border-radius: 4px; }
.sa-meta { font-size: .78rem; color: var(--navy-light); }

/* ── Optimisation IA ─────────────────────────────────────────────────────── */
.optim-hero-grid {
  display: grid; grid-template-columns: 1fr 1fr; gap: 20px; margin-bottom: 24px;
}
@media (max-width: 860px) { .optim-hero-grid { grid-template-columns: 1fr; } }

.optim-score-card, .optim-savings-card {
  background: #fff; border: 1px solid #e2e8f0; border-radius: 14px;
  padding: 20px; box-shadow: 0 1px 4px rgba(0,0,0,.04);
}
.optim-score-card h3, .optim-savings-card h3 {
  font-size: .9rem; font-weight: 700; color: var(--navy); margin-bottom: 16px;
}

/* Score circle — conic-gradient gauge */
.score-gauge-wrap { display: flex; align-items: center; gap: 20px; }
.score-circle-outer { flex-shrink: 0; }
.score-circle {
  width: 110px; height: 110px; border-radius: 50%;
  background: conic-gradient(var(--indigo) calc(var(--pct, 0) * 1%), #e2e8f0 0);
  display: flex; align-items: center; justify-content: center;
  position: relative;
}
.score-circle::before {
  content: ""; position: absolute;
  width: 72%; height: 72%; border-radius: 50%; background: #fff;
}
.score-circle span {
  position: relative; z-index: 1; font-size: 1.4rem; font-weight: 800; color: var(--indigo);
}
.score-dimensions { flex: 1; display: flex; flex-direction: column; gap: 8px; }
.score-dim { display: flex; align-items: center; gap: 8px; font-size: .8rem; color: var(--navy); }
.score-dim > span:first-child { width: 90px; flex-shrink: 0; }
.score-dim > span:last-child  { width: 36px; text-align: right; font-weight: 700; color: var(--indigo); }
.score-dim-bar-wrap { flex: 1; height: 6px; background: #e2e8f0; border-radius: 99px; overflow: hidden; }
.score-dim-bar      { height: 100%; border-radius: 99px; background: var(--indigo); transition: width .5s; }

/* Savings breakdown */
.savings-total {
  font-size: 2rem; font-weight: 800; color: #15803d; margin-bottom: 12px;
}
.savings-breakdown { display: flex; flex-direction: column; gap: 6px; }
.savings-row { display: flex; justify-content: space-between; font-size: .85rem; }
.savings-row-label { color: var(--navy-light); }
.savings-row-val   { font-weight: 700; color: var(--navy); }

/* Opportunity cards */
.opp-card {
  display: flex; align-items: center; gap: 14px; padding: 12px 16px;
  background: #f8fafc; border: 1px solid #e2e8f0; border-radius: 10px; margin-bottom: 8px;
  transition: border-color .15s;
}
.opp-card:hover { border-color: var(--indigo); }
.opp-icon { width: 36px; height: 36px; border-radius: 8px; display: flex; align-items: center; justify-content: center; font-size: 1.1rem; flex-shrink: 0; }
.opp-icon.license  { background: #eff6ff; }
.opp-icon.duplicate{ background: #fef9c3; }
.opp-icon.contract { background: #fce7f3; }
.opp-icon.process  { background: #f0fdf4; }
.opp-body { flex: 1; }
.opp-title { font-weight: 600; color: var(--navy); font-size: .87rem; }
.opp-meta  { font-size: .76rem; color: var(--navy-light); margin-top: 2px; }
.opp-savings { text-align: right; flex-shrink: 0; }
.opp-savings-val { font-size: 1.05rem; font-weight: 800; color: #15803d; }
.opp-confidence  { font-size: .72rem; color: var(--navy-light); }

/* Spinner générique */
.spinner {
  width: 36px; height: 36px; border-radius: 50%;
  border: 3px solid #e2e8f0; border-top-color: var(--indigo);
  animation: spin .7s linear infinite;
}
@keyframes spin { to { transform: rotate(360deg); } }

/* AI Plan output */
.ai-plan-card {
  background: linear-gradient(135deg, rgba(129,140,248,.06) 0%, rgba(99,102,241,.04) 100%);
  border: 1px solid rgba(129,140,248,.3); border-radius: 14px; padding: 20px;
}
.ai-plan-summary { font-size: .95rem; color: var(--navy); margin-bottom: 16px; line-height: 1.6; }
.ai-plan-total   { font-size: 1.6rem; font-weight: 800; color: var(--indigo); margin-bottom: 4px; }
.ai-plan-confidence { font-size: .8rem; color: var(--navy-light); margin-bottom: 16px; }
.ai-steps { display: flex; flex-direction: column; gap: 10px; margin-bottom: 16px; }
.ai-step {
  display: flex; gap: 12px; align-items: flex-start;
  background: #fff; border: 1px solid #e2e8f0; border-radius: 10px; padding: 12px;
}
.ai-step-num { width: 28px; height: 28px; border-radius: 50%; background: var(--indigo); color: #fff; font-weight: 800; font-size: .8rem; display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.ai-step-body { flex: 1; }
.ai-step-action { font-weight: 600; color: var(--navy); font-size: .87rem; }
.ai-step-meta   { font-size: .78rem; color: var(--navy-light); margin-top: 4px; }
.ai-step-savings { font-weight: 700; color: #15803d; }
.impact-high   { background: #dcfce7; color: #15803d; }
.impact-medium { background: #fef9c3; color: #a16207; }
.impact-low    { background: #f1f5f9; color: #64748b; }
.ai-insights { margin-top: 12px; padding-top: 12px; border-top: 1px solid #e2e8f0; }
.ai-insights li { font-size: .85rem; color: var(--navy-light); margin-bottom: 6px; }

/* ── Team page ───────────────────────────────────────────────────────────── */
.member-av {
  width: 36px; height: 36px; border-radius: 50%;
  color: #fff; font-size: .8rem; font-weight: 800;
  display: flex; align-items: center; justify-content: center; flex-shrink: 0;
}
.member-status { font-size: .75rem; font-weight: 700; padding: 3px 10px; border-radius: 99px; }
.status-active   { background: var(--success-bg); color: var(--success); }
.status-inactive { background: var(--error-bg);   color: var(--error); }
.member-actions { display: flex; align-items: center; gap: 6px; }
.role-select-inline {
  font-size: .78rem; border: 1px solid var(--border); border-radius: 6px;
  padding: 3px 6px; color: var(--navy); background: #fff; cursor: pointer;
}
.btn-icon {
  width: 28px; height: 28px; border-radius: 50%; border: none; cursor: pointer;
  font-size: .85rem; display: flex; align-items: center; justify-content: center;
  transition: background .15s;
}
.btn-deactivate { background: var(--error-bg);   color: var(--error); }
.btn-activate   { background: var(--success-bg); color: var(--success); }
.btn-deactivate:hover { background: var(--error);   color: #fff; }
.btn-activate:hover   { background: var(--success); color: #fff; }
.row-inactive td { opacity: .55; }

.pending-inv-list  { display: flex; flex-direction: column; gap: 8px; }
.pending-inv-item  {
  display: flex; align-items: center; justify-content: space-between;
  padding: 10px 14px; background: var(--bg); border: 1px solid var(--border);
  border-radius: var(--radius-sm); font-size: .85rem;
}
.inv-email  { font-weight: 600; color: var(--navy); }
.inv-expiry { color: var(--slate); font-size: .78rem; }

/* Invite modal */
.modal-backdrop {
  position: fixed; inset: 0; background: rgba(15,23,42,.45);
  display: flex; align-items: center; justify-content: center;
  z-index: 5000; padding: 20px;
}
.modal-card {
  background: #fff; border-radius: var(--radius-lg); padding: 36px;
  width: 100%; max-width: 480px; box-shadow: var(--shadow-lg);
  position: relative;
  max-height: 90vh;
  display: flex;
  flex-direction: column;
  overflow-y: auto;
}
.modal-close {
  position: absolute; top: 16px; right: 16px;
  background: none; border: none; font-size: 1.1rem; cursor: pointer;
  color: var(--slate); line-height: 1;
}
.modal-card h3 { font-size: 1.1rem; font-weight: 700; color: var(--navy); margin: 0 0 6px; }
.invite-link-box { display: flex; gap: 8px; margin-top: 8px; }

/* ── Modal générique (setup, credentials, dept, app…) ───────────────────── */
.modal-overlay {
  position: fixed;
  inset: 0;
  background: rgba(15,23,42,.5);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 5000;
  padding: 20px;
}
.modal-box {
  background: #fff;
  border-radius: var(--radius-lg);
  width: 100%;
  max-width: 520px;
  box-shadow: 0 20px 60px rgba(0,0,0,.25);
  display: flex;
  flex-direction: column;
  max-height: 90vh;
  overflow: hidden;
}
.modal-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 20px 24px 16px;
  border-bottom: 1px solid var(--border);
  flex-shrink: 0;
  background: linear-gradient(135deg, #f8f9ff 0%, #eef0ff 100%);
  border-radius: var(--radius-lg) var(--radius-lg) 0 0;
  position: relative;
}
.modal-header::after {
  content: '';
  position: absolute;
  bottom: 0; left: 0; right: 0;
  height: 2px;
  background: linear-gradient(90deg, var(--blue) 0%, #a5b4fc 100%);
}
.modal-header h3 { font-size: 1rem; font-weight: 700; color: var(--navy); margin: 0; }
.modal-header .modal-close {
  position: static;
  background: none;
  border: none;
  font-size: 1.1rem;
  cursor: pointer;
  color: var(--slate);
  line-height: 1;
  padding: 4px 8px;
  border-radius: 4px;
  flex-shrink: 0;
}
.modal-header .modal-close:hover { background: var(--surface2); color: var(--navy); }
.modal-body {
  padding: 20px 24px;
  overflow-y: auto;
  flex: 1;
}
.modal-footer {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 10px;
  padding: 16px 24px;
  border-top: 1px solid var(--border);
  flex-shrink: 0;
  background: var(--surface2);
  border-radius: 0 0 var(--radius-lg) var(--radius-lg);
}
.invite-link-box input {
  flex: 1; font-size: .8rem; padding: 8px 10px;
  border: 1px solid var(--border); border-radius: var(--radius-sm);
  color: var(--navy); background: var(--bg);
}

/* ── Settings page ───────────────────────────────────────────────────────── */
.settings-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(340px, 1fr));
  gap: 20px;
}
.settings-card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-top: 3px solid var(--blue);
  border-radius: var(--radius-md);
  padding: 28px;
  box-shadow: var(--shadow-sm);
  transition: box-shadow .2s, transform .2s;
}
.settings-card:hover {
  box-shadow: var(--shadow-md);
  transform: translateY(-2px);
}
.settings-card h3 {
  font-size: 1rem;
  font-weight: 700;
  color: var(--navy);
  margin: 0 0 20px;
  padding-bottom: 12px;
  border-bottom: 1px solid var(--border-soft);
}
.settings-card-header {
  display: flex;
  align-items: center;
  gap: 16px;
  margin-bottom: 24px;
  padding-bottom: 20px;
  border-bottom: 1px solid var(--border-soft);
}
.settings-avatar {
  width: 60px;
  height: 60px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--blue), var(--blue-dark));
  color: #fff;
  font-size: 1.5rem;
  font-weight: 800;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.settings-name  { font-size: 1.1rem; font-weight: 700; color: var(--navy); }
.settings-email { font-size: .85rem; color: var(--slate); margin-top: 2px; }
.settings-form  { display: flex; flex-direction: column; gap: 14px; }
.settings-desc  { font-size: .85rem; color: var(--slate); line-height: 1.55; margin: 12px 0; }

/* SSO badge */
.sso-status { display: flex; flex-direction: column; gap: 0; }
.sso-badge {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 6px 14px;
  border-radius: 99px;
  font-size: .82rem;
  font-weight: 700;
  width: fit-content;
  margin-bottom: 4px;
}
.sso-badge.inactive { background: var(--warning-bg); color: var(--warning); }
.sso-badge.active   { background: var(--success-bg); color: var(--success); }
.sso-dot {
  width: 8px; height: 8px;
  border-radius: 50%;
  background: currentColor;
  flex-shrink: 0;
}

/* Plan badge */
.plan-badge-wrap { margin-bottom: 16px; }
.plan-badge {
  display: inline-block;
  padding: 6px 18px;
  border-radius: 99px;
  font-size: .9rem;
  font-weight: 800;
  margin-bottom: 8px;
}
.plan-badge.plan-trial   { background: var(--blue-pale);   color: var(--blue-dark); }
.plan-badge.plan-active  { background: var(--success-bg);  color: var(--success); }
.plan-badge.plan-inactive { background: var(--error-bg);   color: var(--error); }

/* ── Connector tab ───────────────────────────────────────────────────────── */
.connector-grid { display: flex; flex-direction: column; gap: 24px; }
.connector-grid-inner {
  display: grid;
  gap: 20px;
  grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
}
.connector-niche-section { display: flex; flex-direction: column; gap: 12px; }
.connector-niche-toggle {
  display: flex;
  align-items: center;
  gap: 8px;
  background: none;
  border: 1.5px dashed var(--border);
  border-radius: var(--radius-sm);
  padding: 10px 16px;
  font-size: .85rem;
  font-weight: 600;
  color: var(--slate);
  cursor: pointer;
  text-align: left;
  width: 100%;
  transition: background .15s, color .15s;
}
.connector-niche-toggle:hover { background: var(--surface2); color: var(--navy); }
.connector-niche-toggle em { font-style: normal; color: var(--primary); }
.niche-toggle-icon { font-size: .9rem; width: 14px; flex-shrink: 0; }
.connector-niche-inner { margin-top: 4px; }
.connector-card {
  padding: 22px;
  border: 1.5px solid var(--border);
  border-radius: var(--radius-lg);
  background: var(--surface);
  box-shadow: var(--shadow-sm);
  display: flex;
  flex-direction: column;
  gap: 12px;
  transition: box-shadow .15s;
}
.connector-card.connected      { border-color: #86efac; background: linear-gradient(135deg,#f0fdf4 0%,#fff 100%); }
.connector-card.connector-error-card { border-color: #fca5a5; background: linear-gradient(135deg,#fef2f2 0%,#fff 100%); }
.connector-card:hover { box-shadow: var(--shadow); }
.connector-head { display: flex; align-items: flex-start; gap: 12px; }
.connector-head-info { flex: 1; min-width: 0; display: flex; flex-direction: column; gap: 2px; }
.connector-icon {
  width: 46px; height: 46px;
  border-radius: 12px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: .82rem;
  font-weight: 800;
  color: #fff;
  flex-shrink: 0;
  box-shadow: 0 2px 8px rgba(0,0,0,.15);
}
.connector-name { font-weight: 700; font-size: .95rem; color: var(--navy); }
.connector-desc { font-size: .77rem; color: var(--slate); line-height: 1.4; }
.connector-badge {
  padding: 3px 10px;
  border-radius: 999px;
  font-size: .7rem;
  font-weight: 700;
  text-transform: uppercase;
  white-space: nowrap;
  flex-shrink: 0;
}
.badge-connected    { background: var(--success-bg); color: var(--success); }
.badge-disconnected { background: #f1f5f9; color: #64748b; }
.badge-oauth        { background: var(--blue-light); color: var(--blue); }
.badge-error        { background: #fef2f2; color: #991b1b; }
.connector-meta  { font-size: .78rem; color: var(--slate); margin: 0; }
.connector-error { font-size: .78rem; color: var(--error); margin: 0; }
.connector-footer {
  display: flex;
  align-items: center;
  gap: 10px;
  padding-top: 4px;
  border-top: 1px solid var(--border);
  margin-top: 2px;
}
.connector-method-tag {
  font-size: .7rem;
  font-weight: 700;
  color: var(--slate);
  background: #f1f5f9;
  padding: 2px 8px;
  border-radius: 4px;
  text-transform: uppercase;
  letter-spacing: .03em;
}
.connector-help-link { font-size: .77rem; color: var(--primary); text-decoration: none; margin-left: auto; }
.connector-help-link:hover { text-decoration: underline; }
.connector-actions { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }

.btn-connect, .btn-disconnect {
  min-height: 38px;
  padding: 0 18px;
  border-radius: var(--radius-sm);
  font-size: .84rem;
  font-weight: 700;
  cursor: pointer;
  transition: background .15s, opacity .15s;
}
.btn-connect.real { background: #0078d4; color: #fff; border: none; box-shadow: 0 4px 12px rgba(0,120,212,.28); }
.btn-connect.real:hover { background: #006bb3; }
.btn-connect.sim  { background: var(--blue-light); color: var(--blue); border: 1.5px solid var(--primary); box-shadow: none; }
.btn-connect.sim:hover  { background: #c3d9fe; }
.btn-disconnect   { background: #fff; color: var(--error); border: 1px solid #fca5a5; box-shadow: none; }
.btn-disconnect:hover   { background: var(--error-bg); }
.btn-connect:disabled, .btn-disconnect:disabled { opacity: .55; cursor: not-allowed; }
.btn-sm { min-height: 30px; padding: 0 12px; font-size: .78rem; }

.btn-access-dept {
  min-height: 32px; padding: 0 12px; font-size: .78rem; font-weight: 600;
  background: #f1f5f9; color: #475569; border: 1px solid #cbd5e1;
  border-radius: var(--radius); cursor: pointer; transition: background .15s;
}
.btn-access-dept:hover { background: #e2e8f0; }

.connector-dept-badges {
  display: flex; flex-wrap: wrap; gap: 6px; margin: 6px 0 2px;
}
.connector-dept-badge {
  display: inline-flex; align-items: center; gap: 4px;
  background: #ede9fe; color: #5b21b6;
  font-size: .7rem; font-weight: 600; padding: 2px 9px;
  border-radius: 999px;
}
.connector-dept-badge.org-wide { background: #e0f2fe; color: #0369a1; }
.connector-dept-badge.removable { background: #dbeafe; color: #1e40af; }

.success-banner {
  margin-bottom: 16px;
  padding: 12px 18px;
  border-radius: var(--radius-md);
  background: var(--success-bg);
  color: var(--success);
  font-weight: 600;
  border: 1px solid #86efac;
}

/* ── Documents tab ───────────────────────────────────────────────────────── */
.doc-grid { display: grid; gap: 18px; grid-template-columns: repeat(2, 1fr); }
.wide     { grid-column: 1 / -1; }
.panel {
  padding: 24px;
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  background: var(--surface);
  box-shadow: var(--shadow-sm);
}
.panel h3 { font-size: 1rem; font-weight: 700; margin-bottom: 16px; }
.panel button {
  min-height: 44px;
  padding: 0 22px;
  background: var(--blue);
  color: #fff;
  border: none;
  border-radius: var(--radius-md);
  font-size: .9rem;
  font-weight: 700;
  cursor: pointer;
  box-shadow: 0 4px 14px rgba(129,140,248,.28);
}
.panel button:hover:not(:disabled) { background: var(--blue-dark); }
.panel button:disabled { opacity: .55; cursor: not-allowed; box-shadow: none; }

.file-picker {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 14px 16px;
  border: 1.5px dashed var(--border);
  border-radius: var(--radius-md);
  cursor: pointer;
  font-size: .875rem;
  font-weight: 600;
  color: var(--slate);
  margin-bottom: 12px;
  transition: border-color .15s;
}
.file-picker:hover { border-color: var(--blue); color: var(--blue); }
.file-picker input { max-width: 200px; border: none; box-shadow: none; padding: 0; font-size: .8rem; }
.file-picker input:focus { box-shadow: none; }
.status { margin-top: 10px; font-size: .85rem; font-weight: 600; color: var(--blue); min-height: 20px; }
.status.error { color: var(--error); }
.output {
  min-height: 110px;
  margin-top: 12px;
  padding: 14px;
  border: 1px solid var(--border-soft);
  border-radius: var(--radius-md);
  background: var(--blue-pale);
  white-space: pre-wrap;
  font-size: .9rem;
  color: var(--slate);
}
.preview {
  min-height: 110px;
  max-height: 280px;
  overflow: auto;
  padding: 14px;
  border-radius: var(--radius-md);
  border: 1px solid var(--border-soft);
  background: #f8f9fb;
  font: .82rem/1.6 ui-monospace, SFMono-Regular, Menlo, monospace;
  white-space: pre-wrap;
  color: var(--navy-mid);
}
.chat-log {
  min-height: 180px;
  max-height: 360px;
  display: flex;
  flex-direction: column;
  gap: 10px;
  overflow-y: auto;
  padding: 14px;
  border: 1px solid var(--border-soft);
  border-radius: var(--radius-md);
  background: var(--bg);
  margin-bottom: 12px;
}
.message { max-width: 85%; padding: 10px 14px; border-radius: 14px; font-size: .9rem; line-height: 1.5; }
.message.assistant { align-self: flex-start; background: var(--surface); border: 1px solid var(--border); color: var(--navy-mid); }
.message.user { align-self: flex-end; background: var(--blue); color: #fff; }
.chat-form { display: flex; gap: 10px; }
.chat-form input { flex: 1; }
.chat-form button { width: auto; min-height: 44px; flex-shrink: 0; }

/* ── Audit tab ───────────────────────────────────────────────────────────── */
.table-wrap { overflow-x: auto; border: 1px solid var(--border); border-radius: var(--radius-lg); background: var(--surface); box-shadow: var(--shadow-sm); }
table { width: 100%; border-collapse: collapse; font-size: .875rem; }
thead { background: linear-gradient(90deg, #f0f4ff 0%, #e8edff 100%); }
th { padding: 12px 16px; text-align: left; font-size: .72rem; font-weight: 800; letter-spacing: .06em; text-transform: uppercase; color: var(--blue-dark); white-space: nowrap; border-bottom: 2px solid var(--blue-light); }
td { padding: 11px 16px; border-top: 1px solid var(--border-soft); color: var(--navy-mid); }
tbody tr:nth-child(even) { background: #fafbff; }
tbody tr:hover { background: var(--blue-pale); transition: background .12s; }
.badge-ok   { color: var(--success); font-weight: 700; }
.badge-fail { color: var(--error);   font-weight: 700; }

/* Auth tablette */
@media (max-width: 860px) {
  .auth-screen { grid-template-columns: 1fr; }
  .auth-left {
    display: flex;
    padding: 32px 32px 28px;
    min-height: auto;
  }
  .auth-left-headline { font-size: 1.4rem; }
  .auth-left-features { display: none; }
  .auth-left-footer { display: none; }
  .auth-left::before, .auth-left::after { display: none; }
  .auth-right { padding: 36px 24px; }
}

/* ── Responsive ──────────────────────────────────────────────────────────── */
@media (max-width: 900px) {
  .land-nav { padding: 0 20px; }
  .land-nav-links { display: none; }
  .hero { padding: 64px 24px 56px; }
  .hero-inner { grid-template-columns: 1fr; gap: 40px; }
  .dash-preview { transform: none; }
  .features-grid { grid-template-columns: repeat(2, 1fr); }
  .pricing-grid { grid-template-columns: 1fr; max-width: 420px; width: 100%; }
  .footer-top { grid-template-columns: 1fr 1fr; }
}
/* ── Dashboard exécutif Organisation ────────────────────────────────────── */
.exec-kpi-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
  gap: 16px;
}
.exec-kpi-loading { display: flex; align-items: center; justify-content: center; padding: 40px; }
.exec-kpi-card {
  background: var(--surface);
  border: 1.5px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 20px 18px;
  display: flex;
  align-items: flex-start;
  gap: 14px;
  box-shadow: var(--shadow-sm);
  transition: box-shadow .15s;
}
.exec-kpi-card:hover { box-shadow: var(--shadow); }
.exec-kpi-card.highlight { border-color: #86efac; background: linear-gradient(135deg,#f0fdf4,#fff); }
.exec-kpi-card.exec-kpi-warn { border-color: #fca5a5; background: linear-gradient(135deg,#fef2f2,#fff); }
.exec-kpi-icon { font-size: 1.6rem; line-height: 1; flex-shrink: 0; }
.exec-kpi-body { display: flex; flex-direction: column; gap: 3px; min-width: 0; }
.exec-kpi-val { font-size: 1.3rem; font-weight: 800; color: var(--navy); line-height: 1.2; }
.exec-kpi-label { font-size: .78rem; color: var(--slate); font-weight: 600; text-transform: uppercase; letter-spacing: .03em; }
.exec-kpi-sub { font-size: .75rem; color: var(--slate); }

.exec-section-title {
  display: flex; align-items: center; justify-content: space-between;
  font-size: .85rem; font-weight: 700; color: var(--navy);
  text-transform: uppercase; letter-spacing: .05em;
  padding-bottom: 10px;
  border-bottom: 2px solid var(--border);
}
.exec-legend { display: flex; align-items: center; gap: 12px; font-weight: 400; text-transform: none; letter-spacing: 0; color: var(--slate); }
.badge-dot { width: 10px; height: 10px; border-radius: 50%; display: inline-block; margin-right: 4px; }
.badge-dot.green  { background: #22c55e; }
.badge-dot.yellow { background: #f59e0b; }
.badge-dot.red    { background: #ef4444; }

/* Ancien grid — conservé pour compatibilité interne */
.exec-dept-grid { display: none; }

/* ── Accordéons Santé des départements ───────────────────────────────────── */
.dept-acc-wrap {
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  overflow: hidden;
  margin-top: 12px;
}
.dept-acc-hd {
  width: 100%;
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 14px 18px;
  background: var(--surface);
  border: none;
  cursor: pointer;
  text-align: left;
  font-size: .92rem;
  font-weight: 700;
  color: var(--navy);
  border-left: 4px solid var(--acc-color, #818cf8);
  transition: background .15s;
}
.dept-acc-hd:hover { background: #f8fafc; }
.dept-acc-title { flex: 1; }
.dept-acc-count {
  font-size: .72rem; font-weight: 700;
  padding: 3px 10px; border-radius: 999px;
}
.dept-acc-chevron { font-size: .8rem; color: var(--slate); margin-left: 4px; }
.dept-acc-body {
  padding: 16px;
  background: #fafbff;
  border-top: 1px solid var(--border);
  transition: all .2s ease;
}
.dept-acc-closed { display: none; }
.exec-dept-grid-inner {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  gap: 14px;
}
.exec-dept-card {
  background: var(--surface);
  border: 2px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 18px;
  display: flex;
  flex-direction: column;
  gap: 12px;
  cursor: pointer;
  transition: box-shadow .15s, transform .1s;
}
.exec-dept-card:hover { box-shadow: var(--shadow); transform: translateY(-2px); }
.exec-dept-green  { border-left: 4px solid #22c55e; }
.exec-dept-yellow { border-left: 4px solid #f59e0b; }
.exec-dept-red    { border-left: 4px solid #ef4444; }

.exec-dept-head { display: flex; align-items: center; gap: 10px; }
.exec-dept-icon { font-size: 1.5rem; flex-shrink: 0; }
.exec-dept-titles { flex: 1; min-width: 0; display: flex; flex-direction: column; gap: 1px; }
.exec-dept-name { font-weight: 700; font-size: .92rem; color: var(--navy); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.exec-dept-type { font-size: .72rem; color: var(--slate); }

.exec-health-badge {
  padding: 3px 9px; border-radius: 999px;
  font-size: .7rem; font-weight: 700; white-space: nowrap; flex-shrink: 0;
}
.exec-health-green  { background: #dcfce7; color: #15803d; }
.exec-health-yellow { background: #fef9c3; color: #92400e; }
.exec-health-red    { background: #fee2e2; color: #991b1b; }

.exec-score-bar-wrap {
  height: 5px; background: var(--border); border-radius: 999px; overflow: hidden;
}
.exec-score-bar { height: 100%; border-radius: 999px; transition: width .4s ease; }

.exec-dept-metrics {
  display: flex; gap: 12px; flex-wrap: wrap;
  font-size: .75rem; color: var(--slate);
}

@media (max-width: 640px) {
  .exec-kpi-grid         { grid-template-columns: 1fr 1fr; }
  .exec-dept-grid-inner  { grid-template-columns: 1fr; }
}

/* ── Organigramme (Phase 14) ─────────────────────────────────────────────── */
.org-dept-block {
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  overflow: hidden;
  margin-bottom: 12px;
}
.org-dept-hd {
  display: flex; align-items: center; gap: 10px;
  padding: 12px 16px; background: var(--surface);
  font-weight: 700; font-size: .9rem; color: var(--navy);
  cursor: pointer; user-select: none;
}
.org-dept-hd:hover { background: #f8fafc; }
.org-dept-count { font-size: .75rem; font-weight: 500; color: var(--slate); margin-left: auto; }
.org-chevron { font-size: .8rem; color: var(--slate); }
.org-add-member-btn { margin-left: 8px !important; flex-shrink: 0; }

/* Preview d'accès hiérarchique dans la modale */
.hierarchy-access-preview {
  background: #f0fdf4; border: 1px solid #bbf7d0; border-radius: 8px;
  padding: 10px 14px; font-size: .82rem; color: #15803d;
  display: flex; flex-direction: column; gap: 4px;
}
.hap-row { display: flex; align-items: center; gap: 8px; }
.hap-icon { font-size: 1rem; }
.hap-sub { color: #6b7280; font-size: .78rem; padding-left: 24px; }
.org-members-list { border-top: 1px solid var(--border); background: #fafbff; }

.org-member-row {
  display: flex; align-items: center; gap: 10px;
  padding: 10px 16px 10px calc(16px + var(--lvl, 0) * 20px);
  border-bottom: 1px solid #f1f5f9;
  transition: background .1s;
}
.org-member-row:last-child { border-bottom: none; }
.org-member-row:hover { background: #f8fafc; }

.org-member-indent {
  width: 3px; height: 32px; border-radius: 2px;
  background: var(--color, #818cf8); flex-shrink: 0;
}
.org-member-av {
  width: 32px; height: 32px; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-size: .75rem; font-weight: 700; flex-shrink: 0;
}
.org-member-info { flex: 1; min-width: 0; display: flex; flex-direction: column; gap: 1px; }
.org-member-name { font-weight: 600; font-size: .85rem; color: var(--navy); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.org-member-title { font-size: .72rem; font-weight: 600; }

.org-title-select {
  font-size: .72rem; padding: 3px 6px; border: 1px solid var(--border);
  border-radius: var(--radius); background: var(--surface); color: var(--navy);
  max-width: 200px; flex-shrink: 0;
}

/* ── Tableau de bord département (Phase 12) ─────────────────────────────── */
/* ── Workspace context banner ─────────────────────────────────────────────── */
.ws-context-banner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  background: linear-gradient(135deg, #eef2ff 0%, #e0e7ff 100%);
  border: 1px solid rgba(129,140,248,.3);
  border-left: 4px solid var(--blue);
  border-radius: var(--radius-md);
  padding: 12px 16px;
  margin-bottom: 16px;
}
.ws-ctx-left { display: flex; align-items: center; gap: 12px; }
.ws-ctx-icon { font-size: 1.6rem; line-height: 1; }
.ws-ctx-name { font-size: .95rem; font-weight: 700; color: var(--navy); }
.ws-ctx-connectors { display: flex; gap: 5px; flex-wrap: wrap; margin-top: 4px; }
.ws-ctx-badge {
  font-size: .68rem; font-weight: 600;
  padding: 2px 8px; border-radius: 99px;
  background: rgba(129,140,248,.15); color: var(--blue-dark);
  border: 1px solid rgba(129,140,248,.25);
}
.ws-ctx-close {
  background: none; border: none; cursor: pointer;
  color: var(--slate); font-size: .9rem; padding: 4px 6px;
  border-radius: 4px; flex-shrink: 0;
  transition: background .15s;
}
.ws-ctx-close:hover { background: rgba(0,0,0,.07); }
.ws-chip.ws-chip-active {
  box-shadow: 0 0 0 2px #fff, 0 0 0 4px rgba(129,140,248,.6);
  opacity: 1;
}

.dept-dashboard {
  background: #fff;
  border: 1px solid #e2e8f0;
  border-radius: 14px;
  padding: 16px 20px 20px;
  margin-bottom: 24px;
  box-shadow: 0 1px 4px rgba(0,0,0,.04);
  --dept-color: #818CF8;
}
.dept-dash-header {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 16px;
}
.dept-dash-icon {
  font-size: 1.6rem;
  line-height: 1;
  flex-shrink: 0;
}
.dept-dash-titles {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.dept-dash-label {
  font-size: .88rem;
  font-weight: 700;
  color: var(--dept-color, #818CF8);
  text-transform: uppercase;
  letter-spacing: .05em;
}
.dept-dash-name {
  font-size: .82rem;
  color: var(--navy-light);
}
.dept-dash-cta {
  border-color: var(--dept-color, #818CF8);
  color: var(--dept-color, #818CF8);
  font-size: .78rem;
  padding: 5px 12px;
  white-space: nowrap;
}
.dept-dash-restricted {
  display: inline-flex; align-items: center; gap: 4px;
  background: #fef3c7; color: #92400e;
  border: 1px solid #fde68a; border-radius: 99px;
  font-size: .72rem; font-weight: 600; padding: 3px 10px;
  white-space: nowrap;
}
.dept-kpi-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
  gap: 12px;
}
.dept-kpi-loading {
  grid-column: 1/-1;
  display: flex;
  justify-content: center;
  padding: 20px 0;
}
.dept-kpi-card {
  background: #f8fafc;
  border-radius: 10px;
  border-top: 3px solid #818CF8;
  padding: 12px 14px;
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.dept-kpi-icon {
  font-size: 1.1rem;
  line-height: 1;
  margin-bottom: 4px;
}
.dept-kpi-val {
  font-size: 1.3rem;
  font-weight: 800;
  color: #1e293b;
  line-height: 1.1;
}
.dept-kpi-label {
  font-size: .75rem;
  font-weight: 600;
  color: var(--navy);
  line-height: 1.3;
}
.dept-kpi-sub {
  font-size: .72rem;
  color: var(--navy-light);
  margin-top: 2px;
}
.dept-type-icon {
  margin-right: 4px;
}
@media (max-width: 640px) {
  .dept-kpi-grid { grid-template-columns: repeat(2, 1fr); }
}

/* ── App catalog select ──────────────────────────────────────────────────── */
#am-name-select { width: 100%; max-height: 400px; }
#am-name-select optgroup { font-weight: 700; font-size: .78rem; color: var(--slate); }
#am-name-select option  { font-weight: 400; padding: 4px 8px; }

/* Desktop intermédiaire */
@media (max-width: 1280px) and (min-width: 1025px) {
  .tab-btn  { font-size: .8rem; padding: 0 10px; }
  .topnav   { padding: 0 16px; gap: 6px; }
  .user-email-nav { max-width: 100px; }
}
/* Petit desktop */
@media (max-width: 1024px) and (min-width: 769px) {
  .tab-btn  { font-size: .76rem; padding: 0 8px; }
  .quota-pill { display: none; }
  .user-email-nav { display: none; }  /* libère de la place */
}

@media (max-width: 640px) {
  .connectors-strip { padding: 20px; }
  .features { padding: 64px 20px; }
  .pricing { padding: 64px 20px; }
  footer { padding: 48px 20px 32px; }
  .features-grid { grid-template-columns: 1fr; }
  .footer-top { grid-template-columns: 1fr; gap: 32px; }
  .topnav { padding: 0 14px; }
  .tab-btn { font-size: .78rem; padding: 0 10px; }
  .doc-grid { grid-template-columns: 1fr; }
  .connector-grid-inner { grid-template-columns: 1fr; }
  .input-row { grid-template-columns: 1fr; }
  .app-main { padding: 20px 14px 60px; }
  .chat-form { flex-direction: column; }
}

/* ══════════════════════════════════════════════════════════════════════════
   MOBILE — améliorations Priorité 3
═══════════════════════════════════════════════════════════════════════════ */

/* Workspace bar mobile */
@media (max-width: 640px) {
  .workspace-bar { padding: 0; height: auto; min-height: 36px; }
  .workspace-bar-inner { flex-wrap: nowrap; overflow-x: auto; -webkit-overflow-scrolling: touch; gap: 6px; padding: 6px 12px; height: auto; width: 100%; }
  .workspace-bar-inner::-webkit-scrollbar { display: none; }
  .workspace-chips { flex-wrap: nowrap; gap: 4px; }
  .ws-chip { font-size: .7rem; padding: 2px 8px; white-space: nowrap; flex-shrink: 0; }
  .ws-marketplace-btn { font-size: .72rem; padding: 3px 8px; white-space: nowrap; flex-shrink: 0; }
  .workspace-current { flex-shrink: 0; }
}

/* Agent send button + chips mobile */
@media (max-width: 640px) {
  #agent-submit { min-width: unset; width: 100%; justify-content: center; }
  .prompt-chips { flex-wrap: wrap; gap: 6px; }
  .prompt-chip { font-size: .74rem; padding: 5px 10px; }
}

/* Settings grid 1 colonne sur mobile */
@media (max-width: 540px) {
  .settings-grid { grid-template-columns: 1fr !important; }
  .settings-card { padding: 20px 16px; }
  .settings-card-header { flex-direction: column; align-items: flex-start; gap: 10px; }
  .settings-avatar { width: 48px; height: 48px; font-size: 1.2rem; }
}

/* KPI grid 2 colonnes sur très petits écrans */
@media (max-width: 400px) {
  .kpi-grid { grid-template-columns: 1fr 1fr; gap: 10px; }
  .kpi-val { font-size: 1.5rem; }
}

/* Tables horizontalement scrollables sur mobile */
@media (max-width: 680px) {
  .table-wrap, table { display: block; overflow-x: auto; -webkit-overflow-scrolling: touch; }
  .audit-table { min-width: 560px; }
  .parc-table  { min-width: 480px; }
}

/* Score gauge compact sur mobile */
@media (max-width: 500px) {
  .score-gauge-wrap { flex-direction: column; align-items: flex-start; gap: 12px; }
  .score-circle { width: 80px; height: 80px; }
  .score-circle span { font-size: 1.1rem; }
}

/* Modal plein écran sur mobile */
@media (max-width: 540px) {
  .modal-overlay, .modal-backdrop { padding: 0; align-items: flex-end; }
  .modal-box, .modal-card {
    max-width: 100%;
    border-radius: var(--radius-lg) var(--radius-lg) 0 0;
    max-height: 92vh;
  }
  .modal-body { padding: 16px; }
  .modal-header { padding: 16px; }
  .modal-footer { padding: 12px 16px; }
}

/* Marketplace grid 1 colonne sur mobile */
@media (max-width: 540px) {
  .marketplace-grid { grid-template-columns: 1fr; }
}

/* Optimisation hero grid */
@media (max-width: 500px) {
  .optim-hero-grid { grid-template-columns: 1fr; }
  .savings-total { font-size: 1.5rem; }
}

/* ── Executive Intelligence Dashboard (Direction) ────────────────────────── */
.eid-header {
  display: flex; justify-content: space-between; align-items: center;
  padding: 0 0 14px; border-bottom: 1px solid var(--border); margin-bottom: 16px;
}
.eid-title  { font-size: 1.05rem; font-weight: 800; color: var(--navy); }
.eid-period { font-size: .78rem; color: var(--slate); margin-top: 2px; }
.eid-actions { display: flex; gap: 8px; }

/* Ticker */
.eid-ticker {
  overflow: hidden; background: linear-gradient(90deg, #ede9fe, #dbeafe);
  border-radius: 8px; padding: 7px 14px; margin-bottom: 14px;
  font-size: .78rem; font-weight: 600; color: #3730a3; border: 1px solid #c7d2fe;
}
.eid-ticker-inner {
  display: inline-block; white-space: nowrap;
  animation: ticker-scroll 55s linear infinite;
}
@keyframes ticker-scroll {
  from { transform: translateX(100%); }
  to   { transform: translateX(-100%); }
}

/* KPI row */
.eid-kpi-row {
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 12px; margin-bottom: 16px;
}
.eid-kpi-card {
  background: var(--bg-light); border: 1px solid var(--border); border-radius: 12px;
  padding: 16px 18px; text-align: center;
}
.eid-kpi-val   { font-size: 2rem; font-weight: 800; line-height: 1.1; }
.eid-kpi-label { font-size: .76rem; color: var(--slate); margin-top: 4px; font-weight: 500; }

/* Charts row */
.eid-charts-row {
  display: grid; grid-template-columns: 2fr 1fr; gap: 12px; margin-bottom: 16px;
}
.eid-chart-card {
  background: var(--bg-light); border: 1px solid var(--border); border-radius: 12px;
  padding: 16px;
}
.eid-card-title {
  font-size: .82rem; font-weight: 700; color: var(--navy); margin-bottom: 12px;
}

/* Bottom grid */
.eid-bottom-grid {
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 12px;
}
.eid-bottom-card {
  background: var(--bg-light); border: 1px solid var(--border); border-radius: 12px;
  padding: 14px 16px; display: flex; flex-direction: column; gap: 2px;
}

/* Shared list rows */
.eid-list-row {
  display: flex; align-items: center; gap: 8px; padding: 5px 0;
  border-bottom: 1px solid var(--border); font-size: .8rem;
}
.eid-list-row:last-child { border-bottom: none; }
.eid-list-rank  { font-size: .72rem; font-weight: 800; color: var(--slate); flex-shrink: 0; width: 14px; text-align: center; }
.eid-list-label { flex: 1; min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; color: var(--navy); }
.eid-list-val   { font-size: .8rem; font-weight: 700; flex-shrink: 0; }
.eid-conn-dot   { width: 7px; height: 7px; border-radius: 50%; flex-shrink: 0; }
.eid-alert-badge { font-size: .68rem; font-weight: 700; padding: 1px 6px; border-radius: 999px; flex-shrink: 0; }
.eid-alert-red    { background: #fee2e2; color: #dc2626; }
.eid-alert-orange { background: #fef3c7; color: #d97706; }
.eid-alert-item {
  border-bottom: 1px solid var(--border); padding: 4px 0;
  cursor: pointer; border-radius: 6px; transition: background .12s;
}
.eid-alert-item:hover { background: var(--bg-light); }
.eid-alert-item:last-child { border-bottom: none; }

/* Accordion bottom cards */
.eid-acc-header {
  display: flex; justify-content: space-between; align-items: center;
  cursor: pointer; padding-bottom: 8px; user-select: none;
  border-bottom: 1px solid var(--border); margin-bottom: 8px;
}
.eid-acc-header:hover .eid-card-title { color: var(--primary); }
.eid-acc-chevron {
  font-size: .85rem; color: var(--slate);
  transition: transform .22s; display: inline-block;
}
.eid-acc-rotated { transform: rotate(-90deg); }
.eid-acc-body {
  overflow: hidden; max-height: 600px;
  transition: max-height .28s ease, opacity .22s;
  opacity: 1;
}
.eid-acc-closed { max-height: 0 !important; opacity: 0; }

@media (max-width: 900px) {
  .eid-kpi-row    { grid-template-columns: repeat(2, 1fr); }
  .eid-charts-row { grid-template-columns: 1fr; }
  .eid-bottom-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 560px) {
  .eid-kpi-row    { grid-template-columns: 1fr 1fr; }
  .eid-bottom-grid { grid-template-columns: 1fr; }
}

/* ── Anciens styles Direction (conservés) ────────────────────────────────── */
.dir-agg-toolbar {
  display: flex; justify-content: space-between; align-items: center;
  padding: 8px 0 14px; border-bottom: 1px solid var(--border); margin-bottom: 16px;
}
.dir-agg-toolbar-left { display: flex; align-items: center; gap: 10px; }
.dir-agg-toolbar-right { display: flex; gap: 8px; }
.dir-agg-period { font-size: .8rem; color: var(--slate); }

/* Bande globale */
.dir-global-strip {
  display: grid; grid-template-columns: repeat(4, 1fr);
  gap: 12px; margin-bottom: 20px;
}
.dir-global-kpi {
  background: var(--bg-light); border: 1px solid var(--border); border-radius: 10px;
  padding: 14px 16px; display: flex; align-items: center; gap: 12px;
}
.dir-global-donut { position: relative; flex-shrink: 0; }
.dir-global-donut-val {
  position: absolute; inset: 0; display: flex; align-items: center; justify-content: center;
  font-size: .75rem; font-weight: 800; line-height: 1;
}
.dir-global-big { font-size: 2rem; font-weight: 800; color: var(--navy); flex-shrink: 0; }
.dir-global-kpi-label { font-size: .82rem; font-weight: 700; color: var(--navy); }
.dir-global-kpi-sub   { font-size: .74rem; color: var(--slate); margin-top: 2px; }

/* Grille cartes dept */
.dir-agg-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 14px;
  margin-top: 4px;
}

/* Carte département */
.dir-agg-card {
  border: 1px solid var(--border); border-radius: 12px; background: #fff;
  border-top: 3px solid var(--dept-accent, #818CF8);
  padding: 16px; display: flex; flex-direction: column; gap: 10px;
  transition: box-shadow .15s, transform .15s;
}
.dir-agg-card:hover { box-shadow: 0 4px 16px rgba(0,0,0,.1); transform: translateY(-1px); }

.dir-agg-card-header {
  display: flex; align-items: flex-start; gap: 10px;
}
.dir-agg-card-icon { font-size: 1.5rem; flex-shrink: 0; margin-top: 2px; }
.dir-agg-card-titles { flex: 1; min-width: 0; }
.dir-agg-card-name { font-weight: 700; font-size: .9rem; color: var(--navy); line-height: 1.3; }
.dir-agg-card-members { font-size: .74rem; color: var(--slate); margin-top: 2px; }

.dir-agg-score-wrap { position: relative; flex-shrink: 0; }
.dir-agg-score-val {
  position: absolute; inset: 0; display: flex; align-items: center; justify-content: center;
  font-size: .65rem; font-weight: 800;
}

/* KPI list dans la carte */
.dir-kpi-list { display: flex; flex-direction: column; gap: 6px; flex: 1; }
.dir-kpi-row { display: flex; align-items: flex-start; gap: 7px; }

/* ══════════════════════════════════════════════════════════════════════════
   SPLASH SCREEN
   ══════════════════════════════════════════════════════════════════════════ */
#splash-screen {
  position: fixed; inset: 0; z-index: 99999;
  display: flex; align-items: center; justify-content: center;
  overflow: hidden;
}
#splash-screen.hidden { display: none; }

.splash-bg {
  position: absolute; inset: 0;
  background: radial-gradient(ellipse at 50% 40%, #1e2d4a 0%, #0f172a 60%, #060d1a 100%);
}

.splash-content {
  position: relative; z-index: 2;
  display: flex; flex-direction: column; align-items: center; gap: 18px;
  animation: splash-in 0.6s cubic-bezier(.16,1,.3,1) both;
}

@keyframes splash-in {
  from { opacity: 0; transform: translateY(24px) scale(.96); }
  to   { opacity: 1; transform: translateY(0) scale(1); }
}

.splash-logo-wrap {
  position: relative; width: 110px; height: 110px;
  display: flex; align-items: center; justify-content: center;
}

.splash-logo-ring {
  position: absolute; inset: 0; border-radius: 50%;
  border: 2px solid transparent;
  background: linear-gradient(135deg, #818CF8, #6366f1, #4f46e5) border-box;
  -webkit-mask: linear-gradient(#fff 0 0) padding-box, linear-gradient(#fff 0 0);
  -webkit-mask-composite: destination-out; mask-composite: exclude;
  animation: splash-ring-spin 3s linear infinite;
}
@keyframes splash-ring-spin { to { transform: rotate(360deg); } }

.splash-logo-letter {
  width: 90px; height: 90px; border-radius: 22px;
  background: linear-gradient(135deg, #1e293b, #0f172a);
  border: 1px solid rgba(129,140,248,.3);
  display: flex; align-items: center; justify-content: center;
  font-size: 3rem; font-weight: 900; font-family: system-ui, sans-serif;
  background: linear-gradient(135deg, #818CF8, #6366f1);
  -webkit-background-clip: text; -webkit-text-fill-color: transparent;
  background-clip: text;
  filter: drop-shadow(0 0 20px rgba(99,102,241,.6));
  animation: splash-letter-pulse 2s ease-in-out infinite alternate;
}
@keyframes splash-letter-pulse {
  from { filter: drop-shadow(0 0 12px rgba(99,102,241,.5)); }
  to   { filter: drop-shadow(0 0 28px rgba(129,140,248,.9)); }
}

.splash-brand {
  font-size: 2rem; font-weight: 800; color: #fff;
  font-family: system-ui, sans-serif; letter-spacing: -.5px;
}
.splash-brand span:first-child { color: #818CF8; }
.splash-eip {
  font-size: .85rem; font-weight: 600; color: #818CF8;
  background: rgba(129,140,248,.15); border: 1px solid rgba(129,140,248,.3);
  padding: 2px 8px; border-radius: 99px; vertical-align: middle;
  margin-left: 6px;
}

.splash-tagline {
  font-size: .95rem; color: #94a3b8; letter-spacing: .08em;
  text-transform: uppercase; font-weight: 500;
}

.splash-org {
  font-size: 1rem; color: #e2e8f0; font-weight: 600;
  background: rgba(255,255,255,.05); border: 1px solid rgba(255,255,255,.1);
  padding: 6px 20px; border-radius: 99px;
  min-width: 120px; text-align: center;
}

.splash-dots { display: flex; gap: 8px; margin-top: 8px; }
.splash-dots span {
  width: 7px; height: 7px; border-radius: 50%;
  background: #6366f1; opacity: .3;
  animation: splash-dot-bounce 1.2s ease-in-out infinite;
}
.splash-dots span:nth-child(2) { animation-delay: .2s; }
.splash-dots span:nth-child(3) { animation-delay: .4s; }
@keyframes splash-dot-bounce {
  0%, 80%, 100% { opacity: .3; transform: scale(1); }
  40% { opacity: 1; transform: scale(1.4); }
}

/* Particules flottantes */
.splash-particles { position: absolute; inset: 0; overflow: hidden; pointer-events: none; }
.splash-particle {
  position: absolute; border-radius: 50%;
  background: radial-gradient(circle, rgba(99,102,241,.6), transparent);
  animation: splash-float linear infinite;
}
@keyframes splash-float {
  0%   { transform: translateY(100vh) scale(0); opacity: 0; }
  10%  { opacity: 1; }
  90%  { opacity: .4; }
  100% { transform: translateY(-20vh) scale(1.5); opacity: 0; }
}

/* Fondu de sortie */
#splash-screen.splash-exit {
  animation: splash-fade-out .8s cubic-bezier(.4,0,1,1) forwards;
}
@keyframes splash-fade-out {
  0%   { opacity: 1; transform: scale(1); }
  100% { opacity: 0; transform: scale(1.04); }
}
.dir-kpi-icon { font-size: .9rem; flex-shrink: 0; margin-top: 1px; }
.dir-kpi-body { flex: 1; min-width: 0; }
.dir-kpi-top  { display: flex; justify-content: space-between; align-items: baseline; gap: 6px; }
.dir-kpi-label { font-size: .78rem; color: var(--slate); flex: 1; min-width: 0; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.dir-kpi-val   { font-size: .82rem; font-weight: 700; flex-shrink: 0; }
.dir-kpi-sub   { font-size: .71rem; color: #94a3b8; margin-top: 1px; }
.dir-kpi-bar-track { height: 4px; background: #e2e8f0; border-radius: 99px; margin-top: 3px; overflow: hidden; }
.dir-kpi-bar-fill  { height: 100%; border-radius: 99px; transition: width .4s; }

/* Bouton workspace */
.dir-agg-open-btn {
  margin-top: auto; padding: 7px 0; background: none;
  border: 1px solid var(--dept-accent, #818CF8); border-radius: 8px;
  color: var(--dept-accent, #818CF8); font-size: .78rem; font-weight: 600;
  cursor: pointer; transition: background .15s, color .15s; width: 100%;
  text-align: center;
}
.dir-agg-open-btn:hover { background: var(--dept-accent, #818CF8); color: #fff; }

@media (max-width: 720px) {
  .dir-global-strip { grid-template-columns: repeat(2, 1fr); }
  .dir-agg-grid { grid-template-columns: 1fr; }
}

/* ── Collaborateurs externes ─────────────────────────────────────────────── */
.dept-external-mini {
  margin-top: 16px;
  border-top: 1px solid var(--border);
  padding-top: 12px;
}
.dept-external-mini-header {
  display: flex; align-items: center; justify-content: space-between;
  font-size: .82rem; font-weight: 700; color: var(--navy);
  margin-bottom: 8px;
}
.dept-external-mini-list { display: flex; flex-direction: column; gap: 4px; }
.ext-card-compact {
  display: flex; align-items: center; gap: 8px;
  padding: 5px 8px; border-radius: 6px; background: var(--bg-light);
  font-size: .81rem; line-height: 1.3;
}
.ext-status-dot {
  width: 8px; height: 8px; border-radius: 50%; flex-shrink: 0;
}
.ext-status-dot.badge-active   { background: #22c55e; }
.ext-status-dot.badge-expiring { background: #f59e0b; }
.ext-status-dot.badge-expired  { background: #ef4444; }
.ext-status-dot.badge-idle     { background: #94a3b8; }
.ext-name { font-weight: 600; color: var(--navy); }
.ext-company { color: var(--slate); font-size: .77rem; }
.ext-dates   { color: var(--slate); }

.ext-type-chip {
  display: inline-block; font-size: .72rem; font-weight: 600;
  padding: 1px 7px; border-radius: 999px;
  background: #e0e7ff; color: #3730a3;
}

.ext-cards-grid { display: flex; flex-direction: column; gap: 10px; }
.ext-card {
  border: 1px solid var(--border); border-radius: 10px;
  padding: 12px 14px; background: #fff;
  transition: box-shadow .15s;
}
.ext-card:hover { box-shadow: 0 2px 8px rgba(0,0,0,.07); }
.ext-card-top {
  display: flex; justify-content: space-between; align-items: flex-start;
  gap: 8px; margin-bottom: 6px;
}
.ext-card-name    { font-weight: 700; font-size: .9rem; color: var(--navy); }
.ext-card-company { font-size: .78rem; color: var(--slate); }
.ext-card-meta {
  display: flex; flex-wrap: wrap; gap: 10px;
  font-size: .79rem; color: var(--slate); margin-bottom: 4px;
}
.ext-card-mission {
  font-size: .8rem; color: var(--slate); border-left: 3px solid var(--indigo);
  padding-left: 8px; margin-top: 6px; font-style: italic;
}
.btn-icon-sm {
  background: none; border: none; cursor: pointer; padding: 2px 4px;
  border-radius: 4px; font-size: .9rem; line-height: 1;
  transition: background .12s;
}
.btn-icon-sm:hover { background: var(--bg-light); }

.dept-checkbox-list label:hover { background: var(--bg-light); border-radius: 4px; }

@media (max-width: 600px) {
  .ext-card-compact { flex-wrap: wrap; }
  .ext-dates { margin-left: 0 !important; }
}

/* ══════════════════════════════════════════════════════════════════════════
   MOBILE BOTTOM NAVIGATION
═══════════════════════════════════════════════════════════════════════════ */
.mobile-bottom-nav {
  display: none;
  position: fixed;
  bottom: 0; left: 0; right: 0;
  height: 62px;
  background: var(--navy);
  border-top: 1px solid rgba(255,255,255,.12);
  z-index: 900;
  padding-bottom: env(safe-area-inset-bottom, 0px);
}

@media (max-width: 640px) {
  /* Affiche la bottom nav */
  .mobile-bottom-nav { display: flex; }
  /* Masque les tabs horizontaux du topnav */
  .nav-tabs { display: none !important; }
  /* Compense la height de la bottom nav */
  .app-main { padding-bottom: 80px !important; }
  /* Topnav plus compact sans les tabs */
  .topnav { min-height: 52px; padding: 0 12px; }
}

.mob-nav-btn {
  flex: 1;
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  gap: 2px;
  background: none; border: none; cursor: pointer;
  color: rgba(255,255,255,.4);
  transition: color .15s;
  padding: 6px 4px;
  -webkit-tap-highlight-color: transparent;
  touch-action: manipulation;
}
.mob-nav-btn.active  { color: #818CF8; }
.mob-nav-btn:active  { opacity: .7; }
.mob-nav-icon  { font-size: 1.25rem; line-height: 1; }
.mob-nav-label { font-size: .58rem; font-weight: 600; letter-spacing: .02em; white-space: nowrap; }

/* Drawer "Plus" */
.mob-more-drawer {
  position: fixed; inset: 0; z-index: 960;
}
.mob-more-backdrop {
  position: absolute; inset: 0; background: rgba(0,0,0,.45);
}
.mob-more-sheet {
  position: absolute; bottom: 0; left: 0; right: 0;
  background: #fff;
  border-radius: 18px 18px 0 0;
  padding: 8px 0 calc(70px + env(safe-area-inset-bottom, 0px));
  animation: mob-slide-up .22s ease;
  box-shadow: 0 -4px 24px rgba(0,0,0,.15);
}
.mob-more-handle {
  width: 38px; height: 4px; background: #e2e8f0;
  border-radius: 99px; margin: 8px auto 12px;
}
.mob-more-item {
  display: flex; align-items: center; gap: 14px;
  width: 100%; background: none; border: none; cursor: pointer;
  padding: 14px 22px; font-size: .92rem; font-weight: 500;
  color: #0f172a; text-align: left;
  transition: background .12s;
  -webkit-tap-highlight-color: transparent;
}
.mob-more-item:active { background: #f1f5f9; }
.mob-more-item span:first-child { font-size: 1.15rem; width: 26px; text-align: center; }

@keyframes mob-slide-up {
  from { transform: translateY(100%); }
  to   { transform: translateY(0); }
}

/* ── Toggle switch ──────────────────────────────────────────────────────────── */
.toggle-switch { position: relative; display: inline-block; width: 42px; height: 24px; flex-shrink: 0; }
.toggle-switch input { opacity: 0; width: 0; height: 0; }
.toggle-slider {
  position: absolute; inset: 0; cursor: pointer;
  background: #cbd5e1; border-radius: 99px; transition: background .2s;
}
.toggle-slider::before {
  content: ""; position: absolute;
  width: 18px; height: 18px; left: 3px; bottom: 3px;
  background: #fff; border-radius: 50%; transition: transform .2s;
  box-shadow: 0 1px 3px rgba(0,0,0,.2);
}
.toggle-switch input:checked + .toggle-slider { background: #818CF8; }
.toggle-switch input:checked + .toggle-slider::before { transform: translateX(18px); }

/* ── Onboarding Wizard ──────────────────────────────────────────────────────── */
.ob-overlay {
  position: fixed; inset: 0; z-index: 9999;
  background: rgba(15,23,42,.7); backdrop-filter: blur(4px);
  display: flex; align-items: center; justify-content: center;
  padding: 16px;
}
.ob-overlay.hidden { display: none; }
.ob-card {
  background: var(--surface); border-radius: 20px;
  width: 100%; max-width: 560px; max-height: 90vh; overflow-y: auto;
  padding: 32px; box-shadow: 0 20px 60px rgba(0,0,0,.25);
}
.ob-header { display: flex; justify-content: space-between; align-items: center; margin-bottom: 20px; }
.ob-brand  { font-weight: 800; font-size: 1.2rem; color: var(--navy); letter-spacing: -.5px; }
.ob-skip-all { background: none; border: none; color: var(--slate); font-size: .82rem; cursor: pointer; padding: 4px 8px; border-radius: 6px; }
.ob-skip-all:hover { background: var(--border-soft); }
.ob-progress-track { height: 6px; background: var(--border); border-radius: 99px; overflow: hidden; margin-bottom: 6px; }
.ob-progress-fill  { height: 100%; background: var(--blue-dark); border-radius: 99px; transition: width .4s ease; }
.ob-step-label { font-size: .78rem; color: var(--slate); margin: 0 0 24px; }
.ob-step { display: block; }
.ob-step.hidden { display: none; }
.ob-step-icon { font-size: 2.4rem; margin-bottom: 10px; line-height: 1; }
.ob-title { font-size: 1.25rem; font-weight: 700; color: var(--navy); margin: 0 0 8px; }
.ob-desc  { color: var(--slate); font-size: .9rem; margin: 0 0 20px; line-height: 1.5; }
.ob-sector-grid {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 10px; margin-bottom: 20px;
}
.ob-sector-card {
  display: flex; flex-direction: column; align-items: center; gap: 6px;
  padding: 14px 8px; border: 1.5px solid var(--border); border-radius: 12px;
  background: var(--surface); cursor: pointer; font-size: .82rem; font-weight: 500;
  color: var(--navy); text-align: center; transition: border-color .15s, background .15s;
}
.ob-sector-card:hover  { border-color: var(--blue); background: var(--blue-pale); }
.ob-sector-card.active { border-color: var(--blue-dark); background: var(--blue-light); }
.ob-sc-icon { font-size: 1.6rem; }
.ob-actions { display: flex; gap: 10px; align-items: center; margin-top: 20px; flex-wrap: wrap; }
.ob-actions-center { justify-content: center; }
.btn-link { background: none; border: none; color: var(--slate); font-size: .85rem; cursor: pointer; padding: 6px; }
.btn-link:hover { color: var(--navy); text-decoration: underline; }
.ob-connector-preview { border: 1.5px solid var(--border); border-radius: 12px; padding: 16px; margin-bottom: 4px; }
.ob-connector-row { display: flex; align-items: center; gap: 12px; }
.ob-conn-icon { width: 38px; height: 38px; border-radius: 8px; display: flex; align-items: center; justify-content: center; font-size: 1.1rem; color: #fff; flex-shrink: 0; }
.ob-connector-row > div { flex: 1; display: flex; flex-direction: column; gap: 2px; }
.ob-conn-sub { font-size: .75rem; color: var(--slate); }
.ob-conn-status { font-size: .8rem; margin: 8px 0 0; border-radius: 6px; padding: 6px 10px; }
.ob-conn-status.success { background: var(--success-bg); color: var(--success); }
.ob-conn-status.error   { background: var(--error-bg); color: var(--error); }
.ob-invite-form { background: var(--bg); border-radius: 12px; padding: 16px; margin-bottom: 4px; }
.ob-checklist { list-style: none; padding: 0; margin: 0 0 4px; display: flex; flex-direction: column; gap: 8px; }
.ob-checklist li { display: flex; align-items: center; gap: 10px; font-size: .9rem; padding: 8px 12px; border-radius: 8px; background: var(--bg); }
.ob-checklist li.done   { color: var(--success); }
.ob-checklist li.skipped{ color: var(--slate); }
.ob-checklist li .ob-check { font-size: 1rem; }

/* ════════════════════════════════════════════════════════════════════════════
   APP SHELL — SIDEBAR LAYOUT
   ════════════════════════════════════════════════════════════════════════════ */

/* App view fills the full viewport when active */
#view-app:not(.hidden) {
  display: flex;
  flex-direction: column;
  height: 100dvh;
  overflow: hidden;
}

/* App layout: sidebar + right panel side by side */
.app-layout {
  display: flex;
  flex: 1;
  overflow: hidden;
  min-height: 0;
}

/* ── Sidebar ──────────────────────────────────────────────────────────────── */
.app-sidebar {
  width: 220px;
  min-width: 220px;
  background: linear-gradient(180deg, #0c1220 0%, #0f172a 100%);
  display: flex;
  flex-direction: column;
  height: 100%;
  overflow-y: auto;
  overflow-x: hidden;
  scrollbar-width: none;
  border-right: 1px solid rgba(255,255,255,.07);
  flex-shrink: 0;
  transition: transform .25s cubic-bezier(.4,0,.2,1);
  z-index: 50;
}
.app-sidebar::-webkit-scrollbar { display: none; }

/* Sidebar brand */
.sidebar-brand {
  display: flex;
  align-items: center;
  gap: 9px;
  padding: 18px 14px 16px;
  color: #fff;
  font-weight: 800;
  font-size: .9rem;
  text-decoration: none !important;
  cursor: pointer;
  flex-shrink: 0;
  border-bottom: 1px solid rgba(255,255,255,.07);
  margin-bottom: 6px;
}

/* Sidebar section label */
.sidebar-section-label {
  padding: 10px 16px 4px;
  font-size: .63rem;
  font-weight: 700;
  letter-spacing: .09em;
  text-transform: uppercase;
  color: rgba(255,255,255,.25);
  flex-shrink: 0;
}

/* Sidebar nav container */
.sidebar-nav {
  display: flex;
  flex-direction: column;
  gap: 1px;
  padding: 0 8px 4px;
}

/* Tab buttons — sidebar variant (override horizontal .tab-btn) */
.app-sidebar .tab-btn {
  display: flex;
  align-items: center;
  gap: 9px;
  width: 100%;
  min-height: 40px;
  padding: 0 12px;
  border-radius: 9px;
  font-size: .845rem;
  font-weight: 500;
  color: rgba(255,255,255,.52);
  background: transparent;
  border: none;
  cursor: pointer;
  transition: background .12s, color .12s;
  white-space: nowrap;
  text-align: left;
  box-shadow: none;
  position: relative;
  flex-shrink: 0;
}
.app-sidebar .tab-btn::after { display: none; }
.app-sidebar .tab-btn:hover  { background: rgba(255,255,255,.07); color: rgba(255,255,255,.88); }
.app-sidebar .tab-btn.active {
  background: rgba(99,102,241,.22);
  color: #c4b5fd;
  font-weight: 700;
}
.app-sidebar .tab-btn.active::before {
  content: '';
  position: absolute;
  left: -8px; top: 8px; bottom: 8px;
  width: 3px;
  background: #818CF8;
  border-radius: 0 3px 3px 0;
}

/* Workspace section inside sidebar */
.sidebar-workspace {
  margin: 8px 10px 4px;
  padding: 10px 12px;
  background: rgba(255,255,255,.04);
  border-radius: 10px;
  border: 1px solid rgba(255,255,255,.07);
  flex-shrink: 0;
}
.sidebar-workspace .workspace-bar-inner  { flex-direction: column; align-items: flex-start; gap: 6px; overflow: visible; }
.sidebar-workspace .workspace-current    { color: rgba(255,255,255,.62); font-size: .75rem; font-weight: 700; }
.sidebar-workspace .workspace-dot        { background: var(--blue); }
.sidebar-workspace .workspace-chips      { flex-direction: column; gap: 4px; overflow: visible; width: 100%; flex: none; }
/* Chips — dark sidebar style; left border picks up the dept family color via --chip-color */
.sidebar-workspace .ws-chip {
  font-size: .73rem;
  padding: 4px 10px 4px 11px;
  border-radius: 7px;
  width: 100%;
  box-sizing: border-box;
  justify-content: flex-start;
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.08);
  border-left: 3px solid var(--chip-color, rgba(255,255,255,.25));
  color: rgba(255,255,255,.82);
  white-space: normal;
  word-break: break-word;
  line-height: 1.35;
  display: flex;
  opacity: 1;
}
.sidebar-workspace .ws-chip:hover {
  background: rgba(255,255,255,.12);
  color: #fff;
}
.sidebar-workspace .ws-chip.ws-chip-active {
  background: rgba(99,102,241,.25);
  border-left-color: #818CF8;
  color: #c4b5fd;
}
/* Marketplace button — classe dédiée sidebar, sans héritage btn-outline */
.sidebar-mkt-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  padding: 6px 10px;
  margin-top: 2px;
  background: rgba(255,255,255,.05);
  border: 1px solid rgba(255,255,255,.18);
  border-radius: 8px;
  color: rgba(255,255,255,.65);
  font-size: .75rem;
  font-weight: 600;
  cursor: pointer;
  transition: background .12s, color .12s;
}
.sidebar-mkt-btn:hover {
  background: rgba(255,255,255,.1);
  color: #fff;
  border-color: rgba(255,255,255,.35);
}

/* Sidebar bottom */
.sidebar-bottom {
  padding: 10px 10px 14px;
  border-top: 1px solid rgba(255,255,255,.06);
  margin-top: auto;
  flex-shrink: 0;
}
.sidebar-bottom .quota-pill {
  background: rgba(255,255,255,.05);
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 8px;
  padding: 6px 10px;
  width: 100%;
  min-width: 0;
  gap: 7px;
  color: rgba(255,255,255,.55);
}
.sidebar-bottom #quota-text { color: rgba(255,255,255,.55); font-size: .75rem; }

/* Sidebar backdrop for mobile */
.sidebar-backdrop {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,.45);
  z-index: 149;
  animation: fadeIn .18s ease;
}

/* ── App right panel ──────────────────────────────────────────────────────── */
.app-right {
  flex: 1;
  min-width: 0;
  display: flex;
  flex-direction: column;
  overflow: hidden;
  background: var(--bg);
}

/* Top bar */
.app-topbar {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  height: 54px;
  padding: 0 20px;
  background: #fff;
  border-bottom: 1px solid var(--border);
  flex-shrink: 0;
  gap: 8px;
  position: relative;
  z-index: 100;
}
.topbar-right {
  display: flex;
  align-items: center;
  gap: 8px;
}

/* Mobile sidebar toggle button */
.sidebar-toggle {
  display: none;
  align-items: center;
  justify-content: center;
  width: 36px; height: 36px;
  border-radius: 8px;
  border: none;
  background: transparent;
  cursor: pointer;
  color: var(--slate);
  box-shadow: none;
  margin-right: auto;
  transition: background .12s;
  flex-shrink: 0;
}
.sidebar-toggle:hover { background: var(--blue-pale); color: var(--blue); }

/* App main — scrollable content, wider now that sidebar handles left space */
.app-main {
  flex: 1 !important;
  overflow-y: auto !important;
  padding: 28px 32px 80px !important;
  width: 100% !important;
  max-width: none !important;
  margin: 0 !important;
}

/* Fix user-menu-dropdown position for new topbar height */
.user-menu-dropdown { top: 54px !important; }

/* Quota pill color in dark sidebar */
.sidebar-bottom .quota-pill.quota-pill-warn     { border-color: rgba(251,191,36,.3);  background: rgba(251,191,36,.08); }
.sidebar-bottom .quota-pill.quota-pill-critical { border-color: rgba(239,68,68,.3);   background: rgba(239,68,68,.08); }
.sidebar-bottom .quota-pill.quota-pill-warn     #quota-text { color: #fbbf24; }
.sidebar-bottom .quota-pill.quota-pill-critical #quota-text { color: #f87171; }

/* ── Mobile: sidebar becomes a fixed drawer ──────────────────────────────── */
@media (max-width: 768px) {
  .app-sidebar {
    position: fixed;
    left: 0; top: 0;
    height: 100dvh;
    transform: translateX(-100%);
    z-index: 150;
    width: 240px;
    min-width: 240px;
    box-shadow: 4px 0 24px rgba(0,0,0,.35);
  }
  .app-sidebar.open { transform: translateX(0); }
  .sidebar-backdrop.visible { display: block; }

  .sidebar-toggle { display: flex; }
  .app-topbar     { justify-content: space-between; }

  .app-main { padding: 16px 16px 80px !important; }
}

/* Ensure trial banner stays above layout */
#trial-banner { flex-shrink: 0; }

/* Keep sidebar quota visible regardless of viewport (overrides topnav media-query hide) */
.sidebar-bottom .quota-pill { display: flex !important; }
