/* ================================================================
   BMK — Billund Motorflyveklub
   Modern utilitarian / aeronautical aesthetic
   ================================================================ */

:root {
  /* Accent — default "runway blue". Overridable via Tweaks. */
  --accent: #1668e3;
  --accent-ink: #ffffff;
  --accent-tint: color-mix(in oklch, var(--accent) 8%, white);

  /* Neutrals — cool, slightly blue-leaning */
  --ink:        #0b1220;
  --ink-2:      #1a2436;
  --ink-3:      #3a4558;
  --ink-4:      #6b7584;
  --ink-5:      #9aa3b2;
  --rule:       #dbe0e8;
  --rule-2:     #eceff4;
  --panel:      #f5f7fa;
  --panel-2:    #fafbfd;
  --bg:         #ffffff;
  --warn:       #c2410c;

  /* Plane colors — harmonious palette, equal chroma */
  --p-bvn: oklch(0.62 0.14 255); /* blue    */
  --p-azh: oklch(0.62 0.14 155); /* green   */
  --p-gaa: oklch(0.62 0.14 85);  /* amber   */
  --p-drg: oklch(0.62 0.14 25);  /* red     */
  --p-est: oklch(0.62 0.14 315); /* magenta */
  --p-cfz: oklch(0.62 0.14 215); /* teal    */
  --p-bbc: oklch(0.62 0.14 290); /* violet  */
  --p-activity: #1668e3; /* blue — club activities */
  --p-flyin:    oklch(0.52 0.18 160); /* teal-green — fly-ins */

  /* Type scale */
  --f-display: 'Inter', ui-sans-serif, system-ui, sans-serif;
  --f-body:    'Inter', ui-sans-serif, system-ui, sans-serif;
  --f-mono:    'IBM Plex Mono', ui-monospace, 'SF Mono', Menlo, monospace;

  --radius: 2px;
}

* { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; text-size-adjust: 100%; }
html, body { margin: 0; padding: 0; overflow-x: hidden; }
body {
  font-family: var(--f-body);
  font-size: 15px;
  line-height: 1.5;
  color: var(--ink);
  background: var(--bg);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

a { color: inherit; text-decoration: none; }
button { font-family: inherit; cursor: pointer; }

/* --------- Utility ----------- */
.mono { font-family: var(--f-mono); font-feature-settings: "tnum" 1, "zero" 1; }
.tick { color: var(--ink-4); font-family: var(--f-mono); font-size: 11px; letter-spacing: 0.08em; text-transform: uppercase; }
.kicker { font-family: var(--f-mono); font-size: 11px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--ink-4); }
.rule { border: 0; border-top: 1px solid var(--rule); margin: 0; }

/* --------- Layout ----------- */
.app {
  min-height: 100vh;
  display: flex;
  flex-direction: column;
}
.container {
  max-width: 1400px;
  margin: 0 auto;
  padding: 0 32px;
  width: 100%;
}

/* --------- Top Nav ----------- */
.nav {
  position: sticky;
  top: 0;
  z-index: 50;
  background: rgba(255,255,255,0.92);
  backdrop-filter: blur(8px);
  border-bottom: 1px solid var(--rule);
}
.nav-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: 64px;
  gap: 24px;
}
.nav-logo {
  display: flex;
  align-items: center;
  gap: 10px;
  font-weight: 700;
  font-size: 13px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}
.nav-logo svg { flex-shrink: 0; }
.nav-logo .sub {
  display: block;
  font-weight: 400;
  color: var(--ink-4);
  font-size: 10px;
  letter-spacing: 0.14em;
}
.nav-links {
  display: flex;
  gap: 4px;
  font-family: var(--f-mono);
  font-size: 12px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}
.nav-link {
  padding: 8px 12px;
  color: var(--ink-3);
  border-radius: var(--radius);
  position: relative;
  transition: color .12s;
}
.nav-link:hover { color: var(--ink); }
.nav-link.active { color: var(--ink); }
.nav-link.active::after {
  content: '';
  position: absolute;
  left: 12px; right: 12px; bottom: 2px;
  height: 2px;
  background: var(--accent);
}
.nav-right {
  display: flex;
  align-items: center;
  gap: 12px;
}
.nav-meta {
  font-family: var(--f-mono);
  font-size: 11px;
  color: var(--ink-4);
  letter-spacing: 0.06em;
  display: flex;
  gap: 16px;
  align-items: center;
}
.nav-meta .dot {
  width: 6px; height: 6px; border-radius: 50%;
  background: #16a34a;
  display: inline-block;
  margin-right: 6px;
  vertical-align: 1px;
}

/* --------- Buttons ----------- */
.btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  height: 36px;
  padding: 0 16px;
  white-space: nowrap;
  border: 1px solid var(--ink);
  background: var(--ink);
  color: #fff;
  font-family: var(--f-mono);
  font-size: 12px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  border-radius: var(--radius);
  transition: background .12s, color .12s, border-color .12s;
}
.btn:hover { background: var(--ink-2); }
.btn.primary {
  background: var(--accent);
  border-color: var(--accent);
  color: var(--accent-ink);
}
.btn.primary:hover { filter: brightness(.94); }
.btn.ghost {
  background: transparent;
  color: var(--ink);
  border-color: var(--rule);
}
.btn.ghost:hover { border-color: var(--ink); }
.btn.sm { height: 28px; padding: 0 10px; font-size: 11px; }
.btn.lg { height: 44px; padding: 0 20px; font-size: 13px; }

