@font-face { font-family: "Saraj Playwrite"; src: url('/assets/fonts/PlaywriteHR-Regular.ttf') format('truetype'); font-display: swap; }
@font-face { font-family: "Saraj Yuyu"; src: url('/assets/fonts/YuyuShort-Regular.ttf') format('truetype'); font-display: swap; }
@font-face { font-family: "Saraj Roboto"; src: url('/assets/fonts/Roboto-Regular.ttf') format('truetype'); font-weight: 400; font-display: swap; }
@font-face { font-family: "Saraj Roboto"; src: url('/assets/fonts/Roboto-Medium.ttf') format('truetype'); font-weight: 500; font-display: swap; }
@font-face { font-family: "Saraj Roboto"; src: url('/assets/fonts/Roboto-Bold.ttf') format('truetype'); font-weight: 700; font-display: swap; }
:root {
  --bg: #f6ead9;
  --paper: #fff9ef;
  --ink: #24150d;
  --muted: #715a4a;
  --red: #8d241f;
  --red-dark: #551613;
  --terracotta: #b85c32;
  --copper: #b8793c;
  --brass: #d1a45b;
  --emerald: #0b5a55;
  --sapphire: #153f67;
  --cream: #fff1d8;
  --line: rgba(85, 22, 19, .18);
  --shadow: 0 26px 80px rgba(50, 20, 11, .18);
  --radius: 30px;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: "Saraj Roboto", ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  color: var(--ink);
  background:
    radial-gradient(circle at top left, rgba(184, 92, 50, .26), transparent 34rem),
    radial-gradient(circle at 88% 4%, rgba(11, 90, 85, .17), transparent 32rem),
    linear-gradient(90deg, rgba(141,36,31,.04) 1px, transparent 1px),
    url('/assets/pattern-kilim.svg'),
    var(--bg);
  background-size: auto, auto, 52px 52px, 520px 200px, auto;
  min-height: 100vh;
}

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

.site-header {
  position: sticky;
  top: 0;
  z-index: 20;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding: 1rem clamp(1rem, 4vw, 3.5rem);
  background: rgba(255, 247, 236, .88);
  backdrop-filter: blur(18px);
  border-bottom: 1px solid var(--line);
}

.brand {
  display: inline-flex;
  align-items: center;
  gap: .8rem;
  text-decoration: none;
}
.brand-mark {
  display: grid;
  place-items: center;
  width: 46px;
  height: 46px;
  border-radius: 15px;
  color: #fff;
  font-size: 1.55rem;
  font-family: "Saraj Yuyu", Georgia, serif;
  background:
    radial-gradient(circle at 35% 30%, rgba(255,255,255,.24), transparent 26px),
    linear-gradient(135deg, var(--red-dark), var(--red) 52%, var(--copper));
  box-shadow: 0 10px 25px rgba(143, 47, 34, .22);
}
.brand strong { display: block; letter-spacing: .02em; }
.brand small { color: var(--muted); display: block; margin-top: .05rem; }

.main-nav {
  display: flex;
  align-items: center;
  gap: .35rem;
  padding: .35rem;
  border: 1px solid var(--line);
  border-radius: 999px;
  background: rgba(255, 250, 242, .62);
}
.main-nav a {
  text-decoration: none;
  padding: .62rem .9rem;
  border-radius: 999px;
  color: var(--muted);
  font-weight: 700;
  font-size: .94rem;
}
.main-nav a:hover,
.main-nav a.active {
  color: #fff;
  background: var(--red);
}
.reserve-pill {
  text-decoration: none;
  color: #fff;
  background: var(--red-dark);
  border-radius: 999px;
  padding: .82rem 1.1rem;
  font-weight: 800;
  box-shadow: 0 12px 30px rgba(94, 31, 24, .22);
}

.hero,
.page-hero,
.section {
  width: min(1160px, calc(100% - 2rem));
  margin: 0 auto;
}
.hero {
  min-height: min(720px, calc(100vh - 80px));
  display: grid;
  grid-template-columns: minmax(0, 1.02fr) minmax(320px, .98fr);
  align-items: center;
  gap: clamp(2rem, 5vw, 5rem);
  padding: clamp(3rem, 7vw, 6rem) 0;
}
.eyebrow {
  margin: 0 0 .75rem;
  color: var(--red);
  text-transform: uppercase;
  letter-spacing: .18em;
  font-size: .78rem;
  font-weight: 900;
}
h1, h2, h3 { line-height: 1.05; margin: 0; }
h1 {
  font-size: clamp(2.8rem, 8vw, 6.6rem);
  letter-spacing: -.07em;
  font-family: "Saraj Yuyu", Georgia, "Times New Roman", serif;
}
h2 {
  font-size: clamp(2rem, 4vw, 3.5rem);
  letter-spacing: -.055em;
  font-family: "Saraj Yuyu", Georgia, "Times New Roman", serif;
}
h3 { font-size: 1.35rem; }
p { color: var(--muted); line-height: 1.72; }
.hero-text { font-size: clamp(1.08rem, 2vw, 1.35rem); max-width: 680px; }
.hero-actions { display: flex; flex-wrap: wrap; gap: .9rem; margin-top: 2rem; }
.btn {
  border: 0;
  appearance: none;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 46px;
  border-radius: 999px;
  padding: .85rem 1.15rem;
  font-weight: 900;
  text-decoration: none;
  cursor: pointer;
  transition: transform .16s ease, box-shadow .16s ease, background .16s ease;
}
.btn:hover { transform: translateY(-1px); }
.btn.primary { color: #fff; background: linear-gradient(135deg, var(--red), var(--terracotta)); box-shadow: 0 14px 34px rgba(143, 47, 34, .22); }
.btn.secondary { color: var(--red-dark); background: rgba(255, 250, 242, .8); border: 1px solid var(--line); }
.btn.full { width: 100%; }
.hero-card {
  position: relative;
  border-radius: 999px 999px 42px 42px;
  padding: clamp(1rem, 3vw, 2rem);
  overflow: hidden;
  background:
    linear-gradient(145deg, rgba(255, 249, 239, .90), rgba(255, 241, 216, .82)),
    url('/assets/pattern-kilim.svg');
  background-size: auto, 420px 160px;
  box-shadow: var(--shadow);
  border: 1px solid rgba(255, 255, 255, .62);
}
.hero-card img { filter: drop-shadow(0 24px 22px rgba(53, 18, 7, .18)); }

.section { padding: clamp(2.5rem, 6vw, 5rem) 0; }
.split {
  display: grid;
  grid-template-columns: .9fr 1.1fr;
  gap: clamp(1.5rem, 4vw, 4rem);
  align-items: start;
}
.split > p { margin: 0; font-size: 1.08rem; }
.cards {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1rem;
}
.feature-card,
.menu-card,
.contact-card,
.reservation-form,
.reservation-info,
.admin-panel {
  border: 1px solid var(--line);
  background: rgba(255, 250, 242, .76);
  border-radius: var(--radius);
  box-shadow: 0 16px 44px rgba(70, 29, 15, .08);
}
.feature-card { padding: 1.4rem; }
.feature-card img { width: 54px; height: 54px; margin-bottom: 1rem; }
.feature-card p { margin-bottom: 0; }
.reservation-preview,
.muted-panel,
.map-placeholder {
  border: 1px solid var(--line);
  background:
    linear-gradient(135deg, rgba(255, 250, 242, .82), rgba(255, 240, 215, .65)),
    url('/assets/pattern-ornament.svg');
  background-size: auto, 300px;
  border-radius: 34px;
  padding: clamp(2rem, 4vw, 3rem);
}
.reservation-preview { display: flex; align-items: center; justify-content: space-between; gap: 1.5rem; }
.hours-list { display: grid; gap: .65rem; }
.hours-list div { display: flex; justify-content: space-between; gap: 1rem; border-bottom: 1px dashed var(--line); padding-bottom: .65rem; }
.hours-list span { color: var(--muted); }

.page-hero {
  padding: clamp(2.5rem, 6vw, 5rem) 0 clamp(1rem, 3vw, 2.5rem);
}
.page-hero.small h1 { max-width: 860px; font-size: clamp(2.4rem, 6vw, 5rem); }
.page-hero.small p:not(.eyebrow) { max-width: 760px; font-size: 1.08rem; }
.menu-grid,
.contact-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1rem;
}
.menu-card,
.contact-card { padding: 1.35rem; }
.menu-card span {
  display: inline-flex;
  margin-top: .8rem;
  color: var(--red);
  font-weight: 900;
  font-size: .9rem;
}
.map-placeholder { min-height: 280px; display: grid; align-items: end; }
.legal-text { max-width: 900px; }
.legal-text h2 { font-size: 1.65rem; margin-top: 2rem; }

