/**
 * Occupancy Feature Styles
 *
 * Styles for the real-time occupancy tracking feature
 *
 * @package    Gay_Sauna_Guide
 * @subpackage Gay_Sauna_Guide/public/css
 * @since      1.23.0
 */

/* ========================================
   Dashboard Quick Update Widget
   ======================================== */

.gsg-occupancy-quick-update {
	margin-top: 1.5rem;
	padding: 1.25rem;
	background: linear-gradient(135deg, #3ECFC4 0%, #35CCBD 100%);
	border-radius: 8px;
	box-shadow: 0 4px 12px rgba(62, 207, 196, 0.3);
}

.gsg-occupancy-quick-update__title {
	margin: 0 0 1rem 0;
	font-size: 1rem;
	font-weight: 700;
	color: #ffffff;
	text-transform: uppercase;
	letter-spacing: 0.5px;
	display: flex;
	align-items: center;
	gap: 0.5rem;
}

.gsg-occupancy-quick-update__title i {
	font-size: 1.2rem;
}

.gsg-occupancy-quick-update__display {
	background: rgba(255, 255, 255, 0.2);
	border-radius: 6px;
	padding: 1rem;
	margin-bottom: 1rem;
	text-align: center;
}

.gsg-occupancy-quick-update__count {
	display: block;
	font-size: 3rem;
	font-weight: 800;
	color: #ffffff;
	line-height: 1;
	margin-bottom: 0.5rem;
	text-shadow: 0 2px 8px rgba(0, 0, 0, 0.2);
}

.gsg-occupancy-quick-update__time {
	display: block;
	font-size: 0.875rem;
	color: rgba(255, 255, 255, 0.9);
	font-weight: 500;
}

.gsg-occupancy-quick-update__controls {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 0.5rem;
}

.gsg-occupancy-quick-update .gsg-occupancy-btn,
button.gsg-occupancy-btn {
	background: rgba(255, 255, 255, 0.95) !important;
	color: #35CCBD !important;
	border: none !important;
	border-radius: 6px !important;
	padding: 0.875rem 0.5rem !important;
	font-size: 1.125rem !important;
	font-weight: 700 !important;
	cursor: pointer !important;
	transition: all 0.2s ease !important;
	box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1) !important;
	line-height: 1 !important;
	text-transform: none !important;
	letter-spacing: normal !important;
}

.gsg-occupancy-quick-update .gsg-occupancy-btn:hover:not(:disabled),
button.gsg-occupancy-btn:hover:not(:disabled) {
	background: #ffffff !important;
	transform: translateY(-2px) !important;
	box-shadow: 0 4px 8px rgba(0, 0, 0, 0.15) !important;
}

.gsg-occupancy-quick-update .gsg-occupancy-btn:active:not(:disabled),
button.gsg-occupancy-btn:active:not(:disabled) {
	transform: translateY(0) !important;
}

.gsg-occupancy-quick-update .gsg-occupancy-btn:disabled,
button.gsg-occupancy-btn:disabled {
	opacity: 0.5 !important;
	cursor: not-allowed !important;
}

.gsg-occupancy-quick-update .gsg-occupancy-btn--decrement,
button.gsg-occupancy-btn--decrement {
	color: #FF6B6B !important;
}

.gsg-occupancy-quick-update .gsg-occupancy-btn--increment,
button.gsg-occupancy-btn--increment {
	color: #4CAF50 !important;
}

.gsg-occupancy-quick-update .gsg-occupancy-btn--set,
button.gsg-occupancy-btn--set {
	color: #3ECFC4 !important;
	font-weight: 800 !important;
}

.gsg-occupancy-quick-update__exact {
	margin-top: 1rem;
	padding-top: 1rem;
	border-top: 1px solid rgba(255, 255, 255, 0.2);
}

.gsg-occupancy-quick-update__exact-label {
	display: block;
	font-size: 0.875rem;
	color: rgba(255, 255, 255, 0.9);
	font-weight: 600;
	margin-bottom: 0.5rem;
}

.gsg-occupancy-quick-update__exact-input-group {
	display: grid;
	grid-template-columns: 1fr auto;
	gap: 0.5rem;
}

.gsg-occupancy-exact-input {
	background: rgba(255, 255, 255, 0.95);
	color: #333;
	border: none;
	border-radius: 6px;
	padding: 0.875rem;
	font-size: 1rem;
	font-weight: 600;
	box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
	transition: all 0.2s ease;
}

.gsg-occupancy-exact-input:focus {
	outline: none;
	background: #ffffff;
	box-shadow: 0 4px 8px rgba(0, 0, 0, 0.15);
}

