/* PWL Systems stable premium stylesheet - 2026-06-29
   One clean visual system: no layered overrides, no white hero panels, no hidden text. */
:root {
  --ink: #05070b;
  --ink-2: #0a1018;
  --panel: #101926;
  --panel-2: #162231;
  --paper: #f5f6f8;
  --white: #ffffff;
  --text: #101820;
  --muted: #596675;
  --soft: #eef1f5;
  --line: rgba(16, 24, 32, .14);
  --line-dark: rgba(255, 255, 255, .14);
  --gold: #f5a23b;
  --gold-2: #ffd37a;
  --copper: #c66b2b;
  --shadow: 0 22px 62px rgba(5, 10, 18, .15);
  --shadow-soft: 0 14px 34px rgba(5, 10, 18, .085);
  --radius: 18px;
  --radius-lg: 24px;
  --max: 1180px;
}

* { 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(--text);
  background:
    radial-gradient(circle at 82% 10%, rgba(245,162,59,.08), transparent 24%),
    linear-gradient(180deg, #f7f8fa 0%, #edf1f5 52%, #f7f8fa 100%);
  line-height: 1.6;
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
body.nav-open { overflow: hidden; }
main {
  position: relative;
  isolation: isolate;
  overflow: hidden;
}
main::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  background:
    radial-gradient(circle at 84% 9%, rgba(245,162,59,.09), transparent 22%),
    radial-gradient(circle at 12% 42%, rgba(16,24,32,.055), transparent 28%),
    radial-gradient(circle at 82% 76%, rgba(245,162,59,.075), transparent 24%),
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='860' height='760' viewBox='0 0 860 760'%3E%3Cg fill='none' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M42 118h164c38 0 60 22 60 60v96c0 38 22 60 60 60h176' stroke='%23f5a23b' stroke-opacity='.26' stroke-width='2.4'/%3E%3Cpath d='M114 602h154c34 0 52-18 52-52V424c0-34 18-52 52-52h160c34 0 52-18 52-52V156h164' stroke='%23101820' stroke-opacity='.115' stroke-width='1.8'/%3E%3Cpath d='M520 694V508c0-38 22-60 60-60h92c38 0 60-22 60-60v-94h82' stroke='%23c66b2b' stroke-opacity='.20' stroke-width='2.1'/%3E%3Cpath d='M54 430h98c28 0 42-14 42-42v-68' stroke='%23101820' stroke-opacity='.10' stroke-width='1.6'/%3E%3Cpath d='M628 90h-96c-34 0-52 18-52 52v58' stroke='%23f5a23b' stroke-opacity='.20' stroke-width='2'/%3E%3Ccircle cx='42' cy='118' r='5' fill='%23f5a23b' fill-opacity='.24'/%3E%3Ccircle cx='502' cy='334' r='5' fill='%23f5a23b' fill-opacity='.19'/%3E%3Ccircle cx='748' cy='156' r='5' fill='%23101820' fill-opacity='.12'/%3E%3Ccircle cx='114' cy='602' r='4.5' fill='%23101820' fill-opacity='.10'/%3E%3Ccircle cx='814' cy='294' r='4.5' fill='%23c66b2b' fill-opacity='.18'/%3E%3C/g%3E%3C/svg%3E"),
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='760' height='620' viewBox='0 0 760 620'%3E%3Cg fill='none' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M76 86v94c0 30 16 46 46 46h112c30 0 46 16 46 46v72' stroke='%23c66b2b' stroke-opacity='.17' stroke-width='1.9'/%3E%3Cpath d='M694 132H548c-32 0-50 18-50 50v98c0 32-18 50-50 50H316' stroke='%23f5a23b' stroke-opacity='.20' stroke-width='2.1'/%3E%3Cpath d='M126 500h158c28 0 44-16 44-44v-54h126c28 0 44-16 44-44v-54' stroke='%23101820' stroke-opacity='.10' stroke-width='1.7'/%3E%3Ccircle cx='76' cy='86' r='4' fill='%23c66b2b' fill-opacity='.16'/%3E%3Ccircle cx='694' cy='132' r='4.5' fill='%23f5a23b' fill-opacity='.20'/%3E%3Ccircle cx='316' cy='330' r='4.5' fill='%23f5a23b' fill-opacity='.15'/%3E%3Ccircle cx='126' cy='500' r='4' fill='%23101820' fill-opacity='.10'/%3E%3C/g%3E%3C/svg%3E"),
    linear-gradient(180deg, rgba(247,248,250,.70), rgba(238,242,246,.82));
  background-size: auto, auto, auto, 860px 760px, 760px 620px, auto;
  background-position: center, center, center, right -145px top 560px, left -155px top 840px, center;
  background-repeat: no-repeat, no-repeat, no-repeat, repeat-y, repeat-y, no-repeat;
  opacity: .95;
}
main > * {
  position: relative;
  z-index: 1;
}
img { max-width: 100%; display: block; }
a { color: inherit; text-decoration: none; }
p { margin: 0 0 1rem; color: var(--muted); }
h1, h2, h3 { margin: 0; letter-spacing: -.055em; line-height: 1.02; color: var(--text); }
h1 { font-size: clamp(3.15rem, 7.3vw, 6.35rem); font-weight: 900; text-transform: uppercase; }
h2 { font-size: clamp(2.25rem, 5vw, 4.7rem); font-weight: 900; }
h3 { font-size: clamp(1.18rem, 2vw, 1.65rem); font-weight: 850; letter-spacing: -.035em; }

.skip-link {
  position: absolute;
  left: 1rem;
  top: -4rem;
  z-index: 2000;
  background: var(--gold);
  color: var(--ink);
  padding: .75rem 1rem;
  border-radius: 999px;
  font-weight: 900;
}
.skip-link:focus { top: 1rem; }

.section, .nav-wrap, .footer-inner { width: min(calc(100% - 40px), var(--max)); margin: 0 auto; }
.section { padding: 92px 0; }
.section-overlap { margin-top: 0; padding-top: 92px; }

.site-header {
  position: sticky;
  top: 0;
  z-index: 1000;
  background: rgba(4, 7, 11, .96);
  border-bottom: 1px solid var(--line-dark);
  backdrop-filter: blur(16px);
  box-shadow: 0 10px 34px rgba(0, 0, 0, .22);
}
.nav-wrap { min-height: 84px; display: flex; align-items: center; justify-content: space-between; gap: 22px; }
.brand { display: inline-flex; align-items: center; gap: 16px; min-width: 230px; color: var(--white); }
.brand-badge {
  width: 60px;
  height: 60px;
  display: grid;
  place-items: center;
  flex: 0 0 auto;
  border-radius: 18px;
  background: #030507;
  border: 1px solid rgba(245, 162, 59, .42);
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.05), 0 12px 34px rgba(0,0,0,.28);
  overflow: hidden;
}
.brand-badge img { width: 88%; height: 88%; object-fit: contain; }
.brand-text { display: flex; flex-direction: column; font-weight: 900; font-size: 1.25rem; line-height: 1.05; letter-spacing: -.025em; }
.brand-text span { margin-top: .32rem; color: var(--gold-2); font-size: .77rem; letter-spacing: .28em; text-transform: uppercase; white-space: nowrap; }
.nav-links { display: flex; align-items: center; justify-content: flex-end; gap: 6px; }
.nav-links > a:not(.btn) {
  color: rgba(255,255,255,.82);
  font-size: .86rem;
  font-weight: 850;
  letter-spacing: .03em;
  padding: .78rem .9rem;
  border-radius: 999px;
  transition: background .2s ease, color .2s ease;
}
.nav-links > a:not(.btn):hover, .nav-links > a[aria-current="page"]:not(.btn) { background: rgba(255,255,255,.09); color: var(--white); }
.nav-toggle { display: none; }

