:root {
  --navy: #10243e;
  --charcoal: #1f2933;
  --muted: #5d6978;
  --line: #dce3ea;
  --soft: #f4f7fa;
  --blue: #1c6dd0;
  --blue-dark: #164f9a;
  --amber: #f59e0b;
  --white: #ffffff;
  --shadow: 0 18px 45px rgba(16, 36, 62, 0.12);
}

* {
  box-sizing: border-box;
}

html {
  scroll-behavior: smooth;
}

body {
  margin: 0;
  font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Arial, sans-serif;
  color: var(--charcoal);
  background: var(--white);
  line-height: 1.6;
}

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

a {
  color: inherit;
}

.skip-link {
  position: absolute;
  left: 12px;
  top: -60px;
  z-index: 20;
  background: var(--navy);
  color: var(--white);
  padding: 10px 14px;
}

.skip-link:focus {
  top: 12px;
}

.container {
  width: min(1180px, calc(100% - 32px));
  margin: 0 auto;
}

.narrow {
  width: min(820px, calc(100% - 32px));
}

.site-header {
  position: sticky;
  top: 0;
  z-index: 10;
  background: rgba(255, 255, 255, 0.94);
  border-bottom: 1px solid var(--line);
  backdrop-filter: blur(18px);
}

.header-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  min-height: 74px;
  gap: 22px;
}

.brand {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  text-decoration: none;
  color: var(--navy);
  min-width: 230px;
}

.brand-mark {
  display: grid;
  place-items: center;
  width: 42px;
  height: 42px;
  border-radius: 8px;
  background: var(--navy);
  color: var(--white);
  font-weight: 800;
}

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

.site-nav {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  flex-wrap: wrap;
  gap: 4px;
}

.site-nav a {
  text-decoration: none;
  color: #334155;
  padding: 8px 10px;
  border-radius: 6px;
  font-size: 14px;
  font-weight: 650;
}

.site-nav a:hover,
.site-nav a.active {
  color: var(--blue-dark);
  background: #eaf2ff;
}

.menu-button {
  display: none;
  border: 1px solid var(--line);
  background: var(--white);
  color: var(--navy);
  padding: 9px 12px;
  border-radius: 6px;
  font-weight: 700;
}

.hero {
  position: relative;
  min-height: 620px;
  display: grid;
  align-items: center;
  overflow: hidden;
  border-bottom: 1px solid var(--line);
}

.hero-media {
  position: absolute;
  inset: 0;
  z-index: 0;
}

.hero-media::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg, rgba(255, 255, 255, 0.98) 0%, rgba(255, 255, 255, 0.92) 38%, rgba(255, 255, 255, 0.44) 64%, rgba(255, 255, 255, 0.18) 100%);
}

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

.hero-content {
  position: relative;
  z-index: 1;
  padding: 92px 0;
}

.hero h1,
.page-hero h1 {
  color: var(--navy);
  margin: 0 0 18px;
  max-width: 760px;
  font-size: clamp(42px, 7vw, 76px);
  line-height: 0.98;
  letter-spacing: 0;
}

.hero p:not(.eyebrow),
.page-hero p:not(.eyebrow) {
  max-width: 620px;
  color: #475569;
  font-size: 20px;
  margin: 0 0 26px;
}

.page-hero {
  background: linear-gradient(180deg, #f7faff 0%, #ffffff 100%);
  border-bottom: 1px solid var(--line);
}

.page-hero.compact {
  padding: 82px 0 56px;
}

.page-hero.compact h1 {
  font-size: clamp(36px, 6vw, 58px);
}

.eyebrow {
  margin: 0 0 10px;
  color: var(--blue-dark);
  text-transform: uppercase;
  font-size: 12px;
  font-weight: 800;
  letter-spacing: 0.08em;
}

.button-row,
.center-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
}

.center-actions {
  justify-content: center;
  margin-top: 30px;
}

.button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 44px;
  padding: 10px 16px;
  border: 1px solid transparent;
  border-radius: 6px;
  text-decoration: none;
  font-weight: 800;
  cursor: pointer;
}

.button.primary {
  background: var(--blue);
  color: var(--white);
}

.button.primary:hover {
  background: var(--blue-dark);
}

.button.secondary {
  background: var(--white);
  color: var(--navy);
  border-color: #b8c4d0;
}

.button.full {
  width: 100%;
  margin-top: 12px;
}

.trust-strip {
  background: var(--navy);
  color: var(--white);
}

.trust-list {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: 1px;
}

.trust-list span {
  min-height: 72px;
  display: grid;
  place-items: center;
  text-align: center;
  padding: 14px;
  border-left: 1px solid rgba(255, 255, 255, 0.12);
  font-weight: 750;
}

.section {
  padding: 76px 0;
}

.section.muted {
  background: var(--soft);
}

.section-head {
  margin-bottom: 28px;
}

.section-head h2,
.cta-inner h2,
.newsletter h2 {
  color: var(--navy);
  max-width: 760px;
  font-size: clamp(28px, 4vw, 42px);
  line-height: 1.08;
  margin: 0;
}

.card-grid,
.tool-grid,
.directory-grid,
.journey {
  display: grid;
  gap: 18px;
}

.card-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.tool-grid {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.directory-grid {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.journey {
  grid-template-columns: repeat(6, minmax(0, 1fr));
}

.tool-card,
.category-card,
.directory-card,
.journey article,
.tool-panel,
.side-panel,
.contact-form {
  background: var(--white);
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 22px;
  box-shadow: 0 1px 2px rgba(16, 36, 62, 0.04);
}

.tool-card {
  min-height: 238px;
  display: flex;
  flex-direction: column;
}

.tool-card h3,
.category-card h3,
.directory-card h3,
.journey h3,
.side-panel h2,
.contact-form h2,
.guide-body h2,
.directory-card h2 {
  color: var(--navy);
  line-height: 1.18;
  margin: 0 0 10px;
}

.tool-card p,
.category-card p,
.directory-card p,
.journey p,
.side-panel p,
.guide-body p {
  color: var(--muted);
}

.card-icon {
  width: 42px;
  height: 42px;
  display: grid;
  place-items: center;
  border-radius: 8px;
  color: var(--blue-dark);
  background: #eaf2ff;
  font-weight: 900;
  margin-bottom: 18px;
}

.text-link,
.mini-link {
  color: var(--blue-dark);
  font-weight: 800;
  text-decoration: none;
}

.text-link {
  margin-top: auto;
}

.text-link:hover,
.mini-link:hover {
  text-decoration: underline;
}

.journey article span {
  display: inline-block;
  color: var(--amber);
  font-weight: 900;
  margin-bottom: 12px;
}

.small-note {
  font-size: 14px;
}

.cta-band {
  background: var(--navy);
  color: var(--white);
  padding: 48px 0;
}

.cta-band .eyebrow,
.cta-band h2 {
  color: var(--white);
}

.cta-inner,
.newsletter-inner,
.split-layout,
.guide-layout,
.tool-layout {
  display: grid;
  gap: 28px;
}

.cta-inner,
.newsletter-inner {
  grid-template-columns: 1.5fr 1fr;
  align-items: center;
}

.split-layout,
.tool-layout,
.guide-layout {
  grid-template-columns: minmax(0, 1fr) 330px;
  align-items: start;
}

.newsletter {
  background: #fff8eb;
}

.inline-form,
.stacked-form {
  display: grid;
  gap: 14px;
}

.inline-form {
  grid-template-columns: 1fr 1fr auto;
  align-items: end;
}

.stacked-form label,
.inline-form label {
  display: grid;
  gap: 6px;
  color: var(--navy);
  font-weight: 750;
}

input,
select,
textarea {
  width: 100%;
  border: 1px solid #b8c4d0;
  border-radius: 6px;
  min-height: 42px;
  padding: 10px 12px;
  color: var(--charcoal);
  background: var(--white);
  font: inherit;
}

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

.generated-text {
  min-height: 310px;
  font-family: ui-monospace, SFMono-Regular, Consolas, monospace;
}

.form-message,
.tool-output {
  margin: 0;
  color: var(--blue-dark);
  font-weight: 750;
}

.tool-output {
  background: #f8fafc;
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 16px;
  min-height: 54px;
}

.tool-output h3 {
  color: var(--navy);
  margin: 0 0 8px;
}

.tool-output ul {
  margin: 10px 0 0;
  padding-left: 20px;
  color: var(--muted);
}

.result-table {
  width: 100%;
  border-collapse: collapse;
  margin: 10px 0 14px;
}

.table-scroll {
  width: 100%;
  overflow-x: auto;
}

.sourcing-city-table {
  min-width: 980px;
}

.sourcing-city-table .map-actions {
  display: grid;
  grid-template-columns: 1fr;
  min-width: 160px;
}

.result-table th,
.result-table td {
  border-bottom: 1px solid var(--line);
  padding: 10px 8px;
  text-align: left;
  vertical-align: top;
}

.result-table th {
  color: var(--navy);
  width: 42%;
}

.search-results {
  width: min(940px, 100%);
  margin-top: 12px;
  padding: 14px;
  background: var(--white);
  border: 1px solid var(--line);
  border-radius: 8px;
  box-shadow: var(--shadow);
  text-align: left;
}

.search-results h2 {
  color: var(--navy);
  font-size: 17px;
  margin: 0 0 10px;
}

.search-results a {
  display: grid;
  grid-template-columns: 132px minmax(0, 1fr);
  gap: 4px 12px;
  padding: 10px 0;
  color: inherit;
  text-decoration: none;
  border-top: 1px solid #edf1f5;
}

.search-results span {
  grid-row: span 2;
  align-self: start;
  width: fit-content;
  color: var(--blue-dark);
  background: #eaf2ff;
  border-radius: 999px;
  padding: 3px 8px;
  font-size: 12px;
  font-weight: 900;
}

.search-results strong {
  color: var(--navy);
}

.search-results small {
  color: var(--muted);
}

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

.related-panel {
  background: var(--white);
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 20px;
}

.related-panel h2 {
  color: var(--navy);
  margin: 0 0 10px;
}

.related-panel a {
  display: block;
  color: var(--blue-dark);
  text-decoration: none;
  font-weight: 800;
  padding: 9px 0;
  border-top: 1px solid #edf1f5;
}

.guide-checklist {
  color: var(--muted);
  padding-left: 22px;
}

.guide-checklist li {
  margin: 8px 0;
}

.compact-portal-section {
  padding: 46px 0;
}

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

.compact-nav-card,
.template-card,
.resource-directory-group {
  display: grid;
  gap: 9px;
  color: inherit;
  text-decoration: none;
  background: var(--white);
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 18px;
}

.compact-nav-card:hover {
  border-color: #9bbbe8;
  box-shadow: var(--shadow);
}

.compact-nav-card strong,
.template-card h2,
.resource-directory-group h2 {
  color: var(--navy);
  margin: 0;
}

.compact-nav-card small,
.template-card p {
  color: var(--muted);
}

.compact-nav-card b {
  color: var(--blue-dark);
}

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

.resource-directory-item {
  border-top: 1px solid #edf1f5;
  padding: 14px 0;
}

.resource-directory-item h3 {
  color: var(--navy);
  margin: 0 0 8px;
}

.resource-directory-item dl {
  display: grid;
  grid-template-columns: 140px minmax(0, 1fr);
  gap: 6px 12px;
  margin: 0;
}

.resource-directory-item dt {
  color: var(--navy);
  font-weight: 900;
}

.resource-directory-item dd {
  margin: 0;
  color: var(--muted);
}

.mini-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 12px;
}

.mini-actions a {
  color: var(--blue-dark);
  background: #eaf2ff;
  border-radius: 999px;
  padding: 5px 9px;
  text-decoration: none;
  font-size: 12px;
  font-weight: 900;
}

.template-card textarea {
  min-height: 180px;
  font-family: ui-monospace, SFMono-Regular, Consolas, monospace;
  font-size: 13px;
}

.result-card {
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--white);
  padding: 14px;
  margin: 12px 0;
}

.result-card h4 {
  color: var(--navy);
  margin: 0 0 8px;
}

.industrial-home-section {
  padding: 42px 0;
  background: #fff8eb;
  border-top: 1px solid #f2d49a;
  border-bottom: 1px solid #f2d49a;
}

.industrial-home-panel {
  display: grid;
  grid-template-columns: 1.2fr 1fr;
  gap: 24px;
  align-items: center;
}

.industrial-home-panel h2 {
  color: var(--navy);
  margin: 0 0 12px;
  font-size: clamp(28px, 4vw, 42px);
}

.industrial-home-panel p {
  color: var(--muted);
}

.industrial-home-search,
.industrial-search {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 10px;
  padding: 10px;
  background: var(--white);
  border: 1px solid #d6e0eb;
  border-radius: 8px;
  box-shadow: var(--shadow);
}

.industrial-filters {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
  margin-top: 14px;
  text-align: left;
}

.large-industrial-search input {
  min-height: 56px;
  font-size: 17px;
}

.popular-chip-row {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 14px;
}

.popular-chip-row a,
.popular-chip-row button {
  border: 1px solid #c7d7ea;
  background: #f8fbff;
  color: var(--navy);
  border-radius: 999px;
  padding: 7px 11px;
  font: inherit;
  font-size: 13px;
  font-weight: 750;
  text-decoration: none;
  cursor: pointer;
}

.popular-chip-row a:hover,
.popular-chip-row button:hover {
  border-color: var(--blue);
  background: #eaf2ff;
}

.industrial-filters label {
  display: grid;
  gap: 6px;
  color: var(--navy);
  font-weight: 800;
}

.industrial-card-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 14px;
}

.industrial-card {
  display: grid;
  gap: 8px;
  background: var(--white);
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 16px;
}

