/**
 * goGLOW Locations Finder styles.
 * Brand: black / white + teal accent (#009CA6, dark #007e87), Inter.
 */

.gg-finder {
	--gg-teal: #009CA6;
	--gg-teal-dark: #007e87;
	--gg-soon: #E08A1E;
	--gg-ink: #1F2124;
	--gg-paper: #f6f4f1;
	--gg-line: #e2ddd6;
	font-family: 'Inter', sans-serif;
	color: var(--gg-ink);
	max-width: 1280px;
	margin: 0 auto;
	padding: 0 16px 48px;
	box-sizing: border-box;
}
.gg-finder *, .gg-finder *::before, .gg-finder *::after { box-sizing: border-box; }

/* ---- Hero (two columns: intro+search left, feature card right) ----
 * Selectors are scoped under #gg-finder so they win against Elementor's
 * global `.elementor input` / `.elementor button` rules.
 */
#gg-finder .gg-finder__top {
	display: grid;
	grid-template-columns: 1.05fr 0.95fr;
	gap: 40px;
	align-items: center;
	padding: 8px 0 48px;
}
#gg-finder .gg-finder__intro {
	text-align: left;
	min-width: 0; /* allow the grid track to shrink instead of overflowing */
}
#gg-finder .gg-finder__title {
	font-size: clamp(30px, 4vw, 46px);
	font-weight: 900;
	letter-spacing: -0.02em;
	margin: 0 0 14px;
}
#gg-finder .gg-finder__lede {
	font-family: 'Inter', sans-serif;
	font-size: 17px;
	line-height: 1.55;
	color: #535353;
	margin: 0 0 20px;
	max-width: 46ch;
}
#gg-finder .gg-finder__subtitle {
	font-family: 'Inter', sans-serif;
	font-size: 12px;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.16em;
	color: var(--gg-teal-dark);
	margin: 0 0 16px;
}

#gg-finder .gg-finder__search {
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	gap: 14px;
}

/* Unified pill: pin + input + Search button as one floating control */
#gg-finder .gg-finder__searchbar {
	display: flex;
	align-items: center;
	gap: 10px;
	width: 100%;
	max-width: 520px;
	background: #fff;
	border: 2px solid var(--gg-ink);
	border-radius: 999px;
	padding: 6px 6px 6px 22px;
	box-shadow: 0 14px 34px -16px rgba(31, 33, 36, .35);
	transition: border-color .18s ease, box-shadow .18s ease;
}
#gg-finder .gg-finder__searchbar:focus-within {
	border-color: var(--gg-teal);
	box-shadow: 0 16px 38px -14px rgba(0, 156, 166, .5);
}
#gg-finder .gg-finder__pinico {
	width: 22px; height: 22px; flex: none;
	color: var(--gg-teal);
}
#gg-finder .gg-finder__zip {
	flex: 1 1 auto;
	min-width: 0;
	width: auto;
	margin: 0;
	border: 0 !important;
	outline: none !important;
	box-shadow: none !important;
	background: transparent;
	font-family: 'Inter', sans-serif;
	font-size: 17px;
	font-weight: 600;
	letter-spacing: 0.02em;
	color: var(--gg-ink);
	padding: 12px 2px;
}
#gg-finder .gg-finder__zip::placeholder { color: #9a958d; font-weight: 500; }
#gg-finder .gg-finder__go {
	flex: none;
	font-family: 'Inter', sans-serif;
	font-weight: 900;
	font-size: 15px;
	letter-spacing: 0.01em;
	color: #fff;
	background: var(--gg-ink);
	border: 0;
	border-radius: 999px;
	padding: 14px 30px;
	cursor: pointer;
	transition: background-color .18s ease, transform .12s ease;
}
#gg-finder .gg-finder__go:hover { background: var(--gg-teal); }
#gg-finder .gg-finder__go:active { transform: scale(.97); }

