/* Domineer PWA — Custom Styles */

:root {
	--primary: #1a56db;
	--sidebar-width: 140px;
}

/* Base font size — tighter overall */
body {
	font-size: 0.82rem;
}

/* Navbar */
.navbar {
	padding-top: 0.3rem;
	padding-bottom: 0.3rem;
	min-height: 48px;
}

.navbar-brand {
	font-size: 0.95rem;
}

.navbar .nav-link {
	font-size: 0.8rem;
	padding-top: 0.3rem;
	padding-bottom: 0.3rem;
}

/* Main content padding */
main.flex-grow-1 {
	padding: 0.9rem 1.1rem !important;
}

/* Sidebar */
.sidebar {
	min-height: calc(100vh - 48px);
	position: sticky;
	top: 48px;
	overflow-y: auto;
	min-width: 140px;
	max-width: 140px;
}

.sidebar .nav-link {
	color: #374151;
	border-radius: 5px;
	padding: 4px 10px;
	font-size: 0.78rem;
	transition: background 0.15s;
}

.sidebar .nav-link:hover,
.sidebar .nav-link.active {
	background: #e5edff;
	color: var(--primary);
}

.sidebar .nav-link i {
	width: 16px;
	text-align: center;
}

/* Cards */
.card {
	border-radius: 8px;
}

.card-body {
	padding: 0.75rem;
}

.card-header {
	padding: 0.45rem 0.75rem;
}

/* Tables */
.table th {
	font-size: 0.72rem;
	text-transform: uppercase;
	letter-spacing: 0.03em;
	font-weight: 600;
}

.table td,
.table th {
	padding: 0.32rem 0.5rem;
	font-size: 0.8rem;
}

/* Badges */
.badge {
	font-weight: 500;
	font-size: 0.68em;
}

/* Buttons */
.btn {
	font-size: 0.78rem;
	padding: 0.25rem 0.65rem;
}

.btn-sm {
	font-size: 0.72rem;
	padding: 0.18rem 0.5rem;
}

.btn-lg {
	font-size: 0.88rem;
}

/* Forms */
.form-label {
	font-size: 0.78rem;
	font-weight: 500;
	color: #374151;
	margin-bottom: 2px;
}

.form-control,
.form-select {
	font-size: 0.8rem;
	padding: 0.28rem 0.55rem;
}

.form-control-sm,
.form-select-sm {
	font-size: 0.75rem;
	padding: 0.2rem 0.45rem;
}

.input-group-text {
	font-size: 0.8rem;
	padding: 0.28rem 0.55rem;
}

/* Headings */
h4,
.h4 {
	font-size: 1.1rem;
}

h5,
.h5 {
	font-size: 0.95rem;
}

h6,
.h6 {
	font-size: 0.85rem;
}

/* Dropdowns */
.dropdown-item {
	font-size: 0.8rem;
	padding: 0.28rem 0.9rem;
}

.dropdown-menu {
	font-size: 0.8rem;
}

/* Modals */
.modal-header {
	padding: 0.45rem 0.85rem;
}

.modal-body {
	padding: 0.7rem 0.85rem;
}

.modal-footer {
	padding: 0.45rem 0.85rem;
}

.modal-title {
	font-size: 0.9rem;
}

/* Flash messages */
.alert {
	animation: fadeIn 0.3s ease;
	padding: 0.4rem 0.85rem;
	font-size: 0.8rem;
}

@keyframes fadeIn {
	from {
		opacity: 0;
		transform: translateY(-8px);
	}

	to {
		opacity: 1;
		transform: translateY(0);
	}
}

/* Responsive sidebar collapse on mobile */
@media (max-width: 768px) {
	.sidebar {
		display: none;
	}

	.sidebar.show {
		display: block;
		position: fixed;
		z-index: 1045;
		top: 48px;
		bottom: 0;
		left: 0;
		background: #fff;
		box-shadow: 4px 0 12px rgba(0, 0, 0, 0.1);
		overflow-y: auto;
	}
}

/* Print */
@media print {

	.sidebar,
	nav,
	.btn,
	.alert {
		display: none !important;
	}

	main {
		padding: 0 !important;
	}
}