/* GT Training — frontend styles. Mobile-first.
 *
 * Selectors deliberately chain the wrapper class twice
 * (`.gt-training-container.gt-training-container`) to outweigh theme rules
 * that target `a {}` / `button {}` globally. Buttons are also matched by
 * element type (`a.gt-training-btn`, `button.gt-training-chip`) so theme
 * link-color and link-underline can't bleed through.
 */

.gt-training-container {
	--accent-blue: #00b2e3;
	--accent-orange: #ff9e18;
	--text-primary: #231f20;
	--text-secondary: #54565a;
	--success: #93d500;
	--danger: #ef3c45;
	--bg-card: #ffffff;
	--bg-page: #f8f8f8;
	--border: #e0e0e0;
	--shadow: 0 2px 8px rgba(0, 0, 0, 0.06);

	box-sizing: border-box;
	color: var(--text-primary);
	font-family: inherit;
	line-height: 1.5;
	max-width: 100%;
	padding-top: 20px;
}

.gt-training-container *,
.gt-training-container *::before,
.gt-training-container *::after {
	box-sizing: border-box;
}

/* ---------- Theme reset ---------- */
/* Strip theme-applied underline / odd background / pill border-radius from
 * every link and button inside the container. Variant rules below restore
 * the intended look. */
.gt-training-container.gt-training-container a,
.gt-training-container.gt-training-container button {
	text-decoration: none;
}
.gt-training-container.gt-training-container a:hover,
.gt-training-container.gt-training-container a:focus,
.gt-training-container.gt-training-container a:visited,
.gt-training-container.gt-training-container a:active {
	text-decoration: none;
}

/* ---------- Skip link ---------- */
.gt-training-container .gt-training-skip-link {
	position: absolute;
	left: -9999px;
	top: auto;
}
.gt-training-container .gt-training-skip-link:focus {
	position: static;
	display: inline-block;
	padding: 0.5rem 1rem;
	background: var(--accent-blue);
	color: #fff;
	margin-bottom: 0.5rem;
}

/* ---------- Buttons ---------- */
.gt-training-container.gt-training-container a.gt-training-btn,
.gt-training-container.gt-training-container button.gt-training-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: 44px;
	padding: 0.6rem 1.2rem;
	border-radius: 4px;
	font-weight: 600;
	text-decoration: none;
	border: 2px solid transparent;
	cursor: pointer;
	font-size: 0.95rem;
	line-height: 1.2;
	transition: opacity 0.15s ease, background 0.15s ease, color 0.15s ease;
	box-shadow: none;
}
.gt-training-container.gt-training-container a.gt-training-btn:focus-visible,
.gt-training-container.gt-training-container button.gt-training-btn:focus-visible {
	outline: 3px solid var(--accent-blue);
	outline-offset: 2px;
}
.gt-training-container.gt-training-container a.gt-training-btn--primary,
.gt-training-container.gt-training-container button.gt-training-btn--primary,
.gt-training-container.gt-training-container a.gt-training-btn--primary:hover,
.gt-training-container.gt-training-container a.gt-training-btn--primary:focus,
.gt-training-container.gt-training-container a.gt-training-btn--primary:visited {
	background: var(--accent-blue);
	color: #fff;
	border-color: var(--accent-blue);
}
.gt-training-container.gt-training-container a.gt-training-btn--primary:hover,
.gt-training-container.gt-training-container button.gt-training-btn--primary:hover {
	background: #0098c2;
	border-color: #0098c2;
}
.gt-training-container.gt-training-container a.gt-training-btn--secondary,
.gt-training-container.gt-training-container button.gt-training-btn--secondary,
.gt-training-container.gt-training-container a.gt-training-btn--secondary:hover,
.gt-training-container.gt-training-container a.gt-training-btn--secondary:focus,
.gt-training-container.gt-training-container a.gt-training-btn--secondary:visited {
	background: #fff;
	color: var(--accent-blue);
	border-color: var(--accent-blue);
}
.gt-training-container.gt-training-container a.gt-training-btn--secondary:hover,
.gt-training-container.gt-training-container button.gt-training-btn--secondary:hover {
	background: #e6f7fc;
}
.gt-training-container.gt-training-container a.gt-training-btn--ghost,
.gt-training-container.gt-training-container button.gt-training-btn--ghost,
.gt-training-container.gt-training-container a.gt-training-btn--ghost:hover,
.gt-training-container.gt-training-container a.gt-training-btn--ghost:focus,
.gt-training-container.gt-training-container a.gt-training-btn--ghost:visited {
	background: #fff;
	color: var(--text-secondary);
	border-color: var(--border);
}
.gt-training-container.gt-training-container a.gt-training-btn--ghost:hover,
.gt-training-container.gt-training-container button.gt-training-btn--ghost:hover {
	background: #f4f4f4;
	color: var(--text-primary);
}

