/**
 * Ktirio Competitions — Full Frontend Styles
 *
 * BEM naming with ktcomp- prefix.
 * Uses CSS custom properties for theme overrides.
 *
 * Sections:
 * 1. Custom Properties
 * 2. Shared / Wrapper
 * 3. Header (block context)
 * 4. Category Tabs
 * 5. Messages
 * 6. Entries Grid
 * 7. Entry Card (new partial-based markup)
 * 8. Vote Button
 * 9. Hero Section (single competition)
 * 10. Single Entry Page
 * 11. Results Section
 * 12. Related Entries
 * 13. Archive Page
 * 14. Responsive
 * 15. Animations & Keyframes
 */

/* ==========================================================================
   1. Custom Properties
   ========================================================================== */

:root {
	--ktcomp-primary: #ed1b2f;
	--ktcomp-primary-hover: #d4182a;
	--ktcomp-primary-light: #fde8ea;
	--ktcomp-success: #38a169;
	--ktcomp-success-light: #c6f6d5;
	--ktcomp-error: #e53e3e;
	--ktcomp-error-light: #fed7d7;
	--ktcomp-warning: #d69e2e;
	--ktcomp-gold: #d4a843;
	--ktcomp-silver: #a0aec0;
	--ktcomp-bronze: #c97a3a;
	--ktcomp-gray-50: #f9fafb;
	--ktcomp-gray-100: #f7fafc;
	--ktcomp-gray-200: #edf2f7;
	--ktcomp-gray-300: #e2e8f0;
	--ktcomp-gray-500: #a0aec0;
	--ktcomp-gray-600: #1a202c;
	--ktcomp-gray-700: #4a5568;
	--ktcomp-gray-800: #2d3748;
	--ktcomp-gray-900: #1a202c;
	--ktcomp-radius: 8px;
	--ktcomp-radius-lg: 12px;
	--ktcomp-shadow: 0 1px 3px rgba(0, 0, 0, 0.12), 0 1px 2px rgba(0, 0, 0, 0.06);
	--ktcomp-shadow-md: 0 4px 6px rgba(0, 0, 0, 0.07), 0 2px 4px rgba(0, 0, 0, 0.06);
	--ktcomp-shadow-hover: 0 10px 15px rgba(0, 0, 0, 0.1), 0 4px 6px rgba(0, 0, 0, 0.05);
	--ktcomp-shadow-lg: 0 20px 25px rgba(0, 0, 0, 0.1), 0 10px 10px rgba(0, 0, 0, 0.04);
	--ktcomp-transition: 0.2s ease;
	--ktcomp-transition-slow: 0.3s ease;
}

/* ==========================================================================
   2. Shared / Wrapper
   ========================================================================== */

.ktcomp-wrapper {
	max-width: 1200px;
	margin: 0 auto;
	padding: 1rem;
}

/* ==========================================================================
   3. Header (block context)
   ========================================================================== */

.ktcomp-header {
	margin-bottom: 1.5rem;
	text-align: center;
}

.ktcomp-header__title {
	font-size: 1.75rem;
	font-weight: 700;
	color: var(--ktcomp-gray-900);
	margin: 0 0 0.75rem;
}

.ktcomp-header__meta {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 0.75rem;
	flex-wrap: wrap;
}

.ktcomp-header__phase-badge {
	display: inline-block;
	padding: 0.375rem 0.875rem;
	background: var(--ktcomp-primary-light);
	color: var(--ktcomp-primary);
	border-radius: 999px;
	font-size: 0.8125rem;
	font-weight: 600;
}

.ktcomp-header__vote-status {
	display: inline-block;
	padding: 0.375rem 0.875rem;
	border-radius: 999px;
	font-size: 0.8125rem;
	font-weight: 500;
}

.ktcomp-header__vote-status--open {
	background: var(--ktcomp-success-light);
	color: var(--ktcomp-success);
}

.ktcomp-header__vote-status--closed,
.ktcomp-header__status--closed {
	display: inline-block;
	padding: 0.375rem 0.75rem;
	background: var(--ktcomp-gray-200);
	color: var(--ktcomp-gray-700);
	border-radius: 999px;
	font-size: 0.875rem;
	font-weight: 500;
}

