:root {
  --bg: #d6ddd8;
  --paper: #f6f3ec;
  --stone: #e3dacb;
  --ink: #111418;
  --muted: #626a73;
  --line: #d9dedc;
  --night: #111821;
  --blue: #123142;
  --petrol: #17485a;
  --green: #285344;
  --gold: #b99a5f;
  --shadow: 0 18px 60px rgba(13, 24, 34, .16);
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  color: var(--ink);
  background: var(--bg);
  line-height: 1.55;
}
a { color: inherit; text-decoration: none; }
p { margin: 0 0 1rem; }
h1, h2, h3 { margin: 0; line-height: 1.08; letter-spacing: 0; }
h1 { font-size: clamp(2.7rem, 7vw, 6.8rem); max-width: 980px; }
h2 { font-size: clamp(2rem, 4vw, 4.4rem); max-width: 880px; }
h3 { font-size: 1.2rem; }

.site-header {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 50;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding: 1rem 1.6rem;
  color: #fff;
  background: linear-gradient(180deg, rgba(8, 12, 16, .86), rgba(8, 12, 16, .35));
  border-bottom: 1px solid rgba(255,255,255,.12);
  transition: background .2s ease, color .2s ease;
}
.site-header.scrolled { background: rgba(17,24,33,.96); }
.brand { display: flex; align-items: center; gap: .8rem; min-width: 260px; }
.brand-mark {
  width: 42px; height: 42px; display: grid; place-items: center;
  border: 1px solid rgba(255,255,255,.36); color: #fff; font-weight: 800;
  background: rgba(255,255,255,.08);
}
.brand-mark svg { width: 31px; height: 31px; display: block; }
.mark-frame { fill: rgba(255,255,255,.04); stroke: rgba(255,255,255,.82); stroke-width: 2; }
.mark-line { fill: none; stroke: rgba(255,255,255,.72); stroke-width: 2; stroke-linecap: square; }
.mark-accent { fill: var(--gold); opacity: .95; }
.brand small { display: block; color: rgba(255,255,255,.68); font-size: .78rem; }
.brand em {
  display: inline-flex;
  margin-left: .45rem;
  padding-left: .55rem;
  border-left: 1px solid rgba(255,255,255,.28);
  color: var(--gold);
  font-style: normal;
  font-size: .86rem;
  font-weight: 800;
  white-space: nowrap;
}
.nav { display: flex; align-items: center; gap: 1.1rem; font-size: .92rem; }
.nav a { color: rgba(255,255,255,.82); }
.nav a:hover { color: #fff; }
.nav-cta { border: 1px solid rgba(255,255,255,.34); padding: .72rem 1rem; background: rgba(255,255,255,.08); }
.nav-toggle { display: none; color: #fff; background: transparent; border: 1px solid rgba(255,255,255,.3); padding: .5rem .7rem; font-size: 1.2rem; }

.hero {
  min-height: 94vh;
  position: relative;
  display: grid;
  align-items: end;
  overflow: hidden;
  color: #fff;
  padding: 9rem 1.4rem 4rem;
}
.hero-bg, .hero-overlay { position: absolute; inset: 0; }
.hero-bg {
  background:
    url("https://images.unsplash.com/photo-1551836022-d5d88e9218df?auto=format&fit=crop&w=2400&q=82") center/cover no-repeat;
  transform: scale(1.02);
}
.hero-overlay { background: linear-gradient(90deg, rgba(9,14,20,.95), rgba(9,14,20,.72), rgba(9,14,20,.25)); }
.hero-content { position: relative; max-width: 1220px; width: 100%; margin: 0 auto; }
.eyebrow {
  color: var(--gold);
  text-transform: uppercase;
  font-weight: 800;
  letter-spacing: .08em;
  font-size: .78rem;
  margin-bottom: 1rem;
}
.hero-copy { max-width: 780px; font-size: clamp(1.1rem, 2vw, 1.45rem); color: rgba(255,255,255,.84); margin-top: 1.2rem; }
.hero-actions { display: flex; flex-wrap: wrap; gap: .8rem; margin: 2rem 0; }
.btn {
  display: inline-flex; align-items: center; justify-content: center;
  min-height: 48px; padding: .9rem 1.15rem; border: 1px solid transparent;
  font-weight: 800; cursor: pointer; transition: transform .18s ease, background .18s ease;
}
.btn:hover { transform: translateY(-1px); }
.primary { background: var(--green); color: #fff; }
.ghost { border-color: rgba(255,255,255,.36); color: #fff; background: rgba(255,255,255,.08); }
.trust-strip { display: grid; grid-template-columns: repeat(4, 1fr); border: 1px solid rgba(255,255,255,.18); background: rgba(17,24,33,.52); backdrop-filter: blur(12px); }
.trust-strip span { padding: 1rem; border-right: 1px solid rgba(255,255,255,.12); color: rgba(255,255,255,.82); font-weight: 700; }
.trust-strip span:last-child { border-right: 0; }

.section {
  padding: clamp(4rem, 8vw, 7rem) 1.4rem;
  background:
    linear-gradient(135deg, rgba(18,49,66,.075), transparent 44%),
    var(--bg);
}
.container { max-width: 1220px; margin: 0 auto; }
.intro {
  background:
    linear-gradient(135deg, rgba(18,49,66,.06), transparent 42%),
    var(--stone);
}
.two-col { display: grid; grid-template-columns: .9fr 1.1fr; gap: clamp(2rem, 6vw, 5rem); align-items: start; }
.rich-text { font-size: 1.08rem; color: #303740; }
.dark {
  background:
    radial-gradient(circle at 12% 0%, rgba(185,154,95,.12), transparent 34%),
    linear-gradient(135deg, #10161f, #132533 58%, #0c1118);
  color: #fff;
}
.dark p, .dark li { color: rgba(255,255,255,.74); }
.muted {
  background:
    linear-gradient(180deg, #d6ddd8, #e3e7e2);
}
.seo-band {
  background: #0f1a23;
  padding: 1rem 1.4rem;
  border-top: 1px solid rgba(255,255,255,.08);
  border-bottom: 1px solid rgba(255,255,255,.08);
}
.seo-grid {
  display: flex;
  flex-wrap: wrap;
  gap: .65rem;
}
.seo-grid a {
  color: rgba(255,255,255,.84);
  border: 1px solid rgba(255,255,255,.16);
  padding: .55rem .75rem;
  font-size: .88rem;
  font-weight: 800;
  background: rgba(255,255,255,.04);
}
.seo-grid a:hover {
  color: #fff;
  border-color: rgba(185,154,95,.55);
}
.section-head { margin-bottom: 2rem; }
.section-head p:not(.eyebrow) { max-width: 720px; color: var(--muted); font-size: 1.08rem; margin-top: 1rem; }
.dark .section-head p:not(.eyebrow) { color: rgba(255,255,255,.7); }

.problem-grid, .service-grid, .pricing-grid, .resource-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1rem;
}
.problem-grid article, .card, .pricing-grid article, .resource-grid article, .package-list article {
  background: var(--paper);
  border: 1px solid #d4cfc4;
  padding: 1.35rem;
  box-shadow: none;
}
.card, .package-list article, .resource-grid article {
  background: rgba(246,243,236,.92);
  box-shadow: 0 18px 44px rgba(18, 49, 66, .08);
}
.dark .problem-grid article { background: rgba(255,255,255,.045); border-color: rgba(255,255,255,.14); }
.dark .pricing-grid article {
  background:
    linear-gradient(145deg, #1f6f55, #154b3c 64%, #123d33);
  border-color: rgba(160, 235, 199, .72);
  box-shadow: inset 0 0 0 1px rgba(210, 255, 231, .16), 0 24px 60px rgba(0,0,0,.2);
}
.problem-grid span { color: var(--gold); font-weight: 900; display: block; margin-bottom: 1.6rem; }
.service-grid { grid-template-columns: repeat(3, 1fr); }
.card p, .resource-grid p, .package-list p { color: var(--muted); }

.timeline {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  border-top: 1px solid var(--line);
  border-left: 1px solid var(--line);
}
.timeline div { padding: 1.4rem; border-right: 1px solid #c5ccc7; border-bottom: 1px solid #c5ccc7; background: rgba(246,243,236,.86); }
.timeline p { color: var(--muted); margin-top: .6rem; }

.split-image { display: grid; grid-template-columns: 1fr 1fr; padding: 0; background: #172b36; color: #fff; }
.image-panel { min-height: 620px; background: url("https://images.unsplash.com/photo-1450101499163-c8848c66ca85?auto=format&fit=crop&w=1800&q=82") center/cover no-repeat; }
.split-content { padding: clamp(3rem, 7vw, 7rem); align-self: center; }
.comparison { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; margin-top: 2rem; }
.comparison div { border: 1px solid rgba(255,255,255,.18); padding: 1rem; background: rgba(255,255,255,.06); }
.comparison b, .comparison span { display: block; }
.comparison span { color: rgba(255,255,255,.72); padding-top: .7rem; }

.package-list { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; }
.pricing-grid {
  grid-template-columns: repeat(3, 1fr);
  align-items: stretch;
}
.pricing-grid article {
  min-height: 520px;
  display: flex;
  flex-direction: column;
  position: relative;
}
.pricing-grid .featured {
  background:
    linear-gradient(145deg, #278b68, #18614d 64%, #114537);
  border-color: rgba(197, 255, 224, .9);
  box-shadow: inset 0 0 0 1px rgba(221, 255, 237, .24), 0 30px 78px rgba(0,0,0,.26);
}
.pricing-grid ul { padding-left: 1.2rem; }
.price-tag {
  display: inline-flex;
  align-items: center;
  gap: .42rem;
  width: fit-content;
  color: #073326;
  background: #b7f0ce;
  border: 1px solid rgba(231, 255, 240, .85);
  box-shadow: 0 10px 28px rgba(5, 42, 31, .18);
  padding: .48rem .7rem;
  font-size: .82rem;
  font-weight: 900;
  margin-bottom: 1rem;
}
.price-tag::before {
  content: "";
  width: .72rem;
  height: .72rem;
  display: inline-block;
  border-radius: 50%;
  background:
    linear-gradient(135deg, transparent 48%, #073326 50%) 36% 54% / 38% 22% no-repeat,
    linear-gradient(45deg, transparent 46%, #073326 48%) 57% 47% / 46% 24% no-repeat,
    rgba(7,51,38,.08);
  border: 1px solid rgba(7,51,38,.35);
}
.package-cta {
  display: inline-flex;
  justify-content: center;
  margin-top: auto;
  padding: .82rem 1rem;
  border: 1px solid rgba(255,255,255,.24);
  color: #fff;
  font-weight: 900;
  background: rgba(255,255,255,.08);
}
.package-cta:hover {
  border-color: var(--gold);
  background: rgba(185,154,95,.14);
}
.pricing-note {
  margin-top: 1.2rem;
  max-width: 900px;
  color: rgba(255,255,255,.68);
  font-size: .95rem;
}
.sector-grid { display: grid; grid-template-columns: repeat(5, 1fr); gap: .8rem; }
.sector-grid span { padding: 1rem; background: #f6f3ec; border: 1px solid #d4cfc4; font-weight: 800; }

.diagnostic { display: grid; grid-template-columns: .85fr 1fr; gap: 2rem; align-items: start; }
.diagnostic-box, .lead-form { background: #f6f3ec; padding: 1.4rem; border: 1px solid #d2cabd; box-shadow: var(--shadow); }
label { display: grid; gap: .4rem; font-weight: 800; margin-bottom: 1rem; }
input, select, textarea {
  width: 100%; border: 1px solid #c8c0b3; background: #fffaf1; color: var(--ink);
  padding: .85rem; font: inherit; border-radius: 0;
}
textarea { resize: vertical; }
.diagnostic-result, .form-success { color: var(--green); font-weight: 800; margin-top: 1rem; }

.resource-grid { grid-template-columns: repeat(3, 1fr); }
.resource-grid small { color: var(--gold); font-weight: 900; }
.accordion { max-width: 900px; }
.accordion button {
  width: 100%; display: flex; justify-content: space-between; align-items: center;
  padding: 1.1rem 0; border: 0; border-bottom: 1px solid var(--line); background: transparent;
  font: inherit; font-weight: 900; color: var(--ink); text-align: left; cursor: pointer;
}
.accordion div { display: none; color: var(--muted); padding: 1rem 0; }
.accordion button.active + div { display: block; }

.contact {
  background:
    linear-gradient(135deg, rgba(185,154,95,.12), transparent 36%),
    linear-gradient(145deg, #102f3f, #0f2633 62%, #09131c);
  color: #fff;
}
.contact p { color: rgba(255,255,255,.74); }
.contact-grid { display: grid; grid-template-columns: .8fr 1.2fr; gap: 2rem; align-items: start; }
.contact h2 { font-size: clamp(2.1rem, 4vw, 4.2rem); }
.contact-direct {
  display: grid;
  gap: .35rem;
  margin: 1.8rem 0 0;
  padding: 1.1rem;
  border: 1px solid rgba(255,255,255,.18);
  background: rgba(255,255,255,.06);
  font-weight: 900;
}
.contact-direct a { color: #fff; }
.contact-direct span { color: rgba(255,255,255,.76); }
.legal-note { border-left: 3px solid var(--gold); padding-left: 1rem; color: rgba(255,255,255,.78); margin-top: 2rem; }
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; }
.lead-form label { color: var(--ink); }
.lead-form input, .lead-form select, .lead-form textarea { color: var(--ink); }
.lead-form input::placeholder, .lead-form textarea::placeholder { color: #8a9299; }
.checkbox { display: flex; align-items: flex-start; gap: .6rem; font-weight: 600; color: #334; }
.checkbox input { width: auto; margin-top: .25rem; }

.footer { background: #070b10; color: #fff; padding: 2.5rem 1.4rem; border-top: 1px solid rgba(255,255,255,.08); }
.footer-grid { display: grid; grid-template-columns: 2fr 1fr 1fr 1fr; gap: 2rem; }
.footer p, .footer a { color: rgba(255,255,255,.65); }
.footer a { display: block; margin-top: .45rem; }
.footer span { display: block; margin-top: .45rem; color: rgba(255,255,255,.65); }

.landing-page { padding-top: 0; }
.landing-hero {
  min-height: 760px;
  display: grid;
  align-items: center;
  padding: clamp(11rem, 16vw, 14rem) 1.4rem clamp(5rem, 8vw, 7rem);
  color: #fff;
  background:
    linear-gradient(90deg, rgba(9,14,20,.96), rgba(15,38,51,.88), rgba(15,38,51,.62)),
    url("https://images.unsplash.com/photo-1497366754035-f200968a6e72?auto=format&fit=crop&w=2200&q=82") center/cover no-repeat;
}
.landing-hero h1 {
  max-width: 980px;
  color: #fff;
  font-size: clamp(3.1rem, 6vw, 5.8rem);
}
.landing-hero .hero-copy { color: rgba(255,255,255,.82); }
.open-static { display: flex; }
.landing-page .dark .card {
  background: rgba(255,255,255,.06);
  border-color: rgba(255,255,255,.16);
}
.landing-page .dark .card p { color: rgba(255,255,255,.72); }

@media (max-width: 920px) {
  .nav-toggle { display: block; }
  .nav {
    position: absolute; top: 100%; left: 0; right: 0; display: none; flex-direction: column; align-items: stretch;
    padding: 1rem; background: rgba(17,24,33,.98);
  }
  .nav.open { display: flex; }
  .nav.open-static { display: none; }
  .brand { min-width: 0; }
  .brand em { display: block; margin-left: 0; padding-left: 0; border-left: 0; font-size: .72rem; }
  .brand small { display: none; }
  .trust-strip, .problem-grid, .service-grid, .timeline, .split-image, .package-list, .pricing-grid, .sector-grid, .diagnostic, .resource-grid, .contact-grid, .footer-grid, .two-col {
    grid-template-columns: 1fr;
  }
  .hero { min-height: 860px; }
  .image-panel { min-height: 360px; }
  .comparison, .form-row { grid-template-columns: 1fr; }
}

@media (max-width: 520px) {
  .site-header { padding: .8rem 1rem; }
  .brand-mark { width: 36px; height: 36px; }
  .hero { padding-left: 1rem; padding-right: 1rem; }
  .section { padding-left: 1rem; padding-right: 1rem; }
}
