[data-theme=light]{--bg-start: #eef3f8;--bg-mid: #e4ecf3;--bg-end: #dce5ef;--bg-accent-a: rgba(78, 205, 196, .08);--bg-accent-b: rgba(232, 146, 124, .06);--text-primary: #254669;--text-muted: #6b7f96;--glass-bg: rgba(255, 255, 255, .55);--glass-border: rgba(255, 255, 255, .65);--glass-header: rgba(238, 243, 248, .78);--glass-shadow: rgba(37, 70, 105, .06);--accent: #e8927c;--accent-soft: rgba(232, 146, 124, .12);--accent-secondary: #4ecdc4;--accent-secondary-soft: rgba(78, 205, 196, .12);--tag-bg: rgba(78, 205, 196, .12);--tag-text: #2a9d8f;--divider: rgba(37, 70, 105, .08);--scrollbar-track: rgba(37, 70, 105, .04);--scrollbar-thumb: rgba(37, 70, 105, .15);--toggle-bg: rgba(37, 70, 105, .06);--card-hover-glow: rgba(232, 146, 124, .18);--wave-color: #eef3f8;--nav-bg: rgba(238, 243, 248, .95);--filter-active-bg: #254669;--filter-active-text: #e6ebef;--otter-shadow: rgba(232, 146, 124, .18);--connect-bg: rgba(37, 70, 105, .04)}[data-theme=dark]{--bg-start: #0d1b2a;--bg-mid: #152238;--bg-end: #1b2d45;--bg-accent-a: rgba(78, 205, 196, .05);--bg-accent-b: rgba(232, 146, 124, .04);--text-primary: #e6ebef;--text-muted: #8fa3b8;--glass-bg: rgba(255, 255, 255, .05);--glass-border: rgba(255, 255, 255, .08);--glass-header: rgba(13, 27, 42, .8);--glass-shadow: rgba(0, 0, 0, .25);--accent: #e8927c;--accent-soft: rgba(232, 146, 124, .12);--accent-secondary: #4ecdc4;--accent-secondary-soft: rgba(78, 205, 196, .1);--tag-bg: rgba(78, 205, 196, .12);--tag-text: #4ecdc4;--divider: rgba(255, 255, 255, .06);--scrollbar-track: rgba(255, 255, 255, .03);--scrollbar-thumb: rgba(255, 255, 255, .12);--toggle-bg: rgba(255, 255, 255, .06);--card-hover-glow: rgba(232, 146, 124, .15);--wave-color: #0d1b2a;--nav-bg: rgba(13, 27, 42, .96);--filter-active-bg: #e8927c;--filter-active-text: #0d1b2a;--otter-shadow: rgba(78, 205, 196, .12);--connect-bg: rgba(78, 205, 196, .04)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;scrollbar-width:thin;scrollbar-color:var(--scrollbar-thumb) var(--scrollbar-track)}html,body{min-height:100vh;min-height:100dvh}body{font-family:DM Sans,system-ui,-apple-system,sans-serif;font-weight:400;line-height:1.65;color:var(--text-primary);overflow-x:hidden;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body:before{content:"";position:fixed;inset:0;z-index:-2;background:radial-gradient(ellipse 80% 60% at 15% 10%,var(--bg-accent-a) 0%,transparent 60%),radial-gradient(ellipse 70% 50% at 85% 80%,var(--bg-accent-b) 0%,transparent 55%),linear-gradient(160deg,var(--bg-start) 0%,var(--bg-mid) 50%,var(--bg-end) 100%)}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:var(--scrollbar-track)}::-webkit-scrollbar-thumb{background:var(--scrollbar-thumb);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--accent)}h1,h2,h3,h4,h5,h6{font-family:Fredoka,DM Sans,system-ui,sans-serif;font-weight:600;line-height:1.2;color:var(--text-primary)}h1{font-size:clamp(2.5rem,6vw,4.5rem)}h2{font-size:clamp(1.75rem,4vw,2.5rem)}h3{font-size:clamp(1.125rem,2vw,1.375rem)}p{color:var(--text-muted);max-width:60ch}a{color:inherit;text-decoration:none}img{display:block;max-width:100%}::selection{background:var(--accent-soft);color:var(--text-primary)}.skip-link{position:absolute;top:-100%;left:0;background:var(--accent);color:#fff;padding:.75rem 1.5rem;z-index:200;font-weight:600;border-radius:0 0 8px;text-decoration:none;transition:top .2s}.skip-link:focus{top:0}.no-js .reveal{opacity:1;transform:none}.reveal{opacity:0;transform:translateY(28px);transition:opacity .65s cubic-bezier(.22,1,.36,1),transform .65s cubic-bezier(.22,1,.36,1);transition-delay:var(--delay, 0ms)}.reveal.revealed{opacity:1;transform:translateY(0)}.reveal.revealed.float-animation{animation:otter-float 3s ease-in-out infinite}@keyframes otter-float{0%,to{transform:translateY(0)}50%{transform:translateY(-4px)}}.site-header{position:fixed;top:0;left:0;right:0;z-index:100;padding:0 1.25rem;height:64px;display:flex;align-items:center;justify-content:space-between;backdrop-filter:blur(18px) saturate(1.6);-webkit-backdrop-filter:blur(18px) saturate(1.6);background:var(--glass-header);border-bottom:1px solid var(--glass-border)}@supports not (backdrop-filter: blur(18px)){.site-header{background:var(--nav-bg)}}.site-logo{display:flex;align-items:center;gap:.5rem;font-family:Fredoka,DM Sans,system-ui,sans-serif;font-weight:600;font-size:1.125rem;letter-spacing:-.01em;color:var(--text-primary);transition:opacity .2s;min-height:44px}.site-logo:hover{opacity:.75}.site-logo img{width:36px;height:36px;border-radius:10px;object-fit:contain}.site-logo span{white-space:nowrap}.header-nav{display:none;align-items:center;gap:2rem}.header-nav a{font-family:DM Sans,system-ui,sans-serif;font-weight:500;font-size:.9375rem;color:var(--text-muted);transition:color .2s;min-height:44px;display:flex;align-items:center;position:relative}.header-nav a:after{content:"";position:absolute;bottom:4px;left:0;width:0;height:2px;background:var(--accent);border-radius:1px;transition:width .3s cubic-bezier(.22,1,.36,1)}.header-nav a:hover{color:var(--text-primary)}.header-nav a:hover:after{width:100%}.header-nav a:focus-visible{outline:2px solid var(--accent);outline-offset:4px;border-radius:4px}.header-actions{display:flex;align-items:center;gap:.375rem}.hamburger{display:flex;flex-direction:column;justify-content:center;align-items:center;width:44px;height:44px;border:none;border-radius:12px;background:none;cursor:pointer;padding:0;gap:5px;transition:background .2s}.hamburger:hover{background:var(--toggle-bg)}.hamburger:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.hamburger span{display:block;width:20px;height:2px;background:var(--text-primary);border-radius:2px;transition:transform .3s cubic-bezier(.22,1,.36,1),opacity .3s}.hamburger[aria-expanded=true] span:nth-child(1){transform:translateY(7px) rotate(45deg)}.hamburger[aria-expanded=true] span:nth-child(2){opacity:0}.hamburger[aria-expanded=true] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}.mobile-nav-overlay{position:fixed;inset:64px 0 0;z-index:99;background:var(--nav-bg);backdrop-filter:blur(20px) saturate(1.5);-webkit-backdrop-filter:blur(20px) saturate(1.5);display:flex;flex-direction:column;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .35s cubic-bezier(.22,1,.36,1)}@supports not (backdrop-filter: blur(20px)){.mobile-nav-overlay{background:var(--nav-bg)}}.mobile-nav-overlay.active{opacity:1;pointer-events:auto}.mobile-nav-links{display:flex;flex-direction:column;align-items:center;gap:2rem}.mobile-nav-links a{font-family:Fredoka,DM Sans,system-ui,sans-serif;font-weight:600;font-size:1.5rem;color:var(--text-muted);transition:color .2s,transform .2s;min-height:44px;display:flex;align-items:center}.mobile-nav-links a:hover{color:var(--accent);transform:translateY(-2px)}.mobile-nav-links a:focus-visible{outline:2px solid var(--accent);outline-offset:4px;border-radius:4px}.theme-toggle{display:flex;align-items:center;justify-content:center;width:44px;height:44px;border:none;border-radius:12px;background:none;cursor:pointer;transition:background .2s,color .2s,transform .2s;padding:0;color:var(--text-muted)}.theme-toggle:hover{background:var(--toggle-bg);color:var(--accent);transform:translateY(-1px)}.theme-toggle:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.theme-toggle svg{width:20px;height:20px;fill:none;stroke:currentColor;transition:transform .35s cubic-bezier(.34,1.56,.64,1)}.theme-toggle:hover svg{transform:rotate(15deg)}.theme-toggle .icon-sun{display:none}.theme-toggle .icon-moon,[data-theme=dark] .theme-toggle .icon-sun{display:block}[data-theme=dark] .theme-toggle .icon-moon{display:none}.hero{min-height:100vh;min-height:100dvh;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:6rem 1.25rem 3rem;gap:1.5rem;position:relative}.hero-content{display:flex;flex-direction:column;align-items:center;gap:.75rem}.hero-name{font-family:Fredoka,DM Sans,system-ui,sans-serif;font-size:clamp(2.75rem,8vw,5rem);font-weight:700;letter-spacing:-.03em;line-height:1.1;background:linear-gradient(135deg,var(--text-primary) 0%,var(--accent) 100%);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}.hero-tagline{font-family:Fredoka,DM Sans,system-ui,sans-serif;font-size:clamp(1.125rem,3vw,1.625rem);font-weight:500;color:var(--text-primary)}.hero-description{font-size:clamp(.9375rem,2vw,1.0625rem);color:var(--text-muted);text-align:center;max-width:48ch;line-height:1.7}.hero-otter{display:flex;align-items:center;justify-content:center;order:-1;margin-bottom:1rem;filter:drop-shadow(0 8px 24px var(--otter-shadow))}.hero-otter video{width:220px;height:auto;display:block}.about-section{padding:4rem 1.25rem;max-width:720px;margin:0 auto;text-align:center}.about-inner{display:flex;flex-direction:column;gap:1rem}.about-text{font-size:clamp(1.0625rem,2.5vw,1.25rem);color:var(--text-muted);line-height:1.75;max-width:none}.about-accent{font-family:Fredoka,DM Sans,system-ui,sans-serif;font-weight:500;font-size:clamp(1rem,2vw,1.125rem);color:var(--accent);line-height:1.6;max-width:none}.about-heading{font-size:clamp(1.75rem,4vw,2.5rem);font-weight:700;letter-spacing:-.03em;margin-bottom:1.5rem;color:var(--text-primary)}.section-divider{width:100%;height:60px;background:var(--wave-color)}.wave-divider{width:100%;line-height:0;margin:-1px 0;overflow:hidden}.wave-divider svg{display:block;width:100%;height:100px}.wave-divider.flipped{transform:scaleY(-1)}.projects-section{padding:4rem 1.25rem;max-width:1120px;margin:0 auto}.projects-heading{font-family:Fredoka,DM Sans,system-ui,sans-serif;font-size:clamp(1.75rem,4vw,2.5rem);font-weight:700;letter-spacing:-.02em;margin-bottom:1.5rem;text-align:center}.filter-tabs{display:flex;justify-content:center;flex-wrap:wrap;gap:.5rem;margin-bottom:2.5rem}.filter-tab{font-family:DM Sans,system-ui,sans-serif;font-size:.875rem;font-weight:500;padding:.5rem 1.25rem;border:1.5px solid var(--glass-border);border-radius:999px;background:var(--glass-bg);color:var(--text-muted);cursor:pointer;transition:all .25s cubic-bezier(.22,1,.36,1);min-height:44px;display:flex;align-items:center;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}@supports not (backdrop-filter: blur(8px)){.filter-tab{background:var(--nav-bg)}}.filter-tab:hover{border-color:var(--accent);color:var(--accent);transform:translateY(-1px)}.filter-tab:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.filter-tab.active{background:var(--filter-active-bg);border-color:var(--filter-active-bg);color:var(--filter-active-text)}.projects-grid{display:grid;grid-template-columns:1fr;gap:1.25rem}.project-card{display:flex;flex-direction:column;text-decoration:none;color:inherit;padding:1.5rem;border-radius:24px;background:var(--glass-bg);border:1px solid var(--glass-border);backdrop-filter:blur(14px) saturate(1.5);-webkit-backdrop-filter:blur(14px) saturate(1.5);box-shadow:0 4px 24px var(--glass-shadow);transition:transform .35s cubic-bezier(.22,1,.36,1),box-shadow .35s cubic-bezier(.22,1,.36,1),border-color .35s;cursor:pointer}@supports not (backdrop-filter: blur(14px)){.project-card{background:var(--nav-bg)}}.project-card.hidden{display:none}.project-card:hover{transform:translateY(-6px);box-shadow:0 12px 40px var(--glass-shadow),0 0 0 1px var(--card-hover-glow);border-color:var(--accent)}.project-card:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.card-header{display:flex;align-items:center;gap:.75rem;margin-bottom:.75rem}.card-icon{width:44px;height:44px;border-radius:12px;object-fit:contain;flex-shrink:0}.card-title{font-family:Fredoka,DM Sans,system-ui,sans-serif;font-size:clamp(1rem,2vw,1.1875rem);font-weight:600;color:var(--text-primary);letter-spacing:-.01em;flex-grow:1}.card-arrow{font-size:1.25rem;color:var(--text-muted);transition:transform .3s cubic-bezier(.22,1,.36,1),color .3s;flex-shrink:0}.project-card:hover .card-arrow{transform:translate(3px,-3px);color:var(--accent)}.card-description{font-size:.9375rem;color:var(--text-muted);line-height:1.6;margin-bottom:1.125rem;flex-grow:1}.card-tags{display:flex;flex-wrap:wrap;gap:.5rem}.card-tag{font-family:DM Sans,system-ui,sans-serif;font-size:.75rem;font-weight:500;padding:.25rem .75rem;border-radius:999px;background:var(--tag-bg);color:var(--tag-text);letter-spacing:.01em}.connect-section{padding:5rem 1.25rem 6rem;max-width:720px;margin:0 auto;text-align:center}.connect-heading{font-family:Fredoka,DM Sans,system-ui,sans-serif;font-size:clamp(1.75rem,4vw,2.5rem);font-weight:700;letter-spacing:-.02em;margin-bottom:.75rem}.connect-description{font-size:clamp(.9375rem,2vw,1.0625rem);color:var(--text-muted);line-height:1.7;max-width:44ch;margin:0 auto 2rem}.connect-links{display:inline-flex;align-items:center;justify-content:center;flex-wrap:wrap;gap:0}.connect-link{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;font-family:DM Sans,system-ui,sans-serif;font-size:.9375rem;font-weight:500;color:var(--text-muted);text-decoration:none;transition:color .25s ease;min-height:44px}.connect-link:hover{color:var(--accent)}.connect-link:focus-visible{outline:2px solid var(--accent);outline-offset:2px;border-radius:8px}.connect-link-icon{display:flex;align-items:center;justify-content:center;color:currentColor}.connect-link-icon svg{width:20px;height:20px}.connect-divider{display:inline-block;width:1px;height:1.25rem;background:var(--divider);margin:0 .25rem}.site-footer{padding:2.5rem 1.25rem 2rem;max-width:1120px;margin:0 auto}.footer-inner{display:flex;flex-direction:column;align-items:center;gap:1rem}.footer-logo{display:flex;align-items:center;gap:.5rem;font-family:Fredoka,DM Sans,system-ui,sans-serif;font-weight:600;font-size:.9375rem;color:var(--text-primary);transition:opacity .2s}.footer-logo:hover{opacity:.75}.footer-logo img{width:28px;height:28px;border-radius:8px;object-fit:contain}.footer-copy{font-size:.8125rem;color:var(--text-muted)}@media (min-width: 640px){.hamburger{display:none}.header-nav{display:flex}.projects-grid{grid-template-columns:repeat(2,1fr)}.hero-otter video{width:220px;height:auto;display:block}}@media (min-width: 768px){.site-header{padding:0 2.5rem}.hero{padding:6rem 2.5rem 4rem;flex-direction:row;text-align:left;justify-content:center;gap:3rem}.hero-content{align-items:flex-start;max-width:520px}.hero-description{text-align:left}.hero-otter{order:0;margin-top:0;margin-bottom:0;flex-shrink:0}.hero-otter video{width:260px;height:auto;display:block}.about-section{padding:5rem 2rem}.projects-section{padding:5rem 2.5rem}.connect-section{padding:5rem 2.5rem 6rem}}@media (min-width: 1024px){.site-header{padding:0 3rem}.hero{padding:6rem 3rem 5rem;gap:4rem}.projects-section{padding:5rem 3rem 6rem}.projects-grid{grid-template-columns:repeat(3,1fr)}.connect-section{padding:6rem 3rem 7rem}}@media (prefers-reduced-motion: reduce){html{scroll-behavior:auto}.reveal{opacity:1;transform:none;transition:none}.reveal.revealed.float-animation{animation:none}.project-card,.filter-tab,.connect-link,.header-nav a:after,.card-arrow,.theme-toggle,.theme-toggle svg{transition:none}.hamburger span{transition:none}}
