/* ============================================================
   Babil Arka Bahçe — design system
   Palette: cream #F6F1E7 · ink #211E1A · rust #A8552F / #C07A52
            olive #5F6238 / #4A4D2E · footer #24221A
   Type:    Cormorant Garamond (serif) · Inter (sans)
   ============================================================ */

:root {
  --bg: #F6F1E7;
  --bg-alt: #EFE8D7;
  --bg-card: #FBF8F0;
  --ink: #211E1A;
  --ink-soft: #33302A;
  --muted: #5C5547;
  --muted-2: #8A8270;
  --muted-3: #8A7E66;
  --rust: #A8552F;
  --rust-2: #C07A52;
  --olive: #5F6238;
  --olive-deep: #4A4D2E;
  --cream: #F0EADA;
  --cream-2: #F2EDDD;
  --line: #DCD2BC;
  --line-2: #D8CDB4;
  --line-3: #C9BD9F;
  --serif: 'Cormorant Garamond', Georgia, serif;
  --sans: 'Inter', system-ui, sans-serif;
  --mono: ui-monospace, 'SF Mono', Menlo, monospace;
}

* { box-sizing: border-box; }

html { scroll-behavior: smooth; }

html, body {
  margin: 0;
  padding: 0;
  background: var(--bg);
}

body {
  color: var(--ink);
  font-family: var(--sans);
  min-height: 100vh;
  -webkit-font-smoothing: antialiased;
}

::selection { background: var(--rust); color: var(--bg); }

img { max-width: 100%; display: block; }

.container {
  max-width: 1320px;
  margin: 0 auto;
  padding-left: clamp(20px, 4vw, 48px);
  padding-right: clamp(20px, 4vw, 48px);
}

/* ---------- typography ---------- */

.eyebrow {
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.3em;
  text-transform: uppercase;
  color: var(--rust);
}

