/* ============================================================
 *  styles.css — Ana stil dosyası
 * ============================================================
 *  Tek sayfalık tanıtım sitesinin tüm stilleri.
 *  Değişkenler variables.css'te tanımlıdır.
 *  Yaklaşım: Mobile-first (base = mobil, min-width ile büyüt)
 *  Bölüm sırası: font → reset → layout → bileşenler (HTML
 *  sırasında) → yardımcı sınıflar → erişilebilirlik → media query
 * ============================================================ */


/* ---- 1. Font tanımları ---- */
/* Outfit variable font — projeye gömülü, dış bağımlılığı yok.
   latin-ext: Türkçe karakterler | latin: Temel latin */
@font-face {
  font-family: 'Outfit';
  font-style: normal;
  font-weight: 100 900;
  font-display: swap;
  src: url(../fonts/outfit-latin-ext.woff2) format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}

@font-face {
  font-family: 'Outfit';
  font-style: normal;
  font-weight: 100 900;
  font-display: swap;
  src: url(../fonts/outfit-latin.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}


/* ---- 2. Sıfırlama ---- */
/* Değişkenler variables.css'te — burada sadece reset ve body */
* {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}

html {
  scroll-behavior: smooth;
}

body {
  background: var(--color-void);
  color: var(--color-text-primary);
  font-family: 'Outfit', sans-serif;
}

/* Preloader sürerken scroll'u engelle */
body.loading {
  overflow: hidden;
}


/* ---- 3. Preloader ---- */
/* Sayfa yüklenirken SONSEQ logosunu gösterir, 2 saniye sonra kaybolur */
.preloader {
  position: fixed;
  inset: 0;
  background: var(--color-void);
  z-index: var(--z-preloader);
  display: flex;
  align-items: center;
  justify-content: center;
  animation: preOut var(--animation-preloader) var(--animation-preloader-delay) forwards;
}

/* Preloader logosu — ortada belirip kaybolur (mobil boyut) */
.preloader-logo {
  height: var(--space-3xl);
  width: auto;
  opacity: 0;
  animation: logoFade var(--animation-logo-fade) ease forwards;
}

@keyframes logoFade {
  0% { opacity: 0; transform: scale(0.95); }
  30% { opacity: 1; transform: scale(1); }
  80% { opacity: 1; transform: scale(1); }
  100% { opacity: 0; transform: scale(1.02); }
}

@keyframes preOut {
  to { opacity: 0; pointer-events: none; }
}


/* ---- 4. Navigasyon (navbar) ---- */
/* Sabit üst bar. Blur arka plan, logo ve linkleri (mobil padding) */
nav {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: var(--z-nav);
  padding: var(--space-md) var(--space-lg);
  display: flex;
  justify-content: space-between;
  align-items: center;
  background: rgba(var(--color-void-rgb), 0.75);
  backdrop-filter: var(--blur-backdrop);
  -webkit-backdrop-filter: var(--blur-backdrop);
}

/* Nav altındaki gradient gölge — içerikle yumuşak geçiş */
nav::after {
  content: '';
  position: absolute;
  top: 100%;
  left: 0;
  right: 0;
  height: var(--space-60);
  background: linear-gradient(180deg, rgba(var(--color-void-rgb), 0.4), rgba(var(--color-void-rgb), 0.1) 40%, transparent);
  pointer-events: none;
}

/* Logo (mobil boyut) */
.logo {
  display: flex;
  align-items: center;
  text-decoration: none;
}

.logo img {
  height: var(--space-3xl);
  width: auto;
}

/* Masaüstü nav linkleri — mobilde gizli */
.nav-links {
  display: none;
  gap: var(--space-28);
  list-style: none;
}

.nav-links a {
  font-size: var(--text-sm);
  letter-spacing: 0;
  color: var(--color-text-secondary);
  text-decoration: none;
  transition: color var(--transition-base);
  position: relative;
}

/* Link altındaki turuncu çizgi animasyonu */
.nav-links a::after {
  content: '';
  position: absolute;
  bottom: calc(-1 * var(--space-4));
  left: 0;
  width: 0;
  height: var(--line-thin);
  background: var(--color-orange);
  transition: width var(--transition-base);
}

.nav-links a:hover {
  color: var(--color-orange);
}

.nav-links a:hover::after {
  width: 100%;
}


/* ---- 5. Hamburger menü (mobil) ---- */
/* Mobilde görünen hamburger butonu ve açılır dropdown menü */

/* Hamburger butonu — mobilde görünür (mobile-first) */
.hamburger {
  display: flex;
  background: none;
  border: var(--line-thin) solid var(--color-border);
  border-radius: var(--radius-sm);
  cursor: pointer;
  padding: var(--space-sm);
  width: var(--touch-min);
  height: var(--touch-min);
  position: relative;
  transition: border-color var(--transition-fast);
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: var(--space-5);
}

.hamburger:hover {
  border-color: var(--color-orange);
}

/* Hamburger çizgileri */
.hamburger span {
  display: block;
  width: var(--space-md);
  height: var(--line-thin);
  background: var(--color-text-primary);
  transition: transform var(--transition-base), opacity var(--transition-base);
  transform-origin: center;
}

/* Açıkken X şeklini alır */
.hamburger.active span:nth-child(1) {
  transform: rotate(45deg) translateY(var(--hamburger-shift));
}

.hamburger.active span:nth-child(2) {
  opacity: 0;
  transform: scaleX(0);
}

.hamburger.active span:nth-child(3) {
  transform: rotate(-45deg) translateY(calc(-1 * var(--hamburger-shift)));
}

/* Mobil dropdown menü */
.mobile-menu {
  position: absolute;
  top: calc(100% - var(--space-4));
  right: var(--space-lg);
  background: rgba(var(--color-surface-rgb), 0.95);
  border: var(--line-thin) solid var(--color-border);
  border-radius: var(--radius-md);
  padding: var(--space-12) var(--space-lg);
  list-style: none;
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transform: translateY(calc(-1 * var(--space-6)));
  transition: opacity var(--transition-base), transform var(--transition-base), visibility 0s var(--transition-base);
  backdrop-filter: var(--blur-backdrop);
  -webkit-backdrop-filter: var(--blur-backdrop);
}

.mobile-menu.open {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
  transform: translateY(0);
  transition: opacity var(--transition-base), transform var(--transition-base), visibility 0s 0s;
}

.mobile-menu li {
  padding: var(--space-sm) 0;
}

.mobile-menu a {
  font-size: var(--text-base);
  letter-spacing: 0;
  color: var(--color-text-secondary);
  text-decoration: none;
  transition: color var(--transition-fast);
  min-height: var(--touch-min);
  display: flex;
  align-items: center;
}

.mobile-menu a:hover {
  color: var(--color-orange);
}


/* ---- 6. Hero bölümü ---- */
/* Tam ekran giriş alanı. Turuncu nokta, başlık ve alt çizgi */

/* 100vh fallback — mobil Safari'de dvh kullanılır */
.hero {
  height: 100vh;
  height: 100dvh;
  display: flex;
  align-items: center;
  justify-content: center;
}

.void-center {
  text-align: center;
  animation: heroIn var(--animation-reveal) var(--animation-reveal-delay) both;
}

@keyframes heroIn {
  from { opacity: 0; }
  to { opacity: 1; }
}

/* Ortadaki turuncu parlayan nokta */
.void-dot {
  width: var(--space-4);
  height: var(--space-4);
  border-radius: 50%;
  background: var(--color-orange);
  margin: 0 auto var(--space-50);
  box-shadow: 0 0 var(--glow-lg) var(--color-orange), 0 0 var(--glow-xl) rgba(var(--color-orange-rgb), 0.2);
  animation: voidPulse var(--animation-pulse) ease-in-out infinite;
}

@keyframes voidPulse {
  0%, 100% {
    transform: scale(1);
    opacity: 0.8;
  }
  50% {
    transform: scale(1.5);
    opacity: 1;
  }
}

/* Hero başlığı (mobil letter-spacing) */
.hero-title {
  font-size: var(--text-hero-title);
  font-weight: 800;
  letter-spacing: var(--tracking-lg);
  color: var(--color-white);
  margin-bottom: var(--space-md);
}

/* Hero alt yazı (mobil letter-spacing) */
.hero-sub {
  font-size: var(--text-hero-sub);
  font-weight: 300;
  letter-spacing: var(--tracking-xl);
  color: var(--color-text-primary);
}

/* Hero alt çizgisi — turuncu gradient */
.hero-line {
  width: var(--space-1);
  height: var(--space-50);
  background: linear-gradient(180deg, var(--color-orange), transparent);
  margin: var(--space-50) auto 0;
  opacity: 0.4;
}


/* ---- 7. Ortak bölüm elemanları ---- */
/* Bölümler arası tekrar eden noktalar ve genel section padding */

/* Turuncu ayırıcı nokta — bölümler arasında kullanılır */
.section-dot {
  width: var(--space-3);
  height: var(--space-3);
  border-radius: 50%;
  background: var(--color-orange);
  margin: var(--space-36) auto;
  opacity: 0.4;
  box-shadow: 0 0 var(--glow-sm) var(--color-orange);
}

/* Genel bölüm padding ve max-width (mobil) */
.section {
  padding: var(--space-5xl) var(--space-lg);
  max-width: var(--max-w-4xl);
  margin: 0 auto;
}


/* ---- 8. Hikayemiz bölümü ---- */
/* Şirket hikayesi, manifesto alanı */
.story-section {
  text-align: center;
}

/* Hikayemiz başlığı (mobil letter-spacing) */
.story-title {
  font-size: var(--text-section-title);
  font-weight: 700;
  color: var(--color-white);
  letter-spacing: var(--tracking-xl);
  margin-bottom: var(--space-4xl);
}

.story-title b {
  color: var(--color-orange);
  font-weight: 700;
}

/* Hikayemiz içerik metni */
.about-text {
  max-width: var(--max-w-xl);
  margin: 0 auto;
  text-align: center;
}

.about-text p {
  font-size: var(--text-md);
  color: var(--color-text-primary);
  line-height: 1.9;
  font-weight: 300;
  margin-bottom: var(--space-18);
}

/* Alt manifesto tek satır */
.manifesto-single {
  text-align: center;
  padding: var(--space-3xl) 0 0;
}

.manifesto-single p {
  font-size: var(--text-manifesto);
  font-weight: 300;
  color: var(--color-text-primary);
  letter-spacing: var(--tracking-sm);
  font-style: italic;
}

/* Manifesto içindeki vurgulu (accent) kelime */
.manifesto-single .accent-word {
  color: var(--color-orange);
  text-shadow: 0 0 var(--glow-lg) rgba(var(--color-orange-rgb), 0.15);
}


/* ---- 9. Projeler bölümü ---- */
/* Açılır-kapanır proje kartları ve store linkleri (mobil padding) */
.works {
  padding: var(--space-5xl) var(--space-lg);
  max-width: var(--max-w-2xl);
  margin: 0 auto;
}

/* Tek proje satırı */
.work-item {
  text-align: center;
  padding: var(--touch-min) 0;
  border-bottom: var(--line-thin) solid var(--color-border);
  transition: border-color var(--transition-slow);
  cursor: pointer;
}

.work-item:hover {
  border-color: var(--color-orange);
}

.work-item.active {
  border-color: var(--color-orange);
}

/* Proje başlığı */
.work-title {
  font-size: var(--text-work-title);
  font-weight: 600;
  letter-spacing: var(--tracking-3xl);
  color: var(--color-text-light);
  transition: color var(--transition-slow);
}

.work-item:hover .work-title,
.work-item.active .work-title {
  color: var(--color-white);
}

/* Proje alt etiketi (örn: MOBİL UYGULAMA) */
.work-meta {
  font-size: var(--text-2xs);
  letter-spacing: var(--tracking-2xl);
  color: var(--color-text-secondary);
  margin-top: var(--space-xs);
  font-weight: 300;
  transition: color var(--transition-slow);
}

.work-item:hover .work-meta,
.work-item.active .work-meta {
  color: var(--color-orange);
}

/* Açılır detay alanı — max-height animasyonu ile (mobil max-height) */
.work-expand {
  max-height: 0;
  overflow: hidden;
  transition: max-height var(--transition-accordion) ease, opacity var(--transition-base) ease, visibility 0s var(--transition-accordion);
  opacity: 0;
  visibility: hidden;
}

.work-item.active .work-expand {
  max-height: var(--max-h-work-expand);
  opacity: 1;
  visibility: visible;
  transition: max-height var(--transition-accordion) ease, opacity var(--transition-base) ease, visibility 0s 0s;
}

.work-detail {
  padding: var(--space-xl) 0 var(--space-xs);
  max-width: var(--max-w-md);
  margin: 0 auto;
}

.work-detail p {
  font-size: var(--text-base);
  color: var(--color-text-primary);
  line-height: 1.8;
  font-weight: 300;
}

/* App Store / Google Play butonları (mobil letter-spacing) */
.store-badges {
  display: flex;
  gap: var(--space-14);
  justify-content: center;
  margin-top: var(--space-xl);
}

.store-link {
  display: inline-flex;
  align-items: center;
  gap: var(--space-6);
  padding: var(--space-sm) var(--space-lg);
  border: var(--line-thin) solid var(--color-border);
  min-height: var(--touch-min);
  border-radius: var(--radius-sm);
  color: var(--color-text-primary);
  font-size: var(--text-sm);
  letter-spacing: 0;
  text-decoration: none;
  font-weight: 400;
  transition: border-color var(--transition-base), color var(--transition-base);
}

.store-link:hover {
  border-color: var(--color-orange);
  color: var(--color-orange);
}

/* Açma/kapama ok ikonu */
.work-toggle {
  font-size: var(--text-lg);
  color: var(--color-text-muted);
  margin-top: var(--space-sm);
  transition: color var(--transition-base), transform var(--transition-base);
  display: inline-block;
}

.work-item:hover .work-toggle {
  color: var(--color-orange);
}

.work-item.active .work-toggle {
  transform: rotate(180deg);
  color: var(--color-orange);
}


/* ---- 10. İletişim (CTA) bölümü ---- */
/* Başlık, açıklama ve e-posta kartları (mobil padding) */
.cta {
  padding: var(--space-5xl) var(--space-lg);
  text-align: center;
}

.cta-title {
  font-size: var(--text-cta-title);
  font-weight: 300;
  color: var(--color-white);
  line-height: 1.4;
  margin-bottom: var(--space-14);
  letter-spacing: var(--tracking-md);
}

.cta-title b {
  color: var(--color-orange);
  font-weight: 300;
}

.cta-sub {
  font-size: var(--text-md);
  color: var(--color-text-secondary);
  margin-bottom: var(--space-2xl);
  font-weight: 300;
  line-height: 1.7;
  max-width: var(--max-w-sm);
  margin-left: auto;
  margin-right: auto;
}

/* Sosyal medya ikonu — CTA bölümünde ortalı */
.cta-social {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: var(--touch-min);
  min-height: var(--touch-min);
  color: var(--color-text-secondary);
  text-decoration: none;
  padding: var(--space-xs);
  margin-bottom: var(--space-xl);
  transition: color var(--transition-base);
}

.cta-social:hover {
  color: var(--color-orange);
}

/* E-posta kartları grid — mobilde tek sütun */
.cta-cards {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-lg);
  max-width: var(--max-w-lg);
  margin: 0 auto;
}

