:root{
  --bg: #070a08;
  --panel: #0f1411;
  --panel2: #101a15;
  --border: #1c2a22;
  --text: #e7f0ea;
  --muted: #9bb1a5;
  --primary: #4b8f5f;
  --primary2: #2f6a45;
  --danger: #d45454;
  --warning: #d2a84e;
  --radius: 16px;
  --shadow: 0 10px 30px rgba(0,0,0,0.45);

  /* 7-stage workflow colors (muted, readable on dark background) */
  --stage1: #2dd4bf; /* teal */
  --stage2: #60a5fa; /* blue */
  --stage3: #a78bfa; /* purple */
  --stage4: #fbbf24; /* amber */
  --stage5: #fb923c; /* orange */
  --stage6: #34d399; /* green */
  --stage7: #94a3b8; /* slate */
}

*{ box-sizing: border-box; }
html,body{ height:100%; }
body{
  margin:0;
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, "Apple Color Emoji","Segoe UI Emoji";
  background: radial-gradient(1200px 800px at 50% -200px, rgba(75,143,95,0.18), transparent 60%), var(--bg);
  color: var(--text);
}

a{ color: inherit; text-decoration: none; }
a:hover{ text-decoration: underline; }

.topbar{
  position: sticky;
  top: 0;
  z-index: 50;
  display:flex;
  align-items:center;
  justify-content: space-between;
  padding: 14px 18px;
  border-bottom: 1px solid var(--border);
  background: rgba(7,10,8,0.75);
  backdrop-filter: blur(10px);
}

.brand{
  display:flex;
  align-items:center;
  gap:12px;
  font-weight: 700;
  letter-spacing: 0.2px;
}

.logo{
  width: 34px;
  height: 34px;
  object-fit: contain;
  border-radius: 10px;
  border: 1px solid var(--border);
  background: rgba(255,255,255,0.03);
  padding: 4px;
}

.top-actions{
  display:flex;
  align-items:center;
  gap: 10px;
}

.badge{
  font-size: 12px;
  color: var(--muted);
  padding: 6px 10px;
  border-radius: 999px;
  border: 1px solid var(--border);
  background: rgba(255,255,255,0.02);
}

.main{
  max-width: 1200px;
  margin: 0 auto;
  padding: 20px 18px 60px;
}

.hstack{ display:flex; align-items:center; gap: 10px; }
.vstack{ display:flex; flex-direction: column; gap: 10px; }

.header-row{
  display:flex;
  align-items:flex-end;
  justify-content: space-between;
  gap: 14px;
  margin: 18px 0 14px;
}

h1{ margin: 0; font-size: 26px; }

.sub{ color: var(--muted); margin-top: 4px; line-height: 1.45; }

.card{
  background: linear-gradient(180deg, rgba(255,255,255,0.02), transparent 70%), var(--panel);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
}

.card.pad{ padding: 16px; }

.grid{
  display:grid;
  grid-template-columns: repeat(12, 1fr);
  gap: 14px;
}

.col-4{ grid-column: span 4; }
.col-6{ grid-column: span 6; }
.col-8{ grid-column: span 8; }
.col-12{ grid-column: span 12; }

@media (max-width: 980px){
  .col-4,.col-6,.col-8{ grid-column: span 12; }
}

.kv{
  display:flex;
  flex-direction: column;
  gap: 4px;
}

.kv .k{ color: var(--muted); font-size: 12px; }
.kv .v{ font-weight: 600; }

.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap: 8px;
  padding: 10px 14px;
  border-radius: 12px;
  border: 1px solid var(--border);
  background: rgba(255,255,255,0.02);
  color: var(--text);
  cursor: pointer;
  user-select: none;
}
.btn:hover{ filter: brightness(1.08); }
.btn:disabled{ opacity: 0.55; cursor:not-allowed; }

.btn-sm{
  padding: 6px 10px;
  border-radius: 10px;
  font-size: 12px;
}

.btn-lg{
  padding: 12px 18px;
  border-radius: 14px;
  font-size: 14px;
}

.btn-primary{
  border-color: rgba(75,143,95,0.5);
  background: linear-gradient(180deg, rgba(75,143,95,0.25), rgba(47,106,69,0.15));
}

.btn-danger{
  border-color: rgba(212,84,84,0.5);
  background: linear-gradient(180deg, rgba(212,84,84,0.18), rgba(212,84,84,0.08));
}

.btn-ghost{
  background: transparent;
}

.btn-attn{
  background: rgba(255, 244, 198, 0.96);
  border-color: rgba(233, 196, 92, 0.85);
  color: #1a1e12;
  font-weight: 800;
}
.btn-attn:hover{
  filter: none;
  background: rgba(255, 244, 198, 1);
  box-shadow: 0 0 0 3px rgba(233,196,92,0.25);
}

.input, textarea, select{
  width: 100%;
  padding: 10px 12px;
  border-radius: 12px;
  border: 1px solid var(--border);
  background: rgba(255,255,255,0.03);
  color: var(--text);
  outline: none;
}

.input::placeholder,
textarea::placeholder{
  color: rgba(255,255,255,0.45);
}

.input:disabled,
textarea:disabled,
select:disabled{
  opacity: 0.65;
  cursor: not-allowed;
}
textarea{ min-height: 90px; resize: vertical; }

label{
  display:block;
  font-size: 12px;
  color: var(--muted);
  margin-bottom: 6px;
}

.form-row{
  display:grid;
  grid-template-columns: repeat(12, 1fr);
  gap: 12px;
}

.form-row .field{ grid-column: span 6; }
.form-row .field.full{ grid-column: span 12; }

@media (max-width: 980px){
  .form-row .field{ grid-column: span 12; }
}

.hr{ height:1px; background: var(--border); margin: 14px 0; }

.click-card{
  transition: transform 120ms ease, filter 120ms ease;
}
.click-card:hover{
  transform: translateY(-2px);
}

.small{ font-size: 12px; color: var(--muted); }

.pill{
  display:inline-flex;
  align-items:center;
  padding: 4px 10px;
  border-radius: 999px;
  border: 1px solid var(--border);
  background: rgba(255,255,255,0.02);
  font-size: 12px;
  color: var(--muted);
}

.stage{
  display:inline-flex;
  align-items:center;
  gap: 8px;
}

.stage-dot{
  width: 8px;
  height: 8px;
  border-radius: 999px;
  background: var(--primary);
  box-shadow: 0 0 0 4px rgba(75,143,95,0.15);
}

.progress{
  height: 10px;
  border-radius: 999px;
  background: rgba(255,255,255,0.08);
  overflow: hidden;
  border: 1px solid rgba(255,255,255,0.08);
}

.progress > span{
  display: block;
  height: 100%;
  width: 0%;
  background: var(--primary);
}

.notice{
  border: 1px dashed rgba(155,177,165,0.35);
  border-radius: 14px;
  padding: 12px;
  color: var(--muted);
}

.center-wrap{
  min-height: calc(100vh - 90px);
  display:flex;
  align-items:center;
  justify-content:center;
}

.stepper{
  display:flex;
  gap: 10px;
  flex-wrap: wrap;
}
.step{
  padding: 6px 10px;
  border-radius: 999px;
  border: 1px solid var(--border);
  color: var(--muted);
  font-size: 12px;
}
.step.active{
  color: var(--text);
  border-color: rgba(75,143,95,0.55);
  background: rgba(75,143,95,0.12);
}

.table{
  width: 100%;
  border-collapse: collapse;
}
.table th,
.table td{
  border-bottom: 1px solid var(--border);
  text-align: left;
  padding: 10px 6px;
  vertical-align: top;
  font-size: 14px;
}
.table th{ color: var(--muted); font-size: 12px; font-weight: 600; }

.file-row{
  display:flex;
  align-items:center;
  justify-content: space-between;
  gap: 12px;
  padding: 10px 12px;
  border: 1px solid var(--border);
  border-radius: 14px;
  background: rgba(255,255,255,0.02);
}
.file-row .left{ display:flex; flex-direction: column; gap: 4px; }
.file-row .right{ display:flex; align-items:center; gap: 8px; }

