/*
Theme Name: K&B Proje Pazarlama
Theme URI: https://kbprojepazarlama.com
Description: K&B Proje Pazarlama için Kadence child teması. Marka kimliği, kurumsal tipografi ve özel bileşenler.
Author: K&B Proje Pazarlama
Version: 1.0.0
Template: kadence
Text Domain: kadence-kb
Tags: real-estate, business, professional
*/

/* ==========================================================================
   Brand tokens — mevcut paleti koruyor
   ========================================================================== */
:root {
	--kb-color-bg: #ffffff;
	--kb-color-bg-alt: #f7f7f7;
	--kb-color-header: #0e0e10;
	--kb-color-text: #1f1f1f;
	--kb-color-text-muted: #6b6b6b;
	--kb-color-border: #e5e5e5;
	--kb-color-primary: #8b1a1f;        /* logo kırmızı */
	--kb-color-primary-dark: #6e1418;
	--kb-color-accent: #e07b2a;         /* sıcak turuncu vurgu */
	--kb-color-accent-dark: #b8611f;

	--kb-radius-sm: 4px;
	--kb-radius-md: 8px;
	--kb-radius-lg: 14px;

	--kb-shadow-sm: 0 1px 2px rgba(0,0,0,.04), 0 1px 3px rgba(0,0,0,.06);
	--kb-shadow-md: 0 4px 6px rgba(0,0,0,.05), 0 10px 15px rgba(0,0,0,.07);
	--kb-shadow-lg: 0 10px 25px rgba(0,0,0,.1), 0 20px 40px rgba(0,0,0,.08);

	--kb-ease: cubic-bezier(.4,0,.2,1);
}

/* ==========================================================================
   Tipografi düzeltmeleri (Inter gövde, Playfair başlık)
   ========================================================================== */
body {
	font-feature-settings: "ss01","cv11","kern";
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}

/* Görseller geçişi yumuşat */
img {
	transition: transform .5s var(--kb-ease), opacity .3s var(--kb-ease);
}

/* Erişilebilir focus halkası */
:focus-visible {
	outline: 2px solid var(--kb-color-primary);
	outline-offset: 2px;
	border-radius: var(--kb-radius-sm);
}

/* ==========================================================================
   Page hero override — Rife'taki ağır siyah filtreyi temizle, modern hero
   ========================================================================== */
.kb-page-hero {
	position: relative;
	min-height: 420px;
	display: flex;
	align-items: center;
	justify-content: center;
	color: #fff;
	text-align: center;
	background: #0e0e10;
	overflow: hidden;
}
.kb-page-hero::before {
	content: "";
	position: absolute;
	inset: 0;
	background: linear-gradient(180deg, rgba(14,14,16,.55) 0%, rgba(14,14,16,.7) 100%);
	z-index: 1;
}
.kb-page-hero__inner {
	position: relative;
	z-index: 2;
	padding: 4rem 1.5rem;
	max-width: 900px;
}
.kb-page-hero__title {
	font-size: clamp(2rem, 4vw, 3.25rem);
	font-weight: 700;
	letter-spacing: -.02em;
	margin: 0 0 .75rem;
	line-height: 1.1;
}
.kb-page-hero__subtitle {
	font-size: clamp(1rem, 1.4vw, 1.15rem);
	color: rgba(255,255,255,.85);
	margin: 0 auto;
	max-width: 640px;
}

/* ==========================================================================
   Referans kartları — modern grid
   ========================================================================== */
.kb-projects-grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
	gap: 1.5rem;
}
.kb-project-card {
	background: #fff;
	border: 1px solid var(--kb-color-border);
	border-radius: var(--kb-radius-md);
	overflow: hidden;
	transition: transform .3s var(--kb-ease), box-shadow .3s var(--kb-ease), border-color .3s var(--kb-ease);
	display: flex;
	flex-direction: column;
}
.kb-project-card:hover {
	transform: translateY(-4px);
	box-shadow: var(--kb-shadow-lg);
	border-color: transparent;
}
.kb-project-card__media {
	aspect-ratio: 16 / 10;
	overflow: hidden;
	background: var(--kb-color-bg-alt);
}
.kb-project-card__media img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}
.kb-project-card:hover .kb-project-card__media img {
	transform: scale(1.04);
}
.kb-project-card__body {
	padding: 1.25rem 1.5rem 1.5rem;
	display: flex;
	flex-direction: column;
	gap: .35rem;
	flex: 1;
}
.kb-project-card__title {
	font-size: 1.15rem;
	font-weight: 700;
	margin: 0;
	color: var(--kb-color-text);
	letter-spacing: -.01em;
}
.kb-project-card__meta {
	font-size: .85rem;
	color: var(--kb-color-text-muted);
	margin: 0;
}
.kb-project-card__meta strong {
	color: var(--kb-color-primary);
	font-weight: 600;
}

/* ==========================================================================
   Hizmet kartları — anasayfa & hizmetlerimiz
   ========================================================================== */
.kb-service-card {
	padding: 2rem 1.75rem;
	border-radius: var(--kb-radius-md);
	background: #fff;
	border: 1px solid var(--kb-color-border);
	transition: all .3s var(--kb-ease);
	height: 100%;
	display: flex;
	flex-direction: column;
}
.kb-service-card:hover {
	border-color: var(--kb-color-primary);
	box-shadow: var(--kb-shadow-md);
	transform: translateY(-2px);
}
.kb-service-card__icon {
	width: 48px;
	height: 48px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	border-radius: var(--kb-radius-sm);
	background: rgba(139,26,31,.08);
	color: var(--kb-color-primary);
	margin-bottom: 1.1rem;
	font-size: 1.5rem;
}
.kb-service-card__title {
	font-size: 1.2rem;
	font-weight: 700;
	margin: 0 0 .5rem;
	color: var(--kb-color-text);
}
.kb-service-card__desc {
	font-size: .95rem;
	line-height: 1.6;
	color: var(--kb-color-text-muted);
	margin: 0;
	flex: 1;
}

/* ==========================================================================
   İstatistik şeridi
   ========================================================================== */