/* ==========================================================================
   3b. Category Grid (single competition landing)
   ========================================================================== */

.ktcomp-category-grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: 1.5rem;
	margin-top: 2rem;
}

.ktcomp-category-card {
	display: flex;
	flex-direction: column;
	background: #fff;
	border-radius: var(--ktcomp-radius-lg);
	box-shadow: var(--ktcomp-shadow);
	overflow: hidden;
	text-decoration: none;
	color: inherit;
	transition: box-shadow var(--ktcomp-transition-slow), transform var(--ktcomp-transition-slow);
}

.ktcomp-category-card:hover {
	box-shadow: var(--ktcomp-shadow-hover);
	transform: translateY(-3px);
}

.ktcomp-category-card__image {
	aspect-ratio: 16 / 9;
	overflow: hidden;
	background: var(--ktcomp-gray-100);
}

.ktcomp-category-card__image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
	transition: transform 0.4s ease;
}

.ktcomp-category-card:hover .ktcomp-category-card__image img {
	transform: scale(1.05);
}

.ktcomp-category-card__placeholder {
	width: 100%;
	height: 100%;
	background: var(--ktcomp-gray-200);
	min-height: 200px;
}

.ktcomp-category-card__body {
	padding: 1.25rem;
	text-align: center;
}

.ktcomp-category-card__title {
	font-size: 1.25rem;
	font-weight: 700;
	color: var(--ktcomp-gray-900);
	margin: 0 0 0.375rem;
}

.ktcomp-category-card__count {
	font-size: 0.875rem;
	color: var(--ktcomp-gray-500);
}

/* Category back link */
.ktcomp-category-back {
	margin-bottom: 1.5rem;
}

.ktcomp-category-back__link {
	display: inline-flex;
	align-items: center;
	gap: 0.375rem;
	color: var(--ktcomp-primary);
	text-decoration: none;
	font-size: 0.9375rem;
	font-weight: 500;
	transition: color var(--ktcomp-transition);
	margin-bottom: 0.75rem;
}

.ktcomp-category-back__link:hover {
	color: var(--ktcomp-primary-hover);
}

.ktcomp-category-back__title {
	font-size: 1.5rem;
	font-weight: 700;
	color: var(--ktcomp-gray-900);
	margin: 0;
}

/* ==========================================================================
   4. Category Tabs
   ========================================================================== */

.ktcomp-categories {
	display: flex;
	gap: 0.5rem;
	overflow-x: auto;
	-webkit-overflow-scrolling: touch;
	padding-bottom: 0.5rem;
	margin-bottom: 1.5rem;
	border-bottom: 2px solid var(--ktcomp-gray-200);
	scrollbar-width: thin;
	scrollbar-color: var(--ktcomp-gray-300) transparent;
}

.ktcomp-categories::-webkit-scrollbar {
	height: 4px;
}

.ktcomp-categories::-webkit-scrollbar-track {
	background: transparent;
}

.ktcomp-categories::-webkit-scrollbar-thumb {
	background: var(--ktcomp-gray-300);
	border-radius: 2px;
}

.ktcomp-category-tab {
	flex-shrink: 0;
	padding: 0.625rem 1.25rem;
	background: transparent;
	border: none;
	border-bottom: 3px solid transparent;
	color: var(--ktcomp-gray-500);
	font-size: 0.9375rem;
	font-weight: 500;
	cursor: pointer;
	transition: color var(--ktcomp-transition), border-color var(--ktcomp-transition), background var(--ktcomp-transition);
	white-space: nowrap;
	margin-bottom: -2px;
	border-radius: var(--ktcomp-radius) var(--ktcomp-radius) 0 0;
}

.ktcomp-category-tab:hover {
	color: var(--ktcomp-gray-700);
	background: var(--ktcomp-gray-50);
}

.ktcomp-category-tab.active {
	color: var(--ktcomp-primary);
	border-bottom-color: var(--ktcomp-primary);
	background: var(--ktcomp-primary-light);
}

/* ==========================================================================
   5. Messages
   ========================================================================== */

