:root {
  --bg: #f7fbff;
  --bg-soft: #eef5ff;
  --panel: rgba(255, 255, 255, 0.92);
  --panel-strong: #ffffff;
  --line: rgba(61, 155, 255, 0.3);
  --text: #10233f;
  --muted: #5f7392;
  --blue: #2f8cff;
  --blue-2: #6bb8ff;
  --red: #ff5c78;
  --purple: #9958d9;
  --shadow: 0 24px 60px rgba(27, 63, 124, 0.12);
  --radius: 24px;
  --max: 1440px;
}
* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: "Noto Sans TC", "Segoe UI", sans-serif;
  background:
    radial-gradient(circle at top left, rgba(61, 155, 255, 0.12), transparent 26%),
    radial-gradient(circle at 85% 10%, rgba(107, 184, 255, 0.12), transparent 20%),
    linear-gradient(180deg, #ffffff 0%, #f7fbff 100%);
  color: var(--text);
}
a { color: inherit; text-decoration: none; }
img { max-width: 100%; display: block; }
.container { width: min(calc(100% - 40px), var(--max)); margin: 0 auto; }
.section { padding: 92px 0; }
.kicker {
  display: inline-flex; align-items: center; gap: 10px;
  margin-bottom: 15px;
  padding: 8px 14px; border-radius: 999px; font-size: 14px; letter-spacing: .08em;
  text-transform: uppercase; background: #ffffff; border: none; box-shadow: 0 0 18px rgba(0, 0, 0, 0.2); color: #888888;
}
.kicker::before { content: ""; width: 8px; height: 8px; border-radius: 50%; background: #2f8cff; box-shadow: 0 0 12px rgba(47, 140, 255, .35); }
h1, h2, h3, h4 { margin: 0 0 14px; font-family: "Noto Sans TC", "Segoe UI", sans-serif; line-height: 1.1; color: inherit; letter-spacing: 0; }
h1 { font-size: clamp(38px, 6.8vw, 68px); letter-spacing: 0; }
h2 { font-size: clamp(32px, 4.4vw, 54px); letter-spacing: 0; }
h3 { font-size: clamp(22px, 2.3vw, 30px); }
p { color: inherit; line-height: 1.8; margin: 0 0 16px; }
.small { font-size: 15px; color: inherit; }
header.site-header {
  position: sticky; top: 0; z-index: 50;
  background: rgba(255, 255, 255, 0.82); backdrop-filter: blur(20px);
  border-bottom: 1px solid rgba(61, 155, 255, 0.12);
}
.nav-wrap { display: flex; align-items: center; justify-content: space-between; gap: 28px; min-height: 78px; }
.brand { display: flex; align-items: center; gap: 14px; }
.brand-image { gap: 0; }
.brand-logo-img { display:block; width: 200px; height: auto; object-fit: contain; }
.footer-logo { width: 220px; }
.brand-mark {
  display:none;
  width: 44px; height: 44px; border-radius: 14px; position: relative;
  background: linear-gradient(135deg, var(--blue), #153f8f);
  box-shadow: inset 0 0 24px rgba(255,255,255,.12), 0 12px 28px rgba(61,155,255,.35);
}
.brand-mark::after {
  content: ""; position: absolute; inset: 10px; border: 2px solid rgba(255,255,255,.8);
  border-radius: 999px 999px 12px 12px; border-bottom-color: transparent; transform: rotate(-15deg);
}
.brand-text strong { display:block; font-size: 18px; }
.brand-text span { display:block; font-size: 13px; color: inherit; letter-spacing: .08em; text-transform: uppercase; }
nav.main-nav { display: flex; flex-wrap: wrap; gap: 18px; align-items: center; }
nav.main-nav a { color: #24456f; font-size: 15px; position: relative; margin-inline: 5px; transition: color .22s ease, transform .22s ease; }
nav.main-nav a::after { content: ""; position: absolute; left: 0; bottom: -6px; width: 100%; height: 2px; background: linear-gradient(135deg, #2f8cff, #9958d9); transform: scaleX(0); transform-origin: center; transition: transform .22s ease; border-radius: 999px; }
nav.main-nav a:hover { color: #10233f; transform: translateY(-1px); }
nav.main-nav a:hover::after { transform: scaleX(1); }
.nav-actions { display:flex; align-items:center; gap:12px; }
.mobile-nav-toggle { display:none; width:48px; height:48px; border:none; border-radius:14px; background: rgba(255,255,255,.92); box-shadow: 0 10px 24px rgba(15,23,42,.08); align-items:center; justify-content:center; flex-direction:column; gap:5px; cursor:pointer; }
.mobile-nav-toggle span { width:20px; height:2px; border-radius:999px; background:#24456f; transition: transform .22s ease, opacity .22s ease; }
.mobile-nav-panel { display:none; }
.nav-cta, .btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 10px;
  padding: 14px 22px; border-radius: 999px; border: 1px solid transparent;
  font-weight: 400; transition: .25s ease; cursor: pointer;
}
.btn-primary, .nav-cta { position: relative; overflow: hidden; background: linear-gradient(135deg, #FF2828, #0b75f7); color: #ffffff; box-shadow: 0 14px 30px rgba(43, 92, 201, .20); }
.btn-primary::after, .nav-cta::after { content: ""; position: absolute; top: -20%; left: -120%; width: 55%; height: 140%; background: linear-gradient(90deg, rgba(255,255,255,0), rgba(255,255,255,.34), rgba(255,255,255,0)); transform: rotate(18deg); animation: ctaShine 5.2s ease-in-out infinite; pointer-events: none; }
.btn-primary:hover, .nav-cta:hover { background: linear-gradient(135deg, #0b75f7, #FF2828); transform: translateY(-2px); }
@keyframes ctaShine {
  0% { left: -120%; opacity: 0; }
  12% { opacity: 1; }
  32% { left: 135%; opacity: 0; }
  100% { left: 135%; opacity: 0; }
}
.btn-secondary { border-color: rgba(16, 35, 63, .08); background: linear-gradient(135deg, #e1e1e1 0%, #e1e1e1 14%, #ffffff 100%); color: #1f2d3d; box-shadow: 0 6px 18px rgba(15, 23, 42, .05); backdrop-filter: blur(14px); }
.btn-secondary:hover { background: linear-gradient(135deg, #e1e1e1 0%, #efefef 12%, #ffffff 100%); box-shadow: 0 10px 24px rgba(15, 23, 42, .08); border-color: rgba(16, 35, 63, .12); }
.hero .btn-secondary { background: linear-gradient(135deg, #e1e1e1 0%, #f3f3f3 12%, #ffffff 100%); }
.nav-contact { padding-inline: 18px; }
.btn:hover { transform: translateY(-2px); }
.hero { padding: 74px 0 52px; }
.hero-grid, .two-col { display: grid; grid-template-columns: 1.08fr .92fr; gap: 38px; align-items: center; }
.hero-copy p { font-size: 18px; max-width: 700px; }
.hero-actions { display:flex; gap:14px; flex-wrap: wrap; margin-top: 28px; }
.hero-card, .glass, .card {
  background: var(--panel); border: 1px solid var(--line); border-radius: var(--radius); box-shadow: var(--shadow);
}
.hero-card { padding: 26px; position: relative; overflow: hidden; background: linear-gradient(180deg, rgba(255,255,255,.98), rgba(240,247,255,.96)); }
.hero-card::before {
  content:""; position:absolute; inset:0; background: linear-gradient(135deg, rgba(47,140,255,.18), transparent 42%, rgba(107,184,255,.14)); pointer-events:none;
}
.dashboard {
  display:grid; grid-template-columns: 1fr; gap:18px; min-height: 420px;
}
.dashboard-panel { padding: 20px; border-radius: 22px; background: rgba(255,255,255,.72); border:1px solid rgba(61,155,255,.14); }
.dashboard-panel.metrics-stack { display:grid; grid-template-columns: repeat(3, 1fr); gap:16px; }
.dashboard-panel.metrics-stack .stat { margin:0; }
.dashboard-preview-panel { border-radius: 22px; overflow: hidden; border: 1px solid rgba(61,155,255,.14); background: rgba(255,255,255,.92); box-shadow: 0 14px 30px rgba(27,63,124,.08); }
.dashboard-preview-image { display:block; width:100%; height:auto; }
.metric-grid, .grid-4, .grid-3, .grid-2, .industry-grid, .news-grid, .faq-grid { display:grid; gap:20px; }
.metric-grid { grid-template-columns: repeat(2, 1fr); }
.grid-4 { grid-template-columns: repeat(4, 1fr); }
.grid-3 { grid-template-columns: repeat(3, 1fr); }
.grid-2 { grid-template-columns: repeat(2, 1fr); }
.industry-grid { grid-template-columns: repeat(4, 1fr); }
.news-grid { grid-template-columns: repeat(3, 1fr); }
.news-grid > * { min-width: 0; }
.news-card { min-width: 0; overflow: hidden; }
.news-meta { min-width: 0; flex-wrap: wrap; }
.news-meta .eyebrow, .news-date { min-width: 0; }
.news-thumb { width: 100%; aspect-ratio: 16 / 9; height: auto; border-radius: 16px; margin-bottom: 16px; border: 1px solid var(--line); overflow: hidden; }
.news-thumb img { width: 100%; height: 100%; object-fit: cover; display: block; }
.news-thumb-blue { background: linear-gradient(135deg, rgba(47,140,255,.20), rgba(11,117,247,.65)), radial-gradient(circle at 20% 20%, rgba(255,255,255,.45), transparent 30%); }
.news-thumb-purple { background: linear-gradient(135deg, rgba(153,88,217,.22), rgba(88,61,196,.68)), radial-gradient(circle at 20% 20%, rgba(255,255,255,.42), transparent 30%); }
.news-thumb-red { background: linear-gradient(135deg, rgba(255,40,40,.18), rgba(255,120,120,.60)), radial-gradient(circle at 20% 20%, rgba(255,255,255,.42), transparent 30%); }
.news-date { font-size: 15px; color: inherit; margin: 0 0 10px; opacity: .72; }
.news-meta { display:flex; align-items:center; justify-content:space-between; gap:12px; margin-bottom: 10px; }
.news-meta .eyebrow, .news-date { display:inline-flex; align-items:center; gap:6px; }
.meta-icon { display:inline-flex; align-items:center; justify-content:center; }
.meta-icon svg { width: 15px; height: 15px; stroke: currentColor; fill: none; stroke-width: 1.8; stroke-linecap: round; stroke-linejoin: round; }
.news-meta .eyebrow { margin-bottom: 0; }
.news-card h3 { white-space: nowrap; overflow: hidden; text-overflow: ellipsis; min-width: 0; }
.faq-grid { grid-template-columns: repeat(2, 1fr); }
.stat, .feature, .industry, .news-card, .step, .compare, .partner, .pricing, .contact-card {
  padding: 24px; border-radius: 22px; background: rgba(255,255,255,.86); border: 1px solid var(--line);
  transition: transform .24s ease, box-shadow .24s ease, border-color .24s ease, background .24s ease;
}
.stat:hover, .feature:hover, .industry:hover, .news-card:hover, .compare:hover, .partner:hover, .pricing:hover, .contact-card:hover {
  transform: translateY(-6px);
  box-shadow: 0 20px 42px rgba(27, 63, 124, 0.14);
  border-color: rgba(61, 155, 255, 0.42);
  background: rgba(255,255,255,.96);
}
.stat.glass { min-height: 150px; display:flex; flex-direction:column; align-items:center; justify-content:center; text-align:center; }
.stat strong { display:block; font-size: 34px; margin-bottom: 8px; color: var(--text); }
.feature-icon, .industry-icon, .step-no {
  width: 54px; height: 54px; border-radius: 999px; display:grid; place-items:center; margin-bottom: 18px;
  background: linear-gradient(135deg, rgba(43,126,235,.42), rgba(18,73,156,.78)); border: 1px solid rgba(255,255,255,.12);
  font-weight: 800; color: white;
}
.feature > .feature-icon, .industry > .industry-icon { margin-right: 15px; margin-bottom: 0; flex-shrink: 0; }
.feature, .industry { display: flex; align-items: flex-start; flex-wrap: wrap; }
.feature h3, .industry h3 { margin-top: 10px; flex: 1 1 calc(100% - 69px); }
.feature p, .industry p { width: 100%; margin-top: 0; }
.feature-icon svg, .industry-icon svg, .step-no svg { width: 35px; height: 35px; stroke: currentColor; fill: none; stroke-width: 1.8; stroke-linecap: round; stroke-linejoin: round; }
.eyebrow { color: inherit; font-size: 15px; letter-spacing: .1em; text-transform: uppercase; margin-bottom: 10px; }
.section-head { display:flex; justify-content:space-between; align-items:end; gap:24px; margin-bottom: 30px; }
.section-head p { max-width: 720px; }
.section-head-vertical { display:grid; justify-items:start; align-items:start; }
.section-head-vertical p { margin-top: 6px; max-width: 920px; }
.pulse-line {
  height: 120px; width: 100%; border-radius: 18px; overflow: hidden; position: relative;
  background: linear-gradient(180deg, rgba(242,247,255,.95), rgba(248,251,255,.98));
}
.pulse-line::before {
  content:""; position:absolute; left:0; right:0; top:50%; height:1.5px; background: rgba(47,140,255,.14); transform: translateY(-50%);
}
.pulse-line svg { position:absolute; inset:0; width:100%; height:100%; }
.pulse-line path { stroke: #2f8cff; stroke-width: 2.8; filter: none; stroke-dasharray: 860; stroke-dashoffset: 860; animation: pulseDraw 4.2s linear infinite; }
@keyframes pulseDraw {
  0% { stroke-dashoffset: 860; opacity: .9; }
  100% { stroke-dashoffset: 0; opacity: .9; }
}
.flow { display:grid; grid-template-columns: repeat(4, 1fr); gap:18px; }
.step { position: relative; }
.step::after { content:""; position:absolute; top:50%; right:-14px; width:10px; height:10px; border-top:2px solid var(--line); border-right:2px solid var(--line); transform:translateY(-50%) rotate(45deg); }
.step:last-child::after { display:none; }
.step-head { display:flex; align-items:center; gap:14px; margin-bottom: 12px; }
.step-head h3 { margin: 0; font-size: 22px; }
.step-no { margin-bottom: 0; flex-shrink: 0; }
.step p { margin-top: 0; }
.compare-list { display:grid; gap:16px; }
.compare { display:flex; gap:16px; align-items:flex-start; border: none; background: #f3f3f3; }
.compare-badge { min-width: 40px; height:40px; border-radius: 50%; display:grid; place-items:center; background: var(--purple); color: #ffffff; font-weight: 800; }
.partner-row { display:grid; grid-template-columns: repeat(3, 1fr); gap:20px; }
.partner { min-height: 140px; display:flex; flex-direction:column; justify-content:space-between; }
.partner strong { font-size: 24px; }
.cta-section {
  background: linear-gradient(135deg, rgba(239,239,239,.9), rgba(232,240,250,.95) 52%, rgba(243,243,243,.92));
}
.cta-band {
  padding: 40px; border-radius: 32px; border: none;
  background: transparent;
  display:flex; justify-content:space-between; gap:20px; align-items:center;
  box-shadow: none;
}
footer { padding: 42px 0 56px; border-top: 1px solid rgba(74, 92, 170, .18); margin-top: 0; background: #b8bccf; color: #24304f; }
.footer-grid { display:grid; grid-template-columns: 1.2fr .8fr .8fr; gap:24px; }
.footer-grid h3, footer .brand-text strong, footer a, footer .brand-text span, footer p, footer .small, footer li { color: #24304f; }
.list { display:grid; gap:12px; padding:0; list-style:none; margin:0; }
.hero-metrics { display:grid; grid-template-columns: repeat(3, 1fr); gap:14px; margin-top: 22px; }
.hero-metric-card { position: relative; display:flex; flex-direction:column; align-items:center; text-align:center; gap:14px; min-height: 210px; padding: 22px 18px 52px; border-radius: 20px; background: rgba(255,255,255,.92); border:1px solid var(--line); box-shadow: 0 14px 32px rgba(27, 63, 124, 0.08); }
.hero-metric-icon { width:44px; height:44px; border-radius:999px; display:grid; place-items:center; background: transparent; color: #2454a6; }
.hero-metric-icon svg { width:40px; height:40px; stroke: currentColor; fill: none; stroke-width: 1.8; stroke-linecap: round; stroke-linejoin: round; }
.hero-metric-copy { display:grid; gap:6px; justify-items:center; }
.hero-metric-copy strong { font-size: 16px; color: var(--text); font-weight: 600; }
.hero-metric-copy span { font-size: 14px; color: inherit; }
.hero-metric-value { position:absolute; right:16px; bottom:16px; display:inline-flex; align-items:center; justify-content:center; min-height: 28px; padding: 6px 10px; border-radius: 999px; background: #e1e1e1; border: 1px solid rgba(16, 35, 63, .06); box-shadow: 0 8px 18px rgba(15, 23, 42, .06); font-size: 13px; color: inherit; }
.page-hero { padding: 88px 0 38px; }
.page-hero .container { max-width: 980px; }
.timeline { display:grid; gap:18px; }
.timeline .item { padding:22px 24px; border-left: 3px solid var(--blue); background: rgba(255,255,255,.03); border-radius: 0 20px 20px 0; }
.table-like { display:grid; gap:14px; }
.table-row { display:grid; grid-template-columns: 1fr 1fr; gap:16px; }
.form-grid { display:grid; grid-template-columns: repeat(2,1fr); gap:16px; }
.form-grid .full { grid-column: 1 / -1; }
input, textarea, select {
  width:100%; background: rgba(255,255,255,.96); color: var(--text); border:1px solid var(--line);
  border-radius: 16px; padding: 15px 16px; font: inherit;
}
textarea { min-height: 160px; resize: vertical; }
.notice { padding: 16px 18px; border-radius: 16px; border:1px solid rgba(255,255,255,.1); background: rgba(95,242,191,.08); color: inherit; }

@media (max-width: 1100px) {
  .dashboard-panel.metrics-stack { grid-template-columns: 1fr; }
}
@media (max-width: 1100px) {
  .dashboard-panel.metrics-stack { grid-template-columns: 1fr; }
  .grid-4, .industry-grid, .partner-row, .flow { grid-template-columns: repeat(2, 1fr); }
  .grid-3, .news-grid, .footer-grid, .hero-grid, .two-col { grid-template-columns: 1fr; }
}
@media (max-width: 991px) {
  .site-header { position: sticky; }
  nav.main-nav { display:none; }
  .nav-wrap { display:grid; grid-template-columns: auto 1fr auto; align-items:center; column-gap:10px; min-height: 78px; }
  .brand { grid-column: 1; }
  .brand-logo-img { width: 168px; }
  .nav-actions { display:flex; grid-column: 2; justify-content:flex-end; gap:8px; width:100%; min-width:0; }
  .nav-actions .btn, .nav-actions .nav-cta { padding: 11px 14px; font-size: 14px; white-space: nowrap; }
  .mobile-nav-toggle { display:flex; grid-column: 3; }
  .mobile-nav-panel { display:none; position:absolute; left:20px; right:20px; top: calc(100% + 10px); width:auto; padding:18px; border-radius:22px; background: rgba(255,255,255,.98); border:1px solid var(--line); box-shadow: 0 18px 40px rgba(15,23,42,.08); z-index: 60; }
  .site-header.mobile-open .mobile-nav-panel { display:grid; gap:14px; }
  .mobile-nav-panel a { font-size: 15px; color: #24456f; }
  .mobile-nav-toggle[aria-expanded="true"] span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
  .mobile-nav-toggle[aria-expanded="true"] span:nth-child(2) { opacity: 0; }
  .mobile-nav-toggle[aria-expanded="true"] span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }
}
@media (max-width: 780px) {
  .metric-grid, .grid-2, .industry-grid, .faq-grid, .form-grid, .table-row, .flow, .partner-row, .hero-metrics { grid-template-columns: 1fr; }
  .dashboard { grid-template-columns: 1fr; }
  .cta-band, .section-head { flex-direction: column; align-items: start; }
  .section { padding: 70px 0; }
  .hero { padding-top: 48px; }
  .nav-wrap { grid-template-columns: auto 1fr auto; align-items: center; column-gap: 8px; }
  .brand { grid-column: 1; }
  .brand-logo-img { width: 138px; }
  .nav-actions { grid-column: 2; justify-content: flex-end; flex-wrap: nowrap; gap: 6px; }
  .nav-actions .btn, .nav-actions .nav-cta { padding: 10px 12px; font-size: 13px; }
  .mobile-nav-toggle { grid-column: 3; grid-row: auto; align-self: center; justify-self: end; }
  .mobile-nav-panel { left: 12px; right: 12px; top: calc(100% + 8px); }
}
@media (max-width: 375px) {
  .brand-logo-img { width: 138px; }
  .nav-actions { gap: 4px; }
  .nav-actions .nav-contact { display: none; }
  .nav-actions .nav-cta { padding: 9px 10px; font-size: 13px; }
  .mobile-nav-toggle { width: 44px; height: 44px; }
}

@media (max-width: 480px) {
  .grid-4 { grid-template-columns: 1fr; }
}

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

.news-card h3 a { display:block; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.news-card h3 a:hover { opacity: .82; }

.news-card p { display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }

.contact-side { display:grid; gap:20px; }
.map-embed { border-radius: 24px; overflow:hidden; border:1px solid var(--line); background:#fff; box-shadow: var(--shadow); min-height: 320px; }
.map-embed iframe { width:100%; height:100%; min-height: 320px; border:0; display:block; }
.contact-card { display:grid; gap:12px; }
.contact-icon { width:54px; height:54px; border-radius:999px; display:grid; place-items:center; background: linear-gradient(135deg, rgba(43,126,235,.42), rgba(18,73,156,.78)); color:#fff; }
.contact-icon svg { width:24px; height:24px; stroke: currentColor; fill: none; stroke-width: 1.8; stroke-linecap: round; stroke-linejoin: round; }

.contact-head { display:flex; align-items:center; gap:12px; }
.contact-head h3 { margin: 0; }

.page-hero-image-wrap { border-radius: 28px; overflow: hidden; border: 1px solid var(--line); background: rgba(255,255,255,.92); box-shadow: var(--shadow); }
.page-hero-image { display:block; width:100%; height:auto; }

.milestone-timeline { position: relative; gap: 22px; }
.milestone-timeline::before { content: ""; position: absolute; left: 12px; top: 8px; bottom: 8px; width: 2px; background: linear-gradient(180deg, rgba(11,117,247,.24), rgba(153,88,217,.24)); }
.milestone-timeline .item { position: relative; display: grid; grid-template-columns: 36px 1fr; gap: 18px; align-items: start; padding: 0; border-left: none; background: transparent; border-radius: 0; }
.timeline-dot { width: 25px; height: 25px; border-radius: 999px; background: linear-gradient(135deg, #FF2828, #0b75f7); box-shadow: 0 10px 24px rgba(43,92,201,.18); position: relative; z-index: 1; }
.timeline-content { padding: 22px 24px; border-radius: 22px; background: rgba(255,255,255,.92); border: 1px solid var(--line); box-shadow: 0 14px 30px rgba(27,63,124,.08); }
.timeline-label { font-size: 13px; margin-bottom: 10px; color: rgba(16,35,63,.56); letter-spacing: .08em; text-transform: uppercase; }

.industry-scene { align-items: flex-start; }
.industry-scene-image { width: 100%; height: 190px; margin-bottom: 18px; border-radius: 18px; overflow: hidden; border: 1px solid var(--line); }
.industry-scene-image img { width: 100%; height: 100%; object-fit: cover; display: block; }
.industry-scene .industry-icon { margin-top: 0; }

.industry-scene h3 { flex: 1 1 100%; margin-top: 0; }

@media (max-width: 991px) {
  .news-thumb { height: auto; aspect-ratio: 4 / 3; }
}
