@import url("https://fonts.googleapis.com/css2?family=Fraunces:opsz,wght@9..144,500;9..144,700&family=Manrope:wght@400;500;600;700;800&display=swap"); @import "tailwindcss"; @plugin "@tailwindcss/typography"; @theme { --font-sans: "Manrope", ui-sans-serif, system-ui, sans-serif; } :root { --sea-ink: #173a40; --sea-ink-soft: #416166; --lagoon: #4fb8b2; --lagoon-deep: #328f97; --palm: #2f6a4a; --sand: #e7f0e8; --foam: #f3faf5; --surface: rgba(255, 255, 255, 0.74); --surface-strong: rgba(255, 255, 255, 0.9); --line: rgba(23, 58, 64, 0.14); --inset-glint: rgba(255, 255, 255, 0.82); --kicker: rgba(47, 106, 74, 0.9); --bg-base: #e7f3ec; --header-bg: rgba(251, 255, 248, 0.84); --chip-bg: rgba(255, 255, 255, 0.8); --chip-line: rgba(47, 106, 74, 0.18); --link-bg-hover: rgba(255, 255, 255, 0.9); --hero-a: rgba(79, 184, 178, 0.36); --hero-b: rgba(47, 106, 74, 0.2); } :root[data-theme="dark"] { --sea-ink: #d7ece8; --sea-ink-soft: #afcdc8; --lagoon: #60d7cf; --lagoon-deep: #8de5db; --palm: #6ec89a; --sand: #0f1a1e; --foam: #101d22; --surface: rgba(16, 30, 34, 0.8); --surface-strong: rgba(15, 27, 31, 0.92); --line: rgba(141, 229, 219, 0.18); --inset-glint: rgba(194, 247, 238, 0.14); --kicker: #b8efe5; --bg-base: #0a1418; --header-bg: rgba(10, 20, 24, 0.8); --chip-bg: rgba(13, 28, 32, 0.9); --chip-line: rgba(141, 229, 219, 0.24); --link-bg-hover: rgba(24, 44, 49, 0.8); --hero-a: rgba(96, 215, 207, 0.18); --hero-b: rgba(110, 200, 154, 0.12); } @media (prefers-color-scheme: dark) { :root:not([data-theme="light"]) { --sea-ink: #d7ece8; --sea-ink-soft: #afcdc8; --lagoon: #60d7cf; --lagoon-deep: #8de5db; --palm: #6ec89a; --sand: #0f1a1e; --foam: #101d22; --surface: rgba(16, 30, 34, 0.8); --surface-strong: rgba(15, 27, 31, 0.92); --line: rgba(141, 229, 219, 0.18); --inset-glint: rgba(194, 247, 238, 0.14); --kicker: #b8efe5; --bg-base: #0a1418; --header-bg: rgba(10, 20, 24, 0.8); --chip-bg: rgba(13, 28, 32, 0.9); --chip-line: rgba(141, 229, 219, 0.24); --link-bg-hover: rgba(24, 44, 49, 0.8); --hero-a: rgba(96, 215, 207, 0.18); --hero-b: rgba(110, 200, 154, 0.12); } } * { box-sizing: border-box; } html, body, #app { min-height: 100%; } body { margin: 0; color: var(--sea-ink); font-family: var(--font-sans); background-color: var(--bg-base); background: radial-gradient(1100px 620px at -8% -10%, var(--hero-a), transparent 58%), radial-gradient(1050px 620px at 112% -12%, var(--hero-b), transparent 62%), radial-gradient(720px 380px at 50% 115%, rgba(79, 184, 178, 0.1), transparent 68%), linear-gradient(180deg, color-mix(in oklab, var(--sand) 68%, white) 0%, var(--foam) 44%, var(--bg-base) 100%); overflow-x: hidden; -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; } body::before { content: ""; position: fixed; inset: 0; pointer-events: none; z-index: -1; opacity: 0.28; background: radial-gradient(circle at 20% 15%, rgba(255, 255, 255, 0.8), transparent 34%), radial-gradient(circle at 78% 26%, rgba(79, 184, 178, 0.2), transparent 42%), radial-gradient(circle at 42% 82%, rgba(47, 106, 74, 0.14), transparent 36%); } body::after { content: ""; position: fixed; inset: 0; pointer-events: none; z-index: -1; opacity: 0.14; background-image: linear-gradient(rgba(255, 255, 255, 0.07) 1px, transparent 1px), linear-gradient(90deg, rgba(255, 255, 255, 0.06) 1px, transparent 1px); background-size: 28px 28px; mask-image: radial-gradient(circle at 50% 30%, black, transparent 78%); } a { color: var(--lagoon-deep); text-decoration-color: rgba(50, 143, 151, 0.4); text-decoration-thickness: 1px; text-underline-offset: 2px; } a:hover { color: #246f76; } code { font-size: 0.9em; border: 1px solid var(--line); background: color-mix(in oklab, var(--surface-strong) 82%, white 18%); border-radius: 7px; padding: 2px 7px; } pre code { border: 0; background: transparent; padding: 0; border-radius: 0; font-size: inherit; color: inherit; } .page-wrap { width: min(1080px, calc(100% - 2rem)); margin-inline: auto; } .display-title { font-family: "Fraunces", Georgia, serif; } .island-shell { border: 1px solid var(--line); background: linear-gradient(165deg, var(--surface-strong), var(--surface)); box-shadow: 0 1px 0 var(--inset-glint) inset, 0 22px 44px rgba(30, 90, 72, 0.1), 0 6px 18px rgba(23, 58, 64, 0.08); backdrop-filter: blur(4px); } .feature-card { background: linear-gradient(165deg, color-mix(in oklab, var(--surface-strong) 93%, white 7%), var(--surface)); box-shadow: 0 1px 0 var(--inset-glint) inset, 0 18px 34px rgba(30, 90, 72, 0.1), 0 4px 14px rgba(23, 58, 64, 0.06); } .feature-card:hover { transform: translateY(-2px); border-color: color-mix(in oklab, var(--lagoon-deep) 35%, var(--line)); } button, .island-shell, a { transition: background-color 180ms ease, color 180ms ease, border-color 180ms ease, transform 180ms ease; } .island-kicker { letter-spacing: 0.16em; text-transform: uppercase; font-weight: 700; font-size: 0.69rem; color: var(--kicker); } .nav-link { position: relative; display: inline-flex; align-items: center; text-decoration: none; color: var(--sea-ink-soft); } .nav-link::after { content: ""; position: absolute; left: 0; bottom: -6px; width: 100%; height: 2px; transform: scaleX(0); transform-origin: left; background: linear-gradient(90deg, var(--lagoon), #7ed3bf); transition: transform 170ms ease; } .nav-link:hover, .nav-link.is-active { color: var(--sea-ink); } .nav-link:hover::after, .nav-link.is-active::after { transform: scaleX(1); } @media (max-width: 640px) { .nav-link::after { bottom: -4px; } } .site-footer { border-top: 1px solid var(--line); background: color-mix(in oklab, var(--header-bg) 84%, transparent 16%); } .rise-in { animation: rise-in 700ms cubic-bezier(0.16, 1, 0.3, 1) both; } @keyframes rise-in { from { opacity: 0; transform: translateY(12px); } to { opacity: 1; transform: translateY(0); } }