/* --------- Tag / Badge ----------- */
.tag {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 2px 8px;
  font-family: var(--f-mono);
  font-size: 10.5px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  border: 1px solid var(--rule);
  border-radius: 2px;
  color: var(--ink-3);
  background: #fff;
}
.tag.solid { background: var(--ink); border-color: var(--ink); color: #fff; }
.tag.accent { background: var(--accent); border-color: var(--accent); color: var(--accent-ink); }
.tag.warn { color: var(--warn); border-color: color-mix(in oklch, var(--warn) 30%, white); background: color-mix(in oklch, var(--warn) 8%, white); }

/* --------- Footer ----------- */
.footer {
  margin-top: auto;
  padding: 48px 0 32px;
  border-top: 1px solid var(--rule);
  background: var(--panel-2);
  color: var(--ink-4);
  font-size: 13px;
}
.footer-grid {
  display: grid;
  grid-template-columns: 2fr 1fr 1fr 1fr;
  gap: 48px;
  margin-bottom: 32px;
}
.footer h5 {
  margin: 0 0 12px;
  font-family: var(--f-mono);
  font-size: 11px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--ink-2);
}
.footer ul { list-style: none; padding: 0; margin: 0; }
.footer ul li { padding: 3px 0; }
.footer ul a:hover { color: var(--ink); }
.footer-bottom {
  display: flex;
  justify-content: space-between;
  padding-top: 20px;
  border-top: 1px solid var(--rule);
  font-family: var(--f-mono);
  font-size: 11px;
  letter-spacing: 0.06em;
}

/* ================================================================
   HOMEPAGE
   ================================================================ */

/* Hero */
.hero {
  position: relative;
  border-bottom: 1px solid var(--rule);
  overflow: hidden;
}
.hero-inner {
  display: grid;
  grid-template-columns: 1.1fr 1fr;
  gap: 0;
  min-height: 640px;
}
.hero-left {
  padding: 56px 56px 48px;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  gap: 40px;
  border-right: 1px solid var(--rule);
  background: #fff;
}
.hero-kicker {
  display: flex;
  gap: 24px;
  flex-wrap: wrap;
  align-items: center;
  font-family: var(--f-mono);
  font-size: 11px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--ink-4);
}
.hero-kicker .coord { color: var(--ink-2); }
.hero h1 {
  margin: 32px 0 24px;
  font-size: clamp(44px, 5.5vw, 84px);
  font-weight: 700;
  line-height: 0.96;
  letter-spacing: -0.035em;
  text-wrap: balance;
}
.hero h1 em {
  font-style: normal;
  color: var(--accent);
}
.hero-lead {
  font-size: 17px;
  line-height: 1.55;
  color: var(--ink-3);
  max-width: 52ch;
  margin: 0 0 32px;
}
.hero-cta {
  display: flex;
  gap: 12px;
  margin-bottom: 32px;
}
.hero-stats {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  border-top: 1px solid var(--rule);
  padding-top: 24px;
  gap: 12px;
}
.hero-stat .num {
  font-family: var(--f-mono);
  font-size: 28px;
  font-weight: 500;
  letter-spacing: -0.01em;
  color: var(--ink);
}
.hero-stat .lbl {
  display: block;
  font-family: var(--f-mono);
  font-size: 10.5px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--ink-4);
  margin-top: 4px;
}
.hero-right {
  position: relative;
  background: var(--ink);
  overflow: hidden;
}
.hero-img {
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: center;
  filter: contrast(1.02);
}
.hero-img::after {
  content: '';
  position: absolute; inset: 0;
  background: linear-gradient(135deg, rgba(11,18,32,0.25) 0%, rgba(11,18,32,0) 50%, rgba(11,18,32,0.6) 100%);
}
.hero-overlay {
  position: absolute;
  bottom: 24px; left: 24px; right: 24px;
  display: flex;
  justify-content: space-between;
  align-items: end;
  color: #fff;
  font-family: var(--f-mono);
  font-size: 11px;
  letter-spacing: 0.08em;
}
.hero-overlay .ov-card {
  background: rgba(11,18,32,0.82);
  backdrop-filter: blur(8px);
  padding: 14px 18px;
  border: 1px solid rgba(255,255,255,0.12);
  color: #fff;
  transition: background 0.15s, border-color 0.15s;
}
.hero-overlay:hover .ov-card {
  background: rgba(22,104,227,0.85);
  border-color: rgba(255,255,255,0.3);
}
.hero-overlay .ov-card .lbl { opacity: 0.6; text-transform: uppercase; font-size: 10px; letter-spacing: 0.12em; }
.hero-overlay .ov-card .val { font-size: 14px; letter-spacing: 0.02em; margin-top: 4px; }
.hero-crosshair {
  position: absolute; top: 24px; left: 24px;
  display: flex; flex-direction: column; gap: 4px;
  font-family: var(--f-mono); font-size: 11px;
  color: rgba(255,255,255,0.9);
  letter-spacing: 0.08em;
  line-height: 1.7;
  background: rgba(11,18,32,0.65);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  border: 1px solid rgba(255,255,255,0.14);
  padding: 14px 16px;
}
.hero-timebox {
  position: absolute; top: 24px; right: 24px;
  display: flex; gap: 8px;
  font-family: var(--f-mono);
}
.hero-timebox-cell {
  background: rgba(11,18,32,0.65);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  border: 1px solid rgba(255,255,255,0.14);
  padding: 10px 14px;
}
.hero-timebox-cell .tb-lbl {
  font-size: 9px; letter-spacing: 0.12em; opacity: 0.6;
  text-transform: uppercase; color: #fff;
}
.hero-timebox-cell .tb-val {
  font-size: 19px; letter-spacing: 0.02em; color: #fff; margin-top: 3px;
}