.kb-stats {
	background: var(--kb-color-header);
	color: #fff;
	padding: 3.5rem 1.5rem;
}
.kb-stats__grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
	gap: 2rem;
	max-width: 1100px;
	margin: 0 auto;
	text-align: center;
}
.kb-stat__num {
	font-size: clamp(2.25rem, 3.5vw, 3rem);
	font-weight: 800;
	color: var(--kb-color-accent);
	letter-spacing: -.02em;
	line-height: 1;
	margin: 0 0 .35rem;
	font-feature-settings: "tnum";
}
.kb-stat__label {
	font-size: .9rem;
	text-transform: uppercase;
	letter-spacing: .1em;
	color: rgba(255,255,255,.75);
	margin: 0;
}

/* ==========================================================================
   Founder kartları — Kurucu Ortaklar
   ========================================================================== */
.kb-founder {
	display: grid;
	grid-template-columns: minmax(220px, 320px) 1fr;
	gap: 2.5rem;
	align-items: center;
	padding: 2.5rem 0;
	border-bottom: 1px solid var(--kb-color-border);
}
.kb-founder:last-child {
	border-bottom: 0;
}
.kb-founder__photo {
	border-radius: var(--kb-radius-md);
	overflow: hidden;
	box-shadow: var(--kb-shadow-md);
	aspect-ratio: 4 / 5;
}
.kb-founder__photo img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}
.kb-founder__name {
	font-size: 1.5rem;
	font-weight: 700;
	letter-spacing: -.01em;
	margin: 0 0 .25rem;
	color: var(--kb-color-text);
}
.kb-founder__role {
	font-size: .9rem;
	text-transform: uppercase;
	letter-spacing: .12em;
	color: var(--kb-color-primary);
	font-weight: 600;
	margin: 0 0 1.25rem;
}
.kb-founder__bio p {
	color: var(--kb-color-text);
	line-height: 1.75;
	margin: 0 0 1rem;
}
.kb-founder__bio p:last-child {
	margin-bottom: 0;
}
@media (max-width: 768px) {
	.kb-founder {
		grid-template-columns: 1fr;
		text-align: center;
	}
	.kb-founder__photo {
		max-width: 280px;
		margin: 0 auto;
	}
}

/* ==========================================================================
   İletişim kartları
   ========================================================================== */
.kb-contact-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
	gap: 1.25rem;
	margin: 2rem 0;
}
.kb-contact-card {
	padding: 1.5rem;
	background: var(--kb-color-bg-alt);
	border-radius: var(--kb-radius-md);
	border: 1px solid var(--kb-color-border);
}
.kb-contact-card__label {
	font-size: .8rem;
	text-transform: uppercase;
	letter-spacing: .12em;
	color: var(--kb-color-text-muted);
	font-weight: 600;
	margin: 0 0 .35rem;
}
.kb-contact-card__value {
	font-size: 1.05rem;
	font-weight: 600;
	color: var(--kb-color-text);
	margin: 0;
	word-break: break-word;
}
.kb-contact-card__value a {
	color: inherit;
	text-decoration: none;
}
.kb-contact-card__value a:hover {
	color: var(--kb-color-primary);
}

/* ==========================================================================
   PAGE template — hero + content
   ========================================================================== */