/* Tek e-posta kartı (mobil padding) */
.cta-card {
  display: block;
  text-decoration: none;
  border: var(--line-thin) solid var(--color-border);
  border-radius: var(--radius-md);
  padding: var(--space-lg) var(--space-18);
  text-align: left;
  transition: border-color var(--transition-slow), box-shadow var(--transition-slow);
}

.cta-card:hover {
  border-color: var(--color-orange);
  box-shadow: 0 0 var(--glow-md) var(--color-orange-dim);
}

/* Kart etiketi (örn: Proje Tasarımı) */
.cta-card-label {
  font-size: var(--text-sm);
  letter-spacing: var(--tracking-sm);
  color: var(--color-text-secondary);
  margin-bottom: var(--space-sm);
  font-weight: 400;
}

/* Kart e-posta adresi */
.cta-card-email {
  font-size: var(--text-md);
  color: var(--color-text-light);
  font-weight: 500;
  letter-spacing: var(--tracking-sm);
  transition: color var(--transition-base);
}

.cta-card:hover .cta-card-email {
  color: var(--color-orange);
}


/* ---- 11. Footer ---- */
/* Alt kısım. KVKK linki ortalı */
footer {
  padding: var(--space-3xl) 0 var(--space-xl);
  text-align: center;
}

/* Footer KVKK linki */
.footer-link {
  font-size: var(--text-xs);
  color: var(--color-text-muted);
  text-decoration: none;
  letter-spacing: var(--tracking-xs);
  font-weight: 300;
  transition: color var(--transition-base);
  min-height: var(--touch-min);
  display: inline-flex;
  align-items: center;
}

