/* contexte SaaS : padding latéral du contenu principal, polices légèrement réduites */
.saas-embed {
	font-size: 91%;
}
.saas-embed .table {
	font-size: 100%;
}

body.capwise-saas {
	margin: 0;
	display: flex;
	min-height: 100vh;
	font-family: system-ui, sans-serif;
}

.saas-sidebar {
	width: 260px;
	background: #0e2141;
	color: #f9fafb;
	padding: 16px 0 16px 14px;  /* padding-right: 0 → la scrollbar de .sidebar-scroll s'aligne sur le bord droit */
	flex-shrink: 0;
	position: fixed;
	top: 0;
	left: 0;
	height: 100vh;
	overflow: hidden;
	display: flex;
	flex-direction: column;
	z-index: 1000;
}
/* Indent à droite sur tout ce qui n'est pas la zone scrollable (badge, logo,
   bloc account+signout). On utilise margin-right plutôt que padding-right
   pour que les éléments avec border-top (separator account) voient leur
   trait s'arrêter avant le bord droit. */
.saas-sidebar > *:not(.sidebar-scroll):not(.saas-sidebar-toggle) {
	margin-right: 12px;
}

.saas-content {
	flex: 1;
	min-width: 0;
	padding: 22px 53px;
	margin-left: 260px;
}

.sidebar-logo {
	margin-bottom: 20px;
}
.sidebar-logo img {
	max-width: 140px;
	height: auto;
	display: block;
}

.sidebar-nav {
	min-height: 0;
}

/* Zone scrollable de la sidebar (entre le badge super admin et le logo).
   Wrappe Organizations / Admin org / Companies. Badge, logo, account et
   sign-out restent toujours visibles. */
.sidebar-scroll {
	flex: 1;
	min-height: 0;
	overflow-y: auto;
	overflow-x: hidden;  /* en rail (48px), les items internes débordent — éviter la scrollbar horizontale */
	scrollbar-width: thin;
	scrollbar-color: #42679a transparent;
	padding-right: 14px;  /* air à droite des items/selects (hover/active) ; scrollbar reste à 14px du bord */
}
.sidebar-scroll::-webkit-scrollbar {
	width: 6px;
}
.sidebar-scroll::-webkit-scrollbar-track {
	background: transparent;
}
.sidebar-scroll::-webkit-scrollbar-thumb {
	background-color: #42679a;
	border-radius: 3px;
}
.sidebar-scroll::-webkit-scrollbar-thumb:hover {
	background-color: #7a9ad0;
}

.sidebar-empty {
	color: #9ca3af;
	font-size: 0.875rem;
}

.sidebar-section-label {
	font-size: 0.7rem;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.08em;
	color: #7a8696;
	padding: 0 4px;
	margin-bottom: 2px;
}

.sidebar-org-name {
	font-size: 0.875rem;
	color: #d1d5db;
	padding: 4px 4px;
}

.sidebar-super-admin-badge {
	display: inline-block;
	align-self: flex-start;
	background: #ffd166;
	color: #1a2f52;
	font-size: 0.7rem;
	font-weight: 700;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	padding: 3px 8px;
	border-radius: 4px;
	margin-bottom: 4px;
}

.sidebar-org-select {
	background-color: #17305a;
	color: #f9fafb;
	border: 1px solid #2a4470;
	font-size: 0.875rem;
}
.sidebar-org-select:focus {
	background-color: #17305a;
	color: #f9fafb;
	border-color: #4a7ac4;
	box-shadow: 0 0 0 0.15rem rgba(74, 122, 196, 0.25);
}
.sidebar-org-select option {
	background-color: #0e2141;
	color: #f9fafb;
}

/* Quand une org/company est active : le select fermé s'affiche en gras (Chrome/FF
   ignorent font-weight sur les <option>). On remet les options en normal pour
   que le dropdown ouvert ne soit pas tout en gras. */
.sidebar-org-select.is-active {
	font-weight: 600;
}
.sidebar-org-select.is-active option {
	font-weight: 400;
}

/* Wrapper du select company : positionnement relatif pour superposer
   l'indicateur ▸ en mode rail (cf. .sidebar-rail-company-indicator). */
.sidebar-company-select-wrap {
	position: relative;
}
.sidebar-rail-company-indicator {
	display: none;
}

.sidebar-link {
	display: block;
	padding: 5px 4px;
	font-size: 0.875rem;
	color: #d1d5db;
	text-decoration: none;
	border-radius: 4px;
}

/* Permet d'utiliser un <button> au look de sidebar-link (pour les actions
   POST type switch-org : on reset les défauts navigateur du button). */
button.sidebar-link {
	width: 100%;
	text-align: left;
	background: transparent;
	border: 0;
	cursor: pointer;
	font-family: inherit;
}

.sidebar-link:hover {
	background: #374151;
	color: #f9fafb;
}

.sidebar-link-active {
	color: #f9fafb;
	font-weight: 600;
	background: rgba(255, 255, 255, 0.10);
	pointer-events: none;
}

/* ── Companies ──────────────────────────────────────────────────────────── */

.sidebar-company {
	margin-bottom: 2px;
}

.sidebar-company-header {
	display: flex;
	align-items: center;
	gap: 4px;
}

.sidebar-company-toggle {
	background: none;
	border: none;
	color: #6b7280;
	padding: 4px 2px;
	cursor: pointer;
	font-size: 0.65rem;
	line-height: 1;
	flex-shrink: 0;
}

.sidebar-company-toggle:hover {
	color: #d1d5db;
}

.sidebar-chevron {
	display: inline-block;
	transition: transform 0.45s ease;
}

.sidebar-company.is-expanded .sidebar-chevron {
	transform: rotate(90deg);
}

.sidebar-company-name {
	flex: 1;
	min-width: 0;
	font-size: 0.875rem;
	color: #d1d5db;
	text-decoration: none;
	padding: 4px 4px;
	border-radius: 4px;
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
	display: block;
}

.sidebar-company-name:hover {
	background: #374151;
	color: #f9fafb;
}

.sidebar-company-name-active {
	color: #f9fafb;
	font-weight: 600;
}