/* Section wrapper */
.section { padding: 80px 0; }
.section.tight { padding: 56px 0; }
.section.dark { background: var(--ink); color: #fff; }
.section.panel { background: var(--panel); }

.section-head {
  display: flex;
  justify-content: space-between;
  align-items: end;
  margin-bottom: 40px;
  gap: 48px;
  flex-wrap: wrap;
}
.section-head .title-block {
  max-width: 640px;
}
.section-head h2 {
  font-size: clamp(32px, 3.4vw, 52px);
  font-weight: 700;
  letter-spacing: -0.025em;
  line-height: 1.02;
  margin: 10px 0 0;
}
.section-head .kicker { margin-bottom: 0; }
.section-head p.lead {
  margin: 16px 0 0;
  font-size: 16px;
  color: var(--ink-3);
  max-width: 56ch;
}

/* Fleet grid on homepage */
.fleet-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1px;
  background: var(--rule);
  border: 1px solid var(--rule);
}
.fleet-card {
  background: #fff;
  padding: 0;
  display: flex;
  flex-direction: column;
  transition: background .12s;
  cursor: pointer;
}
.fleet-card:hover { background: var(--panel-2); }
.fleet-img {
  aspect-ratio: 4/3;
  background-size: cover;
  background-position: center;
  background-color: var(--panel);
  border-bottom: 1px solid var(--rule);
  position: relative;
}
.fleet-img .plane-swatch {
  position: absolute;
  top: 12px; left: 12px;
  display: flex;
  align-items: center;
  gap: 8px;
  background: rgba(255,255,255,0.94);
  padding: 5px 9px;
  font-family: var(--f-mono);
  font-size: 11px;
  letter-spacing: 0.06em;
}
.swatch-dot {
  width: 8px; height: 8px; border-radius: 50%;
}
.fleet-body {
  padding: 20px 22px 24px;
  display: flex;
  flex-direction: column;
  gap: 6px;
  flex: 1;
}
.fleet-body .reg {
  font-size: 28px;
  font-weight: 700;
  letter-spacing: -0.015em;
  font-family: var(--f-mono);
}
.fleet-body .model {
  font-size: 14px;
  color: var(--ink-3);
}
.fleet-body .specs {
  margin-top: 14px;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 10px;
  padding-top: 14px;
  border-top: 1px dashed var(--rule);
  font-family: var(--f-mono);
  font-size: 11px;
}
.fleet-body .specs .s-lbl { color: var(--ink-4); text-transform: uppercase; letter-spacing: 0.06em; font-size: 10px; }
.fleet-body .specs .s-val { color: var(--ink); margin-top: 2px; }
.fleet-body .foot {
  margin-top: 16px;
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.fleet-body .foot .more {
  font-family: var(--f-mono);
  font-size: 11px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--accent);
}

/* Activities on homepage */
.activities-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 24px;
}
.activity-card {
  border: 1px solid var(--rule);
  padding: 24px;
  display: flex;
  gap: 20px;
  background: #fff;
  transition: border-color .12s;
  cursor: pointer;
}
.activity-card:hover { border-color: var(--ink); }
.activity-date {
  flex-shrink: 0;
  width: 76px;
  text-align: center;
  font-family: var(--f-mono);
  border-right: 1px solid var(--rule);
  padding-right: 20px;
}
.activity-date .mo { font-size: 11px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--accent); }
.activity-date .dy { font-size: 36px; font-weight: 700; line-height: 1; margin: 6px 0 4px; color: var(--ink); }
.activity-date .yr { font-size: 11px; color: var(--ink-4); }
.activity-body h3 {
  font-size: 20px;
  font-weight: 700;
  margin: 0 0 8px;
  letter-spacing: -0.01em;
}
.activity-body .meta {
  display: flex;
  gap: 14px;
  flex-wrap: wrap;
  font-family: var(--f-mono);
  font-size: 11px;
  color: var(--ink-4);
  letter-spacing: 0.06em;
  margin-bottom: 10px;
}
.activity-body .meta span { display: flex; align-items: center; gap: 4px; }
.activity-body p {
  margin: 0;
  color: var(--ink-3);
  font-size: 14px;
  line-height: 1.5;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

/* Location / Billund */
.loc-grid {
  display: grid;
  grid-template-columns: 1fr 1.2fr;
  gap: 48px;
  align-items: center;
}
.loc-map {
  aspect-ratio: 4/3;
  background: #0b1220;
  border: 1px solid var(--rule);
  border-radius: 4px;
  position: relative;
  overflow: hidden;
}
.loc-text h3 {
  font-size: 42px;
  letter-spacing: -0.025em;
  font-weight: 700;
  margin: 16px 0 20px;
}
.loc-text .coord-block {
  font-family: var(--f-mono);
  font-size: 13px;
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 8px 20px;
  padding: 20px 0;
  border-top: 1px solid var(--rule);
  border-bottom: 1px solid var(--rule);
  margin: 24px 0;
}
.loc-text .coord-block .k { color: var(--ink-4); text-transform: uppercase; font-size: 11px; letter-spacing: 0.08em; }
.loc-text .coord-block .v { color: var(--ink); }

/* ================================================================
   FLEET PAGE
   ================================================================ */
.page-head {
  padding: 72px 0 40px;
  border-bottom: 1px solid var(--rule);
}
.page-head h1 {
  font-size: clamp(44px, 5vw, 72px);
  font-weight: 700;
  letter-spacing: -0.03em;
  margin: 12px 0 12px;
  line-height: 0.98;
}
.page-head .crumbs {
  font-family: var(--f-mono);
  font-size: 11px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--ink-4);
  display: flex;
  gap: 8px;
  align-items: center;
}
.page-head .crumbs a:hover { color: var(--ink); }
.page-head p.lead {
  max-width: 58ch;
  color: var(--ink-3);
  font-size: 16px;
}