.footer-link:hover {
  color: var(--color-orange);
}


/* ---- 12. KVKK banner ---- */
/* Mobilde tam genişlik, altta sabit çerez onay kutusu */
.consent-banner {
  position: fixed;
  bottom: 0;
  right: 0;
  left: 0;
  max-width: none;
  background: rgba(var(--color-surface-rgb), 0.95);
  border: var(--line-thin) solid var(--color-border);
  border-radius: var(--radius-lg) var(--radius-lg) 0 0;
  padding: var(--space-lg);
  z-index: var(--z-consent);
  backdrop-filter: var(--blur-backdrop);
  -webkit-backdrop-filter: var(--blur-backdrop);
  opacity: 0;
  animation: bannerIn var(--animation-reveal) var(--animation-reveal-delay) both;
}

@keyframes bannerIn {
  from { opacity: 0; }
  to { opacity: 1; }
}

/* Banner gizliyken */
.consent-banner.hidden {
  display: none;
}

/* Banner başlık */
.consent-title {
  font-size: var(--text-base);
  font-weight: 600;
  color: var(--color-white);
  margin-bottom: var(--space-xs);
  letter-spacing: var(--tracking-xs);
}

/* Banner açıklama metni */
.consent-text {
  font-size: var(--text-sm);
  color: var(--color-text-secondary);
  line-height: 1.7;
  font-weight: 300;
  margin-bottom: var(--space-md);
}