.ktcomp-message {
	padding: 0.75rem 1rem;
	border-radius: var(--ktcomp-radius);
	font-size: 0.875rem;
	margin-bottom: 1rem;
	animation: ktcomp-fade-in 0.3s ease;
}

.ktcomp-message[hidden] {
	display: none;
}

.ktcomp-message--error {
	background: var(--ktcomp-error-light);
	color: var(--ktcomp-error);
}

.ktcomp-message--success {
	background: var(--ktcomp-success-light);
	color: var(--ktcomp-success);
}

/* ==========================================================================
   6. Entries Grid
   ========================================================================== */

.ktcomp-entries {
	display: grid;
	gap: 1.5rem;
	grid-template-columns: 1fr;
}

.ktcomp-entries[hidden] {
	display: none;
}

.ktcomp-entries__empty {
	grid-column: 1 / -1;
	text-align: center;
	color: var(--ktcomp-gray-500);
	padding: 3rem 2rem;
	font-size: 0.9375rem;
}

/* ==========================================================================
   7. Entry Card (new partial-based markup)
   ========================================================================== */

.ktcomp-entry {
	background: #fff;
	border-radius: var(--ktcomp-radius-lg);
	box-shadow: var(--ktcomp-shadow);
	overflow: hidden;
	transition: box-shadow var(--ktcomp-transition-slow), transform var(--ktcomp-transition-slow);
	display: flex;
	flex-direction: column;
}

.ktcomp-entry:hover {
	box-shadow: var(--ktcomp-shadow-hover);
	transform: translateY(-3px);
}

.ktcomp-entry.voted {
	box-shadow: 0 0 0 2px var(--ktcomp-success), var(--ktcomp-shadow-md);
}

/* Entry Image Wrapper */
.ktcomp-entry__image-wrapper {
	position: relative;
	aspect-ratio: 16 / 10;
	overflow: hidden;
	background: var(--ktcomp-gray-100);
}

.ktcomp-entry__image-link {
	display: block;
	width: 100%;
	height: 100%;
}

.ktcomp-entry__image-wrapper img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
	transition: transform 0.4s ease;
}

.ktcomp-entry:hover .ktcomp-entry__image-wrapper img {
	transform: scale(1.05);
}

/* Dark overlay on hover */
.ktcomp-entry__overlay {
	position: absolute;
	bottom: 0;
	left: 0;
	right: 0;
	padding: 0.75rem;
	background: linear-gradient(to top, rgba(0, 0, 0, 0.6), transparent);
	opacity: 0;
	transition: opacity var(--ktcomp-transition-slow);
	display: flex;
	align-items: flex-end;
	justify-content: flex-start;
	min-height: 3rem;
}

.ktcomp-entry:hover .ktcomp-entry__overlay {
	opacity: 1;
}

.ktcomp-entry__category-badge {
	display: inline-block;
	padding: 0.25rem 0.625rem;
	background: rgba(255, 255, 255, 0.9);
	color: var(--ktcomp-gray-800);
	border-radius: 999px;
	font-size: 0.6875rem;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.03em;
}

.ktcomp-entry__image-placeholder {
	width: 100%;
	height: 100%;
	background: var(--ktcomp-gray-200);
	min-height: 180px;
}

/* Legacy image class (block compat) */
.ktcomp-entry__image {
	aspect-ratio: 16 / 10;
	overflow: hidden;
	background: var(--ktcomp-gray-100);
}

.ktcomp-entry__image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
	transition: transform 0.4s ease;
}

.ktcomp-entry:hover .ktcomp-entry__image img {
	transform: scale(1.05);
}

/* Entry Body */
.ktcomp-entry__body {
	padding: 0.875rem 1rem 0.5rem;
	flex: 1;
}

.ktcomp-entry__title {
	font-size: 1rem;
	font-weight: 600;
	margin: 0 0 0.25rem;
	color: var(--ktcomp-gray-900);
	line-height: 1.3;
}

.ktcomp-entry__title a {
	color: inherit;
	text-decoration: none;
	transition: color var(--ktcomp-transition);
}

.ktcomp-entry__title a:hover {
	color: var(--ktcomp-primary);
}

