﻿@font-face {
  font-family: "AgencyBold";
  src: url("../fonts/AGENCYBOLD.woff2") format("woff2");
  font-display: swap;
}

@font-face {
  font-family: "BabyMagnolia";
  src: url("../fonts/BabyMagnolia.woff2") format("woff2");
  font-display: swap;
}

@font-face {
  font-family: "Caslon";
  src: url("../fonts/CASLON__.woff2") format("woff2");
  font-display: swap;
}

:root {
  --page-bg: #1a1a1a;
  --de1: #000140;
  --nav-default: #8081ff;
  --nav-hover: #00ffff;
  --header-height: 80px;
  --nav-side-padding: 20px;
  --logo-left-padding: 20px;
}

* {
  box-sizing: border-box;
}

html,
body {
  width: 100%;
  min-height: 100%;
  margin: 0;
  background: var(--page-bg);
}

body {
  min-height: 100vh;
  color: #fff;
}

.site-header {
  width: 100%;
  height: var(--header-height);
  display: flex;
  align-items: stretch;
}

.bcl-logo {
  flex: 0 0 auto;
  height: 100%;
  background: transparent;
  padding-left: var(--logo-left-padding);
  padding-right: 0;
  display: flex;
  align-items: center;
  justify-content: flex-start;
}

.bcl-logo img {
  height: 100%;
  width: auto;
  display: block;
}

.header-right {
  flex: 1;
  height: 100%;
  display: grid;
  grid-template-rows: 1fr 1fr;
}

.nav-row {
  height: 100%;
  background: transparent;
  display: flex;
  align-items: center;
  padding-left: var(--nav-side-padding);
  padding-right: var(--nav-side-padding);
}

.primary-nav {
  width: 100%;
  height: 100%;
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  align-items: stretch;
  column-gap: 28px;
}

.primary-nav a {
  font-family: "AgencyBold", sans-serif;
  font-size: 1.15rem;
  line-height: 1;
  letter-spacing: 0.0428em;
  text-decoration: none;
  text-transform: uppercase;
  color: var(--nav-default);
  text-shadow: 0 0 8px rgba(128, 129, 255, 0.45);
  background: transparent;
  height: 100%;
  padding: 0 12px;
  display: flex;
  justify-content: center;
  align-items: center;
  border: 0;
  border-radius: 0;
  transition: color 120ms linear, text-shadow 120ms linear, background 120ms linear;
  white-space: nowrap;
}

.primary-nav a:hover,
.primary-nav a:focus-visible {
  color: var(--nav-hover);
  background: var(--de1);
  text-shadow: none;
  outline: none;
}

.de1-row {
  height: 100%;
  background: var(--de1);
}

main {
  width: 100%;
}

.home-hero {
  min-height: calc(100vh - var(--header-height) - 140px);
  width: 100%;
  display: grid;
  grid-template-columns: minmax(320px, 1.08fr) minmax(320px, 0.92fr);
  align-items: center;
  gap: 8px;
  padding: 0 5vw;
}

.hero-copy {
  justify-self: center;
  text-align: center;
}

.hero-text-lockup {
  display: inline-block;
}

.hero-intro {
  margin: 0 0 0.27em;
  font-family: "AgencyBold", sans-serif;
  font-size: calc(clamp(0.85rem, 1.95vw, 1.55rem) + 3pt);
  line-height: 1.05;
  letter-spacing: 0.0428em;
  color: #ecefff;
}

.hero-line-main {
  margin: 0;
  font-family: "AgencyBold", sans-serif;
  font-size: clamp(2.2rem, 7vw, 5.8rem);
  line-height: 0.95;
  letter-spacing: 0.0428em;
  text-transform: uppercase;
  color: #f2f5ff;
}

.hero-line-accent {
  margin: 0.11em 0 0;
  font-family: "BabyMagnolia", cursive;
  font-size: clamp(1.7rem, 3.9vw, 3.1rem);
  line-height: 1;
  letter-spacing: normal;
  text-transform: none;
  color: #e5e9ff;
}

.hero-wordmark {
  display: block;
  width: 90%;
  max-width: 90%;
  height: auto;
  margin: 0.62em auto 0.62em;
}

.hero-cammy {
  max-height: min(54vh, 645px);
  width: auto;
  height: auto;
  filter: drop-shadow(0 0 13px rgba(255, 255, 255, 0.32));
  transform: translateX(-40px);
}

.hero-right {
  justify-self: start;
  align-self: center;
  display: flex;
  align-items: center;
  gap: 16px;
}

.hero-ui-shot {
  width: clamp(240px, 24vw, 460px);
  height: auto;
  border: none;
}

.hero-ui-block {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
}

