@font-face{font-family:Opening Hours Sans;src:url(/fonts/OpeningHoursSans-Regular.woff) format("woff");font-weight:400;font-style:normal;font-display:swap}:root{--font-mono: "Opening Hours Sans", ui-monospace, "Cascadia Code", "Source Code Pro", Menlo, Consolas, "DejaVu Sans Mono", monospace;--font-sans: "Opening Hours Sans", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--font-display: "Opening Hours Sans", var(--font-sans);--background: #FFFFFF;--foreground: #1a1a1a;--accent: #0000ff;--accent-transparent: rgba(0, 0, 255, .1);--secondary: #666666;--muted: #e5e5e5;--card-bg: rgba(245, 245, 245, .8);--tag-bg: rgba(0, 0, 0, .05)}html{font-family:Opening Hours Sans,sans-serif}[data-theme="black sheep"]{--background: #070707;--foreground: #ecdfca;--accent: #dfac4e;--accent-transparent: rgba(0, 0, 0, .1);--secondary: #dbd0c3;--muted: rgba(255, 255, 255, .1);--card-bg: rgba(45, 45, 45, .8);--tag-bg: rgba(255, 255, 255, .1)}[data-theme=blue]{--background: #1437aa;--foreground: #ffffff;--accent: #6ca7f5;--accent-transparent: rgba(255, 255, 255, .1);--secondary: #F6F8D5;--muted: #3580e4;--card-bg: rgba(30, 41, 59, .8);--tag-bg: rgba(255, 255, 255, .1)}[data-theme=flower]{--background: #F5ECD5;--foreground: #626F47;--accent: #f5539e;--accent-transparent: rgba(240, 187, 120, .1);--secondary: #626F47;--muted: #d1c299;--card-bg: rgba(245, 236, 213, .9);--tag-bg: #ccc3ab}[data-theme=pink]{--background: #FDFFD2;--foreground: #DA7297;--accent: #667BC6;--accent-transparent: rgba(236, 72, 153, .1);--secondary: #DA7297;--muted: #fcc2cc;--card-bg: rgba(131, 24, 67, .8);--tag-bg: rgba(255, 255, 255, .1)}[data-theme=orange]{--background: #EFECEC;--foreground: #0C2D57;--accent: #0C2D57;--accent-transparent: rgba(251, 146, 60, .1);--secondary: #FC6736;--muted: #0C2D57;--card-bg: rgba(154, 52, 18, .8);--tag-bg: rgba(255, 255, 255, .1)}[data-theme=purple]{--background: #322653;--foreground: #FFD2D7;--accent: #8062D6;--accent-transparent: rgba(168, 85, 247, .1);--secondary: #FFD2D7;--muted: #8062D6;--card-bg: rgba(76, 29, 149, .8);--tag-bg: rgba(255, 255, 255, .1)}[data-theme="deep sea"]{--background: #040d2b;--foreground: #E0F2FE;--accent: #5EEAD4;--accent-transparent: rgba(94, 234, 212, .15);--secondary: #B2E5F0;--muted: rgba(94, 234, 212, .2);--card-bg: rgba(15, 23, 42, .85);--tag-bg: rgba(94, 234, 212, .15)}[data-theme=evergreen]{--background: #223325;--foreground: #E8F5E9;--accent: #81C784;--accent-transparent: rgba(129, 199, 132, .15);--secondary: #C8E6C9;--muted: rgba(129, 199, 132, .2);--card-bg: rgba(27, 46, 27, .85);--tag-bg: rgba(129, 199, 132, .15)}[data-theme=sunset]{--background: #2D1B1B;--foreground: #FFF4E6;--accent: #FF8A65;--accent-transparent: rgba(255, 138, 101, .15);--secondary: #FFE0B2;--muted: rgba(255, 138, 101, .2);--card-bg: rgba(45, 27, 27, .85);--tag-bg: rgba(255, 138, 101, .15)}[data-theme=sage]{--background: #F5F7F0;--foreground: #2D3E2D;--accent: #6B8E5A;--accent-transparent: rgba(107, 142, 90, .1);--secondary: #5A6B5A;--muted: #D4D9C8;--card-bg: rgba(245, 247, 240, .9);--tag-bg: rgba(107, 142, 90, .1)}[data-theme=midnight]{--background: #0F0B1E;--foreground: #E8D5FF;--accent: #A78BFA;--accent-transparent: rgba(167, 139, 250, .15);--secondary: #C4B5FD;--muted: rgba(167, 139, 250, .2);--card-bg: rgba(15, 11, 30, .85);--tag-bg: rgba(167, 139, 250, .15)}[data-theme=ginkgo]{--background: #FFF8E1;--foreground: #3E2723;--accent: #e79804;--accent-transparent: rgba(255, 143, 0, .1);--secondary: #5D4037;--muted: #FFE082;--card-bg: rgba(255, 248, 225, .9);--tag-bg: rgba(255, 143, 0, .1)}[data-theme=rose]{--background: #FFF1F2;--foreground: #4A1E1E;--accent: #E91E63;--accent-transparent: rgba(233, 30, 99, .1);--secondary: #6B2B2B;--muted: #FCE4EC;--card-bg: rgba(255, 241, 242, .9);--tag-bg: rgba(233, 30, 99, .1)}[data-theme=slate]{--background: #F8FAFC;--foreground: #32353a;--accent: #32353a;--accent-transparent: rgba(71, 85, 105, .1);--secondary: #666b72;--muted: #CBD5E1;--card-bg: rgba(248, 250, 252, .9);--tag-bg: rgba(71, 85, 105, .1)}body{background-color:var(--background);color:var(--foreground);font-family:Opening Hours Sans,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;transition:background-color .3s ease,color .3s ease;font-size:16px;line-height:1.6}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-track{background:var(--background)}::-webkit-scrollbar-thumb{background:var(--accent);border-radius:10px;border:2px solid var(--background);-webkit-transition:background .3s ease;transition:background .3s ease}::-webkit-scrollbar-thumb:hover{background:var(--accent);opacity:.8}*{scrollbar-width:thin;scrollbar-color:var(--accent) var(--background)}:root{--text-xs: .75rem;--text-sm: .875rem;--text-base: 1rem;--text-lg: 1.125rem;--text-xl: 1.25rem;--text-2xl: 1.5rem;--text-3xl: 1.875rem;--text-4xl: 2.25rem;--text-5xl: 3rem}.transition-all{transition:all .3s ease}.hover-lift{transition:transform .2s ease}.hover-lift:hover{transform:translateY(-2px)}.font-display{font-family:var(--font-display);font-weight:400;font-variation-settings:"BLDA" 10;transition:font-variation-settings .3s ease}.font-display:hover{font-variation-settings:"BLDA" 50}.prose{font-family:var(--font-sans);font-weight:400;line-height:1.6}.prose strong{color:var(--accent);color:var(--foreground);font-weight:600;font-family:Opening Hours Sans,sans-serif}.project-card{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);transition:all .2s ease}.project-card:hover{transform:translateY(-2px)}.project-tag{background-color:var(--tag-bg);border-radius:999px;padding:.25rem .75rem;font-size:var(--text-xs);color:var(--secondary);transition:all .2s ease}.project-tag:hover{color:var(--accent)}button,.button{border:1px solid var(--muted);border-radius:8px;transition:all .2s ease}button:hover,.button:hover{border-color:var(--accent);color:var(--accent)}@keyframes blink{0%,to{opacity:1}50%{opacity:0}}@keyframes noise{0%,to{transform:translate(0) translateY(0) translateZ(0)}10%{transform:translate3d(-2px,2px,0)}20%{transform:translate3d(2px,-2px,0)}30%{transform:translate3d(-2px,-2px,0)}40%{transform:translate3d(2px,2px,0)}50%{transform:translate3d(-2px,2px,0)}60%{transform:translate3d(2px,-2px,0)}70%{transform:translate3d(-2px,-2px,0)}80%{transform:translate3d(2px,2px,0)}90%{transform:translate3d(-2px,2px,0)}}code{font-family:SF Mono,Monaco,Inconsolata,Roboto Mono,Source Code Pro,Courier New,monospace;font-size:.875em;background-color:var(--background);color:var(--foreground);padding:.125rem .375rem;border-radius:.25rem;border:1px solid var(--foreground)}pre{background-color:var(--background);border:1px solid var(--foreground);border-radius:.5rem;padding:1rem;margin:1.5rem 0;overflow-x:auto;font-family:SF Mono,Monaco,Inconsolata,Roboto Mono,Source Code Pro,Courier New,monospace;font-size:.875rem;line-height:1.5;color:var(--foreground)}pre code{background:none;border:none;padding:0;color:inherit;font-size:inherit;border-radius:0}pre .token.comment,pre .token.prolog,pre .token.doctype,pre .token.cdata{color:var(--secondary);font-style:italic}pre .token.punctuation{color:var(--foreground)}pre .token.property,pre .token.tag,pre .token.boolean,pre .token.number,pre .token.constant,pre .token.symbol,pre .token.deleted{color:var(--accent)}pre .token.selector,pre .token.attr-name,pre .token.string,pre .token.char,pre .token.builtin,pre .token.inserted{color:var(--foreground)}pre .token.operator,pre .token.entity,pre .token.url,pre .language-css .token.string,pre .style .token.string{color:var(--accent)}pre .token.atrule,pre .token.attr-value,pre .token.keyword{color:var(--accent);font-weight:600}pre .token.function,pre .token.class-name{color:var(--foreground);font-weight:500}pre .token.regex,pre .token.important,pre .token.variable{color:var(--accent)}@media (max-width: 640px){code{font-size:.8em;padding:.1rem .25rem}pre{padding:.75rem;font-size:.8rem;margin:1rem 0}}.astro-route-announcer{position:absolute;left:0;top:0;clip:rect(0 0 0 0);clip-path:inset(50%);overflow:hidden;white-space:nowrap;width:1px;height:1px}@keyframes fade-in{0%{opacity:0}to{opacity:1}}@keyframes fade-out{0%{opacity:1}to{opacity:0}}@keyframes slide-up{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}@keyframes slide-down{0%{transform:translateY(0);opacity:1}to{transform:translateY(-20px);opacity:0}}::view-transition-old(root){animation:fade-out .2s ease-out forwards}::view-transition-new(root){animation:fade-in .3s ease-out forwards}main{view-transition-name:main-content}::view-transition-old(main-content){animation:slide-down .2s ease-out forwards}::view-transition-new(main-content){animation:slide-up .3s ease-out forwards}.vertical-nav,.hamburger-btn,.mobile-menu{view-transition-name:none}html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}body{min-height:100vh;font-family:Opening Hours Sans,sans-serif;background-color:var(--background);overflow-x:hidden;margin:0;padding:0}main{position:relative}img{max-width:100%;height:auto}::-moz-selection{background-color:var(--accent);color:var(--background)}::selection{background-color:var(--accent);color:var(--background)}.vertical-nav{position:absolute;top:0;left:0;height:auto;display:flex;flex-direction:column;gap:1rem;padding:1.5rem .75rem;z-index:1000}.nav-items{display:flex;flex-direction:column;gap:.5rem}.nav-item{display:flex;flex-direction:column;align-items:center;gap:.25rem;color:var(--secondary);text-decoration:none;transition:all .2s ease;padding:.5rem;border-radius:8px}.nav-item:hover,.nav-item-active{color:var(--accent)}.nav-item-active .nav-icon{border:1px solid var(--accent);border-radius:8px}.nav-icon{font-size:.875rem;padding:.5rem;border-radius:10px;transition:all .2s ease;border:1px solid var(--muted)}.nav-item:hover .nav-icon{border:1px solid var(--accent);border-radius:8px}.nav-label{font-size:.625rem;text-align:center;white-space:nowrap}.nav-bottom{display:flex;justify-content:center}.hamburger-btn{display:none;position:fixed;top:1rem;left:1rem;z-index:1001;background:var(--background);border:1px solid var(--muted);border-radius:12px;padding:.75rem;cursor:pointer;transition:all .2s ease}.hamburger-btn:hover{color:var(--accent)}.hamburger-icon{font-size:1rem;color:var(--foreground)}.mobile-menu{display:none;position:fixed;top:0;left:0;width:100%;height:100%;background:var(--background);z-index:2000;flex-direction:column;padding:2rem;transform:translate(-100%);transition:transform .3s ease}.mobile-menu.open{transform:translate(0)}.close-btn{align-self:flex-end;background:transparent;border:none;padding:.5rem;cursor:pointer;color:var(--foreground);transition:all .2s ease}.close-btn:hover{color:var(--accent)}.close-icon{font-size:1.5rem}.mobile-nav-items{display:flex;flex-direction:column;gap:1rem;margin-top:3rem}.mobile-nav-item{display:flex;align-items:center;gap:1rem;color:var(--foreground);text-decoration:none;font-size:1.25rem;padding:.75rem;border-radius:12px;transition:all .2s ease}.mobile-nav-item:hover,.mobile-nav-item-active{color:var(--accent)}.mobile-nav-icon{font-size:1rem}.mobile-nav-bottom{margin-top:auto;padding-top:2rem;border-top:1px solid var(--muted)}@media (max-width: 768px){.vertical-nav{display:none}.hamburger-btn{display:block}.mobile-menu{display:flex}}@media (min-width: 769px){.hamburger-btn,.mobile-menu{display:none!important}}
