/**
 * PCM Reservation Form Styles
 *
 * @package PCM_Events_Manager
 */

/* Variables for easy theming */
:root {
	--pcm-primary: #2c3e50;
	--pcm-success: #27ae60;
	--pcm-error: #e74c3c;
	--pcm-warning: #f39c12;
	--pcm-info: #3498db;
	--pcm-border: #ddd;
	--pcm-bg-light: #f9f9f9;
	--pcm-text: #333;
	--pcm-text-light: #666;
	--pcm-radius: 4px;
}

/* Form Layout */
.pcm-reservation-form {
	max-width: 720px;
}

.pcm-reservation-form fieldset {
	border: 1px solid var(--pcm-border);
	border-radius: var(--pcm-radius);
	padding: 1.5em;
	margin-bottom: 1.5em;
}

.pcm-reservation-form legend {
	font-weight: 600;
	font-size: 1.1em;
	padding: 0 0.5em;
	color: var(--pcm-primary);
}

.pcm-reservation-form label {
	display: block;
	margin-bottom: 0.25em;
	font-weight: 500;
	color: var(--pcm-text);
}

.pcm-reservation-form input[type="text"],
.pcm-reservation-form input[type="email"],
.pcm-reservation-form input[type="tel"],
.pcm-reservation-form input[type="number"],
.pcm-reservation-form input[type="date"],
.pcm-reservation-form input[type="time"],
.pcm-reservation-form textarea,
.pcm-reservation-form select {
	width: 100%;
	padding: 0.5em;
	border: 1px solid var(--pcm-border);
	border-radius: var(--pcm-radius);
	font-size: 1em;
	box-sizing: border-box;
}

.pcm-reservation-form textarea {
	resize: vertical;
}

.pcm-form-row {
	margin-bottom: 1em;
}

.pcm-form-row-inline {
	display: flex;
	gap: 1em;
}

.pcm-form-row-inline > div {
	flex: 1;
}

.pcm-form-checkbox {
	display: flex;
	align-items: center;
	gap: 0.5em;
}

.pcm-form-checkbox input {
	width: auto;
}

.pcm-form-checkbox label {
	display: inline;
	margin-bottom: 0;
	font-weight: normal;
}

/* Equipment checkboxes grid */
.pcm-equipment-grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(150px, 1fr));
	gap: 0.5em;
}

/* Submit button */
.pcm-reservation-form .pcm-submit-btn {
	background: var(--pcm-primary);
	color: #fff;
	border: none;
	padding: 0.75em 2em;
	font-size: 1em;
	border-radius: var(--pcm-radius);
	cursor: pointer;
	transition: background 0.2s;
}

.pcm-reservation-form .pcm-submit-btn:hover {
	background: #1a252f;
}

.pcm-reservation-form .pcm-submit-btn:disabled {
	background: #999;
	cursor: not-allowed;
}

/* Messages */
.pcm-form-messages {
	margin-bottom: 1em;
}

.pcm-message {
	padding: 1em;
	border-radius: var(--pcm-radius);
	margin-bottom: 1em;
}

.pcm-message-success {
	background: #d4edda;
	color: #155724;
	border: 1px solid #c3e6cb;
}

.pcm-message-error {
	background: #f8d7da;
	color: #721c24;
	border: 1px solid #f5c6cb;
}

/* Availability indicator */
.pcm-availability-indicator {
	padding: 0.75em;
	margin: 0.5em 0 1em;
	border-radius: var(--pcm-radius);
	font-size: 0.9em;
}

.pcm-checking {
	color: var(--pcm-text-light);
}

.pcm-available {
	color: var(--pcm-success);
	font-weight: 500;
}

.pcm-conflict {
	color: var(--pcm-error);
	font-weight: 500;
}

.pcm-availability-indicator ul {
	margin: 0.5em 0 0 1.5em;
	padding: 0;
}

.pcm-error {
	color: var(--pcm-warning);
}

/* Status badges */
.pcm-status-badge {
	display: inline-block;
	padding: 0.25em 0.75em;
	border-radius: 12px;
	font-size: 0.85em;
	font-weight: 500;
	text-transform: capitalize;
}

.pcm-status-draft { background: #e9ecef; color: #495057; }
.pcm-status-submitted { background: #cce5ff; color: #004085; }
.pcm-status-pending_review,
.pcm-status-pending { background: #fff3cd; color: #856404; }
.pcm-status-approved { background: #d1ecf1; color: #0c5460; }
.pcm-status-confirmed { background: #d4edda; color: #155724; }
.pcm-status-completed { background: #d4edda; color: #155724; }
.pcm-status-denied { background: #f8d7da; color: #721c24; }
.pcm-status-cancelled { background: #e2e3e5; color: #383d41; }
.pcm-status-expired { background: #e2e3e5; color: #6c757d; }

/* My Reservations table */
.pcm-my-reservations table {
	width: 100%;
	border-collapse: collapse;
}

.pcm-my-reservations th,
.pcm-my-reservations td {
	padding: 0.75em;
	text-align: left;
	border-bottom: 1px solid var(--pcm-border);
}

.pcm-my-reservations th {
	background: var(--pcm-bg-light);
	font-weight: 600;
}

.pcm-cancel-reservation {
	background: none;
	border: 1px solid var(--pcm-error);
	color: var(--pcm-error);
	padding: 0.25em 0.75em;
	border-radius: var(--pcm-radius);
	cursor: pointer;
	font-size: 0.85em;
}

.pcm-cancel-reservation:hover {
	background: var(--pcm-error);
	color: #fff;
}

/* Availability list */
.pcm-availability-list {
	list-style: none;
	padding: 0;
}

.pcm-availability-list li {
	padding: 0.75em;
	border-bottom: 1px solid var(--pcm-border);
	display: flex;
	align-items: center;
	gap: 1em;
}

.pcm-availability-list .pcm-slot-date {
	font-weight: 600;
	min-width: 120px;
}

.pcm-availability-list .pcm-slot-time {
	color: var(--pcm-text-light);
	min-width: 100px;
}

/* Login prompt */
.pcm-login-required {
	padding: 2em;
	text-align: center;
	background: var(--pcm-bg-light);
	border: 1px solid var(--pcm-border);
	border-radius: var(--pcm-radius);
}

/* Required field indicator */
.pcm-required {
	color: var(--pcm-error);
}

/* Responsive */
@media (max-width: 600px) {
	.pcm-form-row-inline {
		flex-direction: column;
		gap: 0;
	}

	.pcm-equipment-grid {
		grid-template-columns: 1fr;
	}
}
