@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; } .hero-grid { align-items: start; } .hero-swiss-card { --swiss-red: #d52b1e; align-self: center; justify-self: center; width: min(100%, 340px); padding: 1rem 1.1rem; border: 1px solid var(--color-border); border-left: 4px solid var(--color-brand); border-radius: 12px; background: #fff; animation: fadeUp 0.85s ease both; } .hero-swiss-head { display: flex; align-items: center; gap: 0.5rem; margin-bottom: 0.4rem; } .hero-swiss-emblem { width: 1.3rem; height: 1.3rem; border-radius: 4px; background: var(--swiss-red); display: inline-grid; place-items: center; } .hero-swiss-cross { position: relative; width: 0.86rem; height: 0.86rem; display: block; } .hero-swiss-cross::before, .hero-swiss-cross::after { content: ""; position: absolute; background: #fff; border-radius: 1px; } .hero-swiss-cross::before { width: 0.28rem; height: 100%; left: calc(50% - 0.14rem); top: 0; } .hero-swiss-cross::after { width: 100%; height: 0.28rem; left: 0; top: calc(50% - 0.14rem); } .hero-swiss-kicker { margin: 0; color: var(--color-text); } .hero-swiss-copy { margin: 0 0 0.7rem; color: var(--color-text); font-weight: 500; line-height: 1.4; } .hero-swiss-locations { display: flex; flex-wrap: wrap; gap: 0.4rem; } .hero-swiss-chip { display: inline-flex; align-items: center; min-height: 1.75rem; padding: 0.2rem 0.58rem; border-radius: 999px; border: 1px solid rgba(14, 24, 38, 0.14); background: #fff; font-size: 0.84rem; font-weight: 600; color: #2a2f36; } .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) { .hero-swiss-card { align-self: start; justify-self: center; width: min(100%, 340px); margin-top: 1rem; } .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; } }