.sidebar-company-tabs {
	padding-left: 6px;
	margin-left: 3px;  /* léger décalage à droite par rapport au bord du select */
	margin-top: 10px;
	border-left: 1px solid rgba(157, 180, 204, 0.45);
	overflow: hidden;
	max-height: 0;
	opacity: 0;
	margin-bottom: 0;
	transition: max-height 0.55s ease, opacity 0.55s ease, margin-bottom 0.55s ease;
}

.sidebar-company.is-expanded .sidebar-company-tabs {
	opacity: 1;
	margin-bottom: 4px;
	/* max-height fixée en JS sur scrollHeight pour absorber n'importe quel
	   nombre de customs sans troncature. */
}

.sidebar-company.sidebar-no-anim .sidebar-company-tabs {
	transition: none !important;
}

.sidebar-tab-link {
	display: block;
	padding: 5px 4px;
	font-size: 0.875rem;
	color: #d1d5db;
	text-decoration: none;
	border-radius: 4px;
}

.sidebar-tab-link:hover {
	background: #374151;
	color: #f9fafb;
}

.sidebar-tab-link-active {
	color: #fff;
	font-weight: 600;
	background: rgba(255, 255, 255, 0.10);
	pointer-events: none;
}

.sidebar-new-company {
	color: #d1d5db;
	font-size: 0.875rem;
	padding: 4px;
}

.sidebar-new-company:hover {
	color: #f9fafb;
}

/* Modal large mais pas fullscreen (laisse la sidebar visible sur grand écran) */
.capwise-saas .modal-dialog.saas-modal-wide {
	max-width: min(1350px, 95vw);
}

/* ── Custom use cases : badge sidebar (phase 9) ────────────────────────── */
/* Le tab-link devient flex : label prend l'espace restant (et peut wrapper),
   badge reste collé à droite aligné en haut même si le titre passe sur 2 lignes. */
.sidebar-tab-link-custom {
	display: flex;
	align-items: flex-start;
	gap: 7px;  /* ≈ largeur de `&nbsp;` + espace utilisée par les autres items */
	padding-right: 0;  /* badge aligné sur le bord droit du link (= même indent que les selects et highlights) */
}
.sidebar-tab-link-custom .sidebar-custom-badge {
	margin-left: 6px;  /* un peu d'air entre le texte et le badge */
}
.sidebar-custom-icon {
	flex: 0 0 auto;
	line-height: 1.3;
}
.sidebar-custom-label {
	flex: 1 1 auto;
	min-width: 0;
	/* Si le titre wrappe, la 2ème ligne démarre ici (après l'icône), donc alignée
	   avec le texte de la 1ère ligne — pas sous l'icône. */
}
.sidebar-custom-badge {
	flex: 0 0 auto;
	margin-top: 2px;
	padding: 1px 5px;
	font-size: 0.53rem;
	font-weight: 500;
	letter-spacing: 0.05em;
	text-transform: uppercase;
	color: #1a2f52;
	background: #ffd166;
	border-radius: 4px;
	box-shadow: 0 0 0 1px rgba(255, 209, 102, 0.35);
}
.sidebar-tab-link-active .sidebar-custom-badge {
	color: #1a2f52;
	background: #ffdf8a;
	box-shadow: 0 0 0 1px rgba(255, 255, 255, 0.35);
}

/* Chevron inerte pour les use cases custom à plat : on reprend l'apparence de
   `.sidebar-company-toggle` (déjà stylé) mais on coupe l'interactivité pour que
   le triangle serve uniquement d'ancrage visuel aligné avec les companies. */
.sidebar-toggle-inert {
	cursor: default;
	display: inline-block;
}

/* ── Custom use cases embedés (phase 9) ────────────────────────────────── */
/* Le use case share/*.php émet une navbar fixed-top (render_header) qui sinon
   recouvrirait toute la viewport y compris la sidebar. On la recadre sur la
   zone saas-content. La navbar a z-index:1030 dans render-html-ui.php → on
   reste au-dessus du contenu sans masquer la sidebar (z-index:1000 mais
   fixed à left:0). */
.saas-content:has(.saas-custom-embed) {
	padding: 0;
}
.saas-custom-embed {
	padding: 48px 53px 22px;  /* top = mt-5 Bootstrap (3rem) pour matcher le rendu standalone (header-share.php : `mt-5` sur le container) */
	min-height: 100vh;
}
.saas-custom-embed #main-nav.fixed-top {
	left: 260px;
	right: 0;
	width: auto;
}
body.saas-sidebar-rail .saas-custom-embed #main-nav.fixed-top {
	left: 48px;
}

/* ── Dashboard — org blocks ─────────────────────────────────────────────── */

.cw-dash-org-block {
	margin-bottom: 48px;
}

.cw-dash-org-block-multi + .cw-dash-org-block-multi {
	border-top: 1px solid #e5e7eb;
	padding-top: 40px;
}

.cw-dash-page-title {
	font-size: 1.3rem;
	font-weight: 500;
	color: #111827;
	margin-bottom: 12px;
}

.cw-dash-org-header {
	display: flex;
	align-items: center;
	gap: 16px;
	flex-wrap: wrap;
}

.cw-dash-org-header > .cw-dash-page-title,
.cw-dash-org-header > .cw-dash-org-title {
	margin-bottom: 0;
	flex: 1 1 auto;
}

.cw-dash-filter {
	max-width: 320px;
	flex: 0 0 auto;
	font-size: 0.95rem;
	padding: 0.4rem 0.75rem 0.4rem 2.15rem;
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' fill='%236c757d' viewBox='0 0 16 16'%3E%3Cpath d='M11.742 10.344a6.5 6.5 0 1 0-1.397 1.398h-.001q.044.06.098.115l3.85 3.85a1 1 0 0 0 1.415-1.414l-3.85-3.85a1 1 0 0 0-.115-.1zM12 6.5a5.5 5.5 0 1 1-11 0 5.5 5.5 0 0 1 11 0'/%3E%3C/svg%3E");
	background-repeat: no-repeat;
	background-position: 0.7rem center;
	background-size: 15px 15px;
	border-color: #b8c2d2;
	background-color: #fafbfc;
	transition: border-color .15s ease, background-color .15s ease, box-shadow .15s ease;
}
.cw-dash-filter:hover {
	border-color: #8898ad;
}
.cw-dash-filter:focus {
	background-color: #fff;
	border-color: #6366f1;
	box-shadow: 0 0 0 0.2rem rgba(99,102,241,0.18);
}

