/* IP Location Lookup — dark theme refresh of the legacy synctrack page. */

.ip-hero {
	position: relative;
	padding: 96px 0 64px;
	text-align: center;
	overflow: hidden;
}

.ip-hero--detail {
	padding-top: 64px;
}

.ip-hero-container {
	position: relative;
	z-index: 1;
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 18px;
}

.ip-hero-title {
	font-size: clamp(2.25rem, 5vw, 3.5rem);
	font-weight: 700;
	color: var(--color-text-primary, #fcfcfd);
	margin: 0;
	line-height: 1.15;
	max-width: 720px;
}

.ip-hero-subtitle {
	font-size: 1rem;
	color: var(--color-text-body, #c0c7cf);
	margin: 0;
	max-width: 620px;
	line-height: 1.6;
}

.ip-hero-subtitle--error {
	color: #ff6b6b;
}

.ip-back {
	margin-bottom: 4px;
}

.ip-back a {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	color: var(--color-text-secondary, #b1b5c3);
	text-decoration: none;
	font-size: 0.875rem;
	transition: color 0.2s ease;
}

.ip-back a:hover {
	color: var(--color-text-primary, #fcfcfd);
}

.ip-query {
	background: var(--color-bg-secondary, #1c1929);
	border: 1px solid var(--color-border, #272b30);
	color: var(--color-text-primary, #fcfcfd);
	padding: 2px 10px;
	border-radius: 6px;
	font-family: ui-monospace, SFMono-Regular, Menlo, monospace;
	font-size: 0.95em;
}

/* ----- search form ----- */
.ip-lookup-form {
	display: flex;
	gap: 8px;
	width: 100%;
	max-width: 560px;
	background: var(--color-bg-secondary, #1c1929);
	border: 1px solid var(--color-border, #272b30);
	border-radius: 90px;
	padding: 6px;
	margin-top: 8px;
}

.ip-lookup-input {
	flex: 1 1 auto;
	background: transparent;
	border: 0;
	outline: 0;
	color: var(--color-text-primary, #fcfcfd);
	font-size: 1rem;
	padding: 0 18px;
	min-width: 0;
}

.ip-lookup-input::placeholder {
	color: var(--color-text-nav, #6f767e);
}

.ip-lookup-submit {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	padding: 12px 22px !important;
	border-radius: 90px;
	white-space: nowrap;
}

.ip-badges {
	display: flex;
	gap: 12px;
	flex-wrap: wrap;
	justify-content: center;
	margin-top: 4px;
}

.ip-badge {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	color: var(--color-text-secondary, #b1b5c3);
	font-size: 0.875rem;
	background: var(--color-bg-secondary, #1c1929);
	border: 1px solid var(--color-border, #272b30);
	padding: 8px 14px;
	border-radius: 90px;
}

/* ----- result card ----- */
.ip-result {
	padding: 32px 0 64px;
}

.ip-result-card {
	background: var(--color-bg-secondary, #1c1929);
	border: 1px solid var(--color-border, #272b30);
	border-radius: 16px;
	padding: 32px;
}

.ip-result-header {
	display: flex;
	align-items: center;
	gap: 12px;
	margin-bottom: 24px;
	color: var(--color-text-primary, #fcfcfd);
}

.ip-result-header h2 {
	font-size: 1.25rem;
	margin: 0;
	color: var(--color-text-primary, #fcfcfd);
	font-weight: 700;
}

.ip-result-status {
	margin-left: auto;
	font-size: 0.875rem;
	color: var(--color-text-muted, #777e90);
	font-weight: 500;
}

.ip-result-status.is-error { color: #ff6b6b; }
.ip-result-status.is-done  { color: #34c759; }

.ip-result-grid {
	display: grid;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	gap: 16px;
}

.ip-result-item {
	background: var(--color-bg-tertiary, #26213c);
	border: 1px solid var(--color-border, #272b30);
	border-radius: 12px;
	padding: 18px;
	display: flex;
	flex-direction: column;
	gap: 10px;
	transition: border-color 0.2s ease;
}

.ip-result-item:hover {
	border-color: var(--color-border-hover, #353945);
}

.ip-result-item-head {
	display: flex;
	align-items: center;
	gap: 8px;
	color: var(--color-text-caption, #838c96);
}

.ip-result-item-icon {
	color: var(--color-accent-orange, #ff592c);
	display: inline-flex;
	align-items: center;
}

.ip-result-item h3 {
	font-size: 0.75rem;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.5px;
	color: var(--color-text-caption, #838c96);
	margin: 0;
}

.ip-result-item-value {
	font-size: 1.0625rem;
	color: var(--color-text-primary, #fcfcfd);
	font-weight: 600;
	word-break: break-word;
	line-height: 1.4;
	min-height: 24px;
}

.ip-result-item-value [data-field]:empty::before,
.ip-result-item-value [data-field][data-empty="true"]::before {
	content: '—';
	color: var(--color-text-muted, #777e90);
}

/* ----- how-to use ----- */
.ip-howto {
	padding: 48px 0;
}

.ip-howto-grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 20px;
}

.ip-howto-item {
	background: var(--color-bg-secondary, #1c1929);
	border: 1px solid var(--color-border, #272b30);
	border-radius: 16px;
	padding: 28px;
	display: flex;
	flex-direction: column;
	gap: 12px;
}

.ip-howto-step {
	width: 40px;
	height: 40px;
	border-radius: 12px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	background: linear-gradient(139deg, #ff592c 12.7%, #401a99 98.1%);
	color: #fff;
	font-weight: 700;
}

.ip-howto-title {
	font-size: 1.125rem;
	color: var(--color-text-primary, #fcfcfd);
	margin: 0;
}

.ip-howto-desc {
	color: var(--color-text-body, #c0c7cf);
	font-size: 0.9375rem;
	line-height: 1.6;
	margin: 0;
}

/* ----- promo / CTA ----- */
.ip-promo {
	padding: 64px 0;
}

.ip-promo-grid {
	display: grid;
	grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
	gap: 48px;
	align-items: center;
}

.ip-promo-text {
	color: var(--color-text-body, #c0c7cf);
}

.ip-promo-brand {
	display: inline-flex;
	align-items: center;
	gap: 10px;
	color: var(--color-accent-orange, #ff592c);
	font-weight: 700;
	margin-bottom: 12px;
}

.ip-promo-body h2 {
	font-size: clamp(1.5rem, 3vw, 2.25rem);
	color: var(--color-text-primary, #fcfcfd);
	margin: 0 0 12px;
	line-height: 1.2;
}

.ip-promo-body p {
	margin: 0 0 12px;
}

.ip-promo-badges {
	margin-top: 18px;
	display: flex;
	flex-direction: column;
	gap: 10px;
}

.ip-promo-badges-row {
	display: flex;
	gap: 8px;
	flex-wrap: wrap;
}

.ip-pill {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	background: var(--color-bg-secondary, #1c1929);
	border: 1px solid var(--color-border, #272b30);
	color: var(--color-text-secondary, #b1b5c3);
	padding: 6px 12px;
	border-radius: 90px;
	font-size: 0.8125rem;
}

.ip-promo-image img {
	width: 100%;
	height: auto;
	border-radius: 16px;
	display: block;
}

/* ----- longform ----- */
.ip-longform {
	padding: 32px 0 96px;
}

.ip-longform-content {
	max-width: 820px;
	margin: 0 auto;
	color: var(--color-text-body, #c0c7cf);
	font-size: 1rem;
	line-height: 1.7;
}

.ip-longform-content h2,
.ip-longform-content h3 {
	color: var(--color-text-primary, #fcfcfd);
	margin-top: 28px;
	margin-bottom: 10px;
}

.ip-longform-content ul {
	padding-left: 22px;
}

.ip-longform-content li {
	margin-bottom: 6px;
}

/* ----- responsive ----- */
@media (max-width: 992px) {
	.ip-result-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
	.ip-howto-grid {
		grid-template-columns: 1fr;
	}
	.ip-promo-grid {
		grid-template-columns: 1fr;
	}
}

@media (max-width: 576px) {
	.ip-result-grid {
		grid-template-columns: 1fr;
	}
	.ip-lookup-form {
		flex-direction: column;
		border-radius: 16px;
		padding: 10px;
	}
	.ip-lookup-input {
		padding: 10px 14px;
	}
	.ip-lookup-submit {
		justify-content: center;
	}
}
