/* ========================================
   FORMS
   ======================================== */

.form-control {
	background: var(--bg-elevated) !important;
	border: 1px solid var(--border-light) !important;
	border-radius: var(--radius-md) !important;
	color: var(--text-primary) !important;
	padding: 0.75rem 1rem !important;
	font-size: 0.9rem;
	transition: all var(--transition-fast);
}

.form-control:focus {
	background: var(--bg-elevated) !important;
	border-color: var(--accent-primary) !important;
	box-shadow: 0 0 0 3px rgba(0, 255, 136, 0.15) !important;
	outline: none;
}

.form-control::placeholder {
	color: var(--text-muted);
}

.form-check-input {
	background-color: var(--bg-elevated) !important;
	border-color: var(--border-light) !important;
	width: 1.15em;
	height: 1.15em;
}

.form-check-input:checked {
	background-color: var(--accent-primary) !important;
	border-color: var(--accent-primary) !important;
}

.form-check-input:focus {
	box-shadow: 0 0 0 3px rgba(0, 255, 136, 0.15) !important;
}

.form-check-label {
	color: var(--text-secondary);
	font-size: 0.9rem;
}

.form-label {
	color: var(--text-secondary);
	font-size: 0.85rem;
	font-weight: 500;
	margin-bottom: 0.5rem;
}

/* Dark mode select dropdown - global */
.form-select {
	background-color: var(--bg-tertiary);
	color: var(--text-primary);
	border: 1px solid var(--border-primary);
	border-radius: var(--radius-md);
	padding: 0.6rem 1rem;
}

.form-select:focus {
	background-color: var(--bg-tertiary);
	color: var(--text-primary);
	border-color: var(--accent-primary);
	box-shadow: 0 0 0 2px rgba(0, 255, 136, 0.15);
	outline: none;
}

.form-select option {
	background-color: var(--bg-secondary);
	color: var(--text-primary);
}

/* ========================================
   BLOCK MODAL FORM
   ======================================== */

.form-section {
	margin-bottom: 1rem;
}

.form-row {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 1rem;
}

@media (max-width: 576px) {
	.form-row {
		grid-template-columns: 1fr;
		/* Ensure stacked items use the grid gap only — remove extra bottom
		   margins from child sections so spacing is consistent */
		gap: 1rem;
	}

	.form-row > * {
		margin-bottom: 0;
	}
}

.roles-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(100px, 1fr));
	gap: 0.75rem;
}

.role-input {
	display: flex;
	flex-direction: column;
	gap: 0.35rem;
}

.role-input label {
	font-size: 0.8rem;
	color: var(--text-muted);
	font-weight: 500;
}

.role-input input {
	text-align: center;
}

/* ========================================
   AUTH & ROLES FORMS
   ======================================== */

.roles-checkbox-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(120px, 1fr));
	gap: 0.5rem;
}

.role-checkbox {
	padding: 0.75rem;
	background: var(--bg-elevated);
	border: 1px solid var(--border-color);
	border-radius: var(--radius-sm);
	transition: all var(--transition-fast);
}

.role-checkbox:has(input:checked) {
	border-color: var(--accent-primary);
	background: rgba(0, 255, 136, 0.05);
}

/* Role Checkbox Card (for admin edit roles) */
.role-checkbox-card {
	display: flex;
	align-items: center;
	gap: 0.75rem;
	padding: 0.75rem 1rem;
	background: var(--bg-elevated);
	border: 1px solid var(--border-color);
	border-radius: var(--radius-sm);
	cursor: pointer;
	transition: all var(--transition-fast);
	user-select: none;
}

.role-checkbox-card:hover {
	background: var(--bg-tertiary);
	border-color: var(--border-light);
}

.role-checkbox-card.selected {
	border-color: var(--accent-primary);
	background: rgba(0, 255, 136, 0.1);
}

.role-checkbox-indicator {
	width: 20px;
	height: 20px;
	border: 2px solid var(--border-color);
	border-radius: 4px;
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
	transition: all var(--transition-fast);
}

.role-checkbox-card.selected .role-checkbox-indicator {
	background: var(--accent-primary);
	border-color: var(--accent-primary);
}

.role-checkbox-card.selected .role-checkbox-indicator::after {
	content: "✓";
	color: var(--bg-primary);
	font-size: 12px;
	font-weight: bold;
}