#gg-finder .gg-finder__geo {
	display: inline-flex;
	align-items: center;
	gap: 7px;
	background: none;
	border: 0;
	cursor: pointer;
	font-family: 'Inter', sans-serif;
	font-size: 14px;
	font-weight: 600;
	color: #6a655d;
	padding: 2px 6px;
	transition: color .15s ease;
}
#gg-finder .gg-finder__geo svg { width: 16px; height: 16px; flex: none; }
#gg-finder .gg-finder__geo .gg-finder__geo-txt {
	text-decoration: underline;
	text-decoration-thickness: 1px;
	text-underline-offset: 3px;
}
#gg-finder .gg-finder__geo:hover { color: var(--gg-teal-dark); }

#gg-finder .gg-finder__msg {
	min-height: 22px;
	margin: 18px 0 0;
	font-size: 15px;
	color: #2b2b2b;
}
#gg-finder .gg-finder__msg.is-error { color: #b3261e; }
#gg-finder .gg-finder__msg strong { color: var(--gg-teal-dark); }

/* ---- Feature card (right column of hero, Jungle-style) ---- */
#gg-finder .gg-finder__feature { min-height: 260px; min-width: 0; }
#gg-finder .gg-feature {
	background: #fff;
	border: 1px solid var(--gg-line);
	border-radius: 20px;
	overflow: hidden;
	box-shadow: 0 22px 50px -30px rgba(31, 33, 36, .5);
}
#gg-finder .gg-feature__media {
	height: 168px;
	background-size: cover;
	background-position: center;
}
#gg-finder .gg-feature__media--ph {
	background:
		radial-gradient(120% 120% at 80% 0%, rgba(0,156,166,.18), transparent 60%),
		linear-gradient(135deg, #e7e2db, #f6f4f1);
	display: flex; align-items: center; justify-content: center;
}
#gg-finder .gg-feature__mediapin { width: 40px; height: 40px; color: var(--gg-teal); opacity: .55; }
#gg-finder .gg-feature__media--ph.is-soon .gg-feature__mediapin { color: var(--gg-soon); }
#gg-finder .gg-feature__media.is-soon { filter: saturate(.85); }
#gg-finder .gg-feature__body { padding: 20px 22px 22px; }
#gg-finder .gg-feature__badges {
	display: flex; flex-wrap: wrap; gap: 8px; align-items: center;
	margin-bottom: 8px; min-height: 22px;
}
#gg-finder .gg-feature__badge {
	font-size: 11px; font-weight: 800; text-transform: uppercase; letter-spacing: .05em;
	padding: 3px 9px; border-radius: 999px;
}
#gg-finder .gg-feature__badge--near { background: var(--gg-teal); color: #fff; }
#gg-finder .gg-feature__badge--soon {
	color: var(--gg-soon); border: 1px solid var(--gg-soon);
}
#gg-finder .gg-feature__miles {
	font-size: 13px; font-weight: 700; color: var(--gg-teal-dark); margin-left: auto;
}
#gg-finder .gg-feature__name {
	display: flex; align-items: baseline; gap: 9px;
	font-size: 24px; font-weight: 900; margin: 0 0 6px; letter-spacing: -0.01em;
}
#gg-finder .gg-feature__state {
	font-size: 12px; font-weight: 700; color: #fff;
	background: var(--gg-teal); border-radius: 5px; padding: 2px 7px;
}
#gg-finder .gg-feature--soon .gg-feature__state { background: var(--gg-soon); }
#gg-finder .gg-feature__addr { margin: 0 0 8px; font-size: 14px; line-height: 1.45; color: #535353; }
#gg-finder .gg-feature__phone {
	display: inline-block; font-size: 14px; font-weight: 700; color: var(--gg-ink); text-decoration: none;
}
#gg-finder .gg-feature__phone:hover { color: var(--gg-teal); }
#gg-finder .gg-feature__actions { display: flex; flex-wrap: wrap; gap: 10px; margin-top: 16px; }
#gg-finder .gg-feature__btn {
	flex: 1 1 auto; text-align: center; white-space: nowrap;
	font-size: 14px; font-weight: 800; text-decoration: none;
	padding: 11px 20px; border-radius: 999px; border: 2px solid var(--gg-ink); color: var(--gg-ink);
	transition: background-color .15s ease, color .15s ease, border-color .15s ease;
}
#gg-finder .gg-feature__btn:hover { background: var(--gg-ink); color: #fff; }
#gg-finder .gg-feature__btn--primary { background: var(--gg-ink); color: #fff; }
#gg-finder .gg-feature__btn--primary:hover { background: var(--gg-teal); border-color: var(--gg-teal); }

