@use "../../../styles/patterns"; .home-page { --home-bg: #faf9f6; --color-bg-card: #ffffff; background: var(--home-bg); } .hero { position: relative; padding: 6rem 0 5rem; overflow: hidden; background: var(--home-bg); &::after { content: ""; position: absolute; inset: 0; @include patterns.pattern-grid(var(--color-neutral-900), 40px, 1px); opacity: 0.06; z-index: 0; pointer-events: none; mask-image: linear-gradient(to bottom, black 70%, transparent 100%); } } .hero::before { content: ""; position: absolute; width: 420px; height: 420px; right: -120px; top: -160px; background: radial-gradient( circle at 30% 30%, rgba(0, 0, 0, 0.03), transparent 70% ); opacity: 0.8; z-index: 0; animation: floatGlow 12s ease-in-out infinite; } .hero-copy { animation: fadeUp 0.8s ease both; } .capabilities { position: relative; border-bottom: 1px solid var(--color-border); padding-top: 4.5rem; } .capabilities-bg { display: none; } .calculator { position: relative; border-bottom: 1px solid var(--color-border); } .calculator-list { padding-left: var(--space-4); color: var(--color-text-muted); margin: var(--space-6) 0 0; } .cap-cards { display: grid; gap: var(--space-4); grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); } .quote-card { display: block; } .shop { background: var(--home-bg); position: relative; } .shop .split { align-items: start; } .shop-copy { max-width: 760px; } .shop-list { padding-left: var(--space-4); color: var(--color-text-muted); margin-bottom: var(--space-6); } .shop-gallery { width: min(100%, 440px); justify-self: end; aspect-ratio: 16 / 11; } .shop-gallery-item { aspect-ratio: 16 / 10; } .shop-cards { display: grid; gap: var(--space-4); grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); } .shop-cards h3 { margin-top: 0; margin-bottom: var(--space-2); } .shop-cards p { margin: 0; } .about { background: transparent; border-top: 1px solid var(--color-border); position: relative; } .about-media { position: relative; display: flex; justify-content: flex-end; } .about-feature-photo { position: absolute; inset: 0; width: 100%; height: 100%; display: block; object-fit: cover; } .founder-nav-prev { left: 0.75rem; } .founder-nav-next { right: 0.75rem; } @media (min-width: 960px) { .shop-copy { grid-column: 1; } .shop-gallery { grid-column: 2; } .shop-cards { grid-column: 1 / -1; grid-template-columns: repeat(3, minmax(0, 1fr)); } } @media (max-width: 640px) { .shop-gallery { width: 100%; max-width: none; justify-self: stretch; } .shop-gallery-item { aspect-ratio: 16 / 11; } .shop-cards { grid-template-columns: 1fr; } .about-media { justify-content: flex-start; } .about-feature-image { max-width: min(100%, 360px); aspect-ratio: 16 / 11; } } @keyframes fadeUp { from { opacity: 0; transform: translateY(18px); } to { opacity: 1; transform: translateY(0); } } @keyframes floatGlow { 0%, 100% { transform: translateY(0); } 50% { transform: translateY(20px); } } @media (prefers-reduced-motion: reduce) { .hero-copy { animation: none; } .hero::before { animation: none; } }