:root {
  --silk-black: #111418;
  --signal-gold: #c99a2e;
  --port-teal: #0e7c73;
  --container-red: #c64a3a;
  --cloud-white: #f7f8f6;
  --steel-gray: #5d6670;
  --harbor-green: #123c3a;
  --ledger-blue: #e7f0f1;
  --permit-green: #56a46d;
  --customs-amber: #f1c65b;
  --manifest-gray: #d7dde1;
  --font-ui: "Inter", "Be Vietnam Pro", "Noto Sans", Arial, sans-serif;
  --font-heading: "Manrope", "Inter", Arial, sans-serif;
}

* {
  box-sizing: border-box;
}

html {
  scroll-behavior: smooth;
}

body {
  margin: 0;
  background: var(--cloud-white);
  color: var(--silk-black);
  font-family: var(--font-ui);
  overflow-x: hidden;
}

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

img {
  max-width: 100%;
  display: block;
}

.site-header {
  position: sticky;
  top: 0;
  z-index: 20;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
  padding: 16px clamp(20px, 4vw, 56px);
  background: rgb(247 248 246 / 92%);
  border-bottom: 1px solid var(--manifest-gray);
  backdrop-filter: blur(18px);
}

.brand {
  width: 180px;
  height: 48px;
  display: block;
}

.brand img {
  width: 180px;
  height: 48px;
  object-fit: contain;
}

.desktop-nav {
  display: flex;
  align-items: center;
  gap: 22px;
  color: var(--steel-gray);
  font-size: 14px;
  font-weight: 600;
}

.desktop-nav a:hover {
  color: var(--silk-black);
}

.mobile-nav {
  position: relative;
  display: none;
}

.mobile-nav summary {
  display: inline-flex;
  align-items: center;
  min-height: 38px;
  padding: 0 12px;
  border: 1px solid var(--manifest-gray);
  border-radius: 6px;
  background: white;
  color: var(--silk-black);
  font-size: 13px;
  font-weight: 800;
  list-style: none;
  cursor: pointer;
}

.mobile-nav summary::-webkit-details-marker {
  display: none;
}

.mobile-nav summary::after {
  content: "";
  width: 7px;
  height: 7px;
  margin-left: 8px;
  border-right: 2px solid currentColor;
  border-bottom: 2px solid currentColor;
  transform: rotate(45deg) translateY(-2px);
}

.mobile-nav[open] summary::after {
  transform: rotate(225deg) translate(-2px, -1px);
}

.mobile-nav nav {
  position: absolute;
  top: calc(100% + 10px);
  right: 0;
  z-index: 40;
  width: min(280px, calc(100vw - 32px));
  display: grid;
  padding: 8px;
  border: 1px solid var(--manifest-gray);
  border-radius: 8px;
  background: white;
  box-shadow: 0 18px 44px rgb(17 20 24 / 16%);
}

.mobile-nav nav a {
  padding: 12px 14px;
  border-radius: 6px;
  color: var(--silk-black);
  font-size: 14px;
  font-weight: 700;
}

.mobile-nav nav a:hover,
.mobile-nav nav a:focus-visible {
  background: var(--ledger-blue);
}

.header-cta,
.button,
.cta button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 44px;
  border-radius: 6px;
  font-weight: 750;
  white-space: nowrap;
}

.header-cta {
  padding: 0 18px;
  background: var(--silk-black);
  color: white;
  font-size: 14px;
}

.hero {
  display: grid;
  grid-template-columns: minmax(0, 0.95fr) minmax(420px, 1.05fr);
  gap: clamp(32px, 5vw, 72px);
  align-items: center;
  padding: clamp(44px, 5.4vw, 74px) clamp(20px, 4vw, 56px) 44px;
  min-height: calc(92vh - 78px);
}

.eyebrow {
  margin: 0 0 14px;
  color: var(--port-teal);
  font-size: 12px;
  font-weight: 800;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}

h1,
h2,
h3 {
  margin: 0;
  font-family: var(--font-heading);
  letter-spacing: 0;
}

h1 {
  max-width: 820px;
  font-size: clamp(42px, 6.2vw, 76px);
  line-height: 0.98;
}

.hero-lede {
  max-width: 640px;
  margin: 28px 0 0;
  color: var(--steel-gray);
  font-size: 19px;
  line-height: 1.65;
}

.hero-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-top: 34px;
}

.button {
  padding: 0 20px;
  border: 1px solid var(--manifest-gray);
}

.button.primary {
  background: var(--signal-gold);
  border-color: var(--signal-gold);
  color: var(--silk-black);
}

.button.secondary {
  background: transparent;
}

.hero-visual {
  position: relative;
  min-height: 500px;
  overflow: hidden;
  border-radius: 8px;
  background: var(--harbor-green);
  box-shadow: 0 24px 72px rgb(17 20 24 / 18%);
}

.hero-visual img {
  width: 100%;
  height: 500px;
  object-fit: cover;
  object-position: center;
  filter: saturate(0.92) contrast(1.03);
}