/* KVKK sayfa linki */
.consent-link {
  color: var(--color-text-light);
  text-decoration: none;
  border-bottom: var(--line-thin) solid var(--color-border);
  transition: color var(--transition-fast), border-color var(--transition-fast);
}

.consent-link:hover {
  color: var(--color-orange);
  border-color: var(--color-orange);
}

/* Kabul Et butonunu sağa hizala */
.consent-actions {
  text-align: right;
}

/* Consent butonları — ortak özellikler (mobil letter-spacing) */
.consent-btn {
  display: inline-block;
  -webkit-appearance: none;
  appearance: none;
  background: none;
  border-radius: var(--radius-sm);
  font-family: inherit;
  font-size: var(--text-sm);
  font-weight: 500;
  letter-spacing: 0;
  padding: var(--space-sm) var(--space-xl);
  min-height: var(--touch-min);
  cursor: pointer;
}

/* Reddet butonu — soluk */
.consent-reject {
  border: var(--line-thin) solid var(--color-border);
  color: var(--color-text-secondary);
  transition: border-color var(--transition-fast), color var(--transition-fast);
  margin-right: var(--space-xs);
}

.consent-reject:hover {
  border-color: var(--color-text-muted);
  color: var(--color-text-light);
}

/* Kabul Et butonu */
.consent-accept {
  border: var(--line-thin) solid var(--color-orange);
  color: var(--color-orange);
  transition: background var(--transition-fast), color var(--transition-fast);
}

