.page {
background:
radial-gradient(ellipse at 20% 0%, rgba(122, 162, 247, 0.07), transparent 50%),
radial-gradient(ellipse at 80% 0%, rgba(187, 154, 247, 0.05), transparent 50%),
linear-gradient(180deg, #0d0f18 0%, #111425 30%, #0e1120 100%);
}
.reveal {
opacity: 0;
transform: translateY(28px);
transition: opacity 0.7s cubic-bezier(0.22, 1, 0.36, 1),
transform 0.7s cubic-bezier(0.22, 1, 0.36, 1);
}
.revealVisible {
opacity: 1;
transform: translateY(0);
}
.hero {
position: relative;
padding: 6rem 0 5rem;
overflow: hidden;
border-bottom: 1px solid rgba(122, 162, 247, 0.06);
}
.heroGlow {
position: absolute;
top: -180px;
left: 50%;
transform: translateX(-50%);
width: 800px;
height: 500px;
background: radial-gradient(ellipse, rgba(122, 162, 247, 0.12) 0%, transparent 70%);
pointer-events: none;
filter: blur(60px);
}
.heroGrid {
display: grid;
grid-template-columns: minmax(0, 1.1fr) minmax(320px, 0.9fr);
gap: 3.5rem;
align-items: center;
position: relative;
z-index: 1;
}
.heroCopy {
max-width: 640px;
}
.eyebrow {
display: inline-flex;
align-items: center;
gap: 0.5rem;
padding: 0.4rem 0.85rem;
border-radius: 999px;
border: 1px solid rgba(122, 162, 247, 0.15);
background: rgba(122, 162, 247, 0.06);
color: #9fbdfd;
font-size: 0.76rem;
font-weight: 700;
letter-spacing: 0.05em;
text-transform: uppercase;
}
.eyebrowDot {
width: 6px;
height: 6px;
border-radius: 999px;
background: #9ece6a;
box-shadow: 0 0 6px rgba(158, 206, 106, 0.6);
}
.heroTitle {
margin: 1.4rem 0 1.2rem;
font-size: clamp(2.8rem, 7vw, 4.6rem);
line-height: 1.02;
letter-spacing: -0.04em;
background: linear-gradient(135deg, #f4f7ff 30%, #7aa2f7 70%, #bb9af7 100%);
-webkit-background-clip: text;
-webkit-text-fill-color: transparent;
background-clip: text;
}
.heroSubtitle {
margin: 0 0 1.8rem;
font-size: 1.08rem;
line-height: 1.75;
color: #a5b2d4;
}
.heroActions {
display: flex;
flex-wrap: wrap;
gap: 0.75rem;
margin-bottom: 1.4rem;
}
.btnPrimary {
display: inline-flex;
align-items: center;
gap: 0.5rem;
padding: 0.78rem 1.4rem;
border-radius: 12px;
background: #7aa2f7;
color: #0d0f18 !important;
font-size: 0.95rem;
font-weight: 700;
text-decoration: none !important;
transition: transform 0.2s ease, background 0.2s ease, box-shadow 0.2s ease;
}
.btnPrimary:hover {
background: #96b5fb;
transform: translateY(-1px);
box-shadow: 0 6px 20px rgba(122, 162, 247, 0.25);
}
.btnGhost {
display: inline-flex;
align-items: center;
gap: 0.5rem;
padding: 0.78rem 1.4rem;
border-radius: 12px;
border: 1px solid rgba(122, 162, 247, 0.2);
background: rgba(122, 162, 247, 0.05);
color: #c3cce5 !important;
font-size: 0.95rem;
font-weight: 600;
text-decoration: none !important;
transition: transform 0.2s ease, border-color 0.2s ease, background 0.2s ease;
}
.btnGhost:hover {
border-color: rgba(122, 162, 247, 0.35);
background: rgba(122, 162, 247, 0.1);
transform: translateY(-1px);
}
.installRow {
display: flex;
flex-wrap: wrap;
gap: 0.6rem;
align-items: center;
margin-bottom: 1.1rem;
}
.installCode {
display: inline-flex;
align-items: center;
gap: 0.5rem;
padding: 0.78rem 1rem;
border-radius: 10px;
border: 1px solid rgba(122, 162, 247, 0.12);
background: rgba(9, 11, 18, 0.75);
color: #d9e1f7;
font-size: 0.92rem;
font-family: var(--ifm-font-family-monospace);
}
.installPrompt {
color: #9ece6a;
font-weight: 700;
}
.copyButton {
padding: 0.78rem 1rem;
min-width: 68px;
border: 0;
border-radius: 10px;
background: #7aa2f7;
color: #0d0f18;
font-size: 0.85rem;
font-weight: 700;
cursor: pointer;
transition: transform 0.2s ease, background 0.2s ease;
}
.copyButton:hover {
background: #96b5fb;
transform: translateY(-1px);
}
.langRow {
display: flex;
flex-wrap: wrap;
gap: 0.5rem;
}
.langBadge {
padding: 0.35rem 0.65rem;
border-radius: 8px;
background: rgba(255, 255, 255, 0.035);
border: 1px solid rgba(255, 255, 255, 0.06);
color: #8e9bbd;
font-size: 0.78rem;
font-weight: 600;
}
.heroVisual {
display: flex;
justify-content: flex-end;
}
.demoFrame {
width: 100%;
max-width: 700px;
overflow: hidden;
border-radius: 18px;
border: 1px solid rgba(122, 162, 247, 0.1);
background: #0b0d14;
box-shadow:
0 32px 80px rgba(0, 0, 0, 0.45),
0 0 0 1px rgba(122, 162, 247, 0.04);
}
.demoHeader {
display: flex;
align-items: center;
gap: 0.5rem;
padding: 0.75rem 1rem;
border-bottom: 1px solid rgba(255, 255, 255, 0.04);
background: rgba(255, 255, 255, 0.015);
}
.demoTitle {
margin-left: 0.5rem;
color: #565f89;
font-size: 0.78rem;
font-family: var(--ifm-font-family-monospace);
}
.dotRed,
.dotYellow,
.dotGreen {
width: 0.7rem;
height: 0.7rem;
border-radius: 999px;
}
.dotRed { background: #f7768e; }
.dotYellow { background: #e0af68; }
.dotGreen { background: #9ece6a; }
.demoImage {
display: block;
width: 100%;
height: auto;
}
.compatibility {
padding: 1rem 0;
border-top: 1px solid rgba(255, 255, 255, 0.03);
border-bottom: 1px solid rgba(255, 255, 255, 0.03);
background: rgba(255, 255, 255, 0.015);
}
.compatRow {
display: flex;
align-items: center;
justify-content: center;
gap: 1.5rem;
flex-wrap: wrap;
}
.compatLabel {
color: #565f89;
font-size: 0.72rem;
font-weight: 700;
text-transform: uppercase;
letter-spacing: 0.06em;
}
.compatLogos {
display: flex;
flex-wrap: wrap;
gap: 0.75rem 1.5rem;
align-items: center;
}
.compatItem {
color: #7c88a8;
font-size: 0.9rem;
font-weight: 500;
}
.section {
padding: 5.5rem 0;
}
.sectionAlt {
padding: 5.5rem 0;
background: rgba(255, 255, 255, 0.015);
border-top: 1px solid rgba(255, 255, 255, 0.03);
border-bottom: 1px solid rgba(255, 255, 255, 0.03);
}
.sectionHeader {
max-width: 700px;
margin: 0 auto 3rem;
text-align: center;
}
.sectionLabel {
display: inline-block;
padding: 0.3rem 0.7rem;
margin-bottom: 0.8rem;
border-radius: 8px;
background: rgba(122, 162, 247, 0.08);
border: 1px solid rgba(122, 162, 247, 0.12);
color: #9fbdfd;
font-size: 0.72rem;
font-weight: 700;
letter-spacing: 0.06em;
text-transform: uppercase;
}
.sectionHeader h2 {
margin-bottom: 0.75rem;
color: #f2f5ff;
font-size: clamp(1.8rem, 4vw, 2.6rem);
letter-spacing: -0.03em;
line-height: 1.15;
}
.sectionHeader p {
margin: 0;
color: #9daccc;
line-height: 1.75;
font-size: 1.02rem;
}
.featureGrid {
display: grid;
grid-template-columns: repeat(3, minmax(0, 1fr));
gap: 1.15rem;
}
.featureCard {
padding: 1.6rem;
border-radius: 16px;
border: 1px solid rgba(122, 162, 247, 0.08);
background: rgba(15, 19, 30, 0.7);
transition: border-color 0.3s ease, transform 0.3s ease;
}
.featureCard:hover {
border-color: rgba(122, 162, 247, 0.2);
transform: translateY(-3px);
}
.featureIcon {
display: flex;
align-items: center;
justify-content: center;
width: 2.8rem;
height: 2.8rem;
margin-bottom: 1rem;
border-radius: 12px;
background: rgba(122, 162, 247, 0.08);
border: 1px solid rgba(122, 162, 247, 0.1);
font-size: 1.2rem;
color: #7aa2f7;
}
.featureCard h3 {
margin-bottom: 0.55rem;
color: #edf2ff;
font-size: 1.02rem;
}
.featureCard p {
margin: 0;
color: #8e9bbd;
line-height: 1.65;
font-size: 0.92rem;
}
.scoreGrid {
display: grid;
grid-template-columns: repeat(3, minmax(0, 1fr));
gap: 1rem;
margin-bottom: 2.5rem;
}
.scoreCard {
padding: 1.3rem;
border-radius: 14px;
border: 1px solid rgba(255, 255, 255, 0.05);
background: rgba(15, 19, 30, 0.6);
}
.scoreBar {
height: 4px;
border-radius: 4px;
background: rgba(255, 255, 255, 0.04);
margin-bottom: 0.9rem;
overflow: hidden;
}
.scoreBarFill {
height: 100%;
border-radius: 4px;
transition: width 0.8s cubic-bezier(0.22, 1, 0.36, 1);
}
.scoreInfo {
display: flex;
justify-content: space-between;
align-items: baseline;
margin-bottom: 0.35rem;
}
.scoreName {
font-weight: 700;
font-size: 0.95rem;
}
.scoreWeight {
color: #565f89;
font-size: 0.82rem;
font-weight: 600;
}
.scoreDesc {
margin: 0;
color: #7c88a8;
font-size: 0.82rem;
line-height: 1.5;
}
.scoreRanges {
display: flex;
align-items: center;
justify-content: center;
gap: 1.5rem;
padding: 1.2rem 1.5rem;
border-radius: 14px;
border: 1px solid rgba(255, 255, 255, 0.05);
background: rgba(15, 19, 30, 0.5);
}
.rangeItem {
display: flex;
align-items: baseline;
gap: 0.5rem;
}
.rangeScore {
font-weight: 800;
font-size: 1rem;
font-family: var(--ifm-font-family-monospace);
}
.rangeLabel {
color: #7c88a8;
font-size: 0.82rem;
}
.rangeDivider {
width: 1px;
height: 20px;
background: rgba(255, 255, 255, 0.08);
}
.workflowLayout {
display: grid;
grid-template-columns: minmax(0, 1.2fr) minmax(280px, 0.8fr);
gap: 2rem;
align-items: start;
}
.workflowLeft h2 {
margin-bottom: 0.7rem;
color: #f2f5ff;
font-size: clamp(1.8rem, 4vw, 2.4rem);
letter-spacing: -0.03em;
}
.workflowDesc {
margin: 0 0 1.5rem;
color: #9daccc;
line-height: 1.75;
font-size: 1rem;
}
.stepList {
display: grid;
gap: 0;
}
.stepItem {
display: grid;
grid-template-columns: 52px minmax(0, 1fr);
gap: 1rem;
padding: 1.1rem 0;
border-top: 1px solid rgba(255, 255, 255, 0.06);
}
.stepItem:first-child {
border-top: 0;
}
.stepNumber {
display: flex;
align-items: center;
justify-content: center;
width: 2.8rem;
height: 2.8rem;
border-radius: 12px;
background: rgba(122, 162, 247, 0.1);
color: #9fbdfd;
font-weight: 800;
font-size: 0.85rem;
font-family: var(--ifm-font-family-monospace);
}
.stepContent h3 {
margin-bottom: 0.4rem;
color: #edf2ff;
font-size: 1.02rem;
}
.stepContent p {
margin: 0;
color: #8e9bbd;
line-height: 1.65;
font-size: 0.92rem;
}
.workflowAside {
padding: 1.6rem;
border-radius: 16px;
border: 1px solid rgba(122, 162, 247, 0.1);
background: rgba(15, 19, 30, 0.7);
}
.workflowAside h3 {
margin-bottom: 1rem;
color: #edf2ff;
font-size: 1.05rem;
}
.checkList {
margin: 0;
padding: 0;
list-style: none;
}
.checkList li {
display: flex;
align-items: flex-start;
gap: 0.6rem;
margin-bottom: 0.7rem;
color: #9daccc;
font-size: 0.92rem;
line-height: 1.55;
}
.checkIcon {
flex-shrink: 0;
color: #9ece6a;
font-weight: 700;
font-size: 0.85rem;
margin-top: 1px;
}
.aiLayout {
display: grid;
grid-template-columns: minmax(0, 1fr) minmax(320px, 1fr);
gap: 2.5rem;
align-items: center;
}
.aiContent h2 {
margin-bottom: 0.75rem;
color: #f2f5ff;
font-size: clamp(1.8rem, 4vw, 2.4rem);
letter-spacing: -0.03em;
}
.aiDesc {
margin: 0 0 1.5rem;
color: #9daccc;
line-height: 1.75;
font-size: 1rem;
}
.aiDesc code {
padding: 0.15rem 0.45rem;
border-radius: 6px;
background: rgba(122, 162, 247, 0.12);
color: #7aa2f7;
font-size: 0.9rem;
}
.aiExamples {
display: grid;
gap: 0.6rem;
margin-bottom: 1.5rem;
}
.aiExample {
display: flex;
align-items: flex-start;
gap: 0.6rem;
padding: 0.7rem 0.9rem;
border-radius: 10px;
background: rgba(122, 162, 247, 0.04);
border: 1px solid rgba(122, 162, 247, 0.06);
color: #a5b2d4;
font-size: 0.9rem;
line-height: 1.5;
}
.aiQ {
color: #7aa2f7;
font-weight: 700;
flex-shrink: 0;
}
.aiProviders {
display: flex;
flex-wrap: wrap;
align-items: center;
gap: 0.5rem;
}
.aiProviderLabel {
color: #565f89;
font-size: 0.72rem;
font-weight: 700;
text-transform: uppercase;
letter-spacing: 0.05em;
}
.aiProvider {
padding: 0.3rem 0.6rem;
border-radius: 8px;
background: rgba(187, 154, 247, 0.06);
border: 1px solid rgba(187, 154, 247, 0.1);
color: #bb9af7;
font-size: 0.78rem;
font-weight: 600;
}
.aiTerminal {
border-radius: 16px;
border: 1px solid rgba(187, 154, 247, 0.1);
background: #0b0d14;
overflow: hidden;
box-shadow: 0 24px 60px rgba(0, 0, 0, 0.4);
}
.aiTermHeader {
display: flex;
align-items: center;
gap: 0.5rem;
padding: 0.75rem 1rem;
border-bottom: 1px solid rgba(255, 255, 255, 0.04);
background: rgba(255, 255, 255, 0.015);
}
.aiTermTitle {
margin-left: 0.5rem;
color: #bb9af7;
font-size: 0.78rem;
font-weight: 600;
}
.aiTermBody {
padding: 1.2rem;
display: grid;
gap: 1rem;
}
.aiMsg {
font-size: 0.88rem;
line-height: 1.6;
color: #a5b2d4;
}
.aiMsgUser {
display: block;
margin-bottom: 0.25rem;
color: #7aa2f7;
font-weight: 700;
font-size: 0.78rem;
}
.aiMsgAI {
display: block;
margin-bottom: 0.25rem;
color: #bb9af7;
font-weight: 700;
font-size: 0.78rem;
}
.aiHighlight {
padding: 0.1rem 0.35rem;
border-radius: 4px;
background: rgba(122, 162, 247, 0.12);
color: #7aa2f7;
font-weight: 600;
font-family: var(--ifm-font-family-monospace);
font-size: 0.85rem;
}
.installPanel {
max-width: 640px;
margin: 0 auto 2.5rem;
border-radius: 16px;
border: 1px solid rgba(122, 162, 247, 0.1);
background: rgba(15, 19, 30, 0.7);
overflow: hidden;
}
.installTabs {
display: flex;
border-bottom: 1px solid rgba(255, 255, 255, 0.04);
}
.installTab {
flex: 1;
padding: 0.75rem 1rem;
border: 0;
background: transparent;
color: #565f89;
font-size: 0.85rem;
font-weight: 600;
cursor: pointer;
transition: color 0.2s, background 0.2s;
}
.installTab:hover {
color: #a5b2d4;
background: rgba(255, 255, 255, 0.02);
}
.installTabActive {
color: #7aa2f7;
background: rgba(122, 162, 247, 0.06);
box-shadow: inset 0 -2px 0 #7aa2f7;
}
.installBody {
display: flex;
align-items: center;
gap: 0.75rem;
padding: 1.2rem;
}
.installCmd {
flex: 1;
display: flex;
align-items: center;
gap: 0.5rem;
padding: 0.7rem 0.9rem;
border-radius: 10px;
background: rgba(9, 11, 18, 0.6);
border: 1px solid rgba(255, 255, 255, 0.04);
color: #d9e1f7;
font-size: 0.9rem;
font-family: var(--ifm-font-family-monospace);
white-space: nowrap;
overflow-x: auto;
}
.installCopy {
padding: 0.65rem 0.9rem;
min-width: 60px;
border: 0;
border-radius: 10px;
background: #7aa2f7;
color: #0d0f18;
font-size: 0.82rem;
font-weight: 700;
cursor: pointer;
flex-shrink: 0;
transition: background 0.2s;
}
.installCopy:hover {
background: #96b5fb;
}
.installAlso {
padding: 0.75rem 1.2rem;
border-top: 1px solid rgba(255, 255, 255, 0.03);
color: #565f89;
font-size: 0.82rem;
text-align: center;
}
.installAlso a {
color: #7aa2f7;
text-decoration: none;
}
.installAlso a:hover {
text-decoration: underline;
}
.quickRun {
display: flex;
align-items: center;
justify-content: center;
gap: 1.5rem;
flex-wrap: wrap;
}
.quickRunStep {
display: flex;
align-items: flex-start;
gap: 0.75rem;
}
.quickRunNum {
display: flex;
align-items: center;
justify-content: center;
width: 2rem;
height: 2rem;
border-radius: 8px;
background: rgba(122, 162, 247, 0.1);
color: #7aa2f7;
font-weight: 800;
font-size: 0.82rem;
flex-shrink: 0;
margin-top: 2px;
}
.quickRunStep strong {
display: block;
color: #edf2ff;
font-size: 0.88rem;
margin-bottom: 0.2rem;
}
.quickRunStep code {
display: block;
color: #7c88a8;
font-size: 0.82rem;
font-family: var(--ifm-font-family-monospace);
}
.quickRunArrow {
color: #363d54;
font-size: 1.2rem;
font-weight: 700;
}
.audienceGrid {
display: grid;
grid-template-columns: repeat(3, minmax(0, 1fr));
gap: 1.15rem;
}
.audienceCard {
position: relative;
padding: 1.6rem;
padding-top: 1.8rem;
border-radius: 16px;
border: 1px solid rgba(255, 255, 255, 0.05);
background: rgba(15, 19, 30, 0.6);
overflow: hidden;
transition: border-color 0.3s ease, transform 0.3s ease;
}
.audienceCard:hover {
border-color: rgba(122, 162, 247, 0.15);
transform: translateY(-3px);
}
.audienceAccent {
position: absolute;
top: 0;
left: 1.5rem;
right: 1.5rem;
height: 2px;
border-radius: 0 0 4px 4px;
opacity: 0.6;
}
.audienceCard h3 {
margin-bottom: 0.55rem;
color: #edf2ff;
font-size: 1.05rem;
}
.audienceCard p {
margin: 0;
color: #8e9bbd;
line-height: 1.65;
font-size: 0.92rem;
}
.ossPanel {
display: grid;
grid-template-columns: minmax(0, 1.2fr) minmax(260px, 0.8fr);
gap: 2rem;
align-items: center;
padding: 2.5rem;
border-radius: 20px;
border: 1px solid rgba(122, 162, 247, 0.08);
background:
radial-gradient(ellipse at top left, rgba(122, 162, 247, 0.06), transparent 50%),
rgba(13, 17, 26, 0.6);
}
.ossContent h2 {
margin-bottom: 0.7rem;
color: #f2f5ff;
font-size: clamp(1.8rem, 4vw, 2.4rem);
letter-spacing: -0.03em;
}
.ossContent p {
margin: 0 0 1.5rem;
color: #9daccc;
line-height: 1.75;
font-size: 1rem;
}
.ossActions {
display: flex;
flex-wrap: wrap;
gap: 0.75rem;
}
.ossBadges {
display: grid;
gap: 0.75rem;
}
.ossBadge {
padding: 1rem 1.2rem;
border-radius: 12px;
border: 1px solid rgba(255, 255, 255, 0.05);
background: rgba(255, 255, 255, 0.02);
text-align: center;
}
.ossBadgeValue {
display: block;
color: #edf2ff;
font-weight: 700;
font-size: 0.95rem;
margin-bottom: 0.15rem;
}
.ossBadgeLabel {
color: #565f89;
font-size: 0.72rem;
font-weight: 600;
text-transform: uppercase;
letter-spacing: 0.05em;
}
.finalCta {
padding: 5rem 0 6rem;
}
.ctaInner {
position: relative;
padding: 3rem 2rem;
border-radius: 24px;
border: 1px solid rgba(122, 162, 247, 0.1);
background: rgba(13, 17, 26, 0.8);
text-align: center;
overflow: hidden;
}
.ctaGlow {
position: absolute;
top: -100px;
left: 50%;
transform: translateX(-50%);
width: 500px;
height: 300px;
background: radial-gradient(ellipse, rgba(122, 162, 247, 0.1), transparent 70%);
pointer-events: none;
filter: blur(50px);
}
.ctaInner h2 {
position: relative;
margin-bottom: 0.7rem;
color: #f2f5ff;
font-size: clamp(1.8rem, 4vw, 2.6rem);
letter-spacing: -0.03em;
}
.ctaInner p {
position: relative;
max-width: 540px;
margin: 0 auto 1.5rem;
color: #9daccc;
line-height: 1.75;
font-size: 1.02rem;
}
.ctaActions {
position: relative;
display: flex;
flex-wrap: wrap;
gap: 0.75rem;
justify-content: center;
}
@media (max-width: 996px) {
.hero {
padding: 4rem 0 3rem;
}
.heroGrid,
.workflowLayout,
.aiLayout,
.ossPanel {
grid-template-columns: 1fr;
}
.heroCopy {
max-width: none;
}
.heroVisual {
justify-content: stretch;
}
.featureGrid,
.scoreGrid,
.audienceGrid {
grid-template-columns: repeat(2, minmax(0, 1fr));
}
.scoreRanges {
flex-wrap: wrap;
gap: 1rem;
}
}
@media (max-width: 640px) {
.heroTitle {
font-size: 2.4rem;
}
.heroActions,
.ossActions,
.ctaActions,
.installRow {
flex-direction: column;
align-items: stretch;
}
.featureGrid,
.scoreGrid,
.audienceGrid {
grid-template-columns: 1fr;
}
.quickRun {
flex-direction: column;
align-items: flex-start;
}
.quickRunArrow {
transform: rotate(90deg);
align-self: center;
}
.scoreRanges {
flex-direction: column;
align-items: flex-start;
}
.rangeDivider {
width: 40px;
height: 1px;
}
.compatRow {
flex-direction: column;
gap: 0.75rem;
}
.stepItem {
grid-template-columns: 1fr;
}
.stepNumber {
width: 2.2rem;
height: 2.2rem;
}
}