/*
Theme Name: HTKS Modern
Theme URI: https://www.htks.org/
Author: HTKS
Description: A modern, accessible theme for Hava Trafik Kontrolörleri Sendikası that preserves the existing WordPress content structure.
Version: 1.0.0
Text Domain: htks-modern
*/

:root {
	--ink: #17202a;
	--muted: #66717d;
	--paper: #f6f7f8;
	--white: #fff;
	--red: #c72b2f;
	--red-dark: #991f23;
	--sky: #70b9dc;
	--line: #dfe3e6;
	--radius: 18px;
	--shadow: 0 18px 45px rgba(23, 32, 42, .09);
	--wrap: min(1180px, calc(100% - 40px));
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
	margin: 0;
	background: var(--paper);
	color: var(--ink);
	font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
	font-size: 17px;
	line-height: 1.7;
	-webkit-font-smoothing: antialiased;
}
img { display: block; max-width: 100%; height: auto; }
a { color: var(--red); text-decoration-thickness: .08em; text-underline-offset: .16em; }
a:hover { color: var(--red-dark); }
button, input { font: inherit; }
.screen-reader-text {
	position: absolute;
	width: 1px;
	height: 1px;
	padding: 0;
	margin: -1px;
	overflow: hidden;
	clip: rect(0, 0, 0, 0);
	white-space: nowrap;
	border: 0;
}
.skip-link:focus {
	position: fixed;
	z-index: 9999;
	top: 12px;
	left: 12px;
	width: auto;
	height: auto;
	padding: 10px 16px;
	margin: 0;
	clip: auto;
	background: var(--white);
	border-radius: 8px;
}
.site-wrap { width: var(--wrap); margin-inline: auto; }