/* Empty / prompt state */
#gg-finder .gg-feature--empty {
	display: flex; flex-direction: column; align-items: center; justify-content: center;
	text-align: center; min-height: 260px; padding: 32px 28px;
	background: rgba(255,255,255,.55);
	border-style: dashed;
	box-shadow: none;
}
#gg-finder .gg-feature__pinmark {
	width: 54px; height: 54px; color: var(--gg-teal); margin-bottom: 14px; opacity: .8;
}
#gg-finder .gg-feature__pinmark svg { width: 100%; height: 100%; }
#gg-finder .gg-feature__hint { font-size: 15px; color: #6a655d; max-width: 26ch; margin: 0; }

/* ---- "Locations across the country" — per-state grid ---- */
#gg-finder .gg-finder__states { margin-top: 56px; }
#gg-finder .gg-finder__states-title {
	font-size: clamp(24px, 3vw, 34px);
	font-weight: 900;
	letter-spacing: -0.01em;
	text-align: center;
	margin: 0 0 32px;
}
#gg-finder .gg-states {
	list-style: none; margin: 0; padding: 0;
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 28px 40px;
}
#gg-finder .gg-state { min-width: 0; break-inside: avoid; }
#gg-finder .gg-state__name {
	position: relative;
	font-size: 20px; font-weight: 900; text-transform: uppercase; letter-spacing: 0.04em;
	color: var(--gg-ink);
	margin: 0 0 4px;
	padding-bottom: 10px;
	border-bottom: 2px solid var(--gg-ink);
}
#gg-finder .gg-state__name::after {
	content: ""; position: absolute; left: 0; bottom: -2px;
	width: 42px; height: 2px; background: var(--gg-teal);
}
#gg-finder .gg-state__list { list-style: none; margin: 0; padding: 0; }
#gg-finder .gg-state__item {
	display: flex; align-items: flex-start; justify-content: space-between; gap: 14px;
	padding: 13px 0;
	border-bottom: 1px solid var(--gg-line);
}
#gg-finder .gg-state__item:last-child { border-bottom: 0; }
#gg-finder .gg-state__info { min-width: 0; }
#gg-finder .gg-state__city {
	font-size: 17px; font-weight: 700; color: var(--gg-ink); text-decoration: none;
	transition: color .15s ease;
}
#gg-finder .gg-state__city:hover { color: var(--gg-teal-dark); text-decoration: underline; text-underline-offset: 3px; }
#gg-finder .gg-state__addr { margin: 4px 0 0; font-size: 13px; line-height: 1.45; color: #6a655d; }
#gg-finder .gg-state__pill {
	flex: none;
	font-size: 11px; font-weight: 800; text-transform: uppercase; letter-spacing: .04em;
	padding: 3px 10px; border-radius: 999px; border: 1px solid;
}
#gg-finder .gg-state__pill--open { color: var(--gg-teal-dark); border-color: var(--gg-teal); }
#gg-finder .gg-state__pill--soon { color: var(--gg-soon); border-color: var(--gg-soon); }
@media (max-width: 980px) {
	#gg-finder .gg-states { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 600px) {
	#gg-finder .gg-states { grid-template-columns: 1fr; gap: 24px; }
}

/* ---- Layout split ---- */
.gg-finder__layout {
	display: grid;
	grid-template-columns: 400px 1fr;
	gap: 20px;
	align-items: stretch;
}
.gg-finder__tabs { display: none; }

