Files
3d-homepage-zozomu/styles.css
2026-02-20 21:11:09 +00:00

473 lines
12 KiB
CSS
Raw Blame History

This file contains ambiguous Unicode characters
This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.
/*
═══════════════════════════════════════════════════════════════════
LUMEREL — 3D Hero Page
Font : General Sans (Fontshare)
Theme : Pure black · Web3 · Spline-ready
═══════════════════════════════════════════════════════════════════
*/
/* ── Reset & Base ──────────────────────────────────────────────────── */
*, *::before, *::after {
box-sizing: border-box;
margin: 0;
padding: 0;
}
html, body {
width: 100%;
height: 100%;
background: #000000;
color: #ffffff;
font-family: 'General Sans', system-ui, -apple-system, sans-serif;
-webkit-font-smoothing: antialiased;
-moz-osx-font-smoothing: grayscale;
overflow-x: hidden;
}
a {
text-decoration: none;
color: inherit;
}
ul {
list-style: none;
}
button {
cursor: pointer;
border: none;
background: none;
font-family: inherit;
}
/*
═══════════════════════════════════════════════════════════════════
HERO SECTION
Full-screen · layers: video → 3D → navbar → content
═══════════════════════════════════════════════════════════════════
*/
.hero {
position: relative;
width: 100%;
min-height: 100dvh;
background: #000000;
overflow: hidden;
}
/* ── Layer 0 · Background Video ──────────────────────────────────── */
.hero__video-wrap {
position: absolute;
inset: 0;
z-index: 0;
}
.hero__video {
width: 100%;
height: 100%;
object-fit: cover;
display: block;
}
/* Exactly 50% black overlay */
.hero__overlay {
position: absolute;
inset: 0;
background: rgba(0, 0, 0, 0.50);
}
/* ── Layer 1 · 3D / Spline ───────────────────────────────────────────
Above video (z-index: 1), below all UI (z-index: 2+).
pointer-events: none keeps buttons & links fully clickable.
Call window.Lumerel.enableSpline() for interactive scenes.
─────────────────────────────────────────────────────────────────────── */
.hero__3d-layer {
position: absolute;
inset: 0;
z-index: 1;
pointer-events: none;
}
/* Spline viewer fills the full layer */
.hero__3d-layer spline-viewer {
width: 100%;
height: 100%;
display: block;
}
/* ── 3D Placeholder Orbs ─────────────────────────────────────────────
Animated ambient orbs simulate depth until Spline assets arrive.
Delete .spline-placeholder when adding <spline-viewer>.
─────────────────────────────────────────────────────────────────────── */
.spline-placeholder {
position: relative;
width: 100%;
height: 100%;
}
.orb {
position: absolute;
border-radius: 50%;
filter: blur(80px);
opacity: 0.18;
}
.orb--violet {
width: 520px;
height: 520px;
background: radial-gradient(circle, #7c3aed 0%, #4f46e5 55%, transparent 100%);
top: 8%;
right: 5%;
animation: orbDrift 11s ease-in-out infinite;
}
.orb--cyan {
width: 360px;
height: 360px;
background: radial-gradient(circle, #06b6d4 0%, #3b82f6 55%, transparent 100%);
bottom: 14%;
left: 4%;
animation: orbDrift 13s ease-in-out infinite reverse;
animation-delay: -5s;
}
.orb--pink {
width: 260px;
height: 260px;
background: radial-gradient(circle, #f0abfc 0%, #a78bfa 55%, transparent 100%);
top: 50%;
left: 50%;
transform: translate(-50%, -50%);
animation: orbDriftCenter 9s ease-in-out infinite;
animation-delay: -3s;
}
@keyframes orbDrift {
0%, 100% { transform: translate(0, 0) scale(1); }
33% { transform: translate(-20px, -30px) scale(1.06); }
66% { transform: translate(16px, 22px) scale(0.95); }
}
@keyframes orbDriftCenter {
0%, 100% { transform: translate(-50%, -50%) scale(1); }
40% { transform: translate(-50%, -60%) scale(1.08); }
75% { transform: translate(-50%, -44%) scale(0.94); }
}
/* Placeholder label */
.spline-placeholder__label {
position: absolute;
bottom: 32px;
left: 50%;
transform: translateX(-50%);
font-size: 11px;
font-weight: 500;
letter-spacing: 0.10em;
text-transform: uppercase;
color: rgba(255, 255, 255, 0.20);
white-space: nowrap;
border: 1px solid rgba(255, 255, 255, 0.08);
padding: 6px 14px;
border-radius: 100px;
}
/*
═══════════════════════════════════════════════════════════════════
NAVBAR
z-index: 10 · fixed at top · 120px horizontal / 20px vertical padding
═══════════════════════════════════════════════════════════════════
*/
.navbar {
position: fixed;
top: 0;
left: 0;
right: 0;
z-index: 10;
transition: background 0.25s ease, backdrop-filter 0.25s ease;
}
.navbar__inner {
display: flex;
align-items: center;
justify-content: space-between;
padding: 20px 120px;
}
.navbar__left {
display: flex;
align-items: center;
gap: 40px;
}
/* Logo — exactly 187×25px */
.navbar__logo {
display: flex;
align-items: center;
flex-shrink: 0;
width: 187px;
height: 25px;
}
.navbar__logo svg {
width: 187px;
height: 25px;
overflow: visible;
}
/* Nav links — hidden on mobile (<768px) */
.navbar__links {
display: flex;
align-items: center;
gap: 30px;
}
.navbar__link {
display: inline-flex;
align-items: center;
gap: 6px;
font-size: 14px;
font-weight: 500;
color: #ffffff;
white-space: nowrap;
transition: opacity 0.15s ease;
}
.navbar__link:hover {
opacity: 0.75;
}
.navbar__chevron {
flex-shrink: 0;
width: 14px;
height: 14px;
}
/*
═══════════════════════════════════════════════════════════════════
PILL BUTTON
Layered construction:
1. Outer: box-shadow 0.6px white ring
2. Glow: blurred white radial streak at top edge
3. Inner: pill with text
Two variants: --dark (navbar) and --light (CTA)
═══════════════════════════════════════════════════════════════════
*/
.btn-pill {
position: relative;
display: inline-flex;
align-items: center;
justify-content: center;
border-radius: 100px;
/* 0.6px white outer border via box-shadow */
box-shadow: 0 0 0 0.6px rgba(255, 255, 255, 1);
overflow: hidden;
flex-shrink: 0;
font-family: inherit;
transition: opacity 0.15s ease, transform 0.15s ease;
}
.btn-pill:hover {
opacity: 0.88;
transform: translateY(-1px);
}
.btn-pill:active {
transform: translateY(0);
opacity: 1;
}
/* Glow streak — blurred white gradient at top edge */
.btn-pill__glow {
pointer-events: none;
position: absolute;
top: -4px;
left: 50%;
transform: translateX(-50%);
width: 70%;
height: 20px;
border-radius: 50%;
background: radial-gradient(ellipse at center top, rgba(255,255,255,0.55) 0%, rgba(255,255,255,0) 70%);
filter: blur(4px);
z-index: 1;
}
/* Button label sits above glow */
.btn-pill__label {
position: relative;
z-index: 2;
font-size: 14px;
font-weight: 500;
line-height: 1;
padding: 11px 29px;
white-space: nowrap;
}
/* Dark variant — black background, white text (navbar) */
.btn-pill--dark {
background: #000000;
}
.btn-pill--dark .btn-pill__label {
color: #ffffff;
}
/* Light variant — white background, black text (hero CTA) */
.btn-pill--light {
background: #ffffff;
box-shadow: 0 0 0 0.6px rgba(255, 255, 255, 0.9);
}
.btn-pill--light .btn-pill__label {
color: #000000;
}
/*
═══════════════════════════════════════════════════════════════════
HERO CONTENT
z-index: 3 · centered · 280px top padding desktop / 200px mobile
═══════════════════════════════════════════════════════════════════
*/
.hero__content {
position: relative;
z-index: 3;
display: flex;
flex-direction: column;
align-items: center;
text-align: center;
gap: 40px;
padding-top: 280px;
padding-bottom: 102px;
padding-left: 24px;
padding-right: 24px;
}
/* ── Badge / Pill ────────────────────────────────────────────────── */
.hero__badge {
display: inline-flex;
align-items: center;
gap: 8px;
background: rgba(255, 255, 255, 0.10);
border: 1px solid rgba(255, 255, 255, 0.20);
border-radius: 20px;
padding: 7px 14px;
}
/* 4px white dot */
.hero__badge-dot {
display: block;
width: 4px;
height: 4px;
border-radius: 50%;
background: #ffffff;
flex-shrink: 0;
}
.hero__badge-text {
font-size: 13px;
font-weight: 500;
line-height: 1;
}
.hero__badge-dim {
color: rgba(255, 255, 255, 0.60);
}
.hero__badge-bright {
color: #ffffff;
}
/* ── Heading ─────────────────────────────────────────────────────── */
.hero__heading {
max-width: 613px;
font-size: 56px;
font-weight: 500;
line-height: 1.28;
letter-spacing: -0.01em;
/* Gradient text — 144.5deg, white at 28% → transparent black at 115% */
background: linear-gradient(
144.5deg,
#ffffff 28%,
rgba(0, 0, 0, 0) 115%
);
-webkit-background-clip: text;
-webkit-text-fill-color: transparent;
background-clip: text;
color: transparent;
}
/* ── Subtitle ────────────────────────────────────────────────────── */
.hero__subtitle {
max-width: 680px;
font-size: 15px;
font-weight: 400;
line-height: 1.65;
color: rgba(255, 255, 255, 0.70);
/* Collapse the 40px gap to achieve 24px from heading */
margin-top: -16px;
}
/*
═══════════════════════════════════════════════════════════════════
RESPONSIVE
═══════════════════════════════════════════════════════════════════
*/
/* Large desktop — keep full 120px padding */
@media (max-width: 1280px) {
.navbar__inner {
padding: 20px 80px;
}
}
/* Tablet — reduce navbar padding */
@media (max-width: 1024px) {
.navbar__inner {
padding: 20px 48px;
}
}
/* Mobile — collapse nav links, reduce padding */
@media (max-width: 767px) {
.navbar__inner {
padding: 20px 24px;
}
/* Hide nav links on mobile */
.navbar__links {
display: none;
}
/* Reduce logo width slightly to fit */
.navbar__logo,
.navbar__logo svg {
width: 140px;
}
/* Hero content */
.hero__content {
padding-top: 200px;
gap: 32px;
}
/* Heading scales down */
.hero__heading {
font-size: 36px;
}
/* Subtitle margin adjustment for mobile gap */
.hero__subtitle {
margin-top: -8px;
}
}
@media (max-width: 480px) {
.hero__heading {
font-size: 32px;
}
.navbar__logo,
.navbar__logo svg {
width: 120px;
}
}