.site-header {
	position: sticky;
	z-index: 100;
	top: 0;
	background: rgba(255,255,255,.94);
	border-bottom: 1px solid rgba(23,32,42,.08);
	backdrop-filter: blur(16px);
}
body.admin-bar .site-header { top: 32px; }
.header-inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	min-height: 108px;
	gap: 20px;
}
.brand {
	display: flex;
	align-items: center;
	gap: 14px;
	flex: 0 1 auto;
	min-width: 0;
	color: var(--ink);
	text-decoration: none;
}
.brand-mark {
	width: 84px;
	height: 84px;
	flex: 0 0 84px;
	object-fit: cover;
	border-radius: 50%;
}
.brand-copy { display: grid; line-height: 1.12; }
.brand-name { font-size: clamp(.91rem, 1.35vw, 1.1rem); font-weight: 850; letter-spacing: -.02em; }
.brand-tagline { margin-top: 5px; color: var(--muted); font-size: .78rem; }
.header-actions { display: flex; align-items: center; justify-content: flex-end; gap: 7px; }
.main-nav { display: flex; align-items: center; gap: 6px; }
.main-nav ul { margin: 0; padding: 0; list-style: none; }
.main-nav > ul { display: flex; align-items: center; gap: 4px; }
.main-nav li { position: relative; }
.main-nav a {
	display: block;
	padding: 10px 12px;
	border-radius: 10px;
	color: var(--ink);
	font-size: .88rem;
	font-weight: 700;
	text-decoration: none;
}
.main-nav a:hover, .main-nav .current-menu-item > a { background: #f1f3f4; color: var(--red); }
.main-nav .menu-item-has-children > a { padding-right: 38px; }
.submenu-toggle {
	position: absolute;
	top: 50%;
	right: 5px;
	display: grid;
	place-items: center;
	width: 30px;
	height: 30px;
	padding: 0;
	border: 0;
	border-radius: 8px;
	background: transparent;
	color: var(--ink);
	cursor: pointer;
	transform: translateY(-50%);
}
.submenu-toggle::before {
	content: "";
	width: 7px;
	height: 7px;
	border-right: 2px solid currentColor;
	border-bottom: 2px solid currentColor;
	transform: translateY(-2px) rotate(45deg);
	transition: transform .18s ease;
}
.submenu-toggle:hover, .submenu-toggle:focus-visible { background: #f1f3f4; color: var(--red); }
.submenu-toggle[aria-expanded="true"]::before { transform: translateY(2px) rotate(225deg); }
.submenu-toggle:focus-visible { outline: 2px solid var(--red); outline-offset: 1px; }
.main-nav .sub-menu {
	position: absolute;
	z-index: 20;
	top: calc(100% + 8px);
	left: 0;
	display: grid;
	visibility: hidden;
	min-width: 220px;
	padding: 9px;
	background: var(--white);
	border: 1px solid var(--line);
	border-radius: 13px;
	box-shadow: var(--shadow);
	opacity: 0;
	transform: translateY(-6px);
	transition: opacity .18s ease, transform .18s ease, visibility .18s;
}
.main-nav .sub-menu::before {
	content: "";
	position: absolute;
	top: -9px;
	right: 0;
	left: 0;
	height: 10px;
}
.main-nav .sub-menu a { padding: 10px 12px; white-space: nowrap; }
.main-nav li:hover > .sub-menu,
.main-nav li.submenu-open > .sub-menu {
	visibility: visible;
	opacity: 1;
	transform: translateY(0);
}
.main-nav .sub-menu .sub-menu {
	top: -9px;
	left: calc(100% + 9px);
}
.main-nav .menu-item-member > a,
.main-nav .menu-item-featured > a {
	display: inline-flex;
	align-items: center;
	white-space: nowrap;
	min-height: 44px;
	padding: 8px 16px;
	border-radius: 999px;
	background: var(--red);
	color: var(--white) !important;
	box-shadow: 0 8px 20px rgba(199,43,47,.2);
}
.main-nav .menu-item-featured > a {
	justify-content: center;
	width: 44px;
	min-width: 44px;
	height: 44px;
	padding: 0;
	border-radius: 50%;
}
.menu-calculator-icon { width: 21px; height: 21px; fill: currentColor; }
.main-nav .menu-item-member > a:hover,
.main-nav .menu-item-featured > a:hover { background: var(--red-dark) !important; color: var(--white) !important; }
.header-search { position: relative; }
.search-toggle {
	display: grid;
	place-items: center;
	width: 44px;
	height: 44px;
	padding: 0;
	border: 1px solid var(--line);
	border-radius: 50%;
	background: var(--white);
	color: var(--ink);
	cursor: pointer;
}
.search-toggle:hover, .search-toggle[aria-expanded="true"] { border-color: #e4b8ba; background: #fae9e9; color: var(--red); }
.search-toggle:focus-visible { outline: 2px solid var(--red); outline-offset: 2px; }
.search-toggle svg { width: 20px; height: 20px; fill: currentColor; }
.header-search-form {
	position: absolute;
	z-index: 30;
	top: calc(100% + 14px);
	right: 0;
	visibility: hidden;
	width: min(360px, calc(100vw - 28px));
	padding: 13px;
	background: var(--white);
	border: 1px solid var(--line);
	border-radius: 14px;
	box-shadow: var(--shadow);
	opacity: 0;
	transform: translateY(-6px);
	transition: opacity .18s ease, transform .18s ease, visibility .18s;
}
.header-search.is-open .header-search-form { visibility: visible; opacity: 1; transform: translateY(0); }
.header-search-form .search-field { min-height: 46px; }
.header-search-form .search-submit { min-width: 64px; }
.menu-toggle {
	display: none;
	padding: 9px 12px;
	border: 1px solid var(--line);
	border-radius: 10px;
	background: var(--white);
	color: var(--ink);
}

.hero {
	position: relative;
	overflow: hidden;
	min-height: 475px;
	display: grid;
	align-items: end;
	background: #15212a;
	color: var(--white);
}
.hero::before {
	content: "";
	position: absolute;
	z-index: 0;
	inset: 0;
	background:
		linear-gradient(270deg, rgba(13,23,32,.92) 0%, rgba(13,23,32,.72) 46%, rgba(13,23,32,.12) 100%),
		url("assets/images/htks-hero-control-tower-v2.png") center 56% / cover no-repeat;
}
.hero::after {
	content: "";
	position: absolute;
	z-index: 0;
	inset: auto -10% -45% 45%;
	width: 700px;
	height: 700px;
	border: 1px solid rgba(255,255,255,.14);
	border-radius: 50%;
	box-shadow: 0 0 0 70px rgba(255,255,255,.025), 0 0 0 140px rgba(255,255,255,.025);
}
.hero-content { position: relative; z-index: 1; max-width: 720px; padding-block: 66px 70px; }
.eyebrow {
	display: inline-flex;
	align-items: center;
	gap: 9px;
	margin: 0 0 20px;
	color: inherit;
	font-size: .78rem;
	font-weight: 850;
	letter-spacing: .16em;
	text-transform: uppercase;
}
.eyebrow::before { content: ""; width: 32px; height: 3px; background: var(--red); border-radius: 4px; }
.hero h1 {
	max-width: 720px;
	margin: 0;
	font-size: clamp(2.55rem, 5.5vw, 5rem);
	line-height: .98;
	letter-spacing: -.058em;
}
.hero p { max-width: 620px; margin: 20px 0 0; color: rgba(255,255,255,.82); font-size: clamp(.96rem, 1.7vw, 1.14rem); }
.hero-actions { display: flex; flex-wrap: wrap; gap: 12px; margin-top: 27px; }
.button {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: 50px;
	padding: 10px 21px;
	border: 1px solid transparent;
	border-radius: 999px;
	background: var(--red);
	color: var(--white);
	font-size: .9rem;
	font-weight: 800;
	text-decoration: none;
}
.button:hover { background: var(--red-dark); color: var(--white); transform: translateY(-1px); }
.button-secondary { border-color: rgba(255,255,255,.38); background: rgba(255,255,255,.08); }
.button-secondary:hover { background: var(--white); color: var(--ink); }

.quick-links { position: relative; z-index: 2; margin-top: -45px; }
.quick-grid {
	display: grid;
	grid-template-columns: 1.15fr 1fr 1fr;
	background: var(--white);
	border-radius: var(--radius);
	box-shadow: var(--shadow);
	overflow: hidden;
}
.quick-card {
	display: grid;
	grid-template-columns: 48px 1fr;
	align-items: center;
	gap: 14px;
	min-height: 108px;
	padding: 20px 25px;
	border-right: 1px solid var(--line);
	color: var(--ink);
	text-decoration: none;
}
.quick-card:last-child { border-right: 0; }
.quick-card:hover { background: #fbfbfb; color: var(--red); }
.quick-card-live {
	position: relative;
	grid-template-columns: 58px 1fr;
	background: linear-gradient(135deg, #c72b2f, #a51f23);
	color: var(--white);
}
.quick-card-live:hover { background: linear-gradient(135deg, #d23236, #a51f23); color: var(--white); }
.quick-card-live .quick-icon { width: 58px; height: 58px; background: rgba(255,255,255,.15); color: var(--white); }
.quick-card-live .quick-icon svg { width: 29px; height: 29px; }
.quick-card-live strong { color: var(--white); font-size: 1.12rem; }
.quick-card-live span span:last-child { color: rgba(255,255,255,.72); }
.quick-live-label {
	display: inline-flex !important;
	align-items: center;
	gap: 6px;
	margin-bottom: 2px;
	color: rgba(255,255,255,.9) !important;
	font-size: .64rem !important;
	font-weight: 900;
	letter-spacing: .12em;
	text-transform: uppercase;
}
.quick-live-label i {
	width: 7px;
	height: 7px;
	border-radius: 50%;
	background: #8df0b5;
	box-shadow: 0 0 0 5px rgba(141,240,181,.14);
	animation: htks-live-pulse 1.8s ease-in-out infinite;
}
@keyframes htks-live-pulse {
	50% { box-shadow: 0 0 0 8px rgba(141,240,181,0); }
}
.quick-icon {
	position: relative;
	width: 48px;
	height: 48px;
	flex: 0 0 48px;
	overflow: hidden;
	border-radius: 14px;
	background: #fae9e9;
	color: var(--red);
}
.quick-icon svg {
	position: absolute;
	top: 50%;
	left: 50%;
	display: block;
	width: 24px;
	height: 24px;
	fill: currentColor;
	transform: translate(-50%, -50%);
}
.quick-card:first-child .quick-icon svg { transform: translate(-50%, calc(-50% + 2px)); }
.quick-card strong { display: block; font-size: .98rem; }
.quick-card span { display: block; color: var(--muted); font-size: .78rem; }

.section { padding-block: 90px; }
.section-head {
	display: flex;
	align-items: end;
	justify-content: space-between;
	gap: 24px;
	margin-bottom: 34px;
}
.section-head h2, .page-title {
	margin: 0;
	font-size: clamp(2rem, 4vw, 3.6rem);
	line-height: 1.05;
	letter-spacing: -.045em;
}
.section-head p { max-width: 540px; margin: 8px 0 0; color: var(--muted); }
.text-link { font-size: .88rem; font-weight: 800; white-space: nowrap; }

.posts-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
.post-card {
	display: flex;
	flex-direction: column;
	overflow: hidden;
	min-width: 0;
	background: var(--white);
	border: 1px solid var(--line);
	border-radius: var(--radius);
	transition: transform .2s ease, box-shadow .2s ease;
}
.post-card:hover { transform: translateY(-4px); box-shadow: var(--shadow); }
.post-card-image { display: block; aspect-ratio: 16 / 9; overflow: hidden; background: #dfe7eb; }
.post-card-image img { width: 100%; height: 100%; object-fit: cover; transition: transform .35s ease; }
.post-card:hover .post-card-image img { transform: scale(1.025); }
.post-card-placeholder {
	display: grid;
	place-items: center;
	height: 100%;
	background: linear-gradient(135deg, #233743, #416d81);
	color: rgba(255,255,255,.55);
	font-size: 2.2rem;
}
.post-card-body { display: flex; flex: 1; flex-direction: column; padding: 25px; }
.post-meta { color: var(--red); font-size: .73rem; font-weight: 850; letter-spacing: .09em; text-transform: uppercase; }
.post-card h2, .post-card h3 { margin: 10px 0 12px; font-size: 1.3rem; line-height: 1.25; letter-spacing: -.025em; }
.post-card h2 a, .post-card h3 a { color: var(--ink); text-decoration: none; }
.post-card h2 a:hover, .post-card h3 a:hover { color: var(--red); }
.post-card p { margin: 0; color: var(--muted); font-size: .92rem; line-height: 1.65; }
.post-card .text-link { margin-top: auto; padding-top: 22px; }

.page-hero {
	padding-block: 80px;
	background: #17242c;
	color: var(--white);
}
.page-hero .site-wrap { max-width: 920px; }
.page-hero .eyebrow { color: var(--sky); }
.content-layout {
	display: grid;
	grid-template-columns: minmax(0, 1fr) 300px;
	gap: 60px;
	align-items: start;
	padding-block: 70px 100px;
}
.flight-page { background: #eef2f4; }
.flight-page-hero {
	position: relative;
	overflow: hidden;
	padding-block: 76px 120px;
	background:
		radial-gradient(circle at 82% 22%, rgba(112,185,220,.2), transparent 26%),
		linear-gradient(135deg, #111b22 0%, #20323d 100%);
	color: var(--white);
}
.flight-page-hero::after {
	content: "";
	position: absolute;
	right: -130px;
	bottom: -360px;
	width: 700px;
	height: 700px;
	border: 1px solid rgba(255,255,255,.1);
	border-radius: 50%;
	box-shadow: 0 0 0 70px rgba(255,255,255,.025), 0 0 0 140px rgba(255,255,255,.02);
}
.flight-page-hero .site-wrap { position: relative; z-index: 1; }
.flight-page-hero .eyebrow { color: #a9d9ee; }
.flight-page-hero h1 { max-width: 850px; margin: 0; font-size: clamp(2.6rem, 5vw, 5rem); line-height: 1; letter-spacing: -.055em; }
.flight-page-hero p:last-child { max-width: 620px; margin: 20px 0 0; color: rgba(255,255,255,.7); font-size: 1.1rem; }
.flight-page-content { position: relative; z-index: 2; padding-bottom: 100px; }
.flight-page-entry { margin-top: -66px; font-size: 1rem; }
.flight-page-entry > * { margin-top: 0; }
.entry-content { min-width: 0; font-size: 1.03rem; }
.full-width-page { padding-block: 70px 100px; }
.full-width-entry { width: min(100%, 1040px); margin-inline: auto; }
.entry-content > *:first-child { margin-top: 0; }
.entry-content h2, .entry-content h3 { margin-top: 1.7em; line-height: 1.2; letter-spacing: -.025em; }
.entry-content img { border-radius: 14px; }
.entry-content blockquote { margin: 2em 0; padding: 4px 0 4px 24px; border-left: 4px solid var(--red); font-size: 1.2rem; }
.entry-footer { margin-top: 45px; padding-top: 24px; border-top: 1px solid var(--line); color: var(--muted); font-size: .85rem; }
.sidebar { display: grid; gap: 18px; }
.widget {
	padding: 24px;
	background: var(--white);
	border: 1px solid var(--line);
	border-radius: 15px;
}
.widget-title { margin: 0 0 14px; font-size: .94rem; letter-spacing: -.01em; }
.widget ul { margin: 0; padding: 0; list-style: none; }
.widget li + li { margin-top: 9px; }
.widget a { color: var(--ink); font-size: .86rem; text-decoration: none; }
.widget a:hover { color: var(--red); }
.search-form { display: flex; gap: 8px; }
.search-field {
	min-width: 0;
	width: 100%;
	padding: 11px 13px;
	border: 1px solid var(--line);
	border-radius: 9px;
	background: var(--white);
}
.search-submit {
	padding: 10px 14px;
	border: 0;
	border-radius: 9px;
	background: var(--red);
	color: var(--white);
	font-weight: 800;
	cursor: pointer;
}
.pagination { margin-top: 40px; }
.pagination .nav-links { display: flex; flex-wrap: wrap; gap: 8px; }
.pagination a, .pagination span {
	display: grid;
	place-items: center;
	min-width: 42px;
	height: 42px;
	padding: 0 10px;
	border: 1px solid var(--line);
	border-radius: 9px;
	background: var(--white);
	text-decoration: none;
}
.pagination .current { background: var(--red); color: var(--white); border-color: var(--red); }

.site-footer { background: #121b21; color: rgba(255,255,255,.66); }
.footer-main { display: grid; grid-template-columns: 1.4fr 1fr 1fr; gap: 60px; padding-block: 65px; }
.footer-brand .brand { color: var(--white); }
.footer-brand p { max-width: 440px; margin: 20px 0 0; font-size: .88rem; }
.footer-social { display: flex; gap: 10px; margin-top: 22px; }
.footer-social a {
	display: grid;
	place-items: center;
	width: 42px;
	height: 42px;
	border: 1px solid rgba(255,255,255,.15);
	border-radius: 12px;
	background: rgba(255,255,255,.06);
	color: rgba(255,255,255,.8);
	transition: background .18s ease, border-color .18s ease, color .18s ease, transform .18s ease;
}
.footer-social a:hover { border-color: rgba(255,255,255,.35); color: var(--white); transform: translateY(-2px); }
.footer-social a:hover { border-color: var(--social-color); background: var(--social-color); }
.footer-social a:focus-visible { outline: 2px solid var(--white); outline-offset: 3px; }
.footer-social svg { width: 20px; height: 20px; fill: currentColor; }
.footer-social-facebook svg { width: 23px; height: 23px; }
.footer-title { margin: 0 0 15px; color: var(--white); font-size: .82rem; letter-spacing: .12em; text-transform: uppercase; }
.footer-links { margin: 0; padding: 0; list-style: none; }
.footer-links li + li { margin-top: 7px; }
.footer-links a { color: rgba(255,255,255,.7); font-size: .88rem; text-decoration: none; }
.footer-links a:hover { color: var(--white); }
.footer-bottom { padding-block: 22px; border-top: 1px solid rgba(255,255,255,.1); font-size: .78rem; }

@media (max-width: 1100px) and (min-width: 961px) {
	.brand-copy { max-width: 205px; }
	.brand-name { font-size: .92rem; }
	.main-nav a { padding-inline: 7px; font-size: .79rem; }
	.main-nav .menu-item-has-children > a { padding-right: 34px; }
	.main-nav .menu-item-member > a { padding-inline: 12px; }
	.main-nav .menu-item-featured > a { padding: 0; }
}

@media (max-width: 960px) {
	.menu-toggle { display: block; }
	.main-nav {
		display: none;
		position: absolute;
		top: 108px;
		right: 20px;
		left: 20px;
		padding: 14px;
		background: var(--white);
		border: 1px solid var(--line);
		border-radius: 14px;
		box-shadow: var(--shadow);
	}
	.main-nav.is-open { display: block; }
	.main-nav > ul { align-items: stretch; flex-direction: column; }
	.main-nav a { padding: 12px; }
	.submenu-toggle { top: 6px; right: 7px; transform: none; }
	.main-nav .sub-menu {
		position: static;
		display: none;
		visibility: hidden;
		min-width: 0;
		margin: 0 8px 6px 18px;
		padding: 3px 0 3px 12px;
		background: transparent;
		border: 0;
		border-left: 2px solid #edd0d1;
		border-radius: 0;
		box-shadow: none;
		opacity: 0;
		transform: none;
		transition: none;
	}
	.main-nav li:hover > .sub-menu,
	.main-nav li:focus-within > .sub-menu { display: none; visibility: hidden; opacity: 0; }
	.main-nav li.submenu-open > .sub-menu { display: grid; visibility: visible; opacity: 1; }
	.main-nav .sub-menu a { padding: 9px 12px; white-space: normal; font-size: .83rem; }
	.main-nav .sub-menu .sub-menu { margin-left: 16px; }
	.main-nav .menu-item-member > a,
	.main-nav .menu-item-featured > a { display: flex; justify-content: center; margin-top: 5px; }
	.main-nav .menu-item-featured > a { margin-inline: auto; }
	.posts-grid { grid-template-columns: repeat(2, 1fr); }
	.content-layout { grid-template-columns: 1fr; gap: 45px; }
	.sidebar { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 782px) {
	body.admin-bar .site-header { top: 46px; }
}

@media (max-width: 680px) {
	:root { --wrap: min(100% - 28px, 1180px); }
	body { font-size: 16px; }
	.header-inner { min-height: 88px; }
	.brand { gap: 9px; }
	.brand-mark { width: 64px; height: 64px; flex-basis: 64px; }
	.brand-name { font-size: .87rem; }
	.brand-tagline { display: none; }
	.header-actions { gap: 5px; }
	.search-toggle { width: 42px; height: 42px; }
	.menu-toggle { min-height: 42px; }
	.main-nav { top: 88px; }
	.header-search-form { right: -72px; }
	.hero { min-height: 465px; }
	.hero::before { background-position: center, 62% center; }
	.hero-content { padding-block: 58px 66px; }
	.quick-grid { grid-template-columns: 1fr; }
	.quick-card { min-height: 92px; padding: 18px 20px; border-right: 0; border-bottom: 1px solid var(--line); }
	.quick-card:last-child { border-bottom: 0; }
	.quick-card-live { grid-template-columns: 58px 1fr; }
	.section { padding-block: 65px; }
	.section-head { align-items: start; flex-direction: column; }
	.posts-grid, .sidebar, .footer-main { grid-template-columns: 1fr; }
	.footer-main { gap: 36px; }
	.page-hero { padding-block: 60px; }
	.content-layout { padding-block: 50px 75px; }
	.full-width-page { padding-block: 50px 75px; }
	.flight-page-hero { padding-block: 58px 92px; }
	.flight-page-hero h1 { font-size: 2.55rem; }
	.flight-page-content { padding-bottom: 70px; }
	.flight-page-entry { margin-top: -46px; }
}
