*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

:root {
  --radius: 0.5rem;
  --font-sans: 'Geist', ui-sans-serif, system-ui, sans-serif;
  --background:           oklch(1 0 0);
  --foreground:           oklch(0.141 0.005 285.8);
  --card:                 oklch(1 0 0);
  --card-foreground:      oklch(0.141 0.005 285.8);
  --border:               oklch(0.929 0.013 255.5);
  --input:                oklch(0.929 0.013 255.5);
  --primary:              oklch(0.546 0.245 262.9);
  --primary-foreground:   oklch(0.985 0.002 247.8);
  --secondary:            oklch(0.968 0.007 247.9);
  --secondary-foreground: oklch(0.208 0.042 265.8);
  --muted:                oklch(0.968 0.007 247.9);
  --muted-foreground:     oklch(0.554 0.046 257.4);
  --accent:               oklch(0.968 0.007 247.9);
  --destructive:          oklch(0.577 0.245 27.3);
  --ring:                 oklch(0.546 0.245 262.9);
}

html, body { height: 100%; font-family: var(--font-sans); background: #c8d5b5; }

/* ── Centred glass-card layout (index + 404) ── */
.root {
  position: relative;
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 1.25rem 1rem;
  overflow: hidden;
}

.map-iframe {
  position: absolute;
  inset: -2rem;
  width: calc(100% + 4rem);
  height: calc(100% + 4rem);
  border: 0;
  filter: blur(2px) saturate(0.8) brightness(0.95);
  pointer-events: none;
}

.map-overlay {
  position: absolute;
  inset: 0;
  background: oklch(0.06 0.025 255 / 0.52);
}

/* Base glass panel — pages override padding and text-align */
.panel {
  position: relative;
  z-index: 1;
  width: 100%;
  max-width: 22rem;
  background: oklch(0.985 0.002 250 / 0.88);
  backdrop-filter: blur(20px) saturate(1.6);
  -webkit-backdrop-filter: blur(20px) saturate(1.6);
  border: 1px solid oklch(1 0 0 / 0.35);
  border-radius: calc(var(--radius) * 2.5);
  box-shadow: 0 24px 48px -12px oklch(0 0 0 / 0.4);
}

/* Base logo — pages override margin and alignment */
.logo-row {
  display: flex;
  align-items: center;
  gap: 0.5rem;
}
.logo-icon {
  width: 1.875rem;
  height: 1.875rem;
  background: var(--primary);
  border-radius: calc(var(--radius) * 0.8);
  display: flex;
  align-items: center;
  justify-content: center;
}
.logo-text {
  font-size: 0.9375rem;
  font-weight: 700;
  letter-spacing: -0.02em;
  color: var(--foreground);
}

.heading {
  font-size: 1.25rem;
  font-weight: 700;
  letter-spacing: -0.03em;
  line-height: 1.25;
  color: var(--foreground);
  margin-bottom: 0.375rem;
}
.subheading {
  font-size: 0.8rem;
  color: var(--muted-foreground);
  line-height: 1.55;
  margin-bottom: 1.375rem;
}