.role-checkbox-name {
	font-size: 0.95rem;
	color: var(--text-primary);
}

.error-message {
	color: var(--accent-danger);
	font-size: 0.85rem;
	margin-top: 1rem;
	text-align: center;
}

.error-message:empty {
	display: none;
}

.success-message {
	color: var(--accent-success);
	font-size: 0.85rem;
	margin-top: 1rem;
	text-align: center;
}

.success-message:empty {
	display: none;
}

.forgot-password-link,
.back-to-login {
	text-align: center;
	margin-top: 1rem;
	font-size: 0.9rem;
}

.forgot-password-link a,
.back-to-login a {
	color: var(--accent-primary);
	text-decoration: none;
	transition: color 0.2s ease;
}

.forgot-password-link a:hover,
.back-to-login a:hover {
	color: var(--accent-secondary);
	text-decoration: underline;
}

/* ========================================
   ADMIN TOGGLE SWITCH
   ======================================== */

.admin-toggle-label {
	display: flex;
	align-items: center;
	gap: 0.75rem;
	cursor: pointer;
	padding: 0.75rem 1rem;
	background: var(--bg-tertiary);
	border: 1px solid var(--border-primary);
	border-radius: 8px;
	transition: all 0.2s ease;
}

.admin-toggle-label:hover {
	border-color: var(--border-secondary);
}

.admin-toggle-label input {
	display: none;
}

.admin-toggle-switch {
	position: relative;
	width: 44px;
	height: 24px;
	background: var(--bg-secondary);
	border-radius: 12px;
	transition: all 0.2s ease;
	flex-shrink: 0;
}

.admin-toggle-switch::after {
	content: "";
	position: absolute;
	top: 2px;
	left: 2px;
	width: 20px;
	height: 20px;
	background: var(--text-muted);
	border-radius: 50%;
	transition: all 0.2s ease;
}

.admin-toggle-label input:checked + .admin-toggle-switch {
	background: var(--accent-primary);
}

.admin-toggle-label input:checked + .admin-toggle-switch::after {
	left: 22px;
	background: white;
}

.admin-toggle-text {
	font-weight: 500;
	color: var(--text-primary);
}

/* ========================================
   CLICKABLE CHECKBOXES
   ======================================== */

.clickable-checkbox {
	display: flex;
	align-items: center;
	padding: 0.5rem 0.75rem;
	margin: 0.25rem 0;
	background: var(--bg-tertiary);
	border: 1px solid var(--border-primary);
	border-radius: 8px;
	cursor: pointer;
	transition: all 0.2s ease;
}

.clickable-checkbox:hover {
	background: var(--bg-elevated);
	border-color: var(--border-secondary);
}

.clickable-checkbox input[type="checkbox"] {
	width: 18px;
	height: 18px;
	margin-right: 0.75rem;
	accent-color: var(--accent-primary);
	cursor: pointer;
	flex-shrink: 0;
}

.clickable-checkbox label {
	margin: 0;
	cursor: pointer;
	flex: 1;
	font-size: 0.95rem;
	color: var(--text-primary);
}

/* ========================================
   ADMIN FORM CONTROLS
   ======================================== */

.admin-form-group {
	margin-bottom: 0.875rem;
}

.admin-form-group:last-child {
	margin-bottom: 0;
}

.admin-label {
	display: block;

	font-size: 0.8rem;
	font-weight: 500;
	color: var(--text-muted);
	margin-bottom: 0.4rem;
}

.admin-optional {
	font-weight: 400;
	opacity: 0.7;
}

.admin-input,
.admin-select {
	width: 100%;
	padding: 0.6rem 0.875rem;
	background: var(--bg-primary);
	border: 1px solid var(--border-primary);
	border-radius: 8px;
	color: var(--text-primary);
	font-size: 0.9rem;
	transition: all 0.2s ease;
}

/* Time selects grouped inline (24h UI) */
.admin-time-select {
	display: flex;
	align-items: center;
	gap: 0.5rem;
}
.admin-time-select .admin-input {
	width: auto; /* override full-width */
	min-width: 64px;
	padding: 0.5rem 0.625rem;
}
.admin-time-select .time-colon {
	display: inline-block;
	color: var(--text-muted);
	font-weight: 600;
}