.ktcomp-entry__meta {
	display: flex;
	flex-direction: column;
	gap: 0.125rem;
}

.ktcomp-entry__architect {
	font-size: 0.8125rem;
	color: var(--ktcomp-gray-600);
	margin: 0;
}

.ktcomp-entry__location {
	font-size: 0.75rem;
	color: var(--ktcomp-gray-500);
}

/* Legacy content class (block compat) */
.ktcomp-entry__content {
	padding: 0.75rem 1rem;
}

/* Entry Footer */
.ktcomp-entry__footer {
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: 0.625rem 1rem;
	border-top: 1px solid var(--ktcomp-gray-200);
	margin-top: auto;
}

.ktcomp-entry__vote-count {
	font-size: 0.875rem;
	font-weight: 700;
	color: var(--ktcomp-gray-700);
	min-width: 1.5rem;
	transition: transform var(--ktcomp-transition);
}

/* Vote count animation on update */
.ktcomp-entry__vote-count[data-updated] {
	animation: ktcomp-vote-bump 0.4s ease;
}

/* Legacy actions class (block compat) */
.ktcomp-entry__actions {
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: 0.625rem 1rem;
	border-top: 1px solid var(--ktcomp-gray-200);
}

.ktcomp-entry__votes {
	font-size: 0.875rem;
	font-weight: 600;
	color: var(--ktcomp-gray-700);
	min-width: 1.5rem;
}

/* ==========================================================================
   8. Vote Button
   ========================================================================== */

.ktcomp-entry__vote-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 0.375rem;
	padding: 0.5rem 1.125rem;
	background: var(--ktcomp-primary);
	color: #fff;
	border: none;
	border-radius: var(--ktcomp-radius);
	font-size: 0.8125rem;
	font-weight: 600;
	cursor: pointer;
	transition: background var(--ktcomp-transition), opacity var(--ktcomp-transition), transform var(--ktcomp-transition);
	min-width: 5rem;
	text-align: center;
}

.ktcomp-entry__vote-btn:hover:not(:disabled) {
	background: var(--ktcomp-primary-hover);
	transform: translateY(-1px);
}

.ktcomp-entry__vote-btn:active:not(:disabled) {
	transform: translateY(0);
}

.ktcomp-entry__vote-btn:disabled {
	opacity: 0.6;
	cursor: not-allowed;
}

.ktcomp-entry__vote-btn.voted {
	background: var(--ktcomp-success);
	cursor: default;
}

.ktcomp-entry__vote-btn.voted::before {
	content: "";
	display: inline-block;
	width: 0.75rem;
	height: 0.75rem;
	margin-right: 0.25rem;
}

.ktcomp-entry__vote-btn.loading {
	opacity: 0.7;
	pointer-events: none;
	position: relative;
}

.ktcomp-entry__vote-btn.loading::after {
	content: "";
	display: inline-block;
	width: 0.875rem;
	height: 0.875rem;
	border: 2px solid rgba(255, 255, 255, 0.3);
	border-top-color: #fff;
	border-radius: 50%;
	animation: ktcomp-spin 0.6s linear infinite;
	margin-left: 0.375rem;
}

/* Large vote button (single entry page) */
.ktcomp-entry__vote-btn--large {
	padding: 0.75rem 2rem;
	font-size: 1rem;
	border-radius: var(--ktcomp-radius-lg);
	min-width: 8rem;
}

/* ==========================================================================
   9. Hero Section (single competition)
   ========================================================================== */

.ktcomp-single {
	padding-bottom: 3rem;
}

.ktcomp-hero {
	margin-bottom: 2rem;
}

.ktcomp-hero__image {
	width: 100%;
	max-height: 400px;
	overflow: hidden;
	border-radius: var(--ktcomp-radius-lg);
	margin-bottom: 1.5rem;
}

.ktcomp-hero__image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

.ktcomp-hero__content {
	text-align: center;
}

.ktcomp-hero__title {
	font-size: 2.25rem;
	font-weight: 800;
	color: var(--ktcomp-gray-900);
	margin: 0 0 1rem;
	line-height: 1.2;
}