.eyebrow--sand { color: #C9A77E; }
.eyebrow--gold { color: #D9C9A8; }
.eyebrow--wide { letter-spacing: 0.4em; }

h1, h2, h3 { margin: 0; font-family: var(--serif); font-weight: 400; }

.display {
  font-size: clamp(40px, 6.5vw, 88px);
  line-height: 1.05;
  text-wrap: balance;
}

.display em, .h-section em, .cta-band h2 em { font-style: italic; color: var(--olive); }

.h-section {
  font-size: clamp(32px, 4.4vw, 56px);
  line-height: 1.1;
  text-wrap: balance;
}

.lede {
  margin: 0;
  font-size: 14px;
  line-height: 1.8;
  color: var(--muted);
  max-width: 360px;
  text-wrap: pretty;
}

/* ---------- buttons & links ---------- */

.btn {
  display: inline-block;
  font-family: var(--sans);
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  text-decoration: none;
  cursor: pointer;
  border: none;
  transition: background 0.2s ease, color 0.2s ease, border-color 0.2s ease;
}

.btn--cream { color: #24221A; background: var(--cream); padding: 16px 32px; }
.btn--cream:hover { background: var(--rust-2); color: var(--cream); }

.btn--ghost-light { color: var(--cream); border: 1px solid rgba(240, 234, 218, 0.5); padding: 15px 32px; background: transparent; }
.btn--ghost-light:hover { border-color: var(--cream); background: rgba(240, 234, 218, 0.1); }

.btn--ink { color: var(--bg); background: var(--ink); padding: 18px 36px; white-space: nowrap; }
.btn--ink:hover { background: var(--rust); }

.btn--outline-ink { color: var(--ink); border: 1px solid var(--ink); background: transparent; padding: 15px 30px; white-space: nowrap; }
.btn--outline-ink:hover { background: var(--ink); color: var(--bg); }

.btn--olive-cream { color: var(--olive); background: var(--cream-2); padding: 18px 36px; white-space: nowrap; }
.btn--olive-cream:hover { background: var(--rust-2); color: var(--cream-2); }

.btn--olive-ghost { color: var(--cream-2); border: 1px solid rgba(242, 237, 221, 0.5); padding: 15px 30px; background: transparent; }
.btn--olive-ghost:hover { border-color: var(--cream-2); background: rgba(242, 237, 221, 0.08); }

.link-arrow {
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  text-decoration: none;
  color: var(--ink);
  border-bottom: 1px solid var(--ink);
  padding-bottom: 6px;
  align-self: flex-start;
  transition: color 0.2s ease, border-color 0.2s ease;
}

.link-arrow:hover { color: var(--rust); border-color: var(--rust); }

/* ---------- placeholder tiles ---------- */

.tile {
  border: 1px solid var(--line-2);
  display: flex;
  align-items: center;
  justify-content: center;
  background: repeating-linear-gradient(135deg, #E5DBC4 0px, #E5DBC4 12px, #ECE4D0 12px, #ECE4D0 24px);
}

.tile--b { background: repeating-linear-gradient(135deg, #DCD4BE 0px, #DCD4BE 12px, #E4DCC8 12px, #E4DCC8 24px); }
.tile--c { background: repeating-linear-gradient(135deg, #E0D5BB 0px, #E0D5BB 12px, #E8DFCC 12px, #E8DFCC 24px); }
.tile--dashed { border: 1px dashed var(--line-3); }

.tile > span {
  font-family: var(--mono);
  font-size: 11px;
  color: var(--muted-3);
  letter-spacing: 0.06em;
  padding: 0 16px;
  text-align: center;
}

/* ---------- header / nav ---------- */

.site-header {
  position: sticky;
  top: 0;
  z-index: 50;
  background: rgba(246, 241, 231, 0.94);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  border-bottom: 1px solid #DFD5C0;
}

.site-header__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
  min-height: 78px;
  flex-wrap: wrap;
}

.brand {
  text-decoration: none;
  color: var(--ink);
  display: flex;
  flex-direction: column;
  gap: 3px;
  padding: 14px 0;
}

.brand__name {
  font-family: var(--serif);
  font-size: 25px;
  font-weight: 500;
  letter-spacing: 0.12em;
  line-height: 1;
}

.brand__sub {
  font-family: var(--sans);
  font-size: 8.5px;
  font-weight: 600;
  letter-spacing: 0.46em;
  color: var(--rust);
}

.site-nav {
  display: flex;
  align-items: center;
  gap: clamp(14px, 2vw, 28px);
  flex-wrap: wrap;
  row-gap: 8px;
  padding: 10px 0;
}

.site-nav__link {
  font-family: var(--sans);
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  text-decoration: none;
  color: var(--ink-soft);
  border-bottom: 1px solid transparent;
  padding: 5px 0;
  transition: color 0.2s ease;
}

.site-nav__link:hover { color: var(--rust); }

.site-nav__link.is-active { color: var(--rust); border-bottom-color: var(--rust); }

.site-nav__cta {
  font-family: var(--sans);
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  text-decoration: none;
  color: var(--bg);
  background: var(--ink);
  padding: 13px 24px;
  margin-left: 6px;
  transition: background 0.2s ease;
}

.site-nav__cta:hover { background: var(--rust); }

.nav-toggle {
  display: none;
  flex-direction: column;
  justify-content: center;
  gap: 5px;
  width: 40px;
  height: 40px;
  padding: 8px;
  background: none;
  border: none;
  cursor: pointer;
}

.nav-toggle span {
  display: block;
  width: 24px;
  height: 2px;
  background: var(--ink);
  transition: transform 0.25s ease, opacity 0.2s ease;
}

.nav-toggle.is-open span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.nav-toggle.is-open span:nth-child(2) { opacity: 0; }
.nav-toggle.is-open span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

/* ---------- page header (interior pages) ---------- */

.page-head {
  padding-top: clamp(64px, 10vw, 130px);
  padding-bottom: clamp(48px, 7vw, 80px);
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  gap: 32px;
  flex-wrap: wrap;
}

.page-head__title {
  display: flex;
  flex-direction: column;
  gap: 20px;
  max-width: 760px;
}

/* ---------- CTA bands ---------- */

.cta-band { background: var(--bg-alt); border-top: 1px solid var(--line); }

.cta-band__inner {
  padding-top: clamp(64px, 9vw, 110px);
  padding-bottom: clamp(64px, 9vw, 110px);
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 40px;
  flex-wrap: wrap;
}

.cta-band h2 {
  font-size: clamp(28px, 3.8vw, 46px);
  line-height: 1.18;
  max-width: 680px;
  text-wrap: balance;
}

.band-olive { background: var(--olive); }

.band-olive__inner {
  padding-top: clamp(64px, 9vw, 110px);
  padding-bottom: clamp(64px, 9vw, 110px);
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 40px;
  flex-wrap: wrap;
}

/* ---------- forms ---------- */

input, select, textarea {
  font-family: var(--sans);
  font-size: 14px;
  border-radius: 0;
}

input::placeholder, textarea::placeholder { color: #9C9484; }

.field {
  color: var(--ink);
  background: var(--bg);
  border: 1px solid var(--line-2);
  padding: 14px 16px;
  width: 100%;
}

.field--dark {
  color: var(--cream);
  background: transparent;
  border: 1px solid rgba(240, 234, 218, 0.3);
  padding: 14px 16px;
  width: 100%;
}

.field--dark option { color: var(--ink); background: var(--bg); }

/* ---------- footer ---------- */

.site-footer {
  background: #24221A;
  color: #D8D0BD;
  font-family: var(--sans);
}

.site-footer__inner {
  padding-top: clamp(56px, 8vw, 96px);
  padding-bottom: 40px;
}

.site-footer__top {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  gap: 32px;
  flex-wrap: wrap;
  border-bottom: 1px solid rgba(216, 208, 189, 0.18);
  padding-bottom: clamp(40px, 6vw, 72px);
}

.site-footer__loc {
  font-size: 10px;
  font-weight: 600;
  letter-spacing: 0.34em;
  color: var(--rust-2);
}

.site-footer__motto {
  font-family: var(--serif);
  font-weight: 400;
  font-size: clamp(34px, 5vw, 58px);
  line-height: 1.05;
  color: var(--cream);
}

.site-footer__motto span { color: var(--rust-2); }

.site-footer__desc {
  font-size: 13px;
  color: #9C947F;
  max-width: 420px;
  line-height: 1.7;
}

.site-footer__cta {
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  text-decoration: none;
  color: #24221A;
  background: var(--cream);
  padding: 16px 32px;
  white-space: nowrap;
  transition: background 0.2s ease, color 0.2s ease;
}

.site-footer__cta:hover { background: var(--rust-2); color: var(--cream); }

.site-footer__cols {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: 40px;
  padding-top: clamp(40px, 6vw, 64px);
  padding-bottom: clamp(40px, 6vw, 64px);
}

.site-footer__col { display: flex; flex-direction: column; gap: 14px; }

.site-footer__col-title {
  font-size: 10px;
  font-weight: 600;
  letter-spacing: 0.28em;
  text-transform: uppercase;
  color: var(--muted-2);
}

.site-footer__col a {
  color: #D8D0BD;
  text-decoration: none;
  font-size: 13px;
  transition: color 0.2s ease;
}

.site-footer__col a:hover { color: var(--rust-2); }

.site-footer__col span { color: #D8D0BD; font-size: 13px; line-height: 1.7; }

.site-footer__col span.dim { color: #9C947F; }

.site-footer__bottom {
  display: flex;
  justify-content: space-between;
  gap: 16px;
  flex-wrap: wrap;
  border-top: 1px solid rgba(216, 208, 189, 0.18);
  padding-top: 28px;
}

.site-footer__copy { font-size: 11px; color: var(--muted-2); letter-spacing: 0.04em; }

.site-footer__tag {
  font-family: var(--serif);
  font-style: italic;
  font-size: 14px;
  color: var(--muted-2);
}

/* ============================================================
   ANA SAYFA
   ============================================================ */

.hero {
  position: relative;
  min-height: calc(100vh - 78px);
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  background: repeating-linear-gradient(135deg, #363427 0px, #363427 14px, #3E3C2D 14px, #3E3C2D 28px);
  overflow: hidden;
}

.hero__note {
  position: absolute;
  top: 24px;
  right: 28px;
  display: flex;
  align-items: center;
  gap: 10px;
  z-index: 2;
}

.hero__note-dot { width: 7px; height: 7px; border-radius: 50%; background: var(--rust-2); }

.hero__note-text {
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.08em;
  color: rgba(240, 234, 218, 0.6);
}

.hero__scrim {
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(33, 30, 26, 0.1) 0%, rgba(33, 30, 26, 0.55) 100%);
}

.hero__content {
  position: relative;
  z-index: 2;
  width: 100%;
  padding-top: clamp(48px, 8vw, 110px);
  padding-bottom: clamp(48px, 8vw, 110px);
  display: flex;
  flex-direction: column;
  gap: 28px;
}

.hero__title {
  font-size: clamp(44px, 8.5vw, 124px);
  line-height: 1.0;
  letter-spacing: 0.01em;
  color: #F4EEDE;
  text-wrap: balance;
}

.hero__title span { color: var(--rust-2); font-weight: 300; }

.hero__sub {
  margin: 0;
  font-family: var(--serif);
  font-style: italic;
  font-size: clamp(20px, 2.6vw, 30px);
  color: rgba(240, 234, 218, 0.85);
}

.hero__actions { display: flex; gap: 14px; flex-wrap: wrap; margin-top: 12px; }

/* manifesto */

.manifesto {
  padding-top: clamp(80px, 12vw, 160px);
  padding-bottom: clamp(80px, 12vw, 160px);
}

.manifesto__grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
  gap: clamp(32px, 6vw, 96px);
  align-items: start;
}

.manifesto__left { display: flex; flex-direction: column; gap: 20px; }

.manifesto__right {
  display: flex;
  flex-direction: column;
  gap: 24px;
  padding-top: clamp(0px, 2vw, 44px);
}

.manifesto__right p {
  margin: 0;
  font-size: 15px;
  line-height: 1.85;
  color: var(--muted);
  text-wrap: pretty;
}

.pillars {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: 0;
  margin-top: clamp(64px, 9vw, 120px);
  border-top: 1px solid var(--line);
}

.pillar {
  padding: 36px clamp(0px, 2vw, 32px) 0;
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.pillar:first-child { padding-left: 0; }
.pillar:last-child { padding-right: 0; }

.pillar__no { font-family: var(--serif); font-size: 15px; color: var(--rust); letter-spacing: 0.1em; }

.pillar h3 { font-weight: 500; font-size: 28px; }

.pillar p { margin: 0; font-size: 14px; line-height: 1.75; color: var(--muted); text-wrap: pretty; }

/* section band (deneyimler preview) */

.band-alt { background: var(--bg-alt); border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); }

.band-alt__inner { padding-top: clamp(72px, 10vw, 130px); padding-bottom: clamp(72px, 10vw, 130px); }

.section-head {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  gap: 24px;
  flex-wrap: wrap;
  margin-bottom: clamp(40px, 6vw, 64px);
}

.section-head__title { display: flex; flex-direction: column; gap: 14px; }

.card-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: clamp(20px, 3vw, 36px);
}

.exp-card { text-decoration: none; color: var(--ink); display: flex; flex-direction: column; gap: 16px; }

.exp-card .tile { aspect-ratio: 4 / 5; }

.exp-card__body { display: flex; flex-direction: column; gap: 6px; }

.exp-card h3 { font-weight: 500; font-size: 26px; }

.exp-card p { margin: 0; font-size: 13.5px; line-height: 1.7; color: var(--muted); }

/* upcoming events (home) */

.events-preview { padding-top: clamp(72px, 10vw, 130px); padding-bottom: clamp(72px, 10vw, 130px); }

.events-preview .section-head { margin-bottom: clamp(32px, 5vw, 56px); }

.event-list { display: flex; flex-direction: column; border-top: 1px solid var(--line); }

.event-row {
  text-decoration: none;
  color: var(--ink);
  display: grid;
  grid-template-columns: minmax(90px, 140px) 1fr auto;
  gap: clamp(16px, 3vw, 48px);
  align-items: center;
  padding: 28px 0;
  border-bottom: 1px solid var(--line);
  transition: background 0.2s ease;
}

.event-row:hover { background: var(--bg-alt); }

.event-row__date { display: flex; flex-direction: column; gap: 2px; padding-left: 8px; }

.event-row__day { font-family: var(--serif); font-size: 40px; line-height: 1; color: var(--rust); }

.event-row__month { font-size: 11px; letter-spacing: 0.2em; text-transform: uppercase; color: var(--muted-2); }

.event-row__info { display: flex; flex-direction: column; gap: 4px; }

.event-row__info h3 { font-weight: 500; font-size: 24px; }

.event-row__meta { font-size: 13px; color: var(--muted); }

.event-row__cta {
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--rust);
  padding-right: 8px;
}

/* gallery strip (home) */

.gallery-strip { padding-bottom: clamp(72px, 10vw, 130px); }

.gallery-strip__grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: clamp(14px, 2vw, 24px);
  align-items: end;
}

.gallery-strip__more { display: flex; justify-content: center; margin-top: clamp(32px, 5vw, 48px); }

/* visit band (home) */

.visit-band__text { display: flex; flex-direction: column; gap: 16px; max-width: 640px; }

.visit-band__title {
  font-size: clamp(30px, 4vw, 50px);
  line-height: 1.15;
  color: var(--cream-2);
  text-wrap: balance;
}

.visit-band__title em { font-style: italic; color: var(--cream-2); }

.visit-band__hours { font-size: 13px; color: #C9C4A8; letter-spacing: 0.04em; }

/* ============================================================
   HİKAYEMİZ
   ============================================================ */

.story-head { padding-top: clamp(64px, 10vw, 130px); padding-bottom: clamp(48px, 7vw, 90px); }

.story-head__inner { display: flex; flex-direction: column; gap: 20px; max-width: 880px; }

.story-body { padding-bottom: clamp(80px, 12vw, 150px); }

.story-body__grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
  gap: clamp(32px, 6vw, 96px);
  align-items: start;
}

.story-body__img { aspect-ratio: 4 / 5; position: sticky; top: 110px; }

.story-body__text { display: flex; flex-direction: column; gap: 28px; padding-top: 8px; }

.story-body__lead {
  margin: 0;
  font-family: var(--serif);
  font-size: clamp(22px, 2.6vw, 28px);
  line-height: 1.5;
  color: var(--ink-soft);
  text-wrap: pretty;
}

.story-body__text > p:not(.story-body__lead) {
  margin: 0;
  font-size: 15px;
  line-height: 1.85;
  color: var(--muted);
  text-wrap: pretty;
}

.qa-list { display: flex; flex-direction: column; border-top: 1px solid var(--line); margin-top: 12px; }

.qa-row {
  display: grid;
  grid-template-columns: 110px 1fr;
  gap: 24px;
  padding: 20px 0;
  border-bottom: 1px solid var(--line);
}

.qa-row dt { font-family: var(--serif); font-size: 17px; color: var(--rust); margin: 0; }

.qa-row dd { font-size: 14px; line-height: 1.7; color: var(--muted); margin: 0; }

/* values */

.values__inner {
  padding-top: clamp(64px, 9vw, 110px);
  padding-bottom: clamp(64px, 9vw, 110px);
  display: flex;
  flex-direction: column;
  gap: clamp(36px, 5vw, 56px);
}

.values__pills { display: flex; flex-wrap: wrap; gap: 12px; }

.values__pill {
  font-family: var(--serif);
  font-size: clamp(20px, 2.4vw, 26px);
  color: var(--ink-soft);
  border: 1px solid var(--line-3);
  padding: 12px 26px;
  border-radius: 999px;
}

/* sustainability */

.sustain { background: var(--olive-deep); }

.sustain__inner {
  padding-top: clamp(80px, 11vw, 140px);
  padding-bottom: clamp(80px, 11vw, 140px);
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
  gap: clamp(40px, 6vw, 96px);
  align-items: start;
}

.sustain__intro { display: flex; flex-direction: column; gap: 20px; }

.sustain__title {
  font-size: clamp(34px, 5vw, 62px);
  line-height: 1.08;
  color: var(--cream-2);
  text-wrap: balance;
}

.sustain__title em { font-style: italic; color: #C9A77E; }

.sustain__intro p { margin: 0; font-size: 15px; line-height: 1.85; color: #C9C4A8; text-wrap: pretty; }

.sustain__list { display: flex; flex-direction: column; border-top: 1px solid rgba(242, 237, 221, 0.2); }

.sustain__item {
  display: grid;
  grid-template-columns: 56px 1fr;
  gap: 20px;
  padding: 24px 0;
  border-bottom: 1px solid rgba(242, 237, 221, 0.2);
  align-items: baseline;
}

.sustain__no { font-family: var(--serif); font-size: 20px; color: #C9A77E; }

.sustain__item-body { display: flex; flex-direction: column; gap: 6px; }

.sustain__item h3 { font-weight: 500; font-size: 24px; color: var(--cream-2); }

.sustain__item p { margin: 0; font-size: 13.5px; line-height: 1.7; color: #C9C4A8; }

/* team */

.team { padding-top: clamp(80px, 11vw, 140px); padding-bottom: clamp(80px, 11vw, 140px); }

.team__head { display: flex; flex-direction: column; gap: 14px; margin-bottom: clamp(40px, 6vw, 64px); }

.team__grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: clamp(20px, 3vw, 36px);
}

.team-card { display: flex; flex-direction: column; gap: 16px; }

.team-card .tile { aspect-ratio: 3 / 4; }

.team-card__body { display: flex; flex-direction: column; gap: 4px; }

.team-card h3 { font-weight: 500; font-size: 25px; }

.team-card__role {
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--rust);
}

/* ============================================================
   DENEYİMLER
   ============================================================ */

.exp-grid-wrap { padding-bottom: clamp(80px, 12vw, 150px); }

.exp-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: clamp(20px, 3vw, 36px);
}

.exp-item {
  display: flex;
  flex-direction: column;
  gap: 18px;
  border-top: 1px solid var(--line);
  padding-top: 22px;
}

.exp-item__head { display: flex; justify-content: space-between; align-items: baseline; gap: 12px; }

.exp-item__no { font-family: var(--serif); font-size: 16px; color: var(--rust); letter-spacing: 0.08em; }

.exp-item__tag {
  font-size: 10px;
  font-weight: 600;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--muted-2);
}

.exp-item .tile { aspect-ratio: 4 / 3; }

.exp-item__body { display: flex; flex-direction: column; gap: 8px; }

.exp-item h3 { font-weight: 500; font-size: 28px; }

.exp-item p { margin: 0; font-size: 13.5px; line-height: 1.75; color: var(--muted); text-wrap: pretty; }

/* ============================================================
   ÜRÜNLER
   ============================================================ */

.shop { padding-bottom: clamp(80px, 12vw, 150px); }

.shop__filters {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  border-top: 1px solid var(--line);
  padding-top: 28px;
  margin-bottom: clamp(36px, 5vw, 56px);
  align-items: center;
}

.filter-pill {
  font-family: var(--sans);
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  cursor: pointer;
  border: 1px solid var(--line-3);
  background: transparent;
  color: var(--ink-soft);
  padding: 12px 22px;
  border-radius: 999px;
  transition: border-color 0.2s ease, color 0.2s ease, background 0.2s ease;
}

.filter-pill:hover { border-color: var(--rust); color: var(--rust); }

.filter-pill.is-active { background: var(--ink); color: var(--bg); border-color: var(--ink); }

.filter-pill.is-active:hover { color: var(--bg); }

.shop__count { font-size: 12px; color: var(--muted-2); margin-left: auto; }

.shop__grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(250px, 1fr));
  gap: clamp(20px, 3vw, 36px);
}

.product { display: flex; flex-direction: column; gap: 14px; }

.product .tile { aspect-ratio: 1 / 1.15; position: relative; }

.product__badge {
  position: absolute;
  top: 12px;
  left: 12px;
  font-family: var(--sans);
  font-size: 9.5px;
  font-weight: 600;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--bg);
  background: var(--olive);
  padding: 6px 10px;
}

.product__body { display: flex; flex-direction: column; gap: 4px; }

.product h3 { font-weight: 500; font-size: 23px; }

.product__note { font-size: 12.5px; color: var(--muted-2); }

.shop__notice {
  margin-top: clamp(48px, 7vw, 72px);
  border: 1px solid var(--line);
  background: var(--bg-alt);
  padding: clamp(28px, 4vw, 44px);
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 24px;
  flex-wrap: wrap;
}

.shop__notice p {
  margin: 0;
  font-family: var(--serif);
  font-size: clamp(20px, 2.4vw, 26px);
  line-height: 1.4;
  max-width: 680px;
  text-wrap: pretty;
}

/* ============================================================
   ETKİNLİKLER
   ============================================================ */

.cal-layout {
  padding-bottom: clamp(80px, 12vw, 150px);
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
  gap: clamp(32px, 5vw, 72px);
  align-items: start;
}

.calendar { display: flex; flex-direction: column; gap: 24px; border-top: 1px solid var(--line); padding-top: 28px; }

.calendar__head { display: flex; justify-content: space-between; align-items: baseline; gap: 16px; }

.calendar__head h2 { font-weight: 500; font-size: clamp(28px, 3.4vw, 40px); }

.calendar__count { font-size: 11px; letter-spacing: 0.2em; text-transform: uppercase; color: var(--muted-2); }

.calendar__grid { display: grid; grid-template-columns: repeat(7, 1fr); gap: 6px; }

.calendar__weekday {
  font-size: 10px;
  font-weight: 600;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--muted-2);
  text-align: center;
  padding: 8px 0;
}

.calendar__day {
  aspect-ratio: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 4px;
  background: transparent;
  border: 1px solid #E4DCC8;
  color: var(--muted-2);
  font-size: 13px;
  font-weight: 500;
}

.calendar__day .dot { width: 5px; height: 5px; border-radius: 50%; background: transparent; }

.calendar__day.is-event { background: var(--bg-alt); border-color: var(--line-3); color: var(--ink); }

.calendar__day.is-event .dot { background: var(--rust); }

.calendar__legend { display: flex; align-items: center; gap: 10px; }

.calendar__legend .dot { width: 7px; height: 7px; border-radius: 50%; background: var(--rust); }

.calendar__legend span:last-child { font-size: 12px; color: var(--muted-2); }

/* registration form (dark panel) */

.reg-panel {
  background: #24221A;
  padding: clamp(28px, 4vw, 40px);
  display: flex;
  flex-direction: column;
  gap: 18px;
  margin-top: 12px;
}

.reg-panel__head { display: flex; flex-direction: column; gap: 6px; }

.reg-panel__eyebrow {
  font-size: 10px;
  font-weight: 600;
  letter-spacing: 0.28em;
  text-transform: uppercase;
  color: var(--rust-2);
}

.reg-panel h3 { font-weight: 400; font-size: 28px; color: var(--cream); }

.reg-panel__form { display: flex; flex-direction: column; gap: 12px; }

.people-row { display: flex; align-items: center; gap: 12px; flex-wrap: wrap; }

.people-row__label { font-size: 12px; color: #9C947F; }

.people-row__btns { display: flex; gap: 8px; }

.people-btn {
  font-family: var(--sans);
  font-size: 13px;
  cursor: pointer;
  width: 42px;
  height: 42px;
  border: 1px solid rgba(240, 234, 218, 0.3);
  background: transparent;
  color: var(--cream);
  transition: background 0.15s ease, color 0.15s ease, border-color 0.15s ease;
}

.people-btn.is-active { border-color: var(--cream); background: var(--cream); color: #24221A; }

.reg-panel__submit {
  font-family: var(--sans);
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  cursor: pointer;
  color: #24221A;
  background: var(--cream);
  border: none;
  padding: 16px;
  margin-top: 4px;
  transition: background 0.2s ease, color 0.2s ease;
}

.reg-panel__submit:hover { background: var(--rust-2); color: var(--cream); }

.reg-panel__confirm {
  border: 1px solid rgba(192, 122, 82, 0.5);
  background: rgba(192, 122, 82, 0.12);
  padding: 20px;
  display: none;
  flex-direction: column;
  gap: 6px;
}

.reg-panel__confirm.is-visible { display: flex; }

.reg-panel__confirm-title { font-family: var(--serif); font-size: 22px; color: var(--cream); }

.reg-panel__confirm-text { font-size: 13px; line-height: 1.7; color: #C9C2AC; }

/* event detail list */

.event-detail-list { display: flex; flex-direction: column; border-top: 1px solid var(--line); }

.event-detail { display: flex; flex-direction: column; gap: 16px; padding: 28px 0; border-bottom: 1px solid var(--line); }

.event-detail__top { display: flex; justify-content: space-between; align-items: baseline; gap: 16px; flex-wrap: wrap; }

.event-tag {
  font-size: 10px;
  font-weight: 600;
  letter-spacing: 0.24em;
  text-transform: uppercase;
  color: var(--bg);
  padding: 6px 12px;
}

.event-tag--workshop { background: var(--rust); }
.event-tag--community { background: var(--olive); }
.event-tag--event { background: #8C7355; }

.event-detail__spots { font-size: 12px; letter-spacing: 0.1em; color: var(--muted-2); }

.event-detail__grid {
  display: grid;
  grid-template-columns: minmax(72px, 96px) 1fr;
  gap: clamp(16px, 3vw, 32px);
  align-items: start;
}

.event-detail__date {
  display: flex;
  flex-direction: column;
  gap: 2px;
  border-right: 1px solid var(--line);
  padding-right: 16px;
}

.event-detail__day { font-family: var(--serif); font-size: 44px; line-height: 1; color: var(--rust); }

.event-detail__month { font-size: 10.5px; letter-spacing: 0.2em; text-transform: uppercase; color: var(--muted-2); }

.event-detail__body { display: flex; flex-direction: column; gap: 8px; }

.event-detail h3 { font-weight: 500; font-size: clamp(24px, 2.8vw, 30px); line-height: 1.15; }

.event-detail__meta { font-size: 13px; color: var(--muted); }

.event-detail p { margin: 4px 0 0; font-size: 13.5px; line-height: 1.75; color: var(--muted); text-wrap: pretty; }

.event-note { margin: 24px 0 0; font-size: 12.5px; color: var(--muted-2); font-style: italic; }

/* ============================================================
   COMMUNITY
   ============================================================ */

.photo-strip { padding-bottom: clamp(72px, 10vw, 120px); }

.photo-strip__grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: clamp(12px, 2vw, 20px);
  align-items: start;
}

.testimonials__inner {
  padding-top: clamp(72px, 10vw, 130px);
  padding-bottom: clamp(72px, 10vw, 130px);
  display: flex;
  flex-direction: column;
  gap: clamp(40px, 6vw, 64px);
}

.testimonials__head { display: flex; flex-direction: column; gap: 14px; }

.testimonials__grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: clamp(20px, 3vw, 36px);
  align-items: stretch;
}

.quote-card {
  margin: 0;
  background: var(--bg-card);
  border: 1px solid var(--line);
  padding: clamp(28px, 3.5vw, 40px);
  display: flex;
  flex-direction: column;
  gap: 24px;
  justify-content: space-between;
}

.quote-card blockquote {
  margin: 0;
  font-family: var(--serif);
  font-size: clamp(20px, 2.3vw, 25px);
  line-height: 1.45;
  color: var(--ink-soft);
  text-wrap: pretty;
}

.quote-card figcaption { display: flex; flex-direction: column; gap: 2px; }

.quote-card__name { font-size: 13px; font-weight: 600; color: var(--ink); }

.quote-card__role { font-size: 12px; color: var(--muted-2); }

/* partnerships */

.partners { padding-top: clamp(72px, 10vw, 130px); padding-bottom: clamp(72px, 10vw, 130px); }

.partners__grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
  gap: clamp(32px, 5vw, 80px);
  align-items: start;
}

.partners__intro { display: flex; flex-direction: column; gap: 18px; }

.partners__intro h2 { font-size: clamp(30px, 4vw, 50px); line-height: 1.12; text-wrap: balance; }

.partners__intro p { margin: 0; font-size: 14.5px; line-height: 1.8; color: var(--muted); text-wrap: pretty; }

.partners__logos {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
  gap: 14px;
}

.partners__logos .tile { aspect-ratio: 16 / 9; background: transparent; }

.partners__logos .tile > span { font-size: 10.5px; }

/* join band */

.join-band__text { display: flex; flex-direction: column; gap: 12px; max-width: 640px; }

.join-band__text h2 { font-size: clamp(30px, 4vw, 50px); line-height: 1.15; color: var(--cream-2); text-wrap: balance; }

.join-band__text p { margin: 0; font-size: 14px; line-height: 1.8; color: #C9C4A8; }

.join-band__actions { display: flex; gap: 14px; flex-wrap: wrap; }

/* ============================================================
   GALERİ
   ============================================================ */

.gallery-head {
  padding-top: clamp(64px, 10vw, 130px);
  padding-bottom: clamp(48px, 7vw, 80px);
  display: flex;
  flex-direction: column;
  gap: 20px;
  align-items: center;
  text-align: center;
}

.gallery-head h1 { max-width: 800px; }

.gallery-head p { margin: 0; font-size: 14px; line-height: 1.8; color: var(--muted); max-width: 480px; text-wrap: pretty; }

.gallery-masonry-wrap { padding-bottom: clamp(80px, 12vw, 150px); }

.gallery-masonry { columns: 3 280px; column-gap: clamp(14px, 2vw, 24px); }

.gallery-item {
  margin: 0 0 clamp(14px, 2vw, 24px);
  break-inside: avoid;
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.gallery-item figcaption {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  align-items: baseline;
}

.gallery-item__caption { font-family: var(--serif); font-style: italic; font-size: 16px; color: var(--muted); }

.gallery-item__no { font-size: 10px; letter-spacing: 0.18em; text-transform: uppercase; color: #B0A88F; }

.gallery-note { margin-top: clamp(40px, 6vw, 64px); display: flex; justify-content: center; }

.gallery-note p { margin: 0; font-size: 12.5px; color: var(--muted-2); font-style: italic; text-align: center; }

/* ============================================================
   İLETİŞİM
   ============================================================ */

.contact-layout {
  padding-bottom: clamp(80px, 12vw, 150px);
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
  gap: clamp(32px, 5vw, 72px);
  align-items: start;
}

.contact-info { display: flex; flex-direction: column; gap: 28px; }

.map-tile {
  aspect-ratio: 4 / 3;
  flex-direction: column;
  gap: 12px;
  position: relative;
}

.map-tile__pin {
  width: 14px;
  height: 14px;
  border-radius: 50% 50% 50% 0;
  background: var(--rust);
  transform: rotate(-45deg);
}

.map-tile__badge {
  position: absolute;
  bottom: 14px;
  right: 14px;
  font-family: var(--sans);
  font-size: 10px;
  font-weight: 600;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--bg);
  background: var(--ink);
  padding: 8px 14px;
}

.info-list { display: flex; flex-direction: column; border-top: 1px solid var(--line); }

.info-row {
  display: grid;
  grid-template-columns: minmax(110px, 150px) 1fr;
  gap: 20px;
  padding: 20px 0;
  border-bottom: 1px solid var(--line);
  align-items: baseline;
}

.info-row__label {
  font-size: 10px;
  font-weight: 600;
  letter-spacing: 0.24em;
  text-transform: uppercase;
  color: var(--muted-2);
}

.info-row__value { font-size: 14px; line-height: 1.7; color: var(--ink-soft); }

.info-row__value em { color: var(--muted-2); }

.info-row a {
  font-size: 14px;
  color: var(--ink-soft);
  text-decoration: none;
  border-bottom: 1px solid var(--line-3);
  transition: color 0.2s ease, border-color 0.2s ease;
}

.info-row a:hover { color: var(--rust); border-color: var(--rust); }

/* reservation form */

.res-panel {
  background: var(--bg-card);
  border: 1px solid var(--line);
  padding: clamp(28px, 4vw, 48px);
  display: flex;
  flex-direction: column;
  gap: 22px;
}

.res-panel__head { display: flex; flex-direction: column; gap: 8px; }

.res-panel__eyebrow {
  font-size: 10px;
  font-weight: 600;
  letter-spacing: 0.28em;
  text-transform: uppercase;
  color: var(--rust);
}

.res-panel h2 { font-weight: 400; font-size: clamp(26px, 3vw, 34px); }

.res-panel__head p { margin: 0; font-size: 13px; line-height: 1.7; color: var(--muted-2); }

.res-panel__form { display: flex; flex-direction: column; gap: 14px; }

.res-panel__row {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 14px;
}

.res-panel__form textarea { resize: vertical; }

.res-panel__submit {
  font-family: var(--sans);
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  cursor: pointer;
  color: var(--bg);
  background: var(--ink);
  border: none;
  padding: 17px;
  transition: background 0.2s ease;
}

.res-panel__submit:hover { background: var(--rust); }

.res-panel__hint { font-size: 11.5px; color: #9C9484; text-align: center; }

.res-panel__confirm {
  border: 1px solid var(--line-3);
  background: var(--bg-alt);
  padding: 24px;
  display: none;
  flex-direction: column;
  gap: 8px;
}

.res-panel__confirm.is-visible { display: flex; }

.res-panel__confirm-title { font-family: var(--serif); font-size: 24px; color: var(--ink); }

.res-panel__confirm-text { font-size: 13px; line-height: 1.7; color: var(--muted); }

/* ---------- mobile nav ---------- */

@media (max-width: 920px) {
  .nav-toggle { display: flex; }

  .site-header__inner { min-height: 64px; }

  .site-nav {
    display: none;
    width: 100%;
    flex-direction: column;
    align-items: flex-start;
    gap: 2px;
    padding: 4px 0 22px;
    border-top: 1px solid var(--line);
  }

  .site-nav.is-open { display: flex; }

  .site-nav__link {
    font-size: 13px;
    letter-spacing: 0.14em;
    padding: 12px 0;
    width: 100%;
    border-bottom: 1px solid transparent;
  }

  .site-nav__link.is-active { border-bottom-color: transparent; }

  .site-nav__cta {
    margin-left: 0;
    margin-top: 12px;
    width: 100%;
    text-align: center;
    padding: 15px 24px;
  }
}

/* ---------- small screens ---------- */

@media (max-width: 640px) {
  .hero__note-text { display: none; }
  .hero { min-height: calc(100svh - 64px); }
  .hero__actions .btn { flex: 1 1 auto; text-align: center; }
  .pillar { padding-left: 0; padding-right: 0; }
  .section-head { align-items: flex-start; flex-direction: column; }
  .page-head { align-items: flex-start; flex-direction: column; }
  .lede { max-width: none; }
  .cta-band__inner, .band-olive__inner { align-items: flex-start; flex-direction: column; }
  .shop__count { margin-left: 0; width: 100%; }
  .shop__notice { flex-direction: column; align-items: flex-start; }
  .calendar__day { font-size: 11.5px; }
  .story-body__img { position: static; }
  .info-row { grid-template-columns: 96px 1fr; }
  .event-detail__grid { grid-template-columns: minmax(60px, 76px) 1fr; }
  .event-detail__day { font-size: 36px; }
}

@media (max-width: 560px) {
  .event-row { grid-template-columns: minmax(72px, 90px) 1fr; }
  .event-row__cta { display: none; }
  .qa-row { grid-template-columns: 90px 1fr; }
}