/* ---------- CTA shortcode ---------- */
.gt-training-cta {
	display: flex;
	flex-direction: column;
	gap: 0.75rem;
	margin: 1.5rem 0;
}
@media (min-width: 480px) {
	.gt-training-cta { flex-direction: row; flex-wrap: wrap; }
}

/* ---------- Filter bar ---------- */
.gt-training-container .gt-training-filters {
	display: flex;
	flex-direction: column;
	gap: 0.75rem;
	margin-bottom: 1.5rem;
	padding: 1rem;
	background: var(--bg-card);
	border: 1px solid var(--border);
	border-radius: 6px;
}
.gt-training-container .gt-training-filter {
	display: flex;
	flex-direction: column;
	gap: 0.25rem;
	flex: 1 1 200px;
	min-width: 0;
}
.gt-training-container .gt-training-filter label,
.gt-training-container .gt-training-filter-label {
	font-size: 0.85rem;
	color: var(--text-secondary);
	font-weight: 600;
}
.gt-training-container.gt-training-container .gt-training-filter select {
	width: 100%;
	min-height: 44px;
	padding: 0.45rem 0.6rem;
	border: 1px solid var(--border);
	border-radius: 4px;
	background: #fff;
	color: var(--text-primary);
	font-size: 0.95rem;
}
.gt-training-container .gt-training-filter--chips { flex-basis: 100%; }

.gt-training-container .gt-training-tag-chips {
	display: flex;
	flex-wrap: wrap;
	gap: 0.4rem;
}
.gt-training-container.gt-training-container button.gt-training-chip,
.gt-training-container.gt-training-container a.gt-training-chip {
	min-height: 32px;
	padding: 0.3rem 0.85rem;
	font-size: 0.85rem;
	background: #f0f0f0;
	border: 1px solid var(--border);
	border-radius: 999px;
	cursor: pointer;
	color: var(--text-secondary);
	text-decoration: none;
	font-weight: 400;
	box-shadow: none;
	line-height: 1.2;
	transition: background 0.15s ease, color 0.15s ease;
}
.gt-training-container.gt-training-container button.gt-training-chip[aria-pressed="true"],
.gt-training-container.gt-training-container a.gt-training-chip[aria-pressed="true"] {
	background: var(--accent-blue);
	color: #fff;
	border-color: var(--accent-blue);
}
.gt-training-container.gt-training-container button.gt-training-chip:hover,
.gt-training-container.gt-training-container a.gt-training-chip:hover {
	background: #e3e3e3;
	color: var(--text-primary);
}
.gt-training-container.gt-training-container button.gt-training-chip[aria-pressed="true"]:hover,
.gt-training-container.gt-training-container a.gt-training-chip[aria-pressed="true"]:hover {
	background: #0098c2;
	color: #fff;
}
.gt-training-container.gt-training-container button.gt-training-chip:focus-visible,
.gt-training-container.gt-training-container a.gt-training-chip:focus-visible {
	outline: 3px solid var(--accent-blue);
	outline-offset: 2px;
}

.gt-training-container .gt-training-view-toggle {
	display: inline-flex;
	border: 1px solid var(--border);
	border-radius: 4px;
	overflow: hidden;
	background: #fff;
}
.gt-training-container.gt-training-container button.gt-training-view-btn {
	background: #fff;
	border: 0;
	padding: 0.5rem 1rem;
	cursor: pointer;
	font-size: 0.9rem;
	color: var(--text-secondary);
	min-height: 44px;
	border-radius: 0;
	text-decoration: none;
	box-shadow: none;
	font-weight: 600;
	line-height: 1.2;
}
.gt-training-container.gt-training-container button.gt-training-view-btn.is-active {
	background: var(--accent-blue);
	color: #fff;
}
.gt-training-container.gt-training-container button.gt-training-view-btn:hover:not(.is-active) {
	background: #f4f4f4;
	color: var(--text-primary);
}

.gt-training-container .gt-training-filter-actions {
	display: flex;
	gap: 0.5rem;
	flex-wrap: wrap;
}

@media (min-width: 768px) {
	.gt-training-container .gt-training-filters { flex-direction: row; flex-wrap: wrap; align-items: flex-end; }
}

/* ---------- Empty state ---------- */
.gt-training-container .gt-training-empty {
	padding: 2rem;
	text-align: center;
	color: var(--text-secondary);
	background: var(--bg-card);
	border: 1px dashed var(--border);
	border-radius: 6px;
	margin: 1rem 0;
}