.ktcomp-hero__description {
	max-width: 700px;
	margin: 0 auto 1.5rem;
	color: var(--ktcomp-gray-600);
	font-size: 1.0625rem;
	line-height: 1.7;
}


/* ==========================================================================
   10. Single Entry Page
   ========================================================================== */

.ktcomp-single-entry {
	padding-bottom: 3rem;
}

.ktcomp-single-entry__back {
	margin-bottom: 1.5rem;
	padding-top: 1rem;
}

.ktcomp-single-entry__back-link {
	display: inline-flex;
	align-items: center;
	gap: 0.375rem;
	color: var(--ktcomp-primary);
	text-decoration: none;
	font-size: 0.9375rem;
	font-weight: 500;
	transition: color var(--ktcomp-transition);
}

.ktcomp-single-entry__back-link:hover {
	color: var(--ktcomp-primary-hover);
}

.ktcomp-single-entry__layout {
	display: grid;
	grid-template-columns: 1fr;
	gap: 2rem;
}

/* Media column */
.ktcomp-single-entry__featured-image {
	border-radius: var(--ktcomp-radius-lg);
	overflow: hidden;
	box-shadow: var(--ktcomp-shadow-md);
}

.ktcomp-single-entry__featured-image img {
	width: 100%;
	height: auto;
	display: block;
}

.ktcomp-single-entry__gallery {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 0.75rem;
	margin-top: 1rem;
}

.ktcomp-single-entry__gallery-item {
	border-radius: var(--ktcomp-radius);
	overflow: hidden;
	aspect-ratio: 1;
}

.ktcomp-single-entry__gallery-item img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
	transition: transform 0.3s ease, opacity 0.3s ease;
}

.ktcomp-single-entry__gallery-item:hover img {
	transform: scale(1.05);
	opacity: 0.9;
}

/* Details column */
.ktcomp-single-entry__title {
	font-size: 1.75rem;
	font-weight: 700;
	color: var(--ktcomp-gray-900);
	margin: 0 0 0.75rem;
	line-height: 1.25;
}

.ktcomp-single-entry__competition {
	margin-bottom: 1.25rem;
}

.ktcomp-single-entry__competition-label {
	font-size: 0.875rem;
	font-weight: 600;
	color: var(--ktcomp-gray-600);
	margin-right: 0.375rem;
}

.ktcomp-single-entry__competition-link {
	font-size: 0.875rem;
	color: var(--ktcomp-primary);
	text-decoration: none;
	font-weight: 500;
}

.ktcomp-single-entry__competition-link:hover {
	color: var(--ktcomp-primary-hover);
	text-decoration: underline;
}

.ktcomp-single-entry__section-title {
	font-size: 1.25rem;
	font-weight: 700;
	color: var(--ktcomp-gray-900);
	margin: 0 0 0.75rem;
}

.ktcomp-single-entry__category-badge {
	display: inline-block;
	padding: 0.375rem 0.875rem;
	background: var(--ktcomp-primary-light);
	color: var(--ktcomp-primary);
	border-radius: 999px;
	font-size: 0.8125rem;
	font-weight: 600;
	margin-bottom: 1.25rem;
}

.ktcomp-single-entry__info {
	display: flex;
	flex-direction: column;
	gap: 0.625rem;
	margin-bottom: 1.5rem;
	padding: 1rem;
	background: var(--ktcomp-gray-50);
	border-radius: var(--ktcomp-radius);
	border: 1px solid var(--ktcomp-gray-200);
}

.ktcomp-single-entry__info-item {
	display: flex;
	gap: 0.75rem;
}

.ktcomp-single-entry__info-label {
	font-size: 0.8125rem;
	font-weight: 600;
	color: var(--ktcomp-gray-600);
	min-width: 6.5rem;
	flex-shrink: 0;
}

.ktcomp-single-entry__info-value {
	font-size: 0.8125rem;
	color: var(--ktcomp-gray-900);
}

/* Vote section on single entry */
.ktcomp-single-entry__vote-section {
	display: flex;
	align-items: center;
	gap: 1.5rem;
	padding: 1.25rem;
	background: var(--ktcomp-gray-50);
	border-radius: var(--ktcomp-radius-lg);
	border: 1px solid var(--ktcomp-gray-200);
	margin-bottom: 1.5rem;
	flex-wrap: wrap;
}

