/* Sofra Atlası · Journal V2
   Koyu şarap gecesi + rafine porselen açık tema.
   Kullanıcı tarafından seçilen mekân arşivi estetiğine göre tasarlanmıştır. */

:root {
  --bg: #ffffff;
  --surface: #ffffff;
  --surface-2: #f7f5f3;
  --surface-3: #efebe7;
  --text: #1c181a;
  --muted: #6f686c;
  --faint: #a79fa3;
  --line: #e7e1dd;
  --line-strong: #c9beb8;
  --accent: #b87318;
  --accent-strong: #89500d;
  --secondary: #7a3043;
  --sky: #2f7470;
  --header-bg: rgba(255,255,255,.94);
  --shadow: 0 16px 46px rgba(35,26,30,.07);
  --shadow-hover: 0 24px 64px rgba(35,26,30,.12);
  --display: 'DM Serif Display', Georgia, serif;
  --body: 'DM Sans', system-ui, sans-serif;
  --mono: 'Space Mono', ui-monospace, monospace;
  --container: 1420px;
  --header-h: 72px;
  --radius-sm: 3px;
  --radius-md: 8px;
  --radius-lg: 14px;
  --radius-xl: 20px;
  --ease: cubic-bezier(.2,.75,.24,1);
  color-scheme: light;
}

:root[data-theme='dark'] {
  --bg: #0d080a;
  --surface: #151014;
  --surface-2: #1d161b;
  --surface-3: #281d24;
  --text: #f2eadb;
  --muted: #a38e98;
  --faint: #604852;
  --line: #34262e;
  --line-strong: #5b414e;
  --accent: #d7a03c;
  --accent-strong: #efbb59;
  --secondary: #b95268;
  --sky: #4aa39d;
  --header-bg: rgba(13,8,10,.92);
  --shadow: 0 18px 54px rgba(0,0,0,.28);
  --shadow-hover: 0 24px 72px rgba(0,0,0,.42);
  color-scheme: dark;
}

