/* ============================================================
   AVUKAT SITESI — Tasarim Sistemi
   Editoryel / type-led. Yuksek kontrast + doygun aksan.
   Ayrim: ince kural + bosluk + tipografik hiyerarsi (golge yagmuru YOK).
   ============================================================ */

:root {
  /* ---- Renk: yuksek kontrast + doygun (saf beyaz zemin, derin murekkep) ---- */
  --paper:        #FFFFFF;
  --paper-2:      #F4F6F8;   /* hafif soguk gri — bolum zemini */
  --paper-3:      #ECEFF3;   /* daha derin gri */
  --ink:          #0B1220;   /* neredeyse siyah-lacivert murekkep */
  --ink-soft:     #1C2533;
  --muted:        #44505F;   /* ikincil metin (AA+ kontrast) */
  --muted-2:      #6A7686;
  --border:       #D8DEE6;
  --border-strong:#C2CAD6;
  --accent:       #9B1B2E;   /* doygun bordo — otorite, yon */
  --accent-hover: #7E1525;
  --accent-2:     #0A2A4A;   /* derin lacivert — yapisal vurgu */
  --accent-weak:  rgba(155, 27, 46, 0.08);
  --on-dark:      #EAEEF3;   /* koyu zemin uzeri metin */
  --on-dark-mut:  #9DA9B8;

  /* ---- Tipografi ---- */
  --font-display: 'Newsreader', Georgia, 'Times New Roman', serif;
  --font-body:    'Geist', -apple-system, BlinkMacSystemFont, 'Segoe UI', system-ui, sans-serif;
  --font-mono:    'Geist Mono', ui-monospace, 'SFMono-Regular', 'Cascadia Code', monospace;

  /* ---- Tipografik olcek (Major Third 1.25, fluid clamp) ---- */
  --step--1: clamp(0.83rem, 0.80rem + 0.16vw, 0.92rem);
  --step-0:  clamp(1.00rem, 0.95rem + 0.22vw, 1.13rem);
  --step-1:  clamp(1.25rem, 1.16rem + 0.42vw, 1.52rem);
  --step-2:  clamp(1.56rem, 1.41rem + 0.74vw, 2.03rem);
  --step-3:  clamp(1.95rem, 1.71rem + 1.20vw, 2.71rem);
  --step-4:  clamp(2.44rem, 2.05rem + 1.92vw, 3.62rem);
  --step-5:  clamp(3.05rem, 2.45rem + 2.98vw, 4.82rem);

  /* ---- Bosluk (4/8 grid, fluid) ---- */
  --space-2xs: 0.375rem;
  --space-xs:  0.625rem;
  --space-sm:  1rem;
  --space-md:  1.5rem;
  --space-lg:  2.5rem;
  --space-xl:  clamp(3rem, 2.2rem + 3vw, 5rem);
  --space-2xl: clamp(4.5rem, 3.2rem + 5vw, 8rem);

  /* ---- Layout ---- */
  --container: 1180px;
  --measure: 68ch;          /* okuma genisligi (makale) */
  --gutter: clamp(1.25rem, 4vw, 3rem);

  /* ---- Detay ---- */
  --radius: 3px;            /* neredeyse keskin — resmi/editoryel */
  --rule: 1px solid var(--border);
  --ease: cubic-bezier(0.33, 0.06, 0.16, 1);
  --dur: 220ms;
}

/* ============================================================
   Reset / temel
   ============================================================ */
*, *::before, *::after { box-sizing: border-box; }
* { margin: 0; }
html {
  -webkit-text-size-adjust: 100%;
  text-size-adjust: 100%;
  scroll-behavior: smooth;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}
body {
  font-family: var(--font-body);
  font-size: var(--step-0);
  line-height: 1.65;
  color: var(--ink);
  background: var(--paper);
  text-rendering: optimizeLegibility;
  font-feature-settings: "kern" 1, "liga" 1;
  min-height: 100vh;
  display: flex;
  flex-direction: column;
}
img, picture, svg, video { display: block; max-width: 100%; height: auto; }
input, button, textarea, select { font: inherit; color: inherit; }
button { cursor: pointer; background: none; border: none; }
a { color: inherit; text-decoration: none; }
ul, ol { list-style: none; padding: 0; }
:where(h1, h2, h3, h4, h5, h6) { font-weight: 500; }