.fleet-page-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 1px;
  background: var(--rule);
  border-left: 1px solid var(--rule);
  border-right: 1px solid var(--rule);
  border-bottom: 1px solid var(--rule);
}
.fleet-page-grid .fleet-card { padding: 0; }
.fleet-page-grid::after { content: ''; background: var(--bg); }
.fleet-page-grid .fleet-img { aspect-ratio: 16/9; }

/* ================================================================
   PLANE DETAIL
   ================================================================ */
.plane-hero {
  position: relative;
  height: 540px;
  background-size: cover;
  background-position: center;
  background-color: var(--ink);
  border-bottom: 1px solid var(--rule);
}
.plane-hero::after {
  content: '';
  position: absolute; inset: 0;
  background: linear-gradient(to top, rgba(11,18,32,0.7) 0%, rgba(11,18,32,0.1) 60%, rgba(11,18,32,0.4) 100%);
}
.plane-hero-content {
  position: absolute;
  bottom: 0; left: 0; right: 0;
  padding: 40px 0;
  color: #fff;
  z-index: 1;
}
.plane-hero-content .reg {
  font-size: clamp(56px, 7vw, 104px);
  font-family: var(--f-mono);
  font-weight: 500;
  letter-spacing: -0.02em;
  line-height: 1;
  margin: 0;
}
.plane-hero-content .model {
  font-size: 20px;
  opacity: 0.85;
  margin: 8px 0 0;
  letter-spacing: 0.02em;
}
.plane-hero-content .tags {
  display: flex;
  gap: 8px;
  margin-top: 20px;
}
.plane-hero-content .tags .tag { background: rgba(255,255,255,0.1); border-color: rgba(255,255,255,0.2); color: #fff; }

.plane-body {
  display: grid;
  grid-template-columns: 1fr 340px;
  gap: 64px;
  padding: 64px 0;
}

.spec-panel {
  border: 1px solid var(--rule);
  background: var(--panel-2);
  padding: 24px;
}
.spec-panel h4 {
  font-family: var(--f-mono);
  font-size: 11px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--ink-4);
  margin: 0 0 16px;
  padding-bottom: 12px;
  border-bottom: 1px solid var(--rule);
}
.spec-panel + .spec-panel { margin-top: 16px; }
.spec-row {
  display: flex;
  justify-content: space-between;
  padding: 8px 0;
  font-size: 13px;
  border-bottom: 1px dotted var(--rule);
  font-family: var(--f-mono);
}
.spec-row:last-child { border-bottom: 0; }
.spec-row .k { color: var(--ink-4); }
.spec-row .v { color: var(--ink); font-weight: 500; }

.plane-main h2 {
  font-size: 28px;
  margin: 0 0 16px;
  letter-spacing: -0.015em;
  font-weight: 700;
}
.plane-main h2:not(:first-child) { margin-top: 48px; }
.plane-main p {
  color: var(--ink-3);
  font-size: 15px;
  line-height: 1.65;
  margin: 0 0 16px;
}

.gallery {
  display: grid;
  grid-template-columns: 2fr 1fr 1fr;
  grid-auto-rows: 180px;
  gap: 8px;
}
.gallery div {
  background-size: cover;
  background-position: center;
  background-color: var(--panel);
}
.gallery div:first-child { grid-row: span 2; }

.equip-list {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 8px 24px;
  font-family: var(--f-mono);
  font-size: 13px;
}
.equip-list li {
  display: flex;
  gap: 10px;
  padding: 6px 0;
  border-bottom: 1px dotted var(--rule);
  list-style: none;
}
.equip-list li::before {
  content: '▸';
  color: var(--accent);
  font-size: 10px;
}

.docs-list {
  list-style: none;
  padding: 0;
  margin: 0;
  border-top: 1px solid var(--rule);
}
.docs-list li {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 14px 0;
  border-bottom: 1px solid var(--rule);
  font-family: var(--f-mono);
  font-size: 13px;
}
.docs-list li .name { display: flex; gap: 10px; align-items: center; }
.docs-list li .size { color: var(--ink-4); font-size: 11px; }

/* Sale notice */
.sale-notice {
  border: 1px solid var(--warn);
  background: color-mix(in oklch, var(--warn) 6%, white);
  padding: 16px 20px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 20px;
  margin-bottom: 32px;
}
.sale-notice .txt {
  font-family: var(--f-mono);
  font-size: 13px;
  color: var(--warn);
  letter-spacing: 0.02em;
}

/* ================================================================
   ACTIVITIES PAGE
   ================================================================ */
.activities-tabs {
  display: flex;
  gap: 0;
  border-bottom: 1px solid var(--rule);
  margin-bottom: 40px;
}
.activities-tabs button {
  background: transparent;
  border: 0;
  padding: 16px 24px;
  font-family: var(--f-mono);
  font-size: 12px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--ink-4);
  border-bottom: 2px solid transparent;
  margin-bottom: -1px;
  cursor: pointer;
}
.activities-tabs button.on { color: var(--ink); border-bottom-color: var(--accent); }

.month-heading {
  font-family: var(--f-mono);
  font-size: 12px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--ink-4);
  padding: 24px 0 12px;
  border-top: 1px solid var(--rule);
  display: flex;
  justify-content: space-between;
}