.gsg-occupancy-exact-input::placeholder {
	color: #999;
	font-weight: 500;
}

.gsg-occupancy-quick-update__message {
	margin-top: 0.75rem;
	padding: 0.75rem;
	border-radius: 4px;
	font-size: 0.875rem;
	font-weight: 500;
	text-align: center;
	display: none;
}

.gsg-occupancy-quick-update__message.success {
	display: block;
	background: rgba(76, 175, 80, 0.2);
	color: #ffffff;
	border: 1px solid rgba(76, 175, 80, 0.4);
}

.gsg-occupancy-quick-update__message.error {
	display: block;
	background: rgba(255, 107, 107, 0.2);
	color: #ffffff;
	border: 1px solid rgba(255, 107, 107, 0.4);
}

/* ========================================
   Public Venue Page Display
   ======================================== */

.gsg-occupancy-display {
	display: flex;
	align-items: center;
	gap: 1.5rem;
	padding: 1.5rem;
	margin-bottom: 2rem;
	background: linear-gradient(135deg, #3ECFC4 0%, #35CCBD 100%);
	border-radius: 8px;
	box-shadow: 0 4px 16px rgba(62, 207, 196, 0.3);
	animation: gsg-occupancy-pulse 2s ease-in-out infinite;
	/* Span full width across grid columns */
	grid-column: 1 / -1;
}

@keyframes gsg-occupancy-pulse {
	0%, 100% {
		box-shadow: 0 4px 16px rgba(62, 207, 196, 0.3);
	}
	50% {
		box-shadow: 0 4px 20px rgba(62, 207, 196, 0.5);
	}
}

.gsg-occupancy-display__icon {
	flex-shrink: 0;
	width: 64px;
	height: 64px;
	display: flex;
	align-items: center;
	justify-content: center;
	background: rgba(255, 255, 255, 0.2);
	border-radius: 50%;
	color: #ffffff;
	font-size: 2rem;
}

.gsg-occupancy-display__content {
	flex: 1;
}

.gsg-occupancy-display__count {
	margin-bottom: 0.5rem;
}

.gsg-occupancy-display__number {
	display: inline-block;
	font-size: 2.5rem;
	font-weight: 800;
	color: #ffffff;
	line-height: 1;
	margin-right: 0.75rem;
	text-shadow: 0 2px 8px rgba(0, 0, 0, 0.2);
}

.gsg-occupancy-display__label {
	display: inline-block;
	font-size: 1.125rem;
	font-weight: 600;
	color: #ffffff;
	vertical-align: middle;
}

.gsg-occupancy-display__time {
	font-size: 0.875rem;
	color: rgba(255, 255, 255, 0.9);
	font-weight: 500;
	display: flex;
	align-items: center;
	gap: 0.5rem;
}

.gsg-occupancy-display__time i {
	opacity: 0.8;
}

.gsg-occupancy-display__time span {
	font-weight: 600;
}

/* ========================================
   Responsive Design
   ======================================== */

@media (max-width: 768px) {
	.gsg-occupancy-quick-update {
		padding: 1rem;
	}

	.gsg-occupancy-quick-update__count {
		font-size: 2.5rem;
	}

	.gsg-occupancy-quick-update__controls {
		grid-template-columns: repeat(2, 1fr);
		gap: 0.75rem;
	}

	.gsg-occupancy-quick-update .gsg-occupancy-btn,
	button.gsg-occupancy-btn {
		padding: 1rem !important;
		font-size: 1.25rem !important;
	}

	.gsg-occupancy-quick-update__exact-input-group {
		grid-template-columns: 1fr auto;
	}

	.gsg-occupancy-exact-input {
		font-size: 0.9375rem;
		padding: 0.75rem;
	}

	.gsg-occupancy-display {
		flex-direction: column;
		text-align: center;
		gap: 1rem;
		padding: 1.25rem;
	}

	.gsg-occupancy-display__icon {
		width: 56px;
		height: 56px;
		font-size: 1.75rem;
	}

	.gsg-occupancy-display__number {
		font-size: 2rem;
		margin-right: 0.5rem;
	}

	.gsg-occupancy-display__label {
		font-size: 1rem;
	}

	.gsg-occupancy-display__time {
		justify-content: center;
		font-size: 0.8125rem;
	}
}

@media (max-width: 480px) {
	.gsg-occupancy-quick-update__count {
		font-size: 2rem;
	}

	.gsg-occupancy-display__number {
		font-size: 1.75rem;
		display: block;
		margin-right: 0;
		margin-bottom: 0.25rem;
	}

	.gsg-occupancy-display__label {
		font-size: 0.9375rem;
	}
}
