
:root {
  --sh-primary:#15356F;
  --sh-dark:#0A1E45;
  --sh-accent:#E53935;
  --sh-ink:#101827;
  --sh-muted:#5B6575;
  --sh-line:#E6EAF2;
  --sh-soft:#EEF3FF;
  --sh-bg:#F6F8FB;
  --sh-card:#FFFFFF;
}
* { box-sizing:border-box; }
.sh-page { padding-top:88px; color:var(--sh-ink); background:var(--sh-bg); font-family:system-ui,-apple-system,"Inter","Noto Sans SC","PingFang SC","Microsoft YaHei",sans-serif; }
.sh-page a { color:inherit; text-decoration:none; }
.sh-wrap { width:min(1440px, calc(100% - 48px)); margin:0 auto; }
.sh-btn { display:inline-flex; align-items:center; justify-content:center; gap:8px; min-height:46px; padding:0 20px; border:0; border-radius:8px; background:var(--sh-primary); color:#fff; font-size:15px; font-weight:900; cursor:pointer; box-shadow:0 12px 30px rgba(21,53,111,.16); }
.sh-btn:hover { background:var(--sh-dark); color:#fff; }
.sh-btn--accent { background:var(--sh-accent); }
.sh-btn--ghost { background:#fff; color:var(--sh-primary); border:1px solid var(--sh-line); box-shadow:none; }
.sh-page .sh-btn { color:#fff !important; border-color:transparent; }
.sh-page .sh-btn--accent { color:#fff !important; }
.sh-page .sh-btn--ghost { color:var(--sh-primary) !important; border-color:var(--sh-line); }
.sh-hero { position:relative; overflow:hidden; color:#fff; background:linear-gradient(135deg, rgba(10,30,69,.96), rgba(21,53,111,.9)), url('/assets/addons/ldcms/ldcms2026/images/banner_shfw.jpg') center/cover no-repeat; }
.sh-hero::after { content:"SERVICE"; position:absolute; right:-10px; bottom:-34px; color:rgba(255,255,255,.08); font-size:148px; line-height:1; font-weight:900; letter-spacing:0; pointer-events:none; }
.sh-hero__inner { position:relative; z-index:1; display:grid; grid-template-columns:minmax(0,1.1fr) minmax(360px,.9fr); gap:52px; align-items:end; padding:72px 0 58px; }
.sh-eyebrow { display:inline-flex; align-items:center; gap:10px; color:#ffd9d8; font-size:12px; font-weight:900; letter-spacing:3px; text-transform:uppercase; }
.sh-eyebrow::before { content:""; width:34px; height:3px; background:var(--sh-accent); border-radius:99px; }
.sh-hero h1 { margin:18px 0 18px; max-width:760px; font-size:clamp(36px,5.6vw,76px); line-height:1.05; font-weight:900; letter-spacing:0; }
.sh-hero p { margin:0; max-width:720px; color:rgba(255,255,255,.86); font-size:18px; line-height:1.8; }
.sh-hero__actions { display:flex; flex-wrap:wrap; gap:14px; margin-top:30px; }
.sh-stat-row { display:grid; grid-template-columns:repeat(3,minmax(0,1fr)); gap:12px; margin-top:34px; max-width:720px; }
.sh-stat { padding:18px; border:1px solid rgba(255,255,255,.16); background:rgba(255,255,255,.1); border-radius:8px; }
.sh-stat b { display:block; font-size:34px; line-height:1; font-weight:900; }
.sh-stat span { display:block; margin-top:8px; color:rgba(255,255,255,.78); font-size:13px; font-weight:800; }
.sh-search-panel { background:#fff; color:var(--sh-ink); border-radius:8px; padding:26px; box-shadow:0 42px 90px rgba(10,30,69,.22); }
.sh-search-panel h2 { margin:0 0 8px; font-size:24px; line-height:1.25; color:var(--sh-dark); }
.sh-search-panel p { margin:0 0 20px; color:var(--sh-muted); font-size:14px; line-height:1.7; }
.sh-search-form { display:grid; grid-template-columns:minmax(0,1fr) auto; gap:10px; }
.sh-search-field { position:relative; min-width:0; }
.sh-search-form input { width:100%; height:50px; border:1px solid var(--sh-line); border-radius:8px; padding:0 16px; font-size:15px; outline:none; }
.sh-search-form input.has-clear { padding-right:46px; }
.sh-search-form input:focus { border-color:var(--sh-primary); box-shadow:0 0 0 4px rgba(21,53,111,.08); }
.sh-clear-search { position:absolute; top:50%; right:10px; display:none; align-items:center; justify-content:center; width:30px; height:30px; border:0; border-radius:50%; background:#EEF3FF; color:var(--sh-primary); font-size:22px; line-height:1; cursor:pointer; transform:translateY(-50%); }
.sh-clear-search.is-visible { display:flex; }
.sh-clear-search:hover { background:var(--sh-primary); color:#fff; }
.sh-hot { display:flex; flex-wrap:wrap; gap:8px; margin-top:16px; }
.sh-hot a { display:inline-flex; align-items:center; min-height:32px; padding:0 12px; border-radius:99px; background:var(--sh-soft); color:var(--sh-primary); font-size:13px; font-weight:900; }
.sh-hot-label { color:var(--sh-muted); font-size:12px; font-weight:900; line-height:32px; }
.sh-hot-wrap { position:relative; }
.sh-contact-mini { display:grid; grid-template-columns:1fr 1fr; gap:10px; margin-top:20px; }
.sh-contact-mini a { padding:14px; border-radius:8px; background:#F8F9FB; border:1px solid var(--sh-line); }
.sh-contact-mini span { display:block; color:var(--sh-muted); font-size:12px; font-weight:800; }
.sh-contact-mini b { display:block; margin-top:4px; color:var(--sh-accent); font-size:18px; }
.sh-section { padding:60px 0; }
.sh-section--white { background:#fff; }
.sh-section-head { display:flex; align-items:end; justify-content:space-between; gap:24px; margin-bottom:30px; }
.sh-section-head h2 { margin:6px 0 0; color:var(--sh-dark); font-size:clamp(28px,3.6vw,44px); line-height:1.12; font-weight:900; letter-spacing:0; }
.sh-section-head p { margin:10px 0 0; max-width:720px; color:var(--sh-muted); font-size:16px; line-height:1.75; }
.sh-chip { display:inline-flex; align-items:center; min-height:36px; padding:0 14px; border-radius:8px; border:1px solid var(--sh-line); background:#fff; color:#26364b; font-size:14px; font-weight:800; }
.sh-chip:hover, .sh-chip.is-active { border-color:var(--sh-primary); background:var(--sh-primary); color:#fff; }
.sh-layout { display:grid; grid-template-columns:minmax(0,1fr) 330px; gap:28px; align-items:start; }
.sh-table-card { overflow:hidden; border:1px solid var(--sh-line); border-radius:8px; background:#fff; box-shadow:0 18px 42px rgba(21,53,111,.08); }
.sh-table { width:100%; border-collapse:collapse; }
.sh-table th { background:var(--sh-dark); color:#fff; padding:15px 14px; text-align:left; font-size:13px; font-weight:900; }
.sh-table td { padding:15px 14px; border-bottom:1px solid var(--sh-line); color:#26364b; font-size:14px; line-height:1.58; vertical-align:top; }
.sh-table tr:hover td { background:#F8FAFF; }
.sh-table a { color:var(--sh-accent); font-weight:900; }
.sh-card-list { display:none; gap:12px; }
.sh-service-card { background:#fff; border:1px solid var(--sh-line); border-radius:8px; overflow:hidden; box-shadow:0 10px 24px rgba(21,53,111,.07); }
.sh-service-card__head { padding:16px; background:linear-gradient(180deg,#fff,#F7FAFF); border-bottom:1px solid var(--sh-line); }
.sh-service-card__tag { display:inline-flex; align-items:center; min-height:28px; padding:0 10px; border-radius:99px; background:var(--sh-soft); color:var(--sh-primary); font-size:12px; font-weight:900; }
.sh-service-card h3 { margin:10px 0 0; color:var(--sh-dark); font-size:18px; line-height:1.35; }
.sh-service-card__body { display:grid; gap:10px; padding:16px; color:#2d3b4f; font-size:14px; line-height:1.65; }
.sh-service-card__body b { color:var(--sh-muted); margin-right:8px; }
.sh-service-card__foot { display:grid; grid-template-columns:1fr 1fr; gap:10px; padding:0 16px 16px; }
.sh-side { display:grid; gap:16px; }
.sh-side-card { padding:24px; border-radius:8px; background:#fff; border:1px solid var(--sh-line); box-shadow:0 10px 26px rgba(21,53,111,.07); }
.sh-side-card--dark { background:linear-gradient(165deg,var(--sh-dark),var(--sh-primary)); color:#fff; border:0; position:relative; overflow:hidden; }
.sh-side-card--dark::after { content:"CARE"; position:absolute; right:-4px; bottom:-22px; font-size:84px; font-weight:900; color:rgba(255,255,255,.08); }
.sh-side-card h3 { position:relative; z-index:1; margin:0 0 14px; font-size:20px; color:inherit; }
.sh-side-card p { position:relative; z-index:1; margin:0 0 16px; color:inherit; opacity:.84; line-height:1.7; }
.sh-contact-list { display:grid; gap:10px; position:relative; z-index:1; }
.sh-contact-list a, .sh-contact-list div { padding:13px 14px; border-radius:8px; background:rgba(255,255,255,.12); border:1px solid rgba(255,255,255,.14); }
.sh-contact-list span { display:block; color:rgba(255,255,255,.74); font-size:12px; font-weight:800; }
.sh-contact-list b { display:block; margin-top:4px; font-size:19px; color:#fff; }
.sh-flow { display:grid; grid-template-columns:repeat(4,minmax(0,1fr)); gap:14px; }
.sh-flow-item { padding:24px; background:#fff; border:1px solid var(--sh-line); border-radius:8px; box-shadow:0 10px 26px rgba(21,53,111,.06); }
.sh-flow-item b { display:inline-flex; align-items:center; justify-content:center; width:38px; height:38px; border-radius:50%; background:var(--sh-primary); color:#fff; font-size:18px; }
.sh-flow-item h3 { margin:18px 0 8px; color:var(--sh-dark); font-size:18px; }
.sh-flow-item p { margin:0; color:var(--sh-muted); font-size:14px; line-height:1.7; }
.sh-faq { display:grid; grid-template-columns:repeat(2,minmax(0,1fr)); gap:14px; }
.sh-faq details { background:#fff; border:1px solid var(--sh-line); border-radius:8px; padding:20px 22px; }
.sh-faq summary { cursor:pointer; color:var(--sh-dark); font-size:16px; font-weight:900; }
.sh-faq p { margin:12px 0 0; color:var(--sh-muted); line-height:1.75; }
.sh-mobile-disclosure { display:block; }
.sh-mobile-summary { display:none; }
.sh-empty { padding:70px 20px; text-align:center; color:var(--sh-muted); background:#fff; border:1px solid var(--sh-line); border-radius:8px; }
.sh-backtop { position:fixed; right:18px; bottom:18px; z-index:800; display:none; width:48px; height:48px; border:0; border-radius:50%; background:var(--sh-dark); color:#fff; font-size:12px; font-weight:900; box-shadow:0 14px 34px rgba(10,30,69,.25); }
.sh-backtop.is-visible { display:block; }
@media (max-width: 1100px) {
  .sh-hero__inner { grid-template-columns:1fr; padding:56px 0 44px; }
  .sh-layout { grid-template-columns:1fr; }
  .sh-side { grid-template-columns:repeat(2,minmax(0,1fr)); }
  .sh-flow { grid-template-columns:repeat(2,minmax(0,1fr)); }
}
@media (max-width: 720px) {
  body { background:#F4F7FB; }
  .sh-wrap { width:calc(100% - 24px); }
  .sh-page { padding-top:69px; padding-bottom:96px; }
  .sh-hero { background:linear-gradient(155deg, rgba(10,30,69,.97), rgba(21,53,111,.9)), url('/assets/addons/ldcms/ldcms2026/images/banner_shfw.jpg') center/cover no-repeat; }
  .sh-hero::after { right:-26px; bottom:260px; font-size:82px; opacity:.7; }
  .sh-hero__inner { width:100%; max-width:100%; min-width:0; padding:20px 0 18px; gap:12px; overflow:hidden; }
  .sh-hero__inner > * { min-width:0; max-width:100%; }
  .sh-eyebrow { font-size:10px; letter-spacing:2.4px; }
  .sh-eyebrow::before { width:28px; height:2px; }
  .sh-hero h1 { width:100%; max-width:100%; margin:10px 0 8px; font-size:30px; line-height:1.12; white-space:normal; overflow-wrap:anywhere; }
  .sh-hero p { width:100%; max-width:100%; font-size:14px; line-height:1.68; white-space:normal; overflow-wrap:anywhere; }
  .sh-hero__actions { display:none; }
  .sh-stat-row { width:100%; max-width:100%; display:grid; grid-template-columns:repeat(3,minmax(0,1fr)); gap:7px; margin-top:12px; }
  .sh-stat { min-height:66px; padding:10px 8px; background:rgba(255,255,255,.12); }
  .sh-stat b { font-size:22px; }
  .sh-stat span { font-size:11px; line-height:1.35; }
  .sh-search-panel { width:100%; max-width:100%; min-width:0; padding:16px; border-radius:8px; box-shadow:0 22px 46px rgba(10,30,69,.2); overflow:hidden; }
  .sh-search-panel h2 { font-size:20px; }
  .sh-search-panel p { display:none; }
  .sh-search-form { display:grid; grid-template-columns:1fr; gap:9px; }
  .sh-search-form, .sh-search-field, .sh-search-form input, .sh-search-form .sh-btn { width:100%; max-width:100%; min-width:0; }
  .sh-search-form input { height:46px; font-size:15px; }
  .sh-search-form .sh-btn { min-height:44px; }
  .sh-hot { flex-wrap:wrap; gap:7px; margin-top:10px; }
  .sh-hot a { min-height:30px; padding:0 11px; }
  .sh-hot-label { line-height:30px; white-space:nowrap; }
  .sh-contact-mini { display:none; }
  .sh-contact-mini a { padding:11px 10px; }
  .sh-contact-mini b { font-size:15px; word-break:break-all; }
  .sh-section { padding:40px 0; }
  .sh-section-head { display:block; margin-bottom:18px; }
  .sh-section-head h2 { font-size:27px; }
  .sh-section-head p { font-size:14px; line-height:1.68; }
  #service-list .sh-section-head { margin-bottom:12px; }
  #service-list .sh-section-head h2 { font-size:25px; }
  #service-list .sh-section-head p { display:none; }
  .sh-chip { flex:0 0 auto; min-height:34px; padding:0 13px; border-radius:999px; font-size:13px; background:#F8FAFF; }
  #service-list { padding-top:28px; }
  .sh-table-card { display:none; }
  .sh-card-list { display:grid; gap:10px; }
  .sh-service-card { box-shadow:0 12px 28px rgba(21,53,111,.08); }
  .sh-service-card__head { padding:14px; background:#fff; }
  .sh-service-card__tag { min-height:26px; font-size:11px; }
  .sh-service-card h3 { margin-top:9px; font-size:17px; }
  .sh-service-card__body { padding:14px; gap:9px; font-size:13px; line-height:1.62; }
  .sh-service-card__body div { display:grid; grid-template-columns:42px minmax(0,1fr); gap:7px; }
  .sh-service-card__body b { margin:0; }
  .sh-service-card__foot { display:grid; grid-template-columns:1fr 1fr; gap:8px; padding:0 14px 14px; }
  .sh-service-card__foot .sh-btn { min-height:42px; padding:0 10px; font-size:13px; box-shadow:none; }
  .sh-card-list { padding-bottom:82px; }
  .sh-side { display:none; }
  .sh-side-card { padding:18px; }
  .sh-flow, .sh-faq { grid-template-columns:1fr; }
  .sh-mobile-fold { padding:18px 0; }
  .sh-mobile-fold .sh-section-head { display:none; }
  .sh-mobile-disclosure { border:1px solid var(--sh-line); border-radius:8px; background:#fff; overflow:hidden; box-shadow:0 10px 24px rgba(21,53,111,.06); }
  .sh-mobile-summary { display:flex; align-items:center; justify-content:space-between; min-height:48px; padding:0 16px; color:var(--sh-dark); font-size:16px; font-weight:900; list-style:none; cursor:pointer; }
  .sh-mobile-summary::-webkit-details-marker { display:none; }
  .sh-mobile-summary::after { content:"+"; color:var(--sh-accent); font-size:22px; line-height:1; }
  .sh-mobile-disclosure[open] .sh-mobile-summary::after { content:"-"; }
  .sh-mobile-disclosure__body { padding:0 14px 14px; }
  .sh-mobile-disclosure__body .sh-flow,
  .sh-mobile-disclosure__body .sh-faq { gap:10px; }
  .sh-flow-item { padding:18px; }
  .sh-faq details { padding:16px; }
  .embed-icon { display:none !important; }
  .sh-backtop { display:none !important; }
}