html { background: var(--bg); }
body {
  background: var(--bg);
  color: var(--text);
  font-family: var(--body);
  letter-spacing: -.01em;
}
body::before {
  background:
    radial-gradient(circle at 10% 0%, color-mix(in srgb,var(--secondary) 3.5%,transparent), transparent 30rem),
    radial-gradient(circle at 94% 6%, color-mix(in srgb,var(--accent) 3.5%,transparent), transparent 28rem);
  opacity: 1;
}
::selection { background: var(--accent); color: #120d0f; }
.section-shell { width: min(calc(100% - 56px), var(--container)); }
.section-block { padding-block: clamp(68px,8vw,124px); }
.eyebrow,.hero-kicker,.mini-label,.mono-label {
  color: var(--accent);
  font-family: var(--mono);
  font-size: .61rem;
  font-weight: 700;
  letter-spacing: .18em;
  text-transform: uppercase;
}
.reveal { transform: translateY(10px); transition: opacity .45s ease,transform .45s var(--ease); }
.reveal.is-visible { transform: none; }

/* Header */
.site-header {
  height: var(--header-h);
  grid-template-columns: 1fr auto 1fr;
  padding: 0 clamp(20px,3.1vw,48px);
  border-bottom-color: var(--line);
  background: var(--header-bg);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
}
.site-header.is-scrolled { box-shadow: 0 8px 28px rgba(0,0,0,.08); }
.brand { gap: 10px; }
.brand-mark {
  width: 34px;height:34px;border-radius:50%;
  border: 1px solid var(--line-strong);
  background: transparent;
}
.brand-mark::before {
  width: 12px;height:12px;border: 1px solid var(--accent);border-radius:50%;
}
.brand-mark::after { content:''; position:absolute; width:1px;height:22px;background:var(--accent);transform:rotate(35deg); }
.brand-mark i { display:none; }
.brand strong { font-family: var(--display); font-size: 1.08rem; font-weight: 400; letter-spacing: .01em; }
.brand small { margin-top: 1px; font-family: var(--mono); font-size: .47rem; letter-spacing: .22em; }
.desktop-nav {
  gap: 28px;padding:0;border:0;border-radius:0;background:transparent;
}
.desktop-nav a {
  position:relative;padding:25px 0 23px;border-radius:0;
  color:var(--muted);font-size:.68rem;font-weight:500;letter-spacing:.1em;text-transform:uppercase;
}
.desktop-nav a::after { content:'';position:absolute;left:0;right:100%;bottom:-1px;height:2px;background:var(--accent);transition:right .23s ease; }
.desktop-nav a:hover,.desktop-nav a.is-active { color:var(--text);background:transparent; }
.desktop-nav a.is-active { color:var(--accent); }
.desktop-nav a.is-active::after,.desktop-nav a:hover::after { right:0; }
.header-actions { gap:7px; }
.icon-button {
  height:36px;min-width:36px;padding:0 10px;border-radius:50%;
  background:var(--surface-2);border-color:var(--line);box-shadow:none;
}
.icon-button:hover { transform:none;border-color:var(--accent);color:var(--accent);background:var(--surface); }
.icon-button span { font-family:var(--mono);font-size:.58rem;letter-spacing:.08em;text-transform:uppercase; }
.search-button { border-radius:2px;min-width:auto;padding-inline:13px; }

/* Hero */
.hero {
  min-height: calc(100svh - var(--header-h));
  grid-template-columns: minmax(0,1.12fr) minmax(390px,.72fr);
  gap: clamp(52px,7vw,116px);
  padding-block: clamp(82px,10vh,128px) 90px;
}
.hero-copy { align-self:center; }
.hero-kicker { gap:12px; }
.hero-kicker i { width:44px;height:1px;background:var(--accent); }
.hero h1 {
  max-width: 920px;
  margin: 28px 0 30px;
  font-family: var(--display);
  font-size: clamp(4.6rem,8.5vw,9.4rem);
  font-weight: 400;
  line-height: .84;
  letter-spacing: -.055em;
  text-transform: none;
}
.hero h1 .accent-line { color:var(--accent);font-style:italic;font-weight:400; }
.hero-copy > p { max-width:650px;color:var(--muted);font-size:1.03rem;line-height:1.75; }
.button {
  min-height:46px;padding:0 18px;border-radius:2px;
  font-family:var(--mono);font-size:.62rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;
}
.button--primary { background:var(--accent);color:#160d09;border-color:var(--accent);box-shadow:none; }
:root:not([data-theme='dark']) .button--primary { color:#fff; }
.button--ghost { background:transparent; }
.button:hover { transform:translateY(-2px); }
.hero-stats { gap:0;margin-top:46px;border-top:1px solid var(--line);border-bottom:1px solid var(--line); }
.hero-stats div { min-width:0;flex:1;gap:7px;padding:14px 16px;border:0;border-right:1px solid var(--line);border-radius:0;background:transparent; }
.hero-stats div:last-child { border-right:0; }
.hero-stats strong { font-family:var(--display);font-size:1.8rem;font-weight:400; }
.hero-stats span { font-family:var(--mono);font-size:.55rem;letter-spacing:.1em;text-transform:uppercase; }
.hero-board { min-height:600px; }
.board-card { border-radius:3px;border-color:var(--line-strong);box-shadow:var(--shadow); }
.board-card--main { inset:5% 3% 5% 6%;transform:none; }
.board-card--main::after { background:linear-gradient(180deg,transparent 35%,rgba(8,5,6,.82)); }
.board-card--main > div { left:26px;bottom:24px; }
.board-card--main span { font-family:var(--mono);letter-spacing:.16em; }
.board-card--main strong { font-family:var(--display);font-weight:400;font-size:clamp(2.8rem,4vw,4.8rem);text-transform:none; }
.board-card--small { width:148px;height:148px;padding:18px;border-radius:2px; }
.board-card--small span { font-family:var(--display);font-weight:400;font-size:2.3rem;line-height:.9;letter-spacing:-.03em; }
.board-card--small small { font-family:var(--mono);font-size:.53rem;letter-spacing:.12em; }
.board-card--lime { top:0;right:0;background:var(--sky);color:#071313;transform:rotate(2deg); }
.board-card--orange { left:0;bottom:0;background:var(--secondary);color:#fff;transform:rotate(-2deg); }
.board-card--orange span { font-size:4rem; }
.board-orbit { display:none; }
.scroll-cue { font-family:var(--mono);font-size:.54rem;letter-spacing:.12em;text-transform:uppercase; }
.pulse-strip { border-block:1px solid var(--line);background:var(--surface);color:var(--muted);transform:none; }
.pulse-strip div { padding:12px 0;font-family:var(--mono);font-size:.63rem;letter-spacing:.18em; }
.pulse-strip span::after { content:'◆';margin-left:2rem;color:var(--accent);font-size:.55rem; }

/* Section headings */
.section-head { align-items:end;padding-bottom:22px;border-bottom:1px solid var(--line);margin-bottom:28px; }
.section-head h2,.tip-wall-head h2,.manage-banner h2 {
  margin:12px 0 0;font-family:var(--display);font-size:clamp(2.6rem,5vw,5.8rem);font-weight:400;line-height:.94;letter-spacing:-.04em;text-transform:none;
}
.section-head p { max-width:680px;color:var(--muted);line-height:1.65; }
.text-link { font-family:var(--mono);font-size:.61rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase; }
.text-link::before { content:'';width:34px;height:1px;background:var(--line-strong); }

/* Cities */
.city-grid { gap:14px; }
.city-card > a { min-height:460px;border-radius:3px;border:1px solid var(--line);box-shadow:none; }
.city-card--large > a { min-height:650px; }
.city-card-overlay { background:linear-gradient(180deg,rgba(6,3,4,.05),rgba(6,3,4,.82)); }
.city-card-top { font-family:var(--mono);font-size:.58rem;letter-spacing:.12em;text-transform:uppercase; }
.city-card-copy { padding:28px; }
.city-card-copy > span { font-family:var(--mono);font-size:.56rem;letter-spacing:.14em; }
.city-card h3,.city-card:not(.city-card--large) h3 { font-family:var(--display);font-weight:400;text-transform:none;letter-spacing:-.04em;line-height:.92;font-size:clamp(3rem,5.5vw,6.5rem); }
.city-card:not(.city-card--large) h3 { font-size:clamp(2.4rem,3.5vw,4rem); }
.city-card p { font-size:.92rem; }
.city-card-foot { font-family:var(--mono);font-size:.58rem;letter-spacing:.1em; }
.city-card-foot i { width:34px;height:34px;border-radius:50%; }
.city-grid--archive .city-card:nth-child(4n+2),.city-grid--archive .city-card:nth-child(4n+3) { grid-column:span 6; }

/* Place journal list */
.place-list { display:block;border-top:1px solid var(--line); }
.journal-list-head { display:flex;justify-content:space-between;align-items:center;padding:13px 0 10px;border-bottom:1px solid var(--line);color:var(--faint);font-family:var(--mono);font-size:.55rem;letter-spacing:.16em;text-transform:uppercase; }
.place-entry { display:block;border-bottom:1px solid var(--line);background:transparent;transition:background .2s,border-color .2s; }
.place-entry[hidden] { display:none; }
.place-entry:hover { background:color-mix(in srgb,var(--entry-accent) 4%,transparent); }
.place-entry[open] { background:var(--surface); }
.place-entry summary { list-style:none; }
.place-entry summary::-webkit-details-marker { display:none; }
.place-entry-row { display:flex;align-items:center;gap:14px;min-height:70px;padding:13px 2px;cursor:pointer; }
.place-entry-row:focus-visible { outline:2px solid var(--entry-accent);outline-offset:-2px; }
.place-entry-index { width:38px;flex:0 0 38px;color:var(--entry-accent);font-family:var(--mono);font-size:.61rem;font-weight:700;letter-spacing:.08em; }
.place-entry-name { flex:0 0 auto;font-family:var(--display);font-size:clamp(1.12rem,1.65vw,1.55rem);font-weight:400;line-height:1.08;color:var(--text); }
.place-entry[open] .place-entry-name { color:var(--entry-accent); }
.place-entry-dots { flex:1;min-width:26px;height:1px;background-image:radial-gradient(circle,var(--faint) 1px,transparent 1.2px);background-size:7px 1px;background-repeat:repeat-x;opacity:.52; }
.place-entry-category { color:var(--entry-accent);font-family:var(--mono);font-size:.56rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;white-space:nowrap; }
.place-entry-location { width:190px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--muted);font-size:.72rem;text-align:right; }
.place-entry-chevron { display:grid;place-items:center;color:var(--muted);transition:transform .25s,color .2s; }
.place-entry-chevron svg { width:16px;height:16px;transform:rotate(90deg); }
.place-entry[open] .place-entry-chevron { transform:rotate(180deg);color:var(--entry-accent); }
.place-entry-expand { display:grid;grid-template-columns:minmax(0,1fr) minmax(290px,.42fr);gap:42px;padding:0 2px 26px 52px;border-top:1px solid var(--line); }
.place-entry-copy { padding-top:22px; }
.place-entry-copy blockquote { margin:0;max-width:760px;padding-left:18px;border-left:2px solid var(--entry-accent);color:var(--muted);font-family:var(--display);font-size:clamp(1.05rem,1.5vw,1.28rem);font-style:italic;line-height:1.62; }
.place-entry-tries { margin-top:22px; }
.mono-label { display:block;margin-bottom:9px;color:var(--faint); }
.chip-row { gap:6px; }
.chip-row span { padding:7px 10px;border:1px solid var(--line);border-radius:2px;background:transparent;color:var(--muted);font-size:.67rem; }
.place-entry-meta { padding:22px 0 0;border-left:1px solid var(--line);padding-left:26px; }
.place-entry-meta dl { display:grid;grid-template-columns:1fr 1fr;gap:14px 22px;margin:0 0 20px; }
.place-entry-meta dl div { display:grid;gap:3px; }
.place-entry-meta dt { color:var(--faint);font-family:var(--mono);font-size:.51rem;letter-spacing:.12em;text-transform:uppercase; }
.place-entry-meta dd { margin:0;color:var(--text);font-size:.75rem; }
.map-link { justify-content:flex-start;width:fit-content;padding:10px 13px;border-radius:2px;background:var(--entry-accent,var(--accent));color:#130d0f;font-family:var(--mono);font-size:.58rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase; }
.map-link:hover { filter:brightness(1.08); }
:root:not([data-theme='dark']) .map-link { color:#fff; }
.place-entry--compact .place-entry-row { min-height:66px; }

/* Content cards */
.content-lab { border-top:1px solid var(--line); }
.content-lab-grid { gap:14px; }
.stories-stack,.recipes-stack { gap:14px; }
.story-card > a,.recipe-card > a { border-radius:3px;border-color:var(--line);box-shadow:none; }
.story-card > a:hover,.recipe-card > a:hover { transform:translateY(-3px);box-shadow:var(--shadow); }
.story-card > a { grid-template-columns:220px 1fr;min-height:240px; }
.story-card--feature > a { min-height:520px; }
.story-copy { padding:24px; }
.story-meta,.story-foot,.recipe-meta { font-family:var(--mono);font-size:.54rem;letter-spacing:.08em;text-transform:uppercase; }
.story-card h3,.recipe-card h3 { font-family:var(--display);font-weight:400;letter-spacing:-.035em;text-transform:none;line-height:1.02; }
.story-card p,.recipe-card p { font-size:.87rem; }
.recipe-card > a { grid-template-columns:150px 1fr;min-height:196px; }
.recipe-number { border-radius:1px;background:var(--accent);color:#160e0b;font-family:var(--mono);font-size:.59rem; }
:root:not([data-theme='dark']) .recipe-number { color:#fff; }

/* Tips and editor banner */
.tip-grid { gap:10px; }
.tip-card { min-height:240px;border-radius:3px;border:1px solid var(--line);background:var(--surface);color:var(--text); }
.tip-card:nth-child(2) { background:var(--surface-2);color:var(--text); }
.tip-card:nth-child(3) { background:color-mix(in srgb,var(--sky) 13%,var(--surface));color:var(--text); }
.tip-card > span { color:var(--accent);font-family:var(--mono);font-size:.62rem; }
.tip-card small { font-family:var(--mono);font-size:.53rem;letter-spacing:.12em; }
.tip-card h3 { font-family:var(--display);font-size:1.7rem;font-weight:400;letter-spacing:-.025em;text-transform:none; }
.tip-card p { color:var(--muted);font-size:.87rem; }
.manage-banner { border:1px solid var(--line);border-radius:3px;background:var(--secondary); }
.manage-banner .eyebrow { color:rgba(255,255,255,.72); }
.manage-banner h2 { color:#fff; }
.manage-banner p { color:rgba(255,255,255,.74); }

/* Page headers and filters */
.page-hero { padding-block:clamp(74px,9vw,138px) clamp(44px,6vw,74px);border-bottom:1px solid var(--line); }
.page-hero h1,.not-found h1 { max-width:1100px;margin:18px 0 24px;font-family:var(--display);font-size:clamp(3.8rem,8vw,8.6rem);font-weight:400;line-height:.9;letter-spacing:-.05em;text-transform:none; }
.page-hero h1 span,.not-found h1 span,.page-hero h1 em { color:var(--accent);font-style:italic;font-weight:400; }
.page-hero p { max-width:760px;color:var(--muted);font-size:1rem;line-height:1.7; }
.page-hero--journal { padding-bottom:42px; }
.page-ledger { display:flex;flex-wrap:wrap;gap:0;margin:26px 0 18px;border-block:1px solid var(--line); }
.page-ledger span { padding:12px 22px 12px 0;margin-right:22px;border-right:1px solid var(--line);color:var(--muted);font-family:var(--mono);font-size:.58rem;letter-spacing:.08em;text-transform:uppercase; }
.page-ledger span:last-child { border-right:0; }
.page-ledger strong { color:var(--text); }
.filter-zone { padding-bottom:110px; }
.filter-bar { grid-template-columns:1fr 240px;gap:8px;margin:24px 0 0; }
.filter-search,.filter-bar select { min-height:48px;border-radius:2px;background:var(--surface); }
.filter-search input { font-size:.82rem; }
.filter-bar select { font-family:var(--mono);font-size:.62rem;letter-spacing:.04em; }
.filter-chips { flex-wrap:nowrap;overflow:auto;margin:0;padding:0;border-bottom:1px solid var(--line);scrollbar-width:none; }
.filter-chips::-webkit-scrollbar { display:none; }
.filter-chips button,.search-filters button { flex:0 0 auto;padding:14px 14px 12px;border:0;border-radius:0;background:transparent;color:var(--muted);font-family:var(--mono);font-size:.56rem;letter-spacing:.08em;text-transform:uppercase; }
.filter-chips button.is-active,.search-filters button.is-active { border-bottom:2px solid var(--accent);background:transparent;color:var(--accent); }
.empty-state { border-radius:2px; }

/* Detail pages */
.city-detail-hero { grid-template-columns:1fr minmax(380px,.74fr);min-height:auto;padding-block:clamp(72px,9vw,130px); }
.city-detail-copy h1 { font-family:var(--display);font-weight:400;font-size:clamp(4.6rem,9vw,10rem);letter-spacing:-.055em;text-transform:none; }
.city-detail-copy p { font-size:1rem; }
.city-detail-stats span { border-radius:2px;font-family:var(--mono);font-size:.56rem;letter-spacing:.06em;text-transform:uppercase; }
.city-detail-media { height:580px;border-radius:3px;border:1px solid var(--line);box-shadow:var(--shadow); }
.city-detail-media figcaption,.article-head figure figcaption { border-radius:2px;font-family:var(--mono);font-size:.54rem;letter-spacing:.09em; }
.article-page,.recipe-detail { padding-top:clamp(70px,9vw,126px); }
.article-head,.recipe-detail-head { gap:clamp(34px,6vw,80px); }
.article-head h1,.recipe-detail-head h1 { font-family:var(--display);font-weight:400;text-transform:none;letter-spacing:-.045em; }
.article-head figure,.recipe-detail-head figure { border-radius:3px;border:1px solid var(--line); }
.article-body section > span,.ingredient-panel li > span,.steps-panel li > span { font-family:var(--mono);color:var(--accent); }
.article-grid aside,.ingredient-panel,.steps-panel,.tips-panel { border-radius:3px;border-color:var(--line); }
.recipe-detail-meta span { border-radius:2px;font-family:var(--mono);font-size:.57rem; }
.recipe-origin,.recipe-detail-origin { color:var(--muted);font-family:var(--mono);font-size:.56rem;letter-spacing:.07em;text-transform:uppercase; }
.recipe-origin { margin-top:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis; }
.recipe-detail-origin { margin-top:16px;color:var(--accent); }
.recipe-tags { margin-top:20px; }
.recipe-detail-head figure figcaption { position:absolute;left:14px;bottom:14px;padding:9px 11px;border:1px solid rgba(255,255,255,.24);border-radius:2px;background:rgba(20,14,16,.78);backdrop-filter:blur(10px);font-family:var(--mono);font-size:.52rem;letter-spacing:.08em;text-transform:uppercase; }
.recipe-detail-head figure figcaption a { color:#fff; }

.recipe-archive { padding-top:34px; }
.recipe-toolbar { display:grid;grid-template-columns:minmax(280px,1fr) 220px 260px;gap:8px;margin-bottom:18px; }
.recipe-search,.recipe-select { min-height:54px;border:1px solid var(--line);border-radius:2px;background:var(--surface); }
.recipe-search { display:flex;align-items:center;gap:12px;padding:0 15px; }
.recipe-search svg { flex:0 0 auto;color:var(--accent); }
.recipe-search span,.recipe-select { display:flex;flex-direction:column;justify-content:center; }
.recipe-search span { flex:1; }
.recipe-search small,.recipe-select small { color:var(--muted);font-family:var(--mono);font-size:.48rem;letter-spacing:.12em;text-transform:uppercase; }
.recipe-search input,.recipe-select select { width:100%;border:0;outline:0;background:transparent;color:var(--text);font:inherit; }
.recipe-search input { margin-top:2px;font-size:.82rem; }
.recipe-select { padding:7px 13px; }
.recipe-select select { margin-top:2px;font-family:var(--mono);font-size:.6rem; }
.recipe-archive-head { display:flex;justify-content:space-between;gap:18px;padding:13px 0;margin-bottom:18px;border-block:1px solid var(--line);color:var(--muted);font-family:var(--mono);font-size:.54rem;letter-spacing:.1em;text-transform:uppercase; }

.recipe-support-grid { display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:18px;margin-top:18px; }
.recipe-support-card { min-height:220px;padding:clamp(24px,3vw,38px);border:1px solid var(--line);border-radius:3px;background:var(--surface); }
.recipe-support-card ul { display:grid;gap:12px;margin:24px 0 0;padding:0;list-style:none; }
.recipe-support-card li { position:relative;padding-left:18px;color:var(--muted);line-height:1.65; }
.recipe-support-card li::before { content:'•';position:absolute;left:0;color:var(--accent); }
.recipe-support-card > p { margin:24px 0 0;color:var(--muted);line-height:1.7; }

/* Search, footer, mobile */
.search-drawer { background:var(--bg); }
.search-panel { border-left:1px solid var(--line);background:var(--surface); }
.search-panel-head h2 { font-family:var(--display);font-weight:400; }
.global-search { border-radius:2px;background:var(--surface-2); }
.search-result { border-radius:2px; }
.search-result strong { font-family:var(--display);font-weight:400;font-size:1.05rem; }
.site-footer { border-top:1px solid var(--line); }
.footer-brand strong { font-family:var(--display);font-size:1.25rem;font-weight:400; }
.footer-links,.footer-meta { font-family:var(--mono);font-size:.55rem;letter-spacing:.07em;text-transform:uppercase; }
.back-to-top { border-radius:50%;background:var(--accent);color:#160e0b; }
.mobile-dock { background:var(--header-bg);border-color:var(--line); }
.mobile-dock a { color:var(--muted);font-family:var(--mono);font-size:.46rem;letter-spacing:.04em;text-transform:uppercase; }
.mobile-dock a.is-active { color:var(--accent); }

@media (max-width: 1050px) {
  .hero { grid-template-columns:1fr; }
  .hero-board { min-height:500px;max-width:720px;width:100%; }
  .place-entry-location { width:150px; }
  .place-entry-expand { grid-template-columns:1fr 280px; }
}

@media (max-width: 820px) {
  .section-shell { width:min(calc(100% - 30px),var(--container)); }
  .site-header { grid-template-columns:1fr auto;height:66px; }
  .desktop-nav,.search-button span { display:none; }
  .mobile-menu-button { display:inline-flex; }
  .hero { padding-top:58px; }
  .hero h1 { font-size:clamp(4rem,15vw,7rem); }
  .hero-board { min-height:430px; }
  .board-card--small { width:120px;height:120px; }
  .board-card--small span { font-size:1.8rem; }
  .board-card--orange span { font-size:3rem; }
  .section-head { display:grid;gap:18px; }
  .city-grid,.content-lab-grid,.tip-grid { grid-template-columns:1fr; }
  .city-card,.city-card--large,.city-grid--archive .city-card:nth-child(n) { grid-column:auto; }
  .city-card > a,.city-card--large > a { min-height:500px; }
  .place-entry-row { gap:10px; }
  .place-entry-category { display:none; }
  .place-entry-location { width:130px; }
  .place-entry-expand { grid-template-columns:1fr;gap:12px;padding-left:48px; }
  .place-entry-meta { border-left:0;border-top:1px solid var(--line);padding:18px 0 0; }
  .story-card > a,.recipe-card > a { grid-template-columns:150px 1fr; }
  .story-card--feature > a { grid-template-columns:1fr; }
  .filter-bar { grid-template-columns:1fr; }
  .city-detail-hero,.article-head,.recipe-detail-head,.article-grid,.recipe-columns { grid-template-columns:1fr; }
  .city-detail-media { height:460px; }
  .manage-banner { grid-template-columns:1fr;align-items:start; }
}

@media (max-width: 580px) {
  :root { --header-h:64px; }
  body { padding-bottom:72px; }
  .section-shell { width:min(calc(100% - 24px),var(--container)); }
  .site-header { padding-inline:14px; }
  .brand small { display:none; }
  .icon-button { height:36px;min-width:36px;padding:0; }
  .search-button { border-radius:50%; }
  .hero { min-height:auto;padding-block:54px 72px; }
  .hero h1 { font-size:clamp(3.55rem,17vw,5.6rem); }
  .hero-copy > p { font-size:.94rem; }
  .hero-actions { display:grid;grid-template-columns:1fr; }
  .hero-stats { display:grid;grid-template-columns:repeat(3,1fr); }
  .hero-stats div { display:grid;padding:11px 8px;text-align:center; }
  .hero-stats strong { font-size:1.45rem; }
  .hero-board { min-height:350px; }
  .board-card--main { inset:3% 5% 3% 3%; }
  .board-card--small { width:96px;height:96px;padding:11px; }
  .board-card--small span { font-size:1.35rem; }
  .board-card--small small { font-size:.42rem; }
  .board-card--orange span { font-size:2.35rem; }
  .scroll-cue { display:none; }
  .section-block { padding-block:64px; }
  .section-head h2,.tip-wall-head h2,.manage-banner h2 { font-size:clamp(2.45rem,13vw,4rem); }
  .city-card > a,.city-card--large > a { min-height:430px; }
  .city-card-copy { padding:22px; }
  .city-card h3,.city-card:not(.city-card--large) h3 { font-size:clamp(2.7rem,14vw,4rem); }
  .page-hero { padding-block:58px 34px; }
  .page-hero h1,.not-found h1 { font-size:clamp(3.2rem,16vw,5.2rem); }
  .page-ledger span { padding:10px 12px 10px 0;margin-right:12px; }
  .filter-zone { padding-bottom:84px; }
  .place-entry-row { min-height:64px;padding:12px 0; }
  .place-entry-index { width:27px;flex-basis:27px; }
  .place-entry-name { max-width:52vw;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:1.1rem; }
  .place-entry-dots { min-width:10px; }
  .place-entry-location { display:none; }
  .place-entry-expand { padding:0 0 22px 37px; }
  .place-entry-copy blockquote { font-size:1rem; }
  .place-entry-meta dl { grid-template-columns:1fr 1fr; }
  .map-link { width:100%;justify-content:center; }
  .story-card > a,.recipe-card > a { grid-template-columns:1fr; }
  .story-media,.recipe-media { height:220px; }
  .story-card--feature > a { min-height:480px; }
  .story-card--feature .story-media { height:auto; }
  .tip-card { min-height:0; }
  .city-detail-copy h1 { font-size:clamp(4rem,20vw,6.5rem); }
  .city-detail-media { height:390px; }
  .site-footer { margin-bottom:0; }
}

@media (prefers-reduced-motion: reduce) {
  *,*::before,*::after { scroll-behavior:auto!important;animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important; }
}

/* Ankara büyük arşiv optimizasyonları */
.place-entry-tags{margin-top:18px}
.filter-bar{grid-template-columns:minmax(280px,1fr) minmax(170px,220px) minmax(170px,220px)}
.place-list--archive .place-entry{content-visibility:auto;contain-intrinsic-size:72px 320px}


/* White V4 refinement — clean gallery background */
:root:not([data-theme='dark']) body { background:#fff; }
:root:not([data-theme='dark']) .site-header { box-shadow:0 1px 0 rgba(28,24,26,.035); }
:root:not([data-theme='dark']) .desktop-nav a.is-active { color:var(--accent-strong); }
:root:not([data-theme='dark']) .icon-button,
:root:not([data-theme='dark']) .filter-control,
:root:not([data-theme='dark']) .filter-chips button,
:root:not([data-theme='dark']) .search-filters button { background:#fff; }
:root:not([data-theme='dark']) .place-entry:hover { background:#fcfbfa; }
:root:not([data-theme='dark']) .place-entry[open] { background:#faf8f6; }
:root:not([data-theme='dark']) .place-entry-expand { background:linear-gradient(180deg,#faf8f6,#fff); }
:root:not([data-theme='dark']) .chip-row span { background:#fff; }
:root:not([data-theme='dark']) .story-card > a,
:root:not([data-theme='dark']) .recipe-card > a,
:root:not([data-theme='dark']) .content-card,
:root:not([data-theme='dark']) .search-panel,
:root:not([data-theme='dark']) .mobile-menu { background:#fff; }
:root:not([data-theme='dark']) .pulse-strip { background:#fbfaf8; }
:root:not([data-theme='dark']) .site-footer { border-color:var(--line); }
:root:not([data-theme='dark']) .map-link { color:#fff; box-shadow:0 8px 24px color-mix(in srgb,var(--entry-accent,var(--accent)) 18%,transparent); }
:root:not([data-theme='dark']) .board-card { box-shadow:0 18px 54px rgba(42,30,35,.09); }
:root:not([data-theme='dark']) .board-card--orange { color:#fff; }
:root:not([data-theme='dark']) .board-card--lime { color:#fff; }
:root:not([data-theme='dark']) .page-progress span { background:linear-gradient(90deg,var(--accent),var(--secondary),var(--sky)); }

/* ── V5 · Google puanı ve popülerlik sistemi ── */
.place-entry-google{display:flex;align-items:center;gap:8px;flex:0 0 auto;min-width:122px;padding:6px 9px;border:1px solid var(--line);border-radius:999px;background:var(--surface);white-space:nowrap}
.place-entry-google strong{display:inline-flex;align-items:center;gap:4px;color:var(--accent);font-family:var(--mono);font-size:.63rem;line-height:1}
.place-entry-google strong .icon,.google-score .icon{width:12px;height:12px;fill:currentColor;stroke-width:1.4}
.place-entry-google small{color:var(--muted);font-family:var(--mono);font-size:.5rem;letter-spacing:.02em}
.place-entry-popular{flex:0 0 auto;padding:5px 7px;border-radius:999px;background:color-mix(in srgb,var(--entry-accent) 12%,var(--surface));color:var(--entry-accent);font-family:var(--mono);font-size:.47rem;font-weight:700;letter-spacing:.08em;white-space:nowrap}
.place-entry-copy--facts{display:flex;flex-direction:column;justify-content:center;padding-top:22px}
.place-entry-copy--facts .place-entry-tries{margin-top:0}
.place-entry-empty-note{margin:0;color:var(--muted);font-size:.8rem}
.place-entry-address{display:flex;align-items:flex-start;gap:7px;margin:0 0 15px;color:var(--muted);font-size:.7rem;line-height:1.55}
.place-entry-address .icon{width:14px;height:14px;flex:0 0 14px;margin-top:2px;color:var(--entry-accent)}
.google-score{display:inline-flex;align-items:center;gap:5px;color:var(--accent)!important;font-family:var(--mono)}
.google-data-note{margin:18px 0 0;color:var(--faint);font-family:var(--mono);font-size:.55rem;line-height:1.6}
.filter-bar{grid-template-columns:minmax(280px,1fr) minmax(170px,220px) minmax(170px,220px)}

@media(max-width:1120px){
  .place-entry-location{display:none}
  .place-entry-google{min-width:112px}
  .place-entry-popular{display:none}
}
@media(max-width:860px){
  .place-entry-category{display:none}
  .place-entry-google{margin-left:auto}
  .filter-bar{grid-template-columns:1fr 1fr}
  .filter-search{grid-column:1/-1}
}
@media(max-width:580px){
  .place-entry-google{min-width:auto;padding:6px 7px}
  .place-entry-google small{display:none}
  .place-entry-name{max-width:48vw}
  .filter-bar{grid-template-columns:1fr}
  .filter-search{grid-column:auto}
  .place-entry-expand{padding-left:37px}
}


/* V9 · compact directory controls */
.directory-toolbar{
  position:sticky;top:72px;z-index:70;
  display:grid;grid-template-columns:minmax(280px,1.25fr) repeat(3,minmax(170px,.55fr));
  gap:8px;margin:24px 0 0;padding:10px;
  border:1px solid var(--line);background:color-mix(in srgb,var(--bg) 92%,transparent);
  backdrop-filter:blur(18px);box-shadow:0 12px 34px rgba(28,22,20,.06)
}
.directory-search,.directory-select{min-width:0;min-height:58px;padding:8px 12px;border:1px solid var(--line);background:var(--surface);display:flex;align-items:center;gap:11px}
.directory-search>span,.directory-select{min-width:0}
.directory-search>span{display:grid;gap:3px;flex:1}
.directory-search small,.directory-select small{display:block;color:var(--faint);font-family:var(--mono);font-size:.48rem;letter-spacing:.13em}
.directory-search input,.directory-select select{width:100%;min-width:0;border:0;outline:0;background:transparent;color:var(--text);font:500 .76rem var(--body)}
.directory-select{display:grid;align-content:center;gap:3px}
.directory-select select{font-family:var(--mono);font-size:.59rem;letter-spacing:.02em;cursor:pointer}
.directory-select--sort{border-color:color-mix(in srgb,var(--accent) 48%,var(--line));background:color-mix(in srgb,var(--accent) 5%,var(--surface))}
.quick-filters{display:flex;gap:0;overflow-x:auto;border-bottom:1px solid var(--line);scrollbar-width:none}
.quick-filters::-webkit-scrollbar{display:none}
.quick-filters button{flex:0 0 auto;padding:13px 15px 11px;border:0;border-bottom:2px solid transparent;background:transparent;color:var(--muted);font-family:var(--mono);font-size:.55rem;letter-spacing:.08em;text-transform:uppercase;cursor:pointer}
.quick-filters button:hover{color:var(--text)}
.quick-filters button.is-active{color:var(--accent);border-bottom-color:var(--accent)}
.city-places-directory{padding-top:0}
.city-places-directory .section-head{margin-bottom:0}
.place-entry-location:empty{display:none}
@media(max-width:1100px){.directory-toolbar{grid-template-columns:1fr 1fr;top:66px}.directory-search{grid-column:1/-1}}
@media(max-width:650px){.directory-toolbar{position:relative;top:auto;grid-template-columns:1fr;padding:8px}.directory-search{grid-column:auto}.directory-search,.directory-select{min-height:54px}.quick-filters button{padding-inline:12px}.place-entry-google small{display:none}}

/* V10: public information architecture has three primary sections. */
.home-tip-grid{margin-top:clamp(24px,4vw,48px)}
.board-card--main small{display:block;margin-top:5px;font-family:var(--mono);font-size:.55rem;letter-spacing:.12em;text-transform:uppercase;opacity:.72}

/* V15 · exact column alignment for sortable directory headers */
.directory-toolbar{
  grid-template-columns:minmax(300px,1fr) minmax(180px,220px) minmax(220px,280px);
}

.place-table-head,
.place-entry-row{
  --place-grid-columns:42px minmax(240px,1.55fr) minmax(150px,.85fr) minmax(150px,.8fr) 74px 108px 24px;
  display:grid;
  grid-template-columns:var(--place-grid-columns);
  align-items:center;
  column-gap:16px;
}

.place-table-head{
  min-height:44px;
  padding:0 2px;
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
  background:color-mix(in srgb,var(--surface) 78%,var(--bg));
}
.place-head-index,
.place-head-toggle{
  color:var(--faint);
  font-family:var(--mono);
  font-size:.5rem;
  letter-spacing:.12em;
}
.place-head-index{padding-left:1px}
.place-sort-button{
  width:100%;
  min-width:0;
  height:43px;
  padding:0;
  border:0;
  background:transparent;
  color:var(--faint);
  display:flex;
  align-items:center;
  justify-content:flex-start;
  gap:6px;
  font-family:var(--mono);
  font-size:.52rem;
  font-weight:700;
  letter-spacing:.12em;
  text-transform:uppercase;
  cursor:pointer;
  transition:color .18s ease,background .18s ease;
}
.place-sort-button:hover{color:var(--text)}
.place-sort-button:focus-visible{outline:2px solid var(--accent);outline-offset:-3px}
.place-sort-button i{
  font-style:normal;
  color:var(--faint);
  font-size:.7rem;
  line-height:1;
}
.place-sort-button.is-active{color:var(--accent)}
.place-sort-button.is-active i{color:var(--accent)}
.place-head-location{justify-content:flex-start;text-align:left}
.place-head-rating,
.place-head-reviews{justify-content:flex-end;text-align:right;justify-self:stretch}

.place-entry-row{
  min-height:72px;
  padding:12px 2px;
  /* Header and data rows must use the exact same gutter. */
  column-gap:16px;
  row-gap:0;
}
.place-entry-index{
  width:auto;
  min-width:0;
  flex:none;
}
.place-entry-name{
  min-width:0;
  max-width:none;
  display:flex;
  align-items:center;
  gap:8px;
  overflow:hidden;
}
.place-entry-name>span{
  min-width:0;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}
.place-entry-popular{
  flex:0 0 auto;
  padding:3px 6px;
  border-radius:999px;
  font-size:.43rem;
}
.place-entry-category{
  min-width:0;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
  text-align:left;
}
.place-entry-location{
  width:auto;
  min-width:0;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
  text-align:left;
}
.place-entry-rating,
.place-entry-reviews{
  min-width:0;
  justify-self:end;
  white-space:nowrap;
  font-family:var(--mono);
}
.place-entry-rating{
  display:inline-flex;
  align-items:center;
  gap:4px;
  color:var(--accent);
  font-size:.64rem;
}
.place-entry-rating .icon{
  width:12px;
  height:12px;
  fill:currentColor;
  stroke-width:1.4;
}
.place-entry-rating,
.place-entry-reviews{
  width:100%;
  justify-content:flex-end;
  text-align:right;
}
.place-entry-reviews{
  color:var(--muted);
  font-size:.57rem;
  letter-spacing:.01em;
  text-align:right;
}
.place-entry-chevron{
  justify-self:end;
  margin:0;
}
.place-entry-dots,
.place-entry-google{display:none!important}

@media(max-width:1120px){
  .place-table-head,
  .place-entry-row{
    --place-grid-columns:40px minmax(220px,1.55fr) minmax(145px,.8fr) 72px 100px 24px;
    grid-template-columns:var(--place-grid-columns);
    column-gap:16px;
  }
  .place-head-location,
  .place-entry-location{display:none}
}

@media(max-width:860px){
  .directory-toolbar{grid-template-columns:1fr 1fr}
  .directory-search{grid-column:1/-1}
  .place-table-head,
  .place-entry-row{
    --place-grid-columns:34px minmax(180px,1fr) 66px 92px 22px;
    grid-template-columns:var(--place-grid-columns);
    column-gap:11px;
  }
  .place-head-category,
  .place-entry-category{display:none}
  .place-entry-name{font-size:1.08rem}
}

@media(max-width:650px){
  .directory-toolbar{grid-template-columns:1fr}
  .directory-search{grid-column:auto}
  .journal-list-head{padding-top:16px}
  .place-table-head,
  .place-entry-row{
    --place-grid-columns:27px minmax(0,1fr) 48px 68px 18px;
    grid-template-columns:var(--place-grid-columns);
    column-gap:8px;
  }
  .place-table-head{min-height:40px}
  .place-sort-button{height:39px;font-size:.46rem;letter-spacing:.08em}
  .place-entry-row{min-height:64px;padding:10px 2px}
  .place-entry-name{font-size:1rem}
  .place-entry-popular{display:none}
  .place-entry-rating{font-size:.58rem}
  .place-entry-reviews{font-size:.5rem}
  .place-entry-chevron .icon{width:15px;height:15px}
  .place-entry-expand{padding-left:27px}
}

@media(max-width:420px){
  .place-table-head,
  .place-entry-row{
    --place-grid-columns:24px minmax(0,1fr) 44px 58px 17px;
    grid-template-columns:var(--place-grid-columns);
    column-gap:6px;
  }
  .place-head-reviews span{font-size:0}
  .place-head-reviews span::after{content:'YOR.';font-size:.45rem}
  .place-entry-reviews{font-size:.46rem}
}
@media(max-width:650px){
  .place-entry-name{max-width:none;white-space:normal;overflow:hidden}
}


@media (max-width: 900px) {
  .recipe-toolbar { grid-template-columns:1fr 1fr; }
  .recipe-search { grid-column:1/-1; }
}
@media (max-width: 580px) {
  .recipe-toolbar { grid-template-columns:1fr; }
  .recipe-search { grid-column:auto; }
  .recipe-archive-head { align-items:flex-start;flex-direction:column;gap:6px; }
  .recipe-support-grid { grid-template-columns:1fr; }
  .recipe-detail-head figure figcaption { left:8px;right:8px;bottom:8px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis; }
}
