:root {
  --bg: #f5f7f9;
  --surface: #ffffff;
  --ink: #173247;
  --muted: #5b6b77;
  --line: rgba(23, 50, 71, 0.10);
  --accent: #2d6f95;
  --accent-dark: #204f6a;
  --accent-soft: #eaf2f7;
  --shadow: 0 18px 42px rgba(23, 50, 71, 0.08);
  --radius: 22px;
  --max: 1160px;
}
* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: Inter, ui-sans-serif, system-ui, sans-serif;
  color: var(--ink);
  background: linear-gradient(180deg, #f9fbfc 0%, #f3f6f8 100%);
  line-height: 1.6;
}
a { color: inherit; text-decoration: none; }
img { max-width: 100%; display: block; }
.container { width: min(calc(100% - 2rem), var(--max)); margin: 0 auto; }
.narrow { max-width: 820px; }
.topbar { background: #16354b; color: #fff; font-size: 0.92rem; }
.topbar .container {
  padding: 0.72rem 0;
  display: flex;
  justify-content: space-between;
  gap: 1rem;
  flex-wrap: wrap;
}
.topbar a { color: #fff; }
.topbar-split { align-items: center; }
.header {
  position: sticky;
  top: 0;
  z-index: 20;
  background: rgba(255,255,255,0.9);
  backdrop-filter: blur(16px);
  border-bottom: 1px solid var(--line);
}
.nav {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding: 1rem 0;
  flex-wrap: wrap;
}
.brand {
  display: flex;
  gap: 0.9rem;
  align-items: center;
}
.brand-mark {
  width: 54px;
  height: 54px;
  border-radius: 18px;
  background: linear-gradient(135deg, #2d6f95 0%, #56a8c4 100%);
  color: #fff;
  display: grid;
  place-items: center;
  font-weight: 800;
  letter-spacing: 0.02em;
  box-shadow: var(--shadow);
}
.brand-copy strong { display: block; font-size: 1rem; }
.brand-copy span { display: block; color: var(--muted); font-size: 0.88rem; }
.links {
  display: flex;
  gap: 1rem;
  align-items: center;
  flex-wrap: wrap;
}
.links a { font-weight: 700; color: var(--muted); }
.links a:hover, .links a.active { color: var(--ink); }
.button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.95rem 1.35rem;
  border-radius: 999px;
  font-weight: 800;
  transition: 0.18s ease;
}
.button:hover { transform: translateY(-1px); }
.button.primary {
  background: var(--accent);
  color: #fff;
  box-shadow: 0 12px 26px rgba(45,111,149,0.24);
}
.button.primary:hover { background: var(--accent-dark); }
.button.secondary { background: var(--accent-soft); color: var(--ink); }
.hero { padding: 4.9rem 0 3.4rem; }
.hero-grid {
  display: grid;
  grid-template-columns: 1.02fr 0.98fr;
  gap: 1.4rem;
  align-items: stretch;
}
.eyebrow {
  display: inline-flex;
  padding: 0.48rem 0.82rem;
  border-radius: 999px;
  background: var(--accent-soft);
  color: var(--accent-dark);
  font-size: 0.86rem;
  font-weight: 800;
}
.eyebrow-invert {
  background: rgba(255,255,255,0.14);
  color: #fff;
}
h1 {
  font-size: clamp(2.55rem, 5vw, 4.35rem);
  line-height: 1.02;
  letter-spacing: -0.04em;
  margin: 1rem 0;
}
.lead {
  font-size: 1.08rem;
  color: var(--muted);
  max-width: 62ch;
}
.cta-row {
  display: flex;
  gap: 0.85rem;
  flex-wrap: wrap;
  margin-top: 1.35rem;
}
.panel, .card, .property, .band, .logo-card, .photo-panel {
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
}
.logo-card {
  padding: 1.5rem;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  min-height: 100%;
}
.mock-logo {
  display: inline-flex;
  align-items: center;
  gap: 0.85rem;
  margin-bottom: 1.15rem;
}
.mock-logo-mark {
  width: 70px;
  height: 70px;
  border-radius: 22px;
  background: linear-gradient(135deg, #173247 0%, #2d6f95 55%, #67b2ca 100%);
  color: #fff;
  display: grid;
  place-items: center;
  font-size: 1.15rem;
  font-weight: 800;
  box-shadow: var(--shadow);
}
.mock-logo-copy strong {
  display: block;
  font-size: 1.35rem;
  letter-spacing: -0.02em;
}
.mock-logo-copy span {
  display: block;
  color: var(--muted);
  font-size: 0.92rem;
}
.platform-row {
  display: flex;
  gap: 0.65rem;
  flex-wrap: wrap;
  margin: 1rem 0 1.15rem;
}
.platform-badge {
  padding: 0.55rem 0.85rem;
  border-radius: 999px;
  border: 1px solid var(--line);
  background: #fff;
  color: var(--ink);
  font-weight: 800;
  font-size: 0.84rem;
}
.small-note {
  color: var(--muted);
  font-size: 0.95rem;
}
.photo-panel {
  overflow: hidden;
  min-height: 100%;
  display: flex;
}
.hero-photo {
  min-height: 100%;
  width: 100%;
  background-image: linear-gradient(180deg, rgba(23,50,71,0.08), rgba(23,50,71,0.34)), url('https://sspark.genspark.ai/cfimages?u1=n%2By0RPX4nEWktY%2FnM5DEBNkBeVEOUmIOAOFbWInqnZvGo93V%2Fb8W8ucGVYsBUTTbnOyRyPQyIdndfjuFAjJ%2FZtlgt35uT0buxnpo&u2=B%2BYOyy2412GDJssL&width=2560');
  background-size: cover;
  background-position: center;
  display: flex;
  align-items: end;
  flex: 1;
}
.hero-photo-copy {
  width: 100%;
  padding: 1.25rem;
  color: #fff;
}
.hero-photo-copy strong {
  display: block;
  font-size: 1.05rem;
  margin-bottom: 0.35rem;
}
.section { padding: 3.7rem 0; }
.section-tight-top { padding-top: 1rem; }
.section-title { margin-bottom: 1.45rem; }
.compact-title { margin-bottom: 0.75rem; }
.section-title h2 {
  margin: 0.5rem 0;
  font-size: clamp(2rem, 3vw, 3rem);
  line-height: 1.08;
  letter-spacing: -0.03em;
}
.section-title p { margin: 0; color: var(--muted); max-width: 62ch; }
.grid-2, .grid-3, .footer-grid, .property-layout, .mini-gallery, .faq-grid, .band-grid {
  display: grid;
  gap: 1.2rem;
}
.grid-2 { grid-template-columns: repeat(2, 1fr); }
.grid-3 { grid-template-columns: repeat(3, 1fr); }
.footer-grid { grid-template-columns: 1.2fr 0.8fr 0.9fr; }
.footer-grid-home { align-items: start; }
.faq-grid { grid-template-columns: repeat(3, 1fr); }
.band-grid { grid-template-columns: 1.1fr 0.9fr; align-items: start; }
.card { padding: 1.25rem; }
.card h3, .property h3 { margin: 0.2rem 0 0.4rem; font-size: 1.2rem; }
.card p, .property p, .meta, .footer p, .footer li { color: var(--muted); }
.faq-card p { max-width: none; }
.meta-row {
  display: flex;
  gap: 0.55rem;
  flex-wrap: wrap;
  margin: 0.85rem 0 1rem;
}
.meta-row span {
  background: var(--accent-soft);
  padding: 0.42rem 0.72rem;
  border-radius: 999px;
  font-size: 0.82rem;
  font-weight: 800;
  color: var(--accent-dark);
}
.band {
  padding: 1.5rem;
  background: linear-gradient(135deg, #173247 0%, #245271 100%);
  color: #fff;
}
.band p, .band li { color: rgba(255,255,255,0.86); }
.check-list {
  display: grid;
  gap: 0.8rem;
}
.check-list div {
  padding: 0.9rem 1rem;
  border-radius: 16px;
  background: rgba(255,255,255,0.08);
  border: 1px solid rgba(255,255,255,0.14);
}
.page-hero { padding: 4.1rem 0 2rem; }
.page-hero h1 { font-size: clamp(2.25rem, 4vw, 3.85rem); }
.page-hero-centered { text-align: center; }
.page-hero-centered .lead { margin-left: auto; margin-right: auto; }
.property-layout {
  grid-template-columns: 1.05fr 0.95fr;
  align-items: start;
  margin-bottom: 2rem;
}
.mini-gallery { grid-template-columns: repeat(2, 1fr); }
.mini-gallery img {
  aspect-ratio: 4/3;
  object-fit: cover;
  border-radius: 16px;
  border: 1px solid var(--line);
}
.contact-stack {
  display: grid;
  gap: 0.8rem;
  font-weight: 700;
}
.contact-stack a {
  color: #fff;
  text-decoration: none;
}
.footer {
  padding: 2.6rem 0;
  background: #fff;
  border-top: 1px solid var(--line);
}
.footer ul { list-style: none; padding: 0; margin: 0; display: grid; gap: 0.45rem; }
.footer-copy { margin-top: 0.9rem; }
.footer-bottom {
  margin-top: 1.6rem;
  padding-top: 1rem;
  border-top: 1px solid var(--line);
  display: flex;
  justify-content: space-between;
  gap: 1rem;
  flex-wrap: wrap;
  color: var(--muted);
}
.note {
  padding: 0.95rem 1rem;
  border-radius: 16px;
  background: #f2f7fa;
  border: 1px solid var(--line);
  color: var(--muted);
}
@media (max-width: 940px) {
  .hero-grid, .grid-2, .grid-3, .footer-grid, .property-layout, .mini-gallery, .faq-grid, .band-grid { grid-template-columns: 1fr; }
  .hero-photo { min-height: 340px; }
  .photo-panel { min-height: auto; }
}
@media (max-width: 640px) {
  h1 { font-size: 2.3rem; }
  .button { width: 100%; }
  .topbar .container, .nav { justify-content: center; }
  .brand { justify-content: center; text-align: center; }
  .links { justify-content: center; }
}