.kb-page-hero {
	position: relative;
	min-height: 360px;
	display: flex;
	align-items: center;
	color: #fff;
	overflow: hidden;
	background: linear-gradient(135deg, #0e0e10 0%, #1a0e10 100%);
	padding: 4rem 0 3rem;
}
.kb-page-hero--svg .kb-page-hero__bg {
	position: absolute;
	inset: 0;
	background-size: cover;
	background-position: center;
	background-repeat: no-repeat;
	z-index: 0;
}
.kb-page-hero__overlay {
	position: absolute;
	inset: 0;
	background: linear-gradient(180deg, rgba(14,14,16,.5) 0%, rgba(14,14,16,.85) 100%);
	z-index: 1;
}
.kb-page-hero__inner {
	position: relative;
	z-index: 2;
	max-width: 1200px;
	margin: 0 auto;
	width: 100%;
	padding: 1.5rem;
}
.kb-page-hero__title {
	font-family: "Playfair Display", Georgia, serif;
	font-size: clamp(2rem, 4.5vw, 3.5rem);
	font-weight: 700;
	letter-spacing: -.02em;
	margin: .5rem 0 0;
	line-height: 1.1;
	color: #fff;
}
.kb-breadcrumbs {
	font-size: .82rem;
	letter-spacing: .04em;
	color: rgba(255,255,255,.7);
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: .5rem;
}
.kb-breadcrumbs a {
	color: rgba(255,255,255,.7);
	text-decoration: none;
	transition: color .2s var(--kb-ease);
}
.kb-breadcrumbs a:hover {
	color: var(--kb-color-accent);
}
.kb-breadcrumbs span[aria-hidden] {
	color: rgba(255,255,255,.4);
}

/* Project meta strip on hero */
.kb-project-meta {
	display: flex;
	flex-wrap: wrap;
	gap: 2rem 2.5rem;
	margin: 1.5rem 0 0;
	padding: 0;
}
.kb-project-meta > div {
	display: flex;
	flex-direction: column;
	gap: .15rem;
}
.kb-project-meta dt {
	font-size: .72rem;
	letter-spacing: .2em;
	text-transform: uppercase;
	color: var(--kb-color-accent);
	font-weight: 700;
	margin: 0;
}
.kb-project-meta dd {
	font-size: 1.15rem;
	font-weight: 600;
	color: #fff;
	margin: 0;
	font-family: "Playfair Display", Georgia, serif;
}

/* Page article */
.kb-page-article {
	padding: clamp(2.5rem, 5vw, 4.5rem) 0;
	background: var(--kb-color-bg);
}
.kb-page-content {
	max-width: 880px;
}
.kb-page-content > *:first-child { margin-top: 0; }
.kb-page-content > *:last-child  { margin-bottom: 0; }

.kb-page-content h2,
.kb-page-content h3,
.kb-page-content h4 {
	font-family: "Playfair Display", Georgia, serif;
	letter-spacing: -.01em;
	margin-top: 2.5rem;
	margin-bottom: 1rem;
	color: var(--kb-color-text);
}
.kb-page-content h2 { font-size: clamp(1.6rem, 2.5vw, 2rem); }
.kb-page-content h3 { font-size: 1.4rem; }
.kb-page-content h4 { font-size: 1.18rem; font-family: "Inter", sans-serif; font-weight: 700; }

.kb-page-content p {
	font-size: 1.05rem;
	line-height: 1.8;
	color: var(--kb-color-text);
	margin: 0 0 1.25rem;
}

.kb-page-content ul.wp-block-list,
.kb-page-content ul:not([class]) {
	list-style: none;
	padding: 0;
	margin: 0 0 2rem;
	display: grid;
	gap: 1rem;
}
.kb-page-content ul.wp-block-list li,
.kb-page-content ul:not([class]) li {
	background: var(--kb-color-bg-alt);
	padding: 1.25rem 1.4rem 1.25rem 3rem;
	border-radius: var(--kb-radius-md);
	border-left: 3px solid var(--kb-color-primary);
	position: relative;
	font-size: 1rem;
	line-height: 1.7;
}
.kb-page-content ul.wp-block-list li::before,
.kb-page-content ul:not([class]) li::before {
	content: "";
	position: absolute;
	left: 1rem;
	top: 1.5rem;
	width: 14px;
	height: 14px;
	border-radius: 50%;
	background: var(--kb-color-primary);
	background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='%23fff'><path d='M6.5 11.5l-3-3 1-1 2 2 4.5-4.5 1 1z'/></svg>");
	background-repeat: no-repeat;
	background-position: center;
	background-size: 10px 10px;
}
.kb-page-content ul.wp-block-list li strong:first-child {
	color: var(--kb-color-primary);
	font-weight: 700;
	display: inline;
}
.kb-page-content .wp-block-image,
.kb-page-content .wp-block-media-text {
	border-radius: var(--kb-radius-md);
	overflow: hidden;
}
.kb-page-content .wp-block-image img {
	border-radius: var(--kb-radius-md);
}

/* ==========================================================================
   FRONT PAGE — Hero
   ========================================================================== */
.kb-front {
	background: var(--kb-color-bg);
	color: var(--kb-color-text);
}
.kb-container {
	max-width: 1200px;
	margin: 0 auto;
	padding-left: 1.5rem;
	padding-right: 1.5rem;
}
.kb-eyebrow {
	font-size: .8rem;
	letter-spacing: .25em;
	font-weight: 600;
	color: var(--kb-color-primary);
	text-transform: uppercase;
	margin: 0 0 .75rem;
}
.kb-h2 {
	font-family: "Playfair Display", Georgia, serif;
	font-size: clamp(1.75rem, 3vw, 2.6rem);
	font-weight: 700;
	letter-spacing: -.02em;
	line-height: 1.2;
	margin: 0 0 1.25rem;
	color: var(--kb-color-text);
}

.kb-hero {
	min-height: clamp(560px, 80vh, 740px);
	display: flex;
	align-items: center;
	justify-content: center;
	background-size: cover;
	background-position: center;
	background-repeat: no-repeat;
	color: #fff;
	position: relative;
	overflow: hidden;
}
.kb-hero::after {
	content: "";
	position: absolute;
	right: -200px;
	top: -200px;
	width: 600px;
	height: 600px;
	border-radius: 50%;
	background: radial-gradient(circle, rgba(139,26,31,.4), transparent 70%);
	pointer-events: none;
	z-index: 1;
}
.kb-hero__inner {
	position: relative;
	z-index: 2;
	max-width: 900px;
	padding: 4rem 1.5rem 5rem;
	text-align: left;
	width: 100%;
}
.kb-hero__eyebrow {
	font-family: "Inter", system-ui, sans-serif;
	font-size: .8rem;
	font-weight: 600;
	letter-spacing: .35em;
	color: var(--kb-color-accent);
	margin: 0 0 1.25rem;
	text-transform: uppercase;
}
.kb-hero__title {
	font-family: "Playfair Display", Georgia, serif;
	font-size: clamp(2.25rem, 5vw, 4rem);
	font-weight: 700;
	line-height: 1.1;
	letter-spacing: -.02em;
	margin: 0 0 1.5rem;
	color: #fff;
}
.kb-hero__title-accent {
	color: var(--kb-color-accent);
	font-style: italic;
}
.kb-hero__lead {
	font-size: clamp(1rem, 1.3vw, 1.15rem);
	line-height: 1.7;
	color: rgba(255,255,255,.78);
	margin: 0 0 2rem;
	max-width: 640px;
}
.kb-hero__cta {
	display: flex;
	flex-wrap: wrap;
	gap: .85rem;
}
.kb-hero__scroll {
	position: absolute;
	bottom: 2rem;
	left: 1.5rem;
	width: 22px;
	height: 36px;
	border: 2px solid rgba(255,255,255,.4);
	border-radius: 14px;
	display: flex;
	justify-content: center;
}
.kb-hero__scroll span {
	display: block;
	width: 3px;
	height: 8px;
	background: rgba(255,255,255,.7);
	border-radius: 2px;
	margin-top: 6px;
	animation: kb-scroll 1.6s ease-in-out infinite;
}
@keyframes kb-scroll {
	0%   { transform: translateY(0); opacity: 1; }
	50%  { transform: translateY(8px); opacity: .3; }
	100% { transform: translateY(0); opacity: 1; }
}

/* Buttons (kullanıcıya tutarlı kalsın diye burada da tanımlı) */
.kb-btn {
	display: inline-flex;
	align-items: center;
	gap: .5rem;
	padding: .9rem 1.6rem;
	border-radius: 4px;
	font-weight: 600;
	font-size: .95rem;
	text-decoration: none;
	letter-spacing: .01em;
	transition: all .25s var(--kb-ease);
	border: 1.5px solid transparent;
	cursor: pointer;
	line-height: 1;
}
.kb-btn--primary {
	background: var(--kb-color-primary);
	color: #fff;
}
.kb-btn--primary:hover {
	background: var(--kb-color-primary-dark);
	color: #fff;
	transform: translateY(-1px);
	box-shadow: 0 6px 18px rgba(139,26,31,.35);
}
.kb-btn--ghost {
	background: transparent;
	color: #fff;
	border-color: rgba(255,255,255,.4);
}
.kb-btn--ghost:hover {
	background: rgba(255,255,255,.1);
	border-color: #fff;
	color: #fff;
}
.kb-btn--ghost-light {
	background: transparent;
	color: #fff;
	border-color: rgba(255,255,255,.5);
}
.kb-btn--ghost-light:hover {
	background: #fff;
	color: var(--kb-color-primary);
}
.kb-btn--outline {
	background: transparent;
	color: var(--kb-color-primary);
	border-color: var(--kb-color-primary);
}
.kb-btn--outline:hover {
	background: var(--kb-color-primary);
	color: #fff;
}

/* ==========================================================================
   Stats grid (override)
   ========================================================================== */
.kb-stats {
	background: var(--kb-color-header);
	color: #fff;
	padding: 3rem 1.5rem;
	border-bottom: 1px solid rgba(255,255,255,.06);
}
.kb-stats__grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
	gap: 2rem;
	max-width: 1200px;
	margin: 0 auto;
	text-align: center;
}
.kb-stat__num {
	font-family: "Playfair Display", Georgia, serif;
	font-size: clamp(2.5rem, 4.5vw, 3.5rem);
	font-weight: 800;
	color: var(--kb-color-accent);
	margin: 0 0 .35rem;
	line-height: 1;
	font-feature-settings: "tnum";
}
.kb-stat__label {
	font-size: .82rem;
	text-transform: uppercase;
	letter-spacing: .14em;
	color: rgba(255,255,255,.7);
	margin: 0;
}