.inline-img{
  width: 54px;
  height: 54px;
  border-radius: 14px;
  border: 1px solid var(--border);
  object-fit: cover;
  background: rgba(255,255,255,0.02);
}


/* Modal */
.modal-backdrop{
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,0.62);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 18px;
  z-index: 9999;
}
.modal-card{
  /* Slightly wider by default, but always fit the viewport (fixes title clipping on smaller screens) */
  width: min(980px, 98vw);
  background: var(--panel);
  border: 1px solid var(--border);
  border-radius: 20px;
  box-shadow: var(--shadow);
  /* Prevent text/buttons from being clipped; allow internal scrolling when content is tall */
  overflow: auto;
  max-height: 94vh;
}
.modal-head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding: 14px 16px;
  border-bottom: 1px solid var(--border);
  background: linear-gradient(180deg, rgba(255,255,255,0.03), rgba(255,255,255,0));
}
.modal-title{
  font-size: 15px;
  font-weight: 800;
  color: var(--text);
}
.modal-body{
  padding: 16px;
}
.modal-grid{
  display:grid;
  grid-template-columns: 1fr;
  gap: 12px;
}
@media (min-width: 640px){
  .modal-grid{ grid-template-columns: 1fr 1fr; }
}
.callout{
  border: 1px solid rgba(233,196,92,0.55);
  background: rgba(255,244,198,0.08);
  padding: 10px 12px;
  border-radius: 14px;
}

