:root {
  --ink-strong: #10233f;
  --ink: #25364d;
  --ink-muted: #66768a;
  --brand: #007f89;
  --brand-dark: #00646d;
  --brand-soft: #e8f5f4;
  --line: #dfe7ec;
  --surface: #ffffff;
  --surface-soft: #f5f8fa;
  --shadow: 0 18px 45px rgba(16, 35, 63, 0.1);
}

* { box-sizing: border-box; }

html {
  color: var(--ink);
  background: var(--surface-soft);
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", "PingFang SC", "Microsoft YaHei", Arial, sans-serif;
  line-height: 1.75;
}

body { margin: 0; }
a { color: var(--brand-dark); text-decoration: none; }
a:hover { text-decoration: underline; }
.shell, .topbar, .site-footer { width: min(1120px, calc(100% - 40px)); margin-inline: auto; }

.site-header { background: rgba(255, 255, 255, 0.96); border-bottom: 1px solid var(--line); }
.topbar { min-height: 72px; display: flex; align-items: center; justify-content: space-between; gap: 28px; }
.brand { display: inline-flex; align-items: center; gap: 10px; color: var(--ink-strong); font-size: 19px; font-weight: 750; }
.brand:hover { text-decoration: none; }
.brand-mark { display: block; width: 106px; height: auto; object-fit: contain; }
.nav { display: flex; flex-wrap: wrap; gap: 24px; font-size: 14px; }
.nav a { color: #415269; }

.company-hero { overflow: hidden; padding: 70px 0 58px; border-bottom: 1px solid #d7e6e6; background: radial-gradient(circle at 85% 20%, #dff1ef 0, transparent 36%), linear-gradient(135deg, #fff 0%, #eff7f6 100%); }
.hero-grid { display: grid; grid-template-columns: minmax(0, 1.55fr) minmax(300px, 0.7fr); gap: 64px; align-items: center; }
.eyebrow, .section-kicker { margin: 0 0 10px; color: var(--brand); font-size: 12px; font-weight: 800; letter-spacing: 0.12em; text-transform: uppercase; }
h1 { max-width: 760px; margin: 0; color: var(--ink-strong); font-size: clamp(34px, 5vw, 52px); line-height: 1.18; letter-spacing: -0.025em; }
.company-subtitle { display: flex; flex-wrap: wrap; gap: 9px; margin: 19px 0 0; color: #43546a; font-size: 16px; }
.hero-lead { max-width: 700px; margin: 22px 0 0; color: #53647a; font-size: 17px; }
.live-card { padding: 26px; border: 1px solid rgba(0, 127, 137, 0.18); border-radius: 14px; background: rgba(255,255,255,.92); box-shadow: var(--shadow); }
.live-card-label { margin: 0 0 8px; color: var(--ink-strong); font-size: 20px; font-weight: 750; }
.live-card p:not(.live-card-label) { margin: 0 0 20px; color: var(--ink-muted); font-size: 14px; }
.primary-button { display: inline-flex; min-height: 44px; align-items: center; justify-content: center; gap: 12px; padding: 9px 18px; border-radius: 7px; background: var(--brand); color: white; font-weight: 750; }
.primary-button:hover { background: var(--brand-dark); text-decoration: none; }

.content-layout { display: grid; grid-template-columns: minmax(0, 1fr) 320px; gap: 64px; padding-block: 52px 70px; }
.content-section { padding: 0 0 42px; margin: 0 0 42px; border-bottom: 1px solid var(--line); }
.content-section:last-child { margin-bottom: 0; border-bottom: 0; }
h2 { margin: 0 0 18px; color: var(--ink-strong); font-size: 25px; line-height: 1.35; }
.profile-text { margin: 0; color: #34465c; font-size: 16px; line-height: 2; text-align: justify; }
.industry-list { margin: 0; overflow: hidden; border: 1px solid var(--line); border-radius: 10px; background: var(--surface); }
.industry-row { display: grid; grid-template-columns: 120px 1fr; border-bottom: 1px solid var(--line); }
.industry-row:last-child { border-bottom: 0; }
.industry-row dt, .industry-row dd { margin: 0; padding: 14px 18px; }
.industry-row dt { color: var(--ink-muted); background: #f7fafb; font-size: 14px; }
.industry-row dd { display: flex; align-items: center; }
.section-note { margin: 12px 0 0; color: var(--ink-muted); font-size: 13px; }
.alias-list { display: flex; flex-wrap: wrap; gap: 10px; margin: 0; padding: 0; list-style: none; }
.alias-tag { padding: 7px 12px; border: 1px solid #cfe1e2; border-radius: 999px; color: #285158; background: var(--brand-soft); font-size: 14px; }

.content-aside { display: flex; flex-direction: column; gap: 18px; }
.info-card, .related-card { padding: 24px; border: 1px solid var(--line); border-radius: 12px; background: var(--surface); }
.info-card h2, .related-card h2 { font-size: 19px; }
.facts { margin: 0; }
.facts div { padding: 13px 0; border-bottom: 1px solid #edf1f4; }
.facts div:last-child { padding-bottom: 0; border-bottom: 0; }
.facts dt { color: var(--ink-muted); font-size: 12px; }
.facts dd { margin: 3px 0 0; color: var(--ink-strong); font-size: 14px; font-weight: 650; overflow-wrap: anywhere; }
.related-card { display: flex; flex-direction: column; gap: 13px; }
.related-card h2 { margin-bottom: 2px; }
.related-card a { font-size: 14px; }

.disclosure-wrap { padding: 34px 0; border-top: 1px solid var(--line); background: #eef4f5; }
.disclosure h2 { margin-bottom: 8px; font-size: 18px; }
.disclosure p { max-width: 900px; margin: 0; color: #58697d; font-size: 14px; }
.site-footer-wrap { border-top: 1px solid var(--line); background: var(--surface); }
.site-footer { min-height: 66px; display: flex; align-items: center; justify-content: space-between; gap: 20px; color: var(--ink-muted); font-size: 13px; }

@media (max-width: 860px) {
  .hero-grid, .content-layout { grid-template-columns: 1fr; }
  .hero-grid, .content-layout { gap: 34px; }
  .content-aside { order: -1; }
}

@media (max-width: 640px) {
  .shell, .topbar, .site-footer { width: min(100% - 28px, 1120px); }
  .topbar { align-items: flex-start; flex-direction: column; padding-block: 15px; }
  .nav { gap: 16px; }
  .company-hero { padding: 44px 0 36px; }
  .live-card { padding: 20px; }
  .primary-button { width: 100%; }
  .content-layout { padding-block: 36px 48px; }
  .industry-row { grid-template-columns: 1fr; }
  .industry-row dt { padding-bottom: 4px; }
  .industry-row dd { padding-top: 6px; align-items: flex-start; flex-direction: column; gap: 2px; }
  .site-footer { align-items: flex-start; flex-direction: column; justify-content: center; padding-block: 16px; }
}

@media print {
  .nav, .live-card { display: none; }
  .company-hero { padding: 30px 0; background: white; }
  .content-layout { grid-template-columns: 1fr; }
  .content-aside { order: -1; }
}