.hero-ui-caption-top,
.hero-ui-caption-bottom {
  margin: 0;
  font-size: calc(clamp(0.85rem, 1.95vw, 1.55rem) + 3pt);
  line-height: 1.1;
  letter-spacing: 0.0428em;
  color: #ecefff;
}

.hero-ui-caption-top {
  font-family: "AgencyBold", sans-serif;
  margin-bottom: 0.42em;
}

.hero-ui-caption-bottom {
  font-family: "AgencyBold", sans-serif;
  margin-top: 0.42em;
  font-style: italic;
}

.home-intro-copy {
  max-width: min(1080px, 82vw);
  margin: 0.6rem auto 3.4rem;
  text-align: center;
}

.home-intro-copy p {
  margin: 0;
  font-family: "AgencyBold", sans-serif;
  font-size: calc(clamp(1.02rem, 1.55vw, 1.45rem) + 3pt);
  line-height: 1.34;
  letter-spacing: 0.0428em;
  color: #ecefff;
}

.home-intro-copy p + p {
  margin-top: 1.35rem;
}

.home-lineup-row {
  margin: 1.2rem auto 0;
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
  gap: 8px;
  width: 100%;
}

.home-lineup-image {
  display: block;
  width: auto;
  max-width: min(417px, 78vw);
  border: none;
  height: auto;
  margin: 0;
}

.home-lineup-side {
  margin: 0;
  font-family: "AgencyBold", sans-serif;
  font-size: calc(clamp(0.9rem, 1.25vw, 1.22rem) + 3pt);
  line-height: 1.16;
  letter-spacing: 0.0428em;
  color: #ecefff;
  text-align: center;
}

.home-lineup-side-left,
.home-lineup-side-right {
  text-align: center;
}

.home-lineup-side-right {
  color: #ff0000;
}

.home-intro-copy p.home-lineup-side-left,
.home-intro-copy p.home-lineup-side-right {
  text-align: center;
}

.home-intro-copy p.home-lineup-side-right {
  color: #ff0000;
}

.home-lineup-side-note {
  display: inline-block;
  font-size: calc(1em - 2pt);
}

@media (max-width: 1100px) {
  .home-lineup-row {
    grid-template-columns: 1fr;
    gap: 12px;
  }

  .home-lineup-side-left,
  .home-lineup-side-right {
    text-align: center;
  }

  .home-lineup-image {
    margin: 0 auto;
    max-width: min(417px, 90vw);
  }
}

.pricing-page {
  width: min(1200px, 92vw);
  margin: 0 auto;
  padding: 1.4rem 0 2.4rem;
}

.pricing-hero {
  text-align: center;
  margin: 0.3rem 0 1.4rem;
}

.pricing-hero h1 {
  margin: 0;
  font-family: "AgencyBold", sans-serif;
  font-size: clamp(2rem, 4.8vw, 4rem);
  line-height: 0.96;
  letter-spacing: 0.0428em;
  color: #f2f5ff;
}

.pricing-hero p {
  margin: 0.55rem 0 0;
  font-family: "AgencyBold", sans-serif;
  font-size: clamp(1rem, 1.8vw, 1.35rem);
  line-height: 1.25;
  letter-spacing: 0.0428em;
  color: #ecefff;
}

.pricing-cards {
  display: grid;
  grid-template-columns: repeat(2, minmax(280px, 1fr));
  gap: 16px;
  margin: 0 0 1.4rem;
}

.pricing-card {
  background: rgba(0, 1, 64, 0.35);
  border: 1px solid rgba(128, 129, 255, 0.32);
  padding: 1rem 1rem 1.1rem;
}

.pricing-card h2 {
  margin: 0 0 0.65rem;
  font-family: "AgencyBold", sans-serif;
  font-size: calc(clamp(1.25rem, 2vw, 1.8rem) - 2pt);
  letter-spacing: 0.0428em;
  color: #00ffff;
}

.pricing-card-paid h2 {
  color: #ff0000;
}

.pricing-card ul {
  margin: 0;
  padding-left: 1.15rem;
}

.pricing-card li {
  margin: 0;
  font-family: "AgencyBold", sans-serif;
  font-size: calc(clamp(0.95rem, 1.4vw, 1.2rem) + 2pt);
  line-height: 1.25;
  letter-spacing: 0.0428em;
  color: #ecefff;
}

.pricing-card li + li {
  margin-top: 0.45rem;
}

.pricing-inline-note {
  margin: 0.25rem 0 40px;
  text-align: center;
  font-family: "AgencyBold", sans-serif;
  font-size: calc(clamp(0.95rem, 1.45vw, 1.2rem) + 2pt);
  line-height: 1.28;
  letter-spacing: 0.0428em;
  color: #ecefff;
}

.pricing-inline-note::after {
  content: "";
  display: block;
  width: min(920px, 94%);
  height: 5px;
  margin: 14px auto 0;
  background: #000140;
}

.pricing-cam-camper {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  margin-top: 0.2rem;
}