html, body { overflow-x: hidden; }
body {
  background:
    radial-gradient(900px 480px at 0% 0%, rgba(255,255,255,0.08), transparent 60%),
    linear-gradient(180deg, rgba(108,119,43,0.22), transparent 28%),
    var(--bg);
}
:root {
  --primary: #6c772b;
  --primary2: #515b20;
  --bg: #0d110d;
  --panel: #121713;
  --panel2: #141b16;
  --border: #273126;
  --text: #eef3ea;
  --muted: #bdc7b8;
}
.topbar {
  gap: 16px;
  background: rgba(15, 20, 13, 0.92);
  border-bottom-color: rgba(255,255,255,0.08);
}
.brand-copy { display:flex; flex-direction:column; gap:2px; }
.brand-title { font-size: 16px; line-height: 1.2; }
.brand-sub { color: var(--muted); font-size: 12px; line-height: 1.2; }
.logo { border: none; background: transparent; width: 42px; height: 42px; padding: 0; }
.site-nav { display:flex; align-items:center; gap: 10px; flex-wrap: wrap; margin-left: auto; }
.nav-link {
  display:inline-flex; align-items:center; justify-content:center;
  min-height: 40px; padding: 8px 12px; border-radius: 999px;
  border: 1px solid rgba(255,255,255,0.08); background: rgba(255,255,255,0.03);
  color: var(--text); font-size: 14px; text-decoration: none;
}
.nav-link:hover { text-decoration:none; background: rgba(255,255,255,0.08); }
.lang-select {
  min-width: 78px; max-width: 78px; padding: 8px 12px; border-radius: 999px;
  border: 1px solid rgba(255,255,255,0.08); background: rgba(255,255,255,0.04); color: var(--text);
}
.site-main { max-width: 1240px; }
.landing-hero,
.marketing-hero,
.content-section,
.contact-strip { margin-bottom: 18px; }
.site-home { display:flex; flex-direction:column; gap: 18px; }
.home-section { border-radius: 24px; padding: 28px; border: 1px solid rgba(255,255,255,0.08); box-shadow: var(--shadow); }
.section-white { background: linear-gradient(180deg,#ffffff,#f4f6ef); color: #1d241f; }
.section-white p, .section-white .sub, .section-white h2, .section-white .eyebrow { color: #1d241f; }
.section-green { background: linear-gradient(135deg,#6c772b,#819038); }
.section-dark { background: linear-gradient(135deg,#1a201d,#121613); }
.section-green-soft { background: linear-gradient(180deg, rgba(108,119,43,0.18), rgba(108,119,43,0.08)); }
.hero-grid, .split-grid {
  display:grid; grid-template-columns: 1.1fr 0.9fr; gap: 22px; align-items:center;
}
.reverse-on-mobile { }
.marketing-image { width: 100%; height: auto; border-radius: 22px; display:block; border: 1px solid rgba(255,255,255,0.12); }
.marketing-image.compact { max-height: 320px; object-fit: cover; }
.display-title { font-size: clamp(34px, 5vw, 58px); line-height: 1.02; margin: 8px 0 14px; }
.hero-copy { font-size: 18px; line-height: 1.7; color: var(--muted); max-width: 70ch; }
.section-white .hero-copy { color: rgba(29,36,31,0.8); }
.eyebrow { text-transform: uppercase; letter-spacing: .18em; font-size: 12px; color: var(--primary); font-weight: 800; }
.section-white .eyebrow { color: #66731f; }
.marketing-shell { display:flex; flex-direction:column; gap: 18px; }
.section-heading h2 { margin: 6px 0 12px; font-size: 32px; }
.section-heading p { margin: 0; line-height: 1.7; color: var(--muted); }
.marketing-card-grid { display:grid; gap: 16px; }
.marketing-card-grid.three-up { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.marketing-card-grid.two-up { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.marketing-card {
  padding: 18px; border-radius: 20px; border: 1px solid rgba(255,255,255,0.08);
  background: rgba(255,255,255,0.03); box-shadow: var(--shadow);
}
.marketing-card h3 { margin: 14px 0 10px; font-size: 22px; }
.marketing-card p { margin: 0; color: var(--muted); line-height: 1.65; }
.tone-light { background: linear-gradient(180deg, rgba(255,255,255,0.98), rgba(244,246,239,0.96)); border-color: rgba(29,36,31,0.08); }
.tone-light h3, .tone-light p { color: #1d241f; }
.tone-dark { background: linear-gradient(180deg, rgba(15,19,16,0.94), rgba(15,19,16,0.88)); }
.card-illustration, .card-photo { width:100%; height: 180px; border-radius: 16px; object-fit: cover; display:block; }
.process-grid { display:grid; grid-template-columns: repeat(2, minmax(0,1fr)); gap: 14px; }
.process-step { display:flex; align-items:flex-start; gap: 12px; padding: 18px; border-radius: 18px; background: rgba(255,255,255,0.04); }
.step-badge { width: 28px; height: 28px; border-radius: 999px; background: rgba(108,119,43,0.24); display:inline-flex; align-items:center; justify-content:center; color: #f7f9f2; flex: 0 0 28px; }
.marketing-split-card { display:grid; grid-template-columns: .9fr 1.1fr; gap: 18px; align-items:center; }
.mini-check { padding: 12px 14px; border-radius: 14px; background: rgba(255,255,255,0.04); border: 1px solid rgba(255,255,255,0.06); }
.pricing-callout { margin: 18px 0; padding: 18px; border-radius: 18px; border:1px solid rgba(255,255,255,0.08); background: rgba(15,20,13,0.18); }
.price-big { font-size: 42px; font-weight: 800; line-height: 1; margin-bottom: 6px; }
.link-inline { color: inherit; text-decoration: underline; text-decoration-color: rgba(108,119,43,0.8); text-underline-offset: 3px; }
.link-inline:hover { color: inherit; }
.text-strong { color: var(--text) !important; }
.notice-soft { background: rgba(255,255,255,0.03); }
.wrap-gap { flex-wrap: wrap; }
.marketing-center-wrap { padding-top: 36px; }
.marketing-auth-card { background: linear-gradient(180deg, rgba(255,255,255,0.03), transparent 70%), var(--panel); }
@media (max-width: 980px) {
  .topbar { flex-wrap: wrap; }
  .site-nav { width: 100%; order: 3; margin-left: 0; }
  .hero-grid, .split-grid, .marketing-split-card, .marketing-card-grid.three-up, .marketing-card-grid.two-up, .process-grid { grid-template-columns: 1fr; }
  .home-section, .landing-hero, .marketing-hero, .content-section, .contact-strip { padding: 22px; }
  .display-title { font-size: 34px; }
}
@media (max-width: 640px) {
  .brand-title { font-size: 14px; }
  .brand-sub { font-size: 11px; }
  .site-nav { gap: 8px; }
  .nav-link { font-size: 13px; padding: 8px 10px; }
  .home-section, .landing-hero, .marketing-hero, .content-section, .contact-strip { border-radius: 20px; padding: 18px; }
  .main { padding: 16px 14px 56px; }
}


body{ overflow-x:hidden; }
.top-actions{ gap:14px; }
.lang-toggle{
  display:inline-flex; align-items:center; gap:6px; padding:4px;
  border-radius:999px; border:1px solid rgba(255,255,255,0.1);
  background: rgba(255,255,255,0.04);
}
.lang-pill{
  min-width:44px; height:36px; border:none; border-radius:999px; cursor:pointer;
  background: transparent; color: var(--text); font-weight:700; letter-spacing:.04em;
}
.lang-pill.active{ background:#fff; color:#1d241f; box-shadow:0 6px 20px rgba(0,0,0,.18); }
.lang-pill:hover{ background: rgba(255,255,255,.12); }
.btn-solid{ background: var(--primary); border-color: rgba(255,255,255,.12); color:#fff; font-weight:700; }
.btn-solid:hover{ background:#5d8d48; }
.btn-outline-light{ background:#fff; border-color:#fff; color:#1d241f; font-weight:700; }
.btn-outline-light:hover{ background:#f0f2e7; }
.btn-dark-solid{ background:#1c221e; border-color:#1c221e; color:#fff; font-weight:700; }
.btn-dark-solid:hover{ background:#111512; }
.btn-white-outline{ background:transparent; border:1px solid rgba(29,36,31,0.22); color:#1d241f; font-weight:700; }
.btn-white-outline:hover{ background:rgba(29,36,31,.06); }
.modern-home-shell{ gap:24px; }

/* Home: 3 clear funnel sections (Construction / Insurance / Technology) */
.home-option{
  width:100vw;
  margin-left: calc(50% - 50vw);
  padding: 64px 0;
}
.home-option-inner{
  max-width: var(--max);
  margin: 0 auto;
  padding: 0 18px;
  display:flex;
  flex-direction:column;
  gap: 18px;
}
.home-option-image{
  width:100%;
  height: clamp(220px, 35vw, 420px);
  object-fit: cover;
  border-radius: 28px;
  border: 1px solid rgba(0,0,0,.08);
  box-shadow: var(--shadow);
  display:block;
}
.home-option-content{ max-width: 70ch; }
.home-option-content .section-title{
  font-size: clamp(28px, 4.4vw, 46px);
  line-height: 1.08;
  margin: 10px 0 14px;
}
.home-option-content .section-copy{
  font-size: 17px;
  line-height: 1.85;
  margin: 0;
}
.home-option-buttons{
  display:flex;
  flex-wrap:wrap;
  gap: 14px;
  margin-top: 22px;
}
.home-option-buttons .btn{ min-width: 180px; justify-content:center; }

.home-option--construction{ background:#ffffff; color:#111412; }
.home-option--construction .eyebrow{ color: var(--brand-strong); }
.home-option--construction .section-copy{ color:#263026; }

.home-option--insurance{ background: var(--brand); color:#ffffff; }
.home-option--insurance .eyebrow{ color: rgba(255,255,255,.9); }
.home-option--insurance .section-copy{ color: rgba(255,255,255,.92); }

.home-option--tech{ background:#1b1f1c; color:#ffffff; }
.home-option--tech .eyebrow{ color: rgba(255,255,255,.9); }
.home-option--tech .section-copy{ color: rgba(255,255,255,.9); }
.modern-hero{
  position:relative; overflow:hidden; padding:34px; border-radius:32px;
  background:
    radial-gradient(600px 260px at 0% 0%, rgba(108,119,43,.25), transparent 65%),
    radial-gradient(500px 240px at 100% 20%, rgba(255,255,255,.08), transparent 50%),
    linear-gradient(135deg, rgba(17,20,18,.98), rgba(9,12,10,.98));
}
.hero-grid-wide{ grid-template-columns: 1fr 1.15fr; gap: 28px; }
.modern-display{ max-width: 14ch; }
.modern-copy{ max-width: 60ch; color:#cfdbd2; }
.modern-callout{ margin-bottom:18px; }
.hero-action-row, .service-button-row{ display:flex; flex-wrap:wrap; gap:14px; margin-top:20px; }
.hero-visual-grid{
  display:grid; grid-template-columns: 1.05fr .95fr; grid-template-rows: 1fr 1fr; gap:16px; min-height: 460px;
}
.hero-visual-grid.compact-visual-grid{ min-height:420px; }
.visual-card{ position:relative; overflow:hidden; border-radius:28px; border:1px solid rgba(255,255,255,.14); box-shadow: var(--shadow); }
.visual-card.tall-card{ grid-row:1 / span 2; }
.visual-card.small-card{ min-height:220px; }
.visual-image{ width:100%; height:100%; object-fit:cover; display:block; }
.visual-overlay{
  position:absolute; inset:auto 0 0 0; padding:18px;
  background: linear-gradient(180deg, transparent, rgba(0,0,0,.7) 70%);
  display:flex; flex-direction:column; gap:6px;
}
.visual-overlay span{ font-size:11px; text-transform:uppercase; letter-spacing:.16em; color:#dce7df; }
.visual-overlay strong{ font-size:18px; line-height:1.35; }
.trust-ribbon{ padding:20px 24px; border-radius:28px; background: linear-gradient(135deg, rgba(108,119,43,.16), rgba(255,255,255,.04)); }
.trust-grid{ display:grid; grid-template-columns:repeat(3,minmax(0,1fr)); gap:14px; margin-top:14px; }
.trust-pill{ padding:14px 16px; border-radius:18px; background: rgba(255,255,255,.05); border:1px solid rgba(255,255,255,.08); color:#dfe7e2; }
.modern-panel{ padding:32px; border-radius:30px; }
.service-layout{ display:grid; grid-template-columns: 1.02fr .98fr; gap:28px; align-items:center; }
.service-copy h2{ font-size: clamp(28px, 4vw, 44px); line-height:1.08; margin: 10px 0 14px; }
.service-copy p{ font-size:17px; line-height:1.8; max-width:62ch; }
.media-stack{ display:flex; flex-direction:column; gap:14px; }
.media-card-image{ width:100%; height:400px; border-radius:26px; object-fit:cover; display:block; border:1px solid rgba(0,0,0,.08); box-shadow: var(--shadow); }
.media-collage{ display:grid; gap:14px; }
.two-up-collage{ grid-template-columns: 1fr 1fr; }
.two-up-collage .media-card-image{ height:340px; }
.media-stat{ padding:16px 18px; border-radius:18px; background: rgba(17,20,18,.92); color:#fff; font-weight:700; box-shadow: var(--shadow); }
.media-stat.dark{ background: rgba(17,20,18,.84); }
.modern-footer{ border-radius:26px; }
.social-strip{ display:flex; align-items:center; justify-content:center; gap:18px; border-radius:26px; }
.social-strip-icons-only{ max-width:1320px; margin:36px auto 0; padding:18px 22px; }
.social-row{ display:flex; gap:14px; flex-wrap:wrap; justify-content:center; width:100%; }
.social-link{ width:52px; height:52px; border-radius:999px; display:inline-flex; align-items:center; justify-content:center; background: rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.08); }
.social-icon{ width:24px; height:24px; }
.social-link.facebook{ color:#1877F2; }
.social-link.instagram{ color:#E4405F; }
.social-link.youtube{ color:#FF0000; }
.social-link.tiktok{ color:#25F4EE; }
.social-link:hover{ transform: translateY(-2px); text-decoration:none; }
.modern-marketing-shell{ gap:22px; }
.modern-marketing-hero{ padding:32px; border-radius:32px; overflow:hidden; }
.modern-card{ border-radius:24px; overflow:hidden; }
.modern-card .card-photo{ height:220px; border-radius:18px; }
.modern-process-grid .process-step{ min-height:96px; }
.modern-split-card{ gap:24px; }
.modern-price-box{ background: linear-gradient(135deg, rgba(108,119,43,.25), rgba(255,255,255,.06)); }
@media (max-width: 980px){
  .hero-grid-wide, .service-layout{ grid-template-columns:1fr; }
  .hero-visual-grid{ min-height:auto; grid-template-columns:1fr; grid-template-rows:auto; }
  .visual-card.tall-card{ grid-row:auto; min-height:320px; }
  .visual-card.small-card{ min-height:220px; }
  .trust-grid, .two-up-collage{ grid-template-columns:1fr; }
  .social-strip{ flex-direction:column; align-items:center; }
}
@media (max-width: 640px){
  .modern-hero, .modern-marketing-hero, .modern-panel{ padding:22px; }
  .service-copy h2{ font-size:30px; }
  .media-card-image{ height:300px; }
  .visual-card.tall-card, .visual-card.small-card{ min-height:220px; }
  .top-actions{ width:100%; justify-content:flex-end; }
  .lang-toggle{ margin-left:auto; }
  .hero-action-row .btn, .service-button-row .btn{ width:100%; }
}


/* Updated homepage card layout */
.home-cards-shell{
  width:100vw;
  margin-left: calc(50% - 50vw);
  background: var(--primary);
  padding: 34px 0 40px;
}
.home-product-grid{
  max-width: 1320px;
  margin: 0 auto;
  padding: 0 18px;
  display:grid;
  grid-template-columns: repeat(3, minmax(0,1fr));
  gap: 22px;
  align-items: stretch;
}
.home-product-card{
  background:#fff;
  color:#172019;
  border-radius: 28px;
  overflow:hidden;
  border: 1px solid rgba(17,20,18,0.08);
  box-shadow: 0 24px 60px rgba(0,0,0,0.22);
  display:flex;
  flex-direction:column;
  min-height:100%;
}
.home-product-image{
  width:100%;
  aspect-ratio: 16 / 10;
  object-fit: cover;
  display:block;
  background:#eef3ea;
}
.home-product-image-contain{
  object-fit: contain;
  padding: 18px;
  background: linear-gradient(180deg, #f6f7f3, #e7ecde);
}
.home-product-body{
  padding: 22px;
  display:flex;
  flex-direction:column;
  gap: 12px;
  flex:1;
}
.home-product-title{
  font-size: 13px;
  letter-spacing: .18em;
  text-transform: uppercase;
  font-weight: 800;
  color: var(--primary2);
}
.home-product-subtitle{
  font-size: clamp(24px, 2vw, 32px);
  line-height: 1.12;
  font-weight: 800;
  color:#131915;
}
.home-product-copy{
  margin: 0;
  color:#314034;
  line-height: 1.7;
  font-size: 15px;
}
.home-product-actions{
  margin-top: auto;
  padding-top: 6px;
}
.home-product-actions .btn{
  width:100%;
  justify-content:center;
}

.insurance-product-card .product-card-body{ padding: 20px; display:flex; flex-direction:column; gap:10px; }
.insurance-product-card .product-subtitle{ color:#2f3b31; font-weight:700; line-height:1.45; }
.insurance-product-card p{ margin:0; color:#3c4740; line-height:1.7; }
.insurance-product-card .btn{ margin-top:auto; justify-content:center; }
.home-cards-shell .social-strip{ margin-top:42px; }
@media (max-width: 980px){
  .home-product-grid{ grid-template-columns: 1fr; max-width: 760px; }
}
@media (max-width: 640px){
  .topbar{ flex-direction: column; align-items: center; gap: 10px; }
  .brand{ width:100%; justify-content:center; }
  .top-actions{ width:100%; justify-content:center; }
  .lang-toggle{ margin:0 auto; }
  .social-strip-icons-only{ margin-top:28px; }
  .site-nav{ justify-content:center; width:100%; }
  .home-cards-shell{ padding-top: 20px; }
  .home-product-grid{ padding: 0 14px; gap: 18px; }
  .home-product-body{ padding: 18px; }
}


.footer-contact-actions{ display:flex; flex-wrap:wrap; gap:12px; align-items:flex-start; justify-content:flex-end; }
.footer-email-stack{ display:flex; flex-direction:column; gap:10px; min-width:240px; }
.insurance-page-shell .social-strip{ margin-top: 40px; }
.insurance-summary-only{ padding: 34px; }
.insurance-summary-only .section-heading p{ max-width: 78ch; }
.insurance-summary-only .marketing-card-grid{ margin-top: 18px; }
.home-cards-shell{
  background:
    radial-gradient(1100px 520px at 50% -12%, rgba(132,147,53,0.30), transparent 60%),
    linear-gradient(180deg, rgba(10,18,12,0.98), rgba(5,10,7,1));
}
.home-product-card{
  animation: floatCard 8s ease-in-out infinite;
  transition: transform .28s ease, box-shadow .28s ease, border-color .28s ease;
}
.home-product-card .home-product-image{ transition: transform .48s ease; }
.home-product-card:hover{ transform: translateY(-12px) scale(1.01); box-shadow: 0 30px 70px rgba(0,0,0,0.30); }
.home-product-card:hover .home-product-image{ transform: scale(1.03); }
.card-float-b{ animation-delay: 1.3s; }
.card-float-c{ animation-delay: 2.6s; }
@keyframes floatCard {
  0%, 100% { transform: translateY(0px); }
  50% { transform: translateY(-8px); }
}
.home-cards-shell .social-strip{ margin-top: 68px; }
.detail-section-stack{ display:flex; flex-direction:column; gap:18px; }
.detail-slice{ display:grid; grid-template-columns: 1.02fr .98fr; gap:22px; padding:24px; border-radius:28px; align-items:center; overflow:hidden; }
.detail-slice.detail-reverse{ grid-template-columns: .98fr 1.02fr; }
.detail-slice.detail-reverse .detail-slice-image{ order:2; }
.detail-slice.detail-reverse .detail-slice-copy{ order:1; }
.detail-slice-image{ width:100%; height:340px; object-fit:cover; border-radius:22px; display:block; box-shadow: var(--shadow); }
.detail-slice-copy{ display:flex; flex-direction:column; gap:12px; }
.detail-slice-copy h3{ margin:0; font-size: clamp(28px,3vw,42px); line-height:1.12; }
.detail-slice-copy p{ margin:0; line-height:1.8; font-size:16px; }
.detail-contact-slice .detail-slice-copy{ gap:16px; }
@media (max-width: 980px){
  .footer-contact-actions{ justify-content:center; }
  .detail-slice, .detail-slice.detail-reverse{ grid-template-columns:1fr; }
  .detail-slice.detail-reverse .detail-slice-image, .detail-slice.detail-reverse .detail-slice-copy{ order:initial; }
  .detail-slice-image{ height:280px; }
}
@media (max-width: 640px){
  .insurance-summary-only{ padding:22px; }
  .detail-slice{ padding:18px; }
  .detail-slice-image{ height:220px; }
  .footer-email-stack{ width:100%; min-width:0; }
}


.social-link.x-social{ color:#ffffff; }
.social-link.twitch{ color:#9146FF; }
.social-link.kick{ color:#53FC18; }

.footer-contact-actions{
  display:flex;
  flex-wrap:wrap;
  gap:16px;
  align-items:flex-start;
  justify-content:flex-start;
  margin-top:18px;
}
.footer-email-stack{ display:flex; flex-direction:column; gap:10px; min-width:300px; }
.modern-footer{ display:flex; flex-direction:column; gap:8px; }

.home-product-grid.home-product-grid-four{
  grid-template-columns: repeat(4, minmax(0,1fr));
}
.home-product-actions-stack{ display:flex; flex-direction:column; gap:12px; }
.product-subtitle{
  color:#334234;
  font-weight:700;
  line-height:1.45;
  font-size:14px;
}
.card-float-d{ animation-delay: 3.6s; }

.insurance-video-panel{ position:relative; overflow:hidden; isolation:isolate; }
.page-video{
  position:absolute; inset:0; width:100%; height:100%; object-fit:cover; z-index:0;
  opacity:0.20; pointer-events:none;
}
.insurance-video-overlay{
  position:absolute; inset:0; z-index:1;
  background: radial-gradient(800px 380px at 50% 0%, rgba(108,119,43,.22), transparent 60%), linear-gradient(180deg, rgba(5,10,7,.70), rgba(5,10,7,.84));
  pointer-events:none;
}
.insurance-summary-inner{ position:relative; z-index:2; }
.insurance-card-grid{ grid-template-columns: repeat(4, minmax(0,1fr)); gap:22px; }
.insurance-product-card{
  animation: floatCard 8s ease-in-out infinite;
  transition: transform .28s ease, box-shadow .28s ease;
}
.insurance-product-card:hover{ transform: translateY(-10px) scale(1.01); box-shadow: 0 28px 68px rgba(0,0,0,.28); }
.insurance-product-card .btn{ width:100%; }

@media (max-width: 1200px){
  .home-product-grid.home-product-grid-four,
  .insurance-card-grid{ grid-template-columns: repeat(2, minmax(0,1fr)); }
}
@media (max-width: 980px){
  .footer-contact-actions{ justify-content:center; }
}
@media (max-width: 640px){
  .home-product-grid.home-product-grid-four,
  .insurance-card-grid{ grid-template-columns: 1fr; }
  .footer-contact-actions{ justify-content:center; }
  .footer-email-stack{ width:100%; min-width:0; }
}


/* === C.O.T. service update overrides === */
.topbar{flex-wrap:wrap;align-items:center;justify-content:space-between;row-gap:12px}
.site-nav{display:flex;align-items:center;gap:10px}
.header-action-link{font-weight:800;min-width:140px;justify-content:center}
.header-main-link{background:rgba(132,147,53,.95)!important;border-color:rgba(132,147,53,.95)!important;color:#121710!important}
.header-portal-link{background:rgba(255,255,255,.06);border-color:rgba(255,255,255,.12);color:var(--text)!important}
.mobile-social-bar{display:none;width:100%;justify-content:center;padding-top:6px;border-top:1px solid rgba(255,255,255,.06)}
.mobile-social-bar .social-row{display:flex;justify-content:center;align-items:center;gap:14px;flex-wrap:nowrap;width:100%}
.service-home-shell{display:flex;flex-direction:column;gap:22px}
.service-home-hero{background:linear-gradient(135deg,rgba(15,20,13,.96),rgba(9,12,10,.96));border-radius:28px}
.service-home-hero h1{font-size:clamp(30px,4.2vw,48px);margin:10px 0 8px}
.service-home-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:18px}
.service-home-card{background:rgba(255,255,255,.96);border:1px solid rgba(14,18,14,.08);border-radius:24px;overflow:hidden;box-shadow:0 18px 48px rgba(0,0,0,.22);display:flex;flex-direction:column}
.service-video-wrap{position:relative;aspect-ratio:16/9;background:#e7ece1}
.service-video{width:100%;height:100%;border:0;display:block}
.service-home-body{padding:16px 16px 18px;display:flex;flex-direction:column;gap:10px;min-height:180px}
.service-home-title{font-size:13px;letter-spacing:.16em;text-transform:uppercase;font-weight:800;color:var(--primary2)}
.service-home-question{margin:0;font-size:18px;line-height:1.45;color:#1b241d;flex:1}
.service-home-btn{width:100%;justify-content:center;padding:10px 16px;font-size:14px}
.public-form-card,.training-page,.public-success-card{max-width:920px;margin:0 auto;width:100%;border-radius:28px}
.public-form-card h1,.training-page h1{margin:8px 0 12px;font-size:clamp(30px,4.2vw,46px)}
.training-copy{font-size:16px;line-height:1.8;color:var(--text);margin:0 0 12px}
.training-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:18px;margin:12px 0}
.training-panel{border:1px solid rgba(255,255,255,.08);background:rgba(255,255,255,.03);border-radius:22px;padding:20px}
.training-panel h2{margin:0 0 12px;font-size:22px}
.training-panel ul{margin:0;padding-left:18px;display:grid;gap:8px}
.training-price-panel{display:flex;justify-content:space-between;gap:20px;align-items:flex-end;flex-wrap:wrap}
.training-price{font-size:40px;font-weight:900;line-height:1.05;margin:8px 0 10px}
.mobile-reveal-card{opacity:.78;transform:translateY(0)}
@media (max-width: 1180px){.service-home-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media (max-width: 640px){
  .topbar{justify-content:center;padding:14px 14px 10px}
  .brand{width:100%;justify-content:center}
  .site-nav,.top-actions{width:100%;justify-content:center}
  .site-nav{order:3}
  .top-actions{order:2}
  .lang-toggle{margin:0}
  .mobile-social-bar{display:flex;order:4}
  .mobile-social-bar .social-link{background:transparent;border:none;box-shadow:none;width:auto;height:auto;padding:0}
  .mobile-social-bar .social-icon{width:17px;height:17px}
  .social-strip-icons-only{margin-top:28px}
  .service-home-grid{grid-template-columns:1fr;gap:14px}
  .service-home-hero{padding:18px}
  .service-home-card{border-radius:22px}
  .service-home-body{padding:14px 14px 16px;min-height:auto;gap:8px}
  .service-home-title{font-size:12px}
  .service-home-question{font-size:16px;line-height:1.4}
  .service-home-btn{padding:10px 14px;font-size:13px}
  .training-grid{grid-template-columns:1fr}
  .mobile-reveal-card{opacity:.3;transform:translateY(24px) scale(.97);transition:transform .45s ease,opacity .45s ease}
  .mobile-reveal-card.is-visible{opacity:1;transform:translateY(0) scale(1)}
}


/* v9 refinements */
.mobile-social-bar{display:flex;width:100%;justify-content:center;padding-top:8px;border-top:1px solid rgba(255,255,255,.06)}
.mobile-social-bar .social-row{display:flex;justify-content:center;align-items:center;gap:12px;flex-wrap:nowrap;width:100%}
.topbar{align-items:center;justify-content:space-between;row-gap:12px}
.service-home-hero{background:linear-gradient(135deg,rgba(15,20,13,.96),rgba(9,12,10,.96));border-radius:28px;text-align:left}
.service-home-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:18px}
.service-home-card{background:rgba(255,255,255,.96);border:1px solid rgba(14,18,14,.08);border-radius:24px;overflow:hidden;box-shadow:0 18px 48px rgba(0,0,0,.22);display:flex;flex-direction:column}
.service-home-card-head{padding:18px 18px 12px;background:rgba(255,255,255,.96)}
.service-home-title{font-size:22px;line-height:1.1;font-weight:900;color:#162015;letter-spacing:.01em;text-transform:none}
.service-home-body{padding:14px 18px 18px;display:flex;flex-direction:column;gap:10px;min-height:150px}
.service-home-question{margin:0;font-size:16px;line-height:1.5;color:#1b241d;flex:1}
.service-home-btn{width:100%;justify-content:center;padding:10px 16px;font-size:14px}
.footer-social-hidden,.social-strip,.social-strip-icons-only{display:none!important}
.training-amazon-page{max-width:1240px;margin:0 auto;width:100%;border-radius:28px}
.training-amazon-grid{display:grid;grid-template-columns:minmax(320px,420px) minmax(0,1fr);gap:28px;align-items:start}
.training-media-column{position:sticky;top:98px}

.training-media-stack{display:flex;flex-direction:column;gap:20px}
.training-price-card-secondary{margin-top:0}
.training-media-card{background:#fff;border:1px solid rgba(14,18,14,.08);border-radius:24px;padding:16px;box-shadow:0 18px 48px rgba(0,0,0,.18)}
.training-media-frame{position:relative;aspect-ratio:1/1;border-radius:18px;overflow:hidden;background:#eef2e8}
.training-video{width:100%;height:100%}
.training-detail-column h1{font-size:clamp(32px,4vw,48px);margin:10px 0 14px}
.training-lead-copy{font-size:18px;line-height:1.7}
.training-detail-panels{display:flex;flex-direction:column;gap:20px}
.training-panel{border:1px solid rgba(255,255,255,.08);background:rgba(255,255,255,.03);border-radius:22px;padding:20px}
.training-price-card{display:block;padding:22px;border:1px solid rgba(255,255,255,.12);background:rgba(255,255,255,.04);border-radius:22px;margin-top:8px;overflow:hidden}
.training-price-card-top{display:flex;flex-direction:column;gap:8px;align-items:flex-start}
.training-price-label{font-size:12px;text-transform:uppercase;letter-spacing:.14em;color:var(--muted);font-weight:800}
.training-price-row{display:flex;align-items:flex-start;gap:2px;color:var(--text)}
.training-price-currency{font-size:26px;line-height:1.1;font-weight:800;padding-top:8px}
.training-price-whole{font-size:52px;line-height:1;font-weight:900}
.training-price-subcopy{font-size:15px;line-height:1.6;color:var(--muted);max-width:48ch;display:block}
.training-buy-btn,.training-back-btn{width:100%;justify-content:center;display:flex}
.training-buy-btn-inline{margin-top:18px}
.training-square-note{margin:0;color:var(--muted)}
@media (max-width: 900px){
  .training-amazon-grid{grid-template-columns:1fr;gap:20px}
  .training-media-column{position:static}
  .training-price-card{grid-template-columns:1fr;gap:18px}.training-price-card-secondary{display:flex;flex-direction:column}
}
@media (max-width: 640px){
  .service-home-hero{text-align:center;padding:18px}
  .service-home-hero .eyebrow,.service-home-hero h1,.service-home-hero .sub{margin-left:auto;margin-right:auto}
  .topbar{justify-content:center;padding:14px 14px 10px}
  .brand{width:100%;justify-content:center}
  .site-nav,.top-actions{width:100%;justify-content:center}
  .site-nav{order:3}
  .top-actions{order:2}
  .lang-toggle{margin:0}
  .mobile-social-bar{display:flex;order:4}
  .mobile-social-bar .social-link{background:transparent;border:none;box-shadow:none;width:auto;height:auto;padding:0}
  .mobile-social-bar .social-icon{width:15px;height:15px}
  .mobile-social-bar .social-row{gap:10px}
  .service-home-grid{grid-template-columns:1fr;gap:14px}
  .service-home-card-head{padding:14px 14px 10px}
  .service-home-title{font-size:24px;text-align:left}
  .service-home-body{padding:12px 14px 16px;min-height:auto;gap:8px}
  .service-home-question{font-size:15px;line-height:1.4}
  .training-amazon-page{padding:0}
  .training-media-card,.training-panel,.training-price-card{border-radius:20px}
  .training-detail-column h1{font-size:32px}
  .training-price-whole{font-size:46px}
}

/* ===== v17 website home + dropdown nav ===== */
.topbar.topbar-website-home{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:18px;
  padding:18px 24px;
}
.topbar.topbar-website-home .site-nav,
.topbar.topbar-website-home .top-actions{
  width:auto;
  margin:0;
}
.topbar.topbar-website-home .site-nav{margin-left:auto;}
.topbar.topbar-website-home .mobile-social-bar{display:none !important;}

.topbar.topbar-forms-hub,
.topbar.topbar-public-secondary{
  display:grid;
  grid-template-columns:auto 1fr auto;
  align-items:center;
  gap:18px;
  padding:16px 22px;
}
.topbar.topbar-forms-hub .site-nav,
.topbar.topbar-public-secondary .site-nav{
  justify-self:center;
  margin:0 auto;
}
.topbar.topbar-forms-hub .top-actions,
.topbar.topbar-public-secondary .top-actions{
  justify-self:end;
}
.topbar.topbar-forms-hub .mobile-social-bar{
  grid-column:1 / -1;
  display:flex !important;
  justify-content:center;
  width:100%;
  padding-top:8px;
  border-top:1px solid rgba(255,255,255,.06);
}
.topbar.topbar-forms-hub .mobile-social-bar .social-link{
  background:transparent;
  border:none;
  box-shadow:none;
  width:auto;
  height:auto;
  padding:0;
}
.topbar.topbar-forms-hub .mobile-social-bar .social-icon{width:16px;height:16px;}
.topbar.topbar-public-secondary .mobile-social-bar{display:none !important;}

.site-nav-website-home,
.site-nav-forms-hub,
.site-nav-public-secondary{display:flex;align-items:center;gap:10px;}

.menu-dropdown{
  position:relative;
}
.menu-dropdown > summary{
  list-style:none;
  cursor:pointer;
  user-select:none;
}
.menu-dropdown > summary::-webkit-details-marker{display:none;}
.menu-dropdown-panel{
  position:absolute;
  top:calc(100% + 10px);
  right:0;
  min-width:220px;
  padding:10px;
  border-radius:18px;
  border:1px solid rgba(255,255,255,.10);
  background:linear-gradient(180deg, rgba(18,24,19,.98), rgba(11,16,13,.98));
  box-shadow:0 22px 60px rgba(0,0,0,.28);
  opacity:0;
  transform:translateY(12px);
  pointer-events:none;
  z-index:60;
}
.menu-dropdown[open] .menu-dropdown-panel{
  opacity:1;
  transform:translateY(0);
  pointer-events:auto;
}
.site-nav-forms-hub .menu-dropdown-panel,
.site-nav-public-secondary .menu-dropdown-panel{
  left:50%;
  right:auto;
  transform:translate(-50%, 12px);
}
.site-nav-forms-hub .menu-dropdown[open] .menu-dropdown-panel,
.site-nav-public-secondary .menu-dropdown[open] .menu-dropdown-panel{
  transform:translate(-50%, 0);
}
.menu-dropdown-link{
  display:block;
  padding:12px 14px;
  border-radius:14px;
  color:var(--text);
  font-weight:700;
  text-decoration:none;
}
.menu-dropdown-link:hover{
  text-decoration:none;
  background:rgba(255,255,255,.06);
}

.website-home-shell{
  display:flex;
  flex-direction:column;
  gap:26px;
  padding-bottom:48px;
}
.website-home-hero{
  position:relative;
  display:grid;
  grid-template-columns:minmax(0, 1.1fr) minmax(320px, .9fr);
  gap:30px;
  align-items:center;
  padding:34px;
  border-radius:34px;
  border:1px solid rgba(255,255,255,.08);
  background:
    radial-gradient(780px 360px at 0% 0%, rgba(108,119,43,.22), transparent 60%),
    radial-gradient(560px 240px at 100% 20%, rgba(255,255,255,.06), transparent 55%),
    linear-gradient(135deg, rgba(12,18,14,.98), rgba(6,10,8,.98));
  box-shadow:0 28px 80px rgba(0,0,0,.25);
  overflow:hidden;
}
.website-hero-copy h1{
  margin:10px 0 18px;
  font-size:clamp(40px, 5.8vw, 76px);
  line-height:1.02;
  letter-spacing:-.035em;
  max-width:12ch;
}
.website-hero-body{
  margin:0;
  max-width:66ch;
  font-size:18px;
  line-height:1.85;
  color:#d8e1db;
}
.website-highlight-row{
  display:flex;
  flex-wrap:wrap;
  gap:12px;
  margin-top:24px;
}
.website-highlight-chip{
  display:inline-flex;
  align-items:center;
  padding:12px 16px;
  border-radius:999px;
  background:rgba(255,255,255,.05);
  border:1px solid rgba(255,255,255,.08);
  color:#eef4ef;
  font-size:13px;
  font-weight:700;
}
.website-hero-visual{
  display:grid;
  grid-template-columns:1.12fr .88fr;
  gap:16px;
}
.website-hero-primary img,
.website-hero-secondary img,
.website-media-primary img,
.website-media-secondary img{
  width:100%;
  display:block;
  object-fit:cover;
  border-radius:24px;
  border:1px solid rgba(255,255,255,.08);
  box-shadow:0 18px 48px rgba(0,0,0,.22);
}
.website-hero-primary img{height:420px;}
.website-hero-secondary{
  display:grid;
  gap:16px;
}
.website-hero-secondary img{height:202px;}
.website-section-stack{display:flex;flex-direction:column;gap:24px;}
.website-service-section{
  display:grid;
  grid-template-columns:minmax(0, 1fr) minmax(320px, 430px);
  gap:28px;
  align-items:center;
  padding:30px;
  border-radius:32px;
  border:1px solid rgba(255,255,255,.08);
  box-shadow:0 22px 70px rgba(0,0,0,.20);
  overflow:hidden;
}
.website-service-reverse{
  grid-template-columns:minmax(320px, 430px) minmax(0, 1fr);
}
.website-service-reverse .website-service-copy{order:2;}
.website-service-reverse .website-service-media{order:1;}
.website-section-kicker{
  font-size:12px;
  letter-spacing:.24em;
  text-transform:uppercase;
  font-weight:900;
  color:var(--primary);
}
.website-service-copy h2{
  margin:12px 0 14px;
  font-size:clamp(30px, 4vw, 50px);
  line-height:1.08;
  letter-spacing:-.03em;
}
.website-service-question{
  margin:0 0 14px;
  font-size:20px;
  line-height:1.5;
  font-weight:800;
}
.website-service-body{
  margin:0 0 20px;
  font-size:17px;
  line-height:1.9;
}
.website-service-tags{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin-bottom:22px;
}
.website-service-tags span{
  display:inline-flex;
  align-items:center;
  padding:10px 14px;
  border-radius:999px;
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.10);
  font-size:12px;
  font-weight:800;
  letter-spacing:.05em;
  text-transform:uppercase;
}
.website-service-btn{align-self:flex-start;min-width:180px;justify-content:center;}
.website-service-media{display:flex;flex-direction:column;gap:14px;}
.website-media-primary img{height:320px;}
.website-media-secondary{display:grid;grid-template-columns:1fr 1fr;gap:12px;}
.website-media-secondary img{height:150px;}
.website-theme-bright{
  background:linear-gradient(140deg, rgba(248,251,244,.98), rgba(233,238,224,.95));
  color:#152017;
}
.website-theme-bright .website-service-body,
.website-theme-bright .website-service-question{color:#223324;}
.website-theme-bright .website-service-tags span{background:rgba(21,32,23,.06);border-color:rgba(21,32,23,.08);color:#1c2a1f;}
.website-theme-olive{
  background:linear-gradient(140deg, rgba(92,107,37,.92), rgba(32,44,28,.95));
}
.website-theme-charcoal{
  background:linear-gradient(145deg, rgba(15,20,19,.98), rgba(24,29,27,.96));
}
.website-theme-deep{
  background:linear-gradient(145deg, rgba(7,17,14,.98), rgba(14,34,29,.96));
}
.website-theme-sand{
  background:linear-gradient(145deg, rgba(245,240,228,.98), rgba(233,228,211,.96));
  color:#1b231e;
}
.website-theme-sand .website-service-body,
.website-theme-sand .website-service-question{color:#28322b;}
.website-theme-sand .website-service-tags span{background:rgba(19,31,21,.06);border-color:rgba(19,31,21,.08);color:#243029;}
.website-theme-tech{
  background:linear-gradient(145deg, rgba(17,24,20,.98), rgba(43,61,36,.96));
}
.website-home-footer{
  padding:28px 30px;
  border-radius:24px;
  border:1px solid rgba(255,255,255,.08);
  background:linear-gradient(140deg, rgba(13,19,15,.96), rgba(10,15,12,.98));
}
.website-home-footer p{
  margin:0;
  font-size:16px;
  line-height:1.8;
  color:#d8e2db;
}
.website-reveal{
  opacity:0;
  transform:translateY(42px) scale(.985);
  transition:opacity .65s ease, transform .8s cubic-bezier(.2,.7,.2,1);
}
.website-reveal.is-visible{opacity:1;transform:translateY(0) scale(1);}

@media (max-width: 1180px){
  .website-home-hero,
  .website-service-section,
  .website-service-reverse{
    grid-template-columns:1fr;
  }
  .website-service-reverse .website-service-copy,
  .website-service-reverse .website-service-media{order:initial;}
  .website-hero-copy h1{max-width:none;}
}
@media (max-width: 900px){
  .topbar.topbar-website-home,
  .topbar.topbar-forms-hub,
  .topbar.topbar-public-secondary{
    display:flex;
    flex-wrap:wrap;
    justify-content:center;
    padding:14px 16px 12px;
  }
  .topbar.topbar-website-home .brand,
  .topbar.topbar-forms-hub .brand,
  .topbar.topbar-public-secondary .brand,
  .topbar.topbar-website-home .site-nav,
  .topbar.topbar-forms-hub .site-nav,
  .topbar.topbar-public-secondary .site-nav,
  .topbar.topbar-website-home .top-actions,
  .topbar.topbar-forms-hub .top-actions,
  .topbar.topbar-public-secondary .top-actions{
    width:100%;
    justify-content:center;
  }
  .topbar.topbar-website-home .brand,
  .topbar.topbar-forms-hub .brand,
  .topbar.topbar-public-secondary .brand{justify-content:center;text-align:center;}
  .website-home-hero{padding:22px;gap:20px;}
  .website-hero-copy h1{font-size:38px;}
  .website-hero-body{font-size:16px;line-height:1.75;}
  .website-hero-primary img{height:280px;}
  .website-hero-secondary img{height:140px;}
  .website-service-section{padding:22px;border-radius:28px;}
  .website-service-copy h2{font-size:34px;}
  .website-service-question{font-size:18px;}
  .website-service-body{font-size:16px;line-height:1.75;}
  .website-media-primary img{height:240px;}
  .website-media-secondary img{height:130px;}
}
@media (max-width: 640px){
  .website-highlight-row{gap:8px;}
  .website-highlight-chip{font-size:11px;padding:10px 12px;}
  .website-hero-visual{grid-template-columns:1fr;}
  .website-hero-secondary{grid-template-columns:1fr 1fr;}
  .website-hero-secondary img{height:110px;}
  .website-service-section{padding:18px;gap:18px;}
  .website-section-kicker{font-size:11px;}
  .website-service-copy h2{font-size:30px;}
  .website-service-question{font-size:17px;line-height:1.45;}
  .website-media-primary img{height:220px;}
  .website-media-secondary img{height:110px;}
  .menu-dropdown-panel,
  .site-nav-forms-hub .menu-dropdown-panel,
  .site-nav-public-secondary .menu-dropdown-panel{
    left:50%;
    right:auto;
    min-width:210px;
    transform:translate(-50%, 12px);
  }
  .menu-dropdown[open] .menu-dropdown-panel,
  .site-nav-forms-hub .menu-dropdown[open] .menu-dropdown-panel,
  .site-nav-public-secondary .menu-dropdown[open] .menu-dropdown-panel{
    transform:translate(-50%, 0);
  }
}


/* ===== v18 homepage + public header refinements ===== */
.header-menu-holder{
  display:flex;
  align-items:center;
}
.topbar.topbar-website-home,
.topbar.topbar-forms-hub,
.topbar.topbar-public-secondary{
  display:grid !important;
  grid-template-columns:1fr auto 1fr;
  align-items:center;
  gap:16px;
  padding:16px 22px;
}
.topbar.topbar-website-home .brand,
.topbar.topbar-forms-hub .brand,
.topbar.topbar-public-secondary .brand{
  grid-column:1;
  justify-self:start;
}
.topbar.topbar-website-home .site-nav,
.topbar.topbar-forms-hub .site-nav,
.topbar.topbar-public-secondary .site-nav{
  display:none !important;
}
.topbar.topbar-website-home .top-actions,
.topbar.topbar-forms-hub .top-actions,
.topbar.topbar-public-secondary .top-actions{
  grid-column:2;
  justify-self:center;
  display:flex;
  align-items:center;
  justify-content:center;
  gap:12px;
  margin:0;
  width:auto;
}
.topbar.topbar-website-home .top-actions .lang-toggle,
.topbar.topbar-forms-hub .top-actions .lang-toggle,
.topbar.topbar-public-secondary .top-actions .lang-toggle{
  margin:0;
}
.topbar.topbar-website-home .mobile-social-bar{display:none !important;}
.topbar.topbar-public-secondary .mobile-social-bar{display:none !important;}
.topbar.topbar-forms-hub .mobile-social-bar{
  grid-column:1 / -1;
  display:flex !important;
  justify-content:center;
  width:100%;
  padding-top:8px;
  border-top:1px solid rgba(255,255,255,.06);
}

.website-home-shell{
  display:flex;
  flex-direction:column;
  gap:24px;
  padding-bottom:48px;
}
.website-home-hero{
  display:grid;
  grid-template-columns:minmax(0, 1fr) minmax(320px, 430px);
  gap:26px;
  align-items:center;
  padding:30px;
  border-radius:34px;
  border:1px solid rgba(255,255,255,.08);
  background:
    radial-gradient(700px 320px at 0% 0%, rgba(108,119,43,.20), transparent 60%),
    linear-gradient(140deg, rgba(11,16,13,.98), rgba(6,9,8,.98));
  box-shadow:0 28px 80px rgba(0,0,0,.25);
  overflow:hidden;
}
.website-hero-copy h1{
  margin:10px 0 14px;
  font-size:clamp(28px, 3.8vw, 44px);
  line-height:1.18;
  font-weight:900;
  letter-spacing:-.02em;
  max-width:16ch;
}
.website-hero-body{
  margin:0;
  max-width:60ch;
  font-size:16px;
  line-height:1.8;
  color:#d8e1db;
}
.website-highlight-row,
.website-highlight-chip,
.website-hero-visual,
.website-hero-primary,
.website-hero-secondary,
.website-media-primary,
.website-media-secondary,
.website-service-tags{
  display:none !important;
}
.website-hero-visual-single img{
  width:100%;
  height:340px;
  display:block;
  object-fit:cover;
  border-radius:26px;
  border:1px solid rgba(255,255,255,.08);
  box-shadow:0 18px 48px rgba(0,0,0,.22);
}
.website-section-stack{
  display:flex;
  flex-direction:column;
  gap:22px;
}
.website-service-section{
  display:block;
  padding:26px;
  border-radius:32px;
  border:1px solid rgba(255,255,255,.08);
  box-shadow:0 22px 70px rgba(0,0,0,.20);
  overflow:hidden;
}
.website-service-content{
  display:flex;
  flex-direction:column;
  gap:16px;
}
.website-section-kicker{
  margin:0;
  font-size:clamp(30px, 4vw, 48px);
  line-height:1.04;
  font-weight:900;
  letter-spacing:-.02em;
  text-transform:none;
  color:inherit;
}
.website-service-media{
  display:block;
}
.website-service-media img{
  width:100%;
  height:340px;
  display:block;
  object-fit:cover;
  border-radius:24px;
  border:1px solid rgba(255,255,255,.08);
  box-shadow:0 18px 48px rgba(0,0,0,.18);
}
.website-service-question{
  margin:0;
  font-size:clamp(22px, 2.5vw, 30px);
  line-height:1.28;
  font-weight:900;
}
.website-service-body{
  margin:0;
  font-size:16px;
  line-height:1.85;
}
.website-service-btn{
  align-self:flex-start;
  min-width:190px;
  justify-content:center;
  margin-top:4px;
}
.website-theme-bright{
  background:linear-gradient(140deg, rgba(248,251,244,.98), rgba(233,238,224,.95));
  color:#152017;
}
.website-theme-bright .website-service-body,
.website-theme-bright .website-service-question{color:#223324;}
.website-theme-olive{
  background:linear-gradient(140deg, rgba(92,107,37,.92), rgba(32,44,28,.95));
}
.website-theme-charcoal{
  background:linear-gradient(145deg, rgba(15,20,19,.98), rgba(24,29,27,.96));
}
.website-theme-deep{
  background:linear-gradient(145deg, rgba(7,17,14,.98), rgba(14,34,29,.96));
}
.website-theme-sand{
  background:linear-gradient(145deg, rgba(245,240,228,.98), rgba(233,228,211,.96));
  color:#1b231e;
}
.website-theme-sand .website-service-body,
.website-theme-sand .website-service-question{color:#28322b;}
.website-theme-tech{
  background:linear-gradient(145deg, rgba(17,24,20,.98), rgba(43,61,36,.96));
}
.website-home-footer{
  padding:24px 28px;
  border-radius:24px;
  border:1px solid rgba(255,255,255,.08);
  background:linear-gradient(140deg, rgba(13,19,15,.96), rgba(10,15,12,.98));
}
.website-home-footer p{
  margin:0;
  font-size:16px;
  line-height:1.8;
  color:#d8e2db;
}

@media (max-width: 900px){
  .topbar.topbar-website-home,
  .topbar.topbar-forms-hub,
  .topbar.topbar-public-secondary{
    grid-template-columns:1fr;
    justify-items:center;
    padding:14px 16px 12px;
  }
  .topbar.topbar-website-home .brand,
  .topbar.topbar-forms-hub .brand,
  .topbar.topbar-public-secondary .brand{
    grid-column:1;
    justify-self:center;
    text-align:center;
  }
  .topbar.topbar-website-home .top-actions,
  .topbar.topbar-forms-hub .top-actions,
  .topbar.topbar-public-secondary .top-actions{
    grid-column:1;
    justify-self:center;
    flex-wrap:nowrap;
  }
  .website-home-hero{
    grid-template-columns:1fr;
    padding:22px;
    gap:18px;
  }
  .website-hero-copy h1{
    max-width:none;
    font-size:34px;
  }
  .website-hero-body{
    font-size:15px;
    line-height:1.7;
  }
  .website-hero-visual-single img{
    height:250px;
  }
  .website-service-section{
    padding:20px;
    border-radius:28px;
  }
  .website-section-kicker{
    font-size:34px;
  }
  .website-service-media img{
    height:230px;
  }
  .website-service-question{
    font-size:20px;
  }
  .website-service-body{
    font-size:15px;
    line-height:1.75;
  }
}

@media (max-width: 640px){
  .topbar.topbar-website-home .top-actions,
  .topbar.topbar-forms-hub .top-actions,
  .topbar.topbar-public-secondary .top-actions{
    gap:8px;
  }
  .header-menu-holder .menu-dropdown > summary,
  .lang-toggle{
    transform:scale(.96);
    transform-origin:center;
  }
  .website-hero-copy h1{
    font-size:30px;
  }
  .website-section-kicker{
    font-size:30px;
  }
  .website-service-media img{
    height:200px;
  }
  .website-service-question{
    font-size:18px;
  }
}


.website-home-contact{
  padding:28px 30px;
  border-radius:24px;
  border:1px solid rgba(255,255,255,.08);
  background:linear-gradient(145deg, rgba(30,55,36,.98), rgba(15,33,21,.98));
  box-shadow:0 22px 70px rgba(0,0,0,.18);
}
.website-home-contact-title{
  margin:0 0 16px;
  font-size:clamp(24px, 3vw, 34px);
  line-height:1.15;
  font-weight:900;
  color:#f2f7f2;
}
.website-home-contact-grid{
  display:grid;
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:14px;
}
.website-home-contact-item{
  display:flex;
  flex-direction:column;
  gap:6px;
  padding:16px 18px;
  border-radius:18px;
  background:rgba(255,255,255,.05);
  border:1px solid rgba(255,255,255,.10);
  color:#eef5ef;
  text-decoration:none;
}
.website-home-contact-item:hover{
  text-decoration:none;
  background:rgba(255,255,255,.08);
}
.website-home-contact-item span{
  font-size:12px;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:rgba(238,245,239,.76);
  font-weight:700;
}
.website-home-contact-item strong{
  font-size:18px;
  line-height:1.4;
  font-weight:800;
  color:#ffffff;
  word-break:break-word;
}
@media (max-width: 900px){
  .website-home-contact{
    padding:22px;
  }
  .website-home-contact-grid{
    grid-template-columns:1fr;
  }
  .website-home-contact-item strong{
    font-size:16px;
  }
}