.hero-visual::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(110deg, rgb(18 60 58 / 70%), rgb(17 20 24 / 8%) 54%, rgb(201 154 46 / 16%));
}

.route-overlay {
  position: absolute;
  inset: auto 0 0 auto;
  z-index: 2;
  width: 92%;
  height: 88%;
  overflow: visible;
}

.route-overlay path {
  fill: none;
  stroke: var(--signal-gold);
  stroke-width: 4;
  stroke-dasharray: 10 12;
}

.route-overlay circle {
  fill: var(--container-red);
  stroke: white;
  stroke-width: 3;
}

.route-card {
  position: absolute;
  z-index: 3;
  width: min(260px, 42%);
  padding: 16px;
  background: rgb(247 248 246 / 92%);
  border: 1px solid white;
  border-radius: 8px;
}

.route-card span {
  display: block;
  margin-bottom: 6px;
  color: var(--steel-gray);
  font-size: 12px;
  font-weight: 700;
  text-transform: uppercase;
}

.route-card strong {
  font-size: 15px;
}

.route-card-a {
  left: 22px;
  bottom: 34px;
}

.route-card-b {
  right: 22px;
  top: 28px;
}

.metrics {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1px;
  margin: 0 clamp(20px, 4vw, 56px);
  background: var(--manifest-gray);
  border: 1px solid var(--manifest-gray);
}

.metrics div {
  background: white;
  padding: 24px;
}

.metrics span {
  color: var(--signal-gold);
  font-weight: 800;
}

.metrics strong {
  display: block;
  margin-top: 8px;
  font-size: 18px;
}

.metrics p {
  margin: 10px 0 0;
  color: var(--steel-gray);
  line-height: 1.55;
}

.section {
  padding: clamp(64px, 8vw, 108px) clamp(20px, 4vw, 56px);
}

.section-heading {
  display: grid;
  grid-template-columns: minmax(0, 0.95fr) minmax(280px, 0.7fr);
  gap: 36px;
  align-items: end;
  margin-bottom: 34px;
}

.section-heading.compact {
  display: block;
  max-width: 840px;
}

h2 {
  font-size: clamp(32px, 4.2vw, 52px);
  line-height: 1.08;
}

.section-heading p:not(.eyebrow) {
  margin: 0;
  color: var(--steel-gray);
  font-size: 17px;
  line-height: 1.65;
}

.service-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1px;
  background: var(--manifest-gray);
  border: 1px solid var(--manifest-gray);
}

.service-grid article,
.article-row article {
  min-height: 230px;
  padding: 28px;
  background: white;
}