.industrial-card-meta,
.data-status-row,
.resource-item-head {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px;
}

.status-pill {
  border-radius: 999px;
  border: 1px solid #d6e0eb;
  background: #f6f8fb;
  color: var(--muted);
  padding: 3px 8px;
  font-size: 11px;
  font-weight: 850;
}

.status-pill.status-verified {
  color: #0f766e;
  background: #ecfdf5;
  border-color: #99f6e4;
}

.status-pill.status-review {
  color: #9a3412;
  background: #fff7ed;
  border-color: #fed7aa;
}

.status-pill.status-preliminary {
  color: #7f1d1d;
  background: #fef2f2;
  border-color: #fecaca;
}

.data-status-row {
  margin-top: 16px;
}

.data-status-row span {
  border: 1px solid #d6e0eb;
  background: #f8fbff;
  border-radius: 999px;
  color: var(--navy);
  padding: 6px 10px;
  font-size: 13px;
  font-weight: 800;
}

.review-note {
  margin-top: 12px;
  border: 1px solid #fed7aa;
  background: #fff7ed;
  color: #9a3412;
  border-radius: 8px;
  padding: 10px 12px;
  font-weight: 750;
}

.map-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 7px;
  align-items: center;
}

.button.small {
  min-height: 0;
  padding: 6px 9px;
  font-size: 12px;
}

.static-map-panel {
  display: grid;
  grid-template-columns: minmax(260px, 0.85fr) minmax(0, 1.15fr);
  gap: 14px;
  margin-top: 14px;
}

.map-placeholder {
  min-height: 240px;
  border: 1px solid #c7d7ea;
  border-radius: 8px;
  background:
    linear-gradient(90deg, rgba(28, 109, 208, 0.08) 1px, transparent 1px),
    linear-gradient(rgba(28, 109, 208, 0.08) 1px, transparent 1px),
    #f8fbff;
  background-size: 28px 28px;
  color: var(--navy);
  display: grid;
  place-content: center;
  gap: 6px;
  text-align: center;
  padding: 18px;
}

.map-placeholder.large {
  min-height: 360px;
}

.map-placeholder span {
  color: var(--muted);
  font-size: 14px;
}

.map-point-list {
  display: grid;
  gap: 10px;
}

.map-point-list.compact {
  max-height: 460px;
  overflow: auto;
  padding-right: 4px;
}

.map-point-list article {
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--white);
  padding: 12px;
}

.map-point-list article.active {
  border-color: var(--blue);
  box-shadow: 0 0 0 3px rgba(28, 109, 208, 0.12);
}

.map-point-list h3 {
  color: var(--navy);
  margin: 6px 0 4px;
}

.map-point-list p {
  margin: 0 0 6px;
  color: var(--muted);
  font-size: 14px;
}

.map-role {
  display: inline-flex;
  width: fit-content;
  border-radius: 999px;
  padding: 3px 8px;
  font-size: 11px;
  font-weight: 850;
  color: var(--navy);
  background: #eaf2ff;
}

.map-role.wholesale_market {
  background: #fff7ed;
  color: #9a3412;
}

.map-role.oem_base {
  background: #ecfdf5;
  color: #0f766e;
}

.map-role.cross_border_supply,
.map-role.logistics_node {
  background: #f1f5f9;
  color: #334155;
}

.coordinate-line {
  font-family: ui-monospace, "SFMono-Regular", Consolas, monospace;
}

.map-disclaimer {
  border-top: 1px solid var(--line);
  margin-top: 14px;
  padding-top: 12px;
  color: var(--muted);
  font-size: 13px;
}

.map-modal[hidden] {
  display: none;
}

.map-modal {
  position: fixed;
  inset: 0;
  z-index: 50;
}

.map-modal-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(16, 36, 62, 0.52);
}

.map-modal-panel {
  position: relative;
  width: min(980px, calc(100% - 28px));
  max-height: min(86vh, 820px);
  overflow: auto;
  margin: 7vh auto;
  background: var(--white);
  border-radius: 8px;
  padding: 22px;
  box-shadow: var(--shadow);
}

.map-close {
  position: absolute;
  right: 16px;
  top: 16px;
  border: 1px solid var(--line);
  background: var(--white);
  border-radius: 6px;
  padding: 7px 10px;
  cursor: pointer;
  font-weight: 800;
}

.map-modal-head {
  padding-right: 82px;
  margin-bottom: 14px;
}

.map-modal-head h2 {
  margin: 0 0 6px;
  color: var(--navy);
}

.map-modal-grid {
  display: grid;
  grid-template-columns: minmax(300px, 1fr) minmax(280px, 0.9fr);
  gap: 14px;
}

body.modal-open {
  overflow: hidden;
}

.industrial-detail-hero .container {
  display: grid;
  gap: 14px;
}

.detail-origin-search {
  max-width: 920px;
}

.buyer-filter-links {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.buyer-filter-links a {
  border: 1px solid #d6e0eb;
  background: #fff;
  color: var(--navy);
  border-radius: 6px;
  padding: 7px 10px;
  text-decoration: none;
  font-size: 13px;
  font-weight: 800;
}

.detail-quick-actions {
  justify-content: flex-start;
}

.city-role-groups {
  display: grid;
  gap: 18px;
}

.city-role-group {
  border-bottom: 0 !important;
  padding-bottom: 0 !important;
}

.city-role-group h2 {
  font-size: 22px;
  margin-bottom: 12px;
}

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

.city-role-card,
.map-location-card {
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #fff;
  padding: 14px;
  display: grid;
  gap: 10px;
}

.city-role-card:hover,
.map-location-card:hover {
  border-color: #b8cbe3;
  box-shadow: 0 10px 28px rgba(16, 36, 62, 0.08);
}

.city-card-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
}

.city-role-card h3,
.map-location-card h3 {
  margin: 0;
  color: var(--navy);
  font-size: 18px;
}

.city-role-card dl {
  display: grid;
  grid-template-columns: 118px minmax(0, 1fr);
  gap: 6px 10px;
  margin: 0;
}

.city-role-card dt {
  color: var(--navy);
  font-size: 13px;
  font-weight: 850;
}

.city-role-card dd {
  margin: 0;
  color: var(--muted);
  font-size: 13px;
}

.industrial-sidebar {
  align-self: start;
}

.feedback-panel,
.feedback-links-panel {
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--white);
  padding: 22px;
}

.feedback-head {
  display: grid;
  gap: 8px;
  margin-bottom: 16px;
}

.feedback-head h2,
.feedback-links-panel h2 {
  color: var(--navy);
  margin: 0;
}

.feedback-head p,
.feedback-links-panel p {
  color: var(--muted);
  margin: 0;
}

