/**
 * @file
 * Pikes Peak 3D wireframe hero banner.
 * Layout inspired by business-card reference: dark navy left panel with
 * title/CTA, nav overlaid top-right of banner, 3D scene fills right side.
 */

:root {
  --pp-navy: #0a1f3a;
  --pp-navy-deep: #071629;
  --pp-bg: #f5f7fa;
  --pp-card: #ffffff;
  --pp-teal: #2563eb;        /* primary blue (replaces teal) */
  --pp-teal-hover: #1d4ed8;  /* darker blue on hover */
  --pp-teal-light: #60a5fa;  /* lighter blue for dark backgrounds */
  --pp-text: #0f172a;
  --pp-heading: #0a1f3a;
  --pp-muted: #475569;
  --pp-border: rgba(15, 23, 42, 0.08);
}

/* Whole front page light */
.path-frontpage,
.pp-front {
  background: var(--pp-bg);
  color: var(--pp-text);
}

.pp-front .main-area {
  background: var(--pp-bg);
}

/* ============ HERO — unified light background, full-width 3D scene ============ */
.pp-hero {
  position: relative;
  height: 78vh;
  min-height: 560px;
  max-height: 780px;
  overflow: hidden;
  background: linear-gradient(135deg, #f5f7fa 0%, #e2e8f0 60%, #cbd5e1 100%);
  color: var(--pp-heading);
  font-family: 'Inter', -apple-system, sans-serif;
  margin: 0;
}

/* 3D scene spans the FULL banner width — wireframe flows behind text too */
.pp-hero__scene,
.pp-hero__right {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  z-index: 0;
  overflow: hidden;
  background: transparent;
}

/* Remove the right-side wrapper visual — the inner canvas fills everything */
.pp-hero__right::before { content: none; }

/* Text overlays the full-width scene on the left — pushed toward lower half */
.pp-hero__left {
  position: absolute;
  top: 0;
  left: 0;
  bottom: 0;
  width: min(52%, 720px);
  max-width: calc(100% - 48px);
  z-index: 10;
  background: transparent;
  padding: 8vh 4vw 8vh 5vw;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
}

.pp-hero__title-line1,
.pp-hero__title-line2 {
  white-space: nowrap;
}

/* ============ LEFT PANEL CONTENT (on light bg) ============ */
.pp-hero__badge {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: rgba(37, 99, 235, 0.08);
  border: 1px solid rgba(37, 99, 235, 0.3);
  border-radius: 100px;
  padding: 6px 16px;
  font-size: 11px;
  color: var(--pp-teal);
  margin-bottom: 28px;
  font-weight: 600;
  letter-spacing: 1px;
  text-transform: uppercase;
  width: fit-content;
}

.pp-hero__badge-dot {
  width: 6px; height: 6px;
  background: #22c55e;
  border-radius: 50%;
  animation: pp-pulse 2s infinite;
}

/* Title: first line solid navy, second line outline-navy */
.pp-hero__title {
  font-size: clamp(40px, 5.5vw, 68px);
  font-weight: 800;
  line-height: 1;
  letter-spacing: -1.5px;
  margin: 0 0 24px 0;
  text-shadow: 0 1px 0 rgba(245, 247, 250, 0.8), 0 0 18px rgba(245, 247, 250, 0.9);
}

.pp-hero__title-line1,
.pp-hero__title-line2 {
  display: block;
  color: var(--pp-heading);
  -webkit-text-stroke: 0;
  -moz-text-stroke: 0;
  text-stroke: 0;
}

/* Subtitle — italic, muted slate */
.pp-hero__subtitle {
  font-style: italic;
  font-size: 14px;
  color: var(--pp-muted);
  max-width: 420px;
  line-height: 1.6;
  margin: 0 0 32px 0;
  position: relative;
  padding-left: 16px;
  border-left: 1px solid rgba(71, 85, 105, 0.3);
  text-shadow: 0 1px 0 rgba(245, 247, 250, 0.9), 0 0 10px rgba(245, 247, 250, 0.9);
}

.pp-hero__buttons {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
}

.pp-hero__btn {
  display: inline-block;
  padding: 11px 28px;
  border-radius: 4px;
  font-size: 11px;
  font-weight: 600;
  text-decoration: none;
  transition: all 0.2s;
  cursor: pointer;
  border: 1px solid transparent;
  letter-spacing: 2px;
  text-transform: uppercase;
}

.pp-hero__btn--primary {
  background: var(--pp-teal);
  color: #ffffff;
}
.pp-hero__btn--primary:hover {
  background: var(--pp-teal-hover);
  color: #ffffff;
  transform: translateY(-1px);
  box-shadow: 0 4px 16px rgba(37, 99, 235, 0.3);
}

.pp-hero__btn--ghost {
  background: transparent;
  color: var(--pp-heading);
  border-color: rgba(10, 31, 58, 0.3);
}
.pp-hero__btn--ghost:hover {
  border-color: var(--pp-teal);
  color: var(--pp-teal);
}

/* ============ NAV OVERLAY (top-right of banner, matches inner-page layout) ============ */
.pp-front .site-header {
  position: absolute;
  top: 0;
  right: 0;
  left: 0;
  width: 100%;
  z-index: 30;
  background: transparent !important;
  border: none !important;
  box-shadow: none !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
}

.pp-front .site-header__fixable,
.pp-front .site-header__inner,
.pp-front .site-header__initial,
.pp-front .site-header__inner__container {
  background: transparent !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
  box-shadow: none !important;
  border: none !important;
}

/* Remove any Olivero overlay pseudo-elements */
.pp-front .site-header::before,
.pp-front .site-header::after,
.pp-front .site-header__fixable::before,
.pp-front .site-header__fixable::after,
.pp-front .site-header__inner::before,
.pp-front .site-header__inner::after {
  display: none !important;
  background: none !important;
}

.pp-front .site-header__inner__container {
  justify-content: flex-end !important;
  padding: 24px 48px;
  gap: 12px;
  max-width: 100%;
  margin-left: auto;
  margin-right: 0;
  /* Leave left margin for the left rail (280px) */
  padding-left: calc(280px + 24px);
}

.pp-front #header-nav,
.pp-front .header-nav {
  display: flex !important;
  align-items: center;
  gap: 16px;
  margin-left: auto;
}

/* NAV text: navy on light banner bg */
.pp-front .site-header a,
.pp-front .site-header .menu a,
.pp-front .site-header nav a,
.pp-front #header-nav a,
.pp-front #header-nav a:link,
.pp-front #header-nav a:visited,
.pp-front .header-nav a,
.pp-front .header-nav a:link,
.pp-front .header-nav a:visited,
.pp-front .header-nav .menu-item a,
.pp-front .header-nav ul li a,
.pp-front .primary-nav a,
.pp-front .primary-nav__menu-link,
.pp-front [class*="primary-nav"] a,
.pp-front [class*="menu"] a {
  color: var(--pp-heading) !important;
  font-weight: 600 !important;
  font-size: 13px !important;
  letter-spacing: 1.5px !important;
  text-transform: uppercase !important;
  padding: 10px 18px !important;
  transition: color 0.2s, background 0.2s !important;
  text-decoration: none !important;
  text-shadow: none !important;
  border-radius: 4px !important;
  background: transparent !important;
  -webkit-text-fill-color: var(--pp-heading) !important;
  opacity: 1 !important;
}

.pp-front .site-header a:hover,
.pp-front #header-nav a:hover,
.pp-front .header-nav a:hover,
.pp-front .header-nav .menu-item a:hover,
.pp-front .header-nav ul li a:hover,
.pp-front .primary-nav a:hover,
.pp-front [class*="menu"] a:hover {
  color: var(--pp-teal) !important;
  -webkit-text-fill-color: var(--pp-teal) !important;
  background: rgba(37, 99, 235, 0.08) !important;
}

/* Flatten nested menu lists so they render inline */
.pp-front .site-header ul,
.pp-front .header-nav ul,
.pp-front .header-nav .menu,
.pp-front [class*="primary-nav"] ul {
  list-style: none !important;
  padding: 0 !important;
  margin: 0 !important;
  display: flex !important;
  align-items: center !important;
  gap: 14px !important;
  justify-content: flex-end !important;
}

.pp-front .header-nav ul li,
.pp-front .header-nav .menu li,
.pp-front [class*="primary-nav"] li {
  list-style: none !important;
  padding: 0 !important;
  margin: 0 !important;
  background: transparent !important;
}

/* Remove Olivero underline indicators that may be covering text */
.pp-front .site-header a::before,
.pp-front .site-header a::after {
  display: none !important;
}

/* The actual text lives inside .primary-nav__menu-link-inner — force it navy */
.pp-front .primary-nav__menu-link,
.pp-front .primary-nav__menu-link-inner,
.pp-front [class*="primary-nav__menu-link"] {
  color: var(--pp-heading) !important;
  -webkit-text-fill-color: var(--pp-heading) !important;
  background: transparent !important;
  text-decoration: none !important;
  opacity: 1 !important;
  visibility: visible !important;
}

.pp-front .primary-nav__menu-link:hover,
.pp-front .primary-nav__menu-link:hover .primary-nav__menu-link-inner,
.pp-front [class*="primary-nav__menu-link"]:hover {
  color: var(--pp-teal) !important;
  -webkit-text-fill-color: var(--pp-teal) !important;
}

.pp-front .primary-nav__menu-item {
  background: transparent !important;
}

/* Social icons bottom-right of banner */
.pp-hero__social {
  position: absolute;
  bottom: 24px;
  right: 40px;
  z-index: 15;
  display: flex;
  gap: 14px;
}

.pp-hero__social a {
  color: var(--pp-muted);
  font-size: 14px;
  transition: color 0.2s;
}
.pp-hero__social a:hover { color: var(--pp-teal); }

/* ============ DETAIL LEVEL PICKER (LOW / MED / HIGH) ============ */
.pp-detail-picker {
  position: absolute;
  top: 16px;
  left: 16px;
  z-index: 50;
  display: flex;
  gap: 4px;
  background: rgba(10, 31, 58, 0.82);
  border: 1px solid rgba(96, 165, 250, 0.3);
  border-radius: 6px;
  padding: 3px;
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
}

.pp-detail-picker button {
  appearance: none;
  border: none;
  background: transparent;
  color: #cbd5e1;
  font-family: 'JetBrains Mono', monospace;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 1.5px;
  padding: 5px 10px;
  cursor: pointer;
  border-radius: 4px;
  transition: background 0.2s, color 0.2s;
}

.pp-detail-picker button:hover {
  background: rgba(96, 165, 250, 0.15);
  color: #ffffff;
}

.pp-detail-picker button.is-active {
  background: #2563eb;
  color: #ffffff;
}

@media (max-width: 700px) {
  .pp-detail-picker { top: 10px; left: 10px; }
  .pp-detail-picker button { font-size: 9px; padding: 4px 8px; }
}

/* ============ MAIN CONTENT BELOW BANNER ============ */
.pp-main-wrapper {
  background: var(--pp-bg);
  color: var(--pp-text);
  padding: 0 0 64px 0;
}

/* Dark navy area surrounding the article bar */
.pp-front .pp-main-wrapper {
  background: var(--pp-navy-deep);
}

.pp-front .main-area {
  background: var(--pp-navy-deep);
}

/* Articles block sits flush with banner */
.pp-front .pp-main-wrapper .main-content {
  padding-top: 0;
}

.pp-front .pp-main-wrapper .main-content > *:first-child,
.pp-front .pp-main-wrapper .main-content__container > *:first-child,
.pp-front .pp-main-wrapper main > *:first-child,
.pp-front .pp-main-wrapper .region-content > *:first-child {
  margin-top: 0;
}

/* Kill any empty wrappers that add vertical space */
.pp-front .pp-main-wrapper .main-content > .node,
.pp-front .pp-main-wrapper .main-content > article,
.pp-front .pp-main-wrapper article.node--type-page,
.pp-front .region--highlighted,
.pp-front .region--breadcrumb,
.pp-front .region--content,
.pp-front #block-peak-ai-design-content,
.pp-front .block-system-main-block,
.pp-front .pp-main-wrapper main[role="main"] {
  display: none !important;
}

/* Remove Olivero's default top padding on main */
.pp-front .pp-main-wrapper,
.pp-front .layout-main-wrapper,
.pp-front .main-content,
.pp-front .main-content__container,
.pp-front .region--content-below {
  padding-top: 0 !important;
  margin-top: 0 !important;
}

.pp-front .pp-hero + #main-wrapper,
.pp-front .pp-hero + * {
  margin-top: 0 !important;
  padding-top: 0 !important;
}

/* Front page: article bar spans full width of the main-area (not constrained) */
.pp-front .pp-main-wrapper .main-content__container,
.pp-front .pp-main-wrapper .main-content__container.container {
  background: transparent;
  max-width: 100% !important;
  width: 100%;
  padding-left: 40px;
  padding-right: 40px;
  margin: 0;
}

/* Hide the empty node 13 (Home page) wrapper entirely on front */
.pp-front .node--type-page,
.pp-front article.node--type-page,
.pp-front .node--view-mode-full.node--type-page {
  display: none !important;
}

/* Kill empty blocks that leave empty bordered boxes */
.pp-front .pp-main-wrapper .block:empty,
.pp-front .pp-main-wrapper article:empty,
.pp-front .pp-main-wrapper .views-row:empty,
.pp-front .pp-main-wrapper .node:empty {
  display: none !important;
}

/* If a block only contains a node title + empty body, still hide it */
.pp-front .pp-main-wrapper .block[data-nid="13"],
.pp-front .pp-main-wrapper article[data-nid="13"] {
  display: none !important;
}

/* Section headings — navy on light */
.pp-main-wrapper h1,
.pp-main-wrapper h2,
.pp-main-wrapper h3,
.pp-main-wrapper h4,
.pp-main-wrapper h5 {
  color: var(--pp-heading) !important;
  font-weight: 700;
  letter-spacing: -0.5px;
}

.pp-main-wrapper h2 { font-size: clamp(28px, 3.5vw, 40px); margin-bottom: 12px; }
.pp-main-wrapper h3 { font-size: 18px; }

.pp-main-wrapper h2 a,
.pp-main-wrapper h3 a,
.pp-main-wrapper h4 a {
  color: var(--pp-heading) !important;
  text-decoration: none;
}
.pp-main-wrapper h2 a:hover,
.pp-main-wrapper h3 a:hover,
.pp-main-wrapper h4 a:hover { color: var(--pp-teal) !important; }

.pp-main-wrapper p {
  color: var(--pp-text);
  line-height: 1.7;
  font-size: 15px;
}

/* Section intro text */
.pp-main-wrapper .field--name-body > p:first-child,
.pp-main-wrapper .region-content > section p,
.pp-main-wrapper .block > p {
  color: var(--pp-muted);
  font-size: 16px;
}

.pp-main-wrapper a {
  color: var(--pp-teal);
  text-decoration: none;
}
.pp-main-wrapper a:hover { color: var(--pp-teal-hover); }

/* Block / section containers */
.pp-main-wrapper .block,
.pp-main-wrapper .views-element-container {
  background: transparent;
  border: none;
  border-radius: 0;
  padding: 0;
  margin-bottom: 24px;
}

/* Articles bar — dark navy panel, very compact (~20-25% of viewport) */
.pp-front .pp-main-wrapper .block--latest-articles-block,
.pp-front .pp-main-wrapper [id*="latest-articles"],
.pp-front .pp-main-wrapper .views-element-container {
  background: var(--pp-navy);
  border: 1px solid var(--pp-navy-deep);
  border-radius: 10px;
  padding: 10px 16px;
  margin: 0;
  box-shadow: 0 4px 16px rgba(10, 31, 58, 0.15);
}

/* Headings inside the dark article bar — white */
.pp-front .pp-main-wrapper .block--latest-articles-block h1,
.pp-front .pp-main-wrapper .block--latest-articles-block h2,
.pp-front .pp-main-wrapper .block--latest-articles-block h3,
.pp-front .pp-main-wrapper [id*="latest-articles"] h1,
.pp-front .pp-main-wrapper [id*="latest-articles"] h2,
.pp-front .pp-main-wrapper [id*="latest-articles"] h3,
.pp-front .pp-main-wrapper .views-element-container > .block__title,
.pp-front .pp-main-wrapper .views-element-container h1,
.pp-front .pp-main-wrapper .views-element-container h2,
.pp-front .pp-main-wrapper .views-element-container > h3 {
  color: #ffffff !important;
}

/* Carousel arrows on dark bar */
.pp-front .pp-main-wrapper .views-element-container .slick-arrow,
.pp-front .pp-main-wrapper .views-element-container button[aria-label*="previous" i],
.pp-front .pp-main-wrapper .views-element-container button[aria-label*="next" i] {
  color: #ffffff !important;
  background: rgba(255, 255, 255, 0.1) !important;
  border: 1px solid rgba(255, 255, 255, 0.2) !important;
  box-shadow: none !important;
}

/* "View All Articles" inside dark bar */
.pp-front .pp-main-wrapper .views-element-container .more-link,
.pp-front .pp-main-wrapper .views-element-container .more-link a,
.pp-front .pp-main-wrapper .views-element-container a.more-link {
  color: var(--pp-teal-light);
  border-color: rgba(96, 165, 250, 0.5);
}

.pp-front .pp-main-wrapper .views-element-container .more-link:hover,
.pp-front .pp-main-wrapper .views-element-container a.more-link:hover {
  background: var(--pp-teal-light);
  color: var(--pp-navy);
  border-color: var(--pp-teal-light);
}

.pp-main-wrapper article,
.pp-main-wrapper .node,
.pp-main-wrapper .views-row {
  background: #ffffff;
  border: 1px solid var(--pp-border);
  border-radius: 8px;
  padding: 0;
  margin-bottom: 0;
  overflow: hidden;
  transition: border-color 0.2s, box-shadow 0.2s, transform 0.2s;
  box-shadow: 0 1px 3px rgba(10, 31, 58, 0.06);
  max-height: 180px;
}

.pp-main-wrapper .views-row img {
  max-height: 100px;
  object-fit: cover;
  width: 100%;
}

.pp-main-wrapper article:hover,
.pp-main-wrapper .node:hover,
.pp-main-wrapper .views-row:hover {
  border-color: rgba(37, 99, 235, 0.4);
  box-shadow: 0 4px 20px rgba(10, 31, 58, 0.12);
  transform: translateY(-2px);
}

/* Article card titles: navy on white, compact */
.pp-main-wrapper article h2,
.pp-main-wrapper article h3,
.pp-main-wrapper .node h2,
.pp-main-wrapper .node h3,
.pp-main-wrapper .views-row h2,
.pp-main-wrapper .views-row h3,
.pp-main-wrapper .node__title,
.pp-main-wrapper .views-field-title,
.pp-main-wrapper .views-field-title a,
.pp-main-wrapper .node__title a {
  color: var(--pp-heading) !important;
  font-size: 12px;
  font-weight: 700;
  line-height: 1.25;
  padding: 6px 10px;
  margin: 0;
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  background: transparent;
  text-decoration: none;
  max-height: 60px;
  overflow: hidden;
}

.pp-main-wrapper article:hover h3,
.pp-main-wrapper article:hover .views-field-title a,
.pp-main-wrapper .views-row:hover .views-field-title a {
  color: var(--pp-teal) !important;
}

.pp-main-wrapper img {
  border-radius: 4px 4px 0 0;
  max-width: 100%;
  height: auto;
  display: block;
}

/* Explore Services / big CTA buttons in content — match teal palette */
.pp-main-wrapper .button,
.pp-main-wrapper a.button,
.pp-main-wrapper input[type="submit"],
.pp-main-wrapper .btn-primary,
.pp-main-wrapper a.btn-primary,
.pp-main-wrapper a[class*="explore"],
.pp-front .button--primary {
  background: var(--pp-teal) !important;
  color: var(--pp-navy) !important;
  border: none !important;
  padding: 14px 36px !important;
  border-radius: 4px !important;
  font-size: 13px !important;
  font-weight: 700 !important;
  letter-spacing: 1.5px !important;
  text-transform: uppercase !important;
  text-decoration: none !important;
  display: inline-block !important;
  transition: background 0.2s, transform 0.2s !important;
  box-shadow: 0 2px 12px rgba(96, 165, 250, 0.2) !important;
}

.pp-main-wrapper .button:hover,
.pp-main-wrapper a.button:hover,
.pp-main-wrapper input[type="submit"]:hover,
.pp-main-wrapper .btn-primary:hover,
.pp-main-wrapper a.btn-primary:hover,
.pp-front .button--primary:hover {
  background: var(--pp-teal-hover) !important;
  transform: translateY(-1px);
}

/* "View All Articles" style link — outlined teal button on light bg */
.pp-main-wrapper .more-link,
.pp-main-wrapper .more-link a,
.pp-main-wrapper a.more-link,
.pp-main-wrapper a[href*="articles"]:not(.button) {
  display: inline-block;
  color: var(--pp-teal);
  border: 1px solid var(--pp-teal);
  padding: 10px 24px;
  border-radius: 4px;
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  text-decoration: none;
  transition: all 0.2s;
  margin: 16px auto;
  background: transparent;
}

.pp-main-wrapper .more-link:hover,
.pp-main-wrapper a.more-link:hover {
  background: var(--pp-teal);
  color: #ffffff;
}

/* Carousel / slider arrows on light bg */
.pp-main-wrapper .slick-arrow,
.pp-main-wrapper .carousel-control,
.pp-main-wrapper button[aria-label*="previous" i],
.pp-main-wrapper button[aria-label*="next" i] {
  color: var(--pp-navy) !important;
  background: #ffffff !important;
  border: 1px solid var(--pp-border) !important;
  box-shadow: 0 2px 8px rgba(10, 31, 58, 0.1) !important;
}

/* Footer — navy stays dark for contrast */
.pp-front .site-footer {
  background: var(--pp-navy-deep);
  border-top: 1px solid var(--pp-border);
  color: #cbd5e1;
  padding: 40px 0;
}

.pp-front .site-footer a,
.pp-front .site-footer h1,
.pp-front .site-footer h2,
.pp-front .site-footer h3 { color: #ffffff !important; }

/* Footer dark */
.pp-front .site-footer {
  background: var(--pp-navy-deep);
  border-top: 1px solid var(--pp-border);
  color: var(--pp-muted);
  padding: 40px 0;
}

.pp-front .site-footer a { color: var(--pp-text); }

/* ============ RESPONSIVE — mobile: nav only, no banner ============ */
@media (max-width: 900px) {
  /* Aggressively hide the left rail on mobile */
  .pp-front .left-rail,
  .page-wrapper.has-left-rail > #page > .left-rail,
  aside.left-rail {
    display: none !important;
  }

  /* Main area fills width on mobile */
  .pp-front .main-area,
  .page-wrapper.has-left-rail > #page > .main-area {
    margin-left: 0 !important;
    padding-left: 0 !important;
    width: 100% !important;
    background: var(--pp-navy-deep) !important;
  }

  /* Shrink hero to just the nav bar — hide banner content */
  .pp-hero {
    height: auto;
    min-height: 0;
    max-height: none;
    padding: 0;
    background: var(--pp-navy) !important;
  }

  /* Hide all 3D scene and banner content on mobile */
  .pp-hero__scene,
  .pp-hero__right,
  .pp-hero__left,
  .pp-hero__social,
  .pp-hero__scroll {
    display: none !important;
  }

  /* Nav bar: full-width, solid navy */
  .pp-front .site-header,
  .pp-front .site-header__fixable,
  .pp-front .site-header__inner,
  .pp-front .site-header__initial,
  .pp-front .site-header__inner__container {
    position: relative !important;
    top: auto !important;
    right: auto !important;
    left: auto !important;
    width: 100% !important;
    padding: 0 !important;
    background: var(--pp-navy) !important;
    border: none !important;
    box-shadow: none !important;
    backdrop-filter: none !important;
    -webkit-backdrop-filter: none !important;
  }

  .pp-front .site-header {
    border-bottom: 1px solid rgba(255, 255, 255, 0.08) !important;
  }

  .pp-front .site-header__inner__container {
    justify-content: center !important;
    padding: 12px 16px !important;
    flex-wrap: wrap;
    gap: 4px;
  }

  .pp-front .header-nav a,
  .pp-front .primary-nav__menu-link,
  .pp-front .primary-nav__menu-link-inner,
  .pp-front .header-nav a:link,
  .pp-front .header-nav a:visited,
  .pp-front .site-header a,
  .pp-front [class*="primary-nav"] a {
    color: #64748b !important;
    -webkit-text-fill-color: #64748b !important;
    padding: 6px 10px !important;
    font-size: 11px !important;
    letter-spacing: 1px !important;
    text-shadow: none !important;
  }

  .pp-front .header-nav a:hover,
  .pp-front .primary-nav__menu-link:hover,
  .pp-front .primary-nav__menu-link:hover .primary-nav__menu-link-inner,
  .pp-front [class*="primary-nav"] a:hover {
    color: var(--pp-teal) !important;
    -webkit-text-fill-color: var(--pp-teal) !important;
    background: rgba(37, 99, 235, 0.08) !important;
  }

  /* Hide left rail logo on mobile */
  .left-rail { display: none; }
  .pp-front .main-area { margin-left: 0; }
}

@media (max-width: 500px) {
  .pp-front .site-header__inner__container { padding: 10px 8px; }
  .pp-front .header-nav a,
  .pp-front .primary-nav__menu-link,
  .pp-front .primary-nav__menu-link-inner,
  .pp-front .site-header a {
    color: #64748b !important;
    -webkit-text-fill-color: #64748b !important;
    padding: 5px 8px !important;
    font-size: 10px !important;
    letter-spacing: 0.5px !important;
  }
}

/* Animations */
@keyframes pp-pulse {
  0%, 100% { opacity: 1; transform: scale(1); }
  50% { opacity: 0.4; transform: scale(1.8); }
}

/* ============ CITY LABELS (DOM overlay on 3D scene) ============ */
.pp-city-label {
  position: absolute;
  transform: translate(-50%, -100%);
  font-family: 'Orbitron', 'Inter', sans-serif;
  font-size: 9px;
  font-weight: 700;
  letter-spacing: 1.5px;
  color: #0a1f3a;
  background: rgba(255, 255, 255, 0.88);
  padding: 3px 8px;
  border-radius: 3px;
  border: 1px solid rgba(10, 31, 58, 0.2);
  white-space: nowrap;
  text-shadow: 0 1px 0 rgba(255, 255, 255, 0.7);
  pointer-events: none;
  box-shadow: 0 1px 3px rgba(10, 31, 58, 0.15);
}

.pp-city-label--peak {
  background: #ffffff;
  color: #0b1c2d;
  border-color: #cbd5e1;
  text-shadow: 0 1px 2px rgba(0,0,0,0.3);
  font-size: 10px;
  padding: 4px 10px;
}

/* ============ LEFT-RAIL WEATHER + CLOCK WIDGET ============ */
.pp-weather-clock {
  margin: 8px 16px 0 16px;
  padding: 8px 10px;
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: 8px;
  color: #e2e8f0;
  font-family: 'Inter', sans-serif;
  text-align: center;
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: center;
  gap: 4px;
}

.pp-weather-clock > div { flex: 1 1 auto; }
.pp-weather-clock .pp-wc-divider { display: none; }
.pp-weather-clock .pp-wc-location { flex-basis: 100%; margin-top: 4px; }

.pp-wc-time {
  font-family: 'Orbitron', 'Inter', sans-serif;
  font-size: 16px;
  font-weight: 700;
  color: #ffffff;
  letter-spacing: 0.5px;
  line-height: 1.1;
  flex: 0 0 auto;
}

.pp-wc-date {
  display: none;
}

.pp-wc-divider {
  height: 1px;
  background: rgba(255, 255, 255, 0.08);
  margin: 12px 0;
}

.pp-wc-temp {
  font-family: 'Orbitron', 'Inter', sans-serif;
  font-size: 18px;
  font-weight: 700;
  color: #60a5fa;
  line-height: 1;
  flex: 0 0 auto;
}

.pp-wc-cond {
  font-size: 9px;
  color: #94a3b8;
  letter-spacing: 1px;
  text-transform: uppercase;
  flex: 0 0 auto;
}

.pp-wc-location {
  font-size: 8px;
  color: #64748b;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  font-family: 'JetBrains Mono', monospace;
  text-align: center;
}

@media (max-width: 900px) {
  .pp-weather-clock,
  .pp-rail-card { display: none; }
  .pp-city-label { font-size: 8px; padding: 2px 6px; }
}

/* ============ LEFT-RAIL CARDS (chat, newsletter, contact) ============ */
.pp-rail-card {
  margin: 8px 16px 0 16px;
  padding: 8px 10px;
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: 8px;
  color: #cbd5e1;
  font-family: 'Inter', sans-serif;
}

.pp-rail-card__label {
  font-family: 'JetBrains Mono', monospace;
  font-size: 8px;
  letter-spacing: 2px;
  color: #60a5fa;
  text-transform: uppercase;
  margin-bottom: 4px;
}

.pp-rail-card__title {
  font-family: 'Orbitron', 'Inter', sans-serif;
  font-size: 12px;
  font-weight: 700;
  color: #ffffff;
  margin-bottom: 6px;
  letter-spacing: 0.5px;
}

.pp-rail-card__desc {
  font-size: 10px;
  color: #94a3b8;
  line-height: 1.4;
  margin: 0 0 8px 0;
}

/* Shrink and raise the logo — same treatment on front and inner pages */
.pp-front .left-rail,
.peak-inner-page .left-rail { padding-top: 10px !important; }
.pp-front .left-rail__logo,
.peak-inner-page .left-rail__logo { padding: 0 1rem 0 1rem; }
.pp-front .left-rail__logo img,
.peak-inner-page .left-rail__logo img {
  width: 130px !important;
  max-width: 130px !important;
}

/* AI chat card — taller to fit full chat */
.pp-ai-chat-card { padding: 10px 10px; }
.pp-ai-chat-target {
  height: 220px;
  width: 100%;
  background: #0b1c2d;
  border-radius: 6px;
  overflow: hidden;
  position: relative;
  display: flex;
  flex-direction: column;
}

.pp-ai-messages {
  flex: 1;
  overflow-y: auto;
  padding: 10px;
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.pp-ai-msg {
  max-width: 90%;
  padding: 8px 10px;
  border-radius: 8px;
  font-size: 12px;
  line-height: 1.4;
  white-space: pre-wrap;
  word-wrap: break-word;
}

.pp-ai-msg--bot {
  background: #1a3350;
  color: #e2e8f0;
  align-self: flex-start;
  border-bottom-left-radius: 2px;
}

.pp-ai-msg--user {
  background: #2563eb;
  color: #ffffff;
  align-self: flex-end;
  border-bottom-right-radius: 2px;
}

.pp-ai-msg--typing {
  background: #1a3350;
  color: #94a3b8;
  align-self: flex-start;
  font-style: italic;
}

.pp-ai-input-row {
  display: flex;
  gap: 3px;
  padding: 6px;
  background: rgba(0, 0, 0, 0.25);
  border-top: 1px solid rgba(255, 255, 255, 0.08);
}

.pp-ai-input {
  flex: 1;
  min-width: 0;
  padding: 6px 8px;
  background: rgba(255, 255, 255, 0.08);
  border: 1px solid rgba(255, 255, 255, 0.1);
  border-radius: 4px;
  color: #ffffff;
  font-size: 11px;
  font-family: inherit;
  outline: none;
  box-sizing: border-box;
}

.pp-ai-input:focus { border-color: #60a5fa; }
.pp-ai-input::placeholder { color: rgba(203, 213, 225, 0.4); }

.pp-ai-send {
  padding: 6px 10px;
  background: #2563eb;
  color: #ffffff;
  border: none;
  border-radius: 4px;
  font-size: 10px;
  font-weight: 700;
  cursor: pointer;
  transition: background 0.2s;
  font-family: inherit;
  letter-spacing: 1px;
  text-transform: uppercase;
}

.pp-ai-send:hover { background: #1d4ed8; }
.pp-ai-send:disabled { background: #475569; cursor: not-allowed; }

/* Hide the contrib n8n_chat floating widget on the front page — we use the inline rail version */
.pp-front [class*="chat-window-wrapper"],
.pp-front [class*="chat-toggle-wrapper"],
.pp-front [class*="n8n-chat"],
.pp-front .n8n-chat,
.pp-front #n8n-chat,
.pp-front #n8n-chat-container,
.pp-front .chat-toggle,
.pp-front .chat-window {
  display: none !important;
}

/* Newsletter form — compact */
.pp-newsletter-form {
  display: flex;
  gap: 4px;
}

.pp-newsletter-input {
  flex: 1;
  min-width: 0;
  padding: 6px 8px;
  background: rgba(255, 255, 255, 0.06);
  border: 1px solid rgba(255, 255, 255, 0.1);
  border-radius: 4px;
  color: #ffffff;
  font-size: 11px;
  font-family: inherit;
  outline: none;
  transition: border-color 0.2s;
  box-sizing: border-box;
}

.pp-newsletter-input::placeholder { color: rgba(203, 213, 225, 0.4); }
.pp-newsletter-input:focus {
  border-color: #60a5fa;
  background: rgba(255, 255, 255, 0.08);
}

.pp-newsletter-btn {
  padding: 6px 10px;
  background: #60a5fa;
  color: #0a1f3a;
  border: none;
  border-radius: 4px;
  font-size: 9px;
  font-weight: 700;
  letter-spacing: 1px;
  text-transform: uppercase;
  cursor: pointer;
  transition: background 0.2s;
  font-family: inherit;
  white-space: nowrap;
}

.pp-newsletter-btn:hover { background: #93c5fd; }

/* Contact card matches chat card width/visual box */
.pp-contact-info {
  background: #0b1c2d;
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: 6px;
  margin: 10px 16px 0 16px !important;
  padding: 10px !important;
  box-sizing: border-box;
  width: calc(100% - 32px);
}

.pp-ai-chat-card {
  margin: 10px 16px 0 16px !important;
  padding: 10px !important;
  box-sizing: border-box;
  width: calc(100% - 32px);
}

/* Contact list — compact */
.pp-contact-list {
  list-style: none;
  padding: 0;
  margin: 0 0 8px 0;
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.pp-contact-list li {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 10px;
  color: #cbd5e1;
}

.pp-contact-ico {
  color: #60a5fa;
  font-size: 14px;
  width: 18px;
  text-align: center;
  flex: 0 0 18px;
}

.pp-contact-list a {
  color: #cbd5e1;
  text-decoration: none;
  transition: color 0.2s;
  word-break: break-all;
}

.pp-contact-list a:hover { color: #60a5fa; }

/* Social row */
.pp-social-row {
  display: flex;
  gap: 6px;
  padding-top: 10px;
  border-top: 1px solid rgba(255, 255, 255, 0.06);
}

.pp-social-row a {
  flex: 1;
  padding: 6px 4px;
  text-align: center;
  color: #94a3b8;
  text-decoration: none;
  font-family: 'JetBrains Mono', monospace;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 1px;
  background: rgba(255, 255, 255, 0.04);
  border-radius: 3px;
  transition: all 0.2s;
}

.pp-social-row a:hover {
  background: #60a5fa;
  color: #0a1f3a;
}

/* =========================================================================
   PHONE - override right-aligned nav with centered layout
   ========================================================================= */
@media (max-width: 48rem) {
  .pp-front #header-nav,
  .pp-front .header-nav {
    margin-left: 0 !important;
    margin-right: 0 !important;
    width: 100% !important;
    justify-content: center !important;
    flex-wrap: wrap !important;
  }

  .pp-front .site-header ul,
  .pp-front .header-nav ul,
  .pp-front .header-nav .menu,
  .pp-front [class*="primary-nav"] ul {
    justify-content: center !important;
    flex-wrap: wrap !important;
    width: 100% !important;
  }

  .pp-front .site-header__inner__container {
    justify-content: center !important;
    flex-wrap: wrap !important;
  }
}