.event-row {
  display: grid;
  grid-template-columns: 90px 1fr 240px 120px;
  gap: 24px;
  padding: 24px 0;
  border-bottom: 1px solid var(--rule);
  align-items: start;
}
.event-row:hover { background: var(--panel-2); }
.event-row .e-date {
  font-family: var(--f-mono);
}
.event-row .e-date .d { font-size: 32px; font-weight: 700; color: var(--ink); line-height: 1; letter-spacing: -0.02em; }
.event-row .e-date .m { font-size: 11px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--accent); margin-top: 6px; }
.event-row .e-title { font-size: 20px; font-weight: 700; letter-spacing: -0.01em; margin: 0 0 8px; }
.event-row .e-desc { color: var(--ink-3); font-size: 14px; line-height: 1.55; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.event-row .e-meta {
  font-family: var(--f-mono);
  font-size: 11px;
  color: var(--ink-4);
  letter-spacing: 0.06em;
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.event-row .e-action { text-align: right; }
.event-row .e-action .registered {
  font-family: var(--f-mono);
  font-size: 11px;
  color: #16a34a;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  display: inline-flex;
  align-items: center;
  gap: 6px;
}

/* ================================================================
   LOGIN
   ================================================================ */
.login-wrap {
  min-height: calc(100vh - 64px);
  display: grid;
  grid-template-columns: 1fr 1fr;
}
.login-left {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 48px;
}
.login-form {
  width: 100%;
  max-width: 400px;
}
.login-form h1 {
  font-size: 36px;
  font-weight: 700;
  letter-spacing: -0.02em;
  margin: 12px 0 8px;
}
.login-form .sub {
  color: var(--ink-3);
  margin-bottom: 32px;
}
.field { margin-bottom: 16px; }
.field label {
  display: block;
  font-family: var(--f-mono);
  font-size: 11px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--ink-4);
  margin-bottom: 6px;
}
.field input, .field select, .field textarea {
  width: 100%;
  height: 42px;
  padding: 0 12px;
  border: 1px solid var(--rule);
  border-radius: var(--radius);
  font-family: var(--f-body);
  font-size: 14px;
  color: var(--ink);
  background: #fff;
  transition: border-color .12s;
}
.field textarea { height: auto; padding: 10px 12px; min-height: 80px; resize: vertical; }
.field input:focus, .field select:focus, .field textarea:focus {
  outline: none;
  border-color: var(--accent);
  box-shadow: 0 0 0 3px color-mix(in oklch, var(--accent) 14%, transparent);
}
.login-right {
  background: var(--ink);
  position: relative;
  overflow: hidden;
}
.login-bg {
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: center;
  opacity: 0.55;
}
.login-bg::after {
  content: '';
  position: absolute; inset: 0;
  background: linear-gradient(135deg, rgba(11,18,32,0.4), rgba(11,18,32,0.8));
}
.login-quote {
  position: absolute;
  bottom: 48px; left: 48px; right: 48px;
  color: #fff;
  font-family: var(--f-mono);
  font-size: 12px;
  letter-spacing: 0.1em;
  line-height: 1.8;
  opacity: 0.8;
}
.login-chart {
  position: absolute;
  top: 48px; left: 48px; right: 48px;
  color: rgba(255,255,255,0.9);
  font-family: var(--f-mono);
  font-size: 11px;
  letter-spacing: 0.1em;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
}
.login-chart .chart-cell {
  border: 1px solid rgba(255,255,255,0.18);
  padding: 14px 16px;
  background: rgba(11,18,32,0.5);
  backdrop-filter: blur(4px);
}
.login-chart .chart-cell .l { opacity: 0.6; font-size: 10px; letter-spacing: 0.12em; }
.login-chart .chart-cell .v { font-size: 16px; margin-top: 4px; letter-spacing: 0; }

/* ================================================================
   MEMBER CALENDAR
   ================================================================ */
.cal-shell {
  padding: 24px 0 40px;
  max-width: 1600px;
  margin: 0 auto;
}
.cal-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 20px;
  gap: 24px;
  flex-wrap: wrap;
}
.cal-header h1 {
  font-size: 32px;
  font-weight: 700;
  margin: 0;
  letter-spacing: -0.02em;
  display: flex; align-items: baseline; gap: 14px;
}
.cal-header h1 .month {
  font-family: var(--f-mono);
  font-weight: 500;
  color: var(--ink-4);
  font-size: 20px;
  letter-spacing: 0.02em;
}
.cal-controls {
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
}
.cal-navbtn {
  width: 36px; height: 36px;
  border: 1px solid var(--rule);
  background: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  border-radius: var(--radius);
  color: var(--ink-3);
}
.cal-navbtn:hover { border-color: var(--ink); color: var(--ink); }
.view-switch {
  display: inline-flex;
  border: 1px solid var(--rule);
  border-radius: var(--radius);
  background: #fff;
  overflow: hidden;
}
.view-switch button {
  background: transparent;
  border: 0;
  padding: 0 14px;
  height: 34px;
  font-family: var(--f-mono);
  font-size: 11px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--ink-4);
  cursor: pointer;
}
.view-switch button.on { background: var(--ink); color: #fff; }

.plane-filter {
  display: flex;
  gap: 8px;
  padding: 14px 16px;
  background: var(--panel);
  border: 1px solid var(--rule);
  margin-bottom: 16px;
  flex-wrap: wrap;
  align-items: center;
}
.plane-filter .lbl {
  font-family: var(--f-mono);
  font-size: 11px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--ink-4);
  margin-right: 8px;
}
.plane-chip {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 4px 10px;
  background: #fff;
  border: 1px solid var(--rule);
  border-radius: 100px;
  font-family: var(--f-mono);
  font-size: 12px;
  letter-spacing: 0.02em;
  color: var(--ink-3);
  cursor: pointer;
  transition: all .12s;
}
.plane-chip:hover { border-color: var(--ink-4); }
.plane-chip.off { opacity: 0.35; }
.plane-chip .dot { width: 8px; height: 8px; border-radius: 50%; }
.plane-chip .status {
  font-size: 10px;
  padding: 0 6px;
  border-radius: 2px;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  margin-left: 4px;
}
.plane-chip .status.free { background: #dcfce7; color: #15803d; }
.plane-chip .status.busy { background: #fee2e2; color: #b91c1c; }

/* Month grid */
.month-grid {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  border: 1px solid var(--rule);
  background: var(--rule);
  gap: 1px;
}
.dow-head {
  background: var(--panel);
  padding: 10px 12px;
  font-family: var(--f-mono);
  font-size: 10.5px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--ink-4);
  text-align: left;
}
.day-cell {
  background: #fff;
  min-height: 128px;
  padding: 8px;
  display: flex;
  flex-direction: column;
  gap: 3px;
  position: relative;
}
.day-cell.out { background: var(--panel-2); }
.day-cell.today .daynum {
  background: var(--accent);
  color: #fff;
  border-radius: 100%;
  width: 24px; height: 24px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
.day-cell .daynum {
  font-family: var(--f-mono);
  font-size: 12px;
  color: var(--ink-3);
  padding: 2px 4px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 24px;
  height: 24px;
}
.day-cell.out .daynum { color: var(--ink-5); }
.day-cell .add-btn {
  position: absolute;
  top: 6px; right: 6px;
  width: 22px; height: 22px;
  background: var(--panel);
  border: 0;
  border-radius: 2px;
  color: var(--ink-4);
  opacity: 0;
  display: flex; align-items: center; justify-content: center;
  font-size: 14px;
  transition: opacity .12s;
}
.day-cell:hover .add-btn { opacity: 1; }
.day-cell .add-btn:hover { background: var(--ink); color: #fff; }

.booking-pill {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 3px 7px;
  font-family: var(--f-mono);
  font-size: 11px;
  border-left: 3px solid;
  background: #fff;
  color: var(--ink);
  border-radius: 0 2px 2px 0;
  cursor: pointer;
  transition: transform .08s;
  line-height: 1.3;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.booking-pill:hover { transform: translateX(2px); }
.booking-pill .reg { font-weight: 600; }
.booking-pill .pilot { color: var(--ink-3); }
.booking-pill.bvn { border-color: var(--p-bvn); background: color-mix(in oklch, var(--p-bvn) 10%, white); }
.booking-pill.azh { border-color: var(--p-azh); background: color-mix(in oklch, var(--p-azh) 10%, white); }
.booking-pill.gaa { border-color: var(--p-gaa); background: color-mix(in oklch, var(--p-gaa) 10%, white); }
.booking-pill.drg { border-color: var(--p-drg); background: color-mix(in oklch, var(--p-drg) 10%, white); }
.booking-pill.est { border-color: var(--p-est); background: color-mix(in oklch, var(--p-est) 10%, white); }
.booking-pill.cfz { border-color: var(--p-cfz); background: color-mix(in oklch, var(--p-cfz) 10%, white); }
.booking-pill.activity {
  border-color: var(--p-activity);
  background: var(--p-activity);
  color: #fff;
}
.booking-pill.activity .reg { color: #fff; font-weight: 700; }
.booking-pill.activity .pilot { color: #fff; }
.booking-pill.activity:hover { opacity: 0.9; transform: translateX(2px); }
.booking-pill.flyin {
  border-color: var(--p-flyin);
  background: var(--p-flyin);
  color: #fff;
}
.booking-pill.flyin .reg { color: #fff; font-weight: 700; }
.booking-pill.flyin .pilot { color: #fff; }
.booking-pill.flyin:hover { opacity: 0.9; transform: translateX(2px); }

.booking-more {
  font-family: var(--f-mono);
  font-size: 10.5px;
  color: var(--ink-4);
  padding: 2px 7px;
  letter-spacing: 0.04em;
  cursor: pointer;
}
.booking-more:hover { color: var(--ink); }

/* Activity chips (week/day all-day rows) */
.week-allday-label {
  background: var(--panel);
  padding: 4px 6px;
  font-family: var(--f-mono);
  font-size: 10px;
  color: var(--ink-4);
  text-align: right;
  letter-spacing: 0.06em;
  border-bottom: 1px solid var(--rule);
}
.week-allday-cell {
  background: #fff;
  padding: 2px 3px;
  border-bottom: 1px solid var(--rule);
  display: flex;
  flex-direction: column;
  gap: 2px;
  min-height: 24px;
}
.activity-chip {
  display: flex;
  align-items: center;
  gap: 4px;
  padding: 2px 6px;
  font-family: var(--f-mono);
  font-size: 10px;
  border-left: 2px solid var(--p-activity);
  background: var(--p-activity);
  color: #fff;
  border-radius: 0 2px 2px 0;
  cursor: pointer;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  transition: transform .08s, opacity .08s;
}
.activity-chip:hover { transform: translateX(2px); opacity: 0.9; }
.activity-chip svg { flex-shrink: 0; color: #fff; }
.day-activities-strip {
  border-bottom: 1px solid var(--rule);
  background: var(--panel-2);
  padding: 4px 10px;
  display: flex;
  flex-direction: column;
  gap: 3px;
}
.day-activity-banner {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 6px 10px;
  font-family: var(--f-mono);
  font-size: 12px;
  border-left: 3px solid var(--p-activity);
  background: var(--p-activity);
  color: #fff;
  border-radius: 0 3px 3px 0;
  cursor: pointer;
  transition: opacity .1s;
}
.day-activity-banner:hover { opacity: 0.9; }
.day-activity-banner svg { color: #fff; flex-shrink: 0; }
.day-activity-banner .act-title { font-weight: 600; }
.day-activity-banner .act-meta { color: rgba(255,255,255,0.75); font-size: 11px; }
.day-activity-banner.flyin-banner {
  border-left-color: var(--p-flyin);
  background: var(--p-flyin);
}
.day-activity-banner.flyin-banner:hover { opacity: 0.9; }
.day-activity-banner.flyin-banner .act-meta { color: rgba(255,255,255,0.75); }

/* Fly-in chip (week all-day row) */
.flyin-chip {
  display: flex;
  align-items: center;
  gap: 4px;
  padding: 2px 6px;
  font-family: var(--f-mono);
  font-size: 10px;
  border-left: 2px solid var(--p-flyin);
  background: var(--p-flyin);
  color: #fff;
  border-radius: 0 2px 2px 0;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  transition: transform .08s, opacity .08s;
}
.flyin-chip:hover { transform: translateX(2px); }

/* Activities page two-column layout */
.activities-with-sidebar {
  display: grid;
  grid-template-columns: 1fr 320px;
  gap: 40px;
  align-items: start;
}
@media (max-width: 900px) {
  .activities-with-sidebar {
    grid-template-columns: 1fr;
  }
  .activities-with-sidebar aside {
    order: -1;
  }
}

/* Fly-in item in sidebar */
.flyin-item {
  padding: 12px 0;
  border-bottom: 1px solid var(--rule);
}
.flyin-item:last-of-type { border-bottom: none; }

/* Week view */
.week-grid {
  display: grid;
  grid-template-columns: 60px repeat(7, 1fr);
  border: 1px solid var(--rule);
  background: var(--rule);
  gap: 1px;
}
.week-grid .time-col { background: var(--panel); padding: 4px; font-family: var(--f-mono); font-size: 10.5px; color: var(--ink-4); letter-spacing: 0.06em; }
.week-grid .day-col-head { background: var(--panel); padding: 10px; font-family: var(--f-mono); font-size: 11px; color: var(--ink-3); letter-spacing: 0.08em; text-transform: uppercase; }
.week-grid .day-col-head .daynum { display: block; font-size: 20px; font-weight: 600; color: var(--ink); margin-top: 2px; letter-spacing: -0.01em; }
.week-grid .day-col-head.is-today .daynum { color: var(--accent); }
.week-day-col {
  background: #fff;
  position: relative;
  min-height: 600px;
}
.week-hour-row {
  height: 48px;
  border-bottom: 1px solid var(--rule-2);
}
.time-label {
  background: #fff;
  height: 48px;
  padding: 2px 6px;
  font-family: var(--f-mono);
  font-size: 10.5px;
  color: var(--ink-4);
  text-align: right;
  border-bottom: 1px solid var(--rule-2);
}
.week-booking {
  position: absolute;
  padding: 5px 7px;
  font-family: var(--f-mono);
  font-size: 11px;
  border-left: 3px solid;
  color: var(--ink);
  overflow: hidden;
  cursor: pointer;
}

/* Day view */
.day-shell {
  display: grid;
  grid-template-columns: 80px 1fr;
  border: 1px solid var(--rule);
}
.day-hours { background: var(--panel); }
.day-timeline {
  position: relative;
  background: #fff;
  min-height: 700px;
  display: grid;
  grid-template-rows: repeat(24, 40px);
}
.day-timeline .hour-line { border-bottom: 1px solid var(--rule-2); }
.day-booking {
  position: absolute;
  padding: 10px 12px;
  font-family: var(--f-mono);
  border-left: 4px solid;
  background: #fff;
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.day-booking .reg { font-weight: 600; font-size: 14px; }
.day-booking .pilot { color: var(--ink-3); font-size: 12px; }
.day-booking .time { color: var(--ink-4); font-size: 11px; letter-spacing: 0.06em; }

/* Booking modal */
.modal-backdrop {
  position: fixed;
  inset: 0;
  background: rgba(11,18,32,0.5);
  backdrop-filter: blur(4px);
  z-index: 100;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 24px;
}
.modal {
  background: #fff;
  width: 100%;
  max-width: 560px;
  border: 1px solid var(--rule);
  max-height: 90vh;
  overflow: hidden;
  display: flex;
  flex-direction: column;
}
.modal-body { flex: 1; min-height: 0; overflow-y: auto; overflow-x: hidden; }
.modal-head {
  padding: 20px 24px;
  border-bottom: 1px solid var(--rule);
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.modal-head h3 {
  margin: 0;
  font-size: 18px;
  letter-spacing: -0.01em;
}
.modal-head .close {
  background: none; border: none; font-size: 20px;
  color: var(--ink-4);
}
.modal-body { padding: 24px; }
.booking-dt-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; }
.booking-dt-grid > div { min-width: 0; overflow: hidden; }
.booking-dt-grid input[type="date"] {
  width: 100%;
  min-width: 0;
  max-width: 100%;
  -webkit-appearance: none;
  appearance: none;
}
.activity-detail-layout {
  display: grid;
  grid-template-columns: 1fr 340px;
  gap: 48px;
  align-items: start;
}

@media (max-width: 768px) {
  .activity-detail-layout {
    grid-template-columns: 1fr;
    gap: 32px;
  }
  .activity-detail-layout .activity-sidebar {
    position: static !important;
  }
}

@media (max-width: 600px) {
  .modal-backdrop { padding: 0; align-items: stretch; }
  .modal {
    max-width: 100%;
    height: 100dvh;
    max-height: 100dvh;
    border: 0; border-radius: 0;
  }
  .modal-foot { padding-bottom: max(16px, env(safe-area-inset-bottom)); }
  .booking-dt-grid { grid-template-columns: 1fr; }
  .booking-note-col { display: none; }
}
.modal-foot {
  padding: 16px 24px;
  border-top: 1px solid var(--rule);
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
  background: var(--panel-2);
}

.plane-picker {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 8px;
}
.plane-picker-opt {
  padding: 12px;
  border: 1px solid var(--rule);
  background: #fff;
  font-family: var(--f-mono);
  text-align: left;
  cursor: pointer;
  display: flex;
  flex-direction: column;
  gap: 4px;
  transition: all .12s;
}
.plane-picker-opt:hover { border-color: var(--ink-4); }
.plane-picker-opt.on {
  background: var(--ink);
  color: #fff;
  border-color: var(--ink);
}
.plane-picker-opt .reg { font-size: 15px; font-weight: 600; letter-spacing: -0.005em; }
.plane-picker-opt .model { font-size: 11px; opacity: 0.7; }

.time-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
}

/* ================================================================
   Small utilities and responsive
   ================================================================ */
@media (max-width: 1100px) {
  .hero-inner { grid-template-columns: 1fr; }
  .hero-right { min-height: 360px; }
  .fleet-grid { grid-template-columns: repeat(2, 1fr); }
  .plane-body { grid-template-columns: 1fr; }
  .login-wrap { grid-template-columns: 1fr; }
  .login-right { display: none; }
  .footer-grid { grid-template-columns: 1fr 1fr; }
}
/* ── Mobile nav ─────────────────────────────────────────────────── */
.nav-hamburger {
  display: none;
  align-items: center;
  justify-content: center;
  background: none;
  border: none;
  cursor: pointer;
  padding: 6px;
  color: var(--ink);
  margin-left: 8px;
  flex-shrink: 0;
}
.nav-mobile {
  border-top: 1px solid var(--border);
  background: #fff;
  padding: 8px 0 16px;
}
.nav-mobile-link {
  display: block;
  padding: 12px 24px;
  color: var(--ink-2);
  font-size: 15px;
  font-weight: 500;
  text-decoration: none;
  letter-spacing: 0.01em;
  transition: background 0.1s, color 0.1s;
}
.nav-mobile-link:hover { color: var(--ink); background: var(--bg-2); }
.nav-mobile-link.active { color: var(--accent); font-weight: 600; }
.nav-mobile-divider { height: 1px; background: var(--border); margin: 8px 24px; }
.nav-mobile-action { margin: 8px 24px 0; width: calc(100% - 48px); justify-content: center; }

/* --------- Member list page ----------- */
.member-filter-row {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
  margin-bottom: 24px;
}
.member-search {
  flex: 1;
  min-width: 180px;
  max-width: 300px;
  padding: 8px 12px;
  font-size: 13px;
  border: 1px solid var(--border);
  border-radius: 7px;
  background: var(--surface);
  color: var(--ink);
  outline: none;
  font-family: var(--f-sans);
}
.member-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  gap: 12px;
}
.member-card {
  display: flex;
  flex-direction: column;
  gap: 0;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 14px 16px;
  cursor: pointer;
  text-align: left;
  width: 100%;
  transition: border-color 0.15s, box-shadow 0.15s;
}
.member-card:hover {
  border-color: var(--accent);
  box-shadow: 0 2px 12px color-mix(in oklch, var(--accent) 12%, transparent);
}

@media (max-width: 900px) {
  .member-grid {
    grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
    gap: 10px;
  }
}
@media (max-width: 600px) {
  .member-grid {
    grid-template-columns: 1fr;
    gap: 8px;
  }
  .member-search {
    max-width: 100%;
    flex: 1 1 100%;
    order: -1;
  }
  .member-filter-row {
    gap: 6px;
  }
}

/* DTO page responsive grids */
.dto-sidebar { position: sticky; top: 80px; }
.dto-main-grid {
  display: grid;
  grid-template-columns: minmax(0,2fr) minmax(0,1fr);
  gap: 64px;
  align-items: start;
}
.dto-post-cert-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 48px;
  align-items: center;
}

@media (max-width: 720px) {
  .container { padding: 0 20px; }
  .hero-left { padding: 32px 24px; }
  .fleet-grid { grid-template-columns: 1fr; }
  .activities-grid { grid-template-columns: 1fr; }
  .fleet-page-grid { grid-template-columns: 1fr; }
  .nav-links { display: none; }
  .nav-meta { display: none; }
  .nav-hamburger { display: flex; }
  .event-row { grid-template-columns: 70px 1fr; }
  .event-row .e-meta, .event-row .e-action { grid-column: 2; }
  .day-cell { min-height: 80px; }
  .booking-pill .pilot { display: none; }
  .bliv-medlem-grid { grid-template-columns: 1fr !important; }
  .hero-cta { flex-wrap: wrap; }
  .contact-grid { grid-template-columns: 1fr !important; gap: 48px !important; }
  .prices-grid { grid-template-columns: 1fr !important; gap: 40px !important; }
  .board-role { letter-spacing: 0.01em !important; word-break: break-word; }
  .loc-grid { grid-template-columns: 1fr; }
  .loc-map { height: 260px !important; }
  .loc-text h3 { font-size: clamp(28px, 8vw, 42px); }
  .dto-main-grid { grid-template-columns: 1fr; gap: 40px; }
  .dto-post-cert-grid { grid-template-columns: 1fr; gap: 40px; }
  .dto-sidebar { position: static; }
}