.feedback-form {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.feedback-form label:has(textarea),
.feedback-form label:has(select),
.feedback-form .form-message,
.feedback-form button {
  grid-column: 1 / -1;
}

.feedback-form textarea {
  min-height: 112px;
}

.feedback-form .form-message {
  margin: 0;
}

.industrial-card[hidden] {
  display: none;
}

.industrial-card h3 {
  color: var(--navy);
  margin: 0;
}

.industrial-card p {
  color: var(--muted);
  margin: 0;
  font-size: 14px;
}

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

.cluster-grid article {
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 14px;
  background: #fbfdff;
}

.cluster-grid h3 {
  color: var(--navy);
  margin: 0 0 8px;
}

@media (max-width: 1100px) {
  .industrial-card-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

@media (max-width: 900px) {
  .industrial-home-panel,
  .industrial-card-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 760px) {
  .industrial-home-panel,
  .industrial-home-search,
  .industrial-search,
  .industrial-filters,
  .industrial-card-grid,
  .cluster-grid,
  .static-map-panel,
  .map-modal-grid {
    grid-template-columns: 1fr;
  }

  .city-role-grid {
    grid-template-columns: 1fr;
  }

  .city-role-card dl {
    grid-template-columns: 1fr;
  }

  .feedback-form {
    grid-template-columns: 1fr;
  }

  .map-modal-panel {
    margin: 16px auto;
    max-height: calc(100vh - 32px);
    padding: 18px;
  }

  .map-modal-head {
    padding-right: 70px;
  }
}

@media (max-width: 900px) {
  .compact-card-grid,
  .template-grid,
  .resource-directory-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 760px) {
  .compact-card-grid,
  .template-grid,
  .resource-directory-grid {
    grid-template-columns: 1fr;
  }

  .resource-directory-item dl {
    grid-template-columns: 1fr;
  }
}

.two-col-form {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.span-all {
  grid-column: 1 / -1;
}

.comparison-form fieldset {
  border: 1px solid var(--line);
  border-radius: 8px;
  display: grid;
  gap: 12px;
  margin: 0;
  padding: 16px;
}

.comparison-form legend {
  color: var(--navy);
  font-weight: 900;
  padding: 0 8px;
}

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

.checklist label {
  display: flex;
  align-items: center;
  gap: 10px;
  border: 1px solid var(--line);
  border-radius: 6px;
  padding: 12px;
  font-weight: 650;
}

.checklist input {
  width: 18px;
  min-height: 18px;
}

.side-panel {
  position: sticky;
  top: 94px;
}

.side-panel ul {
  margin: 0 0 16px;
  padding-left: 20px;
  color: var(--muted);
}

.mini-link {
  display: block;
  padding: 11px 0;
  border-bottom: 1px solid var(--line);
}

.guide-body {
  display: grid;
  gap: 30px;
  min-width: 0;
}

.guide-body section {
  border-bottom: 1px solid var(--line);
  padding-bottom: 22px;
  min-width: 0;
}

.faq details {
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 16px;
  margin-top: 12px;
  background: var(--white);
}

.faq summary {
  cursor: pointer;
  color: var(--navy);
  font-weight: 850;
}

.prose {
  max-width: 780px;
}

.prose h2 {
  color: var(--navy);
}

.site-footer {
  background: #0c1b2f;
  color: #d6dfeb;
  padding: 52px 0;
}

.footer-grid {
  display: grid;
  grid-template-columns: 1.6fr 1fr 1fr 1fr;
  gap: 30px;
}

.footer-brand {
  color: var(--white);
}

.footer-grid h2 {
  color: var(--white);
  font-size: 16px;
  margin: 0 0 12px;
}

.footer-grid a {
  display: block;
  color: #d6dfeb;
  text-decoration: none;
  margin: 8px 0;
}

.footer-grid a:hover {
  color: var(--white);
}

.footer-disclaimer {
  max-width: 520px;
  color: #c5d1df;
}

@media (max-width: 1020px) {
  .tool-grid,
  .directory-grid,
  .card-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .journey {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .trust-list {
    grid-template-columns: repeat(3, 1fr);
  }

  .split-layout,
  .tool-layout,
  .guide-layout,
  .cta-inner,
  .newsletter-inner {
    grid-template-columns: 1fr;
  }

  .side-panel {
    position: static;
  }

  .inline-form {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 760px) {
  .header-inner {
    min-height: 66px;
  }

  .brand {
    min-width: 0;
  }

  .brand strong {
    font-size: 14px;
  }

  .menu-button {
    display: inline-flex;
  }

  .site-nav {
    display: none;
    position: absolute;
    top: 66px;
    left: 0;
    right: 0;
    background: var(--white);
    border-bottom: 1px solid var(--line);
    padding: 12px 16px 18px;
    align-items: stretch;
    flex-direction: column;
  }

  .site-nav.open {
    display: flex;
  }

  .site-nav a {
    padding: 10px 12px;
  }

  .hero {
    min-height: 560px;
  }

  .hero-media::after {
    background: rgba(255, 255, 255, 0.88);
  }

  .hero h1,
  .page-hero h1 {
    font-size: 40px;
  }

  .hero p:not(.eyebrow),
  .page-hero p:not(.eyebrow) {
    font-size: 18px;
  }

  .section,
  .page-hero.compact {
    padding: 52px 0;
  }

  .tool-grid,
  .directory-grid,
  .card-grid,
  .journey,
  .trust-list,
  .checklist,
  .two-col-form,
  .footer-grid {
    grid-template-columns: 1fr;
  }

  .button-row,
  .center-actions {
    align-items: stretch;
    flex-direction: column;
  }

  .button {
    width: 100%;
  }
}

/* Portal refinements */
.container {
  width: min(1200px, calc(100% - 32px));
}

.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

.header-inner {
  min-height: 82px;
  gap: 28px;
}

.brand {
  gap: 12px;
  min-width: 280px;
}

.brand-mark {
  width: 48px;
  height: 48px;
}

.brand small {
  font-size: 13px;
}

.site-nav {
  gap: 6px;
}

.site-nav a {
  padding: 10px 11px;
  font-size: 15px;
}

.site-nav .nav-partner {
  color: var(--navy);
  border: 1px solid #b8c4d0;
  background: #fff8eb;
  margin-left: 4px;
}

.hero {
  min-height: 680px;
}

.hero-media::after {
  background: linear-gradient(90deg, rgba(255, 255, 255, 0.99) 0%, rgba(255, 255, 255, 0.95) 42%, rgba(255, 255, 255, 0.48) 70%, rgba(255, 255, 255, 0.22) 100%);
}

.hero-content {
  padding: 96px 0;
}

.hero-search {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 128px;
  gap: 10px;
  width: min(760px, 100%);
  padding: 10px;
  background: var(--white);
  border: 1px solid #cbd5e1;
  border-radius: 8px;
  box-shadow: var(--shadow);
  margin: 30px 0 16px;
}

.hero-search input {
  min-height: 54px;
  border: 0;
  font-size: 17px;
  padding: 12px 14px;
}

.hero-search input:focus {
  outline: 2px solid #bfdbfe;
}

.quick-links {
  width: min(780px, 100%);
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.quick-links a {
  display: inline-flex;
  align-items: center;
  min-height: 34px;
  padding: 7px 11px;
  border: 1px solid #cbd5e1;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.9);
  color: var(--navy);
  text-decoration: none;
  font-size: 14px;
  font-weight: 750;
}

.section {
  padding: 82px 0;
}

.section-head.compact-head {
  margin-bottom: 18px;
}

.section-lede {
  max-width: 760px;
  color: var(--muted);
  font-size: 18px;
  margin: 14px 0 0;
}

.tool-grid {
  gap: 22px;
}

.tool-card,
.category-card,
.directory-card,
.journey article,
.tool-panel,
.side-panel,
.contact-form {
  padding: 24px;
}

.tool-card {
  min-height: 292px;
  transition: transform 160ms ease, box-shadow 160ms ease, border-color 160ms ease;
}

.tool-card:hover {
  transform: translateY(-3px);
  border-color: #9bbbe8;
  box-shadow: var(--shadow);
}

.tool-card-top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 22px;
}

.tool-label {
  color: var(--blue-dark);
  background: #eaf2ff;
  border: 1px solid #d5e6ff;
  border-radius: 999px;
  padding: 5px 9px;
  font-size: 12px;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: 0.06em;
}

.card-icon {
  width: 46px;
  height: 46px;
  margin-bottom: 0;
  color: var(--white);
  background: var(--navy);
}

.tool-button {
  width: 100%;
  margin-top: auto;
  color: var(--blue-dark);
  background: #f8fbff;
  border-color: #b9d3f6;
}

.tool-button:hover {
  background: #eaf2ff;
}

.quick-action-section {
  padding-top: 52px;
  padding-bottom: 60px;
}

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

.quick-action-card {
  display: grid;
  gap: 8px;
  min-height: 142px;
  padding: 22px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--white);
  color: inherit;
  text-decoration: none;
  box-shadow: 0 1px 2px rgba(16, 36, 62, 0.04);
}

.quick-action-card:hover {
  border-color: #9bbbe8;
  box-shadow: var(--shadow);
}

.quick-action-card span {
  color: var(--navy);
  font-size: 20px;
  line-height: 1.15;
  font-weight: 900;
}

.quick-action-card p {
  color: var(--muted);
  margin: 0;
}

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

.topic-group {
  background: var(--white);
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 22px;
}

.topic-group h3 {
  color: var(--navy);
  margin: 0 0 12px;
}

.topic-group a {
  display: block;
  color: var(--blue-dark);
  text-decoration: none;
  font-weight: 750;
  padding: 8px 0;
  border-top: 1px solid #edf1f5;
}

.topic-group a:hover {
  text-decoration: underline;
}

.directory-card ul {
  margin: 14px 0 0;
  padding-left: 18px;
  color: var(--muted);
}

.directory-card li {
  margin: 6px 0;
}

.footer-grid .footer-emphasis {
  color: #ffd48a;
  font-weight: 900;
}

@media (max-width: 1020px) {
  .quick-action-grid,
  .topic-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 760px) {
  .header-inner {
    min-height: 66px;
  }

  .brand {
    min-width: 0;
  }

  .brand-mark {
    width: 42px;
    height: 42px;
  }

  .site-nav {
    top: 66px;
  }

  .site-nav .nav-partner {
    margin-left: 0;
  }

  .hero {
    min-height: 650px;
  }

  .hero-search,
  .quick-action-grid,
  .topic-grid {
    grid-template-columns: 1fr;
  }
}

/* AMZ123-style portal homepage */
.site-header {
  position: sticky;
}

.header-inner {
  align-items: center;
}

.site-nav {
  flex: 1;
}

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

.language-switcher {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 42px;
  min-height: 38px;
  border: 1px solid #cbd5e1;
  border-radius: 6px;
  color: var(--navy);
  text-decoration: none;
  font-weight: 900;
}

.list-service-button {
  min-height: 38px;
  padding: 8px 12px;
  color: var(--white);
  background: var(--blue);
}

.portal-search-area {
  background: linear-gradient(180deg, #f6f9fd 0%, #ffffff 100%);
  border-bottom: 1px solid var(--line);
  padding: 42px 0 34px;
}

.portal-search-inner {
  display: grid;
  justify-items: center;
  text-align: center;
}

.portal-search-inner h1 {
  color: var(--navy);
  font-size: clamp(36px, 5vw, 58px);
  line-height: 1.02;
  letter-spacing: 0;
  margin: 0 0 12px;
}

.portal-search-inner > p {
  color: var(--muted);
  font-size: 19px;
  margin: 0 0 20px;
}

.search-tabs {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 8px;
  margin-bottom: 12px;
}

.search-tabs button {
  border: 1px solid #cbd5e1;
  background: var(--white);
  color: var(--navy);
  border-radius: 999px;
  padding: 8px 15px;
  font-weight: 850;
  cursor: pointer;
}

.search-tabs button.active,
.search-tabs button:hover {
  color: var(--white);
  background: var(--navy);
  border-color: var(--navy);
}

.portal-search-area .hero-search {
  width: min(860px, 100%);
  margin: 0 0 14px;
}

.hot-searches {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 8px;
  max-width: 960px;
}

.hot-searches span {
  color: var(--muted);
  font-weight: 850;
  padding: 6px 0;
}

.hot-searches a {
  color: var(--blue-dark);
  background: var(--white);
  border: 1px solid #d8e1ec;
  border-radius: 999px;
  padding: 6px 10px;
  text-decoration: none;
  font-size: 14px;
  font-weight: 750;
}

.portal-nav-strip {
  padding: 14px 0;
  background: var(--white);
  border-bottom: 1px solid var(--line);
}

.portal-nav-grid {
  display: grid;
  grid-template-columns: repeat(10, minmax(0, 1fr));
  gap: 8px;
}

.portal-nav-grid a {
  display: grid;
  place-items: center;
  min-height: 48px;
  padding: 8px;
  color: var(--navy);
  background: #f8fafc;
  border: 1px solid #dbe4ee;
  border-radius: 6px;
  text-align: center;
  text-decoration: none;
  font-size: 14px;
  font-weight: 850;
}

.portal-nav-grid a:hover {
  color: var(--blue-dark);
  border-color: #9bbbe8;
  background: #edf6ff;
}

.popular-shortcuts-section {
  padding: 16px 0 18px;
  background: linear-gradient(180deg, #ffffff 0%, #f8fafc 100%);
  border-bottom: 1px solid var(--line);
}

.popular-shortcuts-inner {
  display: grid;
  gap: 14px;
  padding: 16px;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.94), rgba(248, 250, 252, 0.9)),
    #ffffff;
  border: 1px solid #dbe4ee;
  border-radius: 16px;
  box-shadow: 0 14px 34px rgba(15, 23, 42, 0.06);
}

.shortcuts-head {
  display: flex;
  align-items: end;
  justify-content: space-between;
  gap: 16px;
}

.shortcuts-head .eyebrow,
.shortcuts-head h2 {
  margin: 0;
}

.shortcuts-head h2 {
  color: var(--navy);
  font-size: 22px;
  line-height: 1.15;
}

.shortcut-grid {
  display: grid;
  grid-template-columns: repeat(8, minmax(0, 1fr));
  gap: 10px;
}

.shortcut-card {
  display: grid;
  grid-template-columns: 34px minmax(0, 1fr);
  align-items: center;
  gap: 9px;
  min-height: 66px;
  padding: 10px;
  color: inherit;
  text-decoration: none;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.92), rgba(255, 255, 255, 0.78)),
    var(--soft-accent, var(--soft-tools));
  border: 1px solid color-mix(in srgb, var(--accent, var(--c-tools)) 24%, white);
  border-radius: 13px;
  box-shadow: 0 8px 18px rgba(15, 23, 42, 0.04);
  transition: transform 160ms ease, border-color 160ms ease, box-shadow 160ms ease;
}

.shortcut-card:hover {
  transform: translateY(-1px);
  border-color: color-mix(in srgb, var(--accent, var(--c-tools)) 42%, white);
  box-shadow: 0 14px 28px color-mix(in srgb, var(--accent, var(--c-tools)) 16%, transparent);
}

.shortcut-icon {
  display: grid;
  place-items: center;
  width: 34px;
  height: 34px;
  color: #fff;
  background: linear-gradient(135deg, var(--accent, var(--c-tools)), color-mix(in srgb, var(--accent, var(--c-tools)) 62%, #111827));
  border-radius: 10px;
  font-size: 11px;
  font-weight: 950;
  letter-spacing: 0;
  box-shadow: 0 8px 16px color-mix(in srgb, var(--accent, var(--c-tools)) 18%, transparent);
}

.shortcut-copy {
  min-width: 0;
}

.shortcut-copy small {
  display: block;
  margin-bottom: 3px;
  color: color-mix(in srgb, var(--accent, var(--c-tools)) 76%, #334155);
  font-size: 11px;
  font-weight: 900;
  line-height: 1;
}

.shortcut-copy strong {
  display: block;
  color: var(--navy);
  font-size: 13px;
  line-height: 1.18;
}

.portal-board-section {
  padding: 24px 0 50px;
  background: #f4f7fa;
}

.portal-board {
  display: grid;
  grid-template-columns: 210px minmax(0, 1fr) 250px;
  gap: 16px;
  align-items: start;
}

.portal-sidebar,
.portal-updates,
.portal-panel {
  background: var(--white);
  border: 1px solid var(--line);
  border-radius: 8px;
}

.portal-sidebar,
.portal-updates {
  position: sticky;
  top: 98px;
  padding: 14px;
}

.portal-sidebar h2,
.portal-updates h2,
.portal-panel h2 {
  color: var(--navy);
  font-size: 18px;
  margin: 0;
}

.portal-sidebar h2 {
  margin-bottom: 10px;
}

.portal-sidebar a {
  display: block;
  color: var(--charcoal);
  text-decoration: none;
  font-size: 14px;
  font-weight: 760;
  padding: 10px 8px;
  border-radius: 6px;
  border-bottom: 1px solid #edf1f5;
}

.portal-sidebar a:hover {
  color: var(--blue-dark);
  background: #edf6ff;
}

.portal-main {
  display: grid;
  gap: 16px;
}

.portal-panel {
  padding: 18px;
}

.portal-panel-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 14px;
}

.portal-panel-head a {
  color: var(--blue-dark);
  text-decoration: none;
  font-weight: 850;
}

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

.toolbox-group {
  border: 1px solid #dbe4ee;
  border-radius: 8px;
  background: #fbfdff;
  padding: 14px;
}

.toolbox-group h3,
.resource-group h3,
.portal-updates h3 {
  color: var(--navy);
  font-size: 16px;
  margin: 0 0 10px;
}

.toolbox-item {
  display: grid;
  gap: 2px;
  color: inherit;
  text-decoration: none;
  padding: 9px 0;
  border-top: 1px solid #edf1f5;
}

.toolbox-item span {
  color: var(--blue-dark);
  font-weight: 850;
  font-size: 14px;
}

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

.resource-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
}

.resource-group {
  padding: 14px;
  border: 1px solid #dbe4ee;
  border-radius: 8px;
  background: var(--white);
}

.resource-group a {
  display: block;
  color: var(--blue-dark);
  text-decoration: none;
  font-size: 14px;
  font-weight: 760;
  padding: 7px 0;
  border-top: 1px solid #edf1f5;
}

.resource-group a:hover,
.toolbox-item:hover span {
  text-decoration: underline;
}

.portal-updates article {
  padding: 12px 0;
  border-top: 1px solid #edf1f5;
}

.portal-updates p {
  color: var(--muted);
  margin: 0;
  font-size: 13px;
}

.services-line {
  font-size: 14px;
}

.site-footer .footer-grid {
  grid-template-columns: 1.35fr repeat(5, 1fr);
}

@media (max-width: 1180px) {
  .portal-board {
    grid-template-columns: 190px minmax(0, 1fr);
  }

  .shortcut-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }

  .portal-updates {
    position: static;
    grid-column: 1 / -1;
  }

  .portal-nav-grid {
    grid-template-columns: repeat(5, minmax(0, 1fr));
  }

  .resource-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

@media (max-width: 900px) {
  .header-actions {
    display: none;
  }

  .portal-board {
    grid-template-columns: 1fr;
  }

  .portal-sidebar {
    position: static;
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 4px;
  }

  .portal-sidebar h2 {
    grid-column: 1 / -1;
  }

  .toolbox-grid,
  .resource-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .site-footer .footer-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 760px) {
  .portal-search-area {
    padding: 34px 0 26px;
  }

  .portal-search-inner {
    text-align: left;
    justify-items: stretch;
  }

  .search-tabs,
  .hot-searches {
    justify-content: flex-start;
  }

  .portal-nav-grid,
  .toolbox-grid,
  .resource-grid,
  .portal-sidebar,
  .site-footer .footer-grid {
    grid-template-columns: 1fr;
  }

  .portal-board-section {
    padding-top: 16px;
  }
}

/* Wider, denser portal pass */
.container {
  width: min(1340px, calc(100% - 32px));
}

.site-header {
  background: rgba(255, 255, 255, 0.97);
}

.header-inner {
  min-height: 76px;
}

.brand {
  min-width: 255px;
}

.brand strong {
  font-size: 18px;
}

.brand small {
  font-size: 12px;
}

.brand-mark {
  width: 44px;
  height: 44px;
  box-shadow: inset 0 -2px 0 rgba(255, 255, 255, 0.15);
}

.site-nav {
  justify-content: flex-start;
  gap: 3px;
}

.site-nav a {
  padding: 9px 9px;
  font-size: 14px;
  font-weight: 760;
}

.site-nav .nav-partner {
  background: #fff5df;
  border-color: #f2bf63;
  color: #81510a;
  font-weight: 900;
}

.list-service-button {
  background: var(--blue);
  box-shadow: 0 6px 16px rgba(28, 109, 208, 0.18);
}

.portal-search-area {
  padding: 26px 0 18px;
  background:
    linear-gradient(180deg, rgba(246, 249, 253, 0.96) 0%, rgba(255, 255, 255, 1) 100%),
    repeating-linear-gradient(90deg, rgba(16, 36, 62, 0.04) 0, rgba(16, 36, 62, 0.04) 1px, transparent 1px, transparent 72px);
}

.portal-search-inner h1 {
  font-size: clamp(34px, 4.2vw, 50px);
  margin-bottom: 8px;
}

.portal-search-inner > p {
  font-size: 17px;
  margin-bottom: 13px;
}

.search-tabs {
  margin-bottom: 9px;
}

.search-tabs button {
  padding: 6px 13px;
  font-size: 14px;
}

.portal-search-area .hero-search {
  width: min(940px, 100%);
  padding: 8px;
  margin-bottom: 10px;
}

.hero-search input {
  min-height: 48px;
}

.hot-searches {
  max-width: 1120px;
}

.hot-searches a {
  padding: 5px 9px;
}

.portal-nav-strip {
  padding: 10px 0;
  background: #fbfcfe;
}

.portal-nav-grid {
  grid-template-columns: repeat(10, minmax(0, 1fr));
  gap: 7px;
}

.portal-nav-grid a {
  min-height: 42px;
  font-size: 13px;
  background: var(--white);
  box-shadow: 0 1px 0 rgba(16, 36, 62, 0.04);
}

.portal-board-section {
  padding: 16px 0 42px;
  background: #eef3f8;
}

.portal-board {
  grid-template-columns: 225px minmax(0, 1fr) 285px;
  gap: 14px;
}

.portal-sidebar,
.portal-updates,
.portal-panel {
  border-color: #d6e0eb;
  box-shadow: 0 1px 2px rgba(16, 36, 62, 0.05);
}

.portal-sidebar,
.portal-updates {
  top: 88px;
  padding: 12px;
}

.portal-sidebar h2,
.portal-updates h2,
.portal-panel h2 {
  font-size: 17px;
}

.portal-sidebar a {
  display: flex;
  align-items: center;
  gap: 9px;
  padding: 8px 8px;
  font-size: 13px;
  font-weight: 820;
}

.side-icon {
  display: inline-grid;
  place-items: center;
  flex: 0 0 28px;
  width: 28px;
  height: 28px;
  border-radius: 6px;
  color: var(--blue-dark);
  background: #eaf2ff;
  font-size: 11px;
  font-weight: 950;
}

.portal-sidebar a:hover .side-icon {
  color: var(--white);
  background: var(--blue);
}

.portal-panel {
  padding: 14px;
}

.portal-panel-head {
  margin-bottom: 10px;
  padding-bottom: 9px;
  border-bottom: 1px solid #e8eef5;
}

.portal-panel-head h2::before {
  content: "";
  display: inline-block;
  width: 7px;
  height: 18px;
  margin-right: 8px;
  border-radius: 99px;
  background: var(--amber);
  vertical-align: -3px;
}

.toolbox-grid {
  gap: 10px;
}

.toolbox-group {
  padding: 11px;
  background: #ffffff;
}

.toolbox-group h3 {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 8px;
  padding-bottom: 8px;
  border-bottom: 1px solid #edf1f5;
}

.toolbox-group h3::after {
  content: "Tools";
  color: #8a5a09;
  background: #fff3d8;
  border: 1px solid #f2c76c;
  border-radius: 999px;
  padding: 2px 7px;
  font-size: 11px;
  font-weight: 900;
}

.toolbox-item {
  position: relative;
  grid-template-columns: 34px minmax(0, 1fr) 16px;
  align-items: center;
  gap: 9px;
  min-height: 74px;
  padding: 8px;
  border: 1px solid transparent;
  border-radius: 7px;
}

.toolbox-item:hover {
  background: #f3f8ff;
  border-color: #b9d3f6;
  box-shadow: 0 8px 20px rgba(16, 36, 62, 0.08);
}

.tool-mini-icon {
  display: grid;
  place-items: center;
  width: 34px;
  height: 34px;
  border-radius: 7px;
  color: var(--white);
  background: var(--navy);
  font-size: 11px;
  font-weight: 950;
}

.toolbox-copy {
  display: grid;
  gap: 2px;
  min-width: 0;
}

.toolbox-meta {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 5px;
  line-height: 1;
}

.toolbox-meta em,
.toolbox-meta b {
  font-style: normal;
  border-radius: 999px;
  padding: 2px 6px;
  font-size: 10px;
  font-weight: 900;
  text-transform: uppercase;
}

.toolbox-meta em {
  color: var(--blue-dark);
  background: #eaf2ff;
}

.toolbox-meta b {
  color: #8a4b00;
  background: #fff0cf;
}

.toolbox-copy strong {
  color: var(--navy);
  font-size: 14px;
  line-height: 1.18;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.toolbox-copy small {
  color: var(--muted);
  font-size: 12px;
  line-height: 1.25;
}

.item-arrow {
  color: var(--blue-dark);
  font-size: 22px;
  font-weight: 900;
}

.resource-grid {
  gap: 10px;
}

.resource-group {
  padding: 12px;
  background: #fbfdff;
}

.resource-group h3 {
  padding-bottom: 8px;
  border-bottom: 1px solid #edf1f5;
}

.resource-group a {
  padding: 6px 0;
  font-size: 13px;
}

.portal-updates article {
  padding: 10px 0;
}

.portal-updates h3 {
  display: flex;
  align-items: center;
  gap: 7px;
  font-size: 14px;
  margin-bottom: 4px;
}

.portal-updates h3::before {
  content: "New";
  color: #8a4b00;
  background: #fff0cf;
  border-radius: 999px;
  padding: 2px 6px;
  font-size: 10px;
  font-weight: 900;
}

.portal-updates p {
  font-size: 12px;
}

.section.muted {
  background: #f3f6fa;
}

.section {
  padding: 56px 0;
}

.compact-portal-section {
  padding: 34px 0 38px;
}

.compact-portal-section .section-head {
  margin-bottom: 16px;
}

.compact-portal-section .section-head h2 {
  margin-bottom: 6px;
}

.compact-portal-section .section-lede {
  max-width: 820px;
  font-size: 15px;
}

.home-portal-grid {
  display: grid;
  gap: 12px;
}

.tool-portal-grid,
.industrial-portal-grid {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.resource-portal-grid,
.template-portal-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.home-portal-card {
  display: grid;
  grid-template-rows: auto auto auto 1fr auto;
  gap: 8px;
  min-height: 216px;
  padding: 14px;
  border: 1px solid #d7e1ec;
  border-radius: 7px;
  background: #fff;
  box-shadow: 0 1px 2px rgba(16, 36, 62, 0.04);
}

.home-portal-card:hover {
  border-color: #a8c4ec;
  box-shadow: 0 10px 24px rgba(16, 36, 62, 0.08);
  transform: translateY(-1px);
}

.home-card-top {
  display: flex;
  align-items: center;
  gap: 7px;
  min-width: 0;
}

.portal-icon {
  display: inline-grid;
  place-items: center;
  flex: 0 0 30px;
  width: 30px;
  height: 30px;
  border-radius: 6px;
  color: var(--white);
  background: var(--navy);
  font-size: 11px;
  font-weight: 950;
}

.home-card-meta {
  margin-left: auto;
  color: #8a4b00;
  background: #fff0cf;
  border: 1px solid #f1ce7b;
  border-radius: 999px;
  padding: 2px 7px;
  font-size: 11px;
  font-weight: 900;
  white-space: nowrap;
}

.home-portal-card h3 {
  margin: 0;
  color: var(--navy);
  font-size: 17px;
  line-height: 1.22;
}

.home-portal-card h3 a {
  text-decoration: none;
}

.home-portal-card h3 a:hover {
  color: var(--blue-dark);
}

.home-portal-card p {
  margin: 0;
  color: #526070;
  font-size: 13px;
  line-height: 1.4;
}

.portal-card-links {
  display: flex;
  flex-wrap: wrap;
  align-content: flex-start;
  gap: 6px;
  padding-top: 2px;
}

.portal-card-links a {
  color: #27435f;
  background: #f2f6fb;
  border: 1px solid #e0e8f1;
  border-radius: 999px;
  padding: 4px 7px;
  text-decoration: none;
  font-size: 11px;
  font-weight: 800;
  line-height: 1.2;
}

.portal-card-links a:hover {
  color: var(--blue-dark);
  background: #eaf2ff;
  border-color: #bad4f7;
}

.portal-card-cta {
  justify-self: start;
  color: var(--blue-dark);
  text-decoration: none;
  font-size: 13px;
  font-weight: 950;
}

.portal-card-cta::after {
  content: " ->";
}

.directory-grid {
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 14px;
}

.directory-card {
  padding: 18px;
}

.directory-card h3::before,
.directory-card h2::before {
  content: "Service";
  display: inline-block;
  margin-right: 8px;
  color: var(--blue-dark);
  background: #eaf2ff;
  border-radius: 999px;
  padding: 3px 7px;
  font-size: 10px;
  font-weight: 900;
  text-transform: uppercase;
  vertical-align: 2px;
}

.services-line {
  min-height: 66px;
  font-size: 13px;
}

.center-actions {
  margin-top: 22px;
}

.newsletter {
  background: #fff8eb;
  border-top: 1px solid #f1d6a5;
}

.site-footer {
  padding: 42px 0;
}

.site-footer .footer-grid {
  grid-template-columns: 1.45fr repeat(5, minmax(120px, 1fr));
  gap: 24px;
}

@media (min-width: 1181px) {
  .portal-board {
    min-height: 650px;
  }
}

@media (max-width: 1280px) {
  .container {
    width: min(1280px, calc(100% - 28px));
  }

  .portal-board {
    grid-template-columns: 210px minmax(0, 1fr) 260px;
  }

  .site-nav a {
    font-size: 13px;
    padding-inline: 7px;
  }
}

@media (max-width: 1180px) {
  .portal-board {
    grid-template-columns: 205px minmax(0, 1fr);
  }

  .tool-portal-grid,
  .industrial-portal-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .portal-nav-grid {
    grid-template-columns: repeat(5, minmax(0, 1fr));
  }
}

@media (max-width: 900px) {
  .portal-board {
    grid-template-columns: 1fr;
  }

  .toolbox-grid,
  .resource-grid,
  .tool-portal-grid,
  .industrial-portal-grid,
  .resource-portal-grid,
  .template-portal-grid,
  .directory-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 760px) {
  .container {
    width: min(100% - 24px, 100%);
  }

  .portal-search-area {
    padding-top: 26px;
  }

  .portal-nav-grid,
  .toolbox-grid,
  .resource-grid,
  .tool-portal-grid,
  .industrial-portal-grid,
  .resource-portal-grid,
  .template-portal-grid,
  .directory-grid,
  .site-footer .footer-grid {
    grid-template-columns: 1fr;
  }

  .toolbox-copy strong {
    white-space: normal;
  }
}

/* Premium B2B portal visual refinement */
:root {
  --bg: #f6f8fb;
  --surface: #ffffff;
  --surface-soft: #f8fafc;
  --ink: #0f172a;
  --text: #334155;
  --muted: #475569;
  --navy: #0b1f3a;
  --blue: #2563eb;
  --blue-dark: #1d4ed8;
  --blue-soft: #eff6ff;
  --amber: #f59e0b;
  --amber-soft: #fff7ed;
  --green: #10b981;
  --line: #e5e7eb;
  --line-strong: #d8dee8;
  --radius-sm: 8px;
  --radius: 12px;
  --radius-lg: 18px;
  --shadow-sm: 0 1px 2px rgba(15, 23, 42, 0.06);
  --shadow-card: 0 10px 30px rgba(15, 23, 42, 0.08);
  --shadow-strong: 0 24px 70px rgba(15, 23, 42, 0.14);
  --space-section: 52px;
}

html {
  background: var(--bg);
}

body {
  color: var(--ink);
  background:
    radial-gradient(circle at 10% -8%, rgba(37, 99, 235, 0.09), transparent 30%),
    linear-gradient(180deg, #fbfdff 0%, var(--bg) 420px, var(--bg) 100%);
  font-family: Inter, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  letter-spacing: 0;
}

.container {
  width: min(1340px, calc(100% - 40px));
}

a {
  text-underline-offset: 3px;
}

.site-header {
  background: rgba(255, 255, 255, 0.88);
  border-bottom: 1px solid rgba(226, 232, 240, 0.9);
  box-shadow: 0 1px 0 rgba(15, 23, 42, 0.03);
}

.header-inner {
  min-height: 72px;
  gap: 18px;
}

.brand {
  min-width: 246px;
  gap: 12px;
}

.brand-mark {
  width: 42px;
  height: 42px;
  border-radius: 10px;
  background:
    linear-gradient(135deg, #0b1f3a 0%, #163b70 58%, #2563eb 100%);
  box-shadow: 0 10px 24px rgba(11, 31, 58, 0.22);
}

.brand strong {
  color: var(--ink);
  font-size: 17px;
  letter-spacing: 0;
}

.brand small {
  color: #64748b;
  font-size: 12px;
}

.site-nav {
  gap: 2px;
}

.site-nav a,
.language-switcher {
  border: 1px solid transparent;
  border-radius: 999px;
  color: #334155;
  font-size: 14px;
  font-weight: 750;
  line-height: 1;
  padding: 10px 12px;
}

.site-nav a:hover,
.site-nav a.active,
.language-switcher:hover {
  color: var(--blue-dark);
  background: var(--blue-soft);
  border-color: #dbeafe;
}

.site-nav .nav-partner {
  color: #92400e;
  background: var(--amber-soft);
  border-color: #fed7aa;
}

.header-actions {
  display: flex;
  align-items: center;
  gap: 8px;
}

.list-service-button {
  min-height: 38px;
  border-radius: 999px;
  background: var(--navy);
  box-shadow: 0 12px 26px rgba(11, 31, 58, 0.18);
  padding-inline: 15px;
}

.button {
  min-height: 42px;
  border-radius: 10px;
  transition: transform 0.16s ease, box-shadow 0.16s ease, border-color 0.16s ease, background 0.16s ease;
}

.button:hover {
  transform: translateY(-1px);
}

.button.primary {
  background: linear-gradient(180deg, #2f70f4 0%, var(--blue) 100%);
  box-shadow: 0 12px 26px rgba(37, 99, 235, 0.22);
}

.button.secondary {
  background: rgba(255, 255, 255, 0.92);
  border-color: var(--line-strong);
  box-shadow: var(--shadow-sm);
}

.tool-label,
.status-pill,
.map-role,
.toolbox-meta em,
.toolbox-meta b {
  border-radius: 999px;
  font-size: 11px;
  font-weight: 850;
  letter-spacing: 0;
}

.tool-label {
  color: var(--blue-dark);
  background: #eef5ff;
  border: 1px solid #dbeafe;
  padding: 4px 8px;
}

.status-pill.status-verified {
  color: #047857;
  background: #ecfdf5;
  border-color: #bbf7d0;
}

.status-pill.status-review {
  color: #9a5b00;
  background: #fff7ed;
  border-color: #fed7aa;
}

.status-pill.status-placeholder {
  color: #475569;
  background: #f1f5f9;
  border-color: #dbe3ec;
}

.section {
  padding: var(--space-section) 0;
}

.section.muted {
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.68), rgba(248, 250, 252, 0.88)),
    #f3f6fa;
  border-top: 1px solid rgba(226, 232, 240, 0.75);
  border-bottom: 1px solid rgba(226, 232, 240, 0.55);
}

.section-head {
  margin-bottom: 22px;
}

.eyebrow {
  color: var(--blue-dark);
  font-size: 12px;
  font-weight: 900;
  letter-spacing: 0.08em;
}

.section-head h2,
.cta-inner h2,
.newsletter h2 {
  color: var(--ink);
  font-size: clamp(26px, 3vw, 38px);
  line-height: 1.08;
  letter-spacing: 0;
}

.section-lede,
.section-head p:not(.eyebrow),
.newsletter p,
.directory-card p,
.home-portal-card p,
.resource-group a,
.toolbox-copy small {
  color: var(--muted);
}

.portal-search-area {
  padding: 34px 0 22px;
  background:
    radial-gradient(circle at 20% 0%, rgba(37, 99, 235, 0.13), transparent 34%),
    radial-gradient(circle at 82% 12%, rgba(245, 158, 11, 0.14), transparent 30%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.94) 0%, rgba(246, 248, 251, 0.92) 100%);
}

.portal-search-inner {
  max-width: 1120px;
}

.portal-search-inner h1 {
  max-width: 980px;
  margin-inline: auto;
  color: var(--ink);
  font-size: clamp(38px, 4.6vw, 62px);
  line-height: 0.98;
  letter-spacing: 0;
}

.portal-search-inner > p {
  max-width: 790px;
  margin-inline: auto;
  color: #475569;
  font-size: 18px;
}

.search-tabs {
  justify-content: center;
  gap: 8px;
}

.search-tabs button {
  border: 1px solid var(--line);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.78);
  color: #475569;
}

.search-tabs button.active,
.search-tabs button:hover {
  color: var(--blue-dark);
  background: #eef5ff;
  border-color: #bfdbfe;
}

.portal-search-area .hero-search {
  max-width: 960px;
  border: 1px solid rgba(191, 219, 254, 0.92);
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.96);
  box-shadow: var(--shadow-strong);
}

.hero-search input,
.industrial-home-search input,
.industrial-search input,
.stacked-form input,
.stacked-form select,
.stacked-form textarea,
.inline-form input,
.inline-form select {
  border: 1px solid #dbe3ec;
  border-radius: 10px;
  background: #fff;
  color: var(--ink);
  box-shadow: inset 0 1px 0 rgba(15, 23, 42, 0.02);
}

.hero-search input:focus,
.industrial-home-search input:focus,
.industrial-search input:focus,
.stacked-form input:focus,
.stacked-form select:focus,
.stacked-form textarea:focus {
  outline: 3px solid rgba(37, 99, 235, 0.14);
  border-color: #93c5fd;
}

.hot-searches {
  justify-content: center;
  gap: 7px;
}

.hot-searches span {
  color: #64748b;
  font-weight: 850;
}

.hot-searches a,
.popular-chip-row a,
.popular-chip-row button,
.buyer-filter-links a {
  border: 1px solid #dbe3ec;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.82);
  color: #334155;
  font-weight: 750;
  box-shadow: var(--shadow-sm);
}

.hot-searches a:hover,
.popular-chip-row a:hover,
.popular-chip-row button:hover,
.buyer-filter-links a:hover {
  color: var(--blue-dark);
  background: #eef5ff;
  border-color: #bfdbfe;
}

.portal-nav-strip {
  background: rgba(255, 255, 255, 0.8);
  border-top: 1px solid rgba(226, 232, 240, 0.7);
  border-bottom: 1px solid rgba(226, 232, 240, 0.7);
}

.portal-nav-grid a {
  border: 1px solid #e2e8f0;
  border-radius: 12px;
  background: #fff;
  color: #1e293b;
  font-size: 13px;
  font-weight: 850;
  min-height: 44px;
}

.portal-nav-grid a:hover {
  border-color: #bfdbfe;
  box-shadow: 0 10px 22px rgba(37, 99, 235, 0.1);
}

.portal-board-section {
  padding: 22px 0 48px;
  background:
    linear-gradient(180deg, rgba(246, 248, 251, 0.92), rgba(241, 245, 249, 0.94));
}

.portal-board {
  gap: 16px;
}

.portal-sidebar,
.portal-updates,
.portal-panel,
.home-portal-card,
.directory-card,
.tool-card,
.category-card,
.template-card,
.resource-directory-group,
.tool-panel,
.side-panel,
.feedback-panel,
.feedback-links-panel,
.industrial-card,
.city-role-card,
.map-location-card,
.cluster-grid article,
.related-panel,
.result-card {
  border: 1px solid rgba(226, 232, 240, 0.94);
  border-radius: var(--radius);
  background: rgba(255, 255, 255, 0.96);
  box-shadow: var(--shadow-sm);
}

.portal-sidebar,
.portal-updates,
.portal-panel {
  box-shadow: var(--shadow-card);
}

.portal-panel,
.portal-sidebar,
.portal-updates {
  padding: 16px;
}

.portal-sidebar h2,
.portal-updates h2,
.portal-panel h2 {
  color: var(--ink);
  font-size: 18px;
  letter-spacing: 0;
}

.portal-panel-head {
  border-bottom: 1px solid #edf2f7;
}

.portal-panel-head h2::before {
  background: linear-gradient(180deg, var(--blue), #60a5fa);
}

.portal-sidebar a {
  border-radius: 10px;
  color: #334155;
}

.portal-sidebar a:hover {
  color: var(--blue-dark);
  background: #eef5ff;
}

.side-icon,
.tool-mini-icon,
.portal-icon,
.service-icon,
.card-icon {
  border-radius: 10px;
  background: linear-gradient(135deg, var(--navy), #1e4f8f);
  box-shadow: 0 8px 18px rgba(11, 31, 58, 0.16);
}

.toolbox-group,
.resource-group {
  border: 1px solid #e6edf5;
  border-radius: 12px;
  background: linear-gradient(180deg, #fff 0%, #fbfdff 100%);
}

.toolbox-item {
  border-radius: 10px;
}

.toolbox-item:hover,
.resource-group a:hover {
  background: #f3f8ff;
}

.resource-group h3,
.toolbox-group h3 {
  color: var(--ink);
}

.portal-updates article {
  border-bottom: 1px solid #edf2f7;
}

.portal-updates h3::before {
  content: "New";
  color: #92400e;
  background: #fff7ed;
  border: 1px solid #fed7aa;
}

.industrial-home-section {
  padding: 46px 0;
  background:
    radial-gradient(circle at 10% 20%, rgba(245, 158, 11, 0.13), transparent 28%),
    linear-gradient(135deg, #fff7ed 0%, #eff6ff 100%);
  border-block: 1px solid rgba(251, 191, 36, 0.26);
}

.industrial-home-panel {
  padding: 28px;
  border: 1px solid rgba(255, 255, 255, 0.82);
  border-radius: 22px;
  background: rgba(255, 255, 255, 0.76);
  box-shadow: var(--shadow-strong);
  backdrop-filter: blur(16px);
}

.industrial-home-panel h2 {
  font-size: clamp(30px, 3.4vw, 46px);
  line-height: 1.04;
}

.industrial-home-search,
.industrial-search {
  border: 1px solid #dbeafe;
  border-radius: 16px;
  background: #fff;
  box-shadow: var(--shadow-card);
}

.compact-portal-section {
  padding: 44px 0;
}

.home-portal-grid {
  gap: 14px;
}

.home-portal-card {
  min-height: 222px;
  padding: 16px;
  border-radius: 14px;
  transition: transform 0.16s ease, box-shadow 0.16s ease, border-color 0.16s ease;
}

.home-portal-card:hover,
.directory-card:hover,
.tool-card:hover,
.industrial-card:hover,
.template-card:hover,
.resource-directory-group:hover,
.city-role-card:hover,
.map-location-card:hover {
  border-color: #bfdbfe;
  box-shadow: var(--shadow-card);
  transform: translateY(-2px);
}

.home-portal-card h3,
.tool-card h3,
.directory-card h3,
.directory-card h2,
.template-card h2,
.resource-directory-group h2,
.industrial-card h3,
.city-role-card h3 {
  color: var(--ink);
  font-weight: 850;
  letter-spacing: 0;
}

.portal-card-links a,
.mini-actions a {
  background: #f8fafc;
  border: 1px solid #e2e8f0;
}

.portal-card-cta,
.text-link,
.mini-link {
  color: var(--blue-dark);
  font-weight: 850;
}

.directory-grid {
  gap: 16px;
}

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

.service-card-top {
  display: flex;
  align-items: center;
  gap: 8px;
}

.service-icon {
  display: inline-grid;
  place-items: center;
  width: 34px;
  height: 34px;
  color: #fff;
  font-size: 11px;
  font-weight: 950;
}

.directory-card h3::before,
.directory-card h2::before {
  content: none;
}

.services-line {
  min-height: auto;
  padding: 10px;
  border-radius: 10px;
  background: #f8fafc;
  border: 1px solid #e7edf4;
}

.cta-band,
.newsletter {
  border-block: 1px solid rgba(226, 232, 240, 0.86);
  background:
    radial-gradient(circle at 12% 10%, rgba(37, 99, 235, 0.12), transparent 34%),
    linear-gradient(135deg, #fff 0%, #f8fafc 100%);
}

.newsletter-inner,
.cta-inner {
  border: 1px solid #e2e8f0;
  border-radius: 20px;
  background: rgba(255, 255, 255, 0.82);
  box-shadow: var(--shadow-card);
  padding: 24px;
}

.page-hero {
  background:
    radial-gradient(circle at 18% -10%, rgba(37, 99, 235, 0.12), transparent 36%),
    linear-gradient(180deg, #fff 0%, #f6f8fb 100%);
}

.page-hero.compact {
  padding: 72px 0 48px;
}

.page-hero h1 {
  color: var(--ink);
  letter-spacing: 0;
}

.guide-body section {
  border-color: #e2e8f0;
  border-radius: 16px;
  box-shadow: var(--shadow-sm);
}

.guide-checklist li,
.checklist label {
  border-radius: 10px;
}

.static-map-panel {
  border-radius: 18px;
  border-color: #dbeafe;
  box-shadow: var(--shadow-card);
}

.site-footer {
  background: #081a31;
  color: #cbd5e1;
  border-top: 1px solid rgba(148, 163, 184, 0.18);
}

.site-footer .brand strong,
.site-footer h2 {
  color: #fff;
}

.site-footer .brand small,
.footer-disclaimer,
.site-footer a {
  color: #cbd5e1;
}

.site-footer a:hover {
  color: #fff;
}

.footer-disclaimer {
  max-width: 440px;
  line-height: 1.7;
}

@media (max-width: 1180px) {
  .header-inner {
    flex-wrap: wrap;
    padding-block: 10px;
  }

  .site-nav {
    order: 3;
    width: 100%;
  }
}

@media (max-width: 900px) {
  .container {
    width: min(100% - 28px, 100%);
  }

  .portal-search-inner h1 {
    font-size: clamp(34px, 9vw, 48px);
  }

  .industrial-home-panel {
    padding: 20px;
  }

  .newsletter-inner,
  .cta-inner {
    padding: 18px;
  }
}

@media (max-width: 760px) {
  .site-header {
    position: sticky;
  }

  .header-inner {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 10px;
    min-height: 68px;
  }

  .brand {
    min-width: 0;
  }

  .brand small {
    display: none;
  }

  .menu-button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 999px;
    background: #fff;
    font-weight: 850;
  }

  .site-nav {
    order: 3;
    grid-column: 1 / -1;
    display: none;
    width: 100%;
    padding: 10px;
    border: 1px solid var(--line);
    border-radius: 16px;
    background: rgba(255, 255, 255, 0.96);
    box-shadow: var(--shadow-card);
  }

  .site-nav.open {
    display: grid;
    grid-template-columns: 1fr;
    gap: 6px;
  }

  .site-nav a {
    justify-content: flex-start;
    padding: 12px;
  }

  .header-actions {
    order: 4;
    grid-column: 1 / -1;
    width: 100%;
    justify-content: space-between;
  }

  .site-nav a,
  .site-nav .nav-partner {
    border-radius: 10px;
  }

  .portal-search-area {
    padding: 28px 0 18px;
  }

  .portal-search-area .hero-search,
  .industrial-home-search,
  .industrial-search {
    grid-template-columns: 1fr;
    padding: 10px;
  }

  .home-portal-card {
    min-height: unset;
  }

  .button,
  .portal-card-cta,
  .text-link {
    min-height: 44px;
  }

  .footer-grid {
    gap: 22px;
  }
}

/* Colorful portal layer: category-led navigation identity */
:root {
  --c-tools: #2563eb;
  --c-resources: #7c3aed;
  --c-industrial: #f97316;
  --c-templates: #16a34a;
  --c-service: #0d9488;
  --c-shipping: #0284c7;
  --c-payment: #f59e0b;
  --c-verification: #4f46e5;
  --c-yiwu: #e11d48;
  --c-inspection: #059669;
  --c-machinery: #475569;
  --c-trade: #ef4444;
  --soft-tools: #eff6ff;
  --soft-resources: #f5f3ff;
  --soft-industrial: #fff7ed;
  --soft-templates: #f0fdf4;
  --soft-service: #f0fdfa;
  --soft-shipping: #f0f9ff;
  --soft-payment: #fffbeb;
  --soft-verification: #eef2ff;
  --soft-yiwu: #fff1f2;
  --soft-inspection: #ecfdf5;
  --soft-trade: #fef2f2;
}

.site-header {
  background:
    linear-gradient(90deg, rgba(239, 246, 255, 0.92), rgba(255, 255, 255, 0.92) 36%, rgba(255, 247, 237, 0.92));
}

.site-nav a[href="/tools/"].active,
.site-nav a[href="/tools/"]:hover {
  color: var(--c-tools);
  background: var(--soft-tools);
  border-color: #bfdbfe;
}

.site-nav a[href*="/resources"].active,
.site-nav a[href*="/resources"]:hover {
  color: var(--c-resources);
  background: var(--soft-resources);
  border-color: #ddd6fe;
}

.site-nav a[href="/industrial-belts/"].active,
.site-nav a[href="/industrial-belts/"]:hover {
  color: var(--c-industrial);
  background: var(--soft-industrial);
  border-color: #fed7aa;
}

.site-nav a[href="/templates/"].active,
.site-nav a[href="/templates/"]:hover {
  color: var(--c-templates);
  background: var(--soft-templates);
  border-color: #bbf7d0;
}

.site-nav a[href="/service-directory/"].active,
.site-nav a[href="/service-directory/"]:hover {
  color: var(--c-service);
  background: var(--soft-service);
  border-color: #99f6e4;
}

.site-nav .nav-partner {
  color: #9a3412;
  background: linear-gradient(180deg, #fff7ed, #ffedd5);
  border-color: #fdba74;
}

.list-service-button {
  background: linear-gradient(135deg, var(--c-service), #0f766e);
  box-shadow: 0 14px 30px rgba(13, 148, 136, 0.24);
}

.portal-search-area {
  background:
    radial-gradient(circle at 12% 16%, rgba(249, 115, 22, 0.18), transparent 28%),
    radial-gradient(circle at 82% 6%, rgba(124, 58, 237, 0.16), transparent 30%),
    radial-gradient(circle at 52% 72%, rgba(13, 148, 136, 0.11), transparent 30%),
    linear-gradient(180deg, #fff 0%, #f7fbff 100%);
}

.search-tabs button:nth-child(1),
.hot-searches a:nth-of-type(1),
.portal-nav-grid a:nth-child(1) { --accent: var(--c-tools); --soft-accent: var(--soft-tools); }
.search-tabs button:nth-child(2),
.hot-searches a:nth-of-type(2),
.portal-nav-grid a:nth-child(2) { --accent: var(--c-verification); --soft-accent: var(--soft-verification); }
.search-tabs button:nth-child(3),
.hot-searches a:nth-of-type(3),
.portal-nav-grid a:nth-child(3) { --accent: var(--c-industrial); --soft-accent: var(--soft-industrial); }
.search-tabs button:nth-child(4),
.hot-searches a:nth-of-type(4),
.portal-nav-grid a:nth-child(4) { --accent: var(--c-yiwu); --soft-accent: var(--soft-yiwu); }
.search-tabs button:nth-child(5),
.hot-searches a:nth-of-type(5),
.portal-nav-grid a:nth-child(5) { --accent: var(--c-shipping); --soft-accent: var(--soft-shipping); }
.hot-searches a:nth-of-type(6),
.portal-nav-grid a:nth-child(6) { --accent: var(--c-inspection); --soft-accent: var(--soft-inspection); }
.hot-searches a:nth-of-type(7),
.portal-nav-grid a:nth-child(7) { --accent: var(--c-templates); --soft-accent: var(--soft-templates); }
.hot-searches a:nth-of-type(8),
.portal-nav-grid a:nth-child(8) { --accent: var(--c-service); --soft-accent: var(--soft-service); }
.portal-nav-grid a:nth-child(9) { --accent: var(--c-payment); --soft-accent: var(--soft-payment); }
.portal-nav-grid a:nth-child(10) { --accent: var(--c-trade); --soft-accent: var(--soft-trade); }

.search-tabs button,
.hot-searches a,
.portal-nav-grid a {
  position: relative;
  background: var(--soft-accent, #fff);
  border-color: color-mix(in srgb, var(--accent, var(--blue)) 28%, white);
  color: color-mix(in srgb, var(--accent, var(--blue)) 78%, #0f172a);
}

.portal-nav-grid a::before {
  content: "";
  width: 8px;
  height: 8px;
  margin-right: 7px;
  border-radius: 999px;
  background: var(--accent, var(--blue));
  box-shadow: 0 0 0 4px color-mix(in srgb, var(--accent, var(--blue)) 14%, transparent);
}

.portal-nav-grid a {
  display: flex;
  align-items: center;
  justify-content: center;
}

.search-tabs button.active,
.search-tabs button:hover,
.hot-searches a:hover,
.portal-nav-grid a:hover {
  background: color-mix(in srgb, var(--soft-accent, #fff) 72%, white);
  border-color: color-mix(in srgb, var(--accent, var(--blue)) 42%, white);
  box-shadow: 0 10px 24px color-mix(in srgb, var(--accent, var(--blue)) 14%, transparent);
}

.portal-board-section {
  background:
    linear-gradient(90deg, rgba(239, 246, 255, 0.9), rgba(245, 243, 255, 0.72) 48%, rgba(255, 247, 237, 0.82)),
    #f6f8fb;
}

.portal-panel,
.portal-sidebar,
.portal-updates {
  background: rgba(255, 255, 255, 0.9);
}

.portal-sidebar a:nth-of-type(1), .toolbox-group:nth-child(1) { --accent: var(--c-tools); --soft-accent: var(--soft-tools); }
.portal-sidebar a:nth-of-type(2), .toolbox-group:nth-child(2) { --accent: var(--c-industrial); --soft-accent: var(--soft-industrial); }
.portal-sidebar a:nth-of-type(3), .toolbox-group:nth-child(3) { --accent: var(--c-verification); --soft-accent: var(--soft-verification); }
.portal-sidebar a:nth-of-type(4) { --accent: var(--c-yiwu); --soft-accent: var(--soft-yiwu); }
.portal-sidebar a:nth-of-type(5) { --accent: var(--c-inspection); --soft-accent: var(--soft-inspection); }
.portal-sidebar a:nth-of-type(6) { --accent: var(--c-shipping); --soft-accent: var(--soft-shipping); }
.portal-sidebar a:nth-of-type(7) { --accent: var(--c-payment); --soft-accent: var(--soft-payment); }
.portal-sidebar a:nth-of-type(8) { --accent: var(--c-service); --soft-accent: var(--soft-service); }
.portal-sidebar a:nth-of-type(9) { --accent: var(--c-machinery); --soft-accent: #f1f5f9; }
.portal-sidebar a:nth-of-type(10) { --accent: var(--c-trade); --soft-accent: var(--soft-trade); }

.portal-sidebar a {
  border: 1px solid transparent;
}

.portal-sidebar a .side-icon {
  background: linear-gradient(135deg, var(--accent, var(--c-tools)), color-mix(in srgb, var(--accent, var(--c-tools)) 68%, #0f172a));
  color: #fff;
}

.portal-sidebar a:hover {
  color: color-mix(in srgb, var(--accent, var(--blue)) 80%, #0f172a);
  background: var(--soft-accent, var(--soft-tools));
  border-color: color-mix(in srgb, var(--accent, var(--blue)) 30%, white);
}

.portal-panel-head h2::before {
  background: linear-gradient(180deg, var(--c-resources), var(--c-tools));
}

.toolbox-group {
  border-left: 4px solid var(--accent, var(--c-tools));
  background:
    linear-gradient(180deg, rgba(255,255,255,0.94), rgba(255,255,255,0.88)),
    var(--soft-accent, var(--soft-tools));
}

.toolbox-group h3::after {
  color: color-mix(in srgb, var(--accent, var(--c-tools)) 75%, #0f172a);
  background: var(--soft-accent, var(--soft-tools));
  border-color: color-mix(in srgb, var(--accent, var(--c-tools)) 30%, white);
}

.toolbox-item {
  border-left: 3px solid transparent;
}

.toolbox-item:hover {
  border-left-color: var(--accent, var(--c-tools));
  background: var(--soft-accent, var(--soft-tools));
}

.toolbox-item:nth-of-type(1) .tool-mini-icon { background: linear-gradient(135deg, var(--c-verification), #312e81); }
.toolbox-item:nth-of-type(2) .tool-mini-icon { background: linear-gradient(135deg, var(--c-templates), #166534); }
.toolbox-item:nth-of-type(3) .tool-mini-icon { background: linear-gradient(135deg, var(--c-shipping), #075985); }
.toolbox-item:nth-of-type(4) .tool-mini-icon { background: linear-gradient(135deg, var(--c-payment), #92400e); }
.toolbox-item:nth-of-type(5) .tool-mini-icon { background: linear-gradient(135deg, var(--c-inspection), #065f46); }
.toolbox-item:nth-of-type(6) .tool-mini-icon { background: linear-gradient(135deg, var(--c-resources), #581c87); }

.resource-group:nth-child(1) { --accent: var(--c-industrial); --soft-accent: var(--soft-industrial); }
.resource-group:nth-child(2) { --accent: var(--c-yiwu); --soft-accent: var(--soft-yiwu); }
.resource-group:nth-child(3) { --accent: var(--c-verification); --soft-accent: var(--soft-verification); }
.resource-group:nth-child(4) { --accent: var(--c-inspection); --soft-accent: var(--soft-inspection); }
.resource-group:nth-child(5) { --accent: var(--c-shipping); --soft-accent: var(--soft-shipping); }
.resource-group:nth-child(6) { --accent: var(--c-payment); --soft-accent: var(--soft-payment); }
.resource-group:nth-child(7) { --accent: var(--c-machinery); --soft-accent: #f1f5f9; }
.resource-group:nth-child(8) { --accent: var(--c-trade); --soft-accent: var(--soft-trade); }

.resource-group {
  border-top: 4px solid var(--accent, var(--c-resources));
  background:
    linear-gradient(180deg, rgba(255,255,255,0.92), rgba(255,255,255,0.84)),
    var(--soft-accent, var(--soft-resources));
}

.resource-group h3 {
  color: color-mix(in srgb, var(--accent, var(--c-resources)) 78%, #0f172a);
}

.resource-group a:hover {
  color: color-mix(in srgb, var(--accent, var(--c-resources)) 82%, #0f172a);
  background: color-mix(in srgb, var(--soft-accent, #fff) 78%, white);
}

.industrial-home-section {
  background:
    radial-gradient(circle at 12% 12%, rgba(249, 115, 22, 0.2), transparent 28%),
    radial-gradient(circle at 88% 24%, rgba(245, 158, 11, 0.14), transparent 30%),
    linear-gradient(135deg, #fff7ed 0%, #fffbeb 45%, #eff6ff 100%);
}

.compact-portal-section:nth-of-type(5) {
  background:
    linear-gradient(180deg, rgba(239,246,255,0.92), rgba(255,255,255,0.9)),
    var(--soft-tools);
}

.compact-portal-section:nth-of-type(6) {
  background:
    linear-gradient(180deg, rgba(245,243,255,0.9), rgba(239,246,255,0.66)),
    var(--soft-resources);
}

.compact-portal-section:nth-of-type(7) {
  background:
    linear-gradient(180deg, rgba(255,247,237,0.96), rgba(255,255,255,0.86)),
    var(--soft-industrial);
}

.compact-portal-section:nth-of-type(8) {
  background:
    linear-gradient(180deg, rgba(240,253,244,0.92), rgba(255,255,255,0.86)),
    var(--soft-templates);
}

.home-portal-card {
  position: relative;
  overflow: hidden;
  border-left: 5px solid var(--accent, var(--c-tools));
  background:
    linear-gradient(180deg, rgba(255,255,255,0.96), rgba(255,255,255,0.9)),
    var(--soft-accent, var(--soft-tools));
}

.home-portal-card::after {
  content: "";
  position: absolute;
  top: -36px;
  right: -34px;
  width: 92px;
  height: 92px;
  border-radius: 999px;
  background: color-mix(in srgb, var(--accent, var(--c-tools)) 12%, transparent);
}

.theme-tools { --accent: var(--c-tools); --soft-accent: var(--soft-tools); }
.theme-resources { --accent: var(--c-resources); --soft-accent: var(--soft-resources); }
.theme-industrial { --accent: var(--c-industrial); --soft-accent: var(--soft-industrial); }
.theme-templates { --accent: var(--c-templates); --soft-accent: var(--soft-templates); }
.theme-service { --accent: var(--c-service); --soft-accent: var(--soft-service); }
.theme-shipping { --accent: var(--c-shipping); --soft-accent: var(--soft-shipping); }
.theme-payment { --accent: var(--c-payment); --soft-accent: var(--soft-payment); }
.theme-verification { --accent: var(--c-verification); --soft-accent: var(--soft-verification); }
.theme-yiwu { --accent: var(--c-yiwu); --soft-accent: var(--soft-yiwu); }
.theme-inspection { --accent: var(--c-inspection); --soft-accent: var(--soft-inspection); }
.theme-trade { --accent: var(--c-trade); --soft-accent: var(--soft-trade); }
.theme-alibaba { --accent: var(--c-industrial); --soft-accent: var(--soft-industrial); }

.home-portal-card .portal-icon,
.home-portal-card .service-icon {
  background: linear-gradient(135deg, var(--accent, var(--c-tools)), color-mix(in srgb, var(--accent, var(--c-tools)) 62%, #111827));
}

.home-portal-card .tool-label,
.home-card-meta {
  color: color-mix(in srgb, var(--accent, var(--c-tools)) 78%, #0f172a);
  background: color-mix(in srgb, var(--soft-accent, #fff) 80%, white);
  border-color: color-mix(in srgb, var(--accent, var(--c-tools)) 26%, white);
}

.portal-card-links a {
  color: color-mix(in srgb, var(--accent, var(--c-tools)) 72%, #0f172a);
  background: color-mix(in srgb, var(--soft-accent, #fff) 82%, white);
  border-color: color-mix(in srgb, var(--accent, var(--c-tools)) 20%, white);
}

.portal-card-cta,
.home-portal-card h3 a:hover {
  color: color-mix(in srgb, var(--accent, var(--c-tools)) 82%, #0f172a);
}

.industrial-portal-grid .portal-card-links a:nth-child(1) { color: #1d4ed8; background: #eff6ff; border-color: #bfdbfe; }
.industrial-portal-grid .portal-card-links a:nth-child(2) { color: #c2410c; background: #fff7ed; border-color: #fed7aa; }
.industrial-portal-grid .portal-card-links a:nth-child(3) { color: #7c3aed; background: #f5f3ff; border-color: #ddd6fe; }
.industrial-portal-grid .portal-card-links a:nth-child(4) { color: #15803d; background: #f0fdf4; border-color: #bbf7d0; }

.directoryPreview,
.section.muted:has(.directory-grid) {
  background:
    radial-gradient(circle at 85% 6%, rgba(13, 148, 136, 0.12), transparent 26%),
    linear-gradient(180deg, #f0fdfa 0%, #f8fafc 100%);
}

.directory-card {
  --accent: var(--c-service);
  --soft-accent: var(--soft-service);
  border-top: 4px solid var(--accent);
  background:
    linear-gradient(180deg, rgba(255,255,255,0.95), rgba(255,255,255,0.88)),
    var(--soft-accent);
}

.service-inspection-companies { --accent: var(--c-inspection); --soft-accent: var(--soft-inspection); }
.service-freight-forwarders { --accent: var(--c-shipping); --soft-accent: var(--soft-shipping); }
.service-china-sourcing-agents { --accent: var(--c-resources); --soft-accent: var(--soft-resources); }
.service-yiwu-market-agents { --accent: var(--c-yiwu); --soft-accent: var(--soft-yiwu); }
.service-1688-purchasing-agents { --accent: var(--c-industrial); --soft-accent: var(--soft-industrial); }
.service-business-translators { --accent: var(--c-verification); --soft-accent: var(--soft-verification); }
.service-trade-fair-support { --accent: var(--c-trade); --soft-accent: var(--soft-trade); }
.service-compliance-testing-labs { --accent: var(--c-service); --soft-accent: var(--soft-service); }

.directory-card .service-icon {
  background: linear-gradient(135deg, var(--accent), color-mix(in srgb, var(--accent) 62%, #111827));
}

.directory-card .tool-label {
  color: color-mix(in srgb, var(--accent) 76%, #0f172a);
  background: color-mix(in srgb, var(--soft-accent) 78%, white);
  border-color: color-mix(in srgb, var(--accent) 24%, white);
}

.directory-card .text-link {
  color: color-mix(in srgb, var(--accent) 82%, #0f172a);
}

.services-line {
  background: color-mix(in srgb, var(--soft-accent) 72%, white);
  border-color: color-mix(in srgb, var(--accent) 18%, white);
}

.map-role.manufacturing_cluster { color: #1d4ed8; background: #eff6ff; border-color: #bfdbfe; }
.map-role.wholesale_market { color: #c2410c; background: #fff7ed; border-color: #fed7aa; }
.map-role.oem_base { color: #7c3aed; background: #f5f3ff; border-color: #ddd6fe; }
.map-role.cross_border_supply { color: #15803d; background: #f0fdf4; border-color: #bbf7d0; }

.newsletter {
  background:
    radial-gradient(circle at 10% 10%, rgba(245, 158, 11, 0.14), transparent 30%),
    linear-gradient(135deg, #fffbeb 0%, #fff7ed 100%);
}

@media (max-width: 760px) {
  .portal-nav-grid a {
    justify-content: flex-start;
  }

  .home-portal-card::after {
    width: 64px;
    height: 64px;
  }
}

/* Final polish: stabilize colorful portal system */
.portal-search-area {
  padding: 30px 0 20px;
  background:
    radial-gradient(circle at 18% 10%, rgba(37, 99, 235, 0.09), transparent 30%),
    radial-gradient(circle at 82% 4%, rgba(249, 115, 22, 0.10), transparent 28%),
    linear-gradient(180deg, #ffffff 0%, #f7faff 62%, #f6f8fb 100%);
}

.portal-search-inner h1 {
  max-width: 920px;
  margin-bottom: 10px;
}

.portal-search-inner > p {
  max-width: 740px;
  margin-bottom: 14px;
}

.portal-search-area .hero-search {
  max-width: 990px;
  border-color: rgba(147, 197, 253, 0.72);
  box-shadow: 0 20px 55px rgba(37, 99, 235, 0.16);
}

.portal-search-area .hero-search input {
  font-size: 16px;
}

.search-tabs {
  margin-bottom: 10px;
}

.search-tabs button {
  background: rgba(255, 255, 255, 0.88);
  border-color: #e2e8f0;
  color: #475569;
  box-shadow: none;
}

.search-tabs button.active {
  color: var(--c-tools);
  background: #eff6ff;
  border-color: #bfdbfe;
}

.hot-searches {
  margin-top: 4px;
}

.hot-searches a {
  background: rgba(255, 255, 255, 0.82);
  border-color: #e2e8f0;
  color: #475569;
  box-shadow: none;
  font-size: 12px;
  padding: 5px 9px;
}

.hot-searches a:hover {
  color: var(--c-tools);
  background: #eff6ff;
  border-color: #bfdbfe;
}

.portal-board-section {
  padding: 20px 0 42px;
  background:
    linear-gradient(180deg, rgba(248, 250, 252, 0.92), rgba(241, 245, 249, 0.9)),
    #f6f8fb;
}

.portal-board {
  gap: 18px;
}

.portal-panel,
.portal-sidebar,
.portal-updates {
  padding: 15px;
  border-color: #e3eaf2;
  box-shadow: 0 12px 34px rgba(15, 23, 42, 0.07);
}

.portal-sidebar h2,
.portal-updates h2,
.portal-panel h2 {
  font-size: 17px;
}

.portal-sidebar a {
  min-height: 42px;
  padding: 8px 9px;
  font-size: 13px;
}

.side-icon {
  flex-basis: 27px;
  width: 27px;
  height: 27px;
  font-size: 10px;
}

.toolbox-grid {
  gap: 12px;
}

.toolbox-group {
  padding: 12px;
  border-left-width: 3px;
  background: #fff;
}

.toolbox-group h3 {
  font-size: 14px;
  line-height: 1.25;
}

.toolbox-group h3::after {
  opacity: 0.82;
  font-size: 10px;
  padding: 2px 6px;
}

.toolbox-item {
  min-height: 78px;
  padding: 9px;
  gap: 9px;
  border-left-width: 2px;
}

.toolbox-copy strong {
  font-size: 14px;
  line-height: 1.25;
  white-space: normal;
}

.toolbox-copy small {
  font-size: 12px;
  line-height: 1.35;
}

.toolbox-meta em,
.toolbox-meta b {
  font-size: 10px;
  padding: 2px 6px;
  background: #f8fafc;
  border-color: #e2e8f0;
}

.tool-mini-icon {
  width: 32px;
  height: 32px;
  box-shadow: 0 6px 14px rgba(15, 23, 42, 0.12);
}

.item-arrow {
  font-size: 16px;
  color: #94a3b8;
}

.resource-grid {
  gap: 12px;
}

.resource-group {
  padding: 12px;
  border-top-width: 3px;
}

.resource-group h3 {
  font-size: 14px;
  line-height: 1.25;
}

.resource-group a {
  font-size: 13px;
  line-height: 1.35;
  padding: 7px 0;
}

.portal-updates {
  background: rgba(255, 255, 255, 0.78);
  box-shadow: 0 8px 24px rgba(15, 23, 42, 0.05);
}

.portal-updates article {
  padding: 11px 0;
}

.portal-updates h3 {
  font-size: 13px;
  line-height: 1.3;
}

.portal-updates h3::before {
  opacity: 0.75;
  font-size: 9px;
  padding: 1px 5px;
}

.portal-updates p {
  color: #64748b;
  font-size: 12px;
  line-height: 1.45;
}

.compact-portal-section {
  padding: 42px 0;
}

.compact-portal-section .section-head {
  margin-bottom: 18px;
}

.compact-portal-section .section-lede {
  font-size: 15px;
  line-height: 1.55;
}

.tool-portal-grid .home-portal-card {
  --accent: var(--c-tools);
  --soft-accent: var(--soft-tools);
}

.resource-portal-grid .home-portal-card {
  --accent: var(--c-resources);
  --soft-accent: var(--soft-resources);
}

.industrial-portal-grid .home-portal-card {
  --accent: var(--c-industrial);
  --soft-accent: var(--soft-industrial);
}

.template-portal-grid .home-portal-card {
  --accent: var(--c-templates);
  --soft-accent: var(--soft-templates);
}

.directory-grid .directory-card {
  --accent: var(--c-service);
  --soft-accent: var(--soft-service);
}

.home-portal-card {
  min-height: 214px;
  padding: 17px;
  gap: 9px;
  border-left-width: 4px;
}

.home-portal-card::after {
  opacity: 0.65;
  width: 76px;
  height: 76px;
}

.home-card-top {
  gap: 8px;
}

.portal-icon,
.service-icon {
  width: 32px;
  height: 32px;
  box-shadow: 0 7px 16px color-mix(in srgb, var(--accent, var(--c-tools)) 20%, transparent);
}

.home-portal-card h3 {
  font-size: 18px;
  line-height: 1.2;
}

.home-portal-card p {
  font-size: 14px;
  line-height: 1.45;
}

.portal-card-links {
  gap: 7px;
}

.portal-card-links a {
  font-size: 12px;
  padding: 5px 8px;
}

.portal-card-cta {
  display: inline-flex;
  align-items: center;
  min-height: 32px;
  font-size: 14px;
}

.home-card-meta {
  font-size: 11px;
  padding: 3px 7px;
}

.industrial-home-section {
  padding: 44px 0;
  background:
    radial-gradient(circle at 12% 16%, rgba(249, 115, 22, 0.16), transparent 28%),
    linear-gradient(135deg, #fff7ed 0%, #fffbeb 48%, #f8fbff 100%);
}

.industrial-home-panel {
  gap: 26px;
}

.industrial-home-panel p {
  font-size: 15px;
}

.industrial-home-search {
  box-shadow: 0 18px 42px rgba(249, 115, 22, 0.12);
}

.directory-grid {
  gap: 15px;
}

.directory-card {
  min-height: 275px;
  border-top-width: 4px;
  padding: 18px;
}

.directory-card h3 {
  font-size: 18px;
  line-height: 1.22;
}

.directory-card p {
  font-size: 14px;
  line-height: 1.5;
}

.services-line {
  font-size: 13px;
  line-height: 1.45;
}

.service-card-top {
  margin-bottom: 2px;
}

.newsletter {
  background:
    radial-gradient(circle at 12% 10%, rgba(245, 158, 11, 0.11), transparent 30%),
    linear-gradient(135deg, #fffdf7 0%, #fff7ed 100%);
}

@media (max-width: 1180px) {
  .portal-board {
    gap: 14px;
  }

  .toolbox-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 900px) {
  .portal-board {
    gap: 14px;
  }

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

  .portal-updates h2 {
    grid-column: 1 / -1;
  }
}

@media (max-width: 760px) {
  .portal-search-inner h1 {
    font-size: clamp(32px, 8.4vw, 42px);
  }

  .portal-search-inner > p {
    font-size: 16px;
  }

  .hot-searches {
    justify-content: flex-start;
  }

  .hot-searches a,
  .popular-chip-row a,
  .popular-chip-row button {
    font-size: 12px;
    padding: 6px 9px;
  }

  .portal-board-section {
    padding-top: 14px;
  }

  .popular-shortcuts-section {
    padding: 12px 0 14px;
  }

  .popular-shortcuts-inner {
    padding: 12px;
    border-radius: 14px;
  }

  .shortcuts-head {
    display: block;
  }

  .shortcuts-head h2 {
    font-size: 20px;
    margin-top: 4px;
  }

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

  .shortcut-card {
    min-height: 60px;
    padding: 9px;
  }

  .shortcut-icon {
    width: 32px;
    height: 32px;
  }

  .shortcut-copy strong {
    font-size: 12px;
  }

  .portal-panel,
  .portal-sidebar,
  .portal-updates {
    padding: 13px;
  }

  .portal-updates {
    grid-template-columns: 1fr;
  }

  .toolbox-grid,
  .resource-grid {
    gap: 10px;
  }

  .home-portal-grid,
  .directory-grid {
    gap: 12px;
  }

  .home-portal-card,
  .directory-card {
    padding: 15px;
  }

  .home-portal-card h3,
  .directory-card h3 {
    font-size: 17px;
  }

  .home-portal-card p,
  .directory-card p {
    font-size: 13px;
  }

  .portal-card-links a {
    font-size: 11px;
  }

  .industrial-home-panel {
    gap: 18px;
  }
}

/* Final homepage efficiency polish */
.header-inner {
  min-height: 68px;
}

@media (min-width: 1181px) {
  .header-inner {
    flex-wrap: nowrap;
  }

  .site-nav {
    flex-wrap: nowrap;
    min-width: 0;
  }

  .site-nav a,
  .language-switcher {
    white-space: nowrap;
    font-size: 13px;
    padding: 9px 10px;
  }

  .brand {
    min-width: 230px;
  }

  .header-actions {
    flex: 0 0 auto;
  }
}

.portal-search-area {
  padding: 22px 0 14px;
}

.portal-search-inner {
  max-width: 1340px;
}

.portal-search-inner h1 {
  max-width: 1120px;
  font-size: clamp(44px, 3.8vw, 52px);
  line-height: 1.07;
  margin-bottom: 8px;
}

.portal-search-inner > p {
  max-width: 860px;
  font-size: 17px;
  margin-bottom: 10px;
}

.search-tabs {
  margin-bottom: 8px;
}

.portal-search-area .hero-search {
  margin-bottom: 8px;
}

.hot-searches {
  margin-top: 0;
  margin-bottom: 0;
}

.portal-nav-strip {
  padding: 8px 0;
}

.portal-board-section {
  padding: 14px 0 38px;
}

.portal-board {
  align-items: start;
}

.home-portal-card h3,
.directory-card h3 {
  letter-spacing: 0;
}

.home-portal-card p,
.directory-card p {
  color: #42526a;
}

.portal-card-cta,
.text-link {
  text-decoration: none;
  border-bottom: 1px solid currentColor;
  line-height: 1.2;
}

.portal-card-cta:hover,
.text-link:hover {
  border-bottom-color: transparent;
}

@media (max-width: 760px) {
  .header-inner {
    min-height: 64px;
  }

  .portal-search-area {
    padding: 22px 0 14px;
  }

  .portal-search-inner h1 {
    font-size: clamp(32px, 8vw, 40px);
    line-height: 1.08;
  }

  .portal-search-inner > p {
    font-size: 15px;
    line-height: 1.5;
    margin-bottom: 10px;
  }

  .portal-search-area .hero-search {
    margin-bottom: 8px;
  }

  .portal-nav-strip {
    padding: 7px 0;
  }

  .portal-nav-grid a {
    min-height: 42px;
  }

  .portal-nav-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 8px;
  }

  .portal-nav-grid a {
    font-size: 12px;
    padding: 9px 8px;
  }
}
.toolbox-hero {
  background:
    radial-gradient(circle at 12% 18%, rgba(37, 99, 235, 0.14), transparent 28%),
    radial-gradient(circle at 88% 20%, rgba(249, 115, 22, 0.12), transparent 30%),
    linear-gradient(135deg, #f8fbff 0%, #fff7ed 100%);
}

.toolbox-directory-section {
  background: #f6f8fb;
}

.toolbox-controls {
  display: grid;
  gap: 14px;
  margin-bottom: 28px;
}

.toolbox-search {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 10px;
  padding: 10px;
  border: 1px solid #dbe4f0;
  border-radius: 14px;
  background: #fff;
  box-shadow: 0 14px 30px rgba(15, 23, 42, 0.07);
}

.toolbox-search input {
  width: 100%;
  border: 0;
  outline: 0;
  padding: 11px 12px;
  font-size: 15px;
  background: transparent;
}

.toolbox-filter-tabs {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.toolbox-filter-tabs button {
  border: 1px solid #d7e0ee;
  background: #fff;
  border-radius: 999px;
  padding: 9px 13px;
  color: #334155;
  font-weight: 750;
  cursor: pointer;
}

.toolbox-filter-tabs button.active {
  color: #fff;
  border-color: #2563eb;
  background: linear-gradient(135deg, #2563eb, #0f766e);
}

.toolbox-filter-tabs span {
  opacity: 0.75;
  margin-left: 4px;
}

.toolbox-result-count {
  margin: 0;
  color: #64748b;
  font-weight: 700;
}

.toolbox-section {
  margin-top: 28px;
}

.section-head.compact {
  margin-bottom: 16px;
}

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

.workflow-shortcut-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
  margin: 22px 0 34px;
}

.workflow-shortcut-card {
  --workflow-accent: #2563eb;
  display: grid;
  grid-template-columns: auto 1fr auto;
  gap: 8px 12px;
  align-items: center;
  padding: 16px;
  border: 1px solid #dbe4f0;
  border-left: 5px solid var(--workflow-accent);
  border-radius: 14px;
  color: inherit;
  background: #fff;
  text-decoration: none;
  box-shadow: 0 14px 28px rgba(15, 23, 42, 0.06);
}

.workflow-shortcut-card:hover {
  transform: translateY(-2px);
  box-shadow: 0 18px 34px rgba(15, 23, 42, 0.1);
}

.workflow-shortcut-card.theme-search-china-1688,
.workflow-shortcut-card.theme-payment-contracts {
  --workflow-accent: #f59e0b;
}

.workflow-shortcut-card.theme-verify-suppliers {
  --workflow-accent: #4f46e5;
}

.workflow-shortcut-card.theme-rfq-quote-comparison,
.workflow-shortcut-card.theme-product-research-industrial-belts {
  --workflow-accent: #f97316;
}

.workflow-shortcut-card.theme-inspection-qc {
  --workflow-accent: #059669;
}

.workflow-shortcut-card.theme-shipping-customs {
  --workflow-accent: #0284c7;
}

.workflow-shortcut-card.theme-trade-fairs-china-visits {
  --workflow-accent: #e11d48;
}

.workflow-icon {
  display: grid;
  place-items: center;
  grid-row: span 3;
  width: 42px;
  height: 42px;
  border-radius: 12px;
  color: #fff;
  background: var(--workflow-accent);
  font-weight: 900;
}

.workflow-shortcut-card strong {
  color: #0f172a;
  font-size: 18px;
}

.workflow-shortcut-card small {
  color: #64748b;
  line-height: 1.35;
}

.workflow-shortcut-card em {
  color: #475569;
  font-size: 12px;
  font-style: normal;
  font-weight: 900;
}

.workflow-shortcut-card b {
  justify-self: end;
  color: var(--workflow-accent);
  font-size: 13px;
}

.workflow-section {
  padding: 24px;
  margin-top: 22px;
  border: 1px solid #dbe4f0;
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.78);
}

.workflow-section-head {
  display: flex;
  justify-content: space-between;
  gap: 16px;
  align-items: end;
  margin-bottom: 16px;
}

.workflow-section-head h2,
.workflow-section-head p {
  margin: 0;
}

.workflow-section-head h2 {
  color: #0f172a;
  font-size: 26px;
}

.workflow-section-head p:not(.eyebrow) {
  margin-top: 6px;
  color: #64748b;
}

.toolbox-card-grid.compact {
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 13px;
}

.toolbox-card {
  --toolbox-accent: #2563eb;
  display: flex;
  flex-direction: column;
  gap: 12px;
  min-height: 100%;
  padding: 18px;
  border: 1px solid #dbe4f0;
  border-top: 4px solid var(--toolbox-accent);
  border-radius: 14px;
  background: linear-gradient(180deg, #fff 0%, #f8fbff 100%);
  box-shadow: 0 14px 26px rgba(15, 23, 42, 0.06);
}

.toolbox-card-grid.compact .toolbox-card {
  padding: 14px;
  gap: 9px;
}

.toolbox-card-grid.compact .toolbox-card h3 {
  font-size: 17px;
}

.toolbox-card-grid.compact .toolbox-card p,
.toolbox-card-grid.compact .toolbox-details dd {
  font-size: 13px;
}

.toolbox-card.theme-external-resource {
  --toolbox-accent: #7c3aed;
}

.toolbox-card.theme-service-category {
  --toolbox-accent: #0f766e;
}

.toolbox-card.theme-template {
  --toolbox-accent: #16a34a;
}

.toolbox-card-top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
}

.toolbox-category {
  color: #64748b;
  font-size: 12px;
  font-weight: 800;
  text-align: right;
}

.toolbox-card h3 {
  margin: 0;
  color: #0f172a;
  font-size: 20px;
  line-height: 1.25;
}

.toolbox-card p {
  margin: 0;
  color: #475569;
  line-height: 1.55;
}

.toolbox-details {
  display: grid;
  gap: 7px;
  margin: 0;
}

.toolbox-details.compact {
  gap: 4px;
}

.toolbox-details dt {
  color: #0f172a;
  font-size: 12px;
  font-weight: 900;
  text-transform: uppercase;
}

.toolbox-details dd {
  margin: -4px 0 3px;
  color: #475569;
  font-size: 14px;
  line-height: 1.45;
}

.tag-row {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.tag-row span {
  border-radius: 999px;
  padding: 5px 8px;
  color: #334155;
  background: #eef2ff;
  font-size: 12px;
  font-weight: 800;
}

.related-mini {
  display: flex;
  flex-wrap: wrap;
  gap: 7px;
  align-items: center;
  padding-top: 2px;
}

.related-mini strong {
  flex-basis: 100%;
  color: #0f172a;
  font-size: 12px;
  text-transform: uppercase;
}

.related-mini a {
  color: #1d4ed8;
  font-size: 13px;
  font-weight: 800;
  text-decoration: none;
}

.toolbox-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: auto;
}

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

.external-shortcut-card {
  display: grid;
  gap: 5px;
  padding: 15px;
  border: 1px solid #dbe4f0;
  border-left: 4px solid #7c3aed;
  border-radius: 12px;
  color: inherit;
  background: #fff;
  text-decoration: none;
  box-shadow: 0 10px 22px rgba(15, 23, 42, 0.05);
}

.external-shortcut-card span {
  color: #7c3aed;
  font-size: 12px;
  font-weight: 900;
  text-transform: uppercase;
}

.external-shortcut-card strong {
  color: #0f172a;
  font-size: 17px;
}

.external-shortcut-card small {
  color: #64748b;
  line-height: 1.4;
}

.resource-hub-layout {
  display: grid;
  grid-template-columns: 260px minmax(0, 1fr);
  gap: 22px;
  align-items: start;
}

.resource-hub-nav {
  position: sticky;
  top: 90px;
  display: grid;
  gap: 8px;
  padding: 16px;
  border: 1px solid #dbe4f0;
  border-radius: 14px;
  background: #fff;
}

.resource-hub-nav h2 {
  margin: 0 0 6px;
  font-size: 18px;
}

.resource-hub-nav a {
  color: #334155;
  padding: 8px 10px;
  border-radius: 9px;
  text-decoration: none;
  font-weight: 800;
}

.resource-hub-nav a:hover {
  background: #eef2ff;
  color: #1d4ed8;
}

.resource-disclaimer {
  margin: 0 0 18px;
  padding: 13px 15px;
  border: 1px solid #fed7aa;
  border-radius: 12px;
  color: #7c2d12;
  background: #fff7ed;
}

.resource-hub-group {
  margin-bottom: 34px;
}

.next-step-flow {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
  margin-top: 14px;
  padding: 12px;
  border-radius: 12px;
  background: #eef6ff;
}

.next-step-flow strong {
  color: #0f172a;
  margin-right: 4px;
}

.next-step-flow a {
  display: inline-flex;
  gap: 6px;
  align-items: center;
  color: #1d4ed8;
  font-weight: 850;
  text-decoration: none;
}

.next-step-flow span {
  display: inline-grid;
  place-items: center;
  width: 20px;
  height: 20px;
  border-radius: 999px;
  color: #fff;
  background: #2563eb;
  font-size: 12px;
}

@media (max-width: 980px) {
  .toolbox-card-grid,
  .toolbox-card-grid.compact,
  .workflow-shortcut-grid,
  .external-shortcut-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .resource-hub-layout {
    grid-template-columns: 1fr;
  }

  .resource-hub-nav {
    position: static;
  }
}

@media (max-width: 640px) {
  .toolbox-search {
    grid-template-columns: 1fr;
  }

  .toolbox-card-grid,
  .toolbox-card-grid.compact,
  .workflow-shortcut-grid,
  .external-shortcut-grid {
    grid-template-columns: 1fr;
  }

  .workflow-section {
    padding: 16px;
  }

  .workflow-section-head {
    align-items: start;
    flex-direction: column;
  }

  .workflow-shortcut-card {
    grid-template-columns: auto 1fr;
  }

  .workflow-shortcut-card b {
    justify-self: start;
  }
}