.admin-input:focus,
.admin-select:focus {
	outline: none;
	border-color: var(--accent-primary);
	box-shadow: 0 0 0 3px rgba(34, 197, 94, 0.15);
}

.admin-textarea {
	resize: vertical;
	min-height: 60px;
}

/* Custom place dropdown */
.admin-place-dropdown {
	position: relative;
}

.admin-place-selected {
	width: 100%;
	padding: 0.6rem 0.875rem;
	background: var(--bg-primary);
	border: 1px solid var(--border-primary);
	border-radius: 8px;
	color: var(--text-primary);
	font-size: 0.9rem;
	cursor: pointer;
	display: flex;
	align-items: center;
	gap: 0.5rem;
	transition: all 0.2s ease;
}

.admin-place-selected:hover {
	border-color: var(--border-secondary);
}

.admin-place-dropdown.open .admin-place-selected {
	border-color: var(--accent-primary);
	box-shadow: 0 0 0 3px rgba(34, 197, 94, 0.15);
}

.admin-place-selected .place-name {
	flex: 1;
	text-align: left;
}

.admin-place-selected i {
	transition: transform 0.2s ease;
	opacity: 0.6;
}

.admin-place-dropdown.open .admin-place-selected i {
	transform: rotate(180deg);
}

.place-color-dot {
	width: 12px;
	height: 12px;
	border-radius: 50%;
	flex-shrink: 0;
}

.admin-place-options {
	position: absolute;
	top: 100%;
	left: 0;
	right: 0;
	margin-top: 4px;
	background: var(--bg-card);
	border: 1px solid var(--border-primary);
	border-radius: 8px;
	box-shadow: 0 10px 25px rgba(0, 0, 0, 0.3);
	z-index: 100;
	opacity: 0;
	visibility: hidden;
	transform: translateY(-8px);
	transition: all 0.2s ease;
}

.admin-place-dropdown.open .admin-place-options {
	opacity: 1;
	visibility: visible;
	transform: translateY(0);
}

.admin-place-option {
	display: flex;
	align-items: center;
	gap: 0.5rem;
	padding: 0.6rem 0.875rem;
	cursor: pointer;
	transition: background 0.15s ease;
}

.admin-place-option:first-child {
	border-radius: 7px 7px 0 0;
}

.admin-place-option:last-child {
	border-radius: 0 0 7px 7px;
}

.admin-place-option:hover {
	background: var(--bg-elevated);
}

.admin-place-option span:last-child {
	font-weight: 500;
}

/* Custom type dropdown */
.admin-type-dropdown {
	position: relative;
}

.admin-type-selected {
	width: 100%;
	padding: 0.6rem 0.875rem;
	background: var(--bg-primary);
	border: 1px solid var(--border-primary);
	border-radius: 8px;
	color: var(--text-primary);
	font-size: 0.9rem;
	cursor: pointer;
	display: flex;
	align-items: center;
	gap: 0.5rem;
	transition: all 0.2s ease;
}

.admin-type-selected:hover {
	border-color: var(--border-secondary);
}

.admin-type-dropdown.open .admin-type-selected {
	border-color: var(--accent-primary);
	box-shadow: 0 0 0 3px rgba(34, 197, 94, 0.15);
}

.admin-type-selected .type-name {
	flex: 1;
	text-align: left;
}

.admin-type-selected > i:last-child {
	transition: transform 0.2s ease;
	opacity: 0.6;
}

.admin-type-dropdown.open .admin-type-selected > i:last-child {
	transform: rotate(180deg);
}

.type-icon {
	font-size: 1rem;
	opacity: 0.8;
}

/* Type-specific icon colors in dropdown */
.admin-type-option[data-value="směna"] .type-icon,
.admin-type-selected .type-icon.bi-clock {
	color: #3b82f6;
}

.admin-type-option[data-value="promítání"] .type-icon,
.admin-type-selected .type-icon.bi-film {
	color: #a855f7;
}

.admin-type-option[data-value="pro školy"] .type-icon,
.admin-type-selected .type-icon.bi-mortarboard {
	color: #f59e0b;
}

.admin-type-option[data-value="speciální"] .type-icon,
.admin-type-selected .type-icon.bi-star {
	color: #f59e0b;
}

.admin-type-option[data-value="seniorské"] .type-icon,
.admin-type-selected .type-icon.bi-heart {
	color: #ec4899;
}

