:root {
  --primary: #0B1F33;
  --accent: #F2B705;
  --teal: #0EA5A4;
  --text: #F7FAFC;
  --subtle: #D8E3EA;
  --surface: #101415;
  --panel: #162C44;
  --panel-2: #1D2022;
  --outline: rgba(14, 165, 164, .22);
}

html {
  background: #0B1F33;
}

body {
  margin: 0;
  background: #0B1F33;
  color: #F7FAFC;
  font-family: "Inter", Arial, sans-serif;
  line-height: 1.7;
  letter-spacing: 0;
}

a {
  color: #F2B705;
}

a:hover,
a:focus {
  color: #F7FAFC;
}

.skip-link {
  position: absolute;
  left: -999px;
  top: 0;
  z-index: 1000;
  padding: .75rem 1rem;
  background: #F2B705;
  color: #0B1F33;
}

.skip-link:focus {
  left: 1rem;
  top: 1rem;
}

.site-header.navbar.is-primary {
  position: sticky;
  top: 0;
  z-index: 50;
  background: rgba(11, 31, 51, .96);
  border-bottom: 1px solid rgba(14, 165, 164, .22);
  min-height: 4rem;
}

.site-header .navbar-item,
.site-header .navbar-link {
  color: #F7FAFC;
  font-size: .78rem;
  font-weight: 700;
  letter-spacing: 0;
  text-transform: uppercase;
}

.site-header .navbar-item:hover,
.site-header .navbar-link:hover,
.site-header .navbar-item:focus,
.site-header .navbar-link:focus,
.site-header .navbar-link:not(.is-arrowless)::after {
  background: transparent;
  color: #F2B705;
  border-color: #F2B705;
}

.site-brand {
  color: #F7FAFC !important;
  font-family: "Sora", Arial, sans-serif;
  font-size: 1rem;
  font-weight: 800;
}

.navbar-dropdown {
  background: #162C44;
  border: 1px solid rgba(14, 165, 164, .25);
}

.phone-link {
  background: #F2B705;
  color: #0B1F33 !important;
  margin: .6rem 0 .6rem .5rem;
  border-radius: 6px;
}

.navbar-burger {
  color: #F2B705;
}

.hero.is-primary.site-hero,
.page-hero {
  background: #0B1F33;
  color: #F7FAFC;
  position: relative;
  overflow: hidden;
}

.hero.is-primary.site-hero::before,
.page-hero::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image: radial-gradient(circle at 2px 2px, rgba(14, 165, 164, .35) 1px, transparent 0);
  background-size: 40px 40px;
  opacity: .18;
}

.site-hero .hero-body {
  position: relative;
  z-index: 1;
  padding: 6.25rem 1.5rem 5rem;
}

.page-hero {
  padding: 4rem 1.5rem 3rem;
}

.page-hero > .container {
  position: relative;
  z-index: 1;
}

.compact-hero {
  border-bottom: 1px solid rgba(14, 165, 164, .22);
}