.ktcomp-single-entry__vote-count {
	display: flex;
	flex-direction: column;
	align-items: center;
}

.ktcomp-single-entry__vote-number {
	font-size: 2rem;
	font-weight: 800;
	color: var(--ktcomp-primary);
	line-height: 1;
}

.ktcomp-single-entry__vote-text {
	font-size: 0.75rem;
	color: var(--ktcomp-gray-500);
	text-transform: uppercase;
	letter-spacing: 0.05em;
}

.ktcomp-single-entry__description {
	line-height: 1.7;
	color: var(--ktcomp-gray-700);
	font-size: 1rem;
}

.ktcomp-single-entry__description p {
	margin-bottom: 1rem;
}

.ktcomp-single-entry__description img {
	max-width: 100%;
	height: auto;
	border-radius: var(--ktcomp-radius);
}

/* ==========================================================================
   11. Results Section
   ========================================================================== */

.ktcomp-results {
	margin-top: 3rem;
	padding-top: 2rem;
	border-top: 2px solid var(--ktcomp-gray-200);
}

.ktcomp-results__title {
	font-size: 1.5rem;
	font-weight: 700;
	color: var(--ktcomp-gray-900);
	margin: 0 0 1.5rem;
	text-align: center;
}

.ktcomp-results__category {
	margin-bottom: 2rem;
}

.ktcomp-results__category-title {
	font-size: 1.125rem;
	font-weight: 600;
	color: var(--ktcomp-gray-800);
	margin: 0 0 1rem;
	padding-bottom: 0.5rem;
	border-bottom: 1px solid var(--ktcomp-gray-200);
}

.ktcomp-results__podium {
	display: flex;
	flex-direction: column;
	gap: 0.5rem;
}

.ktcomp-results__item {
	display: flex;
	align-items: center;
	gap: 0.75rem;
	padding: 0.75rem 1rem;
	background: var(--ktcomp-gray-50);
	border-radius: var(--ktcomp-radius);
	border: 1px solid var(--ktcomp-gray-200);
	transition: transform var(--ktcomp-transition);
}

.ktcomp-results__item:hover {
	transform: translateX(4px);
}