/* ==========================================================================
   Services preview grid
   ========================================================================== */
.kb-services-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
	gap: 1.5rem;
	margin-top: 2.5rem;
}
.kb-service-card {
	display: flex;
	flex-direction: column;
	background: #fff;
	border: 1px solid var(--kb-color-border);
	border-radius: var(--kb-radius-md);
	padding: 2.25rem 1.75rem;
	text-decoration: none;
	color: inherit;
	transition: all .3s var(--kb-ease);
	height: 100%;
}
.kb-service-card:hover {
	border-color: var(--kb-color-primary);
	box-shadow: 0 18px 40px rgba(0,0,0,.08);
	transform: translateY(-4px);
}
.kb-service-card__icon {
	width: 52px;
	height: 52px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	border-radius: 12px;
	background: rgba(139,26,31,.08);
	color: var(--kb-color-primary);
	margin-bottom: 1.25rem;
}
.kb-service-card__icon svg {
	width: 24px;
	height: 24px;
}
.kb-service-card__title {
	font-family: "Playfair Display", Georgia, serif;
	font-size: 1.25rem;
	font-weight: 700;
	margin: 0 0 .65rem;
	color: var(--kb-color-text);
	line-height: 1.3;
}
.kb-service-card__desc {
	font-size: .95rem;
	line-height: 1.65;
	color: var(--kb-color-text-muted);
	margin: 0 0 1.25rem;
	flex: 1;
}
.kb-service-card__more {
	font-size: .85rem;
	font-weight: 600;
	color: var(--kb-color-primary);
	letter-spacing: .03em;
}

/* ==========================================================================
   About strip
   ========================================================================== */
.kb-about-strip__grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 4rem;
	align-items: center;
}
@media (max-width: 900px) {
	.kb-about-strip__grid {
		grid-template-columns: 1fr;
		gap: 2.5rem;
	}
}
.kb-about-strip__media {
	position: relative;
	border-radius: var(--kb-radius-lg);
	overflow: hidden;
	box-shadow: var(--kb-shadow-lg);
	aspect-ratio: 4 / 3;
}
.kb-about-strip__media img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}
.kb-about-strip__badge {
	position: absolute;
	bottom: 1.25rem;
	left: 1.25rem;
	background: rgba(14,14,16,.92);
	color: #fff;
	padding: 1rem 1.25rem;
	border-radius: var(--kb-radius-md);
	display: flex;
	align-items: baseline;
	gap: .55rem;
	backdrop-filter: blur(6px);
}
.kb-about-strip__badge-num {
	font-family: "Playfair Display", Georgia, serif;
	font-size: 1.85rem;
	font-weight: 800;
	color: var(--kb-color-accent);
}
.kb-about-strip__badge-label {
	font-size: .82rem;
	letter-spacing: .04em;
	color: rgba(255,255,255,.85);
}
.kb-checklist {
	list-style: none;
	padding: 0;
	margin: 0 0 1.75rem;
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: .65rem 1.5rem;
}
.kb-checklist li {
	position: relative;
	padding-left: 1.75rem;
	font-weight: 500;
	color: var(--kb-color-text);
}
.kb-checklist li::before {
	content: "";
	position: absolute;
	left: 0;
	top: .35em;
	width: 18px;
	height: 18px;
	border-radius: 50%;
	background: var(--kb-color-primary);
	background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='%23fff'><path d='M6.5 11.5l-3-3 1-1 2 2 4.5-4.5 1 1z'/></svg>");
	background-repeat: no-repeat;
	background-position: center;
	background-size: 12px 12px;
}
@media (max-width: 520px) {
	.kb-checklist { grid-template-columns: 1fr; }
}

/* ==========================================================================
   References
   ========================================================================== */
