/*
 * Salisbury - Event Hero widget (sc_ticket_hero)
 *
 * Selectors + rules ported from the mockup source of truth:
 *   wp-content/themes/generatepress_child/mockups/ticket_page_draft1.html
 *   (hero block CSS: lines 212-372, concert-details CSS: lines 665-710)
 *
 * Palette tokens come from the shared stylesheet via the .sc-ticket-widget
 * wrapper, so this file contains only layout + typography + widget-scoped
 * seat-chart button overrides.
 *
 * Per-instance logo caps come through the widget's wrapper inline style
 * attribute as --sc-logo-max-desktop / --sc-logo-max-mobile custom
 * properties so render() stays CSS-free.
 */

.sc-ticket-widget.hero {
	background: linear-gradient(160deg, #1a1208 0%, #0d0d0d 60%);
	padding: 60px 24px 50px;
	text-align: center;
	border-bottom: 1px solid var(--accent);
	position: relative;
	overflow: hidden;
}
.sc-ticket-widget.hero::before {
	content: '';
	position: absolute;
	top: -100px;
	left: -100px;
	right: -100px;
	bottom: -100px;
	background: radial-gradient(ellipse at 50% 30%, rgba(200, 168, 75, 0.08) 0%, transparent 70%);
	pointer-events: none;
}

.sc-ticket-widget.hero .event-type-badge {
	display: inline-block;
	background: var(--accent);
	color: var(--bg);
	font-family: 'Barlow Condensed', sans-serif;
	font-weight: 800;
	font-size: 12px;
	letter-spacing: 5px;
	padding: 5px 14px;
	border-radius: 2px;
	margin-bottom: 20px;
	text-transform: uppercase;
}

.sc-ticket-widget.hero .hero-logo-wrap {
	margin-bottom: 18px;
}
.sc-ticket-widget.hero .event_logo,
.sc-ticket-widget.hero .hero-logo-wrap img {
	width: 100%;
	max-width: var(--sc-logo-max-desktop, 800px);
	height: auto;
	margin: 0 auto;
	display: block;
}

.sc-ticket-widget.hero h1 {
	font-family: 'Barlow Condensed', sans-serif;
	font-weight: 900;
	font-size: clamp(34px, 6vw, 60px);
	line-height: 1.05;
	color: #ffffff;
	margin: 0 0 12px;
	text-transform: uppercase;
	letter-spacing: 1px;
}
.sc-ticket-widget.hero h1 .highlight {
	color: var(--accent);
}

.sc-ticket-widget.hero .hero-subheadline {
	font-size: clamp(16px, 2.5vw, 20px);
	color: var(--muted);
	margin: 0 auto 28px;
	max-width: 600px;
}

.sc-ticket-widget.hero .price-block {
	display: inline-flex;
	align-items: center;
	gap: 12px;
	background: rgba(181, 33, 33, 0.08);
	border: 1px solid var(--primary);
	border-radius: 6px;
	padding: 14px 28px;
	margin-bottom: 28px;
}
.sc-ticket-widget.hero .price-block > div:not(.price-divider) {
	text-align: center;
}
.sc-ticket-widget.hero .price-block .price-divider {
	width: 1px;
	background: var(--border);
	align-self: stretch;
}
.sc-ticket-widget.hero .price-label {
	font-size: 13px;
	color: var(--muted);
	text-transform: uppercase;
	letter-spacing: 1px;
}
.sc-ticket-widget.hero .price-amount {
	font-family: 'Barlow Condensed', sans-serif;
	font-size: 36px;
	font-weight: 900;
	color: var(--primary);
	line-height: 1;
}
.sc-ticket-widget.hero .price-amount.price-amount--vip {
	color: var(--accent);
}
.sc-ticket-widget.hero .price-from {
	font-size: 13px;
	color: var(--muted);
}

.sc-ticket-widget.hero .hero-cta-wrap {
	max-width: 380px;
	margin: 0 auto 16px;
}
.hero-cta-wrap .tc_seating_map_button {
	display: block !important;
	width: 100%;
	background-color: var(--primary) !important;
	border-color: var(--primary) !important;
	color: #ffffff !important;
	font-family: 'Barlow Condensed', sans-serif !important;
	font-weight: 800 !important;
	font-size: 20px !important;
	line-height: 56px !important;
	letter-spacing: 2px;
	text-transform: uppercase;
	box-shadow: 0 4px 20px rgba(181, 33, 33, 0.35);
	transition: background-color 0.2s, box-shadow 0.2s, transform 0.2s;
}
.hero-cta-wrap .tc_seating_map_button:hover {
	background-color: var(--primary-hv) !important;
	border-color: var(--primary-hv) !important;
	color: #ffffff !important;
	box-shadow: 0 6px 28px rgba(212, 48, 48, 0.45);
	transform: translateY(-1px);
}

.sc-ticket-widget.hero .trust-line {
	font-size: 13px;
	color: var(--muted);
	margin-top: 8px;
}
.sc-ticket-widget.hero .trust-line .check {
	color: var(--accent);
	margin-right: 4px;
}

.sc-ticket-widget.hero .event-intro {
	max-width: 780px;
	margin: 18px auto 0;
	font-size: 15px;
	color: var(--muted);
}

.sc-ticket-widget.hero .event-meta {
	display: flex;
	justify-content: center;
	flex-wrap: wrap;
	gap: 20px;
	margin-top: 36px;
}
.sc-ticket-widget.hero .meta-item {
	display: flex;
	align-items: center;
	gap: 8px;
	font-size: 14px;
	color: var(--muted);
}
.sc-ticket-widget.hero .meta-item .icon {
	color: var(--accent);
	font-size: 16px;
}
.sc-ticket-widget.hero .meta-item strong {
	color: var(--text);
}

.sc-ticket-widget.hero .quick-facts {
	max-width: 860px;
	margin: 30px auto 0;
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
	gap: 12px;
}
.sc-ticket-widget.hero .fact-item {
	background: var(--card);
	border: 1px solid var(--border);
	border-radius: 6px;
	padding: 12px 14px;
	font-size: 13px;
	color: var(--muted);
	text-align: left;
}
.sc-ticket-widget.hero .fact-item strong {
	color: var(--text);
}

@media (max-width: 767px) {
	.sc-ticket-widget.hero {
		padding: 40px 16px 40px;
	}
	.sc-ticket-widget.hero .event_logo,
	.sc-ticket-widget.hero .hero-logo-wrap img {
		max-width: var(--sc-logo-max-mobile, 100%);
	}
}