.consent-accept:hover {
  background: var(--color-orange);
  color: var(--color-void);
}


/* ---- 13. KVKK sayfa stilleri ---- */
/* privacypolicy sayfasının içerik düzeni (mobil padding) */

/* Sayfa içerik alanı — navbar altında başlar */
.legal-content {
  max-width: var(--max-w-3xl);
  margin: 0 auto;
  padding: var(--space-100) var(--space-lg) var(--space-60);
  min-height: 100vh;
  min-height: 100dvh;
}

/* Sayfa başlığı */
.legal-title {
  font-size: var(--text-legal-title);
  font-weight: 600;
  color: var(--color-white);
  letter-spacing: 0;
  margin-bottom: var(--space-3xl);
}

.legal-title b {
  color: var(--color-orange);
  font-weight: 600;
}

/* KVKK içerik kutusu (mobil padding) */
.legal-box {
  border: var(--line-thin) solid var(--color-border);
  border-radius: var(--radius-lg);
  padding: var(--space-lg);
  margin-bottom: var(--space-lg);
  line-height: 1.9;
  font-size: var(--text-md);
  color: var(--color-text-primary);
  font-weight: 300;
}

.legal-box:last-child {
  margin-bottom: 0;
}

.legal-box p {
  margin-bottom: var(--space-md);
}

.legal-box p:last-child {
  margin-bottom: 0;
}

/* Kutu içi alt başlıklar */
.legal-box h2,
.legal-box h3 {
  font-size: var(--text-lg);
  font-weight: 600;
  color: var(--color-white);
  letter-spacing: var(--tracking-md);
  margin: var(--space-2xl) 0 var(--space-12);
}

.legal-box h2:first-child,
.legal-box h3:first-child {
  margin-top: 0;
}