/* ============================================================
   Tipografi
   ============================================================ */
h1, .h1, h2, .h2, h3, .h3 {
  font-family: var(--font-display);
  line-height: 1.12;
  letter-spacing: -0.011em;
  color: var(--ink);
  text-wrap: balance;
}
h1, .h1 { font-size: var(--step-4); font-weight: 500; }
h2, .h2 { font-size: var(--step-3); font-weight: 500; }
h3, .h3 { font-size: var(--step-2); font-weight: 500; }
h4, .h4 { font-family: var(--font-body); font-size: var(--step-1); font-weight: 600; line-height: 1.3; letter-spacing: -0.005em; }

p { text-wrap: pretty; }
p + p { margin-top: var(--space-sm); }

.lead {
  font-size: var(--step-1);
  line-height: 1.5;
  color: var(--ink-soft);
  font-weight: 400;
}

/* Yapisal mono etiket (tarih, sicil no, bolum no) — eyebrow/pill DEGIL */
.mono {
  font-family: var(--font-mono);
  font-size: var(--step--1);
  letter-spacing: 0.04em;
  color: var(--muted);
  font-weight: 500;
}
.mono-label {
  font-family: var(--font-mono);
  font-size: 0.72rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--accent);
  font-weight: 500;
}

/* Baglantilar (govde icinde) */
.prose a, a.link {
  color: var(--accent);
  text-decoration: underline;
  text-decoration-thickness: 1px;
  text-underline-offset: 0.18em;
  text-decoration-color: color-mix(in srgb, var(--accent) 40%, transparent);
  transition: text-decoration-color var(--dur) var(--ease), color var(--dur) var(--ease);
}
.prose a:hover, a.link:hover { text-decoration-color: var(--accent); }

