/* Boutons */
.btn {
	background: var(--btn-bg);
	color: var(--btn-text);
	border: none;
	padding: 6px 12px;
	border-radius: 4px;
	cursor: pointer;
	font-size: 12px;
	transition: background 0.2s;
}

.btn:hover {
	background: var(--btn-hover-bg);
}

.btn.danger {
	background: var(--btn-danger-bg);
}
.btn.danger:hover {
	background: var(--btn-danger-hover-bg);
}

.btn.success {
	background: var(--btn-success-bg);
}
.btn.success:hover {
	background: var(--btn-success-hover-bg);
}
.btn:disabled {
	background-color: #6c757d;
	border-color: #6c757d;
	opacity: 0.65;
	cursor: not-allowed;
}
body.light-theme .btn:disabled {
	background-color: #adb5bd;
	border-color: #adb5bd;
}

/* Header */
.header span, .header label {
	color: var(--text-color);
}
.project-selector {
	display: flex;
	align-items: center;
	gap: 10px;
}
.project-select {
	background: var(--input-bg);
	color: var(--text-color);
	border: 1px solid var(--input-border);
	padding: 5px 10px;
	border-radius: 4px;
	font-size: 14px;
}
body.light-theme .project-select:focus {
	border-color: var(--input-focus-border);
	box-shadow: 0 0 0 0.2rem rgba(0,122,204,.25);
}
.header-actions {
	display: flex;
	gap: 10px;
	align-items: center;
}

/* Sidebar Header & Search */
.sidebar-header {
	padding: 10px 15px;
	background: var(--sidebar-header-bg);
	border-bottom: 1px solid var(--sidebar-border);
	font-weight: bold;
	text-transform: uppercase;
	font-size: 12px;
	letter-spacing: 1px;
	display: flex;
	justify-content: space-between;
	align-items: center;
	min-height: 40px;
}
.sidebar-header span {
	color: var(--text-color);
}
.sidebar-header-buttons {
	display: flex;
	gap: 5px;
}
.search-container {
	padding: 10px 15px;
	background: var(--sidebar-header-bg);
	border-bottom: 1px solid var(--sidebar-border);
}
.search-input {
	width: 100%;
	padding: 6px 10px;
	background: var(--input-bg);
	border: 1px solid var(--input-border);
	color: var(--text-color);
	border-radius: 4px;
	font-size: 12px;
}
.search-input:focus {
	outline: none;
	border-color: var(--input-focus-border);
}
body.light-theme .search-input:focus {
	box-shadow: 0 0 0 0.2rem rgba(0,122,204,.25);
}


/* Fil d'Ariane */
.breadcrumb {
	padding: 8px 15px;
	background: var(--breadcrumb-bg);
	border-bottom: 1px solid var(--sidebar-border);
	font-size: 12px;
	display: flex;
	align-items: center;
	gap: 5px;
}
.breadcrumb-item {
	color: var(--breadcrumb-text);
	cursor: default;
}
.breadcrumb-separator {
	color: var(--breadcrumb-separator);
}

/* Onglets */
.tabs-container {
	background: var(--header-bg);
	border-bottom: 1px solid var(--header-border);
	display: flex;
	overflow-x: auto;
	min-height: 40px;
	flex-shrink: 0;
}
.tab {
	padding: 10px 15px;
	background: var(--tab-bg);
	border-right: 1px solid var(--tab-border);
	cursor: pointer;
	display: flex;
	align-items: center;
	min-width: 120px;
	max-width: 180px;
	font-size: 13px;
	position: relative;
	white-space: nowrap;
	color: var(--text-color);
}
.tab.active {
	background: var(--tab-active-bg);
	font-weight: bold;
}
body.light-theme .tab.active {
	color: #005a9e;
}
.tab-name {
	flex: 1;
	overflow: hidden;
	text-overflow: ellipsis;
}
.tab-close {
	margin-left: 10px;
	width: 16px;
	height: 16px;
	display: flex;
	align-items: center;
	justify-content: center;
	border-radius: 3px;
	font-size: 12px;
	opacity: 0.7;
	flex-shrink: 0;
	color: var(--text-color);
}
.tab-close:hover {
	background: #e74c3c;
	color: white;
	opacity: 1;
}

/* Barre de statut */
.status-bar {
	background: var(--status-bar-bg);
	color: var(--status-bar-text);
	padding: 5px 15px;
	font-size: 12px;
	display: flex;
	justify-content: space-between;
	align-items: center;
	height: 40px;
	flex-shrink: 0;
}

/* Menu contextuel */
.context-menu {
	position: fixed;
	background: var(--context-menu-bg);
	border: 1px solid var(--context-menu-border);
	border-radius: 4px;
	box-shadow: 0 4px 12px rgba(0,0,0,0.15);
	z-index: 10000;
	min-width: 180px;
	display: none;
	padding: 5px 0;
}
.context-menu-item {
	padding: 8px 15px;
	cursor: pointer;
	font-size: 13px;
	color: var(--text-color);
}
.context-menu hr {
	border: none;
	border-top: 1px solid var(--context-menu-border);
	margin: 4px 0;
}
.context-menu-item:hover {
	background: var(--context-menu-hover-bg);
}
body.light-theme .context-menu-item:hover {
	color: #005a9e;
}

/* Écran d'accueil */
.welcome-screen {
	display: flex;
	align-items: center;
	justify-content: center;
	height: 100%;
	flex-direction: column;
	text-align: center;
	color: var(--welcome-text);
	padding: 20px;
}
.welcome-screen h1 {
	font-size: 28px;
	margin-bottom: 20px;
	color: var(--welcome-heading);
}
.welcome-screen p {
	font-size: 14px;
	margin-bottom: 10px;
	line-height: 1.6;
}
.welcome-screen strong {
	color: var(--welcome-heading);
}