.kb-references-section .kb-eyebrow,
.kb-references-section .kb-section__title,
.kb-references-section .kb-section__lead {
	text-align: center;
}
.kb-references-section .kb-eyebrow { text-align: center; }
.kb-section__cta {
	text-align: center;
	margin-top: 3rem;
}
.kb-project-card__placeholder {
	width: 100%;
	height: 100%;
	background: linear-gradient(135deg, #f7f7f7, #e5e5e5);
}

/* ==========================================================================
   CTA band
   ========================================================================== */
.kb-cta-band {
	background: linear-gradient(135deg, #0e0e10 0%, #1a0e10 50%, #2a0f12 100%);
	color: #fff;
	padding: clamp(3rem, 6vw, 5rem) 1.5rem;
	position: relative;
	overflow: hidden;
}
.kb-cta-band::before {
	content: "";
	position: absolute;
	top: -50%;
	right: -10%;
	width: 60%;
	height: 200%;
	background: radial-gradient(circle, rgba(224,123,42,.15), transparent 60%);
	pointer-events: none;
}
.kb-cta-band__inner {
	position: relative;
	display: grid;
	grid-template-columns: 1fr auto;
	gap: 2.5rem;
	align-items: center;
}
@media (max-width: 800px) {
	.kb-cta-band__inner {
		grid-template-columns: 1fr;
		text-align: center;
	}
}
.kb-cta-band__title {
	font-family: "Playfair Display", Georgia, serif;
	font-size: clamp(1.5rem, 2.5vw, 2.25rem);
	font-weight: 700;
	margin: 0 0 .5rem;
	letter-spacing: -.01em;
}
.kb-cta-band__copy {
	color: rgba(255,255,255,.75);
	margin: 0;
	max-width: 560px;
	font-size: 1.02rem;
	line-height: 1.6;
}
.kb-cta-band__actions {
	display: flex;
	flex-wrap: wrap;
	gap: .85rem;
	justify-content: flex-end;
}
@media (max-width: 800px) {
	.kb-cta-band__actions { justify-content: center; }
}

/* ==========================================================================
   ABOUT PAGE
   ========================================================================== */
.kb-about-page {
	max-width: 920px;
	margin: 0 auto;
}
.kb-about-intro {
	margin-bottom: 3rem;
}
.kb-about-intro__title {
	font-family: "Playfair Display", Georgia, serif;
	font-size: clamp(1.6rem, 2.6vw, 2.2rem);
	font-weight: 700;
	letter-spacing: -.01em;
	line-height: 1.25;
	margin: 0 0 1.5rem;
	color: var(--kb-color-text);
}
.kb-about-intro__lead {
	font-size: 1.1rem;
	line-height: 1.8;
	color: var(--kb-color-text);
}
.kb-about-block {
	margin: 2.5rem 0;
	padding: 2rem 2.25rem;
	background: var(--kb-color-bg-alt);
	border-left: 3px solid var(--kb-color-primary);
	border-radius: var(--kb-radius-md);
}
.kb-about-block p {
	margin: 0 0 1.1rem;
	font-size: 1.02rem;
	line-height: 1.75;
	color: var(--kb-color-text);
}
.kb-about-block p:last-child { margin-bottom: 0; }

.kb-fayda-title {
	text-align: center;
	font-family: "Playfair Display", Georgia, serif;
	font-size: clamp(1.6rem, 2.4vw, 2.1rem);
	font-weight: 700;
	margin: 4rem 0 2rem;
	color: var(--kb-color-primary);
	font-style: italic;
}
.kb-fayda-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
	gap: 1.25rem;
	margin: 0 0 2rem;
}
.kb-fayda-card {
	padding: 1.75rem 1.4rem;
	background: #fff;
	border: 1px solid var(--kb-color-border);
	border-radius: var(--kb-radius-md);
	position: relative;
	transition: all .3s var(--kb-ease);
}
.kb-fayda-card:hover {
	border-color: var(--kb-color-primary);
	transform: translateY(-3px);
	box-shadow: 0 12px 30px rgba(0,0,0,.08);
}
.kb-fayda-card__num {
	font-family: "Playfair Display", Georgia, serif;
	font-size: 2.5rem;
	font-weight: 800;
	color: var(--kb-color-accent);
	line-height: 1;
	display: block;
	margin-bottom: .8rem;
	font-feature-settings: "tnum";
}
.kb-fayda-card h4 {
	font-family: "Playfair Display", Georgia, serif;
	font-size: 1.05rem;
	font-weight: 700;
	margin: 0 0 .35rem;
	color: var(--kb-color-text);
}
.kb-fayda-card p {
	margin: 0;
	font-size: .9rem;
	color: var(--kb-color-text-muted);
	line-height: 1.55;
}

/* ==========================================================================
   FOUNDERS PAGE
   ========================================================================== */
.kb-founders {
	max-width: 1100px;
	margin: 0 auto;
}
.kb-founder {
	display: grid;
	grid-template-columns: minmax(260px, 360px) 1fr;
	gap: 3rem;
	align-items: start;
	padding: 3rem 0;
	border-bottom: 1px solid var(--kb-color-border);
}
.kb-founder:last-child { border-bottom: 0; }
.kb-founder--reverse {
	grid-template-columns: 1fr minmax(260px, 360px);
}
.kb-founder--reverse .kb-founder__bio { order: 1; }
.kb-founder--reverse .kb-founder__photo { order: 2; }
.kb-founder__photo {
	border-radius: var(--kb-radius-md);
	overflow: hidden;
	box-shadow: var(--kb-shadow-lg);
	aspect-ratio: 4 / 5;
	position: sticky;
	top: 100px;
}
.kb-founder__photo img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}
.kb-founder__name {
	font-family: "Playfair Display", Georgia, serif;
	font-size: clamp(1.5rem, 2.5vw, 2rem);
	font-weight: 700;
	letter-spacing: -.01em;
	margin: 0 0 .25rem;
	color: var(--kb-color-text);
}
.kb-founder__role {
	font-size: .8rem;
	text-transform: uppercase;
	letter-spacing: .18em;
	color: var(--kb-color-primary);
	font-weight: 700;
	margin: 0 0 1.5rem;
}
.kb-founder__bio p {
	color: var(--kb-color-text);
	line-height: 1.8;
	font-size: 1rem;
	margin: 0 0 1.1rem;
}
@media (max-width: 800px) {
	.kb-founder, .kb-founder--reverse {
		grid-template-columns: 1fr;
		gap: 1.5rem;
	}
	.kb-founder--reverse .kb-founder__bio { order: 2; }
	.kb-founder--reverse .kb-founder__photo { order: 1; }
	.kb-founder__photo {
		max-width: 320px;
		margin: 0 auto;
		position: static;
	}
}