.cw-dash-org-title {
	font-size: 1.1rem;
	font-weight: 600;
	color: #374151;
	margin-bottom: 16px;
}

/* ── Company cards ──────────────────────────────────────────────────────── */

.cw-company-card {
	transition: box-shadow .15s ease, border-color .15s ease;
	cursor: pointer;
	color: inherit;
}

.cw-company-card:hover {
	color: inherit;
	box-shadow: 0 4px 12px rgba(0,0,0,.12);
	border-color: #adb5bd;
}

/* Header Bootstrap card-header */

.cw-cc-header {
	display: flex;
	align-items: center;
	background: #f8f9fa;
	padding: 0.7rem 1rem;
}

.cw-cc-bldg-icon {
	opacity: 0.55;
	font-size: 1.1rem;
	flex-shrink: 0;
}

.cw-cc-name {
	font-size: 1.05rem;
	font-weight: 500;
	color: #0e2141;
	text-decoration: none;
}

/* Corps */

.cw-cc-body {
	display: flex;
	flex-direction: column;
	padding: 1rem;
}

/* Sections internes */

.cw-cc-section {
	margin-bottom: 14px;
}

.cw-cc-section-grow {
	flex: 1;
}

.cw-cc-section-grow > .cw-cc-section-label {
	margin-top: 6px;
}

.cw-cc-section-label {
	font-size: 0.72rem;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: .07em;
	color: #9ca3af;
	margin-bottom: 6px;
}

.cw-cc-empty {
	font-size: 0.875rem;
	color: #adb5bd;
	font-style: italic;
}

/* Instruments (cap table) */

.cw-cc-instr-row {
	display: flex;
	align-items: flex-start;
	gap: 6px;
	margin-bottom: 10px;
}

.cw-cc-section-label:has(+ .cw-cc-instr-row) {
	margin-bottom: 10px;
}

.cw-cc-instr-row:last-child {
	margin-bottom: 0;
}

.cw-cc-pill {
	font-size: 0.7rem;
	font-weight: 700;
	padding: 2px 6px;
	border-radius: 4px;
	flex-shrink: 0;
	letter-spacing: .03em;
}