.service-hero,
.quote-hero {
  background: linear-gradient(135deg, #0B1F33 0%, #162C44 100%);
}

.title,
.content h1,
.content h2,
.content h3,
.content h4,
.footer-brand {
  color: #F7FAFC;
  font-family: "Sora", Arial, sans-serif;
  letter-spacing: 0;
}

.site-hero .title,
.page-hero .title {
  color: #F7FAFC;
  line-height: 1.05;
}

.site-hero .title span,
.eyebrow,
.status-pill,
.text-link {
  color: #F2B705;
}

.subtitle,
.lead,
.content p,
.footer-copy,
.trust-item span,
.service-card p {
  color: #D8E3EA;
}

.status-pill,
.eyebrow {
  display: inline-flex;
  align-items: center;
  gap: .5rem;
  margin-bottom: 1rem;
  font-size: .76rem;
  font-weight: 800;
  letter-spacing: 0;
  text-transform: uppercase;
}

.status-pill {
  padding: .4rem .75rem;
  border: 1px solid rgba(242, 183, 5, .35);
  border-radius: 999px;
  background: rgba(242, 183, 5, .10);
}

.hero-actions {
  display: flex;
  flex-wrap: wrap;
  gap: .85rem;
  margin-top: 2rem;
}

.button.is-warning {
  background: #F2B705;
  border-color: #F2B705;
  color: #0B1F33;
  font-weight: 800;
}

.button.is-warning:hover,
.button.is-warning:focus {
  background: #ffd150;
  border-color: #ffd150;
  color: #0B1F33;
}

.button.is-outlined {
  background: transparent;
  border-color: #0EA5A4;
  color: #0EA5A4;
  font-weight: 800;
}

.button.is-outlined:hover,
.button.is-outlined:focus {
  background: rgba(14, 165, 164, .10);
  color: #F7FAFC;
  border-color: #0EA5A4;
}

.emergency-pulse {
  animation: pulse-glow 2s infinite;
}

@keyframes pulse-glow {
  0% { box-shadow: 0 0 0 0 rgba(242, 183, 5, .40); }
  70% { box-shadow: 0 0 0 15px rgba(242, 183, 5, 0); }
  100% { box-shadow: 0 0 0 0 rgba(242, 183, 5, 0); }
}

.hero-visual,
.site-figure {
  border: 1px solid rgba(14, 165, 164, .30);
  background: #162C44;
  border-radius: 8px;
  overflow: hidden;
}

.hero-visual {
  transform: rotate(6deg);
  box-shadow: 0 24px 70px rgba(0, 0, 0, .35);
}

.hero-visual img,
.site-figure img,
.site-gallery img {
  display: block;
  width: 100%;
  height: auto;
  object-fit: cover;
}

.trust-band {
  background: #101415;
  border-top: 1px solid rgba(14, 165, 164, .18);
  border-bottom: 1px solid rgba(14, 165, 164, .18);
}

.trust-item,
.quote-panel,
.service-card,
.article-shell,
.service-sidebar,
.sidebar-cta {
  background: #162C44;
  border: 1px solid rgba(14, 165, 164, .22);
  border-radius: 8px;
}

.trust-item {
  min-height: 100%;
  padding: 1.2rem;
}

.trust-item strong,
.quote-panel strong {
  display: block;
  color: #F7FAFC;
  font-family: "Sora", Arial, sans-serif;
  font-size: 1.05rem;
}

.content-section {
  background: #0B1F33;
}

.article-shell {
  padding: clamp(1.25rem, 3vw, 2.5rem);
}

.content.article-shell h2,
.content.article-shell h3,
.content.article-shell h4 {
  margin-top: 2rem;
}

.content strong {
  color: #F7FAFC;
}

.content blockquote {
  background: rgba(14, 165, 164, .10);
  border-left-color: #0EA5A4;
  color: #D8E3EA;
}

.content table {
  background: #F7FAFC;
  color: #0B1F33;
}

.service-card {
  height: 100%;
  background: #162C44;
  color: #D8E3EA;
  transition: transform .18s ease, border-color .18s ease;
}

.service-card:hover {
  transform: translateY(-3px);
  border-color: #F2B705;
}

.service-card .title a {
  color: #F7FAFC;
}

.quote-panel {
  padding: 1.5rem;
  box-shadow: 0 18px 60px rgba(0, 0, 0, .20);
}

.phone-number {
  display: block;
  margin-top: .75rem;
  color: #F2B705;
  font-family: "Sora", Arial, sans-serif;
  font-size: 1.35rem;
  font-weight: 800;
}

.service-sidebar {
  position: sticky;
  top: 5rem;
  padding: 1rem;
}

.service-sidebar .menu-label {
  color: #F2B705;
  letter-spacing: 0;
}

.service-sidebar a {
  color: #D8E3EA;
}

.service-sidebar a:hover {
  background: rgba(14, 165, 164, .10);
  color: #F7FAFC;
}

.sidebar-cta {
  margin-top: 1rem;
  padding: 1rem;
}

.breadcrumb a {
  color: #D8E3EA;
}

.breadcrumb li.is-active a,
.breadcrumb a:hover {
  color: #F2B705;
}

.toc-list {
  margin-bottom: 1.5rem;
  padding: 1rem;
  background: #162C44;
  border: 1px solid rgba(14, 165, 164, .22);
  border-radius: 8px;
}

.toc-list ul {
  display: flex;
  flex-wrap: wrap;
  gap: .75rem 1.25rem;
  margin: 0;
  list-style: none;
}

.article-main-image {
  float: right;
  max-width: 34%;
  margin: 0 0 1rem 1.5rem;
}

.site-footer {
  background: #101415;
  border-top: 1px solid rgba(14, 165, 164, .22);
  color: #D8E3EA;
}

.footer-brand {
  margin-bottom: .75rem;
  font-size: 1.25rem;
  font-weight: 800;
}

.footer-heading {
  color: #F7FAFC;
  font-weight: 800;
  text-transform: uppercase;
}

.footer-links {
  display: grid;
  gap: .35rem;
}

.footer-links--compact {
  font-size: .9rem;
}

.footer-call {
  margin-top: 1rem;
}

@media (max-width: 768px) {
  .site-hero .hero-body {
    padding-top: 4.5rem;
  }

  .hero-visual {
    transform: none;
  }

  .page-hero {
    padding: 3rem 1rem 2rem;
  }

  .article-shell {
    padding: 1rem;
  }

  .article-main-image {
    float: none;
    max-width: 100%;
    margin: 0 0 1rem;
  }
}

@media print {
  .site-header,
  .site-footer,
  .service-sidebar,
  .hero-actions,
  .skip-link {
    display: none;
  }

  body {
    background: #fff;
    color: #000;
  }

  a {
    color: #000;
  }
}