/* Secim */
::selection { background: var(--accent); color: #fff; }

/* Odak (a11y — net, lacivert) */
:focus-visible {
  outline: 2px solid var(--accent-2);
  outline-offset: 2px;
  border-radius: 2px;
}

/* Kural / ayraclar */
hr, .rule { border: none; border-top: var(--rule); margin: var(--space-lg) 0; }
.rule-accent { border: none; border-top: 2px solid var(--accent); width: 3.5rem; margin: 0 0 var(--space-md); }

/* ============================================================
   Yerlesim
   ============================================================ */
.container { width: 100%; max-width: var(--container); margin-inline: auto; padding-inline: var(--gutter); }
.section { padding-block: var(--space-2xl); }
.section--tight { padding-block: var(--space-xl); }
.section--alt { background: var(--paper-2); }

main { flex: 1 0 auto; }

.skip-link {
  position: absolute; left: -9999px; top: 0;
  background: var(--ink); color: #fff; padding: 0.6rem 1rem; z-index: 100;
  font-family: var(--font-mono); font-size: var(--step--1);
}
.skip-link:focus { left: 0; }

/* ============================================================
   Butonlar (nesnel, promosyonel DEGIL — sade editoryel)
   ============================================================ */
.btn {
  display: inline-flex; align-items: center; gap: 0.5rem;
  font-family: var(--font-body); font-size: var(--step-0); font-weight: 500;
  padding: 0.7rem 1.35rem; border-radius: var(--radius);
  transition: background var(--dur) var(--ease), color var(--dur) var(--ease), border-color var(--dur) var(--ease);
}
.btn--primary { background: var(--ink); color: var(--paper); }
.btn--primary:hover { background: var(--accent); }
.btn--ghost { border: 1px solid var(--border-strong); color: var(--ink); }
.btn--ghost:hover { border-color: var(--ink); background: var(--paper-2); }
.btn--link { padding: 0; color: var(--accent); font-weight: 500; }
.btn--link .arrow { transition: transform var(--dur) var(--ease); }
.btn--link:hover .arrow { transform: translateX(3px); }

/* ============================================================
   Header / masthead
   ============================================================ */
.site-header { border-bottom: 1px solid var(--border); background: var(--paper); position: sticky; top: 0; z-index: 50; }
.masthead {
  display: flex; align-items: center; justify-content: space-between;
  gap: var(--space-md); padding-block: 1.1rem;
}
.brand { display: flex; flex-direction: row; align-items: center; gap: 0.7rem; }
.brand__logo { width: 46px; height: 46px; flex-shrink: 0; }
.brand__text { display: flex; flex-direction: column; line-height: 1.1; }
.brand__name { font-family: var(--font-display); font-size: var(--step-1); font-weight: 600; color: var(--ink); letter-spacing: -0.01em; }
.brand__meta { font-family: var(--font-mono); font-size: 0.72rem; letter-spacing: 0.08em; color: var(--muted); margin-top: 0.25rem; text-transform: uppercase; }

.main-nav ul { display: flex; align-items: center; gap: clamp(1rem, 2.5vw, 2rem); }
.main-nav a {
  font-family: var(--font-body); font-size: var(--step--1); font-weight: 500; color: var(--ink-soft);
  padding-block: 0.4rem; position: relative; transition: color var(--dur) var(--ease);
}
.main-nav a::after {
  content: ""; position: absolute; left: 0; right: 0; bottom: -2px; height: 2px;
  background: var(--accent); transform: scaleX(0); transform-origin: left; transition: transform var(--dur) var(--ease);
}
.main-nav a:hover { color: var(--ink); }
.main-nav a:hover::after, .main-nav a[aria-current="page"]::after { transform: scaleX(1); }
.main-nav a[aria-current="page"] { color: var(--accent); }

.nav-toggle { display: none; }

/* ============================================================
   Footer (koyu lacivert zemin — yuksek kontrast otorite)
   Baro + sicil no GORUNUR (mesruiyet sinyali).
   ============================================================ */
.site-footer { background: var(--accent-2); color: var(--on-dark); margin-top: var(--space-2xl); }
.site-footer a { color: var(--on-dark); transition: color var(--dur) var(--ease); }
.site-footer a:hover { color: #fff; }
.footer-grid {
  display: grid; grid-template-columns: 1.4fr 1fr 1fr; gap: var(--space-lg);
  padding-block: var(--space-xl);
}
.footer-brand .brand__name { color: #fff; }
.footer-baro {
  font-family: var(--font-mono); font-size: var(--step--1); color: var(--on-dark-mut);
  margin-top: var(--space-sm); line-height: 1.8;
}
.footer-baro strong { color: var(--on-dark); font-weight: 500; }
.footer-col h2 { font-family: var(--font-mono); font-size: 0.72rem; letter-spacing: 0.14em; text-transform: uppercase; color: var(--on-dark-mut); font-weight: 500; margin-bottom: var(--space-sm); }
.footer-col ul { display: flex; flex-direction: column; gap: 0.55rem; }
.footer-col li { font-size: var(--step--1); }
.footer-bottom {
  border-top: 1px solid rgba(255,255,255,0.12); padding-block: 1.25rem;
  display: flex; flex-wrap: wrap; gap: var(--space-sm); justify-content: space-between;
  font-family: var(--font-mono); font-size: 0.72rem; color: var(--on-dark-mut); letter-spacing: 0.03em;
}

/* ============================================================
   Prose (makale / metin govdesi)
   ============================================================ */
.prose { max-width: var(--measure); }
.prose > * + * { margin-top: var(--space-sm); }
.prose h2 { font-size: var(--step-2); margin-top: var(--space-lg); }
.prose h3 { font-size: var(--step-1); margin-top: var(--space-md); }
.prose p, .prose li { color: var(--ink-soft); }
.prose ul { list-style: none; }
.prose ul li { position: relative; padding-left: 1.3rem; }
.prose ul li::before { content: ""; position: absolute; left: 0; top: 0.7em; width: 0.5rem; height: 1px; background: var(--accent); }
.prose ol { list-style: decimal; padding-left: 1.5rem; }
.prose ol li { color: var(--ink-soft); margin-bottom: 0.3rem; }
.prose img { max-width: 100%; height: auto; border-radius: var(--radius); margin: var(--space-md) 0; border-bottom: 2px solid var(--border); }
.prose figure { margin: var(--space-md) 0; }
.prose figure img { margin: 0; }
.prose figcaption { font-size: var(--step--1); color: var(--muted); margin-top: var(--space-2xs); }
.prose blockquote {
  font-family: var(--font-display); font-style: italic; font-size: var(--step-1);
  color: var(--ink); border-left: 2px solid var(--accent); padding-left: var(--space-md); margin-block: var(--space-md);
}

/* ============================================================
   Yardimcilar
   ============================================================ */
.text-muted { color: var(--muted); }
.flow > * + * { margin-top: var(--space-sm); }
.cluster { display: flex; flex-wrap: wrap; gap: var(--space-sm); align-items: center; }
.visually-hidden {
  position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px;
  overflow: hidden; clip: rect(0 0 0 0); white-space: nowrap; border: 0;
}

/* ============================================================
   Mobil / responsive
   ============================================================ */
@media (max-width: 820px) {
  .footer-grid { grid-template-columns: 1fr 1fr; }
  .footer-brand { grid-column: 1 / -1; }
}
@media (max-width: 680px) {
  .nav-toggle {
    display: inline-flex; align-items: center; justify-content: center;
    width: 2.75rem; height: 2.75rem; margin: -0.5rem; color: var(--ink);
  }
  .main-nav {
    position: absolute; top: 100%; left: 0; right: 0; background: var(--paper);
    border-bottom: 1px solid var(--border); padding: var(--space-sm) var(--gutter) var(--space-md);
    display: none;
  }
  .main-nav[data-open="true"] { display: block; }
  .main-nav ul { flex-direction: column; align-items: flex-start; gap: 0; }
  .main-nav li { width: 100%; border-bottom: 1px solid var(--border); }
  .main-nav li:last-child { border-bottom: none; }
  .main-nav a { display: block; padding-block: 0.85rem; width: 100%; font-size: var(--step-0); }
  .main-nav a::after { display: none; }
  .footer-grid { grid-template-columns: 1fr; gap: var(--space-md); }
}

/* ============================================================
   Sayfa bilesenleri — Hero (sinematik tam-genislik gorsel + lacivert scrim)
   ============================================================ */
.hero--feature {
  position: relative; isolation: isolate; overflow: hidden;
  min-height: clamp(540px, 80vh, 780px);
  display: flex; align-items: center;
  padding-block: var(--space-2xl);
  border-bottom: 1px solid var(--border);
}
.hero__media { position: absolute; inset: 0; z-index: -2; }
.hero__media img { width: 100%; height: 100%; object-fit: cover; object-position: 70% center; }
.hero__scrim {
  position: absolute; inset: 0; z-index: -1; display: block;
  background:
    linear-gradient(98deg, rgba(11,18,32,0.96) 0%, rgba(11,18,32,0.88) 28%, rgba(11,18,32,0.58) 52%, rgba(10,42,74,0.30) 78%, rgba(10,42,74,0.12) 100%),
    linear-gradient(0deg, rgba(11,18,32,0.45) 0%, rgba(11,18,32,0) 38%);
}
.hero__inner {
  display: grid; grid-template-columns: 1.15fr 0.85fr;
  gap: clamp(2rem, 5vw, 4.5rem); align-items: center; width: 100%;
}
.hero__content { max-width: 42rem; }
.hero__title { font-size: var(--step-5); font-weight: 500; line-height: 1.03; color: #fff; }
.hero--feature .rule-accent { border-top: 3px solid var(--accent); width: 4rem; margin: var(--space-md) 0; }
.hero__lead { max-width: 46ch; color: rgba(234,238,243,0.92); }
.hero__cta { display: flex; flex-wrap: wrap; gap: var(--space-sm); margin-top: var(--space-lg); }
.hero--feature .btn--primary { background: var(--accent); color: #fff; }
.hero--feature .btn--primary:hover { background: var(--accent-hover); }
.hero--feature .btn--ghost { border-color: rgba(255,255,255,0.45); color: #fff; }
.hero--feature .btn--ghost:hover { border-color: #fff; background: rgba(255,255,255,0.08); }

.hero__portrait { margin: 0; justify-self: end; max-width: 320px; width: 100%; }
.hero__portrait img {
  width: 100%; aspect-ratio: 4 / 5; object-fit: cover; object-position: top center;
  border-radius: var(--radius);
  border: 6px solid #fff;
  box-shadow: 0 34px 70px -28px rgba(0,0,0,0.75);
}
.hero__portrait figcaption {
  margin-top: var(--space-sm); text-align: right;
  font-family: var(--font-mono); font-size: var(--step--1);
  letter-spacing: 0.04em; color: rgba(234,238,243,0.78);
}

@media (max-width: 860px) {
  .hero__inner { grid-template-columns: 1fr; }
  .hero__content { order: 1; }
  .hero__portrait { order: 2; max-width: 220px; justify-self: start; margin-top: var(--space-sm); }
  .hero__portrait figcaption { text-align: left; }
}
@media (max-width: 560px) {
  .hero__portrait { display: none; }
  .hero__media img { object-position: 64% center; }
}

/* ---- Ic sayfa basligi ---- */
.page-head { padding-block: var(--space-xl) var(--space-md); border-bottom: 1px solid var(--border); }
.page-head__kicker { display: block; color: var(--accent); margin-bottom: var(--space-xs); }
.page-head__title { font-size: var(--step-4); }
.page-head__lead { max-width: 62ch; margin-top: var(--space-sm); }

/* ---- Makale kapak hero (kapak gorseli + lacivert scrim) ---- */
.article-hero { position: relative; isolation: isolate; overflow: hidden; min-height: clamp(320px, 48vh, 460px); display: flex; align-items: flex-end; padding-block: var(--space-xl); border-bottom: 1px solid var(--border); }
.article-hero__media { position: absolute; inset: 0; z-index: -2; }
.article-hero__media img { width: 100%; height: 100%; object-fit: cover; object-position: center; }
.article-hero__scrim { position: absolute; inset: 0; z-index: -1; background: linear-gradient(0deg, rgba(11,18,32,0.93) 0%, rgba(11,18,32,0.72) 38%, rgba(11,18,32,0.38) 72%, rgba(11,18,32,0.18) 100%); }
.article-hero__inner { width: 100%; }
.article-hero__date { color: rgba(234,238,243,0.82); margin-bottom: var(--space-xs); }
.article-hero__title { font-size: var(--step-4); color: #fff; max-width: 26ch; }
.article-hero__author { margin-top: var(--space-sm); font-family: var(--font-mono); font-size: var(--step--1); letter-spacing: 0.03em; color: rgba(234,238,243,0.82); }

/* ---- Bolum basligi ---- */
.section-head { margin-bottom: var(--space-lg); max-width: 60ch; }
.section-head h2 { font-size: var(--step-3); }
.section-head__desc { color: var(--muted); margin-top: var(--space-2xs); }
.section-foot { margin-top: var(--space-lg); }

/* ---- Faaliyet kartlari (hairline grid, golge YOK) ---- */
.area-grid {
  display: grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 1px; background: var(--border); border: 1px solid var(--border);
}
.area-grid--full { grid-template-columns: repeat(auto-fit, minmax(320px, 1fr)); }
.area-card { background: var(--paper); display: flex; flex-direction: column; overflow: hidden; }
.area-card__media { position: relative; aspect-ratio: 16 / 10; overflow: hidden; background: var(--accent-2); }
.area-card__media img { width: 100%; height: 100%; object-fit: cover; }
.area-card__media::after { content: ""; position: absolute; inset: 0; background: linear-gradient(180deg, rgba(11,18,32,0) 58%, rgba(11,18,32,0.30) 100%); pointer-events: none; }
.area-card__media--ph { background: linear-gradient(135deg, var(--accent-2) 0%, var(--ink) 72%); }
.area-card__media--ph::before { content: ""; position: absolute; inset: 0; background: radial-gradient(circle at 28% 26%, rgba(155,27,46,0.30), transparent 62%); }
.area-card__body { padding: var(--space-md); display: flex; flex-direction: column; gap: var(--space-2xs); flex: 1; }
.area-card__no { display: block; color: var(--accent); }
.area-card__title { font-size: var(--step-1); }
.area-card__desc { color: var(--muted); font-size: var(--step-0); margin-top: var(--space-2xs); }

/* ---- Makale listesi (eski editoryel liste — referans) ---- */
.article-list { border-top: 1px solid var(--border); }
.article-item { padding-block: var(--space-md); border-bottom: 1px solid var(--border); }
.article-item time { display: block; margin-bottom: var(--space-2xs); }
.article-item__title { font-size: var(--step-2); }
.article-item__title a { transition: color var(--dur) var(--ease); }
.article-item__title a:hover { color: var(--accent); }
.article-item__excerpt { color: var(--muted); margin-top: var(--space-2xs); max-width: 72ch; }

/* ---- Makale kartlari (kapak gorseli + ozet) ---- */
.post-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(300px, 1fr)); gap: var(--space-md); }
.post-card { display: flex; flex-direction: column; background: var(--paper); border: 1px solid var(--border); border-radius: var(--radius); overflow: hidden; transition: transform 0.45s var(--ease-fluid), box-shadow 0.45s var(--ease), border-color 0.3s var(--ease); }
.post-card:hover { transform: translateY(-6px); box-shadow: 0 26px 52px -30px rgba(10,42,74,0.5); border-color: var(--border-strong); }
.post-card__media { display: block; position: relative; aspect-ratio: 16 / 10; overflow: hidden; background: var(--accent-2); }
.post-card__media img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.7s var(--ease-fluid); }
.post-card:hover .post-card__media img { transform: scale(1.05); }
.post-card__media::after { content: ""; position: absolute; inset: 0; background: linear-gradient(180deg, rgba(11,18,32,0) 60%, rgba(11,18,32,0.28) 100%); }
.post-card__media--ph { background: linear-gradient(135deg, var(--accent-2) 0%, var(--ink) 72%); }
.post-card__media--ph::before { content: ""; position: absolute; inset: 0; background: radial-gradient(circle at 72% 28%, rgba(155,27,46,0.28), transparent 60%); }
.post-card__body { display: flex; flex-direction: column; gap: var(--space-2xs); padding: var(--space-md); flex: 1; }
.post-card__body time { color: var(--muted); }
.post-card__title { font-size: var(--step-1); line-height: 1.22; }
.post-card__title a { transition: color var(--dur) var(--ease); }
.post-card__title a:hover { color: var(--accent); }
.post-card__excerpt { color: var(--muted); font-size: var(--step-0); }
.post-card__more { margin-top: auto; padding-top: var(--space-xs); font-size: var(--step--1); font-weight: 500; color: var(--accent); display: inline-flex; align-items: center; gap: 0.4rem; }
.post-card__more .arrow { transition: transform var(--dur) var(--ease); }
.post-card:hover .post-card__more .arrow { transform: translateX(4px); }

/* ---- Iletisim ozeti ---- */
.home-contact { max-width: 660px; }
.contact-list { max-width: 42ch; margin-top: var(--space-sm); }
.contact-list__row { display: flex; align-items: baseline; justify-content: flex-start; gap: var(--space-md); padding-block: 0.7rem; border-bottom: 1px solid var(--border); }
.contact-list__row dt { color: var(--muted); font-size: var(--step--1); min-width: 5.5rem; flex-shrink: 0; }

/* ---- Iki kolon (hakkinda) ---- */
.two-col { display: grid; grid-template-columns: 1fr 320px; gap: var(--space-xl); align-items: start; }
.info-card { border: 1px solid var(--border); padding: var(--space-md); background: var(--paper-2); }
.info-card__head { color: var(--accent); margin-bottom: var(--space-sm); }
.info-list__row { display: flex; justify-content: space-between; gap: var(--space-sm); padding-block: 0.6rem; border-bottom: 1px solid var(--border); }
.info-list__row:last-child { border-bottom: none; }
.info-list__row dt { color: var(--muted); font-size: var(--step--1); }

/* ---- Hakkinda portresi ---- */
.about-portrait { margin: 0 0 var(--space-md); }
.about-portrait img { width: 100%; aspect-ratio: 4 / 5; object-fit: cover; object-position: top center; border-radius: var(--radius); border-bottom: 3px solid var(--accent); }

/* ---- Not kutusu ---- */
.note { margin-top: var(--space-xl); padding: var(--space-md) var(--space-md) var(--space-md) var(--space-lg); border-left: 2px solid var(--accent); background: var(--paper-2); max-width: 72ch; }
.note p { color: var(--muted); }

/* ---- Hata sayfalari ---- */
.error-page { padding-block: var(--space-2xl); }
.error-page__code { display: block; color: var(--accent); margin-bottom: var(--space-sm); }
.error-page__title { font-size: var(--step-4); }
.error-page__text { color: var(--muted); margin-block: var(--space-sm) var(--space-lg); max-width: 50ch; }

@media (max-width: 820px) {
  .two-col { grid-template-columns: 1fr; gap: var(--space-lg); }
}

/* ---- Sayfalama ---- */
.pagination { display: flex; align-items: center; justify-content: space-between; gap: var(--space-md); margin-top: var(--space-xl); padding-top: var(--space-md); border-top: 1px solid var(--border); }
.pagination__link { font-size: var(--step--1); font-weight: 500; color: var(--ink); transition: color var(--dur) var(--ease); }
.pagination__link:hover { color: var(--accent); }
.pagination__link.is-disabled { color: var(--border-strong); pointer-events: none; }
.pagination__status { color: var(--muted); }

/* ---- Makale detay ---- */
.article-detail__title { max-width: 22ch; }
.article-detail__author { margin-top: var(--space-sm); font-family: var(--font-mono); font-size: var(--step--1); letter-spacing: 0.02em; }
.article-detail__body { margin-top: var(--space-lg); }

/* ---- Iletisim formu ---- */
.two-col--contact { grid-template-columns: 1fr 340px; }
.alert { padding: var(--space-sm) var(--space-md); border-radius: var(--radius); margin-bottom: var(--space-md); font-size: var(--step-0); border-left: 3px solid; }
.alert--success { background: rgba(10,42,74,0.05); border-color: var(--accent-2); color: var(--accent-2); }
.alert--error { background: var(--accent-weak); border-color: var(--accent); color: var(--accent-hover); }

.contact-form .field { margin-bottom: var(--space-md); }
.field label { display: block; font-size: var(--step--1); font-weight: 500; margin-bottom: 0.4rem; }
.field .req { color: var(--accent); }
.field input, .field textarea {
  width: 100%; padding: 0.7rem 0.85rem; font-family: var(--font-body); font-size: var(--step-0);
  color: var(--ink); background: var(--paper); border: 1px solid var(--border-strong); border-radius: var(--radius);
  transition: border-color var(--dur) var(--ease), box-shadow var(--dur) var(--ease);
}
.field input:focus, .field textarea:focus { outline: none; border-color: var(--accent-2); box-shadow: 0 0 0 3px rgba(10,42,74,0.12); }
.field input[aria-invalid="true"], .field textarea[aria-invalid="true"] { border-color: var(--accent); }
.field textarea { resize: vertical; min-height: 8rem; }
.field__error { color: var(--accent); font-size: var(--step--1); margin-top: 0.35rem; }
.field__hint { color: var(--muted); font-size: var(--step--1); margin-top: 0.35rem; }
.field--check .check { display: flex; gap: 0.65rem; align-items: flex-start; cursor: pointer; font-size: var(--step--1); color: var(--muted); line-height: 1.55; }
.field--check input { margin-top: 0.15rem; width: 1.05rem; height: 1.05rem; flex-shrink: 0; accent-color: var(--accent); }
.hp-field { position: absolute !important; left: -9999px !important; width: 1px; height: 1px; overflow: hidden; }

.contact-info { border: 1px solid var(--border); padding: var(--space-md); background: var(--paper-2); align-self: start; }
.map-embed { margin-top: var(--space-md); aspect-ratio: 4 / 3; border: 1px solid var(--border); }
.map-embed iframe { width: 100%; height: 100%; border: 0; display: block; }

@media (max-width: 820px) { .two-col--contact { grid-template-columns: 1fr; } }

/* ============================================================
   Motion — akışkan scroll-reveal + premium geçişler
   (high-end-visual-design; GPU-güvenli: yalnız transform + opacity)
   ============================================================ */
:root {
  --ease-fluid:  cubic-bezier(0.32, 0.72, 0, 1);
  --ease-spring: cubic-bezier(0.34, 1.4, 0.64, 1);
}

/* Scroll-reveal — yalnız compositor (transform + opacity); blur YOK (jank kaynağıydı) */
.reveal { opacity: 0; transform: translateY(20px) scale(0.992); transition: opacity 0.5s var(--ease-fluid), transform 0.5s var(--ease-fluid); will-change: opacity, transform; }
.reveal.is-visible { opacity: 1; transform: none; will-change: auto; }
.reveal[data-delay="1"] { transition-delay: 0.05s; }
.reveal[data-delay="2"] { transition-delay: 0.10s; }
.reveal[data-delay="3"] { transition-delay: 0.15s; }
.reveal[data-delay="4"] { transition-delay: 0.20s; }
.reveal[data-delay="5"] { transition-delay: 0.25s; }
.reveal[data-delay="6"] { transition-delay: 0.30s; }

/* Hero — sayfa açılışında akışkan giriş */
.hero__content > *, .hero__portrait { opacity: 0; transform: translateY(26px); animation: heroIn 0.95s var(--ease-fluid) forwards; }
.hero__content > *:nth-child(1) { animation-delay: 0.12s; }
.hero__content > *:nth-child(2) { animation-delay: 0.20s; }
.hero__content > *:nth-child(3) { animation-delay: 0.28s; }
.hero__content > *:nth-child(4) { animation-delay: 0.36s; }
.hero__portrait { animation-delay: 0.32s; }
@keyframes heroIn { to { opacity: 1; transform: translateY(0); } }

/* Magnetic buton fiziği */
.btn { transition: transform 0.4s var(--ease-fluid), background 0.3s var(--ease), color 0.3s var(--ease), border-color 0.3s var(--ease); }
.btn:active { transform: scale(0.97); }
.btn .arrow { display: inline-block; transition: transform 0.4s var(--ease-spring); }
.btn:hover .arrow { transform: translateX(5px); }

/* Kart hover — yumuşak yükselme + görsel zoom */
.area-card { transition: transform 0.45s var(--ease-fluid), box-shadow 0.45s var(--ease); }
.area-card:hover { transform: translateY(-6px); box-shadow: 0 26px 52px -28px rgba(10, 42, 74, 0.5); position: relative; z-index: 1; }
.area-card__media img { transition: transform 0.7s var(--ease-fluid); }
.area-card:hover .area-card__media img { transform: scale(1.05); }

/* Makale satırı hover */
.article-item { transition: transform 0.4s var(--ease-fluid); }
.article-item:hover { transform: translateX(7px); }

/* Portre yakınlaşma */
.hero__portrait img, .about-portrait img { transition: transform 0.7s var(--ease-fluid); }
.hero__portrait:hover img, .about-portrait:hover img { transform: scale(1.03); }

/* Hareket azaltma tercihi */
@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; }
  .reveal { opacity: 1 !important; transform: none !important; filter: none !important; }
  .hero__content > *, .hero__portrait { opacity: 1 !important; transform: none !important; animation: none !important; }
}