.admin-type-options {
	position: absolute;
	top: 100%;
	left: 0;
	right: 0;
	margin-top: 4px;
	background: var(--bg-card);
	border: 1px solid var(--border-primary);
	border-radius: 8px;
	box-shadow: 0 10px 25px rgba(0, 0, 0, 0.3);
	z-index: 100;
	opacity: 0;
	visibility: hidden;
	transform: translateY(-8px);
	transition: all 0.2s ease;
}

.admin-type-dropdown.open .admin-type-options {
	opacity: 1;
	visibility: visible;
	transform: translateY(0);
}

/* Disable entrance transitions for dropdowns during initial page load.
   JS will toggle `data-no-entrance` briefly while removing the loading overlay. */
body[data-no-entrance="true"] .admin-place-options,
body[data-no-entrance="true"] .admin-type-options,
body[data-no-entrance="true"] .admin-place-selected,
body[data-no-entrance="true"] .admin-type-selected {
	transition: none !important;
	animation: none !important;
}

.admin-type-option {
	display: flex;
	align-items: center;
	gap: 0.5rem;
	padding: 0.6rem 0.875rem;
	cursor: pointer;
	transition: background 0.15s ease;
}

.admin-type-option:first-child {
	border-radius: 7px 7px 0 0;
}

.admin-type-option:last-child {
	border-radius: 0 0 7px 7px;
}

.admin-type-option:hover {
	background: var(--bg-elevated);
}

.admin-type-option span {
	font-weight: 500;
}

.admin-input::placeholder {
	color: var(--text-muted);
	opacity: 0.6;
}

.admin-form-row {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 0.75rem;
}

@media (max-width: 576px) {
	.admin-form-row {
		grid-template-columns: 1fr;
		/* rely on grid gap for vertical spacing */
		gap: 0.75rem;
	}

	/* remove individual bottom margins so stacked items use uniform gap */
	.admin-form-row > * {
		margin-bottom: 0;
	}

	/* ensure the whole collapsed row separates from following fields */
	.admin-form-row {
		margin-bottom: 0.875rem;
	}
}

.admin-datetime-grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 1rem;
}

.admin-datetime-group {
	min-width: 0;
}

.admin-datetime-row {
	display: flex;
	flex-direction: column;
	gap: 0.5rem;
}

.admin-date,
.admin-time {
	width: 100%;
}

.admin-date {
	color-scheme: dark;
}

.admin-date::-webkit-calendar-picker-indicator {
	filter: none;
	opacity: 1;
	background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='%23ffffff'%3E%3Cpath d='M19 4h-1V2h-2v2H8V2H6v2H5c-1.1 0-2 .9-2 2v13c0 1.1.9 2 2 2h14c1.1 0 2-.9 2-2V6c0-1.1-.9-2-2-2zm0 15H5V10h14v9zm0-11H5V6h14v2z'/%3E%3C/svg%3E")
		center/1rem 1rem no-repeat;
	color: transparent;
	cursor: pointer;
}

/* Role capacity controls */
.admin-roles-grid {
	display: flex;
	flex-direction: column;
	gap: 0.5rem;
}

.admin-role-capacity {
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: 0.5rem 0.75rem;
	background: var(--bg-primary);
	border-radius: 8px;
	border: 1px solid var(--border-primary);
}

.admin-role-label {
	font-size: 0.9rem;
	font-weight: 500;
	color: var(--text-primary);
}

.admin-capacity-control {
	display: flex;
	align-items: center;
	gap: 0.25rem;
}

.admin-capacity-btn {
	width: 32px;
	height: 32px;
	border: none;
	background: var(--bg-secondary);
	border-radius: 6px;
	color: var(--text-primary);
	cursor: pointer;
	display: flex;
	align-items: center;
	justify-content: center;
	transition: all 0.15s ease;
}

.admin-capacity-btn:hover {
	background: var(--accent-primary);
	color: white;
}

.admin-capacity-btn:active {
	transform: scale(0.95);
}

.admin-capacity-input {
	width: 40px;
	height: 32px;
	text-align: center;
	border: none;
	background: transparent;
	color: var(--text-primary);
	font-size: 0.95rem;
	font-weight: 600;
}

.admin-capacity-input::-webkit-inner-spin-button,
.admin-capacity-input::-webkit-outer-spin-button {
	-webkit-appearance: none;
	margin: 0;
}
