@import url("https://fonts.googleapis.com/css2?family=Manrope:wght@400;500;600;700;800&family=Playfair+Display:wght@600;700&display=swap");

:root {
  --bg: #080a0f;
  --bg-elev: #11151d;
  --panel: rgba(19, 24, 34, 0.78);
  --panel-strong: rgba(14, 18, 26, 0.94);
  --line: rgba(197, 167, 107, 0.24);
  --line-soft: rgba(255, 255, 255, 0.1);
  --text: #f3f0ea;
  --muted: #b4ac9f;
  --gold: #c5a76b;
  --gold-soft: #d8be8b;
  --ivory: #e7dece;
  --danger: #ff9090;
  --radius: 20px;
  --radius-sm: 14px;
  --shadow: 0 24px 70px rgba(0, 0, 0, 0.55);
  --container: min(1240px, 92vw);
}
*,
*::before,
*::after { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: "Manrope", "Segoe UI", "Arial", sans-serif;
  color: var(--text);
  line-height: 1.65;
  background:
    radial-gradient(1300px 700px at 90% -10%, rgba(197, 167, 107, 0.16), transparent 62%),
    radial-gradient(900px 540px at -10% 120%, rgba(110, 125, 148, 0.1), transparent 58%),
    linear-gradient(140deg, #07090d, #0d1119 45%, #0a0e14);
}
img { max-width: 100%; display: block; }
a { color: inherit; text-decoration: none; }
.skip-link { position:absolute; left:-999px; top:0; background:#fff; color:#000; padding:10px; z-index:9999; }
.skip-link:focus { left: 10px; }
.bg-grid {
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: -1;
  opacity: 0.26;
  background-image:
    linear-gradient(var(--line) 1px, transparent 1px),
    linear-gradient(90deg, var(--line) 1px, transparent 1px);
  background-size: 62px 62px;
  mask-image: radial-gradient(circle at center, #000 18%, transparent 82%);
}
.container { width: var(--container); margin: 0 auto; }
.site-header {
  position: sticky;
  top: 0;
  z-index: 70;
  backdrop-filter: blur(12px);
  transition: 0.35s ease;
  border-bottom: 1px solid transparent;
}
.site-header.scrolled {
  background: rgba(8, 10, 14, 0.9);
  border-bottom-color: var(--line);
}
.header-shell {
  width: var(--container);
  margin: 0 auto;
  display: grid;
  grid-template-columns: auto 1fr auto;
  gap: 20px;
  align-items: center;
  padding: 18px 0;
}
.brand-mark { display:flex; align-items:center; gap:12px; }
.brand-dot {
  width: 34px;
  height: 34px;
  border-radius: 10px;
  border: 1px solid var(--gold);
  box-shadow: inset 0 0 0 1px rgba(197, 167, 107, 0.35), 0 0 18px rgba(197, 167, 107, 0.18);
  position: relative;
  background: radial-gradient(circle at 35% 25%, rgba(255, 255, 255, 0.22), transparent 38%);
}
.brand-dot::before,.brand-dot::after { content:""; position:absolute; border-radius:50%; background:var(--gold); }
.brand-dot::before { width:7px; height:7px; top:8px; left:8px; }
.brand-dot::after { width:11px; height:11px; right:5px; bottom:5px; background:var(--gold-soft); }
.brand-text { font-weight: 800; letter-spacing: 0.045em; }
.nav-track { display:flex; justify-content:center; gap:10px; flex-wrap:wrap; }
.nav-track a {
  padding: 8px 13px;
  font-size: 0.92rem;
  border: 1px solid transparent;
  border-radius: 999px;
  color: var(--muted);
  transition: 0.24s;
}
.nav-track a:hover,.nav-track a:focus-visible,.nav-track a.active {
  color: var(--ivory);
  border-color: var(--line);
  background: rgba(197, 167, 107, 0.1);
  outline: none;
}
.menu-toggle {
  display:none;
  border:1px solid var(--line);
  background: rgba(197, 167, 107, 0.1);
  color: var(--text);
  border-radius:12px;
  width:42px;
  height:42px;
  cursor:pointer;
}
.mobile-nav { display:none; }
.mobile-nav.open { display:block; position:fixed; inset:72px 12px auto 12px; background:var(--panel-strong); border:1px solid var(--line); border-radius:14px; box-shadow:var(--shadow); z-index:68; }
.mobile-nav a { display:block; padding:12px 14px; border-bottom:1px solid rgba(255,255,255,.08); color:var(--muted); }
.mobile-nav a:last-child { border-bottom:0; }
.mobile-nav a.active { color:var(--text); background: rgba(197, 167, 107, 0.1); }
main { padding-bottom:56px; }
.hero { width:var(--container); margin:32px auto 34px; display:grid; grid-template-columns:1.15fr .85fr; gap:26px; }
.hero-panel {
  background: linear-gradient(155deg, rgba(28, 34, 48, 0.8), rgba(16, 20, 29, 0.86));
  border: 1px solid var(--line);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  padding: 38px;
  position: relative;
  overflow: hidden;
}
.hero-panel::after {
  content:"";
  position:absolute;
  right:-120px;
  top:-140px;
  width:330px;
  height:330px;
  border-radius:50%;
  background: radial-gradient(circle, rgba(197, 167, 107, 0.3), transparent 70%);
}
.label {
  display:inline-flex;
  border:1px solid var(--line);
  color: var(--gold-soft);
  border-radius:999px;
  padding:5px 12px;
  font-size:.82rem;
  margin-bottom:12px;
}
h1,h2,h3 { line-height:1.2; margin:0 0 12px; }
h1 {
  font-family: "Playfair Display", "Times New Roman", serif;
  font-size: clamp(2.1rem, 4vw, 3.35rem);
  letter-spacing: 0.01em;
}
h2 {
  font-family: "Playfair Display", "Times New Roman", serif;
  font-size: clamp(1.6rem, 2.4vw, 2.3rem);
  letter-spacing: 0.01em;
}
h3 { font-size:1.16rem; color: #f1e6d1; }
p { margin:0 0 12px; color:var(--muted); }
.hero-image,.image-card img {
  border-radius:var(--radius);
  border:1px solid var(--line-soft);
  min-height:100%;
  object-fit:cover;
  filter: saturate(0.9) contrast(1.04);
}
.section {
  width: var(--container);
  margin: 18px auto;
  padding: 30px;
  background: linear-gradient(155deg, rgba(20, 24, 34, 0.78), rgba(14, 18, 26, 0.86));
  border: 1px solid var(--line-soft);
  border-radius: var(--radius);
  position: relative;
  box-shadow: 0 10px 40px rgba(0, 0, 0, 0.28);
}
.section.route::before {
  content:"";
  position:absolute;
  left:24px;
  top:0;
  width:1px;
  height:100%;
  background: linear-gradient(transparent, var(--gold), transparent);
  opacity:.4;
}
.grid-2,.grid-3 { display:grid; gap:18px; }
.grid-2 { grid-template-columns:repeat(2,minmax(0,1fr)); }
.grid-3 { grid-template-columns:repeat(3,minmax(0,1fr)); }
.card {
  background: linear-gradient(165deg, rgba(18, 23, 33, 0.92), rgba(12, 16, 24, 0.92));
  border: 1px solid rgba(255, 255, 255, 0.1);
  border-radius: var(--radius-sm);
  padding: 18px;
  transition: transform 0.25s ease, border-color 0.25s ease, box-shadow 0.25s ease;
}
.card:hover,.card:focus-within {
  transform: translateY(-5px);
  border-color: rgba(197, 167, 107, 0.42);
  box-shadow: 0 14px 30px rgba(0, 0, 0, 0.36);
}
.route-list { list-style:none; margin:0; padding:0; display:grid; gap:10px; }
.route-list li { display:flex; gap:10px; align-items:flex-start; }
.route-list li::before { content:""; width:9px; height:9px; margin-top:8px; border-radius:50%; background: linear-gradient(45deg,var(--gold),var(--gold-soft)); flex:0 0 9px; }
.breadcrumbs { width:var(--container); margin:18px auto 0; color:var(--muted); font-size:.9rem; }
.breadcrumbs a { color: var(--gold-soft); }
.related-nav { display:flex; gap:12px; flex-wrap:wrap; }
.btn {
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  border:1px solid var(--line);
  border-radius:12px;
  padding:11px 16px;
  color: var(--ivory);
  background: linear-gradient(135deg, rgba(197, 167, 107, 0.2), rgba(197, 167, 107, 0.08));
  transition:.22s;
}
.btn:hover,.btn:focus-visible {
  background: linear-gradient(135deg, rgba(197, 167, 107, 0.3), rgba(197, 167, 107, 0.12));
  transform:translateY(-1px);
  outline:none;
}
.btn.secondary {
  border-color: rgba(255, 255, 255, 0.2);
  background: rgba(255, 255, 255, 0.06);
}
.img-split { display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.image-card { overflow:hidden; border-radius:14px; }
.accordion { display:grid; gap:10px; }
.accordion-item { border:1px solid rgba(255,255,255,.16); border-radius:12px; overflow:hidden; background: rgba(15,22,33,.78); }
.accordion-trigger { width:100%; text-align:left; border:0; background:transparent; color:var(--text); padding:14px 16px; font-size:1rem; cursor:pointer; }
.accordion-trigger:focus-visible { outline:2px solid var(--gold); outline-offset:-2px; }
.accordion-content { max-height:0; overflow:hidden; transition:max-height .3s ease; }
.accordion-content p { padding:0 16px 14px; margin:0; }
form { display:grid; gap:12px; }
label { display:grid; gap:6px; color:var(--silver); }
input,textarea,select {
  width:100%;
  padding:11px 12px;
  border-radius:10px;
  border:1px solid rgba(255,255,255,.2);
  background: rgba(8, 12, 18, 0.8);
  color:var(--text);
}
input:focus-visible,textarea:focus-visible,select:focus-visible { outline:2px solid var(--gold); border-color:transparent; }
textarea { min-height:130px; resize:vertical; }
.consent-row { display:flex; gap:10px; align-items:flex-start; font-size:.92rem; color:var(--muted); }
.form-error { color:var(--danger); min-height:20px; }
.map-wrap,.mini-map { border-radius:14px; overflow:hidden; border:1px solid rgba(197, 167, 107, 0.36); }
.map-wrap iframe,.mini-map iframe { width:100%; border:0; }
.map-wrap iframe { min-height:360px; }
.site-footer {
  border-top:1px solid var(--line);
  background: linear-gradient(175deg, rgba(7, 9, 13, 0.97), rgba(10, 12, 18, 0.97));
  padding:34px 0 28px;
}
.footer-grid { width:var(--container); margin:0 auto; display:grid; grid-template-columns:1.2fr 1fr 1fr 1fr; gap:18px; }
.footer-col {
  background: rgba(17, 21, 31, 0.72);
  border:1px solid rgba(255,255,255,.12);
  border-radius:14px;
  padding:16px;
}
.footer-col h3 { margin-bottom:10px; font-size:1rem; }
.footer-col a { display:inline-block; margin:4px 0; color:var(--muted); }
.footer-col a:hover,.footer-col a:focus-visible { color:var(--gold-soft); outline:none; }
.copyright { width:var(--container); margin:12px auto 0; color:var(--muted); font-size:.88rem; }
.cookie-banner {
  position:fixed; left:16px; right:16px; bottom:16px; z-index:90; padding:14px; border-radius:14px; border:1px solid rgba(197, 167, 107, 0.42);
  background: rgba(10,14,20,.96); display:none; grid-template-columns:1fr auto; gap:12px; align-items:center;
}
.cookie-banner.show { display:grid; }
.cookie-banner p { margin:0; font-size:.92rem; }
.reveal { opacity:0; transform: translateY(24px); transition:.65s ease; }
.reveal.show { opacity:1; transform: translateY(0); }
@media (max-width:1024px) {
  .hero { grid-template-columns:1fr; }
  .grid-3 { grid-template-columns:1fr 1fr; }
  .footer-grid { grid-template-columns:1fr 1fr; }
}
@media (max-width:780px) {
  .header-shell { grid-template-columns:auto auto; }
  .nav-track { display:none; }
  .menu-toggle { display:inline-flex; margin-left:auto; }
  .grid-2,.grid-3,.img-split,.footer-grid,.cookie-banner { grid-template-columns:1fr; }
  .section,.hero-panel { padding:20px; }
}