.gg-finder__panel--list { position: relative; }
.gg-finder__list {
	list-style: none;
	margin: 0;
	padding: 0;
	max-height: 620px;
	overflow-y: auto;
	overscroll-behavior: contain;
	background: #fff;
	border: 1px solid var(--gg-line);
	border-radius: 16px;
	box-shadow: 0 18px 40px -28px rgba(31, 33, 36, .4);
}
.gg-finder__panel--list { max-height: 620px; overflow: hidden; }
.gg-finder__scrollhint {
	position: absolute;
	bottom: 6px; left: 50%;
	transform: translateX(-50%);
	font-size: 26px; line-height: 1;
	color: var(--gg-teal);
	pointer-events: none;
	opacity: 0;
	transition: opacity .25s ease;
	animation: gg-bounce 1.4s infinite;
}
@keyframes gg-bounce { 0%,100%{ transform: translate(-50%,0);} 50%{ transform: translate(-50%,5px);} }

/* ---- Cards ---- */
.gg-card {
	padding: 16px 18px;
	border-bottom: 1px solid var(--gg-line);
	cursor: pointer;
	transition: background-color .15s ease, box-shadow .15s ease;
	scroll-margin: 12px;
}
.gg-card:last-child { border-bottom: 0; }
.gg-card:hover, .gg-card.is-hover { background: var(--gg-paper); }
.gg-card.is-active {
	background: #fff;
	box-shadow: inset 4px 0 0 var(--gg-teal);
}
.gg-card__head { display: flex; align-items: baseline; gap: 8px; flex-wrap: wrap; }
.gg-card__name {
	font-size: 18px; font-weight: 900; margin: 0;
	display: flex; align-items: baseline; gap: 7px;
}
.gg-card__state {
	font-size: 12px; font-weight: 700; color: #fff;
	background: var(--gg-teal); border-radius: 4px; padding: 2px 6px;
}
.gg-card--soon .gg-card__state { background: var(--gg-soon); }
.gg-card__miles {
	margin-left: auto; font-size: 13px; font-weight: 700; color: var(--gg-teal-dark);
	white-space: nowrap;
}
.gg-card__badge {
	font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: .04em;
	color: var(--gg-soon); border: 1px solid var(--gg-soon); border-radius: 4px; padding: 1px 6px;
}
.gg-card__addr { margin: 8px 0 6px; font-size: 14px; color: #535353; line-height: 1.4; }
.gg-card__phone { display: inline-block; font-size: 14px; font-weight: 600; color: var(--gg-ink); text-decoration: none; }
.gg-card__phone:hover { color: var(--gg-teal); }
/* When a studio shows both numbers, stack them and label each line. */
#gg-finder .gg-phones { display: flex; flex-direction: column; align-items: flex-start; gap: 2px; }
#gg-finder .gg-phone__label { font-weight: 800; color: var(--gg-teal); }
.gg-card__actions { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 12px; }
.gg-card__btn {
	flex: 1 1 auto; text-align: center; white-space: nowrap;
	font-size: 13px; font-weight: 700; text-decoration: none;
	padding: 9px 16px; border-radius: 50px; border: 2px solid var(--gg-ink); color: var(--gg-ink);
	transition: background-color .15s ease, color .15s ease, border-color .15s ease;
}
.gg-card__btn:hover { background: var(--gg-ink); color: #fff; }
.gg-card__btn--primary { background: var(--gg-ink); color: #fff; }
.gg-card__btn--primary:hover { background: var(--gg-teal); border-color: var(--gg-teal); }

/* ---- Map ---- */
.gg-finder__panel--map { position: relative; }
.gg-finder__map {
	background: #fff;
	border: 1px solid var(--gg-line);
	border-radius: 16px;
	overflow: hidden;
	min-height: 360px;
	box-shadow: 0 18px 40px -28px rgba(31, 33, 36, .4);
}
.gg-finder__svg { display: block; width: 100%; height: auto; }
.gg-finder__land { fill: #e7e2db; }
.gg-finder__borders { fill: none; stroke: #fff; stroke-width: 1; stroke-linejoin: round; }
.gg-finder__maperr { padding: 24px; text-align: center; color: #535353; }

.gg-finder__legend {
	position: absolute; bottom: 12px; right: 14px;
	display: flex; gap: 14px;
	background: rgba(255,255,255,.9);
	border-radius: 8px; padding: 6px 10px; font-size: 12px; font-weight: 600;
}
.gg-finder__legend-item { display: inline-flex; align-items: center; gap: 5px; }
.gg-dot { width: 10px; height: 10px; border-radius: 50%; display: inline-block; }
.gg-dot--open { background: var(--gg-teal); }
.gg-dot--soon { background: var(--gg-soon); }

/* ---- Pins ---- */
.gg-pin { cursor: pointer; }
.gg-pin__dot {
	fill: var(--gg-teal); stroke: #fff; stroke-width: 1.5;
	transform-box: fill-box;   /* keep the pop animation pivoting in place */
	transform-origin: center;
	transition: r .15s ease, fill .15s ease;
}
.gg-pin--soon .gg-pin__dot { fill: var(--gg-soon); }
.gg-pin__halo {
	fill: var(--gg-teal);
	opacity: 0;
	transform-box: fill-box;   /* pivot scale around the halo's own centre, not the whole SVG */
	transform-origin: center;
	transition: opacity .2s ease, transform .2s ease;
}
.gg-pin--soon .gg-pin__halo { fill: var(--gg-soon); }
.gg-pin__label {
	font-family: 'Inter', sans-serif; font-size: 12px; font-weight: 700;
	fill: var(--gg-ink); paint-order: stroke; stroke: #fff; stroke-width: 3px;
	opacity: 0; pointer-events: none; transition: opacity .12s ease;
}
.gg-pin.is-hover .gg-pin__label,
.gg-pin.is-active .gg-pin__label { opacity: 1; }
.gg-pin.is-dim { opacity: .3; }

/* Hover previews the pin as "selected" (no click needed) with the same
   treatment as the active pin: enlarged dot, contained glow, label, and a
   quick one-shot pop. No radiating ripple. */
.gg-pin.is-hover .gg-pin__dot,
.gg-pin.is-active .gg-pin__dot {
	r: 8;
	animation: gg-pop .34s ease-out;
}
.gg-pin.is-hover .gg-pin__halo,
.gg-pin.is-active .gg-pin__halo {
	opacity: .22;
	transform: scale(1.7);
}
@keyframes gg-pop {
	0%   { transform: scale(.55); }
	55%  { transform: scale(1.22); }
	100% { transform: scale(1); }
}

/* ---- Responsive: tabs ---- */
@media (max-width: 860px) {
	#gg-finder .gg-finder__top {
		grid-template-columns: 1fr;
		gap: 24px;
		text-align: center;
	}
	#gg-finder .gg-finder__intro { text-align: center; }
	#gg-finder .gg-finder__lede { max-width: none; }
	#gg-finder .gg-finder__search { align-items: center; }
	#gg-finder .gg-finder__feature { min-height: 0; }
	#gg-finder .gg-feature__media { height: 120px; }

	/* Compact, scrollable list on small screens */
	#gg-finder .gg-card { padding: 12px 14px; }
	#gg-finder .gg-card__name { font-size: 16px; }
	#gg-finder .gg-card__addr { margin: 5px 0 4px; font-size: 13px; }
	#gg-finder .gg-card__phone { font-size: 13px; }
	#gg-finder .gg-card__actions { margin-top: 10px; gap: 8px; }
	#gg-finder .gg-card__btn { padding: 8px 14px; font-size: 12px; }
	#gg-finder .gg-finder__panel--list,
	#gg-finder .gg-finder__list { max-height: 62vh; }

	.gg-finder__layout { grid-template-columns: 1fr; }
	#gg-finder .gg-finder__panel { min-width: 0; }
	.gg-finder__tabs {
		display: flex; gap: 0; margin-bottom: 14px;
		border: 2px solid var(--gg-ink); border-radius: 50px; overflow: hidden;
	}
	.gg-finder__tab {
		flex: 1; font-family: inherit; font-weight: 900; font-size: 14px;
		padding: 11px; background: #fff; border: 0; cursor: pointer; color: var(--gg-ink);
	}
	.gg-finder__tab.is-active { background: var(--gg-ink); color: #fff; }
	.gg-finder__panel { display: none; }
	.gg-finder__panel.is-shown { display: block; }
	.gg-finder__panel--list, .gg-finder__list { max-height: 70vh; }
}
@media (min-width: 861px) {
	.gg-finder__panel { display: block !important; }
}