.icon,
.article-row span {
  color: var(--container-red);
  font-weight: 800;
  font-size: 12px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

h3 {
  margin-top: 22px;
  font-size: 23px;
  line-height: 1.2;
}

.service-grid p,
.article-row p {
  color: var(--steel-gray);
  line-height: 1.6;
}

.industries {
  background: var(--harbor-green);
  color: white;
}

.industries .eyebrow {
  color: var(--customs-amber);
}

.industry-list {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
  margin-top: 34px;
}

.industry-list a {
  min-height: 88px;
  display: flex;
  align-items: center;
  padding: 18px;
  border: 1px solid rgb(255 255 255 / 18%);
  border-radius: 8px;
  background: rgb(255 255 255 / 8%);
  font-weight: 750;
}

.compliance {
  background: var(--ledger-blue);
}

.article-row {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
}

.process-steps {
  margin: 36px 0 0;
  padding: 0;
  list-style: none;
  display: grid;
  gap: 1px;
  background: var(--manifest-gray);
  border: 1px solid var(--manifest-gray);
}

.process-steps li {
  display: grid;
  grid-template-columns: 260px 1fr;
  gap: 24px;
  padding: 22px;
  background: white;
}

.process-steps strong {
  font-size: 18px;
}

.process-steps span {
  color: var(--steel-gray);
  line-height: 1.55;
}

.proof {
  display: grid;
  grid-template-columns: 0.8fr 1fr;
  gap: 48px;
  background: var(--silk-black);
  color: white;
}

.proof .eyebrow {
  color: var(--signal-gold);
}

.proof ul {
  margin: 0;
  padding: 0;
  list-style: none;
  display: grid;
  gap: 14px;
}

.proof li {
  padding: 18px;
  border: 1px solid rgb(255 255 255 / 14%);
  border-radius: 8px;
  background: rgb(255 255 255 / 6%);
}

.cta {
  display: grid;
  grid-template-columns: minmax(0, 0.9fr) minmax(360px, 0.65fr);
  gap: 46px;
  align-items: start;
  padding: clamp(64px, 8vw, 108px) clamp(20px, 4vw, 56px);
  background: white;
}

.cta form {
  display: grid;
  gap: 14px;
  padding: 22px;
  border: 1px solid var(--manifest-gray);
  border-radius: 8px;
  background: var(--cloud-white);
}

label {
  display: grid;
  gap: 8px;
  color: var(--steel-gray);
  font-size: 13px;
  font-weight: 700;
}

input,
textarea {
  width: 100%;
  border: 1px solid var(--manifest-gray);
  border-radius: 6px;
  padding: 13px 14px;
  color: var(--silk-black);
  font: inherit;
}

textarea {
  min-height: 120px;
  resize: vertical;
}

.cta button {
  border: 0;
  background: var(--port-teal);
  color: white;
  cursor: pointer;
}

.site-footer {
  display: flex;
  flex-wrap: wrap;
  gap: 14px 24px;
  justify-content: space-between;
  padding: 28px clamp(20px, 4vw, 56px);
  background: var(--silk-black);
  color: rgb(255 255 255 / 74%);
}

.site-footer strong {
  color: white;
}

@media (max-width: 1120px) {
  .desktop-nav {
    display: none;
  }

  .mobile-nav {
    display: block;
    margin-left: auto;
  }
}

@media (max-width: 980px) {

  .hero,
  .section-heading,
  .proof,
  .cta {
    grid-template-columns: 1fr;
  }

  .hero {
    min-height: 0;
  }

  .hero-visual {
    min-height: 420px;
  }

  .hero-visual img {
    height: 420px;
  }

  .metrics,
  .service-grid,
  .industry-list,
  .article-row {
    grid-template-columns: 1fr 1fr;
  }
}

@media (max-width: 640px) {
  .site-header {
    padding: 12px 16px;
    gap: 10px;
  }

  .brand {
    width: 132px;
  }

  .brand img {
    width: 132px;
  }

  .mobile-nav summary {
    min-height: 36px;
    padding: 0 10px;
    font-size: 12px;
  }

  .header-cta {
    min-height: 36px;
    padding: 0 10px;
    font-size: 12px;
  }

  .hero {
    padding: 40px 16px 28px;
  }

  h1 {
    font-size: 42px;
  }

  .hero-lede {
    font-size: 17px;
  }

  .metrics,
  .service-grid,
  .industry-list,
  .article-row {
    grid-template-columns: 1fr;
    margin-left: 16px;
    margin-right: 16px;
  }

  .section,
  .cta {
    padding-left: 16px;
    padding-right: 16px;
  }

  .process-steps li {
    grid-template-columns: 1fr;
  }

  .route-card {
    width: 220px;
  }

  .route-card-b {
    top: 18px;
    right: 14px;
  }

  .route-card-a {
    left: 14px;
    bottom: 20px;
  }
}

/* --- SEO/A11y additions (skip-link, FAQ, section-more) --- */
.screen-reader-text {
  position: absolute;
  width: 1px;
  height: 1px;
  margin: -1px;
  padding: 0;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  border: 0;
  word-wrap: normal !important;
}

.skip-link.screen-reader-text:focus {
  position: fixed;
  top: 12px;
  left: 12px;
  z-index: 1000;
  width: auto;
  height: auto;
  margin: 0;
  padding: 10px 16px;
  clip: auto;
  background: var(--silk-black);
  color: var(--cloud-white);
  border-radius: 6px;
  font-weight: 600;
}

.section-more {
  margin-top: 24px;
}

.section-more a {
  color: var(--port-teal);
  font-weight: 600;
}

.section.faq .faq-list {
  display: grid;
  gap: 12px;
  max-width: 820px;
}

.section.faq details {
  border: 1px solid var(--manifest-gray);
  border-radius: 8px;
  padding: 16px 20px;
  background: #fff;
}

.section.faq summary {
  cursor: pointer;
  font-family: var(--font-heading);
  font-weight: 700;
  color: var(--harbor-green);
  list-style: none;
}

.section.faq summary::-webkit-details-marker {
  display: none;
}

.section.faq summary::after {
  content: "+";
  float: right;
  color: var(--signal-gold);
  font-weight: 800;
}

.section.faq details[open] summary::after {
  content: "–";
}

.section.faq details p {
  margin: 12px 0 0;
  color: var(--steel-gray);
  line-height: 1.6;
}
.page-main .entry-content blockquote {
  border-left: 4px solid #c99a2e;
  margin: 1.4em 0;
  padding: 4px 0 4px 18px;
  color: #3a4048;
}
.post-list {
  display: grid;
  gap: 22px;
}
.post-card {
  border: 1px solid #d7dde1;
  border-radius: 8px;
  padding: 24px 26px;
  background: #fff;
}
.post-card h2 {
  margin: 0 0 8px;
  font-size: 22px;
}
.post-card h2 a {
  color: #111418;
  text-decoration: none;
}
.post-card h2 a:hover {
  color: #0e7c73;
}
.post-card .read-more {
  display: inline-block;
  margin-top: 10px;
  color: #0e7c73;
  font-weight: 600;
  text-decoration: none;
}
.page-main .navigation {
  margin-top: 32px;
}

/* ============ NATIVE HOMEPAGE COMPONENTS (no Elementor) ============ */

/* Hero chips + shipment card */
.hero-chips { list-style:none; margin:28px 0 0; padding:0; display:flex; flex-wrap:wrap; gap:10px; }
.hero-chips li { font-size:13px; font-weight:700; color:var(--steel-gray); padding:8px 14px;
  border:1px solid var(--manifest-gray); border-radius:999px; background:#fff; }

.ship-card { align-self:center; background:#fff; border:1px solid var(--manifest-gray);
  border-radius:8px; overflow:hidden; box-shadow:0 24px 72px rgb(17 20 24 / 12%); }
.ship-card-head { display:flex; align-items:center; justify-content:space-between; gap:12px;
  padding:16px 18px; background:var(--harbor-green); color:#fff; font-size:14px; }
.ship-card-head .badge { font-size:11px; font-weight:800; letter-spacing:.04em; text-transform:uppercase;
  padding:4px 10px; border-radius:999px; background:rgb(255 255 255 / 16%); }
.ship-rows { list-style:none; margin:0; padding:4px 0; }
.ship-rows li { display:flex; align-items:center; justify-content:space-between; gap:14px;
  padding:13px 18px; border-top:1px solid var(--cloud-white); }
.ship-rows li:first-child { border-top:0; }
.ship-rows span { font-size:14px; font-weight:600; }
.ship-rows em { font-style:normal; font-size:12px; font-weight:800; padding:4px 10px;
  border-radius:999px; white-space:nowrap; }
.ship-rows em.ok { color:var(--harbor-green); background:rgb(86 164 109 / 16%); }
.ship-rows em.warn { color:#8a5d00; background:rgb(241 198 91 / 30%); }
.ship-rows em.muted { color:var(--steel-gray); background:var(--manifest-gray); }
.ship-card-foot { padding:13px 18px; border-top:1px solid var(--manifest-gray);
  color:var(--steel-gray); font-size:12px; font-weight:700; }

/* Service cards — no underline; clean bullets */
.service-grid h3 { margin-top:14px; }
.service-grid h3 a { color:inherit; text-decoration:none; }
.service-grid h3 a:hover { color:var(--port-teal); }
.service-grid article ul { margin:16px 0 0; padding:0; list-style:none; display:grid; gap:8px; }
.service-grid article ul li { position:relative; padding-left:18px; color:var(--steel-gray); font-size:14px; }
.service-grid article ul li::before { content:""; position:absolute; left:0; top:9px; width:6px; height:6px;
  border-radius:50%; background:var(--signal-gold); }

/* Industries image cards */
.industry-cards { display:grid; grid-template-columns:repeat(3,1fr); gap:14px; margin-top:34px; }
.industry-cards a { position:relative; display:flex; align-items:flex-end; min-height:200px; padding:18px;
  border-radius:8px; overflow:hidden; color:#fff; background:var(--harbor-green);
  background-image:linear-gradient(180deg, rgb(17 20 24 / 8%), rgb(17 20 24 / 80%)), var(--bg);
  background-size:cover; background-position:center; }
.industry-cards span { display:grid; gap:2px; font-size:13px; color:rgb(255 255 255 / 82%); }
.industry-cards strong { font-size:17px; color:#fff; font-family:var(--font-heading); }

/* Compliance library table */
.library { background:var(--ledger-blue); }
.lib-table { margin-top:8px; border:1px solid var(--manifest-gray); border-radius:8px; overflow:hidden; background:#fff; }
.lib-row { display:grid; grid-template-columns:170px 1fr 180px; gap:16px; align-items:center;
  padding:14px 20px; border-top:1px solid var(--cloud-white); color:inherit; }
.lib-row:first-child { border-top:0; }
.lib-head { background:var(--cloud-white); color:var(--steel-gray); font-size:12px; font-weight:800;
  letter-spacing:.08em; text-transform:uppercase; }
a.lib-row:hover { background:var(--ledger-blue); }
.lib-row .code { font-weight:700; font-size:13px; letter-spacing:.02em; }
.lib-row .ok { color:var(--harbor-green); font-weight:700; font-size:13px; }

/* Process — dark with numbered timeline */
.process { background:var(--harbor-green); color:#fff; }
.process .eyebrow { color:var(--customs-amber); }
.process .section-heading p:not(.eyebrow) { color:rgb(255 255 255 / 72%); }
.process-steps { background:transparent; border:0; gap:0; margin-top:30px; }
.process-steps li { grid-template-columns:64px 1fr; gap:20px; background:transparent;
  padding:20px 0; border-top:1px solid rgb(255 255 255 / 14%); }
.process-steps li:first-child { border-top:0; }
.process-steps .step-no { font-family:var(--font-heading); font-size:22px; font-weight:800; color:var(--customs-amber); }
.process-steps strong { display:block; font-size:18px; margin-bottom:6px; }
.process-steps span { color:rgb(255 255 255 / 72%); line-height:1.55; }

/* Proof — clean checklist + neutral capability panel */
.proof-list { margin:24px 0 0; padding:0; list-style:none; display:grid; gap:12px; }
.proof-list li { position:relative; padding:0 0 0 26px; border:0; background:transparent;
  color:rgb(255 255 255 / 82%); line-height:1.55; }
.proof-list li::before { content:"✓"; position:absolute; left:0; top:0; color:var(--permit-green); font-weight:800; }
.proof-panel { align-self:center; padding:26px; border:1px solid rgb(255 255 255 / 14%);
  border-radius:8px; background:rgb(255 255 255 / 6%); }
.proof-panel .eyebrow { color:var(--signal-gold); }
.proof-panel p { color:rgb(255 255 255 / 78%); line-height:1.65; margin:8px 0 18px; }
.proof-panel .button.secondary { color:#fff; border-color:rgb(255 255 255 / 30%); background:transparent; }

/* Contact info list */
.contact-info { list-style:none; margin:22px 0 0; padding:0; display:grid; gap:8px; color:var(--steel-gray); }
.contact-info strong { color:var(--silk-black); font-size:18px; }
.contact-info a { color:var(--port-teal); }

/* Responsive for native components */
@media (max-width:980px) {
  .industry-cards { grid-template-columns:1fr 1fr; }
  .lib-row { grid-template-columns:130px 1fr 150px; }
}
@media (max-width:640px) {
  .industry-cards { grid-template-columns:1fr; }
  .lib-head { display:none; }
  .lib-row { grid-template-columns:1fr; gap:4px; padding:14px 16px; }
  .lib-row .ok { font-size:12px; }
  .process-steps li { grid-template-columns:46px 1fr; gap:14px; }
}

/* Footer — multi-column */
.site-footer { display:grid; grid-template-columns:1.5fr repeat(3,1fr); gap:28px 24px;
  align-items:start; padding:48px clamp(20px,4vw,56px) 32px; }
.footer-brand strong { display:block; font-size:22px; font-family:var(--font-heading); color:#fff; }
.footer-brand p { margin:10px 0 12px; color:rgb(255 255 255 / 70%); line-height:1.6; max-width:340px; }
.footer-brand .eyebrow { color:var(--signal-gold); }
.footer-col { display:grid; gap:10px; align-content:start; }
.footer-col h4 { margin:0 0 4px; font-size:12px; letter-spacing:.08em; text-transform:uppercase;
  color:rgb(255 255 255 / 60%); font-family:var(--font-ui); font-weight:800; }
.footer-col a { color:rgb(255 255 255 / 80%); font-size:14px; }
.footer-col a:hover { color:#fff; }
.footer-bar { padding:16px clamp(20px,4vw,56px); background:#0c0f12; color:rgb(255 255 255 / 60%); font-size:13px; }
@media (max-width:900px) { .site-footer { grid-template-columns:1fr 1fr; } }
@media (max-width:560px) { .site-footer { grid-template-columns:1fr; } }

/* ============ BRANDED INNER PAGES ============ */
.page-hero { padding:clamp(48px,6vw,84px) clamp(20px,4vw,56px) clamp(28px,3vw,40px);
  border-bottom:1px solid var(--manifest-gray); background:var(--cloud-white); }
.crumbs { display:flex; gap:8px; align-items:center; font-size:13px; color:var(--steel-gray); margin-bottom:18px; }
.crumbs a { color:var(--port-teal); font-weight:600; }
.crumbs span[aria-hidden] { color:var(--manifest-gray); }
.page-hero h1 { font-size:clamp(34px,5vw,60px); line-height:1.04; max-width:900px; }
.page-lede { max-width:700px; margin:18px 0 0; color:var(--steel-gray); font-size:18px; line-height:1.6; }

.page-main .entry-content { max-width:760px; margin:0 auto;
  padding:clamp(40px,5vw,72px) clamp(20px,4vw,56px); font-size:17px; line-height:1.75; }
.page-main .entry-content h2 { font-size:30px; margin:1.4em 0 .5em; }
.page-main .entry-content h3 { font-size:22px; margin:1.3em 0 .4em; }
.page-main .entry-content p { margin:0 0 1.1em; color:#2b3138; }
.page-main .entry-content ul, .page-main .entry-content ol { margin:0 0 1.2em; padding-left:1.3em; }
.page-main .entry-content li { margin:.4em 0; }
.page-main .entry-content a { color:var(--port-teal); text-decoration:underline; }
.page-main .entry-content img { border-radius:8px; margin:1.2em 0; }

/* Single posts rendered by Elementor theme builder */
body.single-post {
  background: var(--cloud-white);
}

body.single-post .elementor-location-single {
  color: var(--silk-black);
}

body.single-post .elementor-location-single .elementor-widget-theme-post-title .elementor-heading-title {
  font-family: var(--font-heading);
  font-size: clamp(32px, 4.1vw, 52px);
  line-height: 1.08;
  letter-spacing: 0;
  color: var(--silk-black);
  max-width: 18ch;
}

body.single-post .elementor-location-single .elementor-widget-post-info,
body.single-post .elementor-location-single .elementor-widget-post-info .elementor-icon-list-text,
body.single-post .elementor-location-single .elementor-widget-post-info .elementor-icon-list-text a {
  font-family: var(--font-ui);
  font-size: 13px;
  line-height: 1.5;
  color: var(--steel-gray);
}

body.single-post .elementor-location-single .elementor-widget-theme-post-content {
  font-family: var(--font-ui);
  font-size: 17px;
  line-height: 1.78;
  color: #27313a;
  text-align: left;
}

body.single-post .elementor-location-single .elementor-widget-theme-post-content > h1:first-child {
  display: none;
}

body.single-post .elementor-location-single .elementor-widget-theme-post-content p,
body.single-post .elementor-location-single .elementor-widget-theme-post-content ul,
body.single-post .elementor-location-single .elementor-widget-theme-post-content ol,
body.single-post .elementor-location-single .elementor-widget-theme-post-content blockquote,
body.single-post .elementor-location-single .elementor-widget-theme-post-content table {
  margin: 0 0 1.25em;
}

body.single-post .elementor-location-single .elementor-widget-theme-post-content h2,
body.single-post .elementor-location-single .elementor-widget-theme-post-content h3,
body.single-post .elementor-location-single .elementor-widget-theme-post-content h4 {
  font-family: var(--font-heading);
  letter-spacing: 0;
  color: var(--silk-black);
  text-wrap: balance;
}

body.single-post .elementor-location-single .elementor-widget-theme-post-content h2 {
  font-size: clamp(28px, 3vw, 36px);
  line-height: 1.16;
  margin: 1.8em 0 0.6em;
}

body.single-post .elementor-location-single .elementor-widget-theme-post-content h3 {
  font-size: clamp(22px, 2.2vw, 28px);
  line-height: 1.24;
  margin: 1.5em 0 0.5em;
}

body.single-post .elementor-location-single .elementor-widget-theme-post-content h4 {
  font-size: 18px;
  line-height: 1.35;
  margin: 1.2em 0 0.45em;
}

body.single-post .elementor-location-single .elementor-widget-theme-post-content a {
  color: var(--port-teal);
  text-decoration-thickness: 1px;
  text-underline-offset: 0.14em;
}

body.single-post .elementor-location-single .elementor-widget-theme-post-content strong {
  color: var(--silk-black);
}

body.single-post .elementor-location-single .elementor-widget-theme-post-content ul,
body.single-post .elementor-location-single .elementor-widget-theme-post-content ol {
  padding-left: 1.25em;
}

body.single-post .elementor-location-single .elementor-widget-theme-post-content li + li {
  margin-top: 0.45em;
}

body.single-post .elementor-location-single .elementor-widget-theme-post-content blockquote {
  padding: 20px 22px;
  border: 1px solid var(--manifest-gray);
  border-left: 4px solid var(--signal-gold);
  border-radius: 8px;
  background: #fff;
  box-shadow: 0 18px 44px rgb(17 20 24 / 6%);
}

body.single-post .elementor-location-single .elementor-widget-theme-post-content blockquote p:last-child {
  margin-bottom: 0;
}

body.single-post .elementor-location-single .elementor-widget-theme-post-content table {
  width: 100%;
  display: block;
  overflow-x: auto;
  border-collapse: collapse;
  border: 1px solid var(--manifest-gray);
  border-radius: 8px;
  background: #fff;
  box-shadow: 0 12px 30px rgb(17 20 24 / 5%);
}

body.single-post .elementor-location-single .elementor-widget-theme-post-content table thead th {
  background: var(--ledger-blue);
  color: var(--silk-black);
  font-family: var(--font-ui);
  font-size: 13px;
  font-weight: 800;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

body.single-post .elementor-location-single .elementor-widget-theme-post-content table th,
body.single-post .elementor-location-single .elementor-widget-theme-post-content table td {
  padding: 14px 16px;
  border-bottom: 1px solid var(--manifest-gray);
  vertical-align: top;
  text-align: left;
  white-space: normal;
}

body.single-post .elementor-location-single .elementor-widget-theme-post-content table tr:last-child td {
  border-bottom: 0;
}

body.single-post .elementor-location-single .elementor-widget-theme-post-content figure,
body.single-post .elementor-location-single .elementor-widget-theme-post-content img {
  border-radius: 8px;
}

body.single-post .elementor-location-single .elementor-widget-table-of-contents .elementor-widget-container {
  padding: 18px 20px;
  border: 1px solid var(--manifest-gray);
  border-radius: 8px;
  background: #fff;
  box-shadow: 0 18px 40px rgb(17 20 24 / 6%);
}

body.single-post .elementor-location-single .elementor-widget-table-of-contents .elementor-toc__header,
body.single-post .elementor-location-single .elementor-widget-table-of-contents .elementor-toc__header-title {
  font-family: var(--font-heading);
  font-size: 18px;
  line-height: 1.2;
  color: var(--silk-black);
}

body.single-post .elementor-location-single .elementor-widget-table-of-contents .elementor-toc__list-item {
  font-family: var(--font-ui);
  font-size: 14px;
  line-height: 1.55;
  color: var(--steel-gray);
}

body.single-post .elementor-location-single .elementor-widget-table-of-contents .elementor-toc__list-item-text {
  color: inherit;
}

body.single-post .elementor-location-single .elementor-widget-table-of-contents .elementor-toc__list-item.elementor-active .elementor-toc__list-item-text,
body.single-post .elementor-location-single .elementor-widget-table-of-contents .elementor-toc__list-item:hover .elementor-toc__list-item-text {
  color: var(--harbor-green);
}

body.single-post .elementor-location-single .elementor-widget-heading .elementor-heading-title {
  font-family: var(--font-heading);
  letter-spacing: 0;
}

body.single-post .elementor-location-single .elementor-widget-icon-list .elementor-icon-list-item > .elementor-icon-list-text,
body.single-post .elementor-location-single .elementor-widget-icon-list .elementor-icon-list-item > a {
  font-family: var(--font-ui);
  font-size: 14px;
  line-height: 1.55;
}

body.single-post .elementor-location-single .elementor-widget-posts .elementor-post__title,
body.single-post .elementor-location-single .elementor-widget-posts .elementor-post__title a {
  font-family: var(--font-heading);
  font-size: 20px;
  line-height: 1.24;
  letter-spacing: 0;
  color: var(--silk-black);
}

body.single-post .elementor-location-single .elementor-widget-posts .elementor-post__meta-data,
body.single-post .elementor-location-single .elementor-widget-posts .elementor-post__excerpt p {
  font-family: var(--font-ui);
}

body.single-post .elementor-location-single .elementor-widget-posts .elementor-post__excerpt p {
  color: var(--steel-gray);
  line-height: 1.6;
}

@media (max-width: 1024px) {
  body.single-post .elementor-location-single .elementor-widget-theme-post-title .elementor-heading-title {
    max-width: none;
  }

  body.single-post .elementor-location-single .elementor-widget-theme-post-content {
    font-size: 16px;
    line-height: 1.72;
  }
}

@media (max-width: 767px) {
  body.single-post .elementor-location-single .elementor-widget-theme-post-title .elementor-heading-title {
    font-size: 28px;
    line-height: 1.16;
  }

  body.single-post .elementor-location-single .elementor-widget-theme-post-content {
    font-size: 16px;
    line-height: 1.7;
  }

  body.single-post .elementor-location-single .elementor-widget-theme-post-content h2 {
    font-size: 26px;
  }

  body.single-post .elementor-location-single .elementor-widget-theme-post-content h3 {
    font-size: 21px;
  }

  body.single-post .elementor-location-single .elementor-widget-theme-post-content blockquote {
    padding: 16px 16px 16px 18px;
  }

  body.single-post .elementor-location-single .elementor-widget-theme-post-content table th,
  body.single-post .elementor-location-single .elementor-widget-theme-post-content table td {
    min-width: 150px;
    padding: 12px 14px;
  }

  body.single-post .elementor-location-single .elementor-widget-table-of-contents .elementor-widget-container {
    padding: 16px;
  }

  body.single-post .elementor-location-single .elementor-widget-table-of-contents .elementor-toc__header,
  body.single-post .elementor-location-single .elementor-widget-table-of-contents .elementor-toc__header-title {
    font-size: 16px;
  }
}

.page-cta { display:flex; flex-wrap:wrap; align-items:center; justify-content:space-between; gap:20px;
  margin:0 clamp(20px,4vw,56px) clamp(48px,6vw,84px); padding:clamp(26px,3vw,40px);
  border-radius:8px; background:var(--silk-black); color:#fff; }
.page-cta h2 { font-size:clamp(22px,2.6vw,30px); line-height:1.15; }
.page-cta p { margin:8px 0 0; color:rgb(255 255 255 / 72%); }
@media (max-width:640px) { .page-cta { flex-direction:column; align-items:flex-start; } }

/* About / Contact extras */
.value-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:1px; background:var(--manifest-gray);
  border:1px solid var(--manifest-gray); margin-top:8px; }
.value-grid article { background:#fff; padding:26px; }
.value-grid h3 { margin:0 0 10px; font-size:20px; }
.value-grid p { margin:0; color:var(--steel-gray); line-height:1.6; }
.about-offices .office-list { display:flex; flex-wrap:wrap; gap:12px; margin-top:30px; }
.about-offices .office-list span { padding:14px 22px; border:1px solid rgb(255 255 255 / 18%); border-radius:8px;
  background:rgb(255 255 255 / 8%); font-weight:750; font-family:var(--font-heading); font-size:18px; }
.about-note { margin-top:24px; max-width:760px; color:rgb(255 255 255 / 70%); line-height:1.65; }
.contact-help { margin:18px 0 0; color:var(--steel-gray); line-height:1.65; max-width:460px; }
@media (max-width:640px) { .value-grid { grid-template-columns:1fr; } }

/* ============ BLOG LISTING ============ */
.blog-listing .section {
  padding-top: 36px;
}

.blog-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
}

.blog-card {
  display: grid;
  grid-template-rows: auto 1fr;
  overflow: hidden;
  border: 1px solid var(--manifest-gray);
  border-radius: 8px;
  background: #fff;
}

.blog-card-media {
  display: block;
  aspect-ratio: 16 / 10;
  background: var(--harbor-green);
}

.blog-card-media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.placeholder-media {
  width: 100%;
  height: 100%;
  background: linear-gradient(120deg, var(--harbor-green), var(--port-teal));
  opacity: 0.75;
}

.blog-card-body {
  display: grid;
  gap: 10px;
  padding: 18px;
}

.blog-meta {
  margin: 0;
  color: var(--steel-gray);
  font-size: 13px;
}

.blog-title {
  margin: 0;
  font-size: 22px;
  line-height: 1.2;
}

.blog-title a {
  color: var(--silk-black);
}

.blog-excerpt {
  margin: 0;
  color: var(--steel-gray);
  line-height: 1.55;
}

.blog-cats {
  margin: 0;
  color: var(--harbor-green);
  font-size: 12px;
  font-weight: 700;
}

.read-more {
  display: inline-block;
  margin-top: 8px;
  color: var(--port-teal);
  font-weight: 700;
}

.pagination-wrap .nav-links {
  margin-top: 22px;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 10px;
}

.pagination-wrap .page-numbers {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 38px;
  height: 38px;
  border: 1px solid var(--manifest-gray);
  border-radius: 999px;
  padding: 0 14px;
  font-weight: 700;
  color: var(--silk-black);
  background: #fff;
}

.pagination-wrap .page-numbers.current {
  background: var(--harbor-green);
  border-color: var(--harbor-green);
  color: #fff;
}

/* ============ LEGAL LIBRARY ============ */
.library-listing .section {
  padding-top: 34px;
}

.library-stats {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
}

.stat-card {
  padding: 18px 20px;
  border: 1px solid var(--manifest-gray);
  border-radius: 8px;
  background: #fff;
}

.stat-value {
  margin: 0;
  font-size: 34px;
  font-family: var(--font-heading);
  color: var(--harbor-green);
  line-height: 1;
}

.stat-label {
  margin: 10px 0 0;
  color: var(--steel-gray);
  font-size: 14px;
}

.doc-filter {
  margin: 26px 0 18px;
  display: grid;
  gap: 10px;
  max-width: 700px;
}

.doc-filter label {
  color: var(--steel-gray);
  font-size: 13px;
  font-weight: 700;
}

.doc-filter__row {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 8px;
}

.doc-filter input {
  border-radius: 6px;
}

.doc-filter button {
  border: 0;
  border-radius: 6px;
  padding: 0 18px;
  background: var(--harbor-green);
  color: #fff;
  font-weight: 700;
  cursor: pointer;
}

.doc-filter__chips {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin: 4px 0 28px;
}

.doc-chip {
  min-height: 36px;
  border: 1px solid var(--manifest-gray);
  border-radius: 999px;
  padding: 0 14px;
  display: inline-flex;
  align-items: center;
  font-size: 13px;
  font-weight: 700;
  color: var(--silk-black);
  background: #fff;
}

.doc-chip.is-active {
  background: var(--harbor-green);
  border-color: var(--harbor-green);
  color: #fff;
}

.doc-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 16px;
}

.doc-card {
  border: 1px solid var(--manifest-gray);
  border-radius: 8px;
  background: #fff;
  padding: 18px;
  display: grid;
  gap: 8px;
}

.doc-type {
  margin: 0;
  color: var(--port-teal);
  font-size: 12px;
  font-weight: 800;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.doc-title {
  margin: 0;
  font-size: 22px;
  line-height: 1.2;
}

.doc-meta {
  margin: 0;
  color: var(--steel-gray);
  font-size: 13px;
}

.doc-excerpt {
  margin: 0;
  color: var(--silk-black);
  line-height: 1.55;
}

.doc-link {
  margin-top: 6px;
  color: var(--harbor-green);
  font-weight: 700;
}

@media (max-width: 1020px) {
  .blog-grid,
  .doc-grid,
  .library-stats {
    grid-template-columns: 1fr 1fr;
  }
}

@media (max-width: 720px) {
  .blog-grid,
  .doc-grid,
  .library-stats {
    grid-template-columns: 1fr;
  }

  .doc-filter__row {
    grid-template-columns: 1fr;
  }
}