.pricing-cam-camper img {
  width: min(480px, 72vw);
  height: auto;
  border: none;
}

.pricing-cam-camper p {
  margin: 0.8rem 0 0;
  font-family: "AgencyBold", sans-serif;
  font-size: calc(clamp(0.95rem, 1.45vw, 1.2rem) + 2pt);
  line-height: 1.28;
  letter-spacing: 0.0428em;
  color: #ecefff;
}

@media (max-width: 860px) {
  .pricing-cards {
    grid-template-columns: 1fr;
  }

  .pricing-inline-note::after {
    width: min(620px, 94%);
  }
}

.site-footer {
  width: 100%;
  margin: 2rem 0 1.2rem;
  text-align: center;
  font-family: Helvetica, Arial, sans-serif;
  font-size: 9pt;
  line-height: 1.2;
  letter-spacing: 0;
  color: #0705a2;
}





.download-page {
  width: min(1200px, 92vw);
  margin: 0 auto;
  padding: 1.4rem 0 2.4rem;
}

.download-hero {
  display: grid;
  grid-template-columns: minmax(310px, 1fr) minmax(260px, 0.95fr);
  gap: 24px;
  align-items: center;
  margin: 0.3rem 0 1.4rem;
}

.download-hero-copy h1 {
  margin: 0;
  font-family: "AgencyBold", sans-serif;
  font-size: clamp(1.365rem, 3.36vw, 2.625rem);
  line-height: 0.98;
  letter-spacing: 0.0428em;
  text-transform: uppercase;
  color: #f2f5ff;
}

.download-subhead {
  margin: 0.62rem 0 0;
  font-family: "AgencyBold", sans-serif;
  font-size: clamp(0.95rem, 1.8vw, 1.3rem);
  line-height: 1.22;
  letter-spacing: 0.0428em;
  text-transform: uppercase;
  color: #ecefff;
}

.download-body {
  margin: 0.92rem 0 0;
  font-family: "AgencyBold", sans-serif;
  font-size: clamp(1.02rem, 1.5vw, 1.2rem);
  line-height: 1.42;
  letter-spacing: normal;
  color: #ecefff;
  max-width: 70ch;
}

.download-body-safety {
  display: block;
  margin-top: 0.55rem;
  font-size: calc(clamp(1.02rem, 1.5vw, 1.2rem) + 5pt);
  line-height: 1.22;
}

.download-actions {
  margin-top: 1rem;
}

.download-cta {
  display: inline-block;
  font-family: "AgencyBold", sans-serif;
  font-size: clamp(0.98rem, 1.5vw, 1.2rem);
  line-height: 1;
  letter-spacing: 0.0428em;
  text-transform: uppercase;
  text-decoration: none;
  color: #001;
  background: #00ffff;
  border: 1px solid #65ffff;
  box-shadow: 0 0 0 1px rgba(255, 255, 255, 0.08) inset;
  padding: 0.9rem 1.1rem;
  transition: background 120ms linear, color 120ms linear;
}

.download-cta:hover,
.download-cta:focus-visible {
  background: #f2f5ff;
  color: #000140;
  outline: none;
}

.download-version {
  margin: 0.62rem 0 0;
  font-family: "AgencyBold", sans-serif;
  font-size: clamp(0.98rem, 1.4vw, 1.08rem);
  line-height: 1.3;
  letter-spacing: normal;
  color: #dbe0ff;
}

.download-hero-image {
  width: 100%;
  max-width: 480px;
  justify-self: center;
  border: 1px solid rgba(128, 129, 255, 0.38);
}

.download-details {
  display: grid;
  grid-template-columns: repeat(2, minmax(280px, 1fr));
  gap: 16px;
}

.download-panel {
  background: rgba(0, 1, 64, 0.35);
  border: 1px solid rgba(128, 129, 255, 0.32);
  padding: 1rem;
}

.download-panel h2 {
  margin: 0 0 0.65rem;
  font-family: "AgencyBold", sans-serif;
  font-size: clamp(1.2rem, 2vw, 1.65rem);
  line-height: 1.02;
  letter-spacing: 0.0428em;
  text-transform: uppercase;
  color: #00ffff;
}

.download-panel ul {
  margin: 0;
  padding-left: 1.15rem;
}

.download-panel li {
  font-family: "AgencyBold", sans-serif;
  font-size: clamp(1rem, 1.42vw, 1.15rem);
  line-height: 1.35;
  letter-spacing: normal;
  color: #ecefff;
}

.download-panel li + li {
  margin-top: 0.45rem;
}

@media (max-width: 960px) {
  .download-hero {
    grid-template-columns: 1fr;
  }

  .download-hero-image {
    max-width: min(560px, 92vw);
  }

  .download-details {
    grid-template-columns: 1fr;
  }
}