/* Podium effect for top 3 */
.ktcomp-results__item--rank-1 {
	background: linear-gradient(135deg, #fef9e7, #fdf2d1);
	border-color: var(--ktcomp-gold);
	box-shadow: 0 2px 8px rgba(212, 168, 67, 0.15);
}

.ktcomp-results__item--rank-2 {
	background: linear-gradient(135deg, #f0f4f8, #e8ecf1);
	border-color: var(--ktcomp-silver);
}

.ktcomp-results__item--rank-3 {
	background: linear-gradient(135deg, #fef4eb, #fce8d5);
	border-color: var(--ktcomp-bronze);
}

.ktcomp-results__rank {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 2rem;
	height: 2rem;
	border-radius: 50%;
	background: var(--ktcomp-gray-200);
	color: var(--ktcomp-gray-700);
	font-size: 0.875rem;
	font-weight: 700;
	flex-shrink: 0;
}

.ktcomp-results__item--rank-1 .ktcomp-results__rank {
	background: var(--ktcomp-gold);
	color: #fff;
}

.ktcomp-results__item--rank-2 .ktcomp-results__rank {
	background: var(--ktcomp-silver);
	color: #fff;
}

.ktcomp-results__item--rank-3 .ktcomp-results__rank {
	background: var(--ktcomp-bronze);
	color: #fff;
}

.ktcomp-results__entry-title {
	flex: 1;
	font-size: 0.9375rem;
	font-weight: 500;
	color: var(--ktcomp-gray-800);
}

.ktcomp-results__votes {
	font-size: 0.8125rem;
	font-weight: 600;
	color: var(--ktcomp-gray-600);
	white-space: nowrap;
}

/* ==========================================================================
   12. Related Entries
   ========================================================================== */

.ktcomp-related {
	margin-top: 3rem;
	padding-top: 2rem;
	border-top: 2px solid var(--ktcomp-gray-200);
}

.ktcomp-related__title {
	font-size: 1.375rem;
	font-weight: 700;
	color: var(--ktcomp-gray-900);
	margin: 0 0 1.25rem;
}

.ktcomp-related__grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: 1.25rem;
}

.ktcomp-related__card {
	display: flex;
	flex-direction: column;
	background: #fff;
	border-radius: var(--ktcomp-radius-lg);
	box-shadow: var(--ktcomp-shadow);
	overflow: hidden;
	text-decoration: none;
	transition: box-shadow var(--ktcomp-transition-slow), transform var(--ktcomp-transition-slow);
}

.ktcomp-related__card:hover {
	box-shadow: var(--ktcomp-shadow-hover);
	transform: translateY(-2px);
}

.ktcomp-related__image {
	aspect-ratio: 16 / 10;
	overflow: hidden;
}

.ktcomp-related__image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
	transition: transform 0.4s ease;
}

.ktcomp-related__card:hover .ktcomp-related__image img {
	transform: scale(1.05);
}

.ktcomp-related__info {
	padding: 0.75rem 1rem;
}

.ktcomp-related__entry-title {
	font-size: 0.9375rem;
	font-weight: 600;
	color: var(--ktcomp-gray-900);
	margin: 0 0 0.25rem;
}

.ktcomp-related__architect {
	font-size: 0.8125rem;
	color: var(--ktcomp-gray-500);
}

/* ==========================================================================
   13. Archive Page
   ========================================================================== */

.ktcomp-archive {
	padding: 2rem 0 3rem;
}

.ktcomp-archive__header {
	text-align: center;
	margin-bottom: 2rem;
}

.ktcomp-archive__title {
	font-size: 2rem;
	font-weight: 800;
	color: var(--ktcomp-gray-900);
	margin: 0 0 0.5rem;
}

.ktcomp-archive__description {
	max-width: 600px;
	margin: 0 auto;
	color: var(--ktcomp-gray-600);
	font-size: 1rem;
	line-height: 1.6;
}

.ktcomp-archive__grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: 1.5rem;
}

.ktcomp-archive__card {
	display: flex;
	flex-direction: column;
	background: #fff;
	border-radius: var(--ktcomp-radius-lg);
	box-shadow: var(--ktcomp-shadow);
	overflow: hidden;
	text-decoration: none;
	color: inherit;
	transition: box-shadow var(--ktcomp-transition-slow), transform var(--ktcomp-transition-slow);
}

.ktcomp-archive__card:hover {
	box-shadow: var(--ktcomp-shadow-hover);
	transform: translateY(-3px);
}

.ktcomp-archive__card--active {
	box-shadow: 0 0 0 2px var(--ktcomp-success), var(--ktcomp-shadow-md);
}

.ktcomp-archive__card--completed {
	opacity: 0.9;
}

.ktcomp-archive__card-image {
	position: relative;
	aspect-ratio: 16 / 9;
	overflow: hidden;
	background: var(--ktcomp-gray-100);
}

.ktcomp-archive__card-image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
	transition: transform 0.4s ease;
}

.ktcomp-archive__card:hover .ktcomp-archive__card-image img {
	transform: scale(1.05);
}

.ktcomp-archive__status-badge {
	position: absolute;
	top: 0.75rem;
	right: 0.75rem;
	padding: 0.375rem 0.75rem;
	border-radius: 999px;
	font-size: 0.75rem;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.03em;
	background: rgba(255, 255, 255, 0.95);
	color: var(--ktcomp-gray-700);
	backdrop-filter: blur(4px);
}

.ktcomp-archive__status-badge--phase-1,
.ktcomp-archive__status-badge--phase-2,
.ktcomp-archive__status-badge--phase-3 {
	background: var(--ktcomp-success-light);
	color: var(--ktcomp-success);
}

.ktcomp-archive__status-badge--completed {
	background: var(--ktcomp-primary-light);
	color: var(--ktcomp-primary);
}

.ktcomp-archive__card-body {
	padding: 1rem 1.25rem 1.25rem;
	display: flex;
	flex-direction: column;
	flex: 1;
}

