@font-face{font-family:Caveat;font-style:normal;font-weight:400;font-display:swap;src:url(../media/da4b870ab52b3094-s.5e0466e7.woff2)format("woff2");unicode-range:U+460-52F,U+1C80-1C8A,U+20B4,U+2DE0-2DFF,U+A640-A69F,U+FE2E-FE2F}@font-face{font-family:Caveat;font-style:normal;font-weight:400;font-display:swap;src:url(../media/86d70b7c76b6ec6e-s.5d81ed22.woff2)format("woff2");unicode-range:U+301,U+400-45F,U+490-491,U+4B0-4B1,U+2116}@font-face{font-family:Caveat;font-style:normal;font-weight:400;font-display:swap;src:url(../media/11cc37d7380d16b4-s.6c45a7b8.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Caveat;font-style:normal;font-weight:400;font-display:swap;src:url(../media/a85fe84266768609-s.p.e658778d.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Caveat;font-style:normal;font-weight:700;font-display:swap;src:url(../media/da4b870ab52b3094-s.5e0466e7.woff2)format("woff2");unicode-range:U+460-52F,U+1C80-1C8A,U+20B4,U+2DE0-2DFF,U+A640-A69F,U+FE2E-FE2F}@font-face{font-family:Caveat;font-style:normal;font-weight:700;font-display:swap;src:url(../media/86d70b7c76b6ec6e-s.5d81ed22.woff2)format("woff2");unicode-range:U+301,U+400-45F,U+490-491,U+4B0-4B1,U+2116}@font-face{font-family:Caveat;font-style:normal;font-weight:700;font-display:swap;src:url(../media/11cc37d7380d16b4-s.6c45a7b8.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Caveat;font-style:normal;font-weight:700;font-display:swap;src:url(../media/a85fe84266768609-s.p.e658778d.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Caveat Fallback;src:local(Arial);ascent-override:124.77%;descent-override:38.99%;line-gap-override:0.0%;size-adjust:76.94%}.caveat_4269ea75-module__uDY3GW__className{font-family:Caveat,Caveat Fallback;font-style:normal}.caveat_4269ea75-module__uDY3GW__variable{--font-caveat:"Caveat","Caveat Fallback"}
@font-face{font-family:Indie Flower;font-style:normal;font-weight:400;font-display:swap;src:url(../media/5912d36c4cd35192-s.ac3b0c2d.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Indie Flower;font-style:normal;font-weight:400;font-display:swap;src:url(../media/c28f5313a6ae5ee4-s.p.34907654.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Indie Flower Fallback;src:local(Arial);ascent-override:103.05%;descent-override:51.84%;line-gap-override:0.0%;size-adjust:94.19%}.indie_flower_7a9bc523-module__31zhmq__className{font-family:Indie Flower,Indie Flower Fallback;font-style:normal;font-weight:400}.indie_flower_7a9bc523-module__31zhmq__variable{--font-indie:"Indie Flower","Indie Flower Fallback"}
@font-face{font-family:Shadows Into Light;font-style:normal;font-weight:400;font-display:swap;src:url(../media/a07fd904b50ccc02-s.b76bace6.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Shadows Into Light;font-style:normal;font-weight:400;font-display:swap;src:url(../media/9aa6947b4430712c-s.p.b14d6baf.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Shadows Into Light Fallback;src:local(Arial);ascent-override:138.94%;descent-override:51.05%;line-gap-override:0.0%;size-adjust:84.56%}.shadows_into_light_e188e9df-module__2MEmXW__className{font-family:Shadows Into Light,Shadows Into Light Fallback;font-style:normal;font-weight:400}.shadows_into_light_e188e9df-module__2MEmXW__variable{--font-shadows:"Shadows Into Light","Shadows Into Light Fallback"}
:root{--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light;--background:#fdfbf7;--foreground:#171717;--accent:#4a90d9;--sketch-color:#333;--line-color:#b4c8dc59;--margin-color:#ffb4b440}html{--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light;background-color:#fdfbf7}*{box-sizing:border-box;margin:0;padding:0}body{background-color:#fdfbf7;background-image:  linear-gradient(90deg,transparent 0px,transparent 60px,var(--margin-color)60px,var(--margin-color)62px,transparent 62px),repeating-linear-gradient(to bottom,transparent 0px,transparent 29px,var(--line-color)29px,var(--line-color)30px);color:#171717;font-family:var(--font-indie),cursive;-webkit-overflow-scrolling:touch;forced-color-adjust:none;background-size:100% 30px;background-attachment:local;min-height:100vh;overflow-x:hidden}.header{z-index:420;flex-direction:column;align-items:center;display:flex;position:fixed;top:26px;left:50%;transform:translate(-50%)rotate(-3deg)}.header:before{content:"";z-index:10;opacity:.85;clip-path:polygon(0% 15%,3% 8%,1% 20%,4% 35%,0% 45%,3% 55%,1% 70%,4% 80%,0% 90%,2% 100%,8% 95%,15% 100%,25% 97%,35% 100%,45% 96%,55% 100%,65% 97%,75% 100%,85% 96%,92% 100%,98% 97%,100% 88%,97% 75%,100% 65%,96% 55%,100% 45%,97% 35%,100% 25%,96% 15%,100% 8%,98% 0%,90% 5%,80% 0%,70% 4%,60% 0%,50% 6%,40% 0%,30% 4%,20% 0%,10% 5%,2% 0%);background:linear-gradient(#e8956c 0%,#d4845e 50%,#c77a55 100%);width:68px;height:19px;position:absolute;top:-9px;left:50%;transform:translate(-50%)rotate(2deg)}.nav-bar{background:#fef3c7;border-radius:0;padding:clamp(.8rem,1.8vw,1.2rem) clamp(1rem,2.5vw,1.8rem) clamp(.6rem,1.5vw,1rem);position:relative;box-shadow:3px 5px 12px #0000001f,5px 8px 20px #00000014}.nav-bar:before{content:"";pointer-events:none;background:repeating-linear-gradient(#0000,#0000 18px,#b4a07826 18px 19px);border-radius:0;position:absolute;inset:0}.nav-bar:after{content:"";pointer-events:none;background:linear-gradient(90deg,#00000008 0%,#0000 5% 95%,#00000005 100%);border-radius:0;height:100%;position:absolute;bottom:0;left:0;right:0}.nav-bar ul{z-index:1;flex-wrap:wrap;justify-content:center;align-items:center;gap:.3rem;margin:0;padding:0;list-style:none;display:flex;position:relative}.nav-bar li{align-items:center;display:flex}.nav-bar a{color:#3d3d3d;font-family:var(--font-shadows),cursive;padding:.2rem clamp(.3rem,.8vw,.7rem);font-size:clamp(.95rem,1.5vw,1.4rem);text-decoration:none;transition:all .3s;position:relative}.nav-bar a:after{content:"";background:#555;width:0;height:2px;transition:all .3s;position:absolute;bottom:2px;left:50%;transform:translate(-50%)}.nav-bar a:hover{color:#1a1a1a;transform:scale(1.05)}.nav-bar a:hover:after{width:80%}.separator{color:#999;margin:0 .15rem;font-size:.95rem}.torn-edge{display:none}.main-content{flex-direction:column;justify-content:flex-start;align-items:center;max-width:100vw;min-height:100vh;padding:80px clamp(1rem,5%,3rem) 2rem;display:flex;position:relative;overflow-x:hidden}.home-section{flex-wrap:wrap;justify-content:center;align-items:center;gap:clamp(1.5rem,4vw,4rem);width:100%;max-width:1200px;min-height:calc(100vh - 120px);scroll-margin-top:90px;display:flex;position:relative;overflow:visible}.section-divider{justify-content:center;align-items:center;width:100%;max-width:600px;height:40px;margin:1rem 0;display:flex;position:relative}.section-divider:before{content:"";background:repeating-linear-gradient(90deg,#0000001f 0 8px,#0000 8px 14px);height:1.5px;position:absolute;top:50%;left:10%;right:10%}.section-divider:after{content:"✦";z-index:1;color:#00000026;background:var(--background);padding:0 .8rem;font-size:.8rem;position:relative}.stick-figure-container{z-index:5;flex-direction:column;align-items:center;margin-top:5px;display:flex;position:relative}.head{z-index:2;margin-bottom:-24px;position:relative}.head-photo{object-fit:contain;width:clamp(180px,28vw,420px);height:auto}.stick-body{z-index:1;margin-top:clamp(-120px,-9vw,-60px);position:relative;overflow:visible}.waving-arm{transform-origin:50px 28px;animation:1s ease-in-out infinite wave}@keyframes wave{0%,to{transform:rotate(0)}25%{transform:rotate(-15deg)}75%{transform:rotate(15deg)}}.hero-text{text-align:left}.greeting{font-family:var(--font-shadows),cursive;color:#2d2d2d;text-shadow:2px 2px #0000000d;letter-spacing:1px;align-items:center;gap:.5rem;margin-bottom:.5rem;font-size:clamp(1.7rem,4.5vw,3.5rem);font-weight:400;display:flex}.wave-emoji{transform-origin:70% 70%;animation:1.5s ease-in-out infinite wave-hand;display:inline-block}@keyframes wave-hand{0%,to{transform:rotate(0)}25%{transform:rotate(20deg)}75%{transform:rotate(-10deg)}}.title{font-family:var(--font-shadows),cursive;color:#2d2d2d;letter-spacing:3px;text-shadow:2px 2px #0000000d;font-size:clamp(1.4rem,3.5vw,2.8rem);font-weight:400}.icon-wrapper{opacity:.7;cursor:pointer;z-index:20;transition:all .3s;position:absolute}.icon-wrapper:hover{opacity:1;transform:scale(1.1)rotate(5deg)}.icon-tooltip{color:#2a2a2a;text-align:center;opacity:0;visibility:hidden;z-index:1000;pointer-events:none;background:#fffef0;border:1px solid #00000014;border-radius:4px;width:max-content;max-width:280px;padding:.8rem 1.2rem;font-family:Shadows Into Light,Caveat,cursive;font-size:1.25rem;font-weight:600;transition:opacity .3s,visibility .3s;position:absolute;bottom:calc(100% + 12px);left:50%;transform:translate(-50%);box-shadow:3px 4px 10px #0003,0 2px 4px #0000001f}.icon-tooltip:after{content:"";border:10px solid #0000;border-top-color:#fffef0;position:absolute;top:100%;left:50%;transform:translate(-50%)}.icon-tooltip.visible{opacity:1;visibility:visible}.icon-wrapper.icon.book .icon-tooltip{left:7px;transform:translate(0)}.icon-wrapper.icon.book .icon-tooltip:after{left:30px}.icon-wrapper.icon.coffee .icon-tooltip{bottom:calc(100% + 18px);left:7px;transform:translate(0)}.icon-wrapper.icon.coffee .icon-tooltip:after{left:30px}.icon-wrapper.icon.cassette .icon-tooltip{bottom:calc(100% + 18px);left:7px;transform:translate(0)}.icon-wrapper.icon.cassette .icon-tooltip:after{left:30px}.icon-wrapper.icon.cloud .icon-tooltip{inset:calc(100% + 12px) auto auto 50%;transform:translate(-50%)}.icon-wrapper.icon.cloud .icon-tooltip:after{content:"";border:10px solid #0000;border-top:none;border-bottom-color:#fffef0;position:absolute;top:-10px;left:50%;transform:translate(-50%)}.icon-wrapper.icon.floppy .icon-tooltip{inset:50% calc(100% + 12px) auto auto;transform:translateY(-50%)}.icon-wrapper.icon.floppy .icon-tooltip:after{content:"";border:10px solid #0000;border-left-color:#fffef0;border-right:0;position:absolute;top:50%;left:100%;transform:translateY(-50%)}.icon-wrapper.icon.bug .icon-tooltip,.icon-wrapper.icon.chess .icon-tooltip,.icon-wrapper.icon.computer .icon-tooltip{left:auto;right:0;transform:translate(0)}.icon-wrapper.icon.bug .icon-tooltip:after,.icon-wrapper.icon.chess .icon-tooltip:after,.icon-wrapper.icon.computer .icon-tooltip:after{left:auto;right:30px}.icon-wrapper svg{width:clamp(35px,5vw,100%);height:auto}.icon-wrapper.icon.book{top:11%;left:-2%}.icon-wrapper.icon.cloud{top:7%;left:55%}.icon-wrapper.icon.chess{top:12%;left:auto;right:-2%}.icon-wrapper.icon.bug{top:38%;left:auto;right:-1%}.icon-wrapper.icon.coffee{bottom:40%;left:-6%}.icon-wrapper.icon.floppy{bottom:10%;left:auto;right:25%}.icon-wrapper.icon.computer{bottom:17%;left:auto;right:-3%}.icon-wrapper.icon.cassette{bottom:10%;left:-2%}.experience-section{flex-direction:column;justify-content:center;align-items:center;width:100%;max-width:900px;min-height:80vh;padding:5rem 2rem 8rem;scroll-margin-top:90px;display:flex}.exp-title-wrapper{text-align:center;margin-bottom:3rem}.exp-title{font-family:var(--font-shadows),cursive;color:#2d2d2d;letter-spacing:2px;text-shadow:2px 2px #0000000d;font-size:clamp(1.8rem,3.8vw,3rem);font-weight:400}.exp-title-underline{margin:-4px auto 0;display:block}.exp-card{background:#fef9e7 repeating-linear-gradient(#0000,#0000 27px,#b4a0782e 27px 28px);border:none;width:100%;max-width:720px;padding:clamp(1.5rem,3vw,2.5rem) clamp(1.5rem,3vw,2.5rem) clamp(1.2rem,2.5vw,2rem);transition:transform .3s;position:relative;transform:rotate(-.8deg);box-shadow:4px 6px 14px #0000001f,6px 10px 24px #0000000f}.exp-card:hover{transform:rotate(0)translateY(-3px)}.exp-card:before{content:"";pointer-events:none;background:#ff787840;width:2px;height:100%;position:absolute;top:0;left:42px}.exp-tape{z-index:10;clip-path:polygon(0% 15%,3% 5%,1% 25%,4% 35%,0% 50%,3% 60%,1% 75%,4% 85%,0% 95%,2% 100%,10% 95%,20% 100%,30% 96%,45% 100%,55% 97%,70% 100%,80% 95%,90% 100%,98% 97%,100% 88%,97% 75%,100% 60%,96% 50%,100% 40%,97% 30%,100% 20%,96% 10%,100% 5%,98% 0%,85% 5%,75% 0%,60% 4%,50% 0%,35% 5%,20% 0%,10% 4%,2% 0%);background:linear-gradient(#b4d2e68c 0%,#a0c3d780 100%);width:90px;height:22px;position:absolute;top:-10px;left:50%;transform:translate(-50%)rotate(1.5deg)}.exp-header{flex-wrap:wrap;align-items:baseline;gap:.8rem;margin-bottom:1.2rem;padding-left:20px;display:flex}.exp-role{font-family:var(--font-shadows),cursive;color:#2d2d2d;font-size:clamp(1.1rem,2.5vw,1.6rem)}.exp-company{font-family:var(--font-caveat),cursive;color:#4a90d9;font-size:clamp(1.2rem,3vw,1.9rem);font-weight:700;position:relative}.exp-company:before{content:"";pointer-events:none;border:2px solid #4a90d980;border-radius:50% 45% 55% 40%/50% 55% 45% 50%;position:absolute;inset:-6px -10px -4px;transform:rotate(-2deg)}.exp-period{font-family:var(--font-indie),cursive;color:#888;background:#64c86426;border-radius:2px;padding:.15rem .6rem;font-size:1rem;display:inline-block;transform:rotate(1deg)}.exp-description{font-family:var(--font-indie),cursive;color:#3a3a3a;margin-bottom:1.8rem;padding-left:20px;font-size:clamp(1rem,2vw,1.3rem);line-height:1.9}.exp-highlight{color:#2d2d2d;cursor:default;font-weight:600;position:relative}.exp-highlight:after{content:"";z-index:-1;background:#ffe65073;border-radius:2px;height:45%;transition:height .25s,background .25s;position:absolute;bottom:0;left:-3px;right:-3px;transform:rotate(-.5deg)skew(-5deg)}.exp-highlight:hover:after{background:#ffdc328c;height:90%}.exp-tech-stack{flex-wrap:wrap;align-items:center;gap:.6rem;padding-left:20px;display:flex}.exp-tech-label{font-family:var(--font-shadows),cursive;color:#777;margin-right:.3rem;font-size:1.1rem}.exp-tech-tag{font-family:var(--font-indie),cursive;color:#3d3d3d;transform:rotate(var(--tag-rotation,0deg));cursor:default;background:#fef3c7;padding:.3rem .7rem;font-size:.95rem;transition:transform .2s,box-shadow .2s;position:relative;box-shadow:2px 3px 6px #0000001a,1px 1px 3px #0000000f}.exp-tech-tag:nth-child(2){--tag-rotation:-1.5deg}.exp-tech-tag:nth-child(3){--tag-rotation:2deg}.exp-tech-tag:nth-child(4){--tag-rotation:-.5deg}.exp-tech-tag:nth-child(5){--tag-rotation:1.8deg}.exp-tech-tag:nth-child(6){--tag-rotation:-2deg}.exp-tech-tag:hover{transform:rotate(0)scale(1.1)translateY(-2px);box-shadow:3px 5px 10px #00000026,2px 2px 5px #00000014}.exp-doodle{opacity:.6;pointer-events:none;transition:opacity .3s;position:absolute}.exp-doodle-cloud{top:-30px;right:-50px;transform:rotate(8deg)}.exp-doodle-server{bottom:-20px;left:-45px;transform:rotate(-5deg)}.exp-doodle-lightning{top:30px;right:-35px;transform:rotate(12deg)}.about-section{flex-direction:column;align-items:center;width:100%;max-width:1100px;padding:4rem 2rem 6rem;scroll-margin-top:90px;display:flex}.about-title-wrapper{text-align:center;margin-bottom:3rem}.about-title{font-family:var(--font-shadows),cursive;color:#2d2d2d;letter-spacing:2px;text-shadow:2px 2px #0000000d;font-size:clamp(1.8rem,3.8vw,3rem);font-weight:400}.about-title-underline{margin:-4px auto 0;display:block}.about-layout{justify-content:center;align-items:center;gap:2rem;width:100%;display:flex}.about-doodles-left,.about-doodles-right{flex-direction:column;flex-shrink:0;align-items:center;gap:2.5rem;display:flex}.about-doodle{opacity:.55;transition:opacity .3s,transform .3s}.about-doodle:hover{opacity:.9;transform:scale(1.12)rotate(-3deg)}.about-doodle-cap{transform:rotate(-8deg)}.about-doodle-bulb{transform:rotate(6deg)}.about-doodle-checklist{transform:rotate(5deg)}.about-doodle-infinity{transform:rotate(-4deg)}.about-card{background:#fdfbf7 repeating-linear-gradient(#0000,#0000 29px,#b4c8dc4d 29px 30px);border:none;width:100%;max-width:720px;padding:clamp(1.5rem,3.5vw,3rem) clamp(1.5rem,3.5vw,3rem) clamp(1.2rem,3vw,2.5rem) clamp(1.5rem,4vw,3.5rem);transition:transform .3s;position:relative;transform:rotate(.6deg);box-shadow:3px 5px 14px #0000001a,5px 8px 22px #0000000d}.about-card:hover{transform:rotate(0)translateY(-2px)}.about-card:before{content:"";pointer-events:none;background:#ff787847;width:2px;height:100%;position:absolute;top:0;left:48px}.about-tape{z-index:10;clip-path:polygon(0% 15%,3% 5%,1% 25%,4% 35%,0% 50%,3% 60%,1% 75%,4% 85%,0% 95%,2% 100%,10% 95%,20% 100%,30% 96%,45% 100%,55% 97%,70% 100%,80% 95%,90% 100%,98% 97%,100% 88%,97% 75%,100% 60%,96% 50%,100% 40%,97% 30%,100% 20%,96% 10%,100% 5%,98% 0%,85% 5%,75% 0%,60% 4%,50% 0%,35% 5%,20% 0%,10% 4%,2% 0%);background:linear-gradient(#c8dca099 0%,#b4c88c8c 100%);width:95px;height:22px;position:absolute;top:-10px;left:50%;transform:translate(-50%)rotate(-1.5deg)}.about-text{font-family:var(--font-indie),cursive;color:#3a3a3a;margin-bottom:1.5rem;padding-left:22px;font-size:clamp(1rem,2vw,1.3rem);line-height:2}.about-text:last-of-type{margin-bottom:0}.about-red-underlined{color:#2d2d2d;white-space:nowrap;vertical-align:baseline;flex-direction:column;align-items:flex-start;font-weight:600;display:inline-flex;position:relative}.about-highlighted{color:#2d2d2d;cursor:default;font-weight:600;position:relative}.about-highlighted:after{content:"";z-index:-1;background:#ffe65073;border-radius:2px;height:42%;transition:height .25s,background .25s;position:absolute;bottom:1px;left:-2px;right:-2px;transform:rotate(-.4deg)skew(-4deg)}.about-highlighted:hover:after{background:#ffdc328c;height:88%}.about-underlined{color:#2d2d2d;flex-direction:column;align-items:flex-start;font-weight:600;display:inline-flex;position:relative}.about-wave-line{pointer-events:none;position:absolute;bottom:-2px;left:0}.about-period{font-family:var(--font-caveat),cursive;color:#666;background:#b4d2fa33;border-radius:2px;padding:.1rem .5rem;font-size:1.1rem;display:inline-block;transform:rotate(1.5deg)}.projects-section{flex-direction:column;align-items:center;width:100%;max-width:1100px;padding:4rem 2rem 6rem;scroll-margin-top:90px;display:flex}.proj-title-wrapper{text-align:center;margin-bottom:3rem}.proj-title{font-family:var(--font-shadows),cursive;color:#2d2d2d;letter-spacing:2px;text-shadow:2px 2px #0000000d;font-size:clamp(1.8rem,3.8vw,3rem);font-weight:400}.proj-title-underline{margin:-4px auto 0;display:block}.proj-grid{grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:2.5rem;width:100%;display:grid}.proj-card{transform:rotate(var(--card-rotation,0deg));background:#fef9e7 repeating-linear-gradient(#0000,#0000 27px,#b4a07829 27px 28px);border:none;flex-direction:column;padding:2.5rem 2rem 1.8rem;transition:transform .3s,box-shadow .3s;display:flex;position:relative;box-shadow:4px 6px 14px #0000001a,6px 10px 22px #0000000d}.proj-card:hover{transform:rotate(0)translateY(-4px);box-shadow:5px 8px 18px #00000024,8px 14px 28px #00000012}.proj-tape{background:linear-gradient(180deg,var(--tape-color,#c8c8b480)0%,var(--tape-color,#b4b4a073)100%);z-index:10;clip-path:polygon(0% 15%,3% 5%,1% 25%,4% 40%,0% 55%,3% 65%,1% 80%,4% 90%,0% 95%,2% 100%,12% 95%,22% 100%,35% 96%,50% 100%,65% 97%,78% 100%,88% 95%,98% 97%,100% 85%,97% 70%,100% 55%,96% 45%,100% 35%,97% 25%,100% 15%,96% 8%,100% 5%,98% 0%,85% 5%,72% 0%,58% 4%,45% 0%,32% 5%,18% 0%,8% 4%,2% 0%);width:80px;height:20px;position:absolute;top:-10px;left:50%;transform:translate(-50%)rotate(1.5deg)}.proj-doodle-wrapper{opacity:.5;pointer-events:none;transition:opacity .3s,transform .3s;position:absolute;top:8px;right:10px}.proj-card:hover .proj-doodle-wrapper{opacity:.85;transform:scale(1.1)rotate(-5deg)}.proj-card-title{font-family:var(--font-shadows),cursive;color:#2d2d2d;letter-spacing:.5px;margin-bottom:.8rem;padding-right:55px;font-size:clamp(1.1rem,2.5vw,1.55rem);font-weight:400}.proj-card-desc{font-family:var(--font-indie),cursive;color:#444;flex:1;margin-bottom:1.2rem;font-size:clamp(.9rem,1.8vw,1.15rem);line-height:1.8}.proj-tech-row{flex-wrap:wrap;gap:.5rem;margin-bottom:1.2rem;display:flex}.proj-tech-tag{font-family:var(--font-indie),cursive;color:#3d3d3d;transform:rotate(var(--tag-rot,0deg));cursor:default;background:#fef3c7;padding:.2rem .6rem;font-size:.88rem;transition:transform .2s,box-shadow .2s;box-shadow:2px 2px 5px #00000014,1px 1px 2px #0000000d}.proj-tech-tag:first-child{--tag-rot:-1deg}.proj-tech-tag:nth-child(2){--tag-rot:1.5deg}.proj-tech-tag:nth-child(3){--tag-rot:-.5deg}.proj-tech-tag:nth-child(4){--tag-rot:1.8deg}.proj-tech-tag:hover{transform:rotate(0)scale(1.1)translateY(-1px);box-shadow:3px 4px 8px #0000001f,2px 2px 4px #0000000f}.proj-buttons{flex-wrap:wrap;gap:.8rem;display:flex}.proj-btn{font-family:var(--font-indie),cursive;cursor:pointer;border:1.5px solid #2d2d2d;border-radius:2px;align-items:center;padding:.45rem 1rem;font-size:1rem;text-decoration:none;transition:transform .2s,box-shadow .2s,background .2s;display:inline-flex;position:relative}.proj-btn-gh{color:#2d2d2d;background:#fdfbf7}.proj-btn-gh:hover{color:#fdfbf7;background:#2d2d2d;transform:translateY(-2px);box-shadow:3px 4px 8px #00000026}.proj-btn-demo{color:#2d6aa6;background:#4a90d91f;border-color:#4a90d9}.proj-btn-demo:hover{color:#fff;background:#4a90d9;transform:translateY(-2px);box-shadow:3px 4px 8px #4a90d94d}.proj-btn-disabled{opacity:.45;cursor:not-allowed;border-style:dashed}.proj-btn-disabled:hover{box-shadow:none;color:#2d2d2d;background:#fdfbf7;transform:none}.proj-btn-here{cursor:default;color:#4a7a4a;background:#64c8641f;border-style:dashed;border-color:#6a6}.proj-btn-here:hover{box-shadow:none;color:#4a7a4a;background:#64c86433;transform:none}.contact-section{flex-direction:column;justify-content:center;align-items:center;width:100%;max-width:900px;min-height:85vh;padding:1.2rem 2rem 4rem;scroll-margin-top:90px;display:flex}.contact-title-wrapper{text-align:center;margin-bottom:3rem}.contact-title{font-family:var(--font-shadows),cursive;color:#2d2d2d;letter-spacing:2px;text-shadow:2px 2px #0000000d;font-size:clamp(1.8rem,3.8vw,3rem);font-weight:400}.contact-title-underline{margin:-4px auto 0;display:block}.contact-layout{justify-content:center;width:100%;display:flex;position:relative}.contact-note{clip-path:polygon(0% 2%,3% 0%,8% 3%,14% 0%,20% 2%,28% 0%,35% 1%,42% 0%,50% 2%,58% 0%,65% 1%,72% 0%,80% 2%,88% 0%,94% 1%,100% 0%,100% 4%,99% 10%,100% 18%,99% 26%,100% 34%,99% 42%,100% 52%,99% 60%,100% 68%,99% 76%,100% 84%,99% 92%,100% 98%,98% 100%,92% 98%,85% 100%,78% 99%,70% 100%,62% 98%,55% 100%,48% 99%,40% 100%,32% 98%,24% 100%,16% 99%,8% 100%,2% 98%,0% 100%,0% 96%,1% 90%,0% 82%,1% 74%,0% 66%,1% 58%,0% 50%,1% 42%,0% 34%,1% 26%,0% 18%,1% 10%,0% 4%);background:#fef9e7 repeating-linear-gradient(#0000,#0000 27px,#b4a07829 27px 28px);width:100%;max-width:580px;padding:clamp(1.5rem,3.5vw,3rem) clamp(1.5rem,3.5vw,3rem) clamp(1.2rem,3vw,2.5rem);transition:transform .3s;position:relative;transform:rotate(-1.2deg);box-shadow:4px 6px 16px #0000001a,6px 10px 24px #0000000d}.contact-note:hover{transform:rotate(0)translateY(-3px)}.contact-tape{z-index:10;clip-path:polygon(0% 15%,3% 5%,1% 25%,4% 40%,0% 55%,3% 65%,1% 80%,4% 90%,0% 95%,2% 100%,12% 95%,22% 100%,35% 96%,50% 100%,65% 97%,78% 100%,88% 95%,98% 97%,100% 85%,97% 70%,100% 55%,96% 45%,100% 35%,97% 25%,100% 15%,96% 8%,100% 5%,98% 0%,85% 5%,72% 0%,58% 4%,45% 0%,32% 5%,18% 0%,8% 4%,2% 0%);background:linear-gradient(#e6be8299 0%,#d2aa6e8c 100%);width:100px;height:22px;position:absolute;top:-6px;left:50%;transform:translate(-50%)rotate(2deg)}.contact-header-text{font-family:var(--font-shadows),cursive;color:#2d2d2d;text-align:center;letter-spacing:.5px;margin-bottom:2rem;font-size:clamp(1.1rem,2.5vw,1.6rem)}.contact-links{flex-direction:column;gap:1.6rem;margin:0;padding:0;list-style:none;display:flex}.contact-link-item{align-items:center;gap:1rem;display:flex}.contact-link-doodle{opacity:.65;flex-shrink:0;transition:opacity .3s,transform .3s;display:flex}.contact-link-item:hover .contact-link-doodle{opacity:1;transform:rotate(-5deg)scale(1.1)}.contact-link{font-family:var(--font-indie),cursive;color:#3a3a3a;padding:.15rem .3rem;font-size:clamp(.9rem,2vw,1.25rem);text-decoration:none;transition:color .2s;position:relative}.contact-link:after{content:"";z-index:-1;background:#ffe65080;border-radius:2px;height:0;transition:height .25s;position:absolute;bottom:0;left:-2px;right:-2px;transform:skew(-3deg)}.contact-link:hover{color:#1a1a1a}.contact-link:hover:after{height:55%}.contact-deco{opacity:.4;pointer-events:none;transition:opacity .3s;position:absolute}.contact-deco-clip{top:-20px;left:-25px;transform:rotate(15deg)}.contact-deco-coffee{bottom:-15px;right:-40px;transform:rotate(-8deg)}.site-footer{text-align:center;border-top:1px dashed #00000014;width:100%;padding:2rem 1rem 2.5rem}.footer-text{font-family:var(--font-indie),cursive;color:#999;letter-spacing:.5px;font-size:.9rem}.drawing-canvas{z-index:50;position:absolute;top:0;left:0}.drawing-toolbar{z-index:410;flex-direction:column-reverse;align-items:center;gap:8px;display:flex;position:fixed;bottom:clamp(16px,3vh,24px);right:clamp(16px,3vw,24px)}.drawing-toolbar-toggle{cursor:pointer;background:#fef9e7;border:2px solid #0000001f;border-radius:50%;justify-content:center;align-items:center;width:50px;height:50px;transition:transform .25s,box-shadow .25s,background .25s;display:flex;box-shadow:3px 4px 10px #00000026,1px 2px 4px #00000014}.drawing-toolbar-toggle:hover{background:#fef3c7;transform:scale(1.08)rotate(-3deg);box-shadow:4px 6px 14px #0003,2px 3px 6px #0000001a}.drawing-tools{background:#fef9e7;border:2px solid #00000014;border-radius:2px;flex-direction:column;align-items:center;gap:4px;padding:10px 8px;animation:.25s toolbar-slide-in;display:flex;transform:rotate(-1deg);box-shadow:3px 5px 14px #00000024,2px 2px 6px #0000000f}@keyframes toolbar-slide-in{0%{opacity:0;transform:translateY(10px)rotate(-1deg)}to{opacity:1;transform:translateY(0)rotate(-1deg)}}.drawing-tool-btn{cursor:pointer;background:0 0;border:1.5px solid #0000;border-radius:2px;justify-content:center;align-items:center;width:46px;height:46px;transition:background .2s,border-color .2s,transform .2s;display:flex;position:relative}.drawing-tool-btn:hover{background:#ffe65033;transform:rotate(2deg)}.drawing-tool-btn.active{background:#e85d3a1a;border-color:#e85d3a59;transform:rotate(-1.5deg)}.drawing-tool-divider{background:repeating-linear-gradient(90deg,#00000026 0 4px,#0000 4px 8px);width:32px;height:1.5px;margin:2px 0}.drawing-hint-bubble{z-index:415;pointer-events:none;animation:3s ease-in-out infinite hint-float,.5s hint-fade-in;position:fixed;bottom:72px;right:12px}.drawing-hint-svg{position:absolute;top:0;left:0}.drawing-hint-text{z-index:1;font-family:var(--font-caveat),cursive;color:#888;white-space:nowrap;letter-spacing:.3px;padding:8px 16px 14px;font-size:1rem;display:block;position:relative}@keyframes hint-float{0%,to{transform:translateY(0)}50%{transform:translateY(-4px)}}@keyframes hint-fade-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@media (max-width:1280px){.header{transform:translate(-50%)rotate(-3deg)scale(.88)}.icon-wrapper{transform:scale(.8)}}@media (max-width:1100px){.header{transform:translate(-50%)rotate(-3deg)scale(.75)}.icon-wrapper{transform:scale(.65)}.icon-wrapper.icon.coffee,.icon-wrapper.icon.bug{display:none}.drawing-toolbar{bottom:16px;right:16px}.drawing-hint-bubble{bottom:66px;right:6px}}@media (max-width:1024px){.icon-wrapper{transform:scale(.55)}.icon-wrapper.icon.coffee,.icon-wrapper.icon.computer,.icon-wrapper.icon.cassette,.icon-wrapper.icon.bug{display:none}.about-card{max-width:600px}.exp-card{max-width:640px}}@media (max-width:768px){.header{transform-origin:top;width:min(98vw,600px);top:10px;left:50%;transform:translate(-50%)rotate(-2deg)scale(.78)}.header:before{width:58px;height:16px;top:-8px}.nav-bar{width:100%;padding:.5rem .7rem .65rem}.nav-bar ul{flex-wrap:nowrap;justify-content:space-between;gap:.2rem}.nav-bar li{min-width:0}.nav-bar a{white-space:nowrap;padding:.08rem .2rem;font-size:clamp(.58rem,2.15vw,.78rem)}.separator{margin:0 .05rem;font-size:.58rem}.main-content{padding-top:92px}.home-section{text-align:center;flex-direction:column;min-height:calc(100vh - 80px)}.hero-text{text-align:center}.greeting{justify-content:center}.icon-wrapper,.icon-tooltip{display:none!important}.experience-section{padding:3rem 1rem 4rem}.exp-card{transform:rotate(0)}.exp-card:before{left:20px}.exp-header,.exp-description,.exp-tech-stack{padding-left:0}.exp-doodle{display:none}.about-section{padding:3rem 1rem 4rem}.about-layout{flex-direction:column;gap:1.5rem}.about-doodles-left,.about-doodles-right{flex-direction:row;gap:2rem}.about-card{max-width:100%;transform:rotate(0)}.about-text{padding-left:0;line-height:1.85}.about-card:before{display:none}.projects-section{padding:3rem 1rem 4rem}.proj-grid{grid-template-columns:1fr;gap:2rem}.proj-card{transform:rotate(0)!important}.proj-doodle-wrapper{opacity:.4}.contact-section{min-height:auto;padding:3rem 1rem 2rem}.contact-note{clip-path:none;transform:rotate(0)}.contact-deco{display:none}.contact-link-doodle svg{width:40px;height:40px}.drawing-toolbar{bottom:16px;right:16px}.drawing-toolbar-toggle{width:44px;height:44px}.drawing-hint-bubble{bottom:62px;right:8px}}@media (max-width:480px){.header{width:min(99vw,520px);top:8px;transform:translate(-50%)rotate(-1.8deg)scale(.68)}.nav-bar{padding:.4rem .55rem .52rem}.nav-bar a{padding:.05rem .12rem;font-size:clamp(.5rem,2.7vw,.64rem)}.separator{display:none}body{background-image:repeating-linear-gradient(to bottom,transparent 0px,transparent 29px,var(--line-color)29px,var(--line-color)30px);background-size:100% 30px}.main-content{padding:84px 1rem 1rem}.home-section{min-height:calc(100vh - 60px)}.section-divider{max-width:200px;height:30px}.experience-section{min-height:auto;padding:2rem .8rem 3rem}.exp-card:before,.exp-company:before{display:none}.exp-description{line-height:1.75}.exp-tech-tag{padding:.2rem .5rem;font-size:.85rem}.about-section{padding:2rem .8rem 3rem}.about-doodles-left,.about-doodles-right{gap:1rem;transform:scale(.8)}.about-text{line-height:1.75}.about-red-underlined{white-space:normal}.projects-section{padding:2rem .8rem 3rem}.proj-card-title{padding-right:45px}.proj-card-desc{line-height:1.7}.proj-doodle-wrapper{top:4px;right:4px;transform:scale(.7)}.proj-btn{padding:.35rem .8rem;font-size:.9rem}.contact-section{padding:2rem .8rem}.contact-link-doodle svg{width:32px;height:32px}.contact-links{gap:1.2rem}.site-footer{padding:1.5rem .8rem 2rem}.footer-text{font-size:.8rem}.drawing-toolbar{bottom:12px;right:12px}.drawing-toolbar-toggle{width:40px;height:40px}.drawing-hint-bubble{display:none}}