/* ---------- Grid + cards ---------- */
.gt-training-container .gt-training-grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: 1rem;
	margin: 1rem 0;
}
.gt-training-container .gt-training-card {
	background: var(--bg-card);
	border: 1px solid var(--border);
	border-radius: 6px;
	padding: 1.25rem;
	box-shadow: var(--shadow);
	display: flex;
	flex-direction: column;
	gap: 0.75rem;
}
.gt-training-container .gt-training-event-card { flex-direction: row; gap: 1rem; align-items: flex-start; }
.gt-training-container .gt-training-event-body { flex: 1 1 auto; min-width: 0; }
.gt-training-container .gt-training-card-title { margin: 0; font-size: 1.15rem; line-height: 1.3; color: var(--text-primary); }
.gt-training-container.gt-training-container .gt-training-card-title a,
.gt-training-container.gt-training-container .gt-training-card-title a:hover,
.gt-training-container.gt-training-container .gt-training-card-title a:focus,
.gt-training-container.gt-training-container .gt-training-card-title a:visited {
	color: var(--text-primary);
	text-decoration: none;
	background: transparent;
}
.gt-training-container.gt-training-container .gt-training-card-title a:hover {
	color: var(--accent-blue);
}
.gt-training-container .gt-training-meta { color: var(--text-secondary); font-size: 0.9rem; }
.gt-training-container .gt-training-marketing { margin: 0.25rem 0; color: var(--text-primary); }
.gt-training-container.gt-training-container .gt-training-marketing a,
.gt-training-container.gt-training-container .gt-training-marketing a:visited {
	color: var(--accent-blue);
	text-decoration: underline;
	background: transparent;
}
.gt-training-container.gt-training-container .gt-training-marketing a:hover {
	color: #0098c2;
}
.gt-training-container .gt-training-tags { display: flex; flex-wrap: wrap; gap: 0.3rem; margin-top: 0.25rem; }
.gt-training-container .gt-training-tag {
	font-size: 0.75rem;
	padding: 0.15rem 0.6rem;
	background: #f0f0f0;
	color: var(--text-secondary);
	border-radius: 999px;
	line-height: 1.4;
}
.gt-training-container .gt-training-cost { font-weight: 600; color: var(--text-primary); }
.gt-training-container .gt-training-cost-block { font-size: 0.9rem; color: var(--text-secondary); }
.gt-training-container .gt-training-cost-block strong { color: var(--text-primary); }
.gt-training-container .gt-training-description {
	color: var(--text-primary);
	font-size: 0.95rem;
	line-height: 1.5;
}

/* Catalog: list courses one per row at every breakpoint (overrides the
   default 2-up / 3-up grid that the calendar uses). */
.gt-training-container.gt-training-catalog .gt-training-grid {
	grid-template-columns: 1fr;
}
.gt-training-container .gt-training-card-actions { display: flex; flex-wrap: wrap; gap: 0.5rem; margin-top: auto; }
/* Event card has short labels ("Register" / "Learn More") that almost-but-not-quite
   fit side-by-side in the 3-col grid. Force equal-share so they stay one row. */
.gt-training-container.gt-training-container .gt-training-event-card .gt-training-card-actions a.gt-training-btn,
.gt-training-container.gt-training-container .gt-training-event-card .gt-training-card-actions button.gt-training-btn {
	flex: 1 1 0;
	min-width: 0;
	padding-left: 0.75rem;
	padding-right: 0.75rem;
}

.gt-training-container .gt-training-date-icon {
	flex: 0 0 64px;
	width: 64px;
	height: 64px;
	border-radius: 6px;
	background: linear-gradient(135deg, var(--accent-blue), var(--accent-orange));
	color: #fff;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	font-weight: 700;
	line-height: 1.1;
}
.gt-training-container .gt-training-date-icon__month { font-size: 0.7rem; text-transform: uppercase; letter-spacing: 0.04em; }
.gt-training-container .gt-training-date-icon__day { font-size: 1.5rem; line-height: 1; }

.gt-training-container .gt-training-month-divider {
	font-size: 1.05rem;
	font-weight: 700;
	color: var(--text-secondary);
	padding: 0.5rem 0;
	border-bottom: 2px solid var(--border);
	margin-top: 1.5rem;
	margin-bottom: 0.5rem;
}
.gt-training-container .gt-training-month-divider:first-child { margin-top: 0; }

.gt-training-container.gt-training-container button.gt-training-back-link {
	display: inline-flex;
	align-items: center;
	gap: 0.35rem;
	background: transparent;
	border: 1px solid var(--border);
	color: var(--accent-blue);
	font-size: 0.95rem;
	font-weight: 600;
	padding: 0.4rem 0.85rem;
	border-radius: 4px;
	cursor: pointer;
	margin-bottom: 1rem;
}
.gt-training-container.gt-training-container button.gt-training-back-link:hover,
.gt-training-container.gt-training-container button.gt-training-back-link:focus {
	background: var(--bg-page);
	border-color: var(--accent-blue);
}