/* ---- 14. Animasyonlar ---- */
/* Scroll ile görünür olan elemanlar için fade-in efekti */
.fade {
  opacity: 0;
  transform: translateY(var(--space-lg));
  transition: opacity var(--animation-fade) cubic-bezier(0.25, 0.46, 0.45, 0.94), transform var(--animation-fade) cubic-bezier(0.25, 0.46, 0.45, 0.94);
}

.fade.in {
  opacity: 1;
  transform: translateY(0);
}


/* ---- 15. Erişilebilirlik ---- */
/* Tab ile gezinirken odaklanan elemanı belirgin hale getirir */
:focus-visible {
  outline: var(--outline-focus) solid var(--color-orange);
  outline-offset: var(--space-3);
}

/* Sadece screen reader'lar için görünür — görsel olarak gizli */
.sr-only {
  position: absolute;
  width: var(--space-1);
  height: var(--space-1);
  padding: 0;
  margin: calc(-1 * var(--space-1));
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}


/* ---- 16. Responsive — Tablet ve üstü (min-width: 768px) ---- */
@media (min-width: 768px) {
  nav { padding: var(--space-22) var(--space-2xl); }

  /* Masaüstü linkleri göster, hamburger gizle */
  .nav-links { display: flex; }
  .hamburger { display: none; }

  /* Navbar ve preloader logosu büyüt */
  .logo img { height: var(--space-54); }
  .preloader-logo { height: var(--space-54); }

  .section { padding: var(--space-100) var(--space-2xl); }
  .works { padding: var(--space-100) var(--space-2xl); }

  /* Hero letter-spacing büyüt */
  .hero-title { letter-spacing: var(--tracking-3xl); }
  .hero-sub { letter-spacing: var(--tracking-5xl); }

  /* Hikayemiz başlığı letter-spacing büyüt */
  .story-title { letter-spacing: var(--tracking-4xl); }

  /* Store buton letter-spacing */
  .store-link { letter-spacing: var(--tracking-md); }

  /* Proje detayı masaüstü max-height */
  .work-item.active .work-expand { max-height: var(--max-h-work-expand-md); }

  /* İletişim bölümü büyüt */
  .cta { padding: var(--space-6xl) var(--space-2xl); }

  /* E-posta kartları 2 sütun, padding büyüt */
  .cta-cards { grid-template-columns: 1fr 1fr; }
  .cta-card { padding: var(--space-28) var(--space-xl); }

  /* KVKK banner — sağ alt köşe, sabit genişlik */
  .consent-banner {
    bottom: var(--space-lg);
    right: var(--space-lg);
    left: auto;
    max-width: var(--max-w-xs);
    border-radius: var(--radius-lg);
    padding: var(--space-xl);
  }

  /* Consent buton letter-spacing */
  .consent-btn { letter-spacing: var(--tracking-sm); }

  /* KVKK sayfa padding büyüt */
  .legal-content { padding: var(--space-140) var(--space-2xl) var(--space-60); }
  .legal-box { padding: var(--space-2xl); }
}


/* ---- 17. Responsive — Masaüstü ve üstü (min-width: 1024px) ---- */
@media (min-width: 1024px) {
  nav { padding: var(--space-22) var(--space-4xl); }
  .section { padding: var(--space-6xl) var(--space-4xl); }
  .works { padding: var(--space-6xl) var(--space-4xl); }
  .cta { padding: var(--space-7xl) var(--space-4xl); }
  .legal-content { padding: var(--space-7xl) var(--space-4xl) var(--space-5xl); }
}


/* ---- 18. Responsive — Yatay telefon/tablet ---- */
/* Hero bölümünün taşmasını engeller, boşlukları daraltır.
   max-height kullandığı için mobile-first dönüşümünden etkilenmez */
@media (max-height: 500px) and (orientation: landscape) {
  .hero { height: auto; min-height: 100dvh; }
  .void-dot { margin-bottom: var(--space-xl); }
  .hero-line { height: var(--space-30); margin-top: var(--space-xl); }
  .section { padding: var(--space-60) var(--space-2xl); }
  .works { padding: var(--space-60) var(--space-2xl); }
  .cta { padding: var(--space-60) var(--space-2xl); }
  .legal-content { padding: var(--space-5xl) var(--space-2xl) var(--space-3xl); }
}


/* ---- 19. Erişilebilirlik — Hareket hassasiyeti ---- */
/* Kullanıcı işletim sisteminde "hareketi azalt" seçeneğini
   açtıysa tüm animasyonları ve geçişleri devre dışı bırakır */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }
}
