:root{--bg-top:#eaf4fb;--bg-bottom:#c5dff1;--ink:#1f3a52;--ink-soft:#496a85;--ink-faint:#7e9bb2;--paper:#fbf9f4;--card:#ffffff9e;--card-strong:#ffffffdb;--line:#1f3a5224;--coral:#f7b1bd;--coral-deep:#e88497;--sun:#ffe1a3;--seafoam:#b9e3d2;--lavender:#cdc4ef;--accent:var(--coral-deep);--serif:"Instrument Serif", "Cormorant Garamond", "Times New Roman", serif;--sans:"Nunito", ui-rounded, "SF Pro Rounded", system-ui, sans-serif;--mono:"Geist Mono", ui-monospace, "SF Mono", Menlo, monospace;--anim:1}*,:before,:after{box-sizing:border-box}html,body{margin:0;padding:0}body{font-family:var(--sans);color:var(--ink);background:radial-gradient(120% 70% at 50% -10%, #fff 0%, transparent 55%), linear-gradient(180deg, var(--bg-top) 0%, var(--bg-bottom) 100%);-webkit-font-smoothing:antialiased;min-height:100vh;font-weight:500;overflow-x:hidden}img{max-width:100%;display:block}button{font:inherit;color:inherit;cursor:pointer;background:0 0;border:0;padding:0}a{color:inherit;text-decoration:none}em,.italic{font-family:var(--serif);font-style:italic;font-weight:400}.app{isolation:isolate;min-height:100vh;position:relative}.serif{font-family:var(--serif);letter-spacing:-.01em;font-style:italic;font-weight:400}.tnum{font-variant-numeric:tabular-nums}.mono{font-family:var(--mono);letter-spacing:-.02em}.handle{font-family:var(--mono);letter-spacing:.04em;color:var(--ink-soft);text-transform:lowercase;font-size:12px}.kbd{font-family:var(--mono);border:1px solid var(--line);background:var(--card-strong);color:var(--ink-soft);border-bottom-width:2px;border-radius:5px;padding:1px 5px;font-size:11px}.nav{z-index:50;pointer-events:none;justify-content:space-between;align-items:center;padding:16px 28px;display:flex;position:fixed;top:0;left:0;right:0}.nav>*{pointer-events:auto}.nav-brand{cursor:pointer;align-items:center;gap:10px;display:flex}.nav-brand .dot{background:radial-gradient(circle at 35% 35%, #fff, var(--coral) 60%, var(--coral-deep));border-radius:50%;width:24px;height:24px;box-shadow:0 2px 10px #e8849759,inset 0 0 0 1px #ffffff80}.nav-brand b{font-family:var(--mono);letter-spacing:-.01em;font-size:13px;font-weight:600}.nav-links{background:var(--card);-webkit-backdrop-filter:blur(12px);border:1px solid #ffffffb3;border-radius:999px;align-items:center;gap:4px;padding:5px;display:flex;box-shadow:0 6px 24px #1f3a520f}.nav-links a{color:var(--ink-soft);border-radius:999px;padding:7px 14px;font-size:13px;font-weight:600}.nav-links a:hover{color:var(--ink);background:#ffffff80}.nav-links a.active{background:var(--ink);color:#fff}.bubbles{z-index:-1;pointer-events:none;position:fixed;inset:0;overflow:hidden}.bubble{opacity:.65;background:radial-gradient(circle at 30% 28%,#ffffffe6,#ffffff2e 45%,#fff0 65%);border:1px solid #ffffff8c;border-radius:50%;animation:linear infinite floatUp;position:absolute}@keyframes floatUp{0%{opacity:0;transform:translateY(110vh)translate(0)scale(.9)}10%{opacity:.7}50%{transform:translateY(50vh)translate(20px)scale(1)}90%{opacity:.5}to{opacity:0;transform:translateY(-15vh)translate(-10px)scale(.9)}}.caustic{z-index:-1;pointer-events:none;filter:blur(20px);background:radial-gradient(60% 40% at 20% 20%,#ffffff59,#0000 60%),radial-gradient(50% 35% at 80% 30%,#ffe1a32e,#0000 60%),radial-gradient(40% 30% at 60% 80%,#f7b1bd29,#0000 60%);animation:22s ease-in-out infinite alternate drift;position:fixed;inset:-20%}@keyframes drift{0%{transform:translate(0)rotate(0)}to{transform:translate(2%,-2%)rotate(2deg)}}.mascot{z-index:40;pointer-events:none;transform-origin:50%;position:fixed;bottom:24px;right:24px}.mascot svg{filter:drop-shadow(0 6px 14px #1f3a522e);animation:4s ease-in-out infinite bob}@keyframes bob{0%,to{transform:translateY(0)rotate(-2deg)}50%{transform:translateY(-8px)rotate(2deg)}}.hero{text-align:center;max-width:980px;margin:0 auto;padding:140px 28px 40px;position:relative}.hero .eyebrow{font-family:var(--mono);letter-spacing:.18em;color:var(--ink-faint);text-transform:uppercase;margin-bottom:14px;font-size:12px}.hero h1{font-family:var(--serif);letter-spacing:-.02em;color:var(--ink);margin:0 0 18px;font-size:clamp(56px,9vw,120px);font-style:italic;font-weight:400;line-height:.95}.hero h1 .wave{animation:6s ease-in-out infinite wave;display:inline-block}@keyframes wave{0%,to{transform:translateY(0)}50%{transform:translateY(-6px)}}.hero p.lede{color:var(--ink-soft);text-wrap:pretty;max-width:560px;margin:0 auto;font-size:18px;line-height:1.55}.hero .hint{color:var(--ink-faint);font-size:12px;font-family:var(--mono);align-items:center;gap:8px;margin-top:30px;display:inline-flex}.aquarium{min-height:calc(100vh - 80px);margin-top:-40px;padding:0 0 80px;position:relative}.tank{width:100%;max-width:1240px;height:660px;margin:0 auto;position:relative}.fishcard{background:var(--card-strong);-webkit-backdrop-filter:blur(6px);cursor:pointer;text-align:center;border:1px solid #ffffffd9;border-radius:50%;flex-direction:column;justify-content:center;align-items:center;width:240px;height:240px;padding:14px;transition:transform .35s cubic-bezier(.34,1.56,.64,1),box-shadow .35s;animation:ease-in-out infinite bobcard;display:flex;position:absolute;box-shadow:inset 0 1px #ffffffe6,inset 0 -20px 40px #1f3a520f,0 18px 40px #1f3a521a,0 2px 6px #1f3a520f}.fishcard:before{content:"";pointer-events:none;background:radial-gradient(circle at 30% 25%,#ffffffb3,#0000 35%);border-radius:50%;position:absolute;inset:8px}.fishcard:hover{z-index:5;box-shadow:inset 0 1px #fffffff2,0 24px 50px #1f3a522e,0 0 0 6px #fff6;transform:translate(var(--tx,0), calc(var(--ty,0) - 8px)) scale(1.05)!important}@keyframes bobcard{0%,to{transform:translate(var(--tx,0), var(--ty,0))}50%{transform:translate(calc(var(--tx,0) + var(--dx,4px)), calc(var(--ty,0) + var(--dy,-12px)))}}.fishcard .ico{border-radius:24px;place-items:center;width:80px;height:80px;margin-bottom:10px;display:grid;position:relative}.fishcard .name{font-family:var(--serif);color:var(--ink);font-size:24px;font-style:italic;font-weight:400;line-height:1.05}.fishcard .tag{font-family:var(--mono);letter-spacing:.08em;text-transform:uppercase;color:var(--ink-faint);margin-top:6px;font-size:10px}.bento{grid-template-columns:repeat(12,1fr);grid-auto-rows:170px;gap:18px;max-width:1240px;margin:20px auto;padding:0 28px 60px;display:grid}.bento .bcard{background:var(--card-strong);cursor:pointer;border:1px solid #ffffffd9;border-radius:26px;flex-direction:column;justify-content:space-between;padding:22px;transition:transform .3s,box-shadow .3s;display:flex;position:relative;overflow:hidden;box-shadow:0 14px 36px #1f3a5214,inset 0 1px #ffffffe6}.bento .bcard:hover{transform:translateY(-4px);box-shadow:0 22px 50px #1f3a5224}.bento .bcard h3{font-family:var(--serif);color:var(--ink);margin:0;font-size:30px;font-style:italic;font-weight:400;line-height:1.05}.bento .bcard .tag{font-family:var(--mono);letter-spacing:.08em;text-transform:uppercase;color:var(--ink-faint);font-size:10px}.bento .bcard .ico{align-self:flex-start}.strip{grid-template-columns:1fr 1fr;gap:18px;max-width:1100px;margin:0 auto 24px;padding:0 28px;display:grid}.strip .pill{background:var(--card-strong);border:1px solid #fffc;border-radius:22px;align-items:center;gap:14px;padding:18px 22px;display:flex;box-shadow:0 10px 26px #1f3a520f}.strip .pill .icn{background:var(--seafoam);border-radius:50%;flex:none;place-items:center;width:38px;height:38px;display:grid}.strip .pill .lbl{font-family:var(--mono);letter-spacing:.12em;text-transform:uppercase;color:var(--ink-faint);font-size:10px}.strip .pill .val{font-family:var(--serif);color:var(--ink);font-size:22px;font-style:italic;line-height:1.1}.strip .pill .val .mini{font-family:var(--sans);color:var(--ink-soft);margin-top:2px;font-size:13px;font-style:normal;font-weight:600;display:block}.foot{border-top:1px dashed var(--line);max-width:1240px;font-family:var(--mono);color:var(--ink-faint);justify-content:space-between;align-items:center;margin:60px auto 0;padding:30px 28px 50px;font-size:11px;display:flex}.foot .links{gap:14px;display:flex}.foot .links a:hover{color:var(--ink)}.proj{max-width:1180px;margin:0 auto;padding:110px 28px 0}.proj .back{color:var(--ink-soft);font-family:var(--mono);background:var(--card);border:1px solid #ffffffb3;border-radius:999px;align-items:center;gap:8px;margin-bottom:24px;padding:6px 12px;font-size:12px;transition:transform .2s;display:inline-flex}.proj .back:hover{color:var(--ink);transform:translate(-3px)}.proj-head{grid-template-columns:1.1fr 1fr;align-items:center;gap:48px;margin-bottom:48px;display:grid}@media (max-width:880px){.proj-head{grid-template-columns:1fr}}.proj-head .eyebrow{font-family:var(--mono);letter-spacing:.18em;text-transform:uppercase;color:var(--ink-faint);margin-bottom:10px;font-size:11px}.proj-head h1{font-family:var(--serif);letter-spacing:-.02em;color:var(--ink);margin:0 0 18px;font-size:clamp(56px,8vw,108px);font-style:italic;font-weight:400;line-height:.95}.proj-head .blurb{color:var(--ink-soft);text-wrap:pretty;max-width:520px;font-size:18px;line-height:1.55}.proj-head .cta{flex-wrap:wrap;gap:10px;margin-top:26px;display:flex}.btn{border-radius:999px;align-items:center;gap:8px;padding:13px 20px;font-size:14px;font-weight:700;transition:transform .2s,box-shadow .2s;display:inline-flex}.btn.primary{background:var(--ink);color:#fff;box-shadow:0 8px 22px #1f3a5240}.btn.primary:hover{transform:translateY(-2px);box-shadow:0 12px 28px #1f3a5259}.btn.ghost{background:var(--card-strong);color:var(--ink);border:1px solid var(--line)}.btn.ghost:hover{background:#fff;transform:translateY(-2px)}.btn .arr{transition:transform .2s}.btn:hover .arr{transform:translate(2px,-2px)}.btn.soon{cursor:default;color:var(--ink-soft);background:var(--card);border:1px dashed var(--line);box-shadow:none}.btn.soon:hover{background:var(--card);box-shadow:none;transform:none}.btn.soon .soon-tag{font-family:var(--mono);letter-spacing:.12em;text-transform:uppercase;color:var(--ink-soft);background:#1f3a5214;border-radius:99px;margin-left:2px;padding:2px 7px;font-size:9px}.proj-shot{animation:6s ease-in-out infinite bob;position:relative}.mac{background:#fff;border:1px solid #1f3a521f;border-radius:14px;overflow:hidden;box-shadow:0 30px 60px #1f3a5238,0 4px 12px #1f3a5214}.mac .bar{background:linear-gradient(#f3f1ec,#e9e5dc);border-bottom:1px solid #0000000f;align-items:center;gap:6px;padding:10px 14px;display:flex}.mac .dots{gap:6px;display:flex}.mac .dot{border-radius:50%;width:12px;height:12px}.mac .dot.r{background:#ff5f57}.mac .dot.y{background:#febc2e}.mac .dot.g{background:#28c840}.mac .title{text-align:center;font-family:var(--mono);color:#6b6862;flex:1;font-size:11px}.mac .stage{aspect-ratio:16/10;background:#fff;position:relative;overflow:hidden}.features{grid-template-columns:repeat(3,1fr);gap:18px;margin:60px 0;display:grid}@media (max-width:760px){.features{grid-template-columns:1fr}}.feat{background:var(--card-strong);border:1px solid #fffc;border-radius:22px;padding:24px;box-shadow:0 10px 26px #1f3a520f}.feat .ico{background:linear-gradient(180deg, var(--coral) 0%, var(--coral-deep) 100%);color:#fff;border-radius:14px;place-items:center;width:42px;height:42px;margin-bottom:14px;display:grid}.feat h4{font-family:var(--serif);margin:0 0 8px;font-size:24px;font-style:italic;font-weight:400;line-height:1.1}.feat p{color:var(--ink-soft);margin:0;font-size:14px;line-height:1.5}.changelog{grid-template-columns:200px 1fr;gap:30px;margin:60px 0;display:grid}@media (max-width:760px){.changelog{grid-template-columns:1fr}}.changelog h3{font-family:var(--serif);color:var(--ink);margin:0;font-size:32px;font-style:italic;font-weight:400}.changelog ul{flex-direction:column;gap:14px;margin:0;padding:0;list-style:none;display:flex}.changelog li{color:var(--ink-soft);gap:14px;font-size:14px;display:flex}.changelog .when{font-family:var(--mono);color:var(--ink-faint);min-width:80px;padding-top:2px;font-size:11px}.changelog .what b{color:var(--ink);font-weight:700}.nextproj{background:var(--card-strong);cursor:pointer;border:1px solid #fffc;border-radius:28px;justify-content:space-between;align-items:center;gap:24px;margin:40px 0 60px;padding:32px;transition:transform .25s;display:flex;box-shadow:0 14px 36px #1f3a5214}.nextproj:hover{transform:translateY(-3px)}.nextproj .lbl{font-family:var(--mono);letter-spacing:.14em;text-transform:uppercase;color:var(--ink-faint);font-size:11px}.nextproj h2{font-family:var(--serif);color:var(--ink);margin:6px 0 0;font-size:42px;font-style:italic;font-weight:400;line-height:1}.nextproj .arr{color:var(--ink-soft);font-size:32px}.page-enter{animation:.45s cubic-bezier(.2,.7,.2,1) both pageIn}@keyframes pageIn{0%{opacity:0;transform:translateY(14px)scale(.992)}to{opacity:1;transform:none}}.about{max-width:780px;margin:0 auto;padding:130px 28px 80px}.about h1{font-family:var(--serif);letter-spacing:-.02em;margin:0 0 24px;font-size:80px;font-style:italic;font-weight:400;line-height:.95}.about p{color:var(--ink-soft);text-wrap:pretty;font-size:17px;line-height:1.65}.about .who{background:var(--card-strong);border:1px solid #fffc;border-radius:24px;align-items:center;gap:18px;margin:32px 0;padding:18px;display:flex}.about .who .av{background:radial-gradient(circle at 30% 30%, #fff, var(--coral) 60%, var(--coral-deep));border-radius:50%;flex:none;width:72px;height:72px;box-shadow:0 6px 18px #e8849766}.mock{font-family:var(--sans);position:absolute;inset:0}@keyframes swim{0%{transform:translate(0)}to{transform:translate(-180px)}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes sway{0%,to{transform:rotate(-4deg)}50%{transform:rotate(4deg)}}@keyframes drift1{0%,to{transform:translate(0)}50%{transform:translate(40px,-20px)}}@keyframes drift2{0%,to{transform:translate(0)}50%{transform:translate(-30px,10px)}}@keyframes drift3{0%,to{transform:translate(0)}50%{transform:translate(20px,-15px)}}@keyframes ripple{0%{opacity:.9;transform:scale(.5)}to{opacity:0;transform:scale(4)}}