.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: .55rem;
  min-height: 52px;
  padding: .95rem 1.3rem;
  border: 1px solid transparent;
  border-radius: 999px;
  font-weight: 950;
  letter-spacing: .04em;
  text-transform: uppercase;
  font-size: .86rem;
  cursor: pointer;
  transition: transform .2s ease, box-shadow .2s ease, background .2s ease, border-color .2s ease;
}
.btn:hover { transform: translateY(-2px); }
.btn-primary {
  color: #120b03;
  background: linear-gradient(135deg, var(--gold-2), var(--gold) 54%, var(--copper));
  box-shadow: 0 18px 42px rgba(199, 112, 44, .30);
}
.btn-secondary {
  color: var(--white);
  background: rgba(255,255,255,.08);
  border-color: rgba(255,255,255,.25);
}
.card .btn-secondary, .statement-band .btn-secondary, .quote-strip .btn-secondary, .contact-panel .btn-secondary { color: var(--ink); border-color: rgba(16,24,32,.16); background: rgba(255,255,255,.72); }
.nav-cta { margin-left: 6px; min-height: 44px; padding: .72rem 1rem; font-size: .76rem; }

.hero {
  position: relative;
  isolation: isolate;
  overflow: hidden;
  min-height: 660px;
  background: var(--ink);
  color: var(--white);
  display: grid;
  align-items: center;
}
.hero-page { min-height: 500px; }
.hero-bg { position: absolute; inset: 0; z-index: -2; background-size: cover; background-position: center; transform: scale(1.02); }
.hero-bg::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 1;
  background:
    radial-gradient(circle at 78% 20%, rgba(245,162,59,.25), transparent 32%),
    linear-gradient(90deg, rgba(3,5,9,.94) 0%, rgba(4,7,12,.84) 46%, rgba(4,7,12,.48) 100%);
}
.hero-bg::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 2;
  background: linear-gradient(180deg, rgba(5,7,10,.08), rgba(5,7,10,.62));
}
.hero-grid { position: relative; z-index: 1; display: grid; grid-template-columns: minmax(0, 1fr); gap: 54px; align-items: center; padding-top: 88px; padding-bottom: 88px; }
.hero-copy { max-width: 820px; color: var(--white); background: transparent; }
.hero-home .hero-copy { max-width: 920px; margin: 0 auto; text-align: center; }
.hero-home .hero-actions { justify-content: center; }
.hero-copy h1, .hero-copy h2, .hero-copy h3 { color: var(--white); text-shadow: 0 14px 46px rgba(0,0,0,.34); }
.hero-home .hero-copy h1 {
  color: var(--gold-2);
  background: linear-gradient(92deg, #ffd37a 0%, #f5a23b 48%, #c66b2b 100%);
  background-clip: text;
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  text-shadow: none;
  filter: drop-shadow(0 16px 30px rgba(0,0,0,.58));
  font-size: clamp(3rem, 6.8vw, 5.9rem);
  letter-spacing: -.048em;
}
.hero-copy .lead { max-width: 720px; margin-top: 1.5rem; color: rgba(255,255,255,.9); font-size: clamp(1.05rem, 2vw, 1.35rem); }
.hero-home .hero-copy .lead { margin-left: auto; margin-right: auto; }
.eyebrow { margin: 0 0 1rem; color: var(--gold-2); font-size: .76rem; font-weight: 950; letter-spacing: .24em; text-transform: uppercase; }
.hero-actions, .cta-row, .quote-actions { display: flex; flex-wrap: wrap; gap: 14px; align-items: center; margin-top: 2rem; }

.premium-intro { background: var(--paper); }
.editorial-grid, .section-head { display: grid; grid-template-columns: minmax(0, 1.05fr) minmax(280px, .72fr); gap: 42px; align-items: end; }
.editorial-grid > p, .section-head > p { font-size: 1.1rem; color: #4b5664; }
.home-tabs {
  position: relative;
  isolation: isolate;
}
.home-standard::before {
  content: "";
  position: absolute;
  left: 50%;
  width: 100vw;
  transform: translateX(-50%);
  pointer-events: none;
}
.home-head {
  align-items: center;
  position: relative;
  overflow: hidden;
  padding: clamp(26px, 4vw, 40px);
  border: 1px solid rgba(16,24,32,.10);
  border-radius: var(--radius-lg);
  background:
    linear-gradient(135deg, rgba(255,255,255,.88), rgba(255,255,255,.68)),
    linear-gradient(90deg, rgba(245,162,59,.10), transparent 44%);
  box-shadow: 0 22px 56px rgba(5,10,18,.08);
}
.home-head::before {
  content: "";
  position: absolute;
  inset: 0 auto 0 0;
  width: 5px;
  background: linear-gradient(180deg, var(--gold-2), var(--gold), var(--copper));
}
.service-tabs {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 22px;
  margin-top: 34px;
}
.service-tab {
  position: relative;
  overflow: hidden;
  min-height: 455px;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  padding: 30px;
  border-radius: var(--radius-lg);
  background: #0a1018;
  border: 1px solid rgba(255,255,255,.16);
  box-shadow: 0 30px 74px rgba(5,10,18,.18);
  isolation: isolate;
}
.service-tab img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  z-index: -2;
  transition: transform .45s ease;
}
.service-tab::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: -1;
  background:
    linear-gradient(180deg, rgba(5,7,11,.05), rgba(5,7,11,.86) 74%),
    radial-gradient(circle at 22% 18%, rgba(245,162,59,.24), transparent 34%);
}
.service-tab::before {
  content: "";
  position: absolute;
  inset: 16px;
  z-index: -1;
  border: 1px solid rgba(255,255,255,.16);
  border-radius: calc(var(--radius-lg) - 8px);
  opacity: .78;
}
.service-tab:hover img { transform: scale(1.045); }
.service-tab span {
  width: fit-content;
  margin-bottom: .85rem;
  padding: .1rem 0 .1rem .85rem;
  border-radius: 0;
  color: var(--gold-2);
  background: transparent;
  border: 0;
  border-left: 3px solid var(--gold);
  font-size: .72rem;
  font-weight: 950;
  letter-spacing: .18em;
  text-transform: uppercase;
}
.service-tab h3 { color: var(--white); font-size: clamp(1.55rem, 2.2vw, 2.25rem); }
.service-tab p { color: rgba(255,255,255,.78); margin-top: .85rem; margin-bottom: 0; }
.clean-home-band { text-align: center; }
.clean-home-band h2, .clean-home-band .lead { margin-left: auto; margin-right: auto; }
.clean-home-band .lead { max-width: 820px; }
.clean-home-band .cta-row { justify-content: center; }
.home-standard {
  position: relative;
  isolation: isolate;
}
.home-standard::before {
  z-index: -2;
  top: -80px;
  bottom: 0;
  background:
    radial-gradient(circle at 80% 20%, rgba(245,162,59,.12), transparent 26%),
    linear-gradient(180deg, #eef2f6 0%, #f7f8fa 100%);
}
.trust-grid, .standards-grid, .grid { display: grid; gap: 20px; }
.trust-grid { grid-template-columns: repeat(3, 1fr); margin-top: 42px; }
.grid-2 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.grid-3 { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.card, .trust-grid article, .standards-grid article, .prestige-bar > div, .contact-panel > div, .timeline > div {
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: rgba(255,255,255,.92);
  box-shadow: var(--shadow-soft);
  padding: 28px;
}
.card { position: relative; overflow: hidden; }
.card::before {
  content: "";
  position: absolute;
  left: 0;
  top: 24px;
  bottom: 24px;
  width: 3px;
  background: linear-gradient(180deg, var(--gold-2), var(--copper));
  opacity: .72;
}
.card.accent { border-top: 0; }
.card h3, .trust-grid h3, .standards-grid h3, .prestige-bar strong { color: var(--text); }
.card a:not(.btn), .card h2 a, .contact-panel a { color: #b65f22; font-weight: 900; }
.trust-grid span, .prestige-bar span, .standards-grid span { display: inline-flex; color: var(--gold); font-weight: 950; margin-bottom: .85rem; letter-spacing: .12em; }
.prestige-bar { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; }
.prestige-bar > div { min-height: 190px; }
.prestige-bar strong { display: block; font-size: 1.25rem; letter-spacing: -.035em; }

.dark-section, .standards-section {
  position: relative;
  isolation: isolate;
  overflow: hidden;
  width: 100%;
  max-width: none;
  padding-left: max(20px, calc((100vw - var(--max)) / 2));
  padding-right: max(20px, calc((100vw - var(--max)) / 2));
  background:
    radial-gradient(circle at 8% 0%, rgba(245,162,59,.18), transparent 34%),
    linear-gradient(135deg, #060a10 0%, #0f1b29 100%);
  color: var(--white);
}
.dark-section::before {
  content: "";
  position: absolute;
  right: max(-40px, calc((100vw - var(--max)) / 2 - 120px));
  top: 50%;
  width: min(520px, 36vw);
  aspect-ratio: 1;
  transform: translateY(-50%);
  background: url("../images/pwl-mark.png") center / contain no-repeat;
  opacity: .13;
  filter: saturate(1.15) drop-shadow(0 0 64px rgba(245,162,59,.18));
  z-index: -1;
  pointer-events: none;
}
.dark-section::after {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 82% 46%, rgba(245,162,59,.13), transparent 24%),
    linear-gradient(90deg, rgba(6,10,16,.08), rgba(6,10,16,.42));
  z-index: -2;
  pointer-events: none;
}
.dark-section h2, .dark-section h3, .dark-section .section-head h2,
.standards-section h2, .standards-section h3 { color: var(--white); }
.dark-section p, .standards-section p { color: rgba(255,255,255,.72); }
.market-grid { display: grid; grid-template-columns: 1.15fr .85fr; gap: 20px; margin-top: 42px; }
.market-card {
  position: relative;
  min-height: 330px;
  overflow: hidden;
  border-radius: var(--radius-lg);
  display: flex;
  flex-direction: column;
  justify-content: end;
  padding: 28px;
  background: #101820;
  border: 1px solid rgba(255,255,255,.14);
  box-shadow: 0 30px 72px rgba(0,0,0,.28);
}
.market-card img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; z-index: 0; filter: saturate(.9) contrast(1.04); transition: transform .45s ease; }
.market-card::after { content: ""; position: absolute; inset: 0; z-index: 1; background: linear-gradient(180deg, rgba(0,0,0,.12), rgba(2,4,7,.88)); }
.market-card > *:not(img) { position: relative; z-index: 2; }
.market-card:hover img { transform: scale(1.05); }
.market-card span { color: var(--gold-2); font-size: .78rem; font-weight: 950; letter-spacing: .18em; text-transform: uppercase; }
.market-card h3 { margin-top: .7rem; color: var(--white); }
.market-card p { color: rgba(255,255,255,.78); }
.market-large { grid-row: span 2; min-height: 680px; }

.split-lux { display: grid; grid-template-columns: .82fr 1fr; gap: 40px; align-items: center; }
.executive-panel, .statement-band, .quote-strip, .contact-panel, .quote-layout { border-radius: var(--radius-lg); }
.executive-panel { background: var(--white); padding: 54px; box-shadow: var(--shadow); }
.service-feature {
  background: linear-gradient(180deg, rgba(255,255,255,.96), rgba(248,250,252,.94));
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  padding: clamp(28px, 5vw, 58px);
  box-shadow: var(--shadow);
}
.image-card {
  margin: 0;
  overflow: hidden;
  border-radius: var(--radius-lg);
  background: #05070b;
  border: 1px solid rgba(245,162,59,.22);
  box-shadow: 0 26px 70px rgba(5,10,18,.22);
}
.image-card img {
  width: 100%;
  height: clamp(320px, 42vw, 520px);
  object-fit: cover;
}
.image-card figcaption {
  padding: 18px 22px 22px;
  color: rgba(255,255,255,.76);
  font-size: .92rem;
  line-height: 1.55;
}
.brand-display { border-radius: var(--radius-lg); background: #05070b; padding: 30px; border: 1px solid rgba(245,162,59,.22); box-shadow: var(--shadow); }
.brand-display.no-pad { padding: 0; overflow: hidden; }
.brand-display img { border-radius: 22px; width: 100%; height: auto; object-fit: contain; }
.process-list { display: grid; gap: 14px; margin-top: 24px; }
.process-list div { display: grid; grid-template-columns: 110px 1fr; gap: 20px; padding: 18px 0; border-top: 1px solid var(--line); }
.process-list span { color: #b65f22; font-weight: 950; text-transform: uppercase; letter-spacing: .12em; font-size: .78rem; }

.standards-grid { grid-template-columns: repeat(4, 1fr); margin-top: 42px; }
.standards-grid article { background: rgba(255,255,255,.075); border-color: rgba(255,255,255,.14); box-shadow: none; }
.service-area-section { padding-top: 92px; }
.statement-band, .quote-strip {
  background: var(--white);
  border: 1px solid var(--line);
  box-shadow: var(--shadow);
}
.statement-band { padding: clamp(34px, 6vw, 64px); }
.statement-band h2 { max-width: 920px; }
.home-standard .statement-band {
  position: relative;
  overflow: hidden;
  color: var(--white);
  background:
    radial-gradient(circle at 18% 0%, rgba(245,162,59,.28), transparent 34%),
    linear-gradient(135deg, #05070b 0%, #101820 56%, #1a2736 100%);
  border-color: rgba(255,255,255,.14);
  box-shadow: 0 34px 90px rgba(5,10,18,.24);
}
.home-standard .statement-band::before {
  content: "";
  position: absolute;
  inset: 18px;
  border: 1px solid rgba(255,255,255,.12);
  border-radius: calc(var(--radius-lg) - 8px);
  pointer-events: none;
}
.home-standard .statement-band::after {
  content: "";
  position: absolute;
  right: -120px;
  top: -120px;
  width: 340px;
  height: 340px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(245,162,59,.20), transparent 66%);
  pointer-events: none;
}
.home-standard .statement-band h2 { color: var(--white); }
.home-standard .statement-band .lead { color: rgba(255,255,255,.76); }
.home-standard .statement-band .btn-secondary {
  color: var(--white);
  background: rgba(255,255,255,.08);
  border-color: rgba(255,255,255,.25);
}
.quote-strip { display: flex; align-items: center; justify-content: space-between; gap: 28px; padding: 42px; }
.quote-strip > div:first-child { max-width: 620px; }

.service-matrix { display: grid; grid-template-columns: repeat(4, 1fr); gap: 12px; margin-top: 34px; }
.service-matrix span { padding: 18px; border-radius: 18px; background: var(--white); border: 1px solid var(--line); font-weight: 850; box-shadow: var(--shadow-soft); }
.timeline { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; }
.timeline span { color: var(--gold); font-weight: 950; letter-spacing: .16em; text-transform: uppercase; font-size: .78rem; }
.contact-panel { display: grid; grid-template-columns: 1fr; gap: 18px; }
.contact-panel > div { padding: 34px; }
.quote-layout { display: grid; grid-template-columns: 1fr .88fr; gap: 24px; align-items: stretch; }
.check-list { padding-left: 1.15rem; color: var(--muted); }
.check-list li { margin: .55rem 0; }
.quote-form-card { padding: clamp(26px, 4vw, 44px); }
.quote-form {
  display: grid;
  gap: 18px;
  margin-top: 26px;
}
.form-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 16px;
}
.quote-form label {
  display: grid;
  gap: 8px;
  color: var(--text);
  font-size: .84rem;
  font-weight: 900;
  letter-spacing: .05em;
  text-transform: uppercase;
}
.quote-form input,
.quote-form select,
.quote-form textarea {
  width: 100%;
  border: 1px solid rgba(16,24,32,.16);
  border-radius: 14px;
  background: rgba(255,255,255,.92);
  color: var(--text);
  padding: 14px 15px;
  font: inherit;
  font-weight: 650;
  letter-spacing: 0;
  text-transform: none;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.75);
  transition: border-color .2s ease, box-shadow .2s ease, background .2s ease;
}
.quote-form textarea { resize: vertical; min-height: 170px; }
.quote-form input:focus,
.quote-form select:focus,
.quote-form textarea:focus {
  outline: none;
  border-color: rgba(245,162,59,.72);
  box-shadow: 0 0 0 4px rgba(245,162,59,.16);
  background: #fff;
}
.form-honey {
  position: absolute !important;
  left: -9999px !important;
  width: 1px !important;
  height: 1px !important;
  opacity: 0 !important;
}
.form-note {
  margin: -2px 0 0;
  font-size: .95rem;
}
.form-status {
  margin: -4px 0 0;
  color: #9a541f;
  font-size: .95rem;
  font-weight: 800;
}
.photo-side { background: linear-gradient(135deg, var(--ink), var(--panel)); color: var(--white); }
.photo-side h3 { color: var(--white); }
.photo-side .lead, .photo-side p, .photo-side .check-list { color: rgba(255,255,255,.74); }
.photo-side .check-list { margin-top: 18px; margin-bottom: 22px; }

.site-footer { background: #05070b; color: var(--white); padding-top: 64px; }
.footer-inner { display: grid; grid-template-columns: 1.4fr .8fr .8fr 1.1fr; gap: 34px; padding-bottom: 48px; }
.footer-inner h3 { color: var(--white); font-size: 1rem; letter-spacing: -.02em; }
.footer-inner p, .footer-links a { color: rgba(255,255,255,.68); }
.footer-links { display: grid; gap: 10px; }
.footer-links a:hover, .site-footer a:hover { color: var(--gold-2); }
.footer-bottom { border-top: 1px solid rgba(255,255,255,.1); padding: 20px 0; color: rgba(255,255,255,.58); font-size: .9rem; }
.footer-brand { margin-bottom: 18px; }

@media (prefers-reduced-motion: no-preference) {
  .hero-copy, .card, .market-card, .trust-grid article, .prestige-bar > div { animation: fadeUp .7s ease both; }
  @keyframes fadeUp { from { opacity: 0; transform: translateY(18px); } to { opacity: 1; transform: translateY(0); } }
}

@media (max-width: 1080px) {
  .nav-links { gap: 2px; }
  .nav-links > a:not(.btn) { padding-left: .64rem; padding-right: .64rem; }
  .hero-grid { grid-template-columns: 1fr; }
  .service-tabs { grid-template-columns: 1fr; }
  .service-tab { min-height: 360px; }
  .prestige-bar, .standards-grid, .service-matrix { grid-template-columns: repeat(2, 1fr); }
  .market-grid, .split-lux, .quote-layout, .editorial-grid, .section-head, .quote-strip, .footer-inner { grid-template-columns: 1fr; }
  .market-large { min-height: 440px; }
}

@media (max-width: 820px) {
  .section, .nav-wrap, .footer-inner { width: min(calc(100% - 32px), var(--max)); }
  .nav-wrap { min-height: 78px; }
  .brand { min-width: 0; gap: 12px; }
  .brand-badge { width: 54px; height: 54px; border-radius: 16px; }
  .brand-text { font-size: 1.05rem; }
  .brand-text span { font-size: .66rem; letter-spacing: .20em; }
  .nav-toggle {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 46px;
    padding: .75rem 1rem;
    border-radius: 999px;
    border: 1px solid rgba(255,255,255,.18);
    background: rgba(255,255,255,.09);
    color: var(--white);
    font-weight: 950;
    font-size: .88rem;
  }
  .nav-links {
    position: fixed;
    left: 16px;
    right: 16px;
    top: 92px;
    display: none;
    flex-direction: column;
    align-items: stretch;
    gap: 8px;
    padding: 18px;
    border-radius: 24px;
    background: rgba(5,7,11,.98);
    border: 1px solid rgba(255,255,255,.14);
    box-shadow: 0 22px 60px rgba(0,0,0,.34);
  }
  body.nav-open .nav-links { display: flex; }
  .nav-links > a:not(.btn), .nav-links .btn { width: 100%; justify-content: center; text-align: center; }
  .nav-cta { margin-left: 0; }
  .hero { min-height: auto; }
  .hero-page { min-height: auto; }
  .hero-grid { display: block; padding-top: 72px; padding-bottom: 76px; }
  .hero-copy { max-width: 100%; }
  h1 { font-size: clamp(2.55rem, 12vw, 4rem); line-height: .98; letter-spacing: -.06em; }
  h2 { font-size: clamp(2rem, 8vw, 3.1rem); }
  .hero-copy .lead { font-size: 1.04rem; line-height: 1.65; color: rgba(255,255,255,.9); }
  .hero-actions .btn, .cta-row .btn, .quote-actions .btn { width: 100%; }
  .section { padding: 66px 0; }
  .section-overlap { padding-top: 66px; }
  .executive-panel { padding: 28px; }
  .market-card, .market-large { min-height: 330px; }
  .quote-strip, .statement-band { padding: 28px; }
  .quote-strip { display: block; }
  .quote-actions { width: 100%; }
  .service-feature { padding: 24px; }
  .image-card img { height: 300px; }
  .process-list div { grid-template-columns: 1fr; gap: 6px; }
}

@media (max-width: 620px) {
  .section, .nav-wrap, .footer-inner { width: min(calc(100% - 28px), var(--max)); }
  .brand-badge { width: 48px; height: 48px; }
  .brand-text { font-size: 1rem; }
  .brand-text span { white-space: normal; letter-spacing: .16em; line-height: 1.2; }
  .hero-bg::before { background: linear-gradient(90deg, rgba(3,5,9,.94), rgba(3,5,9,.75)); }
  .eyebrow { font-size: .68rem; letter-spacing: .18em; line-height: 1.5; }
  .prestige-bar, .trust-grid, .standards-grid, .grid-2, .grid-3, .service-matrix, .timeline, .form-grid { grid-template-columns: 1fr; }
  .market-grid { gap: 16px; }
  .card, .trust-grid article, .standards-grid article, .prestige-bar > div, .contact-panel > div, .timeline > div { padding: 22px; border-radius: 22px; }
  .footer-inner { gap: 24px; }
}