.reservation-shell {
  display: grid;
  grid-template-columns: minmax(0, 1.35fr) minmax(280px, .65fr);
  gap: 1.2rem;
  align-items: start;
}
.reservation-form,
.reservation-info { padding: clamp(1.2rem, 3vw, 2rem); }
.reservation-info { position: sticky; top: 96px; }
.reservation-info img { width: 70px; margin-bottom: 1rem; }
.reservation-info ol { padding-left: 1.25rem; color: var(--muted); line-height: 1.85; }
.form-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: .9rem; }
label { display: grid; gap: .42rem; font-weight: 850; margin-bottom: 1rem; }
.field-title { display: block; font-weight: 850; margin-bottom: .5rem; }
input, textarea, select {
  width: 100%;
  border: 1px solid var(--line);
  border-radius: 16px;
  background: rgba(255, 255, 255, .66);
  min-height: 48px;
  padding: .75rem .85rem;
  font: inherit;
  color: var(--ink);
  outline: none;
}
textarea { resize: vertical; min-height: 110px; }
input:focus, textarea:focus { border-color: var(--terracotta); box-shadow: 0 0 0 4px rgba(199, 104, 61, .12); }
.checkline {
  display: flex;
  align-items: flex-start;
  gap: .7rem;
  font-weight: 700;
  color: var(--muted);
}
.checkline input { width: auto; min-height: auto; margin-top: .3rem; }
.slot-grid { display: flex; flex-wrap: wrap; gap: .55rem; margin-bottom: .5rem; }
.slot-button {
  border: 1px solid var(--line);
  background: rgba(255, 255, 255, .72);
  color: var(--ink);
  padding: .7rem .9rem;
  border-radius: 999px;
  font-weight: 900;
  cursor: pointer;
}
.slot-button:hover:not(:disabled), .slot-button.active { color: #fff; background: var(--red); }
.slot-button:disabled { opacity: .45; cursor: not-allowed; }
.hint { font-size: .92rem; margin-top: 0; }
.form-message { min-height: 1.5rem; font-weight: 800; }
.form-message.success { color: #196b3d; }
.form-message.error { color: var(--red); }
.confirmation.ok { color: #196b3d; }
.confirmation.error { color: var(--red); }

.site-footer {
  width: min(1160px, calc(100% - 2rem));
  margin: 2rem auto 0;
  border-top: 1px solid var(--line);
  display: flex;
  justify-content: space-between;
  gap: 1rem;
  padding: 2rem 0 2.5rem;
  color: var(--muted);
}
.footer-links { display: flex; flex-wrap: wrap; gap: .85rem; }
.footer-links a { color: var(--muted); font-weight: 750; }

.admin-body { background: #f8efe5; }
.admin-login { width: min(440px, calc(100% - 2rem)); min-height: 100vh; margin: 0 auto; display: grid; align-content: center; gap: 1rem; }
.admin-brand { justify-content: center; margin-bottom: 1rem; }
.admin-header { display: flex; justify-content: space-between; align-items: center; padding: 1rem clamp(1rem, 4vw, 2rem); border-bottom: 1px solid var(--line); background: rgba(255, 250, 242, .86); }
.admin-main { width: min(1280px, calc(100% - 2rem)); margin: 0 auto; padding: 2rem 0 4rem; display: grid; gap: 1rem; }
.admin-panel { padding: 1.2rem; }
.admin-title { display: flex; justify-content: space-between; gap: 1rem; align-items: center; }
.admin-title h1 { font-size: clamp(2rem, 4vw, 3.2rem); }
.admin-list { display: grid; gap: .8rem; margin-top: 1rem; }
.reservation-row {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 1rem;
  border: 1px solid var(--line);
  border-radius: 20px;
  padding: 1rem;
  background: rgba(255,255,255,.48);
}
.reservation-row h3 { margin: 0 0 .35rem; }
.meta { color: var(--muted); font-size: .95rem; display: flex; flex-wrap: wrap; gap: .8rem; }
.status-badge { display: inline-flex; border-radius: 999px; padding: .35rem .65rem; background: var(--cream); color: var(--red-dark); font-weight: 900; }
.row-actions { display: flex; flex-wrap: wrap; gap: .4rem; align-content: start; }
.row-actions button { min-height: 38px; padding: .55rem .7rem; }
.two-col { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; }
.admin-form { display: grid; gap: .4rem; }
.day-row { display: grid; grid-template-columns: 1.1fr auto 1fr 1fr; gap: .5rem; align-items: center; border-bottom: 1px dashed var(--line); padding: .5rem 0; }
.day-row label { margin: 0; }
.settings-form { grid-template-columns: repeat(2, 1fr); }
.settings-form .full-row { grid-column: 1 / -1; }
.special-list { display: grid; gap: .5rem; margin-top: 1rem; }
.special-item { display: flex; justify-content: space-between; gap: .7rem; align-items: center; background: rgba(255,255,255,.45); border: 1px solid var(--line); border-radius: 16px; padding: .75rem; }

@media (max-width: 900px) {
  .site-header { flex-wrap: wrap; }
  .main-nav { order: 3; width: 100%; justify-content: center; overflow-x: auto; }
  .reserve-pill { display: none; }
  .hero, .split, .reservation-shell, .two-col { grid-template-columns: 1fr; }
  .hero { padding-top: 2.5rem; }
  .cards, .menu-grid, .contact-grid { grid-template-columns: 1fr; }
  .reservation-preview, .site-footer { flex-direction: column; align-items: flex-start; }
  .reservation-info { position: static; }
}
@media (max-width: 620px) {
  .form-grid, .settings-form, .day-row { grid-template-columns: 1fr; }
  h1 { letter-spacing: -.045em; }
  .main-nav a { padding: .55rem .7rem; }
  .reservation-row { grid-template-columns: 1fr; }
}


/* Saraj Modern Balkan Ethno-Chic refinement */
h1 { font-family: "Saraj Yuyu", Georgia, serif; font-weight: 400; letter-spacing: -.035em; }
h2 { font-family: "Saraj Yuyu", Georgia, serif; font-weight: 400; letter-spacing: -.025em; }
.brand strong { font-family: "Saraj Yuyu", Georgia, serif; font-size: 1.18rem; font-weight: 400; }
.eyebrow { color: var(--emerald); }
.main-nav a:hover, .main-nav a.active { background: var(--emerald); }
.reserve-pill { background: linear-gradient(135deg, var(--red-dark), var(--emerald)); }
.btn.primary { background: linear-gradient(135deg, var(--red-dark), var(--terracotta) 55%, var(--copper)); }
.btn.secondary { background: rgba(255, 249, 239, .82); }
.hero { grid-template-columns: minmax(0, .96fr) minmax(320px, 1.04fr); }
.hero::before, .page-hero::before { content: ""; display: block; width: 140px; height: 16px; background: url('/assets/pattern-kilim.svg') center/210px 80px; margin-bottom: 1rem; border-radius: 999px; opacity: .75; }
.photo-card { padding: .72rem; border: 1px solid rgba(209,164,91,.35); }
.photo-card::before { content: ""; position: absolute; inset: 1.05rem; border: 1px solid rgba(255,241,216,.72); border-radius: 999px 999px 35px 35px; z-index: 2; pointer-events: none; }
.photo-card img { width: 100%; height: min(620px, 72vh); object-fit: cover; border-radius: 999px 999px 34px 34px; filter: saturate(1.03) contrast(1.04); }
.photo-caption { position: absolute; left: 2rem; right: 2rem; bottom: 2rem; z-index: 3; display: inline-flex; justify-content: center; padding: .72rem 1rem; color: #fff9ef; background: rgba(36,21,13,.66); backdrop-filter: blur(12px); border: 1px solid rgba(255,255,255,.22); border-radius: 999px; font-weight: 800; letter-spacing: .08em; text-transform: uppercase; font-size: .78rem; }
.feature-card, .menu-card, .contact-card, .reservation-form, .reservation-info, .admin-panel { background: linear-gradient(180deg, rgba(255,249,239,.86), rgba(255,241,216,.58)); }
.feature-card, .menu-card { position: relative; overflow: hidden; }
.feature-card::after, .menu-card::after { content: ""; position: absolute; inset: auto 0 0; height: 6px; background: url('/assets/pattern-kilim.svg') center/190px 72px; opacity: .75; }
.reservation-preview, .muted-panel, .map-placeholder { background: linear-gradient(135deg, rgba(255,249,239,.88), rgba(255,241,216,.70)), url('/assets/pattern-kilim.svg'); background-size: auto, 420px 160px; }
.slot-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(128px, 1fr)); }
.slot-button { display: grid; gap: .18rem; justify-items: center; border-radius: 18px; padding: .72rem .55rem; }
.slot-button small { display: block; color: var(--muted); font-size: .72rem; font-weight: 700; line-height: 1.2; }
.slot-button.active small, .slot-button:hover:not(:disabled) small { color: rgba(255,255,255,.9); }
.hint.compact { margin-top: -.5rem; font-size: .88rem; }
.table-inventory { display: flex; flex-wrap: wrap; gap: .6rem; margin: 1rem 0; }
.table-inventory span { border: 1px solid var(--line); background: rgba(255,255,255,.5); border-radius: 999px; padding: .45rem .65rem; color: var(--muted); }
.table-plan { display: grid; gap: .5rem; }
.table-plan-row { display: grid; grid-template-columns: 1fr 1fr 1fr 1.4fr; gap: .7rem; align-items: center; border: 1px solid var(--line); border-radius: 16px; background: rgba(255,255,255,.46); padding: .75rem; }
.inline-date { margin: 0; min-width: 190px; }
@media (max-width: 900px) { .table-plan-row { grid-template-columns: 1fr; } .photo-card img { height: 460px; } }

/* v3 readability and calmer Modern Balkan Ethno-Chic */
body {
  font-family: "Saraj Roboto", ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  background:
    radial-gradient(circle at 12% 8%, rgba(184, 92, 50, .16), transparent 30rem),
    radial-gradient(circle at 86% 12%, rgba(11, 90, 85, .12), transparent 34rem),
    linear-gradient(180deg, #f8eee0 0%, #f3e4d0 100%);
  position: relative;
}
body::before,
body::after {
  content: "";
  position: fixed;
  pointer-events: none;
  z-index: -1;
  width: 560px;
  height: 560px;
  border-radius: 50%;
  opacity: .075;
  background:
    radial-gradient(circle, transparent 0 54px, rgba(85,22,19,.7) 55px 57px, transparent 58px 100%),
    conic-gradient(from 0deg, transparent 0 8deg, rgba(141,36,31,.7) 8deg 10deg, transparent 10deg 22deg, rgba(11,90,85,.7) 22deg 24deg, transparent 24deg 45deg);
  filter: blur(.2px);
}
body::before { left: -180px; top: 120px; }
body::after { right: -220px; bottom: 20px; transform: rotate(18deg); }
.site-header { background: rgba(255, 249, 240, .94); }
.brand-mark {
  width: 58px;
  height: 42px;
  border-radius: 18px;
  font-family: "Saraj Yuyu", Georgia, serif;
  font-size: 1rem;
  letter-spacing: .01em;
}
.brand strong,
h1,
h2,
.admin-title h1 {
  font-family: "Saraj Playwrite", Georgia, serif !important;
  font-weight: 400 !important;
  letter-spacing: -.02em !important;
}
.saraj-word {
  font-family: "Saraj Yuyu", Georgia, serif;
  font-weight: 400;
  letter-spacing: .01em;
  white-space: nowrap;
}
h1 { font-size: clamp(2.55rem, 6vw, 5.2rem); max-width: 920px; }
h2 { font-size: clamp(1.8rem, 3.2vw, 3rem); }
h3, .main-nav a, .btn, label, .field-title { font-family: "Saraj Roboto", ui-sans-serif, sans-serif; }
p { color: #634d3f; }
.hero.clean-hero {
  grid-template-columns: minmax(0, .95fr) minmax(330px, .8fr);
  min-height: auto;
  padding: clamp(2rem, 5vw, 4.5rem) 0 clamp(2rem, 4vw, 3.5rem);
}
.panel-soft,
.story-card,
.accent-card,
.feature-card,
.menu-card,
.contact-card,
.reservation-form,
.reservation-info,
.admin-panel,
.muted-panel,
.map-panel {
  background: rgba(255, 250, 243, .88) !important;
  border: 1px solid rgba(85, 22, 19, .14);
  box-shadow: 0 18px 58px rgba(55, 25, 12, .10);
  backdrop-filter: blur(6px);
}
.panel-soft { padding: clamp(1.2rem, 3vw, 2.1rem); border-radius: 34px; }
.hero::before,
.page-hero::before { display: none !important; }
.photo-card {
  background: linear-gradient(145deg, rgba(255,249,239,.96), rgba(248,231,204,.92)) !important;
  border-radius: 46px;
  padding: .8rem;
}
.photo-card::before { border-radius: 36px; inset: 1rem; }
.photo-card img {
  border-radius: 36px;
  height: clamp(340px, 48vw, 580px);
  object-fit: cover;
}
.photo-caption { bottom: 1.65rem; left: 1.65rem; right: 1.65rem; }
.story-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1rem;
  padding-top: 1rem;
}
.story-card { border-radius: 34px; padding: clamp(1.4rem, 3vw, 2.4rem); }
.accent-card { background: linear-gradient(145deg, rgba(255,250,243,.91), rgba(246,230,205,.92)) !important; }
.cards.section { padding-top: 1rem; }
.feature-card::after,
.menu-card::after { opacity: .28; height: 4px; }
.reservation-preview,
.muted-panel,
.map-placeholder { background-image: none !important; }
.opening-panel { align-items: center; }
.hours-list div { background: rgba(255,255,255,.36); border: 1px solid rgba(85,22,19,.10); border-radius: 16px; padding: .75rem .9rem; }
.page-hero { padding-top: clamp(2rem, 5vw, 4rem); }
.page-hero.small h1 { font-size: clamp(2.05rem, 4.4vw, 4rem); }
.map-panel {
  width: min(1160px, calc(100% - 2rem));
  margin: 0 auto;
  border-radius: 34px;
  padding: clamp(1rem, 3vw, 1.4rem);
  display: grid;
  grid-template-columns: .72fr 1.28fr;
  gap: 1rem;
  align-items: stretch;
}
.map-copy { padding: clamp(1rem, 2vw, 1.5rem); }
.local-map {
  position: relative;
  min-height: 380px;
  border-radius: 26px;
  overflow: hidden;
  background: linear-gradient(135deg, rgba(11,90,85,.14), rgba(184,92,50,.10)), #ead9c4;
  border: 1px solid rgba(85,22,19,.14);
}
.local-map .tile { position: absolute; width: 256px; height: 256px; image-rendering: auto; }
.map-fallback {
  position: absolute;
  inset: 0;
  display: grid;
  place-items: center;
  text-align: center;
  padding: 1rem;
  color: #5d4535;
  font-weight: 800;
  background:
    radial-gradient(circle at 50% 45%, rgba(255,255,255,.48), transparent 9rem),
    linear-gradient(90deg, rgba(85,22,19,.08) 1px, transparent 1px),
    linear-gradient(0deg, rgba(85,22,19,.08) 1px, transparent 1px);
  background-size: auto, 48px 48px, 48px 48px;
}
.map-fallback span { display: block; margin-top: .3rem; font-weight: 500; }
.map-attribution { position: absolute; right: .55rem; bottom: .45rem; background: rgba(255,250,243,.86); padding: .25rem .45rem; border-radius: 8px; font-size: .72rem; color: #634d3f; }
code { background: rgba(85,22,19,.08); border-radius: 6px; padding: .1rem .3rem; }
@media (max-width: 900px) {
  .story-grid, .map-panel { grid-template-columns: 1fr; }
  .hero.clean-hero { grid-template-columns: 1fr; }
}

/* v4 Saraj Balkan Warmth: ruhiger, lesbarer, kein dominantes Muster */
:root {
  --saraj-bg-dark: #24140D;
  --saraj-bg-deep: #160D09;
  --saraj-primary: #6E1F16;
  --saraj-primary-hover: #8A3E24;
  --saraj-copper: #B66A32;
  --saraj-gold: #C99A4A;
  --saraj-cream: #F4E8D2;
  --saraj-cream-muted: #E8D6B8;
  --saraj-text-dark: #1A0F0A;
  --saraj-text-light: #F4E8D2;
  --saraj-text-muted: #D8C2A3;
  --saraj-green: #4F6650;
  --saraj-border: rgba(201, 154, 74, 0.28);
  --bg: var(--saraj-bg-dark);
  --paper: var(--saraj-cream);
  --ink: var(--saraj-text-dark);
  --muted: #6F5848;
  --red: var(--saraj-primary);
  --red-dark: #46140F;
  --terracotta: var(--saraj-primary-hover);
  --copper: var(--saraj-copper);
  --brass: var(--saraj-gold);
  --emerald: var(--saraj-green);
  --cream: var(--saraj-cream);
  --line: rgba(201, 154, 74, .22);
}

body {
  background:
    radial-gradient(circle at 10% 0%, rgba(182, 106, 50, .18), transparent 36rem),
    radial-gradient(circle at 92% 6%, rgba(79, 102, 80, .16), transparent 32rem),
    linear-gradient(180deg, var(--saraj-bg-dark), var(--saraj-bg-deep));
  color: var(--saraj-text-light);
  overflow-x: hidden;
}
body::before {
  content: "";
  position: fixed;
  inset: 0;
  width: auto;
  height: auto;
  border-radius: 0;
  z-index: -2;
  pointer-events: none;
  opacity: .18;
  filter: none;
  background:
    linear-gradient(90deg, rgba(36,20,13,.82), rgba(36,20,13,.48) 42%, rgba(36,20,13,.86)),
    linear-gradient(180deg, rgba(22,13,9,.28), rgba(22,13,9,.82)),
    url('/assets/photos/saraj-arches-bg.webp') center top / cover no-repeat;
}
body::after { display: none !important; }
main { position: relative; z-index: 1; }

a { text-underline-offset: .18em; }
p { color: #6B5545; }
.site-header {
  background: rgba(22, 13, 9, .82);
  border-bottom: 1px solid rgba(201, 154, 74, .22);
  backdrop-filter: blur(18px);
}
.brand { color: var(--saraj-text-light); }
.brand-mark {
  color: var(--saraj-cream);
  background: linear-gradient(135deg, var(--saraj-primary), var(--saraj-copper));
  box-shadow: 0 12px 28px rgba(0,0,0,.24);
}
.brand strong { color: var(--saraj-text-light); font-family: "Saraj Roboto", sans-serif !important; font-weight: 800 !important; letter-spacing: .02em !important; }
.brand small { color: var(--saraj-text-muted); }
.main-nav { background: rgba(244, 232, 210, .06); border-color: rgba(201,154,74,.24); }
.main-nav a { color: var(--saraj-text-muted); }
.main-nav a:hover, .main-nav a.active { background: var(--saraj-primary); color: var(--saraj-cream); }
.reserve-pill { background: linear-gradient(135deg, var(--saraj-primary), var(--saraj-copper)); color: var(--saraj-cream); }

.hero,
.page-hero,
.section,
.map-panel { width: min(1180px, calc(100% - 2rem)); }
.hero.clean-hero {
  grid-template-columns: minmax(0, 1fr) minmax(300px, .78fr);
  gap: clamp(1.4rem, 4vw, 4rem);
  min-height: auto;
  padding: clamp(2.4rem, 6vw, 5.2rem) 0 clamp(1.6rem, 4vw, 3rem);
}
.panel-soft {
  background: linear-gradient(135deg, rgba(244,232,210,.94), rgba(232,214,184,.88)) !important;
  color: var(--saraj-text-dark);
  border: 1px solid rgba(201,154,74,.34);
  box-shadow: 0 26px 78px rgba(0,0,0,.28);
  border-radius: 34px;
  padding: clamp(1.4rem, 4vw, 3rem);
}
.eyebrow { color: var(--saraj-green); letter-spacing: .16em; }
.panel-soft .eyebrow { color: var(--saraj-primary); }
h1, .page-hero.small h1 {
  font-family: "Saraj Playwrite", Georgia, serif !important;
  font-size: clamp(2.15rem, 5vw, 4.35rem);
  letter-spacing: -.025em !important;
  line-height: 1.08;
  color: var(--saraj-text-dark);
}
h2 {
  font-family: "Saraj Roboto", ui-sans-serif, sans-serif !important;
  font-weight: 900 !important;
  letter-spacing: -.035em !important;
  font-size: clamp(1.65rem, 3.2vw, 2.8rem);
  color: var(--saraj-text-dark);
}
h3 { color: var(--saraj-text-dark); }
.saraj-word { font-family: "Saraj Yuyu", Georgia, serif; font-size: 1.08em; letter-spacing: .01em; }
.hero-text { max-width: 620px; color: #5F4939; }
.btn.primary { background: linear-gradient(135deg, var(--saraj-primary), var(--saraj-primary-hover)); color: var(--saraj-cream); box-shadow: 0 16px 38px rgba(110,31,22,.28); }
.btn.primary:hover { background: linear-gradient(135deg, var(--saraj-primary-hover), var(--saraj-copper)); }
.btn.secondary { color: var(--saraj-primary); background: rgba(255,255,255,.48); border-color: rgba(110,31,22,.20); }

.photo-card {
  background: linear-gradient(145deg, rgba(36,20,13,.92), rgba(22,13,9,.94)) !important;
  border: 1px solid rgba(201,154,74,.30);
  box-shadow: 0 30px 90px rgba(0,0,0,.32);
  border-radius: 34px;
  padding: .75rem;
}
.photo-card::before { border-color: rgba(201,154,74,.36); border-radius: 26px; inset: .95rem; }
.photo-card img { border-radius: 26px; height: clamp(280px, 42vw, 500px); object-fit: cover; opacity: .92; }
.photo-caption { background: rgba(22,13,9,.76); color: var(--saraj-cream); border-color: rgba(201,154,74,.35); }

.story-grid {
  grid-template-columns: minmax(0, 1.1fr) minmax(280px, .9fr);
  padding-top: clamp(1.2rem, 3vw, 2rem);
}
.story-card,
.feature-card,
.menu-card,
.contact-card,
.reservation-form,
.reservation-info,
.admin-panel,
.muted-panel,
.map-panel {
  background: linear-gradient(180deg, rgba(244,232,210,.97), rgba(232,214,184,.92)) !important;
  color: var(--saraj-text-dark);
  border: 1px solid rgba(201,154,74,.28);
  box-shadow: 0 20px 60px rgba(0,0,0,.22);
  backdrop-filter: none;
}
.story-card { border-radius: 28px; }
.story-card p,
.feature-card p,
.menu-card p,
.contact-card p,
.reservation-info p,
.reservation-info li,
.legal-text p { color: #5D493A; }
.accent-card { background: linear-gradient(135deg, rgba(244,232,210,.98), rgba(216,194,163,.94)) !important; }
.feature-card::after, .menu-card::after { opacity: 0 !important; }
.cards.section { gap: 1.1rem; }
.feature-card { border-radius: 26px; padding: 1.6rem; }
.feature-card img { background: rgba(182,106,50,.10); border-radius: 18px; padding: .5rem; }

.opening-panel {
  display: grid;
  grid-template-columns: minmax(0, .8fr) minmax(280px, 1.2fr);
  gap: clamp(1rem, 3vw, 2rem);
  border-radius: 30px;
  margin-top: 1.4rem;
}
.hours-list div { background: rgba(255,255,255,.35); border-color: rgba(110,31,22,.10); }
.hours-list span { color: #6B5545; }
.hours-list strong { color: var(--saraj-text-dark); }

.page-hero.small {
  margin-top: clamp(1.3rem, 3vw, 2.2rem);
  padding: clamp(1.4rem, 4vw, 3rem);
  background: linear-gradient(135deg, rgba(244,232,210,.96), rgba(216,194,163,.88));
  border: 1px solid rgba(201,154,74,.28);
  border-radius: 32px;
  box-shadow: 0 20px 60px rgba(0,0,0,.22);
}
.page-hero.small p:not(.eyebrow) { color: #5D493A; }
.menu-grid, .contact-grid { margin-top: 1.2rem; }
input, textarea, select {
  background: rgba(255,255,255,.72);
  border-color: rgba(110,31,22,.18);
  color: var(--saraj-text-dark);
}
input:focus, textarea:focus, select:focus { border-color: var(--saraj-copper); box-shadow: 0 0 0 4px rgba(182,106,50,.16); }
.slot-button { background: rgba(255,255,255,.56); color: var(--saraj-text-dark); border-color: rgba(110,31,22,.16); }
.slot-button:hover:not(:disabled), .slot-button.active { background: var(--saraj-primary); color: var(--saraj-cream); }
.checkline { color: #5D493A; }
.hint { color: #6B5545; }

.map-panel { grid-template-columns: .8fr 1.2fr; margin-top: 1rem; }
.local-map { background: linear-gradient(135deg, rgba(79,102,80,.16), rgba(182,106,50,.16)), #E8D6B8; }
.map-fallback { color: #4D392C; }
.site-footer {
  color: var(--saraj-text-muted);
  border-top-color: rgba(201,154,74,.22);
}
.footer-links a { color: var(--saraj-text-muted); }
.legal-text h2 { color: var(--saraj-text-light); }
.legal-text p { color: var(--saraj-text-muted); }
.legal-text {
  background: rgba(22,13,9,.38);
  border: 1px solid rgba(201,154,74,.18);
  border-radius: 26px;
  padding: clamp(1.2rem, 3vw, 2rem);
}
.admin-body { background: var(--saraj-bg-dark); }
.admin-header { background: rgba(22,13,9,.88); border-bottom-color: rgba(201,154,74,.22); color: var(--saraj-text-light); }
.admin-title h1 { color: var(--saraj-text-dark); font-family: "Saraj Roboto", sans-serif !important; font-weight: 900 !important; }
.admin-panel h2, .admin-panel h3 { color: var(--saraj-text-dark); }
.meta, .table-inventory span { color: #675142; }

@media (max-width: 900px) {
  .hero.clean-hero,
  .story-grid,
  .opening-panel,
  .map-panel { grid-template-columns: 1fr; }
  .photo-card img { height: 360px; }
}
@media (max-width: 620px) {
  .panel-soft, .page-hero.small { border-radius: 24px; }
  h1, .page-hero.small h1 { font-size: clamp(1.95rem, 10vw, 2.9rem); }
}

/* v5: ruhiger Premium-Look, echte Hintergrundtiefe, lokale OSM-/Routen-Komponente */
body {
  background:
    linear-gradient(180deg, rgba(22,13,9,.70), rgba(22,13,9,.95) 72%, #160D09),
    radial-gradient(circle at 12% 18%, rgba(182,106,50,.34), transparent 30rem),
    radial-gradient(circle at 86% 12%, rgba(201,154,74,.16), transparent 28rem),
    url('/assets/photos/saraj-dark-kilim-bg.webp') center top / cover fixed no-repeat,
    #24140D !important;
}
body::before {
  opacity: .16 !important;
  background:
    linear-gradient(90deg, rgba(22,13,9,.85), rgba(22,13,9,.18) 48%, rgba(22,13,9,.86)),
    linear-gradient(180deg, rgba(36,20,13,.18), rgba(22,13,9,.82)),
    url('/assets/photos/saraj-coffee-table-bg.webp') center top / cover no-repeat !important;
  mix-blend-mode: screen;
}
main::before {
  content: "";
  position: fixed;
  inset: 0;
  z-index: -1;
  pointer-events: none;
  background:
    radial-gradient(circle at 28% 18%, rgba(244,232,210,.10), transparent 14rem),
    linear-gradient(90deg, rgba(244,232,210,.035) 1px, transparent 1px),
    linear-gradient(0deg, rgba(244,232,210,.028) 1px, transparent 1px);
  background-size: auto, 92px 92px, 92px 92px;
  mask-image: linear-gradient(180deg, rgba(0,0,0,.7), rgba(0,0,0,.18));
}

.site-header {
  box-shadow: 0 18px 48px rgba(0,0,0,.22);
}
.hero.clean-hero {
  grid-template-columns: minmax(0, .92fr) minmax(320px, .82fr);
  align-items: stretch;
}
.panel-soft,
.page-hero.small,
.story-card,
.feature-card,
.menu-card,
.contact-card,
.reservation-form,
.reservation-info,
.admin-panel,
.muted-panel,
.route-panel {
  border-radius: 28px;
  border: 1px solid rgba(201,154,74,.30);
  box-shadow: 0 24px 72px rgba(0,0,0,.26), inset 0 1px 0 rgba(255,255,255,.32);
}
.panel-soft,
.page-hero.small,
.story-card,
.feature-card,
.menu-card,
.contact-card,
.reservation-form,
.reservation-info,
.admin-panel,
.muted-panel {
  background:
    linear-gradient(180deg, rgba(244,232,210,.97), rgba(232,214,184,.92)),
    radial-gradient(circle at top right, rgba(182,106,50,.14), transparent 17rem) !important;
}
.panel-soft { display: flex; flex-direction: column; justify-content: center; }

h1,
h2,
.page-hero.small h1,
.story-card h2,
.menu-card h2,
.contact-card h2,
.reservation-info h2,
.opening-panel h2 {
  font-family: "Saraj Playwrite", Georgia, serif !important;
  font-weight: 400 !important;
  letter-spacing: -.018em !important;
}
h1 { font-size: clamp(2.3rem, 5.4vw, 4.8rem) !important; }
h2 { font-size: clamp(1.55rem, 3vw, 2.55rem) !important; }
.menu-card h2,
.contact-card h2 { font-size: clamp(1.35rem, 2.2vw, 2rem) !important; }
.brand strong,
h3,
.main-nav a,
.btn,
label,
input,
select,
textarea,
p,
li,
.hours-list,
.hint {
  font-family: "Saraj Roboto", ui-sans-serif, system-ui, sans-serif !important;
}
.saraj-word,
.brand-mark { font-family: "Saraj Yuyu", Georgia, serif !important; }

.photo-card {
  display: grid;
  align-items: end;
  min-height: 100%;
  background:
    linear-gradient(180deg, rgba(36,20,13,.18), rgba(22,13,9,.72)),
    url('/assets/photos/saraj-arches-copper-bg.webp') center / cover no-repeat !important;
  padding: 1.1rem;
  overflow: hidden;
}
.photo-card img {
  max-height: 520px;
  width: 100%;
  object-fit: cover;
  box-shadow: 0 18px 50px rgba(0,0,0,.35);
}
.photo-card::after {
  content: "";
  position: absolute;
  inset: 1.1rem;
  border: 1px solid rgba(201,154,74,.38);
  border-radius: 26px;
  pointer-events: none;
}
.feature-card,
.menu-card,
.contact-card { transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease; }
.feature-card:hover,
.menu-card:hover,
.contact-card:hover {
  transform: translateY(-3px);
  border-color: rgba(182,106,50,.46);
  box-shadow: 0 28px 78px rgba(0,0,0,.30), inset 0 1px 0 rgba(255,255,255,.35);
}

.route-panel {
  width: min(1180px, calc(100% - 2rem));
  margin: 1.2rem auto clamp(2rem, 5vw, 4rem);
  display: grid;
  grid-template-columns: minmax(300px, .82fr) minmax(0, 1.18fr);
  gap: clamp(1rem, 3vw, 1.6rem);
  align-items: stretch;
  padding: clamp(1rem, 3vw, 1.35rem);
  background:
    linear-gradient(135deg, rgba(244,232,210,.98), rgba(232,214,184,.92)),
    radial-gradient(circle at 88% 14%, rgba(182,106,50,.16), transparent 18rem) !important;
}
.route-copy { padding: clamp(1.1rem, 3vw, 2.2rem); display: flex; flex-direction: column; justify-content: center; }
.route-copy p { color: #5D493A; }
.route-actions { display: flex; flex-wrap: wrap; gap: .75rem; margin: 1.1rem 0 .5rem; }
.map-shell { min-height: 420px; }
.local-map {
  min-height: 420px;
  height: 100%;
  border-radius: 24px;
  background:
    linear-gradient(135deg, rgba(36,20,13,.18), rgba(22,13,9,.08)),
    radial-gradient(circle at 52% 45%, rgba(244,232,210,.45), transparent 11rem),
    #d9c49f !important;
  box-shadow: inset 0 0 0 1px rgba(110,31,22,.12), inset 0 -70px 90px rgba(36,20,13,.12);
}
.local-map::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  opacity: .32;
  background:
    linear-gradient(90deg, rgba(36,20,13,.16) 1px, transparent 1px),
    linear-gradient(0deg, rgba(36,20,13,.12) 1px, transparent 1px);
  background-size: 64px 64px;
}
.local-map .tile { position: absolute; width: 256px; height: 256px; z-index: 1; }
.map-fallback {
  z-index: 2;
  background:
    linear-gradient(135deg, rgba(244,232,210,.54), rgba(232,214,184,.34)),
    radial-gradient(circle at 50% 48%, rgba(110,31,22,.14), transparent 10rem) !important;
  color: transparent;
}
.map-pin,
.route-pin {
  position: absolute;
  z-index: 5;
  transform: translate(-50%, -100%);
  display: inline-grid;
  place-items: center;
  min-width: 62px;
  min-height: 42px;
  padding: .38rem .68rem;
  border-radius: 999px 999px 999px 8px;
  color: var(--saraj-cream);
  background: linear-gradient(135deg, var(--saraj-primary), var(--saraj-copper));
  border: 1px solid rgba(244,232,210,.38);
  box-shadow: 0 10px 26px rgba(0,0,0,.26);
  font-weight: 900;
  font-size: .82rem;
}
.map-pin { left: 50%; top: 50%; }
.route-pin.start { background: linear-gradient(135deg, var(--saraj-green), #314834); }
.route-pin.destination { background: linear-gradient(135deg, var(--saraj-primary), var(--saraj-copper)); }
.route-overlay {
  position: absolute;
  inset: 0;
  z-index: 4;
  pointer-events: none;
}
.route-overlay polyline {
  fill: none;
  stroke: var(--saraj-primary);
  stroke-width: 5;
  stroke-linecap: round;
  stroke-linejoin: round;
  filter: drop-shadow(0 2px 4px rgba(0,0,0,.28));
}
.map-attribution { display: none !important; }
.hint.error { color: var(--saraj-primary); font-weight: 800; }

@media (max-width: 980px) {
  .route-panel { grid-template-columns: 1fr; }
  .map-shell, .local-map { min-height: 340px; }
}
@media (max-width: 680px) {
  .hero.clean-hero { padding-top: 1.4rem; }
  .site-header { position: relative; flex-wrap: wrap; }
  .main-nav { order: 3; width: 100%; overflow-x: auto; justify-content: flex-start; }
  .reserve-pill { display: none; }
  .cards, .menu-grid, .contact-grid { grid-template-columns: 1fr; }
}
.local-map.has-tiles .map-fallback { display: none !important; }

/* v6: ruhiger Restaurant-Look + stabilere lokale OSM-Karte */
body {
  background:
    radial-gradient(circle at 18% 6%, rgba(182,106,50,.24), transparent 38rem),
    radial-gradient(circle at 82% 2%, rgba(79,102,80,.20), transparent 32rem),
    linear-gradient(180deg, #24140D, #160D09 72%, #0f0705) !important;
}
body::before {
  opacity: .34 !important;
  background:
    linear-gradient(90deg, rgba(22,13,9,.78), rgba(22,13,9,.42) 44%, rgba(22,13,9,.82)),
    linear-gradient(180deg, rgba(22,13,9,.16), rgba(22,13,9,.86)),
    url('/assets/photos/saraj-dark-kilim-bg.webp') center center / cover no-repeat !important;
}
body::after {
  content: "" !important;
  display: block !important;
  position: fixed;
  inset: 0;
  z-index: -1;
  pointer-events: none;
  opacity: .12;
  background:
    radial-gradient(circle at 52% 0%, rgba(201,154,74,.30), transparent 20rem),
    linear-gradient(90deg, rgba(244,232,210,.055) 1px, transparent 1px),
    linear-gradient(0deg, rgba(244,232,210,.04) 1px, transparent 1px);
  background-size: auto, 72px 72px, 72px 72px;
}

h1,
h2,
.page-hero.small h1,
.story-card h2,
.menu-card h2,
.contact-card h2,
.reservation-info h2,
.opening-panel h2,
.route-copy h2 {
  font-family: "Saraj Playwrite", Georgia, serif !important;
  font-weight: 400 !important;
  letter-spacing: -.012em !important;
}
.brand-mark,
.saraj-word { font-family: "Saraj Yuyu", Georgia, serif !important; }
p, li, .hint, label, input, select, textarea, .btn, .main-nav a, .hours-list, .contact-card a {
  font-family: "Saraj Roboto", ui-sans-serif, system-ui, sans-serif !important;
}

.route-panel {
  background:
    linear-gradient(135deg, rgba(244,232,210,.985), rgba(232,214,184,.955)),
    radial-gradient(circle at 90% 12%, rgba(182,106,50,.18), transparent 18rem) !important;
  border: 1px solid rgba(201,154,74,.32);
  box-shadow: 0 32px 95px rgba(0,0,0,.33), inset 0 1px 0 rgba(255,255,255,.38);
}
.route-copy h2 { font-size: clamp(2rem, 4vw, 3.6rem) !important; line-height: 1.05; }
.route-copy p { max-width: 56ch; }
.map-shell {
  min-height: 460px;
  border-radius: 30px;
  overflow: hidden;
  box-shadow: inset 0 0 0 1px rgba(36,20,13,.14), 0 24px 70px rgba(36,20,13,.18);
}
.local-map {
  position: relative;
  overflow: hidden;
  min-height: 460px;
  height: 100%;
  border-radius: 30px;
  background:
    radial-gradient(circle at 50% 48%, rgba(244,232,210,.58), transparent 13rem),
    linear-gradient(135deg, rgba(79,102,80,.13), rgba(182,106,50,.17)),
    #dac5a3 !important;
}
.local-map::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  opacity: .34;
  background:
    linear-gradient(90deg, rgba(36,20,13,.14) 1px, transparent 1px),
    linear-gradient(0deg, rgba(36,20,13,.11) 1px, transparent 1px);
  background-size: 64px 64px;
}
.local-map::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 3;
  pointer-events: none;
  box-shadow: inset 0 0 0 1px rgba(110,31,22,.18), inset 0 -80px 120px rgba(36,20,13,.11);
}
.local-map .tile {
  position: absolute;
  width: 256px;
  height: 256px;
  z-index: 1;
  max-width: none;
  user-select: none;
}
.local-map.has-tiles {
  background: #d7c5a6 !important;
}
.map-status {
  position: absolute;
  left: 50%;
  top: 50%;
  z-index: 4;
  transform: translate(-50%, -50%);
  width: min(78%, 430px);
  padding: 1.05rem 1.2rem;
  border-radius: 22px;
  text-align: center;
  color: #F4E8D2;
  background: linear-gradient(135deg, rgba(36,20,13,.86), rgba(110,31,22,.78));
  border: 1px solid rgba(201,154,74,.34);
  box-shadow: 0 18px 48px rgba(0,0,0,.28);
  backdrop-filter: blur(12px);
}
.map-status strong { display: block; font-weight: 900; margin-bottom: .25rem; }
.map-status span { color: #D8C2A3; font-size: .92rem; }
.local-map.has-tiles .map-status { display: none; }
.route-pin {
  z-index: 6;
  border-radius: 999px 999px 999px 10px;
  min-width: auto;
  min-height: auto;
  padding: .48rem .78rem;
  color: #F4E8D2;
  background: linear-gradient(135deg, #6E1F16, #B66A32);
  border: 1px solid rgba(244,232,210,.44);
  box-shadow: 0 12px 28px rgba(0,0,0,.28);
  font-size: .82rem;
  font-weight: 900;
}
.route-pin.start { background: linear-gradient(135deg, #4F6650, #2d3e30); }
.route-pin.destination { background: linear-gradient(135deg, #6E1F16, #B66A32); }
.route-overlay { z-index: 5; }
.route-overlay polyline { stroke: #6E1F16; stroke-width: 5; stroke-dasharray: 9 8; }
.map-fallback, .map-pin { display: none !important; }

@media (max-width: 980px) {
  .map-shell, .local-map { min-height: 360px; }
}

/* v7 Saraj polish: readable restaurant UI, tiled background and compact logo */
:root {
  --saraj-bg-dark: #24140D;
  --saraj-bg-deep: #160D09;
  --saraj-primary: #6E1F16;
  --saraj-primary-hover: #8A3E24;
  --saraj-copper: #B66A32;
  --saraj-gold: #C99A4A;
  --saraj-cream: #F4E8D2;
  --saraj-cream-muted: #E8D6B8;
  --saraj-text-dark: #1A0F0A;
  --saraj-text-light: #F4E8D2;
  --saraj-text-muted: #D8C2A3;
  --saraj-green: #4F6650;
  --saraj-border: rgba(201, 154, 74, 0.28);
}

html, body { min-height: 100%; }
body {
  font-family: "Saraj Roboto", ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif !important;
  color: var(--saraj-text-light) !important;
  background-color: var(--saraj-bg-dark) !important;
  background-image:
    radial-gradient(circle at 18% 10%, rgba(182,106,50,.22), transparent 28rem),
    radial-gradient(circle at 82% 4%, rgba(79,102,80,.18), transparent 24rem),
    linear-gradient(180deg, rgba(22,13,9,.70), rgba(22,13,9,.86)),
    url('/assets/photos/saraj-bg-seamless.webp') !important;
  background-size: auto, auto, auto, 768px 432px !important;
  background-repeat: no-repeat, no-repeat, repeat, repeat !important;
  background-attachment: fixed, fixed, fixed, fixed !important;
}
body::before {
  content: "";
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: -1;
  background:
    linear-gradient(90deg, rgba(244,232,210,.035) 1px, transparent 1px),
    linear-gradient(180deg, rgba(244,232,210,.025) 1px, transparent 1px);
  background-size: 48px 48px;
  opacity: .55;
}
body::after { display: none !important; }

.site-header {
  background: rgba(22, 13, 9, .80) !important;
  border-bottom: 1px solid rgba(201,154,74,.22) !important;
  backdrop-filter: blur(18px) saturate(1.2) !important;
}
.brand-logo {
  width: 58px;
  height: 58px;
  border-radius: 18px;
  display: grid;
  place-items: center;
  overflow: hidden;
  background: rgba(244,232,210,.06);
  border: 1px solid rgba(201,154,74,.38);
  box-shadow: 0 12px 28px rgba(0,0,0,.22);
  flex: 0 0 auto;
}
.brand-logo img { width: 94%; height: 94%; object-fit: contain; }
.brand strong { color: var(--saraj-text-light) !important; font-family: "Saraj Roboto", sans-serif !important; font-weight: 900 !important; letter-spacing: .04em !important; }
.brand small { color: var(--saraj-text-muted) !important; }
.main-nav { background: rgba(244,232,210,.08) !important; border-color: rgba(201,154,74,.22) !important; }
.main-nav a { color: var(--saraj-text-muted) !important; }
.main-nav a:hover, .main-nav a.active { color: var(--saraj-text-light) !important; background: linear-gradient(135deg, var(--saraj-primary), var(--saraj-primary-hover)) !important; }
.reserve-pill { background: linear-gradient(135deg, var(--saraj-primary), var(--saraj-copper)) !important; color: var(--saraj-text-light) !important; }

h1, h2, .page-hero.small h1, .story-card h2, .menu-card h2, .contact-card h2, .reservation-info h2, .opening-panel h2, .route-copy h2 {
  font-family: "Saraj Playwrite", Georgia, serif !important;
  font-weight: 400 !important;
  letter-spacing: -.04em !important;
}
.saraj-word { font-family: "Saraj Yuyu", "Saraj Playwrite", Georgia, serif !important; }
p, li, label, input, select, textarea, button, .main-nav a, .hint, .hours-list, .meta, .status-badge { font-family: "Saraj Roboto", sans-serif !important; }

.panel-soft, .story-card, .feature-card, .menu-card, .contact-card, .reservation-form, .reservation-info, .muted-panel, .route-panel, .admin-panel, .page-hero.small, .opening-panel {
  background:
    linear-gradient(145deg, rgba(244,232,210,.96), rgba(232,214,184,.90)),
    radial-gradient(circle at 100% 0, rgba(182,106,50,.10), transparent 16rem) !important;
  color: var(--saraj-text-dark) !important;
  border: 1px solid rgba(201,154,74,.34) !important;
  box-shadow: 0 24px 70px rgba(0,0,0,.28), inset 0 1px 0 rgba(255,255,255,.42) !important;
}
.panel-soft p, .story-card p, .feature-card p, .menu-card p, .contact-card p, .reservation-form p, .reservation-info p, .route-panel p, .page-hero.small p, .opening-panel p,
.panel-soft li, .reservation-info li { color: #5D493A !important; }
.eyebrow { color: var(--saraj-green) !important; letter-spacing: .20em !important; }
.btn.primary { background: linear-gradient(135deg, var(--saraj-primary), var(--saraj-primary-hover) 55%, var(--saraj-copper)) !important; color: var(--saraj-text-light) !important; }
.btn.secondary { background: rgba(244,232,210,.72) !important; color: var(--saraj-primary) !important; border: 1px solid rgba(110,31,22,.20) !important; }

.clean-hero { align-items: center !important; gap: clamp(1.5rem, 4vw, 4rem) !important; }
.hero-card.photo-card { border-radius: 34px !important; max-width: 460px; justify-self: end; background: rgba(244,232,210,.12) !important; }
.hero-card.photo-card img { border-radius: 24px; }
.site-footer { background: rgba(22,13,9,.78) !important; color: var(--saraj-text-muted) !important; border-top: 1px solid rgba(201,154,74,.20) !important; }

.hours-list strong { color: var(--saraj-text-dark) !important; text-align: right; }
.hours-list div { grid-template-columns: minmax(120px,.5fr) 1fr !important; gap: 1rem; }

.multi-day-row {
  grid-template-columns: minmax(96px, .7fr) minmax(130px,.8fr) repeat(4, minmax(112px,1fr)) !important;
  align-items: end;
}
.holiday-calendar { display: grid; gap: .75rem; }
.holiday-row {
  display: grid;
  grid-template-columns: minmax(190px, 1.2fr) minmax(130px,.7fr) repeat(4, minmax(100px,.75fr)) auto;
  gap: .65rem;
  align-items: end;
  padding: .9rem;
  border-radius: 18px;
  background: rgba(255,255,255,.52);
  border: 1px solid rgba(110,31,22,.12);
}
.holiday-row strong { display: block; }
.holiday-row span { display: block; color: #674f3e; font-size: .92rem; margin-top: .15rem; }
.holiday-row label { margin: 0; }
.holiday-row .checkline { align-self: center; }

.route-panel { overflow: hidden; }
.map-shell { position: relative; border-radius: 30px; overflow: hidden; border: 1px solid rgba(110,31,22,.20); background: var(--saraj-cream-muted); }
.local-map {
  position: relative;
  min-height: 470px;
  overflow: hidden;
  background:
    linear-gradient(135deg, rgba(79,102,80,.12), rgba(182,106,50,.16)),
    linear-gradient(90deg, rgba(36,20,13,.08) 1px, transparent 1px),
    linear-gradient(180deg, rgba(36,20,13,.06) 1px, transparent 1px),
    #E8D6B8 !important;
  background-size: auto, 64px 64px, 64px 64px, auto !important;
}
.local-map .tile { position: absolute; width: 256px; height: 256px; z-index: 1; }
.local-map.has-tiles { background: #d9d2bf !important; }
.route-pin {
  position: absolute;
  transform: translate(-50%, -100%);
  z-index: 6;
  border-radius: 16px 16px 16px 4px;
  padding: .45rem .62rem;
  color: var(--saraj-text-light);
  font-weight: 900;
  font-size: .84rem;
  box-shadow: 0 12px 28px rgba(0,0,0,.26);
  border: 2px solid rgba(244,232,210,.75);
}
.route-pin.destination { background: linear-gradient(135deg, var(--saraj-primary), var(--saraj-copper)); }
.route-pin.start { background: linear-gradient(135deg, var(--saraj-green), #314834); }
.map-status {
  position: absolute;
  inset: auto 1rem 1rem 1rem;
  z-index: 8;
  border-radius: 22px;
  padding: 1rem;
  background: rgba(244,232,210,.92);
  color: var(--saraj-text-dark);
  border: 1px solid rgba(110,31,22,.16);
  box-shadow: 0 16px 38px rgba(0,0,0,.18);
}
.map-status strong { display:block; margin-bottom:.2rem; }
.map-status span { color:#5D493A; }
.route-overlay { position: absolute; inset: 0; z-index: 5; pointer-events: none; }
.route-overlay polyline { fill: none; stroke: var(--saraj-primary); stroke-width: 5; stroke-linecap: round; stroke-linejoin: round; filter: drop-shadow(0 4px 4px rgba(0,0,0,.22)); }

@media (max-width: 980px) {
  .multi-day-row, .holiday-row { grid-template-columns: 1fr 1fr !important; }
  .holiday-row > div, .holiday-row button { grid-column: 1 / -1; }
  .brand-logo { width: 50px; height: 50px; }
}
@media (max-width: 680px) {
  body { background-size: auto, auto, auto, 640px 360px !important; }
  .main-nav { width: 100%; overflow-x: auto; justify-content: flex-start; }
  .reserve-pill { width: 100%; justify-content: center; }
  .multi-day-row, .holiday-row { grid-template-columns: 1fr !important; }
  .hours-list div { grid-template-columns: 1fr !important; }
  .hours-list strong { text-align: left; }
}

/* v8 Saraj updates: real address, compact logo/favicon, softer media frame and rounded footer */
body {
  background-color: var(--saraj-bg-dark) !important;
  background-image:
    radial-gradient(circle at 12% 0%, rgba(201,154,74,.20), transparent 24rem),
    radial-gradient(circle at 92% 10%, rgba(110,31,22,.18), transparent 28rem),
    linear-gradient(180deg, rgba(22,13,9,.72), rgba(22,13,9,.84)),
    url('/assets/photos/website-bg-tile.webp') !important;
  background-size: auto, auto, auto, 1024px 683px !important;
  background-repeat: no-repeat, no-repeat, repeat, repeat !important;
  background-attachment: fixed, fixed, fixed, fixed !important;
}
body::before {
  background:
    radial-gradient(circle at 50% 0%, rgba(244,232,210,.08), transparent 34rem),
    linear-gradient(90deg, rgba(244,232,210,.025) 1px, transparent 1px),
    linear-gradient(180deg, rgba(244,232,210,.018) 1px, transparent 1px) !important;
  background-size: auto, 56px 56px, 56px 56px !important;
  opacity: .42 !important;
}

.brand-logo {
  width: 54px !important;
  height: 54px !important;
  border-radius: 50% !important;
  background: rgba(244,232,210,.92) !important;
  border: 1px solid rgba(201,154,74,.55) !important;
  padding: 3px !important;
}
.brand-logo img { width: 100% !important; height: 100% !important; object-fit: contain !important; }
.admin-brand .brand-logo, .admin-header .brand-logo { width: 48px !important; height: 48px !important; }

.hero-card.photo-card {
  max-width: 420px !important;
  padding: .55rem !important;
  border-radius: 28px !important;
  background: linear-gradient(145deg, rgba(244,232,210,.18), rgba(201,154,74,.10)) !important;
  border: 1px solid rgba(201,154,74,.30) !important;
  box-shadow: 0 24px 62px rgba(0,0,0,.26) !important;
}
.hero-card.photo-card::before {
  display: none !important;
}
.hero-card.photo-card img {
  border-radius: 22px !important;
  height: clamp(320px, 44vw, 520px) !important;
  border: 1px solid rgba(244,232,210,.24);
}
.photo-caption {
  left: 1.1rem !important;
  right: 1.1rem !important;
  bottom: 1.1rem !important;
  border-radius: 18px !important;
  background: linear-gradient(90deg, rgba(36,20,13,.86), rgba(110,31,22,.76)) !important;
  border: 1px solid rgba(201,154,74,.36) !important;
  letter-spacing: .10em !important;
}

.site-footer {
  width: min(1160px, calc(100% - 2rem));
  margin: clamp(2rem, 5vw, 4rem) auto 1rem !important;
  border-radius: 34px 34px 0 0 !important;
  padding: clamp(1.4rem, 3vw, 2rem) clamp(1.2rem, 4vw, 2.8rem) !important;
  display: flex !important;
  justify-content: space-between !important;
  align-items: center !important;
  gap: 1.4rem !important;
  background:
    radial-gradient(circle at 15% 0%, rgba(182,106,50,.18), transparent 22rem),
    linear-gradient(145deg, rgba(22,13,9,.94), rgba(36,20,13,.90)) !important;
  border: 1px solid rgba(201,154,74,.24) !important;
  border-bottom: 0 !important;
  box-shadow: 0 -18px 60px rgba(0,0,0,.24), inset 0 1px 0 rgba(244,232,210,.08) !important;
}
.site-footer strong { color: var(--saraj-text-light) !important; }
.site-footer span { color: var(--saraj-text-muted) !important; }
.footer-links { display: flex; flex-wrap: wrap; justify-content: flex-end; gap: .7rem 1rem; }
.footer-links a { color: var(--saraj-text-muted) !important; text-decoration-thickness: 1px; text-underline-offset: 4px; }
.footer-links a:hover { color: var(--saraj-text-light) !important; }

.hours-list strong { white-space: normal; }
.route-panel .route-copy h2 { max-width: 520px; }
.map-status { max-width: 520px; }

@media (max-width: 760px) {
  .site-footer { align-items: flex-start !important; flex-direction: column !important; border-radius: 26px 26px 0 0 !important; }
  .footer-links { justify-content: flex-start; }
  .hero-card.photo-card { justify-self: stretch !important; max-width: none !important; }
}

/* v9 Saraj layout polish: sticky footer and unified hero card */
html, body { min-height: 100%; }
body {
  min-height: 100dvh !important;
  display: flex !important;
  flex-direction: column !important;
}
main {
  flex: 1 0 auto !important;
  display: block;
}
.site-footer {
  flex-shrink: 0 !important;
  margin-top: auto !important;
  margin-bottom: 0 !important;
  border-radius: 34px 34px 0 0 !important;
  position: relative;
  overflow: hidden;
}
.site-footer::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background:
    linear-gradient(90deg, rgba(201,154,74,.18), transparent 18%, transparent 82%, rgba(201,154,74,.12)),
    radial-gradient(circle at 20% 0%, rgba(182,106,50,.22), transparent 24rem);
  opacity: .72;
}
.site-footer > * { position: relative; z-index: 1; }

.hero.clean-hero.hero-unified {
  width: min(1180px, calc(100% - 2rem)) !important;
  min-height: auto !important;
  margin-top: clamp(1.4rem, 4vw, 4rem) !important;
  margin-bottom: clamp(2.2rem, 5vw, 4rem) !important;
  padding: clamp(1.1rem, 2.4vw, 1.8rem) !important;
  grid-template-columns: minmax(0, 1fr) minmax(280px, .72fr) !important;
  gap: clamp(1.2rem, 3vw, 2.4rem) !important;
  border-radius: clamp(30px, 4vw, 48px) !important;
  border: 1px solid rgba(201,154,74,.34) !important;
  background:
    radial-gradient(circle at 82% 12%, rgba(201,154,74,.18), transparent 18rem),
    radial-gradient(circle at 12% 88%, rgba(110,31,22,.10), transparent 22rem),
    linear-gradient(135deg, rgba(244,232,210,.96), rgba(232,214,184,.92)) !important;
  box-shadow: 0 34px 90px rgba(0,0,0,.30), inset 0 1px 0 rgba(255,255,255,.60) !important;
  overflow: hidden !important;
  position: relative !important;
}
.hero.clean-hero.hero-unified::before {
  content: "" !important;
  display: block !important;
  position: absolute !important;
  width: min(34vw, 330px) !important;
  height: min(42vw, 410px) !important;
  right: clamp(310px, 29vw, 450px) !important;
  top: 50% !important;
  transform: translateY(-50%) rotate(-7deg) !important;
  margin: 0 !important;
  background: url('/assets/bosnia-outline.svg') center/contain no-repeat !important;
  opacity: .105 !important;
  filter: sepia(.45) saturate(.7) !important;
  pointer-events: none !important;
}
.hero.clean-hero.hero-unified::after {
  content: "";
  position: absolute;
  inset: .75rem;
  border: 1px solid rgba(182,106,50,.18);
  border-radius: calc(clamp(30px, 4vw, 48px) - .75rem);
  pointer-events: none;
}
.hero-unified .hero-copy.panel-soft {
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  padding: clamp(1.2rem, 4vw, 3.2rem) !important;
  position: relative;
  z-index: 1;
}
.hero-unified .hero-copy h1 {
  max-width: 760px;
  color: var(--saraj-text-dark, #1A0F0A);
  text-shadow: none !important;
}
.hero-unified .hero-text {
  color: #5a4535 !important;
  font-size: clamp(1.05rem, 1.7vw, 1.25rem) !important;
  line-height: 1.75 !important;
}
.hero-unified .hero-card.photo-card {
  align-self: center !important;
  justify-self: center !important;
  max-width: 380px !important;
  width: 100% !important;
  padding: .45rem !important;
  border-radius: 28px !important;
  background: rgba(36,20,13,.06) !important;
  border: 1px solid rgba(182,106,50,.28) !important;
  box-shadow: 0 18px 45px rgba(36,20,13,.20) !important;
  position: relative;
  z-index: 1;
}
.hero-unified .hero-card.photo-card img {
  height: clamp(280px, 35vw, 440px) !important;
  border-radius: 22px !important;
  object-fit: cover !important;
  object-position: center !important;
  border: 1px solid rgba(244,232,210,.42) !important;
}
.hero-unified .photo-caption {
  left: .9rem !important;
  right: .9rem !important;
  bottom: .9rem !important;
  padding: .72rem 1rem !important;
  border-radius: 999px !important;
  font-size: .72rem !important;
}

@media (max-width: 920px) {
  .hero.clean-hero.hero-unified {
    grid-template-columns: 1fr !important;
    padding: 1rem !important;
  }
  .hero.clean-hero.hero-unified::before {
    right: -4rem !important;
    top: 6rem !important;
    transform: rotate(-8deg) !important;
    width: 260px !important;
    height: 320px !important;
  }
  .hero-unified .hero-copy.panel-soft { padding: clamp(1.2rem, 5vw, 2rem) !important; }
  .hero-unified .hero-card.photo-card { max-width: 520px !important; }
}
@media (max-width: 620px) {
  .hero.clean-hero.hero-unified { width: min(100% - 1rem, 1180px) !important; border-radius: 28px !important; }
  .hero.clean-hero.hero-unified::after { inset: .45rem; border-radius: 22px; }
  .hero-unified .hero-card.photo-card img { height: 330px !important; }
  .site-footer { width: min(100% - 1rem, 1160px) !important; border-radius: 24px 24px 0 0 !important; }
}
