/* ==========================================================================
   Pages: page-specific layout and styles
   ========================================================================== */

/* Number Detail
   ========================================================================== */

.ktv-detail-hero {
	background-color: var(--wp--preset--color--bg-secondary, #F9FAFB);
	border-bottom: 1px solid var(--wp--preset--color--border, #E5E7EB);
	padding-block: var(--ktv-section-space-sm);
	padding-inline: var(--ktv-content-padding);
}

.ktv-detail-hero__inner {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: var(--ktv-space-20);
	max-width: 1200px;
	margin-inline: auto;
	text-align: center;
}

.ktv-detail-hero__number-row {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: var(--ktv-space-12);
}

.ktv-detail-hero__flag-link {
	flex-shrink: 0;
	line-height: 0;
}

.ktv-detail-hero__flag {
	width: 48px;
	height: 32px;
	border-radius: 4px;
	background-color: var(--ktv-color-surface-placeholder);
	object-fit: cover;
}

.ktv-detail-hero__number {
	font-size: var(--ktv-font-page);
	font-weight: 800;
	letter-spacing: -0.03em;
}

.ktv-detail-hero__desc {
	font-size: var(--ktv-font-body);
	color: var(--wp--preset--color--text-secondary, #6B7280);
	line-height: 1.6;
	max-width: 640px;
}

.ktv-detail-hero__actions {
	display: flex;
	gap: var(--ktv-space-12);
}

.ktv-detail-hero__badge-slot {
	display: flex;
	justify-content: center;
}

.ktv-detail-share {
	display: flex;
	align-items: center;
	gap: var(--ktv-space-12);
}

.ktv-detail-share__label {
	font-size: var(--ktv-font-2xs);
	font-weight: 700;
	letter-spacing: 0.1em;
	color: var(--wp--preset--color--text-tertiary, #6B7280);
	text-transform: uppercase;
}

.ktv-detail-share__icons {
	display: flex;
	align-items: center;
	gap: var(--ktv-space-8);
}

.ktv-detail-share__btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 36px;
	height: 36px;
	border-radius: 18px;
	border: 1px solid var(--wp--preset--color--border, #E5E7EB);
	background: var(--wp--preset--color--bg-secondary, #F9FAFB);
	color: var(--wp--preset--color--text-secondary, #6B7280);
	cursor: pointer;
	transition: border-color var(--ktv-transition), background-color var(--ktv-transition), color var(--ktv-transition);
}

.ktv-detail-share__btn:hover {
	border-color: var(--wp--preset--color--accent-primary, #53389E);
	background: var(--wp--preset--color--accent-primary-light, #EEF2FF);
	color: var(--wp--preset--color--accent-primary, #53389E);
}

.ktv-detail-share__btn .ktv-icon {
	flex-shrink: 0;
}

@media (max-width: 767px) {
	.ktv-detail-hero__number {
		font-size: var(--ktv-font-page);
	}

	.ktv-detail-hero__actions {
		flex-direction: column;
		width: 100%;
	}

	.ktv-detail-hero__actions .ktv-btn {
		justify-content: center;
	}
}

/* Search strip */

.ktv-detail-search {
	background-color: var(--wp--preset--color--bg-secondary, #F9FAFB);
	padding-block: var(--ktv-section-space-tight);
	padding-inline: var(--ktv-content-padding);
}

.ktv-detail-search__inner {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: var(--ktv-space-16);
	max-width: 1200px;
	margin-inline: auto;
}

.ktv-detail-search__title {
	font-size: var(--ktv-font-title-sm);
	font-weight: 600;
	color: var(--wp--preset--color--text-primary, #111827);
	text-align: center;
}

/* Content area */

.ktv-detail-content {
	padding-block: var(--ktv-section-space-sm);
	padding-inline: var(--ktv-content-padding);
}

.ktv-detail-content__inner {
	max-width: 1200px;
	margin-inline: auto;
	display: flex;
	flex-direction: column;
	gap: var(--ktv-section-space-sm);
}

/* Top Row: Stats Card + Ad */

.ktv-detail-top-row {
	display: flex;
	gap: var(--ktv-space-24);
}

.ktv-stats-card {
	width: 40%;
	flex-shrink: 0;
	display: flex;
	flex-direction: column;
	gap: var(--ktv-space-20);
	padding: var(--ktv-space-24);
	border: 1px solid var(--wp--preset--color--border, #E5E7EB);
	border-radius: var(--ktv-radius-xl);
}

.ktv-stats-card__title {
	font-size: var(--ktv-font-title-sm);
	font-weight: 700;
}

.ktv-stats-card__block {
	display: flex;
	flex-direction: column;
	gap: var(--ktv-space-8);
}

.ktv-stats-card__block--border {
	padding-top: var(--ktv-space-16);
	border-top: 1px solid var(--wp--preset--color--border, #E5E7EB);
}

.ktv-stats-card__block-title {
	font-size: var(--ktv-font-base);
	font-weight: 600;
	color: var(--wp--preset--color--text-primary, #111827);
}

.ktv-stats-card__row {
	display: flex;
	align-items: center;
	gap: var(--ktv-space-8);
}

.ktv-stats-card__label {
	font-size: var(--ktv-font-base);
	color: var(--wp--preset--color--text-secondary, #6B7280);
}

.ktv-stats-card__value {
	font-size: var(--ktv-font-base);
	font-weight: 600;
	color: var(--wp--preset--color--text-primary, #111827);
}

.ktv-stats-card__value--danger {
	color: var(--wp--preset--color--danger-text, #B91C1C);
}

.ktv-stats-card__value--safe {
	color: var(--wp--preset--color--success-text, #047857);
}

.ktv-stats-card__value--neutral {
	color: var(--wp--preset--color--neutral-text, #2563EB);
}

/* Star rating */

.ktv-rating-stars {
	display: inline-flex;
	align-items: center;
	gap: 2px;
	vertical-align: middle;
	color: #F59E0B;
}

.ktv-star {
	flex-shrink: 0;
}

.ktv-star--empty {
	opacity: 0.3;
}

.ktv-stats-card__rating-num {
	margin-left: var(--ktv-space-4);
}

[data-ktv-stat="rating"] {
	display: flex;
	align-items: center;
}

/* Rating bars */

.ktv-stats-card__bars {
	display: flex;
	flex-direction: column;
	gap: var(--ktv-space-8);
	padding-top: var(--ktv-space-16);
	border-top: 1px solid var(--wp--preset--color--border, #E5E7EB);
}

.ktv-stats-card__bars-title {
	font-size: var(--ktv-font-xs);
	font-weight: 600;
	color: var(--wp--preset--color--text-secondary, #6B7280);
}

.ktv-stats-card__bar-row {
	display: flex;
	align-items: center;
	gap: var(--ktv-space-8);
}

.ktv-stats-card__bar-label {
	font-size: var(--ktv-font-2xs);
	color: var(--wp--preset--color--text-secondary, #6B7280);
	width: 60px;
	flex-shrink: 0;
}

.ktv-stats-card__bar-track {
	flex: 1;
	height: 8px;
	background-color: var(--wp--preset--color--bg-tertiary, #F3F4F6);
	border-radius: 4px;
	overflow: hidden;
}

.ktv-stats-card__bar-fill {
	height: 100%;
	border-radius: 4px;
	transition: width 300ms ease;
}

.ktv-stats-card__bar-fill--danger {
	background-color: var(--wp--preset--color--danger, #EF4444);
}

.ktv-stats-card__bar-fill--warning {
	background-color: var(--wp--preset--color--warning, #F59E0B);
}

.ktv-stats-card__bar-fill--success {
	background-color: var(--wp--preset--color--success, #10B981);
}

/* Activity Heatmap */

.ktv-heatmap {
	display: flex;
	flex-direction: column;
	gap: var(--ktv-space-8);
	padding-top: var(--ktv-space-8);
}

.ktv-heatmap__grid {
	display: grid;
	grid-template-columns: 24px repeat(24, 1fr);
	grid-template-rows: auto repeat(7, 1fr);
	gap: 2px;
}

.ktv-heatmap__corner {
	/* Empty top-left corner */
}

.ktv-heatmap__hour {
	font-size: 9px;
	color: var(--wp--preset--color--text-tertiary, #9CA3AF);
	text-align: center;
	line-height: 1;
	padding-bottom: 2px;
}

.ktv-heatmap__day {
	font-size: var(--ktv-font-2xs, 10px);
	color: var(--wp--preset--color--text-secondary, #6B7280);
	display: flex;
	align-items: center;
	font-weight: 500;
	line-height: 1;
}

.ktv-heatmap__cell {
	aspect-ratio: 1;
	border-radius: 2px;
	transition: background-color var(--ktv-transition, 150ms ease);
	position: relative;
	cursor: default;
}

.ktv-heatmap__cell[data-level="0"] { background-color: var(--wp--preset--color--bg-tertiary, #F3F4F6); }
.ktv-heatmap__cell[data-level="1"] { background-color: #E0D6F5; }
.ktv-heatmap__cell[data-level="2"] { background-color: #B8A9E0; }
.ktv-heatmap__cell[data-level="3"] { background-color: #8B72C8; }
.ktv-heatmap__cell[data-level="4"] { background-color: #53389E; }

/* Tooltip on hover */
.ktv-heatmap__cell:hover::after {
	content: attr(data-count);
	position: absolute;
	bottom: calc(100% + 4px);
	left: 50%;
	transform: translateX(-50%);
	background-color: var(--wp--preset--color--text-primary, #111827);
	color: #fff;
	font-size: 10px;
	line-height: 1;
	padding: 3px 6px;
	border-radius: 4px;
	white-space: nowrap;
	pointer-events: none;
	z-index: 10;
}

/* Legend */

.ktv-heatmap__legend {
	display: flex;
	align-items: center;
	justify-content: flex-end;
	gap: 3px;
}

.ktv-heatmap__legend-label {
	font-size: 9px;
	color: var(--wp--preset--color--text-tertiary, #9CA3AF);
	padding-inline: 4px;
}

.ktv-heatmap__legend-cell {
	width: 10px;
	height: 10px;
	border-radius: 2px;
}

.ktv-heatmap__legend-cell[data-level="0"] { background-color: var(--wp--preset--color--bg-tertiary, #F3F4F6); }
.ktv-heatmap__legend-cell[data-level="1"] { background-color: #E0D6F5; }
.ktv-heatmap__legend-cell[data-level="2"] { background-color: #B8A9E0; }
.ktv-heatmap__legend-cell[data-level="3"] { background-color: #8B72C8; }
.ktv-heatmap__legend-cell[data-level="4"] { background-color: #53389E; }

@media (max-width: 479px) {
	.ktv-heatmap__grid {
		overflow-x: auto;
		-webkit-overflow-scrolling: touch;
		grid-template-columns: 24px repeat(24, 10px);
	}

	.ktv-heatmap__day,
	.ktv-heatmap__corner {
		position: sticky;
		left: 0;
		z-index: 1;
		background-color: var(--wp--preset--color--bg-primary, #fff);
	}

	.ktv-heatmap__corner {
		z-index: 2;
	}
}

@media (max-width: 1023px) {
	.ktv-detail-top-row {
		flex-direction: column;
	}

	.ktv-stats-card {
		width: 100%;
	}
}

/* Sections */

.ktv-detail-section {
	padding-top: var(--ktv-space-32);
	border-top: 1px solid var(--wp--preset--color--border, #E5E7EB);
}

.ktv-detail-section__title {
	font-size: var(--ktv-font-title-md);
	font-weight: 700;
	margin-bottom: var(--ktv-space-20);
}

/* Review form wrap */

.ktv-detail-form-wrap {
	display: flex;
	justify-content: center;
}

.ktv-detail-form-wrap .ktv-review-form {
	max-width: 720px;
	width: 100%;
}

.ktv-detail-reviews {
	display: flex;
	flex-direction: column;
}

.ktv-detail-comments-empty {
	width: 100%;
}

/* FAQ list */

.ktv-detail-faq-list {
	display: flex;
	flex-direction: column;
	gap: var(--ktv-space-12);
}

/* Blog section */

.ktv-detail-blog {
	padding-block: var(--ktv-section-space-sm);
	padding-inline: var(--ktv-content-padding);
}

.ktv-detail-blog__inner {
	max-width: 1200px;
	margin-inline: auto;
	display: flex;
	flex-direction: column;
	gap: var(--ktv-space-24);
}

.ktv-detail-blog__label {
	font-size: var(--ktv-font-base);
	font-weight: 600;
	color: var(--wp--preset--color--accent-primary, #53389E);
	letter-spacing: 0.03em;
}

.ktv-detail-blog__title {
	font-size: var(--ktv-font-2xl);
	font-weight: 700;
}

/* Prefix Detail
   ========================================================================== */

.ktv-prefix-hero {
	background-color: var(--wp--preset--color--bg-secondary, #F9FAFB);
	border-bottom: 1px solid var(--wp--preset--color--border, #E5E7EB);
	padding-block: var(--ktv-section-space-sm);
	padding-inline: var(--ktv-content-padding);
}

.ktv-prefix-hero__inner {
	max-width: 1200px;
	margin-inline: auto;
	display: flex;
	flex-direction: column;
	gap: var(--ktv-space-24);
}

.ktv-prefix-hero__row {
	display: flex;
	align-items: center;
	gap: var(--ktv-space-20);
}

.ktv-prefix-hero__flag {
	flex-shrink: 0;
	width: 72px;
	height: 48px;
	border-radius: 6px;
	background-color: var(--ktv-color-surface-placeholder);
	object-fit: cover;
}

.ktv-prefix-hero__texts {
	display: flex;
	flex-direction: column;
	gap: var(--ktv-space-4);
	min-width: 0;
}

.ktv-prefix-hero__title {
	margin: 0;
	font-size: var(--ktv-font-3xl);
	font-weight: 800;
	letter-spacing: -0.03em;
	line-height: 1.2;
}

.ktv-prefix-hero__meta {
	font-size: var(--ktv-font-body);
	color: var(--wp--preset--color--text-secondary, #6B7280);
	line-height: 1.5;
}

.ktv-prefix-content {
	padding-block: var(--ktv-section-space-sm);
	padding-inline: var(--ktv-content-padding);
}

.ktv-prefix-content__inner {
	display: flex;
	gap: var(--ktv-space-32);
	max-width: 1200px;
	margin-inline: auto;
}

.ktv-prefix-content__main {
	flex: 1;
	display: flex;
	flex-direction: column;
	gap: var(--ktv-space-32);
}

.ktv-prefix-content__sidebar {
	width: 360px;
	flex-shrink: 0;
	display: flex;
	flex-direction: column;
	gap: var(--ktv-space-16);
}

.ktv-prefix-about {
	display: flex;
	flex-direction: column;
	gap: var(--ktv-space-16);
}

.ktv-prefix-about__title {
	font-size: var(--ktv-font-title-md);
	font-weight: 700;
}

.ktv-prefix-about__body {
	font-size: var(--ktv-font-body);
	line-height: 1.7;
	color: var(--wp--preset--color--text-secondary, #6B7280);
}

.ktv-prefix-about__body p + p {
	margin-top: var(--ktv-space-16);
}

.ktv-prefix-data-card {
	background-color: var(--wp--preset--color--bg-primary, #fff);
	border: 1px solid var(--wp--preset--color--border, #E5E7EB);
	border-radius: var(--ktv-radius-xl);
	overflow: hidden;
}

.ktv-prefix-data-card__header {
	padding: var(--ktv-space-16) var(--ktv-space-24);
	border-bottom: 1px solid var(--wp--preset--color--border, #E5E7EB);
}

.ktv-prefix-data-card__title {
	font-size: var(--ktv-font-lg);
	font-weight: 700;
}

.ktv-prefix-data-card__row {
	display: grid;
	grid-template-columns: minmax(170px, 0.42fr) 1fr;
	align-items: start;
	gap: var(--ktv-space-16);
	padding: var(--ktv-space-14) var(--ktv-space-24);
	border-bottom: 1px solid var(--wp--preset--color--border, #E5E7EB);
}

.ktv-prefix-data-card__row:last-child {
	border-bottom: none;
}

.ktv-prefix-data-card__label {
	font-size: var(--ktv-font-base);
	color: var(--wp--preset--color--text-secondary, #6B7280);
}

.ktv-prefix-data-card__value {
	font-size: var(--ktv-font-base);
	font-weight: 600;
	color: var(--wp--preset--color--text-primary, #111827);
	line-height: 1.45;
}

.ktv-prefix-info-card {
	background-color: var(--wp--preset--color--bg-primary, #fff);
	border: 1px solid var(--wp--preset--color--border, #E5E7EB);
	border-radius: var(--ktv-radius-xl);
	overflow: hidden;
}

.ktv-prefix-info-card__header {
	padding: var(--ktv-space-16) var(--ktv-space-20);
	border-bottom: 1px solid var(--wp--preset--color--border, #E5E7EB);
}

.ktv-prefix-info-card__title {
	font-size: var(--ktv-font-md);
	font-weight: 700;
}

.ktv-prefix-info-card__row {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: var(--ktv-space-8);
	padding: var(--ktv-space-14) var(--ktv-space-20);
	border-bottom: 1px solid var(--wp--preset--color--border, #E5E7EB);
}

.ktv-prefix-info-card__row:last-child {
	border-bottom: none;
}

.ktv-prefix-info-card__label {
	font-size: var(--ktv-font-xs);
	color: var(--wp--preset--color--text-secondary, #6B7280);
}

.ktv-prefix-info-card__value {
	font-size: var(--ktv-font-xs);
	font-weight: 600;
	color: var(--wp--preset--color--text-primary, #111827);
	text-align: right;
}

.ktv-prefix-neighbours {
	display: flex;
	flex-direction: column;
	gap: var(--ktv-space-12);
}

.ktv-prefix-neighbours__title {
	font-size: var(--ktv-font-md);
	font-weight: 700;
}

.ktv-prefix-neighbours__list {
	display: flex;
	flex-wrap: wrap;
	gap: var(--ktv-space-8);
}

.ktv-prefix-neighbours__chip {
	display: inline-flex;
	align-items: center;
	padding: var(--ktv-space-8) var(--ktv-space-14);
	border: 1px solid var(--wp--preset--color--border, #E5E7EB);
	border-radius: var(--ktv-radius-pill);
	font-size: var(--ktv-font-xs);
	font-weight: 500;
	color: var(--wp--preset--color--text-primary, #111827);
	text-decoration: none;
	transition: background-color var(--ktv-transition), border-color var(--ktv-transition);
}

.ktv-prefix-neighbours__chip:hover {
	background-color: var(--wp--preset--color--bg-secondary, #F9FAFB);
	border-color: var(--wp--preset--color--accent-primary-light, #EBE9FE);
	color: var(--wp--preset--color--text-primary, #111827);
}

/* Dialing guide */

.ktv-prefix-dialing {
	display: flex;
	flex-direction: column;
	gap: var(--ktv-space-20);
}

.ktv-prefix-dialing__title {
	font-size: var(--ktv-font-title-md);
	font-weight: 700;
}

.ktv-prefix-dialing__steps {
	display: flex;
	align-items: center;
	gap: var(--ktv-space-12);
	flex-wrap: wrap;
}

.ktv-prefix-dialing__step {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: var(--ktv-space-4);
	padding: var(--ktv-space-16) var(--ktv-space-24);
	border: 1px solid var(--wp--preset--color--border, #E5E7EB);
	border-radius: var(--ktv-radius-lg);
	background-color: var(--wp--preset--color--bg-secondary, #F9FAFB);
	min-width: 100px;
	text-align: center;
}

.ktv-prefix-dialing__step-value {
	font-size: var(--ktv-font-xl);
	font-weight: 800;
	color: var(--wp--preset--color--accent-primary, #53389E);
}

.ktv-prefix-dialing__step-label {
	font-size: var(--ktv-font-2xs);
	color: var(--wp--preset--color--text-secondary, #6B7280);
}

.ktv-prefix-dialing__arrow {
	font-size: var(--ktv-font-xl);
	color: var(--wp--preset--color--text-tertiary, #6B7280);
}

.ktv-prefix-dialing__examples {
	display: flex;
	flex-direction: column;
	gap: var(--ktv-space-8);
}

.ktv-prefix-dialing__example {
	display: flex;
	align-items: center;
	gap: var(--ktv-space-8);
	font-size: var(--ktv-font-base);
}

.ktv-prefix-dialing__example-label {
	color: var(--wp--preset--color--text-secondary, #6B7280);
}

.ktv-prefix-dialing__example-value {
	font-weight: 600;
	color: var(--wp--preset--color--text-primary, #111827);
	font-family: var(--ktv-font-mono, monospace);
}

.ktv-prefix-dialing__info {
	display: flex;
	flex-direction: column;
	gap: var(--ktv-space-6);
}

.ktv-prefix-dialing__info-row {
	display: flex;
	align-items: center;
	gap: var(--ktv-space-8);
	font-size: var(--ktv-font-sm);
}

.ktv-prefix-dialing__info-label {
	color: var(--wp--preset--color--text-secondary, #6B7280);
}

.ktv-prefix-dialing__info-value {
	font-weight: 600;
	color: var(--wp--preset--color--text-primary, #111827);
}

/* Number types table */

.ktv-prefix-number-types {
	display: flex;
	flex-direction: column;
	gap: var(--ktv-space-16);
}

.ktv-prefix-number-types__title {
	font-size: var(--ktv-font-title-md);
	font-weight: 700;
}

.ktv-prefix-number-types__table-wrap {
	overflow-x: auto;
	-webkit-overflow-scrolling: touch;
}

.ktv-prefix-number-types__table {
	width: 100%;
	border-collapse: collapse;
	font-size: var(--ktv-font-base);
}

.ktv-prefix-number-types__table th {
	text-align: left;
	font-size: var(--ktv-font-xs);
	font-weight: 600;
	color: var(--wp--preset--color--text-secondary, #6B7280);
	padding: var(--ktv-space-12) var(--ktv-space-16);
	border-bottom: 2px solid var(--wp--preset--color--border, #E5E7EB);
}

.ktv-prefix-number-types__table td {
	padding: var(--ktv-space-12) var(--ktv-space-16);
	border-bottom: 1px solid var(--wp--preset--color--border, #E5E7EB);
	color: var(--wp--preset--color--text-primary, #111827);
}

.ktv-prefix-number-types__table tr:last-child td {
	border-bottom: none;
}

.ktv-prefix-number-types__table td:last-child {
	font-family: var(--ktv-font-mono, monospace);
	font-weight: 500;
}

/* Emergency numbers */

.ktv-prefix-emergency {
	display: flex;
	flex-direction: column;
	gap: var(--ktv-space-16);
}

.ktv-prefix-emergency__title {
	font-size: var(--ktv-font-title-md);
	font-weight: 700;
}

.ktv-prefix-emergency__card {
	border: 1px solid var(--wp--preset--color--border, #E5E7EB);
	border-radius: var(--ktv-radius-lg);
	padding: var(--ktv-space-20);
	background-color: var(--wp--preset--color--bg-primary, #fff);
}

.ktv-prefix-emergency__list {
	list-style: none;
	padding: 0;
	margin: 0;
	display: flex;
	flex-direction: column;
	gap: var(--ktv-space-10);
}

.ktv-prefix-emergency__item {
	display: flex;
	align-items: center;
	gap: var(--ktv-space-12);
	font-size: var(--ktv-font-base);
}

.ktv-prefix-emergency__number {
	font-size: var(--ktv-font-lg);
	font-weight: 800;
	color: var(--wp--preset--color--text-primary, #111827);
	min-width: 48px;
	font-family: var(--ktv-font-mono, monospace);
}

.ktv-prefix-emergency__desc {
	color: var(--wp--preset--color--text-secondary, #6B7280);
}

/* Operators card (sidebar) */

.ktv-prefix-operators {
	display: flex;
	flex-direction: column;
	gap: var(--ktv-space-12);
}

.ktv-prefix-operators__title {
	font-size: var(--ktv-font-md);
	font-weight: 700;
}

.ktv-prefix-operators__list {
	display: flex;
	flex-direction: column;
	gap: var(--ktv-space-6);
}

.ktv-prefix-operators__item {
	display: flex;
	justify-content: space-between;
	align-items: flex-start;
	gap: var(--ktv-space-8);
	padding: var(--ktv-space-8) 0;
	border-bottom: 1px solid var(--wp--preset--color--border, #E5E7EB);
	font-size: var(--ktv-font-xs);
}

.ktv-prefix-operators__item:last-child {
	border-bottom: none;
}

.ktv-prefix-operators__item--overflow {
	display: none;
}

.ktv-prefix-operators.is-expanded .ktv-prefix-operators__item--overflow {
	display: flex;
}

.ktv-prefix-operators__name {
	font-weight: 600;
	color: var(--wp--preset--color--text-primary, #111827);
	flex-shrink: 0;
}

.ktv-prefix-operators__prefixes {
	color: var(--wp--preset--color--text-secondary, #6B7280);
	text-align: right;
	font-family: var(--ktv-font-mono, monospace);
	font-size: var(--ktv-font-2xs);
}

.ktv-prefix-operators__toggle {
	display: inline-flex;
	align-items: center;
	gap: var(--ktv-space-4);
	padding: var(--ktv-space-8) 0;
	border: none;
	background: none;
	cursor: pointer;
	font-size: var(--ktv-font-xs);
	font-weight: 500;
	color: var(--wp--preset--color--accent-primary, #53389E);
	font-family: inherit;
}

.ktv-prefix-operators__toggle:hover {
	text-decoration: underline;
}

/* Prefix FAQ */

.ktv-prefix-faq {
	padding-block: var(--ktv-section-space-sm);
	padding-inline: var(--ktv-content-padding);
}

.ktv-prefix-faq__inner {
	max-width: 1200px;
	margin-inline: auto;
	display: flex;
	flex-direction: column;
	gap: var(--ktv-space-24);
}

.ktv-prefix-faq__title {
	font-size: var(--ktv-font-title-md);
	font-weight: 700;
}

.ktv-prefix-faq__list {
	display: flex;
	flex-direction: column;
	gap: var(--ktv-space-12);
}

@media (max-width: 767px) {
	.ktv-prefix-dialing__steps {
		flex-direction: column;
		align-items: stretch;
	}

	.ktv-prefix-dialing__arrow {
		text-align: center;
		transform: rotate(90deg);
	}

	.ktv-prefix-dialing__example {
		flex-direction: column;
		align-items: flex-start;
		gap: var(--ktv-space-4);
	}

	.ktv-prefix-number-types__table thead {
		display: none;
	}

	.ktv-prefix-number-types__table,
	.ktv-prefix-number-types__table tbody,
	.ktv-prefix-number-types__table tr,
	.ktv-prefix-number-types__table td {
		display: block;
	}

	.ktv-prefix-number-types__table tr {
		padding: var(--ktv-space-12) 0;
		border-bottom: 1px solid var(--wp--preset--color--border, #E5E7EB);
	}

	.ktv-prefix-number-types__table tr:last-child {
		border-bottom: none;
	}

	.ktv-prefix-number-types__table td {
		padding: var(--ktv-space-4) 0;
		border-bottom: none;
	}

	.ktv-prefix-number-types__table td::before {
		content: attr(data-label) ": ";
		font-weight: 600;
		color: var(--wp--preset--color--text-secondary, #6B7280);
	}

	.ktv-prefix-dialing__info-row {
		flex-direction: column;
		align-items: flex-start;
		gap: var(--ktv-space-2);
	}
}

@media (max-width: 1023px) {
	.ktv-prefix-content__inner {
		flex-direction: column;
	}

	.ktv-prefix-content__sidebar {
		width: 100%;
	}
}

@media (max-width: 767px) {
	.ktv-prefix-hero__row {
		align-items: flex-start;
	}

	.ktv-prefix-hero__title {
		font-size: var(--ktv-font-3xl);
	}

	.ktv-prefix-hero__meta {
		font-size: var(--ktv-font-body);
	}

	.ktv-prefix-data-card__row {
		grid-template-columns: 1fr;
		gap: var(--ktv-space-6);
	}

	.ktv-prefix-info-card__row {
		align-items: flex-start;
		flex-direction: column;
		gap: var(--ktv-space-4);
	}

	.ktv-prefix-info-card__value {
		text-align: left;
	}
}

/* Prefixes Overview
   ========================================================================== */

.ktv-prefixes-hero {
	background-color: var(--wp--preset--color--bg-secondary, #F9FAFB);
	border-bottom: 1px solid var(--wp--preset--color--border, #E5E7EB);
	padding-block: var(--ktv-section-space-sm);
	padding-inline: var(--ktv-content-padding);
}

.ktv-prefixes-hero__inner {
	max-width: 1200px;
	margin-inline: auto;
	display: flex;
	flex-direction: column;
	gap: var(--ktv-space-16);
}

.ktv-prefixes-hero__title {
	font-size: var(--ktv-font-3xl);
	font-weight: 800;
	letter-spacing: -0.03em;
	line-height: 1.2;
}

.ktv-prefixes-hero__desc {
	max-width: 800px;
	font-size: var(--ktv-font-md);
	line-height: 1.6;
	color: var(--wp--preset--color--text-secondary, #6B7280);
}

.ktv-prefixes-content {
	padding-block: var(--ktv-section-space-sm);
	padding-inline: var(--ktv-content-padding);
}

.ktv-prefixes-content__inner {
	max-width: 1200px;
	margin-inline: auto;
	display: flex;
	flex-direction: column;
	gap: var(--ktv-space-32);
}

.ktv-prefixes-toolbar {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: var(--ktv-space-16);
}

.ktv-prefixes-filter {
	display: flex;
	align-items: center;
	flex-wrap: wrap;
	gap: var(--ktv-space-8);
}

.ktv-prefixes-search {
	position: relative;
	flex-shrink: 0;
}

.ktv-prefixes-search__icon {
	position: absolute;
	left: var(--ktv-space-12);
	top: 50%;
	transform: translateY(-50%);
	color: var(--wp--preset--color--text-muted, #6B7280);
	pointer-events: none;
}

.ktv-prefixes-search__input {
	width: 200px;
	padding: var(--ktv-space-8) var(--ktv-space-12) var(--ktv-space-8) calc(var(--ktv-space-12) + 16px + var(--ktv-space-8));
	border: 1px solid var(--wp--preset--color--border, #E5E7EB);
	border-radius: var(--ktv-radius-pill);
	background-color: var(--wp--preset--color--bg-primary, #fff);
	font-size: var(--ktv-font-xs);
	font-family: inherit;
	color: var(--wp--preset--color--text-primary, #111827);
	outline: none;
	transition: border-color var(--ktv-transition), box-shadow var(--ktv-transition);
}

.ktv-prefixes-search__input::placeholder {
	color: var(--wp--preset--color--text-muted, #6B7280);
}

.ktv-prefixes-search__input:focus {
	border-color: var(--wp--preset--color--accent-primary, #53389E);
	box-shadow: 0 0 0 3px rgba(83, 56, 158, 0.1);
}

.ktv-prefixes-chip {
	display: inline-flex;
	align-items: center;
	padding: var(--ktv-space-8) var(--ktv-space-16);
	border-radius: var(--ktv-radius-pill);
	background-color: var(--wp--preset--color--bg-tertiary, #F3F4F6);
	color: var(--wp--preset--color--text-secondary, #4B5563);
	font-size: var(--ktv-font-xs);
	font-weight: 500;
	text-decoration: none;
	transition: background-color var(--ktv-transition), color var(--ktv-transition);
}

.ktv-prefixes-chip:hover {
	background-color: var(--wp--preset--color--bg-secondary, #F9FAFB);
	color: var(--wp--preset--color--text-primary, #111827);
}

.ktv-prefixes-chip--active,
.ktv-prefixes-chip--active:hover {
	background-color: var(--wp--preset--color--accent-primary, #53389E);
	color: var(--wp--preset--color--text-on-dark, #fff);
	font-weight: 600;
}

.ktv-prefixes-content.is-loading .ktv-country-grid,
.ktv-prefixes-content.is-loading .ktv-prefixes-pagination {
	opacity: 0.55;
}

.ktv-prefixes-content.is-loading .ktv-prefixes-toolbar {
	pointer-events: none;
}

.ktv-prefixes-content .ktv-country-grid {
	margin-top: 0;
}

.ktv-prefixes-content .ktv-empty-state {
	grid-column: 1 / -1;
	border: 1px solid var(--wp--preset--color--border, #E5E7EB);
	border-radius: var(--ktv-radius-lg);
}

.ktv-prefixes-pagination {
	display: flex;
	justify-content: center;
}

@media (max-width: 767px) {
	.ktv-prefixes-hero__title {
		font-size: var(--ktv-font-3xl);
	}

	.ktv-prefixes-hero__desc {
		font-size: var(--ktv-font-md);
	}

	.ktv-prefixes-toolbar {
		flex-direction: column;
		align-items: stretch;
	}

	.ktv-prefixes-search__input {
		width: 100%;
	}
}

/* Leaderboard
   ========================================================================== */

.ktv-leaderboard-hero {
	background-color: var(--wp--preset--color--bg-secondary, #F9FAFB);
	border-bottom: 1px solid var(--wp--preset--color--border, #E5E7EB);
	padding-block: var(--ktv-section-space-sm);
	padding-inline: var(--ktv-content-padding);
	text-align: center;
}

.ktv-leaderboard-hero__inner {
	max-width: 760px;
	margin-inline: auto;
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: var(--ktv-space-16);
}

.ktv-leaderboard-hero .ktv-breadcrumbs {
	justify-content: center;
	flex-wrap: wrap;
}

.ktv-leaderboard-hero__title {
	font-size: var(--ktv-font-3xl);
	font-weight: 800;
	line-height: 1.2;
	letter-spacing: -0.03em;
	margin: 0;
	color: var(--wp--preset--color--text-primary, #111827);
}

.ktv-leaderboard-hero__desc {
	max-width: 600px;
	font-size: var(--ktv-font-md);
	line-height: 1.6;
	margin: 0;
	color: var(--wp--preset--color--text-secondary, #6B7280);
}

.ktv-leaderboard-hero .ktv-tabs {
	justify-content: center;
	margin-top: var(--ktv-space-8);
	flex-wrap: wrap;
}

.ktv-leaderboard-content {
	padding-block: var(--ktv-section-space-sm);
	padding-inline: var(--ktv-content-padding);
}

.ktv-leaderboard-content__inner {
	max-width: 760px;
	margin-inline: auto;
}

.ktv-leaderboard-list {
	display: flex;
	flex-direction: column;
	gap: var(--ktv-space-8);
}

.ktv-leaderboard-item {
	display: grid;
	grid-template-columns: 3rem 1fr auto;
	align-items: center;
	gap: var(--ktv-space-16);
	padding: var(--ktv-space-16) var(--ktv-space-20);
	background-color: var(--wp--preset--color--bg-primary, #fff);
	border: 1px solid var(--wp--preset--color--border, #E5E7EB);
	border-radius: var(--ktv-radius-lg);
	text-decoration: none;
	color: inherit;
	transition: border-color var(--ktv-transition), box-shadow var(--ktv-transition), transform var(--ktv-transition);
}

.ktv-leaderboard-item:hover {
	border-color: var(--wp--preset--color--accent-primary-light, #EBE9FE);
	box-shadow: var(--ktv-shadow-sm);
	transform: translateY(-1px);
	color: inherit;
}

/* Rank badge */

.ktv-leaderboard-item__rank {
	width: 3rem;
	height: 3rem;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: var(--ktv-font-sm);
	font-weight: 700;
	color: var(--wp--preset--color--text-tertiary, #6B7280);
	background-color: var(--wp--preset--color--bg-secondary, #F9FAFB);
	border-radius: var(--ktv-radius-md);
	flex-shrink: 0;
}

/* Top 3 — zlato / stříbro / bronz */

.ktv-leaderboard-item--rank-1 {
	border-color: #FDE68A;
}

.ktv-leaderboard-item--rank-1 .ktv-leaderboard-item__rank {
	background-color: #FEF9C3;
	color: #854D0E;
	font-size: var(--ktv-font-md);
}

.ktv-leaderboard-item--rank-2 {
	border-color: #D1D5DB;
}

.ktv-leaderboard-item--rank-2 .ktv-leaderboard-item__rank {
	background-color: #F3F4F6;
	color: #374151;
	font-size: var(--ktv-font-md);
}

.ktv-leaderboard-item--rank-3 .ktv-leaderboard-item__rank {
	background-color: #FEF3C7;
	color: #92400E;
	font-size: var(--ktv-font-md);
}

/* Body (číslo + excerpt) */

.ktv-leaderboard-item__body {
	display: flex;
	flex-direction: column;
	gap: var(--ktv-space-4);
	min-width: 0;
}

.ktv-leaderboard-item__number {
	font-size: var(--ktv-font-md);
	font-weight: 600;
	color: var(--wp--preset--color--text-primary, #111827);
}

.ktv-leaderboard-item__excerpt {
	font-size: var(--ktv-font-sm);
	color: var(--wp--preset--color--text-secondary, #6B7280);
	line-height: 1.4;
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}

/* Meta (statistiky, hvězdičky) */

.ktv-leaderboard-item__meta {
	display: flex;
	align-items: center;
	gap: var(--ktv-space-16);
	flex-shrink: 0;
}

.ktv-leaderboard-item__stat {
	display: flex;
	align-items: center;
	gap: var(--ktv-space-4);
	font-size: var(--ktv-font-sm);
	color: var(--wp--preset--color--text-secondary, #6B7280);
}

.ktv-leaderboard-item__stat .ktv-icon {
	color: var(--wp--preset--color--text-tertiary, #6B7280);
}

@media (max-width: 599px) {
	.ktv-leaderboard-item {
		grid-template-columns: 2.5rem 1fr;
		row-gap: var(--ktv-space-8);
	}

	.ktv-leaderboard-item__rank {
		width: 2.5rem;
		height: 2.5rem;
		grid-row: 1 / 3;
		align-self: start;
		margin-top: var(--ktv-space-4);
	}

	.ktv-leaderboard-item__meta {
		grid-column: 2;
		gap: var(--ktv-space-12);
	}
}

/* Blog
   ========================================================================== */

.ktv-blog-hero {
	background-color: var(--wp--preset--color--bg-secondary, #F9FAFB);
	border-bottom: 1px solid var(--wp--preset--color--border, #E5E7EB);
	padding: var(--ktv-section-space-sm) 0;
}

.ktv-blog-hero__inner {
	max-width: 1440px;
	margin-inline: auto;
	padding-inline: var(--ktv-content-padding);
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: var(--ktv-space-16);
	text-align: center;
}

.ktv-blog-hero .ktv-breadcrumbs {
	justify-content: center;
	flex-wrap: wrap;
}

.ktv-blog-hero__title {
	font-size: var(--ktv-font-3xl);
	font-weight: 800;
	line-height: 1.2;
	letter-spacing: -0.03em;
	margin: 0;
	color: var(--wp--preset--color--text-primary, #111827);
}

.ktv-blog-hero__desc {
	max-width: 800px;
	font-size: var(--ktv-font-md);
	line-height: 1.6;
	margin: 0;
	color: var(--wp--preset--color--text-secondary, #6B7280);
}

.ktv-blog-content {
	padding: var(--ktv-section-space-sm) 0;
}

.ktv-blog-content__inner {
	max-width: 1440px;
	margin-inline: auto;
	padding-inline: var(--ktv-content-padding);
}

.ktv-blog-content__pagination {
	display: flex;
	justify-content: center;
	margin-top: var(--ktv-space-32);
}

.ktv-article {
	max-width: 800px;
	margin-inline: auto;
}

.ktv-article__header {
	margin-bottom: var(--ktv-space-32);
}

.ktv-article__title {
	font-size: var(--ktv-font-page);
	margin-bottom: var(--ktv-space-16);
}

.ktv-article__meta {
	display: flex;
	align-items: center;
	gap: var(--ktv-space-16);
	font-size: var(--ktv-font-sm);
	color: var(--wp--preset--color--text-secondary, #6B7280);
}

.ktv-article__cover {
	width: 100%;
	border-radius: var(--ktv-radius-lg);
	margin-bottom: var(--ktv-space-32);
}

.ktv-article__body {
	font-size: var(--ktv-font-md);
	line-height: 1.75;
	color: var(--wp--preset--color--text-primary, #111827);
}

.ktv-article__body h2 {
	margin-top: var(--ktv-space-32);
	margin-bottom: var(--ktv-space-16);
}

.ktv-article__body h3 {
	margin-top: var(--ktv-space-24);
	margin-bottom: var(--ktv-space-12);
}

.ktv-article__body p {
	margin-bottom: var(--ktv-space-16);
}

.ktv-article__body ul,
.ktv-article__body ol {
	margin-bottom: var(--ktv-space-16);
	padding-left: var(--ktv-space-24);
	list-style: disc;
}

.ktv-article__body ol {
	list-style: decimal;
}

.ktv-article__body li {
	margin-bottom: var(--ktv-space-8);
}

.ktv-article__body a {
	text-decoration: underline;
}

.ktv-article__body blockquote {
	border-left: 4px solid var(--wp--preset--color--accent-primary, #53389E);
	padding-left: var(--ktv-space-16);
	margin: var(--ktv-space-24) 0;
	color: var(--wp--preset--color--text-secondary, #6B7280);
	font-style: italic;
}

/* Blog detail – reading progress bar
   ========================================================================== */

.ktv-reading-progress {
	position: fixed;
	top: 0;
	left: 0;
	width: 0;
	height: 3px;
	background: var(--ktv-color-primary, #7c3aed);
	z-index: 9999;
	transition: none;
	pointer-events: none;
}

/* Blog detail (single) – BlogDetail design
   ========================================================================== */

.ktv-article--detail {
	max-width: none;
}

.ktv-article-breadcrumbs {
	padding: var(--ktv-space-12) 0;
	border-bottom: 1px solid var(--wp--preset--color--border, #E5E7EB);
}

.ktv-article-breadcrumbs__inner {
	max-width: 1440px;
	margin-inline: auto;
	padding-inline: var(--ktv-content-padding);
}

.ktv-article-breadcrumbs .ktv-breadcrumbs {
	display: flex;
	align-items: center;
	gap: var(--ktv-space-8);
	flex-wrap: wrap;
}

.ktv-article-hero {
	background-color: var(--wp--preset--color--bg-secondary, #F9FAFB);
	border-bottom: 1px solid var(--wp--preset--color--border, #E5E7EB);
	padding: var(--ktv-section-space-sm) 0;
}

.ktv-article-hero__inner {
	display: flex;
	align-items: center;
	gap: var(--ktv-section-space-sm);
}

.ktv-article-hero__left {
	flex: 1;
	min-width: 0;
	display: flex;
	flex-direction: column;
	gap: var(--ktv-space-24);
}

.ktv-article-hero__meta {
	display: flex;
	flex-direction: column;
	gap: var(--ktv-space-16);
}

.ktv-article-hero__category {
	font-size: var(--ktv-font-base);
	font-weight: 600;
	color: var(--wp--preset--color--accent-primary, #53389E);
}

.ktv-article-hero__title {
	font-size: var(--ktv-font-3xl);
	font-weight: 800;
	letter-spacing: -0.03em;
	line-height: 1.2;
	color: var(--wp--preset--color--text-primary, #111827);
	margin: 0;
}

.ktv-article-hero__perex {
	font-size: var(--ktv-font-lg);
	line-height: 1.6;
	color: var(--wp--preset--color--text-secondary, #6B7280);
	margin: 0;
}

.ktv-article-hero__author {
	display: flex;
	align-items: center;
	gap: var(--ktv-space-12);
}

.ktv-article-hero__avatar {
	width: 40px;
	height: 40px;
	border-radius: 50%;
	object-fit: cover;
	flex-shrink: 0;
}

.ktv-article-hero__author-info {
	display: flex;
	flex-direction: column;
	gap: var(--ktv-space-2);
}

.ktv-article-hero__author-name {
	font-size: var(--ktv-font-base);
	font-weight: 600;
	color: var(--wp--preset--color--text-primary, #111827);
}

.ktv-article-hero__author-date {
	font-size: var(--ktv-font-xs);
	color: var(--wp--preset--color--text-tertiary, #6B7280);
}

.ktv-article-hero__image {
	flex-shrink: 0;
	width: 100%;
	max-width: 560px;
}

.ktv-article-hero__img {
	width: 100%;
	height: 380px;
	object-fit: cover;
	border-radius: var(--ktv-radius-xl);
	display: block;
}

.ktv-article-main {
	padding: var(--ktv-section-space-sm) 0;
}

.ktv-article-main__inner {
	display: flex;
	gap: var(--ktv-section-space-sm);
	align-items: flex-start;
}

.ktv-article-sidebar {
	width: 280px;
	flex-shrink: 0;
	display: flex;
	flex-direction: column;
	gap: var(--ktv-space-32);
	position: sticky;
	top: calc(var(--ktv-header-height, 64px) + var(--ktv-space-16));
	max-height: calc(100vh - var(--ktv-header-height, 64px) - var(--ktv-space-32));
	overflow-y: auto;
}

.ktv-article-toc,
.ktv-article-share {
	display: flex;
	flex-direction: column;
	gap: var(--ktv-space-12);
}

.ktv-article-toc__label,
.ktv-article-share__label {
	font-size: var(--ktv-font-2xs);
	font-weight: 700;
	letter-spacing: 0.1em;
	color: var(--wp--preset--color--text-tertiary, #6B7280);
	margin: 0;
}

.ktv-article-toc__divider,
.ktv-article-share__divider {
	height: 1px;
	background: var(--wp--preset--color--border, #E5E7EB);
	margin: 0;
	flex-shrink: 0;
}

.ktv-article-toc__list {
	list-style: none;
	padding: 0;
	margin: 0;
	display: flex;
	flex-direction: column;
	gap: var(--ktv-space-12);
}

.ktv-article-toc__link {
	font-size: var(--ktv-font-xs);
	color: var(--wp--preset--color--text-secondary, #6B7280);
	text-decoration: none;
	transition: color var(--ktv-transition);
}

.ktv-article-toc__link:hover,
.ktv-article-toc__link--active {
	color: var(--wp--preset--color--accent-primary, #53389E);
	font-weight: 500;
}

.ktv-article-share__icons {
	display: flex;
	align-items: center;
	gap: var(--ktv-space-8);
}

.ktv-article-share__btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 36px;
	height: 36px;
	border-radius: 18px;
	border: 1px solid var(--wp--preset--color--border, #E5E7EB);
	background: var(--wp--preset--color--bg-secondary, #F9FAFB);
	color: var(--wp--preset--color--text-secondary, #6B7280);
	transition: border-color var(--ktv-transition), background-color var(--ktv-transition);
}

.ktv-article-share__btn:hover {
	border-color: var(--wp--preset--color--accent-primary, #53389E);
	background: var(--wp--preset--color--accent-primary-light, #EEF2FF);
	color: var(--wp--preset--color--accent-primary, #53389E);
}

.ktv-article-share__btn .ktv-icon {
	flex-shrink: 0;
}

.ktv-article-sidebar-cta {
	background: var(--ktv-color-surface-strong);
	color: var(--wp--preset--color--text-on-dark, #fff);
	border-radius: var(--ktv-radius-lg);
	padding: var(--ktv-space-20);
	display: flex;
	flex-direction: column;
	gap: var(--ktv-space-12);
}

.ktv-article-sidebar-cta__title {
	font-size: var(--ktv-font-body);
	font-weight: 700;
	line-height: 1.3;
	margin: 0;
	color: var(--wp--preset--color--text-on-dark, #fff);
}

.ktv-article-sidebar-cta__desc {
	font-size: var(--ktv-font-xs);
	line-height: 1.5;
	margin: 0;
	color: var(--ktv-color-text-on-dark-muted);
}

.ktv-article-sidebar-cta__btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: var(--ktv-space-8);
	padding: var(--ktv-space-12) var(--ktv-space-20);
	border-radius: var(--ktv-radius-md);
	background: var(--wp--preset--color--accent-primary, #53389E);
	color: var(--wp--preset--color--text-on-dark, #fff);
	font-size: var(--ktv-font-body);
	font-weight: 600;
	text-decoration: none;
	transition: background-color var(--ktv-transition), opacity var(--ktv-transition);
}

.ktv-article-sidebar-cta__btn:hover {
	opacity: 0.95;
	background: var(--wp--preset--color--accent-primary-hover, #4F46E5);
	color: var(--wp--preset--color--text-on-dark, #fff);
}

.ktv-article-sidebar-cta__btn .ktv-icon {
	flex-shrink: 0;
}

.ktv-article-body-wrap {
	flex: 1;
	min-width: 0;
	max-width: 720px;
}

.ktv-article--detail .ktv-article__body h2 {
	font-size: var(--ktv-font-2xl);
	line-height: 1.3;
	margin-top: var(--ktv-space-32);
	margin-bottom: var(--ktv-space-16);
}

.ktv-article--detail .ktv-article__body h2:first-child {
	margin-top: 0;
}

.ktv-article--detail .ktv-article__body [id] {
	scroll-margin-top: calc(var(--ktv-header-height, 64px) + var(--ktv-space-16));
}

.ktv-article--detail .ktv-article__body blockquote {
	border-left-width: 3px;
	padding: var(--ktv-space-20) var(--ktv-space-24);
	margin: var(--ktv-space-24) 0;
	border-radius: 0 var(--ktv-radius-md) var(--ktv-radius-md) 0;
	background: var(--wp--preset--color--accent-primary-bg, #F5F3FF);
	font-weight: 500;
	font-style: italic;
	color: var(--wp--preset--color--text-primary, #111827);
}

@media (max-width: 1024px) {
	.ktv-blog-hero__title {
		font-size: var(--ktv-font-3xl);
	}

	.ktv-article-hero__inner {
		flex-direction: column;
		align-items: stretch;
	}

	.ktv-article-hero__image {
		max-width: none;
	}

	.ktv-article-hero__img {
		height: 280px;
	}

	.ktv-article-main__inner {
		flex-direction: column;
	}

	.ktv-article-sidebar {
		width: 100%;
		position: static;
		flex-direction: row;
		flex-wrap: wrap;
		gap: var(--ktv-space-24);
	}

	.ktv-article-toc,
	.ktv-article-share {
		flex: 1;
		min-width: 200px;
	}

	.ktv-article-sidebar-cta {
		width: 100%;
	}

	.ktv-article-body-wrap {
		max-width: none;
	}
}

@media (max-width: 767px) {
	.ktv-blog-hero__title {
		font-size: var(--ktv-font-3xl);
	}
}

/* About
   ========================================================================== */

.ktv-about {
	display: flex;
	align-items: center;
	gap: var(--ktv-section-space-md);
}

.ktv-about__content {
	flex: 1;
	display: flex;
	flex-direction: column;
	gap: var(--ktv-space-24);
}

.ktv-about__title {
	font-size: var(--ktv-font-2xl);
	font-weight: 700;
	color: var(--wp--preset--color--text-primary, #111827);
}

.ktv-about__text {
	display: flex;
	flex-direction: column;
	gap: var(--ktv-space-16);
	font-size: var(--ktv-font-body);
	color: var(--wp--preset--color--text-secondary, #6B7280);
	line-height: 1.7;
}

.ktv-about__image {
	width: 480px;
	flex-shrink: 0;
}

.ktv-about__image img {
	width: 100%;
	height: auto;
	display: block;
	border-radius: var(--ktv-radius-xl);
	background-color: var(--wp--preset--color--bg-tertiary, #F3F4F6);
}

@media (max-width: 1023px) {
	.ktv-about {
		flex-direction: column;
		gap: var(--ktv-space-40);
	}

	.ktv-about__image {
		width: 100%;
	}

	.ktv-about__image img {
		height: auto;
	}
}

/* FAQ
   ========================================================================== */

.ktv-faq-wrap {
	max-width: 800px;
	margin-inline: auto;
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: var(--ktv-space-32);
}

.ktv-faq-wrap .ktv-accordion-list {
	width: 100%;
}

/* Blog Preview
   ========================================================================== */

.ktv-blog-preview__top {
	display: flex;
	align-items: flex-start;
	justify-content: space-between;
	gap: var(--ktv-space-24);
	margin-bottom: var(--ktv-space-32);
}

.ktv-blog-preview__info {
	display: flex;
	flex-direction: column;
	gap: var(--ktv-space-8);
}

.ktv-blog-preview__title {
	font-size: var(--ktv-font-2xl);
	font-weight: 700;
	color: var(--wp--preset--color--text-primary, #111827);
}

.ktv-blog-preview__subtitle {
	font-size: var(--ktv-font-body);
	color: var(--wp--preset--color--text-secondary, #6B7280);
	line-height: 1.5;
	max-width: 560px;
}

@media (max-width: 767px) {
	.ktv-blog-preview__top {
		flex-direction: column;
	}
}

/* 404
   ========================================================================== */

.ktv-404 {
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	gap: var(--ktv-space-32);
	min-height: 600px;
	padding-block: var(--ktv-section-space-lg);
	padding-inline: var(--ktv-content-padding);
	text-align: center;
}

.ktv-404__code {
	font-size: var(--ktv-font-display);
	font-weight: 800;
	color: var(--wp--preset--color--bg-tertiary, #F3F4F6);
	line-height: 1;
}

.ktv-404__title {
	font-size: var(--ktv-font-3xl);
}

.ktv-404__desc {
	font-size: var(--ktv-font-md);
	color: var(--wp--preset--color--text-secondary, #6B7280);
	max-width: 480px;
}

/* Static Pages (Privacy, Terms, Cookies, …)
   ========================================================================== */

.ktv-page-wrap {
	padding-block: var(--ktv-section-space-md);
	padding-inline: var(--ktv-content-padding);
}

.ktv-page {
	max-width: 760px;
	margin-inline: auto;
}

.ktv-page__title {
	font-size: var(--ktv-font-page);
	font-weight: 800;
	letter-spacing: -0.02em;
	line-height: 1.15;
	margin-bottom: var(--ktv-space-32);
	padding-bottom: var(--ktv-space-32);
	border-bottom: 1px solid var(--wp--preset--color--border, #E5E7EB);
}

.ktv-page__content {
	font-size: var(--ktv-font-body);
	line-height: 1.75;
	color: var(--wp--preset--color--text-primary, #111827);
}

/* Paragraphs */

.ktv-page__content p {
	margin-bottom: var(--ktv-space-16);
}

.ktv-page__content p:last-child {
	margin-bottom: 0;
}

/* Headings */

.ktv-page__content h2 {
	font-size: var(--ktv-font-2xl);
	font-weight: 700;
	letter-spacing: -0.01em;
	line-height: 1.25;
	margin-top: var(--ktv-space-48);
	margin-bottom: var(--ktv-space-16);
}

.ktv-page__content h2.wp-block-heading:first-child {
	margin-top: 0;
}

.ktv-page__content h3 {
	font-size: var(--ktv-font-xl);
	font-weight: 700;
	line-height: 1.3;
	margin-top: var(--ktv-space-32);
	margin-bottom: var(--ktv-space-12);
}

/* Lists */

.ktv-page__content ul.wp-block-list {
	list-style: disc;
	padding-left: var(--ktv-space-24);
	margin-bottom: var(--ktv-space-16);
}

.ktv-page__content ol.wp-block-list {
	list-style: decimal;
	padding-left: var(--ktv-space-24);
	margin-bottom: var(--ktv-space-16);
}

.ktv-page__content li {
	margin-bottom: var(--ktv-space-8);
	line-height: 1.65;
}

.ktv-page__content li:last-child {
	margin-bottom: 0;
}

/* Links */

.ktv-page__content a {
	text-decoration: underline;
	text-underline-offset: 3px;
}

/* Responsive */

@media (max-width: 767px) {
	.ktv-page-wrap {
		padding-block: var(--ktv-section-space-sm);
	}

	.ktv-page__title {
		font-size: var(--ktv-font-3xl);
		margin-bottom: var(--ktv-space-24);
		padding-bottom: var(--ktv-space-24);
	}

	.ktv-page__content h2 {
		font-size: var(--ktv-font-xl);
		margin-top: var(--ktv-space-32);
		margin-bottom: var(--ktv-space-12);
	}

	.ktv-page__content h3 {
		font-size: var(--ktv-font-lg);
		margin-top: var(--ktv-space-24);
		margin-bottom: var(--ktv-space-8);
	}
}

/* ────────────── Deletion Request Page ────────────── */

.ktv-deletion-hero {
	background-color: var(--wp--preset--color--bg-secondary, #F9FAFB);
	border-bottom: 1px solid var(--wp--preset--color--border, #E5E7EB);
	padding-block: var(--ktv-section-space-sm);
	padding-inline: var(--ktv-content-padding);
}

.ktv-deletion-hero__inner {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: var(--ktv-space-16);
	max-width: 1200px;
	margin-inline: auto;
	text-align: center;
}

.ktv-deletion-hero__title {
	font-size: var(--ktv-font-page);
	font-weight: 700;
	color: var(--wp--preset--color--text-primary, #111827);
	line-height: 1.15;
}

.ktv-deletion-hero__desc {
	font-size: var(--ktv-font-body);
	color: var(--wp--preset--color--text-secondary, #6B7280);
	max-width: 560px;
	line-height: 1.5;
}

.ktv-deletion-content {
	padding-block: var(--ktv-section-space-sm);
	padding-inline: var(--ktv-content-padding);
}

.ktv-deletion-content__inner {
	max-width: 720px;
	margin-inline: auto;
	display: flex;
	flex-direction: column;
	gap: var(--ktv-space-32);
}

/* ────────────── Number Removal Page ────────────── */

.ktv-removal-hero {
	background-color: var(--wp--preset--color--bg-secondary, #F9FAFB);
	border-bottom: 1px solid var(--wp--preset--color--border, #E5E7EB);
	padding-block: var(--ktv-section-space-sm);
	padding-inline: var(--ktv-content-padding);
}

.ktv-removal-hero__inner {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: var(--ktv-space-16);
	max-width: 1200px;
	margin-inline: auto;
	text-align: center;
}

.ktv-removal-hero__title {
	font-size: var(--ktv-font-page);
	font-weight: 700;
	color: var(--wp--preset--color--text-primary, #111827);
	line-height: 1.15;
}

.ktv-removal-hero__desc {
	font-size: var(--ktv-font-body);
	color: var(--wp--preset--color--text-secondary, #6B7280);
	max-width: 560px;
	line-height: 1.5;
}

.ktv-removal-content {
	padding-block: var(--ktv-section-space-sm);
	padding-inline: var(--ktv-content-padding);
}

.ktv-removal-content__inner {
	max-width: 560px;
	margin-inline: auto;
	display: flex;
	flex-direction: column;
	gap: var(--ktv-space-24);
}

/* --- Steps --- */

.ktv-removal-step {
	display: flex;
	flex-direction: column;
	gap: var(--ktv-space-24);
	padding: var(--ktv-space-32);
	background-color: var(--wp--preset--color--bg-primary, #fff);
	border: 1px solid var(--wp--preset--color--border, #E5E7EB);
	border-radius: var(--ktv-radius-xl);
}

.ktv-removal-step[hidden] {
	display: none;
}

.ktv-removal-step--done {
	border: none;
	background-color: transparent;
}

.ktv-removal-step__heading {
	font-size: var(--ktv-font-title-sm);
	font-weight: 600;
	color: var(--wp--preset--color--text-primary, #111827);
}

.ktv-removal-step__info {
	font-size: var(--ktv-font-sm);
	color: var(--wp--preset--color--text-secondary, #6B7280);
	margin-top: calc(-1 * var(--ktv-space-12));
}

.ktv-removal-step__actions {
	display: flex;
	align-items: center;
	gap: var(--ktv-space-12);
	flex-wrap: wrap;
}

.ktv-removal-step__timer {
	font-size: var(--ktv-font-sm);
	color: var(--wp--preset--color--text-tertiary, #9CA3AF);
	margin-top: calc(-1 * var(--ktv-space-12));
}

/* --- Search bar inside removal step --- */

.ktv-removal-step .ktv-search-bar {
	max-width: 100%;
}

/* --- Removal form fields --- */

.ktv-removal-form__group {
	display: flex;
	flex-direction: column;
	gap: var(--ktv-space-8);
}

.ktv-removal-form__label {
	font-size: var(--ktv-font-md);
	font-weight: 600;
	color: var(--wp--preset--color--text-primary, #111827);
}

.ktv-removal-form__input,
.ktv-removal-form__textarea {
	padding: var(--ktv-space-12);
	border: 1px solid var(--wp--preset--color--border, #E5E7EB);
	border-radius: var(--ktv-radius-md);
	font-size: var(--ktv-font-base);
	color: var(--wp--preset--color--text-primary, #111827);
	background-color: var(--wp--preset--color--bg-primary, #fff);
	width: 100%;
	font-family: inherit;
	line-height: 1.5;
	outline: none;
	transition: border-color var(--ktv-transition), outline-color var(--ktv-transition);
}

.ktv-removal-form__input:focus,
.ktv-removal-form__textarea:focus,
.ktv-removal-form__select:focus {
	border-color: var(--wp--preset--color--accent-primary, #53389E);
	outline: var(--ktv-focus-outline);
	outline-offset: 2px;
}

.ktv-removal-form__input::placeholder {
	color: var(--wp--preset--color--text-tertiary, #6B7280);
}

.ktv-removal-form__textarea {
	resize: vertical;
	min-height: 120px;
}

.ktv-removal-form__error {
	font-size: var(--ktv-font-sm);
	color: var(--wp--preset--color--danger-text, #B91C1C);
	line-height: 1.4;
}

.ktv-removal-form__status {
	padding: var(--ktv-space-14) var(--ktv-space-16);
	border: 1px solid var(--wp--preset--color--border, #E5E7EB);
	border-radius: var(--ktv-radius-md);
	background-color: var(--wp--preset--color--bg-secondary, #F9FAFB);
	font-size: var(--ktv-font-sm);
}

.ktv-removal-form__status[data-state="error"] {
	border-color: var(--ktv-color-danger-border, #FECACA);
	background-color: var(--wp--preset--color--danger-light, #FEF2F2);
	color: var(--wp--preset--color--danger-text, #B91C1C);
}

/* --- OTP Input --- */

.ktv-otp-input {
	display: flex;
	gap: var(--ktv-space-8);
}

.ktv-otp-input input {
	width: 48px;
	height: 56px;
	text-align: center;
	font-size: var(--ktv-font-xl);
	font-weight: 700;
	border: 2px solid var(--wp--preset--color--border, #E5E7EB);
	border-radius: var(--ktv-radius-md);
	background-color: var(--wp--preset--color--bg-primary, #fff);
	color: var(--wp--preset--color--text-primary, #111827);
	outline: none;
	transition: border-color var(--ktv-transition), outline-color var(--ktv-transition);
}

.ktv-otp-input input:focus {
	border-color: var(--wp--preset--color--accent-primary, #53389E);
	outline: var(--ktv-focus-outline);
	outline-offset: 2px;
}

/* --- Done state --- */

.ktv-removal-done {
	text-align: center;
	padding: var(--ktv-space-32) 0;
}

.ktv-removal-done .ktv-icon {
	color: var(--wp--preset--color--success-text, #047857);
	margin-bottom: var(--ktv-space-16);
}

.ktv-removal-done__title {
	font-size: var(--ktv-font-xl);
	font-weight: 700;
	color: var(--wp--preset--color--text-primary, #111827);
	margin-bottom: var(--ktv-space-8);
}

.ktv-removal-done__desc {
	font-size: var(--ktv-font-body);
	color: var(--wp--preset--color--text-secondary, #6B7280);
	line-height: 1.5;
}

@media (max-width: 767px) {
	.ktv-removal-step {
		padding: var(--ktv-space-24);
	}

	.ktv-otp-input input {
		width: 40px;
		height: 48px;
		font-size: var(--ktv-font-lg);
	}

}