/* ---------- Month view ---------- */
.gt-training-container .gt-training-month-header { font-size: 1.25rem; font-weight: 700; margin-bottom: 0.75rem; color: var(--text-primary); }
.gt-training-container .gt-training-month-grid {
	display: grid;
	/* minmax(0, 1fr) — without the 0 minimum, a long no-wrap event title
	   forces its column to min-content width, blowing the 7-column grid past
	   the container; overflow:hidden then clips the later columns so only the
	   first few weekdays show. */
	grid-template-columns: repeat(7, minmax(0, 1fr));
	gap: 2px;
	background: var(--border);
	border: 1px solid var(--border);
	border-radius: 6px;
	overflow: hidden;
}
.gt-training-container .gt-training-month-weekday {
	background: #f4f4f4;
	padding: 0.5rem;
	font-size: 0.75rem;
	font-weight: 700;
	text-transform: uppercase;
	color: var(--text-secondary);
	text-align: center;
}
.gt-training-container .gt-training-month-cell {
	background: var(--bg-card);
	min-height: 88px;
	min-width: 0; /* allow no-wrap event pills to shrink + ellipsis instead of widening the column */
	padding: 0.35rem;
	display: flex;
	flex-direction: column;
	gap: 0.2rem;
}
.gt-training-container .gt-training-month-cell.is-outside { background: #fafafa; }
.gt-training-container .gt-training-month-day { font-weight: 700; font-size: 0.85rem; color: var(--text-secondary); }
.gt-training-container .gt-training-month-pill {
	font-size: 0.7rem;
	padding: 0.15rem 0.4rem;
	background: var(--accent-blue);
	color: #fff;
	border-radius: 3px;
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
	cursor: pointer;
	line-height: 1.3;
}
.gt-training-container .gt-training-month-pill:hover { opacity: 0.85; }
.gt-training-container .gt-training-month-more { font-size: 0.7rem; color: var(--text-secondary); }

/* ---------- Pagination ---------- */
.gt-training-container .gt-training-pagination {
	display: flex;
	flex-wrap: wrap;
	gap: 0.25rem;
	margin-top: 1.5rem;
	justify-content: center;
}
.gt-training-container.gt-training-container button.gt-training-page-btn {
	min-width: 36px;
	min-height: 36px;
	background: #fff;
	border: 1px solid var(--border);
	color: var(--text-secondary);
	cursor: pointer;
	border-radius: 4px;
	padding: 0.3rem 0.6rem;
	box-shadow: none;
	text-decoration: none;
	font-weight: 600;
	line-height: 1.2;
}
.gt-training-container.gt-training-container button.gt-training-page-btn.is-active {
	background: var(--accent-blue);
	color: #fff;
	border-color: var(--accent-blue);
}
.gt-training-container.gt-training-container button.gt-training-page-btn:focus-visible {
	outline: 3px solid var(--accent-blue);
	outline-offset: 2px;
}
.gt-training-container.gt-training-container button.gt-training-page-btn:hover:not(.is-active) {
	background: #f4f4f4;
	color: var(--text-primary);
}

/* ---------- Course request ---------- */
.gt-training-container.gt-training-course-request {
	background: var(--bg-card);
	border: 1px solid var(--border);
	border-radius: 6px;
	padding: 1.5rem;
	margin: 2rem 0;
	text-align: center;
}
.gt-training-container .gt-training-cr-heading,
.gt-training-container.gt-training-course-request .gt-training-cr-heading { margin: 0 0 0.5rem; font-size: 1.25rem; color: var(--text-primary); }
.gt-training-container .gt-training-cr-text,
.gt-training-container.gt-training-course-request .gt-training-cr-text { margin: 0 0 1rem; color: var(--text-secondary); }

/* ---------- Responsive grid ---------- */
@media (min-width: 480px) {
	.gt-training-container .gt-training-card { padding: 1.5rem; }
}
@media (min-width: 768px) {
	.gt-training-container .gt-training-grid { grid-template-columns: repeat(2, 1fr); gap: 1.25rem; }
	.gt-training-container .gt-training-month-cell { min-height: 110px; }
}
@media (min-width: 1024px) {
	.gt-training-container .gt-training-grid { grid-template-columns: repeat(3, 1fr); gap: 1.5rem; }
}
@media (max-width: 767px) {
	.gt-training-container .gt-training-month-cell { min-height: 70px; }
	.gt-training-container .gt-training-month-pill { display: none; }
	.gt-training-container .gt-training-month-more { display: none; }
}