/* ==========================================================================
   CONTACT PAGE
   ========================================================================== */
.kb-contact-page {
	max-width: 1100px;
	margin: 0 auto;
}
.kb-contact-grid--detailed {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
	gap: 1.25rem;
	margin: 0 0 3rem;
}
.kb-contact-grid--detailed .kb-contact-card {
	padding: 1.75rem 1.5rem;
	background: var(--kb-color-bg-alt);
	border: 1px solid var(--kb-color-border);
	border-radius: var(--kb-radius-md);
	transition: all .3s var(--kb-ease);
}
.kb-contact-grid--detailed .kb-contact-card:hover {
	transform: translateY(-3px);
	border-color: var(--kb-color-primary);
	box-shadow: 0 12px 30px rgba(0,0,0,.08);
}
.kb-contact-card__icon {
	width: 44px;
	height: 44px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	border-radius: 10px;
	background: rgba(139,26,31,.08);
	color: var(--kb-color-primary);
	margin-bottom: 1rem;
}
.kb-contact-card__icon svg {
	width: 22px;
	height: 22px;
}
.kb-contact-grid--detailed .kb-contact-card__label {
	font-size: .72rem;
	letter-spacing: .2em;
	text-transform: uppercase;
	color: var(--kb-color-text-muted);
	font-weight: 700;
	margin: 0 0 .35rem;
}
.kb-contact-grid--detailed .kb-contact-card__value {
	font-size: 1rem;
	font-weight: 600;
	color: var(--kb-color-text);
	margin: 0;
	line-height: 1.55;
}
.kb-contact-grid--detailed .kb-contact-card__value a {
	color: inherit;
	text-decoration: none;
	border-bottom: 1px dashed transparent;
	transition: border-color .2s var(--kb-ease);
}
.kb-contact-grid--detailed .kb-contact-card__value a:hover {
	border-color: var(--kb-color-primary);
	color: var(--kb-color-primary);
}
.kb-contact-map {
	margin: 0 0 3rem;
	border-radius: var(--kb-radius-lg);
	overflow: hidden;
	box-shadow: var(--kb-shadow-lg);
}
.kb-contact-map iframe {
	display: block;
	width: 100%;
	border: 0;
}
.kb-contact-cta {
	background: linear-gradient(135deg, #0e0e10 0%, #1a0e10 50%, #2a0f12 100%);
	color: #fff;
	padding: 3rem 2rem;
	border-radius: var(--kb-radius-lg);
	text-align: center;
	position: relative;
	overflow: hidden;
}
.kb-contact-cta::before {
	content: "";
	position: absolute;
	top: -100%;
	right: -20%;
	width: 60%;
	height: 300%;
	background: radial-gradient(circle, rgba(224,123,42,.18), transparent 60%);
	pointer-events: none;
}
.kb-contact-cta h3 {
	font-family: "Playfair Display", Georgia, serif;
	font-size: clamp(1.4rem, 2.2vw, 1.85rem);
	font-weight: 700;
	margin: 0 0 .65rem;
	color: #fff;
	position: relative;
}
.kb-contact-cta p {
	color: rgba(255,255,255,.78);
	max-width: 600px;
	margin: 0 auto 1.5rem;
	position: relative;
	line-height: 1.65;
}
.kb-contact-cta__actions {
	display: flex;
	flex-wrap: wrap;
	gap: .75rem;
	justify-content: center;
	position: relative;
}
.kb-contact-cta__actions .kb-btn--outline {
	color: #fff;
	border-color: rgba(255,255,255,.5);
}
.kb-contact-cta__actions .kb-btn--outline:hover {
	background: #fff;
	color: var(--kb-color-primary);
}

/* ==========================================================================
   REFERENCES PAGE (post listing landing)
   ========================================================================== */
.kb-references-page__lead {
	max-width: 760px;
	margin: 0 auto 3rem;
	text-align: center;
	font-size: 1.1rem;
	line-height: 1.75;
	color: var(--kb-color-text-muted);
}
.kb-page-content .kb-references-page + p,
.kb-page-content .kb-projects-grid {
	margin-top: 0;
}

/* ==========================================================================
   KURUMSAL PAGE
   ========================================================================== */
.kb-kurumsal {
	max-width: 920px;
	margin: 0 auto;
	text-align: center;
}
.kb-kurumsal > p {
	max-width: 700px;
	margin: 0 auto 3rem;
	font-size: 1.05rem;
	line-height: 1.75;
	color: var(--kb-color-text-muted);
}
.kb-kurumsal-cards {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
	gap: 1.5rem;
	text-align: left;
}
.kb-kurumsal-card {
	display: block;
	padding: 2rem 1.75rem;
	background: #fff;
	border: 1px solid var(--kb-color-border);
	border-radius: var(--kb-radius-md);
	text-decoration: none;
	color: inherit;
	transition: all .3s var(--kb-ease);
}
.kb-kurumsal-card:hover {
	border-color: var(--kb-color-primary);
	transform: translateY(-3px);
	box-shadow: 0 12px 30px rgba(0,0,0,.08);
}
.kb-kurumsal-card h3 {
	font-family: "Playfair Display", Georgia, serif;
	font-size: 1.4rem;
	font-weight: 700;
	margin: 0 0 .65rem;
	color: var(--kb-color-text);
}
.kb-kurumsal-card p {
	font-size: .95rem;
	line-height: 1.65;
	color: var(--kb-color-text-muted);
	margin: 0 0 1rem;
}
.kb-kurumsal-card span {
	font-size: .85rem;
	font-weight: 600;
	color: var(--kb-color-primary);
}

/* ==========================================================================
   Yardımcı sınıflar
   ========================================================================== */
.kb-section {
	padding: clamp(3rem, 6vw, 5rem) 1.5rem;
}
.kb-section--alt {
	background: var(--kb-color-bg-alt);
}
.kb-section__title {
	text-align: center;
	font-size: clamp(1.75rem, 3vw, 2.5rem);
	font-weight: 700;
	letter-spacing: -.02em;
	margin: 0 0 .75rem;
}
.kb-section__lead {
	text-align: center;
	color: var(--kb-color-text-muted);
	max-width: 720px;
	margin: 0 auto 3rem;
	font-size: 1.05rem;
	line-height: 1.65;
}

/* ==========================================================================
   POLISH & OVERRIDES (round 4) — Aria's punch-list applied
   ========================================================================== */

/* Spacing tokens (8px-aligned) — unified section rhythm */
:root {
	--kb-space-section: clamp(4rem, 8vw, 6rem);
	--kb-space-component: clamp(2rem, 4vw, 3rem);
}

.kb-section,
.kb-page-article {
	padding-top: var(--kb-space-section);
	padding-bottom: var(--kb-space-section);
}
.kb-stats {
	padding-top: var(--kb-space-component);
	padding-bottom: var(--kb-space-component);
}

/* ----- Numbered section markers via CSS counter ----- */
.kb-front {
	counter-reset: kb-section;
}
.kb-front .kb-services-preview .kb-eyebrow,
.kb-front .kb-about-strip .kb-eyebrow,
.kb-front .kb-references-section .kb-eyebrow {
	display: inline-flex;
	align-items: baseline;
	gap: .65rem;
}
.kb-front .kb-services-preview .kb-eyebrow::before,
.kb-front .kb-about-strip .kb-eyebrow::before,
.kb-front .kb-references-section .kb-eyebrow::before {
	counter-increment: kb-section;
	content: "0" counter(kb-section);
	color: var(--kb-color-accent);
	font-weight: 800;
	letter-spacing: 0;
}
.kb-front .kb-services-preview .kb-eyebrow::after,
.kb-front .kb-about-strip .kb-eyebrow::after,
.kb-front .kb-references-section .kb-eyebrow::after {
	content: "";
	display: inline-block;
	width: 28px;
	height: 1px;
	background: var(--kb-color-accent);
	opacity: .5;
	margin-left: .25rem;
}

/* ----- Hero Ken Burns subtle motion (gated) ----- */
.kb-hero {
	position: relative;
	background: #0e0e10 !important;
	overflow: hidden;
}
.kb-hero::before {
	content: "";
	position: absolute;
	inset: -20px;
	background-image: var(--kb-hero-bg);
	background-size: cover;
	background-position: center;
	z-index: 0;
	pointer-events: none;
	will-change: transform;
}
.kb-hero::after {
	z-index: 1; /* keep red glow above bg image */
}
.kb-hero__inner {
	z-index: 2;
}
@media (prefers-reduced-motion: no-preference) {
	.kb-hero::before {
		animation: kb-ken 22s ease-in-out infinite alternate;
	}
}
@keyframes kb-ken {
	0%   { transform: scale(1)    translate(0, 0); }
	100% { transform: scale(1.08) translate(-1%, -1%); }
}

/* Hero scroll indicator centered */
.kb-hero__scroll {
	left: 50% !important;
	transform: translateX(-50%);
}

/* ----- Project card hover overlay + slide-in ----- */
.kb-project-card {
	position: relative;
}
.kb-project-card__media {
	position: relative;
}
.kb-project-card__media::after {
	content: "";
	position: absolute;
	inset: 0;
	background: linear-gradient(180deg, rgba(14,14,16,0) 30%, rgba(14,14,16,.85) 100%);
	opacity: 0;
	transition: opacity .45s var(--kb-ease);
	z-index: 1;
	pointer-events: none;
}
.kb-project-card:hover .kb-project-card__media::after {
	opacity: 1;
}
.kb-project-card__media img {
	transition: transform .7s cubic-bezier(.2,.6,.2,1);
}
.kb-project-card:hover .kb-project-card__media img {
	transform: scale(1.08);
}
.kb-project-card__hover-tag {
	position: absolute;
	left: 1.25rem;
	bottom: 1.25rem;
	z-index: 2;
	color: #fff;
	font-size: .78rem;
	font-weight: 600;
	letter-spacing: .2em;
	text-transform: uppercase;
	background: var(--kb-color-primary);
	padding: .45rem .85rem;
	border-radius: 4px;
	transform: translateY(12px);
	opacity: 0;
	transition: transform .35s var(--kb-ease), opacity .35s var(--kb-ease);
	pointer-events: none;
}
.kb-project-card:hover .kb-project-card__hover-tag {
	transform: translateY(0);
	opacity: 1;
}

/* ----- Service card refined hover ----- */
.kb-service-card {
	position: relative;
	overflow: hidden;
}
.kb-service-card::before {
	content: "";
	position: absolute;
	left: 0;
	top: 0;
	width: 100%;
	height: 3px;
	background: linear-gradient(90deg, var(--kb-color-primary), var(--kb-color-accent));
	transform: scaleX(0);
	transform-origin: left center;
	transition: transform .45s var(--kb-ease);
}
.kb-service-card:hover::before {
	transform: scaleX(1);
}
.kb-service-card__more {
	display: inline-flex;
	align-items: center;
	gap: .35rem;
	transition: gap .25s var(--kb-ease);
}
.kb-service-card:hover .kb-service-card__more {
	gap: .65rem;
}

/* ----- Stat card refined ----- */
.kb-stat__num {
	font-family: "Playfair Display", Georgia, serif;
	font-feature-settings: "tnum", "lnum";
	letter-spacing: -.02em;
}

/* ----- Buttons refined ----- */
.kb-btn {
	position: relative;
	overflow: hidden;
	isolation: isolate;
}
.kb-btn--primary::after {
	content: "";
	position: absolute;
	inset: 0;
	background: linear-gradient(135deg, var(--kb-color-primary), #b32228);
	z-index: -1;
	opacity: 0;
	transition: opacity .3s var(--kb-ease);
}
.kb-btn--primary:hover::after { opacity: 1; }

/* ----- Typography rhythm tighten ----- */
.kb-page-content > * + * {
	margin-top: 1.25em;
}
.kb-page-content p {
	line-height: 1.75;
	margin: 0 0 1.4rem;
}

/* ----- Section divider — decorative line marker ----- */
.kb-section + .kb-section,
.kb-section + .kb-section--alt,
.kb-section--alt + .kb-section {
	position: relative;
}

/* ----- Scroll-reveal base + visible state ----- */
.kb-reveal {
	opacity: 0;
	transform: translateY(28px);
	transition: opacity .7s var(--kb-ease), transform .7s var(--kb-ease);
	will-change: opacity, transform;
}
.kb-reveal.is-visible {
	opacity: 1;
	transform: translateY(0);
}
.kb-reveal-stagger > * {
	opacity: 0;
	transform: translateY(20px);
	transition: opacity .55s var(--kb-ease), transform .55s var(--kb-ease);
}
.kb-reveal-stagger.is-visible > * {
	opacity: 1;
	transform: translateY(0);
}
.kb-reveal-stagger.is-visible > *:nth-child(1) { transition-delay: 0ms; }
.kb-reveal-stagger.is-visible > *:nth-child(2) { transition-delay: 80ms; }
.kb-reveal-stagger.is-visible > *:nth-child(3) { transition-delay: 160ms; }
.kb-reveal-stagger.is-visible > *:nth-child(4) { transition-delay: 240ms; }
.kb-reveal-stagger.is-visible > *:nth-child(5) { transition-delay: 320ms; }
.kb-reveal-stagger.is-visible > *:nth-child(6) { transition-delay: 400ms; }
@media (prefers-reduced-motion: reduce) {
	.kb-reveal,
	.kb-reveal-stagger > * {
		opacity: 1 !important;
		transform: none !important;
		transition: none !important;
	}
	.kb-hero::before {
		animation: none !important;
	}
}

/* ============================================================
   CUSTOM FOOTER
   ============================================================ */
.kb-site-footer {
	background: var(--kb-color-header);
	color: rgba(255,255,255,.78);
	padding: clamp(3rem, 6vw, 4.5rem) 1.5rem 0;
	border-top: 4px solid var(--kb-color-primary);
	font-family: "Inter", system-ui, sans-serif;
}
.kb-site-footer__grid {
	max-width: 1200px;
	margin: 0 auto;
	display: grid;
	grid-template-columns: 1.4fr 1fr 1fr 1.2fr;
	gap: 3rem;
	padding-bottom: 3rem;
}
@media (max-width: 900px) {
	.kb-site-footer__grid {
		grid-template-columns: 1fr 1fr;
		gap: 2.5rem;
	}
}
@media (max-width: 540px) {
	.kb-site-footer__grid {
		grid-template-columns: 1fr;
	}
}
.kb-site-footer__brand img,
.kb-site-footer__brand .kb-footer-logo {
	display: block;
	width: 180px;
	height: 84px;
	background-image: var(--kb-footer-logo-url);
	background-repeat: no-repeat;
	background-position: left center;
	background-size: contain;
	margin-bottom: 1.25rem;
}
.kb-site-footer__tagline {
	font-family: "Playfair Display", Georgia, serif;
	font-size: 1.15rem;
	font-style: italic;
	color: #fff;
	margin: 0 0 1rem;
	line-height: 1.4;
}
.kb-site-footer__about {
	font-size: .95rem;
	line-height: 1.7;
	color: rgba(255,255,255,.65);
	margin: 0 0 1.25rem;
	max-width: 320px;
}
.kb-site-footer__heading {
	font-family: "Playfair Display", Georgia, serif;
	color: #fff;
	font-size: 1rem;
	font-weight: 700;
	letter-spacing: .04em;
	margin: 0 0 1.25rem;
	padding-bottom: .65rem;
	border-bottom: 1px solid rgba(255,255,255,.12);
}
.kb-site-footer__list {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: .65rem;
}
.kb-site-footer__list a {
	color: rgba(255,255,255,.7);
	text-decoration: none;
	font-size: .95rem;
	transition: color .25s var(--kb-ease), padding-left .25s var(--kb-ease);
	display: inline-flex;
	align-items: center;
	gap: .4rem;
}
.kb-site-footer__list a::before {
	content: "›";
	color: var(--kb-color-accent);
	opacity: 0;
	transform: translateX(-4px);
	transition: opacity .25s var(--kb-ease), transform .25s var(--kb-ease);
}
.kb-site-footer__list a:hover {
	color: #fff;
}
.kb-site-footer__list a:hover::before {
	opacity: 1;
	transform: translateX(0);
}
.kb-site-footer__contact {
	display: flex;
	flex-direction: column;
	gap: .75rem;
	font-size: .95rem;
	color: rgba(255,255,255,.78);
	line-height: 1.65;
}
.kb-site-footer__contact a {
	color: rgba(255,255,255,.78);
	text-decoration: none;
	transition: color .25s var(--kb-ease);
}
.kb-site-footer__contact a:hover {
	color: var(--kb-color-accent);
}
.kb-site-footer__contact-row {
	display: flex;
	gap: .65rem;
	align-items: flex-start;
}
.kb-site-footer__contact-row svg {
	width: 16px;
	height: 16px;
	color: var(--kb-color-accent);
	flex: none;
	margin-top: .2em;
}
.kb-site-footer__social {
	display: flex;
	gap: .6rem;
	margin-top: 1rem;
}
.kb-site-footer__social a {
	width: 36px;
	height: 36px;
	border-radius: 50%;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	background: rgba(255,255,255,.08);
	color: #fff;
	transition: all .25s var(--kb-ease);
}
.kb-site-footer__social a:hover {
	background: var(--kb-color-primary);
	transform: translateY(-2px);
}
.kb-site-footer__social svg {
	width: 16px;
	height: 16px;
}
.kb-site-footer__bottom {
	max-width: 1200px;
	margin: 0 auto;
	padding: 1.4rem 0;
	border-top: 1px solid rgba(255,255,255,.08);
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
	gap: 1rem;
	font-size: .85rem;
	color: rgba(255,255,255,.5);
}
.kb-site-footer__bottom em {
	font-family: "Playfair Display", Georgia, serif;
	font-style: italic;
	color: rgba(255,255,255,.7);
}

/* Hide Kadence default footer when our custom is rendered */
.kb-has-custom-footer #colophon { display: none !important; }

