main { max-width: 1400px; margin: 0 auto; padding: 40px 20px; min-height: 100vh; } @media (max-width: 768px) { main { padding: 20px 12px; } } h1 { font-size: 42px; font-weight: 700; margin-bottom: 16px; color: #2c3e50; } @media (max-width: 768px) { h1 { font-size: 32px; } } .subtitle { color: var(--text); margin: 0; } .status { display: inline-block; margin-bottom: 40px; padding: 8px 16px; border-radius: 6px; font-size: 13px; font-weight: 500; } .status--loading { background: #f5f5f5; color: #666; } .status--ok { background: #f5f5f5; color: #666; } .status--error { background: #ffebee; color: #c62828; } .error-message { position: fixed; top: 20px; right: 20px; background: #ffebee; color: #c62828; padding: 12px 16px; border-radius: 6px; box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15); z-index: 1000; display: flex; align-items: center; gap: 12px; max-width: 400px; animation: slideIn 0.3s ease; } @media (max-width: 768px) { .error-message { left: 12px; right: 12px; max-width: none; } } @keyframes slideIn { from { transform: translateX(100%); opacity: 0; } to { transform: translateX(0); opacity: 1; } } .error-dismiss { background: none; border: none; color: #c62828; cursor: pointer; font-size: 18px; padding: 0; width: 24px; height: 24px; display: flex; align-items: center; justify-content: center; flex-shrink: 0; } .error-dismiss:hover { opacity: 0.7; } .hero { position: relative; .base, .framework, .vite { inset-inline: 0; margin: 0 auto; } .base { width: 170px; position: relative; z-index: 0; } .framework, .vite { position: absolute; } .framework { z-index: 1; top: 34px; height: 28px; transform: perspective(2000px) rotateZ(300deg) rotateX(44deg) rotateY(39deg) scale(1.4); } .vite { z-index: 0; top: 107px; height: 26px; width: auto; transform: perspective(2000px) rotateZ(300deg) rotateX(40deg) rotateY(39deg) scale(0.8); } } #center { display: flex; flex-direction: column; gap: 25px; place-content: center; place-items: center; flex-grow: 1; @media (max-width: 1024px) { padding: 32px 20px 24px; gap: 18px; } } #next-steps { display: flex; border-top: 1px solid var(--border); text-align: left; & > div { flex: 1 1 0; padding: 32px; @media (max-width: 1024px) { padding: 24px 20px; } } .icon { margin-bottom: 16px; width: 22px; height: 22px; } @media (max-width: 1024px) { flex-direction: column; text-align: center; } } #docs { border-right: 1px solid var(--border); @media (max-width: 1024px) { border-right: none; border-bottom: 1px solid var(--border); } } #next-steps ul { list-style: none; padding: 0; display: flex; gap: 8px; margin: 32px 0 0; .logo { height: 18px; } a { color: var(--text-h); font-size: 16px; border-radius: 6px; background: var(--social-bg); display: flex; padding: 6px 12px; align-items: center; gap: 8px; text-decoration: none; transition: box-shadow 0.3s; &:hover { box-shadow: var(--shadow); } .button-icon { height: 18px; width: 18px; } } @media (max-width: 1024px) { margin-top: 20px; flex-wrap: wrap; justify-content: center; li { flex: 1 1 calc(50% - 8px); } a { width: 100%; justify-content: center; box-sizing: border-box; } } } #spacer { height: 88px; border-top: 1px solid var(--border); @media (max-width: 1024px) { height: 48px; } } .ticks { position: relative; width: 100%; &::before, &::after { content: ''; position: absolute; top: -4.5px; border: 5px solid transparent; } &::before { left: 0; border-left-color: var(--border); } &::after { right: 0; border-right-color: var(--border); } }