.ktcomp-archive__card-title {
	font-size: 1.25rem;
	font-weight: 700;
	color: var(--ktcomp-gray-900);
	margin: 0 0 0.5rem;
	line-height: 1.3;
}

.ktcomp-archive__card-excerpt {
	font-size: 0.875rem;
	color: var(--ktcomp-gray-600);
	margin: 0 0 0.75rem;
	line-height: 1.5;
}

.ktcomp-archive__card-meta {
	display: flex;
	gap: 1rem;
	font-size: 0.8125rem;
	color: var(--ktcomp-gray-500);
	margin-bottom: 0.75rem;
}

.ktcomp-archive__results-link,
.ktcomp-archive__vote-link {
	font-size: 0.875rem;
	font-weight: 600;
	margin-top: auto;
}

.ktcomp-archive__results-link {
	color: var(--ktcomp-primary);
}

.ktcomp-archive__vote-link {
	color: var(--ktcomp-success);
}

.ktcomp-archive__empty {
	text-align: center;
	padding: 3rem;
	color: var(--ktcomp-gray-500);
	font-size: 1rem;
}

/* Notice (no competition selected) */
.ktcomp-notice {
	text-align: center;
	padding: 2rem;
	color: var(--ktcomp-gray-500);
	background: var(--ktcomp-gray-100);
	border-radius: var(--ktcomp-radius);
}

/* ==========================================================================
   14. Responsive
   ========================================================================== */

/* Tablet (>= 768px) */
@media (min-width: 768px) {
	.ktcomp-category-grid {
		grid-template-columns: repeat(2, 1fr);
	}

	.ktcomp-entries {
		grid-template-columns: repeat(2, 1fr);
	}

	.ktcomp-single-entry__layout {
		grid-template-columns: 1.2fr 1fr;
	}

	.ktcomp-related__grid {
		grid-template-columns: repeat(3, 1fr);
	}

	.ktcomp-archive__grid {
		grid-template-columns: repeat(2, 1fr);
	}

	.ktcomp-hero__title {
		font-size: 2.75rem;
	}
}

/* Desktop (>= 1024px) */
@media (min-width: 1024px) {
	.ktcomp-columns-3 .ktcomp-entries {
		grid-template-columns: repeat(3, 1fr);
	}

	.ktcomp-columns-4 .ktcomp-entries {
		grid-template-columns: repeat(4, 1fr);
	}

	.ktcomp-archive__grid {
		grid-template-columns: repeat(3, 1fr);
	}

	.ktcomp-hero__title {
		font-size: 3rem;
	}
}

/* Mobile (< 768px): category tabs as pill-style horizontal scroll */
@media (max-width: 767px) {
	.ktcomp-categories {
		border-bottom: none;
		gap: 0.375rem;
		padding: 0.25rem;
		background: var(--ktcomp-gray-100);
		border-radius: 999px;
		margin-bottom: 1.25rem;
	}

	.ktcomp-category-tab {
		padding: 0.5rem 1rem;
		border-bottom: none;
		border-radius: 999px;
		margin-bottom: 0;
		font-size: 0.8125rem;
	}

	.ktcomp-category-tab.active {
		background: #fff;
		color: var(--ktcomp-primary);
		box-shadow: var(--ktcomp-shadow);
		border-bottom-color: transparent;
	}

	.ktcomp-single-entry__info-item {
		flex-direction: column;
		gap: 0.125rem;
	}

	.ktcomp-single-entry__gallery {
		grid-template-columns: repeat(2, 1fr);
	}

	.ktcomp-hero__title {
		font-size: 1.75rem;
	}

	.ktcomp-hero__description {
		font-size: 0.9375rem;
	}
}

/* ==========================================================================
   15. Animations & Keyframes
   ========================================================================== */

@keyframes ktcomp-spin {
	to {
		transform: rotate(360deg);
	}
}

@keyframes ktcomp-fade-in {
	from {
		opacity: 0;
		transform: translateY(-0.5rem);
	}
	to {
		opacity: 1;
		transform: translateY(0);
	}
}

@keyframes ktcomp-vote-bump {
	0% {
		transform: scale(1);
	}
	50% {
		transform: scale(1.2);
	}
	100% {
		transform: scale(1);
	}
}