.cw-cc-pill-ao  { background: #dbeafe; color: #1e40af; }
.cw-cc-pill-ap  { background: #ede9fe; color: #6d28d9; }
.cw-cc-pill-opt { background: #dcfce7; color: #166534; }

.cw-cc-pill-count {
	font-weight: 400;
	letter-spacing: 0;
}

.cw-cc-instr-names-wrap {
	flex: 1;
	min-width: 0;
}

.cw-cc-instr-names {
	font-size: 0.875rem;
	line-height: 1.5;
	color: #374151;
	display: -webkit-box;
	-webkit-line-clamp: 2;
	line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
}

.cw-cc-instr-names.cw-cc-expanded {
	display: block;
	-webkit-line-clamp: unset;
	line-clamp: unset;
	overflow: visible;
}

.cw-cc-toggle {
	background: none;
	border: 0;
	padding: 0;
	margin: 0;
	font-size: 0.875rem;
	line-height: 1.5;
	color: #2563eb;
	cursor: pointer;
	display: flex;
	align-items: center;
	gap: 4px;
}

.cw-cc-toggle::before {
	content: '';
	display: inline-block;
	width: 0;
	height: 0;
	border-left: 4px solid transparent;
	border-right: 4px solid transparent;
	border-top: 5px solid currentColor;
	transition: transform 0.18s ease;
}

.cw-cc-toggle.cw-cc-toggle-expanded::before {
	transform: rotate(180deg);
}

.cw-cc-toggle:hover {
	text-decoration: underline;
}

/* Positions */

.cw-cc-pos-row {
	margin-bottom: 8px;
}

.cw-cc-pos-head {
	display: flex;
	align-items: baseline;
	gap: 8px;
}

.cw-cc-pos-name {
	font-size: 0.9rem;
	font-weight: 600;
	color: #1f2937;
}

.cw-cc-pos-instruments {
	font-size: 0.85rem;
	color: #6b7280;
	margin-top: 1px;
}

.cw-cc-pos-total {
	font-size: 0.85rem;
	color: #0e2141;
	font-weight: 500;
	margin-left: auto;
	white-space: nowrap;
}

/* Pied de card */

.cw-cc-footer {
	font-size: 0.78rem;
	color: #9097a3;
	background: #f8f9fa;
	border-top: 1px solid #dde0e4;
	padding: 0.5rem 1rem;
}
.cw-cc-custom-badge {
	flex: 0 0 auto;
	margin-left: auto;
	font-size: 0.62rem;
	background: #ffe9a8;
	box-shadow: 0 0 0 1px rgba(255, 233, 168, 0.45);
}

.cw-cc-body {
	padding-bottom: 0.25rem;
}

/* Carte "Nouvelle company" */

.cw-cc-new-card {
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	min-height: 120px;
	border: 2px dashed #d1d5db !important;
	box-shadow: none !important;
	color: #9ca3af;
	text-decoration: none;
	gap: 8px;
	font-size: 0.95rem;
	background: #fff;
}

.cw-cc-new-card:hover {
	border-color: #6b7280 !important;
	color: #374151;
	background: #f9fafb;
}

.cw-cc-new-icon {
	font-size: 1.5rem;
}

/* ── Badges rôle membre ─────────────────────────────────────────────────── */

.cw-role-badge {
	display: inline-block;
	font-size: 0.7rem;
	font-weight: 600;
	letter-spacing: 0.04em;
	padding: 0.32em 0.65em 0.38em;
	border-radius: 6px;
	line-height: 1;
	vertical-align: middle;
}

/* Curseur pointer sur les badges qui portent un tooltip — natif (`title`)
   ou Bootstrap (qui transforme `title` en `data-bs-original-title` à l'init).
   Pour signaler visuellement que survoler révèle de l'info. */
.cw-role-badge[title],
.cw-role-badge[data-bs-original-title] {
	cursor: pointer;
}

/* Customisation des tooltips Bootstrap (init dans saas.js avec customClass: 'cw-tooltip').
   On reprend le bleu sombre de la sidebar via la CSS var native --bs-tooltip-bg
   (Bootstrap 5.2+) — colore à la fois le bloc et la flèche, quel que soit le placement. */
.tooltip.cw-tooltip {
	/* --bs-tooltip-bg pilote la flèche : alignée sur la couleur de border pour qu'elle
	   matche visuellement (et pas avec la couleur du texte qui est plus dense). */
	--bs-tooltip-bg: #8aaad6;
	--bs-tooltip-color: #3258a0;
	--bs-tooltip-opacity: 1;
}
.tooltip.cw-tooltip .tooltip-inner {
	background-color: #f8f9fb;
	border: 1px solid #a5bce0;
	padding: 0.34rem 0.62rem;
}

/* Pas de flèche : on cache via visibility (et non display:none) pour ne pas casser
   les calculs de positionnement Popper qui utilisent la bbox de l'arrow. */
.tooltip.cw-tooltip .tooltip-arrow {
	visibility: hidden;
}

.cw-role-badge-admin {
	background: rgba(13, 110, 253, 0.12);
	color: #0a58ca;
}

.cw-role-badge-user {
	background: rgba(25, 135, 84, 0.12);
	color: #146c43;
}

.cw-role-badge-guest {
	background: rgba(108, 117, 125, 0.12);
	color: #495057;
}

.cw-role-badge-me {
	background: rgba(25, 135, 84, 0.12);
	color: #146c43;
}

.cw-role-badge-danger {
	background: rgba(220, 53, 69, 0.12);
	color: #b02a37;
}

.cw-role-badge-warning {
	background: rgba(255, 193, 7, 0.18);
	color: #997404;
}

/* ── Switch « Revoke access » : rouge quand activé ─────────────────────── */

.cw-switch-danger .form-check-input:checked {
	background-color: #dc3545;
	border-color: #dc3545;
}

.cw-switch-danger .form-check-input:focus {
	border-color: #dc3545;
	box-shadow: 0 0 0 0.25rem rgba(220, 53, 69, 0.25);
}

/* ── Lien admin org dans la sidebar ────────────────────────────────────── */

.sidebar-admin-link {
	margin-top: 4px;
	font-size: 0.8rem;
	color: #9ca3af !important;
	padding: 3px 4px;
}

.sidebar-admin-link:hover {
	color: #f9fafb !important;
}

.sidebar-admin-link.sidebar-link-active {
	color: #f9fafb !important;
}

/* ── Titre de page avec nom d'org ───────────────────────────────────────── */

.cw-org-page-title {
	font-size: 1.3rem;
	font-weight: 500;
	color: #111827;
	margin-bottom: 0;
	display: flex;
	align-items: center;
	gap: 0;
}

.cw-org-page-title-icon {
	opacity: 0.55;
	font-size: 1.15rem;
	margin-right: 0.5rem;
	flex-shrink: 0;
}

/* ── Logo sidebar cliquable ─────────────────────────────────────────────── */
/* Logo sidebar cliquable */

.sidebar-account-link {
	display: block;
	font-size: 0.875rem;
	word-break: break-all;
	color: #9db4cc;
	text-decoration: none;
	margin-bottom: 16px;
	padding-left: 0;
	text-align: left;
}

.sidebar-account-link:hover {
	color: #fff;
}

.sidebar-logo-link {
	display: block;
	transition: opacity .15s ease;
}

.sidebar-logo-link:hover {
	opacity: .85;
}

/* ─────────────────────────────────────────────────────────────────────────
   Sidebar rail mode (desktop) — sidebar repliée en colonne d'icônes ;
   se déplie en overlay au hover sans pousser le contenu principal.
   État persisté via cookie cw_sidebar_rail (lu côté PHP, classe sur <body>).
   ───────────────────────────────────────────────────────────────────────── */

/* Bouton qui dépasse à cheval sur le bord droit de la sidebar (pattern
   Notion/Linear/Slack). position: fixed pour échapper au overflow:hidden de
   la sidebar, et z-index au-dessus de la sidebar (1060). */
.saas-sidebar-toggle {
	position: fixed;
	top: 7px;
	left: 236px; /* 260 - 24 = 3/4 dans la sidebar, 1/4 dépassant */
	width: 32px;
	height: 32px;
	border: 1px solid #6b7c92;
	background: #0e2141;
	color: #f9fafb;
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 0.8rem;
	cursor: pointer;
	z-index: 1061;
	padding: 0;
	box-shadow: 0 2px 8px rgba(0, 0, 0, 0.25);
	transition: left .18s ease, background .15s ease, transform .15s ease, box-shadow .15s ease;
}
.saas-sidebar-toggle:hover {
	background: #1e3a5f;
	transform: scale(1.1);
	box-shadow: 0 3px 12px rgba(0, 0, 0, 0.35);
}

/* Logo carré transparent affiché en bas de la sidebar en rail mode. */
.saas-sidebar-rail-logo {
	display: none;
	width: 30px;
	height: 30px;
	margin: auto auto 4px;
	opacity: 1;
}
@media (min-width: 769px) {
	body.saas-sidebar-rail .saas-sidebar:not(.is-hover-expanded) .saas-sidebar-rail-logo {
		display: block;
	}
}

/* En rail (non hover), le bouton suit le bord droit de la sidebar étroite. */
body.saas-sidebar-rail .saas-sidebar:not(.is-hover-expanded) ~ .saas-sidebar-toggle,
body.saas-sidebar-rail .saas-sidebar:not(.is-hover-expanded) .saas-sidebar-toggle {
	left: 24px; /* 48 - 24 */
}

@media (min-width: 769px) {
	.saas-sidebar {
		transition: width .18s ease;
	}

	body.saas-sidebar-rail .saas-sidebar {
		width: 48px;
		padding: 2px 0 16px;
		z-index: 1040;
	}
	/* Annule le padding-right:16px (posé pour le mode déplié) sur les blocs
	   hors .sidebar-scroll : en rail (48px), il décale les icônes vers la
	   gauche au lieu de les centrer (visible sur account + signout). */
	body.saas-sidebar-rail .saas-sidebar:not(.is-hover-expanded) > * {
		padding-right: 0 !important;
		margin-right: 0 !important;  /* annule le margin-right:12px (mode déplié), sinon icônes du bas (logo, account, sign out) décalées de 6px à gauche */
	}
	body.saas-sidebar-rail .saas-content {
		margin-left: 48px;
	}
	body.saas-sidebar-rail #loader {
		left: 48px !important;
		width: calc(100% - 48px) !important;
	}
	/* Scoping sur .top-0 : on ne recentre que les toasts top-centered (Saved /
	   Deleted du layout, qui ont transform:translateX(-50%) inline). Les toasts
	   bottom-end (position, analyze, newround) gardent leur right:0 d'origine. */
	body.saas-sidebar-rail .toast-container.top-0 {
		left: calc(48px + (100vw - 48px) / 2) !important;
	}
	body.saas-sidebar-rail .scroll-hint {
		left: calc(48px + (100vw - 48px) / 2);
	}

	/* En rail : on garde la structure verticale de la sidebar (chaque ligne reste
	   à la même hauteur qu'en mode déplié), mais on n'affiche que les icônes —
	   labels rendus transparents et selects masqués via visibility (espace
	   préservé). La classe .is-hover-expanded (posée par JS au survol) restaure
	   l'affichage complet pour l'overlay déplié. */
	body.saas-sidebar-rail .saas-sidebar.is-hover-expanded .sidebar-company-tabs {
		max-height: none !important;
	}

	/* Liens : labels invisibles (font-size:0 pour ne pas perturber le centrage),
	   icônes centrées horizontalement via flex. min-height préserve la hauteur
	   d'origine pour que les icônes restent à la même Y qu'en mode déplié. */
	body.saas-sidebar-rail .saas-sidebar:not(.is-hover-expanded) .sidebar-link,
	body.saas-sidebar-rail .saas-sidebar:not(.is-hover-expanded) .sidebar-tab-link,
	body.saas-sidebar-rail .saas-sidebar:not(.is-hover-expanded) .sidebar-account-link,
	body.saas-sidebar-rail .saas-sidebar:not(.is-hover-expanded) .sidebar-new-company {
		display: flex !important;
		align-items: center;
		justify-content: center;
		color: transparent !important;
		font-size: 0 !important;
		padding-left: 0;
		padding-right: 0;
		overflow: hidden;
		white-space: nowrap;
		min-height: 1.3125rem;
	}
	body.saas-sidebar-rail .saas-sidebar:not(.is-hover-expanded) .sidebar-link i.bi,
	body.saas-sidebar-rail .saas-sidebar:not(.is-hover-expanded) .sidebar-tab-link i.bi,
	body.saas-sidebar-rail .saas-sidebar:not(.is-hover-expanded) .sidebar-account-link i.bi,
	body.saas-sidebar-rail .saas-sidebar:not(.is-hover-expanded) .sidebar-new-company i.bi {
		color: #d1d5db;
		margin: 0 !important;
		font-size: 1.05rem;
		flex: 0 0 auto;
	}
	body.saas-sidebar-rail .saas-sidebar:not(.is-hover-expanded) .sidebar-link:hover,
	body.saas-sidebar-rail .saas-sidebar:not(.is-hover-expanded) .sidebar-tab-link:hover {
		background: transparent;
	}

	/* Onglets de company : pas d'indentation ni de border-left en rail, pour que
	   les icônes s'alignent verticalement avec celles des autres rubriques. */
	body.saas-sidebar-rail .saas-sidebar:not(.is-hover-expanded) .sidebar-company-tabs {
		padding-left: 0 !important;
		margin-left: 0 !important;
		border-left: 0 !important;
		margin-top: 0 !important;
		max-height: none !important;
		opacity: 1 !important;
		overflow: visible !important;
	}
	body.saas-sidebar-rail .saas-sidebar:not(.is-hover-expanded) .sidebar-custom-label,
	body.saas-sidebar-rail .saas-sidebar:not(.is-hover-expanded) .sidebar-custom-badge {
		display: none !important;
	}

	/* Item actif : pas de fond pleine largeur en rail (juste l'icône colorée). */
	body.saas-sidebar-rail .saas-sidebar:not(.is-hover-expanded) .sidebar-tab-link-active,
	body.saas-sidebar-rail .saas-sidebar:not(.is-hover-expanded) .sidebar-link-active {
		background: transparent !important;
	}
	body.saas-sidebar-rail .saas-sidebar:not(.is-hover-expanded) .sidebar-tab-link-active i.bi,
	body.saas-sidebar-rail .saas-sidebar:not(.is-hover-expanded) .sidebar-link-active i.bi {
		color: #fff !important;
	}

	/* Élements purement textuels (sans icône) : on garde l'espace mais on cache
	   le contenu pour préserver l'alignement vertical avec le mode déplié. */
	body.saas-sidebar-rail .saas-sidebar:not(.is-hover-expanded) .sidebar-section-label,
	body.saas-sidebar-rail .saas-sidebar:not(.is-hover-expanded) .sidebar-org-name,
	body.saas-sidebar-rail .saas-sidebar:not(.is-hover-expanded) .sidebar-empty {
		visibility: hidden;
	}
	body.saas-sidebar-rail .saas-sidebar:not(.is-hover-expanded) .sidebar-org-select {
		visibility: hidden;
	}
	/* Logo en haut du bloc bas (au-dessus de user + sign out, comme en mode déplié) :
	   on remplace la version large par le carré, et on neutralise le rail-logo
	   autonome qui était posé tout en bas de l'<aside>. */
	body.saas-sidebar-rail .saas-sidebar:not(.is-hover-expanded) .sidebar-logo {
		margin-bottom: 30px !important;
		padding: 0 !important;
	}
	body.saas-sidebar-rail .saas-sidebar:not(.is-hover-expanded) .sidebar-logo img {
		visibility: hidden;
		width: 26px !important;
		max-width: 26px !important;
		height: 26px !important;
		margin: 0 auto;
	}
	body.saas-sidebar-rail .saas-sidebar:not(.is-hover-expanded) .sidebar-logo-link {
		display: block;
		width: 26px;
		height: 26px;
		margin: 0 auto;
		background: url('/assets/logo-capwise-square.png') center/contain no-repeat;
	}
	body.saas-sidebar-rail .saas-sidebar:not(.is-hover-expanded) .saas-sidebar-rail-logo {
		display: none !important;
	}

	/* Badge super-admin : retiré du flux en rail (display:none) pour que les
	   sections suivantes remontent à la même hauteur qu'en mode user/admin. */
	body.saas-sidebar-rail .saas-sidebar:not(.is-hover-expanded) .sidebar-super-admin-badge {
		display: none;
	}
	/* Compense légèrement la disparition du badge : pousse la section
	   Organizations vers le bas pour matcher l'alignement attendu.
	   La sélection passe par .sidebar-scroll car le wrapper s'intercale entre
	   le badge et le bloc Organizations (.mt-3 est désormais le premier
	   enfant de .sidebar-scroll). */
	body.saas-sidebar-rail .saas-sidebar:not(.is-hover-expanded):has(.sidebar-super-admin-badge) .sidebar-scroll > .mt-3:first-child {
		margin-top: 1.6rem !important;
	}
	/* Décale juste les 4 liens super-admin (Manage orgs / Users / Customs /
	   Audit log) sans impacter le flux : translateY ne pousse pas le reste. */
	body.saas-sidebar-rail .saas-sidebar:not(.is-hover-expanded):has(.sidebar-super-admin-badge) .sidebar-scroll > .mt-3:first-child .sidebar-link {
		transform: translateY(13px);
	}

	/* Bouton "Sign out" : on conserve l'icône, on neutralise le chrome du btn. */
	body.saas-sidebar-rail .saas-sidebar:not(.is-hover-expanded) a.btn,
	body.saas-sidebar-rail .saas-sidebar:not(.is-hover-expanded) button.btn {
		display: flex !important;
		align-items: center;
		justify-content: center;
		color: transparent !important;
		background: transparent !important;
		border-color: transparent !important;
		font-size: 0 !important;
		padding-left: 0;
		padding-right: 0;
	}
	body.saas-sidebar-rail .saas-sidebar:not(.is-hover-expanded) a.btn i.bi,
	body.saas-sidebar-rail .saas-sidebar:not(.is-hover-expanded) button.btn i.bi {
		color: #d1d5db;
		margin: 0 !important;
		font-size: 1.05rem;
	}
	body.saas-sidebar-rail .saas-sidebar:not(.is-hover-expanded) .border-top {
		border-top-color: transparent !important;
		padding-top: 0 !important;
	}
	/* Rapproche user + sign out en bas (en mode déplié on garde 16px). */
	body.saas-sidebar-rail .saas-sidebar:not(.is-hover-expanded) .sidebar-account-link {
		margin-bottom: 2px !important;
	}

	/* Indicateur ▸ pour la company active : superposé au select masqué pour
	   conserver la position verticale exacte du nom de company. */
	body.saas-sidebar-rail .saas-sidebar:not(.is-hover-expanded) .sidebar-rail-company-indicator {
		display: flex;
		align-items: center;
		justify-content: center;
		position: absolute;
		inset: 0;
		color: #d1d5db;
		font-size: 0.85rem;
		pointer-events: none;
	}

	/* Overlay déplié au survol (piloté par JS, pas par :hover, pour pouvoir
	   suspendre le hover juste après un toggle sans déplacer la souris). */
	body.saas-sidebar-rail .saas-sidebar.is-hover-expanded {
		width: 260px;
		padding: 16px;
		box-shadow: 4px 0 20px rgba(0, 0, 0, 0.25);
	}
}

/* ─────────────────────────────────────────────────────────────────────────
   Mobile / responsive (≤ 768px)
   Règles ajoutées en fin de fichier pour ne jamais altérer le rendu desktop.
   ───────────────────────────────────────────────────────────────────────── */

.saas-mobile-toggle {
	display: none;
}
.saas-mobile-logo {
	display: none;
}
.saas-sidebar-backdrop {
	display: none;
}

@media (max-width: 768px) {
	/* — Pas de scroll horizontal global : sinon le logo fixed (right:8px)
	   se retrouve hors viewport sur les pages qui débordent (Dashboard). — */
	html, body.capwise-saas {
		overflow-x: hidden;
		max-width: 100vw;
	}

	/* — Barre d'en-tête mobile : fond blanc opaque + border-bottom gris clair,
	   pour que la zone hamburger/badge/logo ne laisse plus voir le contenu
	   défiler à travers. Hauteur 56px = 8 + 40 + 8 (logo carré). — */
	body.capwise-saas::before {
		content: "";
		position: fixed;
		top: 0;
		left: 0;
		right: 0;
		height: 56px;
		background: #f9fafb;
		border-bottom: 1px solid #e5e7eb;
		z-index: 1098;
		pointer-events: none;
	}
	body.saas-sidebar-open::before {
		opacity: 0;
	}
	/* — Modals au-dessus du chrome mobile (header bar 1098, hamburger/logo 1100). — */
	.modal-backdrop {
		z-index: 1110;
	}
	.modal {
		z-index: 1111;
	}

	/* — Bouton hamburger fixed top-left — */
	.saas-mobile-toggle {
		display: flex;
		align-items: center;
		justify-content: center;
		position: fixed;
		top: 8px;
		left: 8px;
		z-index: 1100;
		width: 40px;
		height: 40px;
		border: 0;
		background: #0e2141;
		border-radius: 6px;
		font-size: 1.4rem;
		color: #f9fafb;
		box-shadow: 0 1px 3px rgba(0,0,0,0.18);
		padding: 0;
	}
	.saas-mobile-toggle:active {
		background: #1a2f52;
	}
	body.saas-sidebar-open .saas-mobile-toggle {
		opacity: 0;
		pointer-events: none;
	}

	/* — Logo carré symétrique en haut à droite — */
	.saas-mobile-logo {
		display: block;
		position: fixed;
		top: 8px;
		right: 8px;
		z-index: 1100;
		width: 40px;
		height: 40px;
		border-radius: 6px;
		overflow: hidden;
		box-shadow: 0 1px 3px rgba(0,0,0,0.18);
		line-height: 0;
	}
	.saas-mobile-logo img {
		width: 100%;
		height: 100%;
		display: block;
	}

	/* — Sidebar drawer escamotable — */
	.saas-sidebar {
		transform: translateX(-100%);
		transition: transform .25s ease;
		width: 84vw;
		max-width: 320px;
		overflow-y: auto;
	}
	.saas-sidebar.is-open {
		transform: translateX(0);
		box-shadow: 4px 0 20px rgba(0,0,0,0.25);
	}
	.saas-sidebar-backdrop {
		display: block;
		position: fixed;
		inset: 0;
		background: rgba(0,0,0,0.45);
		z-index: 999;
		opacity: 0;
		pointer-events: none;
		transition: opacity .25s ease;
	}
	.saas-sidebar-backdrop.is-open {
		opacity: 1;
		pointer-events: auto;
	}
	body.saas-sidebar-open {
		overflow: hidden;
	}

	/* — Contenu principal pleine largeur, padding réduit — */
	.saas-content {
		margin-left: 0;
		padding: 88px 20px 22px;
	}
	#loader {
		left: 0 !important;
		width: 100% !important;
	}
	.toast-container {
		left: 50% !important;
	}

	/* — Bootstrap grid : tout passe en 100% sur mobile — */
	.saas-content [class*="col-md-"],
	.saas-content [class*="col-lg-"],
	.saas-content [class*="col-xl-"] {
		flex: 0 0 100%;
		max-width: 100%;
	}

	/* — Tables : scroll horizontal en dernier recours — */
	.saas-content .table {
		display: block;
		overflow-x: auto;
		max-width: 100%;
		-webkit-overflow-scrolling: touch;
	}
	.saas-content .table-responsive {
		overflow-x: auto;
	}
	/* Empêche les sauts de ligne intempestifs (prénom/nom, dates, etc.).
	   Le scroll horizontal du conteneur compense la largeur. */
	.saas-content .table th,
	.saas-content .table td {
		white-space: nowrap;
	}
	/* Échappatoire si une colonne doit pouvoir wrapper (texte long). */
	.saas-content .table .cw-wrap,
	.saas-content .table th.cw-wrap,
	.saas-content .table td.cw-wrap {
		white-space: normal;
	}

	/* — Réduit le font-size global du SaaS pour gagner de la place — */
	.saas-embed {
		font-size: 95%;
	}

	/* — Titre de page sans débordement — */
	.cw-org-page-title {
		font-size: 1.1rem;
		flex-wrap: wrap;
	}

	/* — Header de company sur mobile :
	   badge nom de company fixé en haut au centre (entre hamburger et logo),
	   bouton(s) d'action centrés en flow juste en dessous. — */
	.saas-company-header {
		display: block !important;
		text-align: center;
	}
	.saas-company-header .badge {
		position: fixed;
		top: 8px;
		left: 56px;
		right: 56px;
		z-index: 1099;
		margin: 0 auto;
		min-height: 40px;
		max-width: calc(100vw - 112px);
		justify-content: center;
		flex-wrap: wrap;
		text-align: center;
		/* Rend le badge opaque (sinon on voit la page défiler à travers
		   à cause du bg-opacity-10 de Bootstrap). */
		background-color: color-mix(in srgb, var(--bs-primary) 10%, #fff) !important;
		--bs-bg-opacity: 1 !important;
	}
	body.saas-sidebar-open .saas-company-header .badge {
		opacity: 0;
		pointer-events: none;
	}
	/* Bouton share : fixé sous la barre d'en-tête (56px) + petit gap. */
	.saas-company-share-btn {
		position: fixed;
		top: 64px;
		right: 12px;
		z-index: 1099;
	}
	body.saas-sidebar-open .saas-company-share-btn {
		opacity: 0;
		pointer-events: none;
	}
	.saas-company-header-right {
		justify-content: center !important;
		width: 100%;
		flex-wrap: wrap;
		gap: 8px;
		margin-top: 18px;
	}
	.saas-company-header-right .btn {
		white-space: normal;
	}
	/* Annule les ms-3 inline qui décalent le bouton à gauche en desktop. */
	.saas-company-header-right > .btn,
	.saas-company-header-right > div {
		margin-left: 0 !important;
	}
	/* — Dashboard : moins d'air entre le titre d'org et les cards — */
	.cw-dash-page-title,
	.cw-dash-org-title {
		margin-bottom: 4px;
		text-align: center;
	}
	.saas-content .cw-dash-org-block .row.g-5 {
		--bs-gutter-y: 1rem;
		margin-top: 0 !important;
	}
}

/* — XS (≤ 576px) : nom de company plus compact — */
@media (max-width: 576px) {
	.saas-company-header .badge {
		font-size: 1.05rem !important;
		padding: 0.55em 0.85em !important;
	}
}

/* — Mobile + use case custom embedé (`.saas-custom-embed`) :
     la navbar fixed-top du use case (#main-nav) cohabite avec le chrome SaaS.
     On ne garde qu'une seule barre :
     - hamburger SaaS conservé à gauche (déjà z-index 1100, au-dessus de #main-nav z-1030),
     - logo carré masqué (libère le coin droit pour le hamburger d'onglets de la navbar),
     - padding-left réservé sur #main-nav pour que le titre/onglets ne passent pas
       sous le hamburger SaaS.
     Scope strictement limité à `:has(.saas-custom-embed)` pour ne rien changer ailleurs. — */
@media (max-width: 768px) {
	body.capwise-saas:has(.saas-custom-embed) .saas-mobile-logo {
		display: none;
	}
	/* La navbar du use case (#main-nav, fixed-top) joue déjà le rôle de barre
	   d'en-tête : on supprime notre ::before SaaS pour laisser apparaître le
	   hamburger d'onglets de la navbar à droite. */
	body.capwise-saas:has(.saas-custom-embed)::before {
		display: none;
	}
	/* Annule le `left: 260px` desktop (cf. règle .saas-custom-embed #main-nav.fixed-top
	   plus haut) qui aligne la navbar sur la sidebar fixe — sur mobile la sidebar
	   est en drawer, la navbar doit reprendre toute la largeur. */
	body.capwise-saas:has(.saas-custom-embed) #main-nav.fixed-top {
		left: 0;
		right: 0;
		width: auto;
	}
	/* Réserve la place du hamburger SaaS (top:8 left:8, 40px) à gauche du titre.
	   `!important` nécessaire pour écraser `.px-3` de Bootstrap (utility class avec !important). */
	body.capwise-saas:has(.saas-custom-embed) #main-nav .container-fluid {
		padding-left: 56px !important;
	}
	/* Titre centré entre les deux hamburgers : on annule le `text-start` que
	   render_header applique en mode `from_saas`. */
	body.capwise-saas:has(.saas-custom-embed) #main-nav .container-fluid > span.text-start {
		text-align: center !important;
	}
	/* Padding latéral du contenu use case revu pour mobile (sinon 53px desktop trop large).
	   On aligne sur le padding latéral des pages SaaS natives (20px). */
	body.capwise-saas .saas-custom-embed {
		padding: 48px 20px 22px;
	}
	/* Annule le pattern responsive `display:block + overflow-x:auto` que le SaaS
	   applique à toutes les `.saas-content .table` sur mobile (cf. règle plus haut).
	   Dans un use case custom embed, les `.table` sont des composants UI (récap form,
	   etc.), pas des tableaux de data — on restaure le rendu table normal pour qu'ils
	   suivent le centrage de leur col Bootstrap. */
	body.capwise-saas .saas-content .saas-custom-embed .table {
		display: table;
		width: 100%;
	}
	body.capwise-saas .saas-content .saas-custom-embed .table th,
	body.capwise-saas .saas-content .saas-custom-embed .table td {
		white-space: normal;
	}
}

