:root { --text-xs:clamp(.75rem,.7rem + .25vw,.875rem); --text-sm:clamp(.875rem,.8rem + .35vw,1rem); --text-base:clamp(1rem,.95rem + .25vw,1.125rem); --text-lg:clamp(1.125rem,1rem + .75vw,1.5rem); --text-xl:clamp(1.5rem,1.2rem + 1.25vw,2.25rem); --text-2xl:clamp(2rem,1.2rem + 2.5vw,3.5rem); --transition: 200ms cubic-bezier(.16, 1, .3, 1); --content-default: 1160px; --font-display:'Cabinet Grotesk', 'Helvetica Neue', sans-serif; --font-body:'Satoshi', 'Helvetica Neue', sans-serif; }
:root, [data-theme="light"] { --color-bg:#fff; --color-surface:#f8f9fa; --color-surface-2:#f1f3f5; --color-border:#e5e7eb; --color-divider:#eaedf0; --color-text:#0d0f14; --color-text-muted:#5a6070; --color-text-faint:#9aa0ad; --color-text-inverse:#fff; --color-primary:#0a0d14; --color-primary-hover:#1e2535; --color-accent:#00cfff; --shadow-card:0 1px 3px rgba(8,9,12,.06), 0 4px 16px rgba(8,9,12,.06); --shadow-card-hover:0 4px 20px rgba(8,9,12,.12), 0 2px 8px rgba(8,9,12,.08); }
[data-theme="dark"],
@media (prefers-color-scheme: dark) { :root:not([data-theme]) {
--color-bg:#0d0f14;
--color-surface:#13151c;
--color-surface-2:#1a1d26;
--color-border:#1e2130;
--color-divider:#181b24;
--color-text:#e8eaf0;
--color-text-muted:#8890a0;
--color-text-faint:#4a5060;
--color-text-inverse:#0d0f14;
--color-primary:#fff;
--color-primary-hover:#e8eaf0;
--color-accent:#00cfff;
--shadow-card:0 1px 3px rgba(0,0,0,.2), 0 4px 16px rgba(0,0,0,.2);
--shadow-card-hover:0 4px 20px rgba(0,0,0,.35), 0 2px 8px rgba(0,0,0,.2);
}}[data-theme="dark"] {
--color-bg:#0d0f14;
--color-surface:#13151c;
--color-surface-2:#1a1d26;
--color-border:#1e2130;
--color-divider:#181b24;
--color-text:#e8eaf0;
--color-text-muted:#8890a0;
--color-text-faint:#4a5060;
--color-text-inverse:#0d0f14;
--color-primary:#fff;
--color-primary-hover:#e8eaf0;
--color-accent:#00cfff;
--shadow-card:0 1px 3px rgba(0,0,0,.2), 0 4px 16px rgba(0,0,0,.2);
--shadow-card-hover:0 4px 20px rgba(0,0,0,.35), 0 2px 8px rgba(0,0,0,.2);
}
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; text-rendering: optimizeLegibility; scroll-padding-top: 80px; }
body { font-family: var(--font-body); font-size: var(--text-base); color: var(--color-text); background: var(--color-bg); line-height: 1.65; min-height: 100dvh; transition: background var(--transition), color var(--transition); }
img, svg { display: block; max-width: 100%; }
a { color: inherit; text-decoration: none; }
ul[role="list"], ol[role="list"] { list-style: none; }
input, button, textarea, select { font: inherit; color: inherit; }
h1,h2,h3,h4,h5,h6 { text-wrap: balance; }
p, li { text-wrap: pretty; }
:focus-visible { outline: 2px solid var(--color-accent); outline-offset: 3px; border-radius: .375rem;}
@media (prefers-reduced-motion: reduce) {
*, *::before, *::after { animation-duration: .01ms !important; transition-duration: .01ms !important;}
}
.container { max-width: var(--content-default); margin-inline: auto; padding-inline: clamp(1.5rem, 5vw, 3rem);}
.section { padding-block: clamp(4rem, 8vw, 6rem);}
.btn { display: inline-flex; align-items: center; gap: .5rem; padding: .6em 1.4em; font-family: var(--font-body); font-size: var(--text-sm); font-weight: 600; border-radius: .5rem; cursor: pointer; border: none; transition: all var(--transition); white-space: nowrap; letter-spacing: .01em; }
.btn-primary { background: #08090c; color: #fff;}
.btn-primary:hover { background: #1a1d26; transform: translateY(-1px); box-shadow: 0 4px 16px rgba(8,9,12,.08),0 2px 6px rgba(8,9,12,.05); }
[data-theme="dark"] .btn-primary { background: #00cfff; color: #08090c;}
[data-theme="dark"] .btn-primary:hover { background: #33d8ff; }
[data-theme="dark"] .nav-logo-mark,
[data-theme="dark"] .footer-logo-mark,
[data-theme="dark"] .about-ha-mark-img { filter: brightness(0) invert(1);}
.btn-outline { background: transparent; color: var(--color-text); border: 1.5px solid var(--color-border);}
.btn-outline:hover { border-color: var(--color-text); background: var(--color-surface); transform: translateY(-1px); }
.btn-lg { padding: .75em 1.8em; font-size: var(--text-base); }
.btn-sm { padding: .4em 1em; font-size: var(--text-xs); }
.section-label { font-family: var(--font-body); font-size: var(--text-xs); font-weight: 600; letter-spacing: .12em; text-transform: uppercase; color: var(--color-accent); margin-bottom: .75rem; }
.section-label--light { color: rgba(255,255,255,.6);}
.section-header { display: flex; flex-direction: column; margin-bottom: 2.5rem;}
.section-title { font-family: var(--font-display); font-size: var(--text-2xl); font-weight: 800; line-height: 1.1; color: var(--color-text); margin-bottom: 1rem; }
.section-link { font-size: var(--text-sm); font-weight: 600; color: var(--color-text-muted); align-self: flex-start; margin-top: .5rem; transition: color var(--transition); }
.section-link:hover { color: var(--color-accent); }
.site-header { position: sticky; top: 0; z-index: 100; background: var(--color-bg); border-bottom: 1px solid var(--color-divider); transition: background var(--transition), box-shadow var(--transition); }
.site-header.scrolled { box-shadow: 0 1px 3px rgba(8,9,12,.06),0 1px 2px rgba(8,9,12,.04);}
.nav-inner { display: flex; align-items: center; justify-content: space-between; gap: 2rem; max-width: var(--content-default); margin-inline: auto; padding-inline: clamp(1.5rem, 5vw, 3rem); height: 84px; }
.nav-logo { display: flex; align-items: center; gap: .75rem; flex-shrink: 0; }
.nav-logo-mark { display: block; height: 66px; width: auto; object-fit: contain; flex-shrink: 0; }
.nav-logo-text { display: flex; flex-direction: column; gap: 2px; line-height: 1; }
.nav-logo-brand { font-family: var(--font-display); font-size: 1.1rem; font-weight: 800; letter-spacing: .08em; color: var(--color-text); white-space: nowrap; }
.nav-logo-tagline { font-family: var(--font-body); font-size: .7rem; font-weight: 500; letter-spacing: .04em; color: var(--color-accent); white-space: nowrap; }
.footer-logo-mark { display: block; height: 52px; width: auto; object-fit: contain; flex-shrink: 0; }
.footer-logo-text { display: flex; flex-direction: column; gap: 2px; line-height: 1; }
.footer-logo-brand { font-family: var(--font-display); font-size: var(--text-base); font-weight: 800; letter-spacing: .08em; color: var(--color-text); white-space: nowrap; }
.footer-logo-tagline { font-family: var(--font-body); font-size: .62rem; font-weight: 500; letter-spacing: .04em; color: var(--color-accent); white-space: nowrap; }
.nav-links { display: flex; align-items: center; gap: 2rem; list-style: none; }
.nav-link { font-size: var(--text-sm); font-weight: 500; color: var(--color-text-muted); transition: color var(--transition); position: relative; }
.nav-link:hover { color: var(--color-text); }
.nav-link--active { color: var(--color-text); font-weight: 600; }
.nav-link::after { content: ''; position: absolute; bottom: -4px; left: 0; right: 0; height: 2px; background: var(--color-accent); transform: scaleX(0); transition: transform var(--transition); }
.nav-link:hover::after { transform: scaleX(1); }
.nav-actions { display: flex; align-items: center; gap: .75rem;}
.theme-toggle { width: 36px; height: 36px; display: flex; align-items: center; justify-content: center; border-radius: .5rem; background: transparent; border: 1.5px solid var(--color-border); color: var(--color-text-muted); cursor: pointer; transition: all var(--transition); }
.theme-toggle:hover { border-color: var(--color-text); color: var(--color-text); }
.mobile-menu-btn { display: none; width: 36px; height: 36px; align-items: center; justify-content: center; border-radius: .5rem; background: transparent; border: 1.5px solid var(--color-border); color: var(--color-text-muted); cursor: pointer; transition: all var(--transition); }
.mobile-menu-btn:hover { border-color: var(--color-text); color: var(--color-text); }
.mobile-menu { display: none; border-top: 1px solid var(--color-divider); background: var(--color-bg);}
.mobile-menu.open { display: block; }
.mobile-menu ul { padding: 1rem clamp(1.5rem, 5vw, 3rem); display: flex; flex-direction: column; gap: .25rem; list-style: none; }
.mobile-link { display: block; padding: .75rem 0; font-size: var(--text-base); font-weight: 500; color: var(--color-text-muted); border-bottom: 1px solid var(--color-divider); transition: color var(--transition); }
.mobile-link:hover { color: var(--color-text); }
.mobile-cta { color: var(--color-accent) !important; font-weight: 700; border-bottom: none; }
@media (max-width: 768px) {
.nav-links { display: none; }
.mobile-menu-btn { display: flex; }
.nav-actions .btn-primary { display: none; }
}
.hero { position: relative; overflow: hidden; display: grid; gap: 3rem; align-items: flex-start; max-width: var(--content-default); margin-inline: auto; padding-inline: clamp(1.5rem, 5vw, 3rem); grid-template-columns: 520px 1fr; padding-top: calc(84px + 2rem); padding-bottom: 2.5rem; }
.hero-inner { position: relative; z-index: 2; overflow: visible; max-width: 520px; }
.hero-eyebrow { display: inline-flex; align-items: center; gap: .5rem; font-size: var(--text-xs); font-weight: 600; letter-spacing: .12em; text-transform: uppercase; color: var(--color-accent); margin-bottom: 1.5rem; }
.eyebrow-dot { width: 8px; height: 8px; border-radius: 50%; background: var(--color-accent); animation: pulse-dot 2s ease-in-out infinite; }
@keyframes pulse-dot {
0%, 100% { opacity: 1; transform: scale(1); }
50% { opacity: .5; transform: scale(.8); }
}
.hero-headline { font-family: var(--font-display); font-size: clamp(2rem, 3.8vw, 3.4rem); font-weight: 900; line-height: 1.08; letter-spacing: -.02em; color: var(--color-text); margin-bottom: 1rem; }
.headline-accent { color: var(--color-accent); background: linear-gradient(135deg, #00cfff, #0080cc); -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text; }
.hero-subtext { font-size: .95rem; font-weight: 400; color: var(--color-text-muted); max-width: 44ch; line-height: 1.6; margin-bottom: 1.25rem; }
.hero-cta-row { display: flex; flex-wrap: wrap; gap: .75rem; margin-bottom: 1.25rem; }
.hero-stats { display: flex; flex-wrap: nowrap; gap: 0; padding-top: 1.25rem; border-top: 1px solid var(--color-divider); width: 100%; max-width: 480px; }
.stat-item { display: flex; flex-direction: column; gap: .25rem; padding-right: 1.25rem; flex-shrink: 0; }
.stat-num { font-family: var(--font-display); font-size: 1.25rem; font-weight: 800; color: var(--color-text); line-height: 1; }
.stat-label { font-size: .72rem; font-weight: 500; color: var(--color-text-muted); max-width: 14ch; line-height: 1.25; }
.stat-item:last-child .stat-label,
.stat-item:nth-child(7) .stat-label { max-width: 10ch;}
.stat-divider { width: 1px; background: var(--color-divider); margin-right: 2rem; align-self: stretch; }
.hero-visual { position: relative; display: flex; align-items: stretch; justify-content: center; min-height: 420px; padding: 0; }
.hero-bg-grid { position: absolute; inset: 0; background-image: linear-gradient(rgba(0,207,255,.04) 1px, transparent 1px), linear-gradient(90deg, rgba(0,207,255,.04) 1px, transparent 1px); background-size: 40px 40px; border-radius: 1.5rem; }
.hero-robot-silhouette { position: relative; z-index: 1; width: 260px; opacity: .9; }
.robot-svg { width: 100%; height: auto; color: var(--color-text);}
.hero-img-mosaic { position: relative; width: 100%; height: 100%; min-height: 420px; display: grid; grid-template-columns: 1fr; grid-template-rows: 1fr; gap: .75rem; border-radius: 20px; overflow: hidden; }
.hero-img-main { grid-column: 1 / -1; grid-row: 1 / -1; position: relative; min-height: 420px; border-radius: 16px; overflow: hidden; }
.hero-img-main img { width: 100%; height: 100%; object-fit: cover; object-position: center 35%; display: block; }
.hero-img-overlay { position: absolute; inset: 0; background: linear-gradient( to bottom, transparent 40%, rgba(8,9,12,.6) 100% ); }
.hero-img-portrait { position: relative; border-radius: 14px; overflow: hidden; background: #0d1117; }
.hero-img-portrait img { width: 100%; height: 100%; object-fit: cover; object-position: center top; display: block; transition: transform .4s ease; }
.hero-img-portrait:hover img { transform: scale(1.04);}
.hero-img-caption { position: absolute; bottom: 0; left: 0; right: 0; padding: .6rem .9rem; background: linear-gradient(transparent, rgba(0,0,0,.75)); font-size: .72rem; font-weight: 600; color: rgba(255,255,255,.85); letter-spacing: .04em; }
@media (max-width: 1100px) {
.hero { grid-template-columns: 1fr 1fr;}
}
@media (max-width: 900px) {
.hero { grid-template-columns: 1fr; min-height: unset;}
.hero-visual { min-height: 280px; display: flex;}
.hero-img-mosaic { min-height: 280px; grid-template-rows: 200px 1fr;}
.hero-headline { font-size: clamp(2.5rem, 8vw, 4rem);}
}
@media (max-width: 600px) {
.hero-headline { font-size: clamp(1.8rem, 8vw, 2.5rem);}
.hero-stats { flex-wrap: wrap;}
}
@media (max-width: 500px) {
.hero-stats {
display: grid;
grid-template-columns: 1fr 1fr;
gap: .75rem;
padding: 1rem;
max-width: none;
flex-wrap: wrap;
}
.stat-divider { display: none; }
.stat-item { padding: 0; }
}
.partners-strip { border-top: 1px solid var(--color-border); border-bottom: 1px solid var(--color-border); padding: 1.25rem clamp(1rem, 5vw, 3rem); background: var(--color-surface); }
.partners-inner { max-width: var(--content-default); margin-inline: auto; display: flex; align-items: center; gap: 2rem; overflow-x: auto; -webkit-overflow-scrolling: touch; scrollbar-width: none; }
.partners-inner::-webkit-scrollbar { display: none; }
.partners-label { font-size: .68rem; font-weight: 700; letter-spacing: .12em; text-transform: uppercase; color: var(--color-text-muted); white-space: nowrap; flex-shrink: 0; }
.partners-logos { display: flex; align-items: center; gap: .25rem; flex-wrap: nowrap; }
.partner-logo { text-decoration: none; flex-shrink: 0;}
.plogo { display: flex; align-items: center; justify-content: center; padding: .55rem 1rem; border-radius: 8px; font-family: var(--font-display); font-size: .78rem; font-weight: 800; letter-spacing: .04em; line-height: 1.15; text-align: center; border: 1px solid transparent; transition: all .18s ease; white-space: nowrap; color: #fff; }
.plogo small { font-size: .62rem; font-weight: 600; display: block; letter-spacing: .05em; opacity: .8; }
.partner-logo:hover .plogo { transform: translateY(-2px); opacity: 1;}
.plogo--agibot   { background: #0d1a2e; border-color: #00cfff40; color: #00cfff; }
.plogo--unitree  { background: #1a0d08; border-color: #f9731640; color: #f97316; }
.plogo--ubtech   { background: #150d2a; border-color: #8b5cf640; color: #a78bfa; }
.plogo--fourier  { background: #0d2018; border-color: #10b98140; color: #34d399; }
.plogo--kawada   { background: #2a0d0d; border-color: #ef444440; color: #fca5a5; }
.plogo--softbank { background: #2a1a0d; border-color: #f59e0b40; color: #fbbf24; }
.plogo--rainbow  { background: #0d0d2a; border-color: #6366f140; color: #818cf8; }
.plogo--boston   { background: #0d1a2a; border-color: #0ea5e940; color: #38bdf8; }
.plogo--techman  { background: #0d2020; border-color: #14b8a640; color: #2dd4bf; }
.plogo--1x       { background: #1a0d2a; border-color: #a855f740; color: #c084fc; font-size: 1rem; }
.plogo--agility  { background: #1a1a0d; border-color: #eab30840; color: #fde68a; }
.plogo--agora    { background: #131820; border-color: #64748b40; color: #94a3b8; }
[data-theme="dark"] .plogo { opacity: .85; }
[data-theme="dark"] .partner-logo:hover .plogo { opacity: 1; }
@media (max-width: 600px) {
.partners-strip { padding: 1rem;}
}
.ticker-wrap { display: flex; align-items: center; background: #08090c; overflow: hidden; height: 44px; }
.ticker-label { flex-shrink: 0; padding: 0 1.25rem; font-family: var(--font-body); font-size: var(--text-xs); font-weight: 700; letter-spacing: .14em; text-transform: uppercase; color: var(--color-accent); border-right: 1px solid rgba(255,255,255,.1); height: 100%; display: flex; align-items: center; }
.ticker-track { flex: 1; overflow: hidden; mask-image: linear-gradient(90deg, transparent 0%, black 5%, black 95%, transparent 100%);}
.ticker-inner { display: flex; align-items: center; gap: 1.25rem; white-space: nowrap; animation: ticker-scroll 45s linear infinite; font-size: var(--text-xs); color: rgba(255,255,255,.7); padding: 0 1.25rem; }
.ticker-sep { color: var(--color-accent); opacity: .6;}
@keyframes ticker-scroll {
0% { transform: translateX(0); }
100% { transform: translateX(-50%); }
}
.ticker-wrap:hover .ticker-inner { animation-play-state: paused;}
.ad-banner-wrap { width: 100%; overflow: hidden; position: relative; background: #0d0f14; border-top: 1px solid #1e2130; border-bottom: 1px solid #1e2130; }
.ad-banner-track { display: flex; transition: transform .6s cubic-bezier(.4, 0, .2, 1); will-change: transform;}
.ad-banner-slide { min-width: 100%; display: flex; align-items: center; justify-content: space-between; gap: 1.5rem; padding: 1rem clamp(1rem, 5vw, 3rem); min-height: 72px; text-decoration: none; color: inherit; cursor: pointer; transition: background .2s; }
.ad-banner-slide:hover { background: rgba(0,207,255,.04);}
.ad-banner-slide--1 { background: linear-gradient(90deg, #08090c 0%, #0d1a2e 100%); }
.ad-banner-slide--2 { background: linear-gradient(90deg, #08090c 0%, #1a0d08 100%); }
.ad-banner-slide--3 { background: linear-gradient(90deg, #08090c 0%, #0d2018 100%); }
.ad-banner-label { font-size: .62rem; font-weight: 700; letter-spacing: .12em; text-transform: uppercase; color: #5a6480; white-space: nowrap; flex-shrink: 0; }
.ad-banner-content { display: flex; align-items: center; gap: 1.25rem; flex: 1; min-width: 0; }
.ad-banner-badge { flex-shrink: 0; padding: .3em .85em; border-radius: 999px; font-size: .7rem; font-weight: 700; letter-spacing: .06em; white-space: nowrap; }
.ad-banner-badge--blue { background: rgba(0,207,255,.15); color: #00cfff; border: 1px solid rgba(0,207,255,.3); }
.ad-banner-badge--red  { background: rgba(239,68,68,.15);  color: #fca5a5; border: 1px solid rgba(239,68,68,.3); }
.ad-banner-badge--green{ background: rgba(16,185,129,.15); color: #34d399; border: 1px solid rgba(16,185,129,.3); }
.ad-banner-text { min-width: 0;}
.ad-banner-title { font-size: .88rem; font-weight: 700; color: #e8eaf0; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; font-family: var(--font-display); }
.ad-banner-sub { font-size: .75rem; color: #5a6480; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.ad-banner-cta { flex-shrink: 0; padding: .45em 1.1em; border-radius: 8px; font-size: .78rem; font-weight: 700; border: 1px solid currentColor; white-space: nowrap; transition: all .18s; }
.ad-banner-cta--blue  { color: #00cfff; }
.ad-banner-cta--red   { color: #fca5a5; }
.ad-banner-cta--green { color: #34d399; }
.ad-banner-slide:hover .ad-banner-cta { background: rgba(0,207,255,.1);}
.ad-banner-dots { display: flex; align-items: center; gap: .4rem; flex-shrink: 0; }
.ad-dot { width: 6px; height: 6px; border-radius: 50%; background: #2a3040; border: none; padding: 0; cursor: pointer; transition: background .2s, transform .2s; }
.ad-dot--active { background: #00cfff; transform: scale(1.3);}
@media (max-width: 600px) {
.ad-banner-sub { display: none; }
.ad-banner-title { font-size: .8rem; }
.ad-banner-cta { display: none; }
}
.news-section { background: var(--color-bg);}
.featured-card { display: grid; grid-template-columns: 480px 1fr; gap: 0; background: var(--color-surface); border: 1px solid var(--color-border); border-radius: 1.5rem; overflow: hidden; margin-bottom: 2rem; transition: box-shadow var(--transition), transform var(--transition); }
.featured-card:hover { box-shadow: var(--shadow-card-hover); transform: translateY(-2px); }
.featured-card-image { position: relative; min-height: 340px;}
.featured-card-img-inner { width: 100%; height: 100%; min-height: 340px; display: flex; align-items: center; justify-content: center; position: relative; overflow: hidden; }
.featured-card-img-inner img { transition: transform .5s ease;}
.featured-card:hover .featured-card-img-inner img { transform: scale(1.04);}
.featured-card-img-overlay { width: 100%; height: 100%; display: flex; align-items: center; justify-content: center; padding: 2.5rem; }
.featured-robot-art { width: 100%; max-width: 300px;}
.featured-tag { position: absolute; top: 1rem; left: 1rem; padding: .25rem .75rem; background: rgba(0,207,255,.15); border: 1px solid rgba(0,207,255,.3); border-radius: 9999px; font-size: var(--text-xs); font-weight: 600; color: var(--color-accent); letter-spacing: .08em; }
.featured-card-body { padding: clamp(2rem, 4vw, 2.5rem); display: flex; flex-direction: column; justify-content: center; }
.article-meta { display: flex; align-items: center; gap: .75rem; margin-bottom: 1rem; }
.article-category { font-size: var(--text-xs); font-weight: 700; letter-spacing: .1em; text-transform: uppercase; color: var(--color-accent); }
.article-date { font-size: var(--text-xs); color: var(--color-text-faint);}
.featured-title { font-family: var(--font-display); font-size: var(--text-xl); font-weight: 800; line-height: 1.2; color: var(--color-text); margin-bottom: 1rem; }
.featured-excerpt { font-size: var(--text-base); color: var(--color-text-muted); line-height: 1.7; margin-bottom: 1.5rem; max-width: 60ch; }
.featured-footer { display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: 1rem; padding-top: 1.25rem; border-top: 1px solid var(--color-divider); }
.article-read-more { font-size: var(--text-sm); font-weight: 600; color: var(--color-text); transition: color var(--transition); display: flex; align-items: center; gap: .25rem; }
.article-read-more:hover { color: var(--color-accent); }
.article-tags { display: flex; gap: .5rem; flex-wrap: wrap;}
.tag { padding: .2em .7em; background: var(--color-surface-2); border: 1px solid var(--color-border); border-radius: 9999px; font-size: var(--text-xs); font-weight: 500; color: var(--color-text-muted); }
.news-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 1.5rem;}
.news-card { background: var(--color-surface); border: 1px solid var(--color-border); border-radius: 1rem; overflow: hidden; transition: box-shadow var(--transition), transform var(--transition); display: flex; flex-direction: column; }
.news-card:hover { box-shadow: var(--shadow-card-hover); transform: translateY(-2px); }
.news-card-image { position: relative; height: 160px; display: flex; align-items: center; justify-content: center; overflow: hidden; }
.news-card-image img { transition: transform .4s ease;}
.news-card:hover .news-card-image img { transform: scale(1.05);}
.news-img-robot { width: 120px; opacity: .9;}
.news-card-tag { position: absolute; z-index: 2; bottom: .75rem; left: .75rem; padding: .2em .7em; background: rgba(0,0,0,.5); border-radius: 9999px; font-size: var(--text-xs); font-weight: 600; color: rgba(255,255,255,.85); letter-spacing: .06em; }
.news-card-body { padding: 1.25rem 1.5rem; display: flex; flex-direction: column; flex: 1; gap: .75rem; }
.news-card-title { font-family: var(--font-display); font-size: var(--text-lg); font-weight: 700; line-height: 1.25; color: var(--color-text); }
.news-card-excerpt { font-size: var(--text-sm); color: var(--color-text-muted); line-height: 1.65; flex: 1; }
@media (max-width: 900px) {
.featured-card { grid-template-columns: 1fr; }
.featured-card-image { min-height: 240px; }
.news-grid { grid-template-columns: 1fr; }
}
@media (max-width: 640px) {
.featured-card-image { display: none; }
}
.intelligence-band { background: #08090c; padding-block: clamp(4rem, 8vw, 5rem);}
.intelligence-inner { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(2.5rem, 6vw, 4rem); align-items: center; }
.intelligence-copy .section-label { color: var(--color-accent); }
.intelligence-title { font-family: var(--font-display); font-size: var(--text-2xl); font-weight: 800; line-height: 1.1; color: #fff; margin-bottom: 1.25rem; }
.intelligence-text { font-size: var(--text-base); color: rgba(255,255,255,.6); line-height: 1.7; margin-bottom: 2rem; max-width: 52ch; }
.intelligence-copy .btn-primary { background: var(--color-accent); color: #08090c;}
.intelligence-copy .btn-primary:hover { background: #33d8ff; }
.intel-stat { padding: 1.5rem; background: rgba(255,255,255,.04); border: 1px solid rgba(255,255,255,.08); border-radius: 1rem; margin-bottom: 1rem; }
.intel-stat:last-child { margin-bottom: 0; }
.intel-stat-num { font-family: var(--font-display); font-size: var(--text-2xl); font-weight: 800; color: #fff; line-height: 1; margin-bottom: .5rem; }
.intel-stat-label { font-size: var(--text-sm); color: rgba(255,255,255,.55); margin-bottom: .75rem;}
.intel-stat-bar { height: 3px; background: rgba(255,255,255,.08); border-radius: 9999px; margin-bottom: .5rem; overflow: hidden; }
.intel-stat-fill { height: 100%; background: linear-gradient(90deg, var(--color-accent), #0080cc); border-radius: 9999px;}
.intel-stat-note { font-size: var(--text-xs); color: rgba(255,255,255,.35);}
@media (max-width: 768px) {
.intelligence-inner { grid-template-columns: 1fr; }
}
.brands-section { background: var(--color-surface);}
.brands-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.25rem;}
.brand-card { background: var(--color-bg); border: 1px solid var(--color-border); border-radius: 1rem; padding: 1.5rem; transition: all var(--transition); cursor: pointer; display: flex; flex-direction: column; gap: .75rem; }
.brand-card:hover { box-shadow: var(--shadow-card-hover); transform: translateY(-2px); border-color: var(--color-text-faint); }
.brand-card-header { display: flex; align-items: center; justify-content: space-between;}
.brand-logo-placeholder { width: 44px; height: 44px; background: #08090c; color: rgba(255,255,255,.8); border-radius: .5rem; display: flex; align-items: center; justify-content: center; font-family: var(--font-display); font-size: var(--text-sm); font-weight: 800; letter-spacing: .05em; }
.brand-status { padding: .2em .7em; border-radius: 9999px; font-size: var(--text-xs); font-weight: 600; letter-spacing: .06em; }
.brand-status--commercial { background: rgba(0,229,160,.12); color: #00b87a; border: 1px solid rgba(0,229,160,.25);}
.brand-status--pilot { background: rgba(255,196,0,.1); color: #c49000; border: 1px solid rgba(255,196,0,.25);}
[data-theme="dark"] .brand-status--commercial { color: #00e5a0; }
[data-theme="dark"] .brand-status--pilot { color: #ffc400; }
.brand-name { font-family: var(--font-display); font-size: var(--text-lg); font-weight: 700; color: var(--color-text); line-height: 1.2; }
.brand-country { font-size: var(--text-xs); color: var(--color-text-muted); font-weight: 500;}
.brand-desc { font-size: var(--text-sm); color: var(--color-text-muted); line-height: 1.6; flex: 1; }
.brand-meta { display: flex; gap: .5rem; font-size: var(--text-xs); color: var(--color-text-faint); padding-top: .75rem; border-top: 1px solid var(--color-divider); }
.brand-card--cta { background: linear-gradient(135deg, #08090c 0%, #1a2035 100%); border-color: rgba(0,207,255,.2); cursor: default;}
.brand-card--cta:hover { transform: none; border-color: rgba(0,207,255,.4); }
.brand-cta-inner { display: flex; flex-direction: column; align-items: flex-start; gap: .75rem; height: 100%; }
.brand-cta-icon { color: var(--color-accent); width: 44px; height: 44px; display: flex; align-items: center; justify-content: center; background: rgba(0,207,255,.1); border-radius: .5rem; border: 1px solid rgba(0,207,255,.2); }
.brand-cta-text { font-family: var(--font-display); font-size: var(--text-lg); font-weight: 700; color: #fff; }
.brand-cta-desc { font-size: var(--text-sm); color: rgba(255,255,255,.5); line-height: 1.6; flex: 1; }
.brand-card--cta .btn-primary { background: var(--color-accent); color: #08090c; margin-top: auto;}
@media (max-width: 960px) {
.brands-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 640px) {
.brands-grid { grid-template-columns: 1fr; }
}
.trends-section { background: var(--color-surface); }
.trend-featured { background: linear-gradient(135deg, #0d1a2a 0%, #0a1520 60%, #0d1a2a 100%); border: 1px solid var(--color-border); border-radius: 1rem; padding: clamp(2rem, 4vw, 3rem); margin-bottom: 2.5rem; position: relative; overflow: hidden; }
.trend-featured::before { content: ''; position: absolute; inset: 0; background: radial-gradient(ellipse at 80% 50%, rgba(0,207,255,.06) 0%, transparent 60%); pointer-events: none; }
.trend-featured-label { display: inline-block; font-family: var(--font-body); font-size: var(--text-xs); font-weight: 700; letter-spacing: .12em; text-transform: uppercase; color: var(--color-accent); background: rgba(0,207,255,.1); border: 1px solid rgba(0,207,255,.25); border-radius: 999px; padding: .25em .9em; margin-bottom: 1rem; }
.trend-featured-title { font-family: var(--font-display); font-size: var(--text-xl); font-weight: 800; color: #fff; margin-bottom: .75rem; line-height: 1.2; }
.trend-featured-desc { font-size: var(--text-base); color: rgba(255,255,255,.65); line-height: 1.7; max-width: 800px; margin-bottom: 2rem; }
.trend-featured-stats { display: flex; gap: 2rem; flex-wrap: wrap; }
.trend-stat { display: flex; flex-direction: column; gap: .25rem; }
.trend-stat-num { font-family: var(--font-display); font-size: var(--text-xl); font-weight: 900; color: var(--color-accent); line-height: 1; }
.trend-stat-label { font-size: var(--text-xs); color: rgba(255,255,255,.5); font-weight: 500; max-width: 160px; line-height: 1.4; }
.trend-card-cover { border-radius: 10px; overflow: hidden; margin-bottom: 1rem;}
.trend-card-cover img { height: 160px; object-fit: cover; border-radius: 10px; transition: transform .4s ease; }
.trend-card:hover .trend-card-cover img { transform: scale(1.04);}
.trend-featured-bg img { filter: saturate(.7);}
.trends-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(260px, 1fr)); gap: 1.25rem;}
.trend-card { background: var(--color-bg); border: 1px solid var(--color-border); border-radius: .75rem; padding: 1.5rem; display: flex; flex-direction: column; gap: .75rem; transition: border-color var(--transition), box-shadow var(--transition), transform var(--transition); }
.trend-card:hover { border-color: rgba(0,207,255,.3); box-shadow: 0 8px 32px rgba(0,207,255,.08); transform: translateY(-2px);}
.trend-card-icon { width: 40px; height: 40px; border-radius: .5rem; display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.trend-card-icon--blue   { background: rgba(0,207,255,.1);   color: #00cfff; }
.trend-card-icon--teal   { background: rgba(0,229,160,.1);   color: #00e5a0; }
.trend-card-icon--violet { background: rgba(167,139,250,.1); color: #a78bfa; }
.trend-card-icon--amber  { background: rgba(255,196,0,.1);   color: #ffc400; }
.trend-card-region { font-size: var(--text-xs); font-weight: 700; letter-spacing: .1em; text-transform: uppercase; color: var(--color-accent); }
.trend-card-title { font-family: var(--font-display); font-size: var(--text-base); font-weight: 700; color: var(--color-text); line-height: 1.3; margin: 0; }
.trend-card-desc { font-size: var(--text-sm); color: var(--color-text-muted); line-height: 1.65; flex: 1; margin: 0; }
.trend-card-tag { display: inline-block; font-size: var(--text-xs); font-weight: 600; color: var(--color-text-muted); background: var(--color-surface); border: 1px solid var(--color-border); border-radius: 999px; padding: .2em .75em; align-self: flex-start; margin-top: auto; }
@media (max-width: 768px) {
.trend-featured-stats { gap: 1.5rem; }
.trends-grid { grid-template-columns: 1fr; }
}
.newsletter-section { background: #08090c; padding-block: clamp(4rem, 8vw, 5rem);}
.newsletter-inner { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(2.5rem, 6vw, 4rem); align-items: center; }
.newsletter-title { font-family: var(--font-display); font-size: var(--text-2xl); font-weight: 800; line-height: 1.1; color: #fff; margin-bottom: 1.25rem; }
.newsletter-text { font-size: var(--text-base); color: rgba(255,255,255,.55); line-height: 1.7; margin-bottom: 1.5rem; max-width: 52ch; }
.newsletter-benefits { display: flex; flex-direction: column; gap: .75rem; list-style: none; }
.newsletter-benefits li { display: flex; align-items: center; gap: .75rem; font-size: var(--text-sm); color: rgba(255,255,255,.6); }
.newsletter-benefits svg { color: var(--color-accent); flex-shrink: 0; }
.newsletter-form-wrap { background: rgba(255,255,255,.04); border: 1px solid rgba(255,255,255,.08); border-radius: 1.5rem; padding: clamp(2rem, 4vw, 2.5rem); }
.form-label { display: block; font-size: var(--text-sm); font-weight: 600; color: rgba(255,255,255,.7); margin-bottom: .75rem; }
.form-row { display: flex; gap: .75rem;}
.form-input { flex: 1; padding: .7em 1em; background: rgba(255,255,255,.06); border: 1.5px solid rgba(255,255,255,.12); border-radius: .5rem; font-size: var(--text-sm); color: #fff; outline: none; transition: border-color var(--transition); min-width: 0; }
.form-input::placeholder { color: rgba(255,255,255,.3); }
.form-input:focus { border-color: var(--color-accent); }
.newsletter-form-wrap .btn-primary { background: var(--color-accent); color: #08090c; flex-shrink: 0;}
.newsletter-form-wrap .btn-primary:hover { background: #33d8ff; }
.form-note { margin-top: .75rem; font-size: var(--text-xs); color: rgba(255,255,255,.3);}
.form-success { display: none; margin-top: 1rem; padding: .75rem 1rem; background: rgba(0,229,160,.12); border: 1px solid rgba(0,229,160,.25); border-radius: .5rem; font-size: var(--text-sm); font-weight: 600; color: #00e5a0; }
.form-success.visible { display: block; }
@media (max-width: 768px) {
.newsletter-inner { grid-template-columns: 1fr; }
.form-row { flex-direction: column; }
}
.about-section { background: var(--color-bg); padding-block: clamp(4rem, 8vw, 6rem);}
.about-inner { display: grid; grid-template-columns: 1fr auto; gap: clamp(2.5rem, 6vw, 4rem); align-items: center; }
.about-title { font-family: var(--font-display); font-size: var(--text-2xl); font-weight: 800; line-height: 1.1; color: var(--color-text); margin-bottom: 1.25rem; }
.about-text { font-size: var(--text-base); color: var(--color-text-muted); line-height: 1.75; max-width: 60ch; margin-bottom: 1.25rem; }
.about-text:last-child { margin-bottom: 0; }
.about-logo-wrap { display: flex; flex-direction: column; align-items: center; gap: 1rem; flex-shrink: 0; }
.about-ha-mark-img { width: 160px; height: 160px; object-fit: contain; border-radius: 28px; box-shadow: 0 20px 60px rgba(0,207,255,.15), 0 4px 20px rgba(0,0,0,.15); }
.about-tagline { text-align: center;}
.about-brand-name { font-family: var(--font-display); font-size: var(--text-sm); font-weight: 800; letter-spacing: .14em; color: var(--color-text); margin-bottom: .25rem; }
.about-brand-tagline { font-size: var(--text-xs); color: var(--color-accent); font-weight: 500; letter-spacing: .05em; }
@media (max-width: 768px) {
.about-inner { grid-template-columns: 1fr;}
.about-logo-wrap { flex-direction: row; align-self: flex-start;}
.about-tagline { text-align: left; }
.about-ha-mark-img { width: 80px; height: 80px; }
}
.site-footer { background: var(--color-surface); border-top: 1px solid var(--color-border); padding-block: clamp(3rem, 6vw, 4rem) 2rem;}
.footer-inner { display: grid; grid-template-columns: 300px 1fr; gap: 4rem; margin-bottom: 3rem; }
.footer-logo { display: flex; align-items: center; gap: .75rem; font-family: var(--font-display); font-size: var(--text-base); font-weight: 800; color: var(--color-text); margin-bottom: .75rem; letter-spacing: .06em; }
.footer-tagline { font-size: var(--text-xs); font-weight: 600; letter-spacing: .08em; text-transform: uppercase; color: var(--color-accent); margin-bottom: .75rem; }
.footer-desc { font-size: var(--text-sm); color: var(--color-text-muted); line-height: 1.65; max-width: 36ch; }
.footer-links-group { display: grid; grid-template-columns: repeat(3, 1fr); gap: 2rem;}
.footer-col-title { font-size: var(--text-xs); font-weight: 700; letter-spacing: .1em; text-transform: uppercase; color: var(--color-text); margin-bottom: 1rem; }
.footer-col ul { list-style: none; display: flex; flex-direction: column; gap: .75rem; }
.footer-col a { font-size: var(--text-sm); color: var(--color-text-muted); transition: color var(--transition);}
.footer-col a:hover { color: var(--color-text); }
.footer-bottom { display: flex; align-items: center; justify-content: space-between; padding-top: 1.5rem; border-top: 1px solid var(--color-divider); }
.footer-copy { font-size: var(--text-xs); color: var(--color-text-faint);}
.footer-social { display: flex; gap: .75rem;}
.social-link { width: 36px; height: 36px; display: flex; align-items: center; justify-content: center; border-radius: .5rem; border: 1px solid var(--color-border); color: var(--color-text-muted); transition: all var(--transition); }
.social-link:hover { border-color: var(--color-text); color: var(--color-text); background: var(--color-surface-2); }
@media (max-width: 900px) {
.footer-inner { grid-template-columns: 1fr; gap: 2rem; }
.footer-links-group { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 500px) {
.footer-links-group { grid-template-columns: 1fr; }
.footer-bottom { flex-direction: column; gap: 1rem; text-align: center; }
}
html.font-cjk-tc { --font-display:'Noto Sans TC', 'PingFang TC', 'Hiragino Sans CNS', sans-serif; --font-body:'Noto Sans TC', 'PingFang TC', 'Hiragino Sans CNS', sans-serif;}
html.font-cjk-sc { --font-display:'Noto Sans SC', 'PingFang SC', 'Hiragino Sans GB', 'Microsoft YaHei', sans-serif; --font-body:'Noto Sans SC', 'PingFang SC', 'Hiragino Sans GB', 'Microsoft YaHei', sans-serif;}
html.font-cjk-jp { --font-display:'Noto Sans JP', 'Hiragino Kaku Gothic ProN', 'Yu Gothic', sans-serif; --font-body:'Noto Sans JP', 'Hiragino Kaku Gothic ProN', 'Yu Gothic', sans-serif;}
html.font-cjk-tc,
html.font-cjk-sc,
html.font-cjk-jp { --cjk-lh-heading: 1.3; --cjk-lh-body: 1.75;}
html.font-cjk-tc body,
html.font-cjk-sc body,
html.font-cjk-jp body { line-height: var(--cjk-lh-body, 1.75);}
html.font-cjk-tc .hero-headline,
html.font-cjk-sc .hero-headline,
html.font-cjk-jp .hero-headline { font-size: clamp(1.6rem, 3.2vw, 2.8rem); line-height: 1.15; letter-spacing: -.01em; font-weight: 700; }
html.font-cjk-tc .hero-subtext,
html.font-cjk-sc .hero-subtext,
html.font-cjk-jp .hero-subtext { font-size: .9rem; line-height: 1.7; max-width: 38ch;}
html.font-cjk-tc .stat-label,
html.font-cjk-sc .stat-label,
html.font-cjk-jp .stat-label { font-size: .65rem; max-width: 12ch;}
html.font-cjk-tc .section-title,
html.font-cjk-sc .section-title,
html.font-cjk-jp .section-title,
html.font-cjk-tc .intelligence-title,
html.font-cjk-sc .intelligence-title,
html.font-cjk-jp .intelligence-title,
html.font-cjk-tc .newsletter-title,
html.font-cjk-sc .newsletter-title,
html.font-cjk-jp .newsletter-title,
html.font-cjk-tc .about-title,
html.font-cjk-sc .about-title,
html.font-cjk-jp .about-title { font-weight: 700; letter-spacing: .01em;}
html.font-cjk-jp .nav-links .nav-link { white-space: nowrap; font-size: .82rem;}
html.font-cjk-jp .nav-links { gap: .5rem;}
html.font-cjk-tc .nav-links .nav-link,
html.font-cjk-sc .nav-links .nav-link { white-space: nowrap;}
.lang-switcher { display: flex; align-items: center; gap: 2px; background: var(--color-surface-2, #f3f3f0); border: 1px solid var(--color-border, #e0ddd8); border-radius: var(--radius-full, 9999px); padding: 3px; }
[data-theme="dark"] .lang-switcher { background: #1a1d26; border-color: #1e2130;}
.lang-btn { padding: 4px 10px; border-radius: var(--radius-full, 9999px); font-size: .7rem; font-weight: 600; letter-spacing: .04em; color: var(--color-text-muted, #888); background: transparent; border: none; cursor: pointer; white-space: nowrap; transition: background 160ms ease, color 160ms ease; font-family: var(--font-body, sans-serif); }
.lang-btn:hover { color: var(--color-text, #1a1a1a); background: var(--color-surface-offset, #eae8e4);}
[data-theme="dark"] .lang-btn:hover { background: #252836; color: #e8eaf0;}
.lang-btn--active { background: var(--color-text, #1a1a1a); color: var(--color-bg, #fff) !important;}
[data-theme="dark"] .lang-btn--active { background: #e8eaf0; color: #0d0f14 !important;}
.lang-switcher--mobile { margin: var(--space-4, 1rem) var(--space-6, 1.5rem); justify-content: center;}
@media (max-width: 767px) {
.nav-actions .lang-switcher:not(.lang-switcher--mobile) { display: none;}
.site-header .nav-actions .btn.btn-primary { display: none;}
.mobile-menu-btn { display: flex; }
}
@media (min-width: 768px) {
.lang-switcher--mobile { display: none;}
}
.article-hero { min-height: 420px; display: flex; align-items: flex-end; padding-bottom: clamp(2.5rem, 5vw, var(--space-14)); }
.article-hero-inner { max-width: var(--content-default); margin-inline: auto; padding-inline: clamp(1.5rem, 5vw, 3rem); width: 100%; }
.article-hero-meta { display: flex; gap: .5rem; margin-bottom: 1rem; flex-wrap: wrap; }
.article-region-badge,
.article-category-badge { display: inline-block; font-family: var(--font-body); font-size: var(--text-xs); font-weight: 700; letter-spacing: .1em; text-transform: uppercase; border-radius: 999px; padding: .3em 1em; }
.article-region-badge { background: rgba(0,207,255,.15); color: var(--color-accent); border: 1px solid rgba(0,207,255,.3);}
.article-category-badge { background: rgba(255,255,255,.08); color: rgba(255,255,255,.7); border: 1px solid rgba(255,255,255,.15);}
.article-hero-title { font-family: var(--font-display); font-size: clamp(1.6rem, 3.5vw, 2.8rem); font-weight: 800; color: #fff; line-height: 1.15; max-width: 860px; margin-bottom: 1.25rem; }
.article-byline { display: flex; align-items: center; gap: .5rem; font-size: var(--text-sm); color: rgba(255,255,255,.5); }
.article-byline-dot { opacity: .4; }
.article-body-wrap { display: grid; grid-template-columns: 1fr 300px; gap: 3rem; max-width: var(--content-default); margin-inline: auto; padding: clamp(2.5rem, 5vw, 4rem) clamp(1.5rem, 5vw, 3rem); align-items: start; }
.article-body .article-lead { font-size: var(--text-lg); color: var(--color-text); line-height: 1.75; font-weight: 500; margin-bottom: 2rem; border-left: 3px solid var(--color-accent); padding-left: 1.25rem; }
.article-body h2 { font-family: var(--font-display); font-size: var(--text-xl); font-weight: 800; color: var(--color-text); margin-top: 2.5rem; margin-bottom: 1rem; line-height: 1.2; }
.article-body p { font-size: var(--text-base); color: var(--color-text-muted); line-height: 1.8; margin-bottom: 1.25rem; }
.article-stat-block { display: flex; gap: 1.5rem; flex-wrap: wrap; background: var(--color-surface); border: 1px solid var(--color-border); border-radius: .75rem; padding: 1.5rem 2rem; margin: 2rem 0; }
.article-stat { display: flex; flex-direction: column; gap: .25rem; flex: 1; min-width: 120px; }
.article-stat-num { font-family: var(--font-display); font-size: var(--text-xl); font-weight: 900; color: var(--color-accent); line-height: 1; }
.article-stat-label { font-size: var(--text-xs); color: var(--color-text-muted); font-weight: 500; line-height: 1.4; }
.article-tags-row { display: flex; flex-wrap: wrap; gap: .5rem; margin-top: 2.5rem; padding-top: 2rem; border-top: 1px solid var(--color-border); }
.article-tags-row .tag { background: var(--color-surface); border: 1px solid var(--color-border); color: var(--color-text-muted); font-size: var(--text-xs); font-weight: 600; border-radius: 999px; padding: .35em 1em; }
.article-sidebar { position: sticky; top: calc(84px + 1.5rem); display: flex; flex-direction: column; gap: 1.25rem; }
.sidebar-card { background: var(--color-surface); border: 1px solid var(--color-border); border-radius: .75rem; padding: 1.25rem; }
.sidebar-card-label { font-family: var(--font-body); font-size: var(--text-xs); font-weight: 700; letter-spacing: .12em; text-transform: uppercase; color: var(--color-accent); margin-bottom: 1rem; }
.sidebar-links { list-style: none; display: flex; flex-direction: column; gap: .75rem; }
.sidebar-links a { font-size: var(--text-sm); color: var(--color-text-muted); line-height: 1.4; transition: color var(--transition); }
.sidebar-links a:hover { color: var(--color-accent); }
.sidebar-company { display: flex; flex-direction: column; gap: .5rem;}
.sidebar-company-name { font-family: var(--font-display); font-size: var(--text-base); font-weight: 700; color: var(--color-text); }
.sidebar-company-detail { font-size: var(--text-sm); color: var(--color-text-muted);}
@media (max-width: 900px) {
.article-body-wrap { grid-template-columns: 1fr;}
.article-sidebar { position: static;}
.article-stat-block { gap: 1rem;}
}
@media (max-width: 640px) {
.article-hero { min-height: 320px; padding-top: calc(var(--nav-height,84px) + 2rem); }
.article-hero-title { font-size: clamp(1.5rem, 6vw, 2.4rem); line-height: 1.2; }
.article-stat-block { grid-template-columns: 1fr; }
.article-stat { padding: 1rem; }
.article-body { padding-inline: 1rem; }
.lang-switcher { gap: .25rem; }
.lang-btn { padding: .3em .6em; font-size: .72rem; }
}
.dir-hero { padding: clamp(4rem, 8vw, 6rem) clamp(1rem, 5vw, 3rem); padding-top: calc(var(--nav-height, 84px) + clamp(3rem, 5vw, 5rem));}
.dir-filter-bar { position: sticky; top: 84px; z-index: 90; background: var(--color-bg); border-bottom: 1px solid var(--color-border); padding: .75rem clamp(1rem, 5vw, 3rem); display: flex; align-items: center; gap: .75rem; overflow-x: auto; -webkit-overflow-scrolling: touch; scrollbar-width: none; }
.dir-filter-bar::-webkit-scrollbar { display: none; }
.dir-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.25rem; max-width: var(--content-default); margin-inline: auto; padding-inline: clamp(1rem, 5vw, 3rem); padding-block: 2rem 4rem; }
@media (max-width: 1100px) {
.dir-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 700px) {
.dir-grid { grid-template-columns: 1fr; }
.dir-hero { padding-inline: 1rem; }
}
.trends-page-hero { padding: clamp(4rem, 8vw, 6rem) clamp(1rem, 5vw, 3rem); padding-top: calc(var(--nav-height, 84px) + clamp(3rem, 5vw, 5rem));}
.trends-filter-bar { position: sticky; top: 84px; z-index: 90; background: var(--color-bg); border-bottom: 1px solid var(--color-border); padding: .75rem clamp(1rem, 5vw, 3rem); display: flex; align-items: center; gap: .75rem; overflow-x: auto; -webkit-overflow-scrolling: touch; scrollbar-width: none; }
.trends-filter-bar::-webkit-scrollbar { display: none; }
.trend-deep-dive { padding-inline: clamp(1rem, 5vw, 3rem);}
@media (max-width: 768px) {
.trend-deep-stats { grid-template-columns: 1fr; }
.trend-deep-dive { padding-inline: 1rem; }
}
.brand-page-hero { background: linear-gradient(135deg, #0d1117 0%, #13151c 100%); padding: calc(84px + 3rem) clamp(1rem, 5vw, 3rem) 3rem; border-bottom: 1px solid #1e2130;}
.brand-back-link { display: inline-flex; align-items: center; gap: .5rem; color: #00cfff; font-size: .85rem; font-weight: 600; text-decoration: none; margin-bottom: 2rem; letter-spacing: .05em; text-transform: uppercase; }
.brand-hero-initials { width: 72px; height: 72px; border-radius: 16px; display: flex; align-items: center; justify-content: center; font-size: 1.5rem; font-weight: 900; color: #fff; margin-bottom: 1.5rem; font-family: 'Cabinet Grotesk', sans-serif; }
.brand-hero-name { font-size: clamp(2rem, 5vw, 3.5rem); font-weight: 900; color: #fff; margin-bottom: .5rem; }
.brand-hero-meta { display: flex; align-items: center; gap: 1rem; flex-wrap: wrap; margin-bottom: 1rem; color: #8892a4; font-size: .9rem; }
.brand-hero-tagline { font-size: 1.1rem; color: #c8d0e0; max-width: 650px; line-height: 1.6; }
.brand-section { max-width: 1200px; margin: 0 auto; padding: 4rem clamp(1rem, 5vw, 3rem); }
.brand-section-label { font-size: .72rem; font-weight: 700; letter-spacing: .12em; text-transform: uppercase; color: #00cfff; margin-bottom: .5rem; }
.brand-section + .brand-section { border-top: 1px solid #1e2130; }
.brand-section h2 { margin-top: .5rem; margin-bottom: 1.5rem;}
.products-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 1.5rem; margin-top: 2rem; }
.product-card { background: #13151c; border: 1px solid #1e2130; border-radius: 16px; padding: 1.75rem; transition: border-color .2s; }
.product-card:hover { border-color: #00cfff40; }
.product-card-header { display: flex; align-items: flex-start; justify-content: space-between; margin-bottom: 1rem; gap: 1rem; }
.product-name { font-size: 1.25rem; font-weight: 800; color: #fff; font-family: 'Cabinet Grotesk', sans-serif; }
.product-status { font-size: .7rem; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; padding: .25em .8em; border-radius: 999px; white-space: nowrap; }
.product-status--commercial { background: rgba(0,229,160,.15); color: #00e5a0; border: 1px solid rgba(0,229,160,.3); }
.product-status--pilot { background: rgba(0,207,255,.15); color: #00cfff; border: 1px solid rgba(0,207,255,.3); }
.product-status--rd { background: rgba(167,139,250,.15); color: #a78bfa; border: 1px solid rgba(167,139,250,.3); }
.product-status--roadmap { background: rgba(245,158,11,.15); color: #f59e0b; border: 1px solid rgba(245,158,11,.3); }
.product-price { font-size: 1.1rem; font-weight: 700; color: #00cfff; margin-bottom: .75rem; }
.product-desc { font-size: .9rem; color: #8892a4; line-height: 1.65; margin-bottom: 1.25rem; }
.product-specs { display: grid; grid-template-columns: 1fr 1fr; gap: .5rem 1rem; margin-bottom: 1.25rem; }
.spec-row { display: flex; flex-direction: column; gap: .1rem; }
.spec-label { font-size: .7rem; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; color: #5a6480; }
.spec-value { font-size: .85rem; color: #c8d0e0; font-weight: 500; }
.product-tags { display: flex; flex-wrap: wrap; gap: .4rem; }
.product-tag { font-size: .72rem; font-weight: 600; padding: .25em .7em; border-radius: 999px; background: #1e2130; color: #8892a4; border: 1px solid #2a3040; }
.product-img-wrap { width: 100%; aspect-ratio: 16/9; border-radius: 10px; overflow: hidden; margin-bottom: 1.25rem; background: #0d1117; display: flex; align-items: center; justify-content: center; }
.product-img-wrap img { width: 100%; height: 100%; object-fit: cover; object-position: center top; transition: transform .4s ease; }
.product-card:hover .product-img-wrap img { transform: scale(1.04);}
.product-img-wrap.portrait img { object-position: center 10%;}
.brand-cta-box { background: linear-gradient(135deg, #0d1a2e 0%, #0d1117 100%); border: 1px solid #1e2130; border-radius: 16px; padding: 2.5rem; text-align: center; margin-top: 2rem; }
.brand-cta-box h3 { font-size: 1.5rem; font-weight: 800; color: #fff; margin-bottom: .75rem; }
.brand-cta-box p { color: #8892a4; margin-bottom: 1.5rem; }
@media (max-width: 768px) { .products-grid { grid-template-columns: 1fr; } }
@media (max-width: 640px) { .product-specs { grid-template-columns: 1fr; } }
.listing-hero { background: linear-gradient(135deg, #0d1117 0%, #13151c 60%, #0d1520 100%); padding: calc(84px + 3.5rem) clamp(1rem, 5vw, 3rem) 3.5rem; border-bottom: 1px solid #1e2130; text-align: center; }
.listing-hero-eyebrow { font-size: .75rem; font-weight: 700; letter-spacing: .14em; text-transform: uppercase; color: #00cfff; margin-bottom: 1.25rem;}
.listing-hero-title { font-size: clamp(2rem, 5vw, 3.25rem); font-weight: 900; color: #fff; margin-bottom: 1rem; line-height: 1.15; font-family: 'Cabinet Grotesk', sans-serif;}
.listing-hero-subtitle { font-size: 1.1rem; color: #8892a4; max-width: 600px; margin: 0 auto 2rem; line-height: 1.65;}
.listing-benefits { display: flex; align-items: center; justify-content: center; gap: .5rem; flex-wrap: wrap; margin-top: 0;}
.listing-benefit-badge { display: inline-flex; align-items: center; gap: .4rem; background: rgba(0,207,255,.1); border: 1px solid rgba(0,207,255,.25); color: #c8d0e0; font-size: .82rem; font-weight: 600; padding: .35em .9em; border-radius: 999px; }
.listing-benefit-badge .check { color: #00e5a0; }
.listing-form-container { max-width: 800px; margin: 0 auto; padding: 3rem clamp(1rem, 5vw, 2rem) 5rem;}
.listing-form-section { background: #13151c; border: 1px solid #1e2130; border-radius: 20px; padding: 2rem; margin-bottom: 1.5rem;}
.listing-form-section-title { font-size: 1rem; font-weight: 800; color: #fff; font-family: 'Cabinet Grotesk', sans-serif; margin-bottom: .25rem; letter-spacing: .01em;}
.listing-form-section-num { font-size: .7rem; font-weight: 700; letter-spacing: .12em; text-transform: uppercase; color: #00cfff; margin-bottom: 1.25rem;}
.listing-form-section-divider { border: none; border-top: 1px solid #1e2130; margin: 1.25rem 0 1.5rem;}
.form-field { margin-bottom: 1.25rem; }
.form-field:last-child { margin-bottom: 0; }
.form-label { display: block; font-size: .72rem; font-weight: 700; letter-spacing: .09em; text-transform: uppercase; color: #8892a4; margin-bottom: .45rem;}
.form-label .required { color: #00cfff; margin-left: .15em; }
.form-input, .form-select, .form-textarea { width: 100%; background: #0d1117; border: 1px solid #1e2130; border-radius: 10px; color: #e8edf5; font-size: .9rem; font-family: 'Satoshi', sans-serif; padding: .7rem .9rem; transition: border-color .18s, box-shadow .18s; box-sizing: border-box; outline: none; appearance: none; }
.form-input::placeholder, .form-textarea::placeholder { color: #3a4460; }
.form-input:focus, .form-select:focus, .form-textarea:focus { border-color: #00cfff44; box-shadow: 0 0 0 3px rgba(0,207,255,.08);}
.form-input.error, .form-select.error, .form-textarea.error { border-color: #ef4444; box-shadow: 0 0 0 3px rgba(239,68,68,.1);}
.form-select { background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%238892a4' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E"); background-repeat: no-repeat; background-position: right .85rem center; padding-right: 2.2rem; cursor: pointer;}
.form-textarea { resize: vertical; min-height: 90px; line-height: 1.6; }
.form-textarea--tall { min-height: 120px; }
.char-counter-wrap { position: relative; }
.char-counter { position: absolute; bottom: .55rem; right: .7rem; font-size: .72rem; font-weight: 600; color: #3a4460; pointer-events: none; transition: color .15s;}
.char-counter.warn { color: #f59e0b; }
.char-counter.over { color: #ef4444; }
.char-counter-wrap .form-textarea { padding-bottom: 1.8rem; }
.form-checkbox-group { display: grid; grid-template-columns: repeat(2, 1fr); gap: .5rem 1rem; margin-top: .15rem;}
.form-checkbox-label { display: flex; align-items: center; gap: .55rem; cursor: pointer; color: #c8d0e0; font-size: .875rem; font-weight: 500;}
.form-checkbox-label input[type="checkbox"] { width: 16px; height: 16px; accent-color: #00cfff; border-radius: 4px; cursor: pointer; flex-shrink: 0;}
.consent-row { display: flex; align-items: flex-start; gap: .75rem; background: #0d1117; border: 1px solid #1e2130; border-radius: 12px; padding: 1.25rem; margin-bottom: 1.5rem;}
.consent-row input[type="checkbox"] { width: 18px; height: 18px; accent-color: #00cfff; cursor: pointer; flex-shrink: 0; margin-top: .1rem;}
.consent-text { font-size: .875rem; color: #8892a4; line-height: 1.6; }
.listing-submit-btn { width: 100%; padding: 1rem 2rem; background: linear-gradient(135deg, #00cfff 0%, #0090c0 100%); color: #0d1117; font-size: 1rem; font-weight: 800; font-family: 'Cabinet Grotesk', sans-serif; border: none; border-radius: 12px; cursor: pointer; transition: opacity .2s, transform .15s; letter-spacing: .01em; }
.listing-submit-btn:hover { opacity: .9; transform: translateY(-1px); }
.listing-submit-btn:active { transform: translateY(0); }
.listing-submit-btn:disabled { opacity: .5; cursor: not-allowed; transform: none; }
.field-error { font-size: .75rem; color: #ef4444; font-weight: 600; margin-top: .35rem; display: none;}
.field-error.visible { display: block; }
.listing-success { display: none; text-align: center; background: #13151c; border: 1px solid #00e5a030; border-radius: 20px; padding: 4rem 2rem; margin: 3rem 0; }
.listing-success.show { display: block; }
.success-icon { width: 72px; height: 72px; background: rgba(0,229,160,.15); border: 2px solid rgba(0,229,160,.3); border-radius: 50%; display: flex; align-items: center; justify-content: center; margin: 0 auto 1.5rem; font-size: 2rem; }
.success-title { font-size: 1.6rem; font-weight: 900; color: #fff; font-family: 'Cabinet Grotesk', sans-serif; margin-bottom: .75rem;}
.success-subtitle { font-size: 1rem; color: #8892a4; line-height: 1.65; max-width: 480px; margin: 0 auto; }
.success-email { color: #00cfff; font-weight: 600; }
@media (max-width: 600px) {
.form-row { grid-template-columns: 1fr; }
.form-checkbox-group { grid-template-columns: 1fr; }
.listing-form-section { padding: 1.5rem; }
}

/* ─── Missing page-specific classes ─── */
.trend-deep-header { padding: 3rem clamp(1rem,5vw,3rem) 1.5rem; }
.trend-deep-header h2 { font-size: clamp(1.4rem,3vw,2.2rem); font-weight:900; color:var(--color-text); line-height:1.15; margin-top:.75rem; margin-bottom:0; font-family:var(--font-display); }

.dir-filter-bar,.trends-filter-bar { position:sticky; top:84px; z-index:90; background:var(--color-bg); border-bottom:1px solid var(--color-border); padding:.75rem clamp(1rem,5vw,3rem); display:flex; align-items:center; gap:.75rem; overflow-x:auto; scrollbar-width:none; }
.dir-filter-bar::-webkit-scrollbar,.trends-filter-bar::-webkit-scrollbar { display:none; }
.dir-pill,.trends-pill { padding:.4em 1em; border-radius:999px; font-size:.8rem; font-weight:600; border:1px solid var(--color-border); background:transparent; color:var(--color-text-muted); cursor:pointer; white-space:nowrap; transition:all .18s; }
.dir-pill--active,.trends-pill--active,.dir-pill:hover { background:var(--color-text); color:var(--color-bg); border-color:var(--color-text); }
.dir-count { font-size:.85rem; color:var(--color-text-muted); padding:.5rem clamp(1rem,5vw,3rem); }

/* ─── Trend deep-dive sections — ensure breathing room ─── */
.trend-deep-dive { padding: 4rem clamp(1rem,5vw,3rem); border-bottom:1px solid var(--color-border); }
.trend-deep-dive:nth-child(even) { background:var(--color-surface); }
.trend-deep-body { max-width:72ch; }
.trend-deep-body p { font-size:1rem; line-height:1.75; color:var(--color-text-secondary); margin-bottom:1.25rem; }
.trend-deep-stats { display:grid; grid-template-columns:repeat(3,1fr); gap:1.5rem; margin:2.5rem 0; padding:2rem; background:var(--color-surface-2); border:1px solid var(--color-border); border-radius:12px; }
.trend-stat { display:flex; flex-direction:column; gap:.35rem; }
.trend-stat-num { font-size:1.6rem; font-weight:900; color:var(--color-accent); font-family:var(--font-display); line-height:1; }
.trend-stat-label { font-size:.78rem; color:var(--color-text-muted); line-height:1.4; }
.trend-deep-tags { display:flex; flex-wrap:wrap; gap:.5rem; margin-top:1.5rem; }
.trend-tag { font-size:.75rem; font-weight:600; padding:.3em .8em; border-radius:999px; background:var(--color-surface-2); color:var(--color-text-muted); border:1px solid var(--color-border); }

/* ─── Directory card grid spacing ─── */
.dir-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:1.5rem; max-width:var(--content-default); margin:0 auto; padding:2rem clamp(1rem,5vw,3rem) 5rem; }
.dir-card { background:var(--color-surface); border:1px solid var(--color-border); border-radius:16px; padding:1.75rem; transition:border-color .2s, box-shadow .2s; text-decoration:none; color:inherit; display:flex; flex-direction:column; gap:.75rem; }
.dir-card:hover { border-color:rgba(0,207,255,.3); box-shadow:0 4px 24px rgba(0,207,255,.06); }
.dir-card-header { display:flex; align-items:flex-start; justify-content:space-between; gap:.75rem; margin-bottom:.25rem; }
.dir-card-initials { width:44px; height:44px; border-radius:10px; display:flex; align-items:center; justify-content:center; font-weight:900; font-size:.9rem; flex-shrink:0; font-family:var(--font-display); }
.dir-card-meta { display:flex; align-items:center; gap:.5rem; flex-wrap:wrap; }
.dir-status { font-size:.65rem; font-weight:700; letter-spacing:.08em; text-transform:uppercase; padding:.25em .7em; border-radius:999px; }
.dir-status--commercial { background:rgba(0,229,160,.12); color:#00e5a0; border:1px solid rgba(0,229,160,.25); }
.dir-status--pilot { background:rgba(0,207,255,.12); color:#00cfff; border:1px solid rgba(0,207,255,.25); }
.dir-status--rd { background:rgba(167,139,250,.12); color:#a78bfa; border:1px solid rgba(167,139,250,.25); }
.dir-founded { font-size:.72rem; color:var(--color-text-muted); }
.dir-card-name { font-size:1.05rem; font-weight:800; color:var(--color-text); font-family:var(--font-display); }
.dir-card-location { font-size:.8rem; color:var(--color-text-muted); }
.dir-card-desc { font-size:.85rem; line-height:1.6; color:var(--color-text-secondary); flex:1; }
.dir-card-stats { display:grid; grid-template-columns:1fr 1fr; gap:.5rem .75rem; padding:.75rem 0; border-top:1px solid var(--color-border); }
.dir-stat-label { font-size:.65rem; font-weight:700; letter-spacing:.08em; text-transform:uppercase; color:var(--color-text-muted); }
.dir-stat-value { font-size:.8rem; font-weight:600; color:var(--color-text); }
.dir-card-link-row { display:flex; justify-content:flex-end; padding-top:.5rem; }
.dir-card-footer a { font-size:.8rem; font-weight:700; color:var(--color-accent); }
@media(max-width:1100px){.dir-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:680px){.dir-grid{grid-template-columns:1fr}}

/* ─── Trend region/category badges ─── */
.trend-region-badge { display:inline-flex; align-items:center; gap:.4rem; padding:.3em .9em; border-radius:999px; font-size:.75rem; font-weight:700; background:rgba(0,207,255,.12); color:#00cfff; border:1px solid rgba(0,207,255,.25); }
.trend-category-badge { display:inline-flex; align-items:center; gap:.4rem; padding:.3em .9em; border-radius:999px; font-size:.75rem; font-weight:700; border:1px solid; }
.trend-category-badge--manufacturing { background:rgba(245,158,11,.12); color:#f59e0b; border-color:rgba(245,158,11,.25); }
.trend-category-badge--investment { background:rgba(16,185,129,.12); color:#10b981; border-color:rgba(16,185,129,.25); }
.trend-category-badge--technology { background:rgba(0,207,255,.12); color:#00cfff; border-color:rgba(0,207,255,.25); }
.trend-category-badge--policy { background:rgba(139,92,246,.12); color:#8b5cf6; border-color:rgba(139,92,246,.25); }
.trend-category-badge--healthcare { background:rgba(236,72,153,.12); color:#ec4899; border-color:rgba(236,72,153,.25); }
.trend-badges { display:flex; align-items:center; gap:.5rem; flex-wrap:wrap; margin-bottom:1rem; }
.dir-card-footer svg,.dir-card-link svg,.dir-card-footer img{width:20px!important;height:20px!important;max-width:20px}
