/**
 * com_xtickets — time-slot wizard styles
 * xart:psp | 2026-05-25 | task 1100
 * Card-based 4-step wizard + calendar grid + slot picker.
 */

.tickets-time-slot {
	--ts-primary:    #1976d2;
	--ts-primary-dk: #115293;
	--ts-success:    #2e7d32;
	--ts-warning:    #ef6c00;
	--ts-info:       #0288d1;
	--ts-danger:     #c62828;
	--ts-muted:      #9e9e9e;
	--ts-border:     #e0e0e0;
	--ts-bg:         #ffffff;
	--ts-bg-alt:     #f7f9fc;
	--ts-shadow:     0 1px 3px rgba(0,0,0,.06);
	--ts-shadow-md:  0 2px 6px rgba(0,0,0,.10);
	--ts-radius:     8px;
	--ts-radius-sm:  4px;
	color: #222;
	font-size: 15px;
}

/* Layout: form column + sticky summary aside on desktop ----------- */
.tickets-time-slot .ts-form { margin-top: 16px; }
.tickets-time-slot .ts-layout { display: grid; grid-template-columns: 1fr 320px; gap: 24px; align-items: start; }
@media (max-width: 991px) { .tickets-time-slot .ts-layout { grid-template-columns: 1fr; } }

/* Stepper -------------------------------------------------------- */
.tickets-time-slot .ts-stepper {
	list-style: none; padding: 0; margin: 0 0 20px 0;
	display: flex; gap: 0; counter-reset: tsstep;
	border-bottom: 1px solid var(--ts-border);
}
.tickets-time-slot .ts-stepper li {
	flex: 1; padding: 12px 8px 14px; text-align: center; position: relative;
	color: var(--ts-muted); font-size: 13px; cursor: default;
	border-bottom: 3px solid transparent; transition: .15s;
}
.tickets-time-slot .ts-stepper li::before {
	counter-increment: tsstep;
	content: counter(tsstep);
	display: inline-flex; align-items: center; justify-content: center;
	width: 26px; height: 26px; border-radius: 50%;
	background: #eceff1; color: #607d8b; font-weight: 600;
	margin-right: 8px; vertical-align: middle; font-size: 13px;
	transition: .15s;
}
.tickets-time-slot .ts-stepper li.is-done::before { background: var(--ts-success); color: #fff; content: "✓"; }
.tickets-time-slot .ts-stepper li.is-active { color: var(--ts-primary); border-bottom-color: var(--ts-primary); font-weight: 600; }
.tickets-time-slot .ts-stepper li.is-active::before { background: var(--ts-primary); color: #fff; }
.tickets-time-slot .ts-stepper li.is-clickable { cursor: pointer; }
.tickets-time-slot .ts-stepper li.is-clickable:hover { color: var(--ts-primary-dk); }

/* Sections (cards) ----------------------------------------------- */
.tickets-time-slot .ts-step { display: none; }
.tickets-time-slot .ts-step.is-active { display: block; animation: tsFade .2s ease; }
@keyframes tsFade { from { opacity: 0; transform: translateY(4px); } to { opacity: 1; transform: none; } }

.tickets-time-slot .ts-section {
	border: 1px solid var(--ts-border); border-radius: var(--ts-radius);
	padding: 18px 20px; margin: 0 0 16px 0;
	background: var(--ts-bg); box-shadow: var(--ts-shadow);
}
.tickets-time-slot .ts-section legend,
.tickets-time-slot .ts-section .ts-section-title {
	font-weight: 600; font-size: 16px; padding: 0 6px;
	color: var(--ts-primary-dk);
}

/* Form fields ---------------------------------------------------- */
.tickets-time-slot .ts-field { margin: 12px 0; display: flex; flex-direction: column; gap: 4px; }
.tickets-time-slot .ts-field label { font-weight: 500; font-size: 14px; color: #455a64; }
.tickets-time-slot .ts-field input[type=text],
.tickets-time-slot .ts-field input[type=email],
.tickets-time-slot .ts-field input[type=tel],
.tickets-time-slot .ts-field input[type=number] {
	padding: 10px 12px; font-size: 15px; border: 1px solid #cfd8dc;
	border-radius: var(--ts-radius-sm); background: #fff; transition: .15s;
	max-width: 420px;
}
.tickets-time-slot .ts-field input:focus {
	outline: none; border-color: var(--ts-primary);
	box-shadow: 0 0 0 3px rgba(25,118,210,.15);
}
.tickets-time-slot .ts-field-checkbox { flex-direction: row; align-items: center; gap: 8px; }
.tickets-time-slot .ts-field-checkbox label { font-weight: 400; cursor: pointer; }
.tickets-time-slot .ts-field-error input { border-color: var(--ts-danger); }
.tickets-time-slot .ts-error-msg { color: var(--ts-danger); font-size: 13px; }

/* Radios --------------------------------------------------------- */
.tickets-time-slot .ts-radio {
	display: inline-flex; align-items: center; gap: 6px;
	padding: 8px 14px; margin: 0 8px 8px 0;
	border: 1px solid var(--ts-border); border-radius: var(--ts-radius-sm);
	cursor: pointer; transition: .15s; background: #fff;
}
.tickets-time-slot .ts-radio:hover { border-color: var(--ts-primary); }
.tickets-time-slot .ts-radio input { margin: 0; }
.tickets-time-slot .ts-radio small { color: #607d8b; }

/* Categories table ---------------------------------------------- */
.tickets-time-slot .ts-categories { width: 100%; border-collapse: collapse; margin-top: 8px; }
.tickets-time-slot .ts-categories th,
.tickets-time-slot .ts-categories td {
	padding: 10px 8px; border-bottom: 1px solid #eef1f4; text-align: left; vertical-align: middle;
}
.tickets-time-slot .ts-categories th { font-size: 13px; color: #607d8b; font-weight: 600; text-transform: uppercase; letter-spacing: .04em; }
.tickets-time-slot .ts-th-price,
.tickets-time-slot .ts-th-qty,
.tickets-time-slot .ts-categories td.ts-td-price,
.tickets-time-slot .ts-categories td.ts-td-qty { text-align: right; }
.tickets-time-slot .ts-categories input[type=number] { width: 90px; padding: 8px 10px; border: 1px solid #cfd8dc; border-radius: var(--ts-radius-sm); font-size: 15px; }
.tickets-time-slot .ts-categories input[type=number]:focus { outline: none; border-color: var(--ts-primary); box-shadow: 0 0 0 3px rgba(25,118,210,.15); }

/* Calendar ------------------------------------------------------- */
.tickets-time-slot .ts-calendar { margin-top: 8px; }
.tickets-time-slot .ts-cal-header {
	display: flex; align-items: center; justify-content: space-between;
	padding: 6px 0 14px; gap: 8px;
}
.tickets-time-slot .ts-cal-nav {
	background: #fff; border: 1px solid var(--ts-border);
	border-radius: 50%; width: 36px; height: 36px;
	cursor: pointer; font-size: 18px; line-height: 1; color: var(--ts-primary);
	transition: .15s;
}
.tickets-time-slot .ts-cal-nav:hover:not([disabled]) { background: var(--ts-primary); color: #fff; border-color: var(--ts-primary); }
.tickets-time-slot .ts-cal-nav[disabled] { opacity: .35; cursor: not-allowed; }
.tickets-time-slot .ts-cal-title { font-weight: 600; color: #37474f; font-size: 15px; }

.tickets-time-slot .ts-cal-months {
	display: grid; grid-template-columns: 1fr 1fr; gap: 20px;
}
@media (max-width: 767px) {
	.tickets-time-slot .ts-cal-months { grid-template-columns: 1fr; gap: 12px; }
	.tickets-time-slot .ts-cal-month:nth-child(2) { display: none; }
	.tickets-time-slot .ts-calendar.show-second .ts-cal-month:nth-child(2) { display: block; }
}
.tickets-time-slot .ts-cal-month-name { text-align: center; font-weight: 600; color: #455a64; margin: 0 0 8px; }
.tickets-time-slot .ts-cal-grid {
	display: grid; grid-template-columns: repeat(7, 1fr); gap: 4px;
}
.tickets-time-slot .ts-cal-dow { font-size: 11px; color: var(--ts-muted); text-align: center; padding: 4px 0; text-transform: uppercase; font-weight: 600; }
.tickets-time-slot .ts-day {
	position: relative; aspect-ratio: 1 / 1;
	display: flex; flex-direction: column; align-items: center; justify-content: center;
	border: 1px solid var(--ts-border); border-radius: var(--ts-radius-sm);
	cursor: pointer; transition: .15s; background: #fff;
	font-size: 14px; padding: 4px;
}
.tickets-time-slot .ts-day-num { font-weight: 600; font-size: 15px; line-height: 1; }
.tickets-time-slot .ts-day.is-empty { background: transparent; border: none; cursor: default; }
.tickets-time-slot .ts-day.is-today { box-shadow: inset 0 0 0 2px var(--ts-primary); }

.tickets-time-slot .ts-day--inactive { background: #f5f5f5; color: #bdbdbd; cursor: not-allowed; }
.tickets-time-slot .ts-day--closed   { background: #eceff1; color: #90a4ae; cursor: not-allowed; }
.tickets-time-slot .ts-day--soldout  { background: #cfd8dc; color: #546e7a; cursor: not-allowed; text-decoration: line-through; }
.tickets-time-slot .ts-day--inquiry  { background: var(--ts-info); color: #fff; border-color: var(--ts-info); }
.tickets-time-slot .ts-day--open     { background: var(--ts-success); color: #fff; border-color: var(--ts-success); }
.tickets-time-slot .ts-day--last     { background: var(--ts-warning); color: #fff; border-color: var(--ts-warning); }
.tickets-time-slot .ts-day--open:hover,
.tickets-time-slot .ts-day--last:hover,
.tickets-time-slot .ts-day--inquiry:hover { filter: brightness(1.08); transform: translateY(-1px); box-shadow: var(--ts-shadow-md); }

/* xart:psp | 2026-05-25 | task 1102 | selected day must override --open/--last/--inquiry */
.tickets-time-slot .ts-day.is-selected,
.tickets-time-slot .ts-day--open.is-selected,
.tickets-time-slot .ts-day--last.is-selected,
.tickets-time-slot .ts-day--inquiry.is-selected {
	background: #e3f2fd;
	color: #1565c0;
	border: 2px solid var(--ts-primary);
	font-weight: 700;
	box-shadow: 0 0 0 3px var(--ts-primary);
	transform: translateY(-1px);
}
.tickets-time-slot .ts-day.is-selected:hover,
.tickets-time-slot .ts-day--open.is-selected:hover,
.tickets-time-slot .ts-day--last.is-selected:hover,
.tickets-time-slot .ts-day--inquiry.is-selected:hover { background: #bbdefb; filter: none; }

.tickets-time-slot .ts-cal-legend { display: flex; flex-wrap: wrap; gap: 14px; margin-top: 14px; font-size: 12px; color: #607d8b; }
.tickets-time-slot .ts-cal-legend span { display: inline-flex; align-items: center; gap: 6px; }
.tickets-time-slot .ts-cal-legend i { display: inline-block; width: 12px; height: 12px; border-radius: 3px; }
.tickets-time-slot .ts-cal-legend i.lg-open    { background: var(--ts-success); }
.tickets-time-slot .ts-cal-legend i.lg-last    { background: var(--ts-warning); }
.tickets-time-slot .ts-cal-legend i.lg-inquiry { background: var(--ts-info); }
.tickets-time-slot .ts-cal-legend i.lg-soldout { background: #cfd8dc; }
.tickets-time-slot .ts-cal-legend i.lg-closed  { background: #eceff1; }

/* Slots ---------------------------------------------------------- */
.tickets-time-slot .ts-slots-wrap { margin-top: 18px; }
.tickets-time-slot .ts-slots-title { font-weight: 600; color: #37474f; margin: 0 0 8px; font-size: 14px; }
.tickets-time-slot .ts-slots { display: grid; grid-template-columns: 1fr; gap: 16px; }
@media (min-width: 1024px) { .tickets-time-slot .ts-slots { grid-template-columns: 1fr 1fr; } }
.tickets-time-slot .ts-slots-col { display: flex; flex-direction: column; gap: 8px; }
.tickets-time-slot .ts-slots-col h4 { margin: 0 0 4px; font-size: 13px; font-weight: 600; color: #607d8b; text-transform: uppercase; letter-spacing: .04em; }
.tickets-time-slot .ts-slots-inner { display: grid; grid-template-columns: repeat(2, 1fr); gap: 8px; }
@media (min-width: 1280px) { .tickets-time-slot .ts-slots-inner { grid-template-columns: repeat(3, 1fr); } }
.tickets-time-slot .ts-slot {
	position: relative; overflow: hidden;
	padding: 10px 8px; border: 1px solid var(--ts-border);
	background: #fff; color: #333; border-radius: var(--ts-radius-sm);
	cursor: pointer; transition: .15s; text-align: center;
	display: flex; flex-direction: column; gap: 2px; font: inherit;
}
.tickets-time-slot .ts-slot:hover:not([disabled]) { background: #f5f9ff; border-color: var(--ts-primary); transform: translateY(-1px); box-shadow: var(--ts-shadow); }
.tickets-time-slot .ts-slot.is-selected { background: var(--ts-primary); color: #fff; border-color: var(--ts-primary-dk); }
/* xart:psp | 2026-05-25 | task 1102 | selected slot hover must stay dark with white text */
.tickets-time-slot .ts-slot.is-selected:hover,
.tickets-time-slot .ts-slot.is-selected:focus {
	background: var(--ts-primary);
	color: #fff;
	border-color: var(--ts-primary);
}
.tickets-time-slot .ts-slot[disabled] { background: #eceff1; color: #90a4ae; cursor: not-allowed; text-decoration: line-through; }
.tickets-time-slot .ts-slot--inquiry { background: #fff; color: var(--ts-info); border-color: var(--ts-info); }
.tickets-time-slot .ts-slot--inquiry:hover:not([disabled]) { background: #e3f2fd; }
.tickets-time-slot .ts-slot--inquiry.is-selected { background: var(--ts-info); color: #fff; }
.tickets-time-slot .ts-slot strong { font-size: 15px; font-weight: 600; }
.tickets-time-slot .ts-slot-progress {
	position: absolute; left: 0; right: 0; bottom: 0; height: 3px;
	background: linear-gradient(to right, var(--ts-progress-color, var(--ts-primary)) var(--p, 0%), transparent var(--p, 0%));
}
.tickets-time-slot .ts-slot.is-selected .ts-slot-progress { background: linear-gradient(to right, rgba(255,255,255,.85) var(--p, 0%), rgba(255,255,255,.2) var(--p, 0%)); }

/* Summary aside -------------------------------------------------- */
.tickets-time-slot .ts-summary-aside {
	border: 1px solid var(--ts-border); border-radius: var(--ts-radius);
	padding: 16px 18px; background: var(--ts-bg-alt);
	box-shadow: var(--ts-shadow);
}
@media (min-width: 992px) {
	.tickets-time-slot .ts-summary-aside { position: sticky; top: 80px; }
}
@media (max-width: 991px) {
	.tickets-time-slot .ts-summary-aside {
		position: sticky; bottom: 0; z-index: 50;
		border-radius: var(--ts-radius) var(--ts-radius) 0 0;
		box-shadow: 0 -2px 8px rgba(0,0,0,.08);
		margin: 0 -8px;
	}
}
.tickets-time-slot .ts-summary-title { font-weight: 600; color: var(--ts-primary-dk); margin: 0 0 10px; font-size: 15px; }
.tickets-time-slot .ts-summary-row { display: flex; justify-content: space-between; padding: 4px 0; font-size: 14px; }
.tickets-time-slot .ts-summary-row strong { color: #455a64; }
.tickets-time-slot .ts-summary-row .ts-sum-val { color: #1b2a3a; font-weight: 600; }
.tickets-time-slot .ts-sum-price-val { color: var(--ts-primary-dk); font-size: 18px; }
.tickets-time-slot .ts-summary-errors { color: var(--ts-danger); margin-top: 8px; font-size: 13px; }
.tickets-time-slot .ts-summary-errors ul { margin: 4px 0 0 18px; padding: 0; }
.tickets-time-slot .ts-summary-warnings { color: var(--ts-warning); margin-top: 8px; font-size: 13px; }

/* Info-only / inquiry box --------------------------------------- */
.tickets-time-slot .ts-info-only-box {
	background: #e3f2fd; border: 1px solid var(--ts-info);
	color: #0d3c5e; padding: 12px 16px; border-radius: var(--ts-radius-sm); margin: 12px 0;
}

/* Pay types ------------------------------------------------------ */
.tickets-time-slot .ts-pay-types { margin-top: 12px; padding-top: 10px; border-top: 1px dashed var(--ts-border); }
.tickets-time-slot .ts-pay-types-label { margin: 0 0 6px; font-size: 13px; color: #607d8b; }

/* Navigation buttons -------------------------------------------- */
.tickets-time-slot .ts-nav { display: flex; justify-content: space-between; margin-top: 18px; gap: 8px; }
.tickets-time-slot .ts-button {
	padding: 0 22px; min-height: 40px;
	display: inline-flex; align-items: center; justify-content: center;
	border: 1px solid transparent; border-radius: var(--ts-radius-sm);
	cursor: pointer; font-size: 15px; font-weight: 500; line-height: 1.2; transition: .15s;
	background: #fff; color: #455a64; border-color: var(--ts-border); font-family: inherit;
}
.tickets-time-slot .ts-button:hover:not([disabled]) { background: #f5f5f5; }
.tickets-time-slot .ts-button-primary { background: var(--ts-primary); color: #fff; border-color: var(--ts-primary); }
.tickets-time-slot .ts-button-primary:hover:not([disabled]) { background: var(--ts-primary-dk); }
.tickets-time-slot .ts-button[disabled] { opacity: .5; cursor: not-allowed; }
@media (max-width: 767px) { .tickets-time-slot .ts-button { flex: 1; } }

.tickets-time-slot .ts-hint { color: #607d8b; font-size: 13px; margin: 8px 0 0; }
.tickets-time-slot .ts-ztpp-note { color: #a94442; background: #fdecea; border: 1px solid #f5c2c0; padding: 8px 12px; border-radius: var(--ts-radius-sm); margin: 8px 0 0; font-size: 13px; }
.tickets-time-slot .ts-empty { padding: 30px; background: #fff8e1; border: 1px solid #f0c36d; border-radius: var(--ts-radius); text-align: center; }