/* ─────────────────────────────────────────────────────────────────────────
   Scroll-hint : bouton flottant bas-centre sur les pages company longues
   (Cap table, Positions, Analyze). Cliqué → scroll smooth jusqu'en bas.
   Caché via .is-hidden quand on est déjà en bas (logique JS dans la vue).
   ───────────────────────────────────────────────────────────────────────── */
.scroll-hint {
	position: fixed; bottom: 24px;
	left: calc(260px + (100vw - 260px) / 2);
	transform: translateX(-50%);
	width: 52px; height: 52px; border-radius: 50%;
	background: #fff; box-shadow: 0 6px 20px rgba(13,110,253,.16), 0 2px 6px rgba(0,0,0,.08);
	border: 1px solid rgba(13,110,253,.25);
	display: flex; align-items: center; justify-content: center;
	color: #0d6efd; text-decoration: none; z-index: 1050;
	font-size: 1.15rem; cursor: pointer; padding: 0;
	animation: scrollHintBounce 2s infinite;
	transition: opacity .3s ease, box-shadow .15s ease, color .15s ease;
}
.scroll-hint:hover { color: #0a58ca; box-shadow: 0 8px 24px rgba(13,110,253,.22), 0 2px 6px rgba(0,0,0,.1); }
.scroll-hint.is-hidden { opacity: 0; pointer-events: none; }

/* Lien souligné uniquement au survol */
.link-hover-underline { text-decoration: none; }
.link-hover-underline:hover { text-decoration: underline; }
@keyframes scrollHintBounce {
	0%, 100% { transform: translateX(-50%) translateY(0); }
	50%      { transform: translateX(-50%) translateY(-6px); }
}
@media (max-width: 991.98px) {
	.scroll-hint { left: 50%; }
}

/* ─────────────────────────────────────────────────────────────────────────
   Modals fullscreen contenus dans la zone content (la sidebar reste visible
   et non dimmée). On bump la sidebar au-dessus du modal-backdrop (1050) et
   du modal (1055), et on contraint la largeur du modal-fullscreen pour qu'il
   commence après la sidebar.
   ───────────────────────────────────────────────────────────────────────── */
.saas-sidebar { z-index: 1060; }
@media (min-width: 769px) {
	body.saas-sidebar-rail .saas-sidebar { z-index: 1060; }
}

.modal-fullscreen.modal-saas-content {
	width: calc(100vw - 260px);
	margin-left: 260px;
}
/* Le toggle de la sidebar dépasse de ~11px sur la zone content : on pousse
   le header pour ne pas coller le titre au cercle. */
.modal-fullscreen.modal-saas-content .modal-header { padding-left: 2.5rem; }
@media (min-width: 769px) {
	body.saas-sidebar-rail .modal-fullscreen.modal-saas-content {
		width: calc(100vw - 48px);
		margin-left: 48px;
	}
}
@media (max-width: 768px) {
	.modal-fullscreen.modal-saas-content {
		width: 100vw;
		margin-left: 0;
	}
}
/* Lock le scroll racine quand un modal Bootstrap est ouvert : Bootstrap pose
   overflow:hidden sur body uniquement, mais la scrollbar peut être rendue sur
   <html> (selon flux), et le wrapper .modal a aussi son propre overflow-y:auto
   qui peut produire une 2e barre en mode fullscreen. */
html:has(body.modal-open) { overflow: hidden !important; }
body.modal-open { overflow: hidden !important; }
.modal.show:has(.modal-saas-content) { overflow: hidden !important; }

/* Vue super admin /admin/companies : étiquette org dans le header de card. */
.cw-cc-org-tag {
	flex: 0 0 auto;
	margin-left: auto;
	padding-left: 8px;
	font-family: "JetBrains Mono", "Courier New", Courier, monospace;
	font-weight: 500;
	font-size: 0.78rem;
	color: #1f4e8c;
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
	max-width: 50%;
}
.cw-cc-org-tag .bi { opacity: 0.9; }

/* Badge custom use cases déplacé dans le body de la card sur /admin/companies
   (le header concentre déjà nom company + nom org). Aligné en haut à droite,
   à la hauteur du label "Cap table" / "Custom use cases" de la 1re section. */
.cw-cc-body { position: relative; }
.cw-cc-custom-badge-floating {
	position: absolute;
	top: 1rem;
	right: 1rem;
	margin: 0;
	z-index: 1;
}
