:root{--bg:#faf7f2;--bg-secondary:#f2ede5;--bg-tile:#fff;--fg:#2d2418;--fg-secondary:#6b5d4f;--fg-muted:#a89f93;--tile-border:#2d24180f;--tile-hover-border:#2d24181f;--tile-shadow:0 1px 3px #2d24180a;--tile-hover-shadow:0 6px 20px #2d241812;--overlay-bg:#2d241859;--accent:#6b7f5e;--accent-soft:#6b7f5e14;--accent-hover:#5a6d4f;--tag-bg:#2d24180a;--tag-fg:#6b5d4f;--divider:#2d24180f;--radius:18px;--radius-sm:12px;--radius-xs:8px;--tile-sage:#d4dbc8;--tile-sand:#e5ddd0;--tile-clay:#d9c9b8;--tile-moss:#c8d4c0;--tile-stone:#d0ccc6;--tile-dune:#ddd5c8}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-text-size-adjust:100%}body{font-family:var(--font-inter),"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;background:var(--bg);color:var(--fg);-webkit-font-smoothing:antialiased;overflow-x:hidden}body.no-scroll{overflow:hidden}a{color:inherit;text-decoration:none}img{max-width:100%;display:block}button{cursor:pointer;background:0 0;border:none;font-family:inherit}:focus-visible{outline:2px solid var(--accent);outline-offset:2px;border-radius:4px}.tile-interactive:focus-visible{outline-offset:3px;border-radius:var(--radius)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.97)}to{opacity:1;transform:scale(1)}}@keyframes scaleOut{0%{opacity:1;transform:scale(1)}to{opacity:0;transform:scale(.97)}}@keyframes fadeOut{0%{opacity:1}to{opacity:0}}@keyframes shimmer{0%,to{opacity:.55}50%{opacity:1}}@keyframes skeletonShimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.skeleton-image-wrapper{position:relative;overflow:hidden}.skeleton-image-loading{background:linear-gradient(90deg,var(--bg-secondary)0%,#e8e0d5 20%,#f0e9e0 50%,#e8e0d5 80%,var(--bg-secondary)100%);background-size:200% 100%;animation:1.5s ease-in-out infinite skeletonShimmer}.bento-wrapper{justify-content:center;align-items:center;min-height:100vh;padding:20px;display:flex;position:relative}.bento-grid{z-index:1;grid-template-rows:auto;grid-template-columns:repeat(4,1fr);gap:12px;width:100%;max-width:1080px;animation:.5s fadeIn;display:grid;position:relative}.tile{background:var(--bg-tile);border:1px solid var(--tile-border);border-radius:var(--radius);box-shadow:var(--tile-shadow);transition:transform .3s cubic-bezier(.4,0,.2,1),box-shadow .3s cubic-bezier(.4,0,.2,1),border-color .3s;animation:.5s both slideUp;overflow:hidden}.tile:first-child{animation-delay:0s}.tile:nth-child(2){animation-delay:40ms}.tile:nth-child(3){animation-delay:60ms}.tile:nth-child(4){animation-delay:80ms}.tile:nth-child(5){animation-delay:.1s}.tile:nth-child(6){animation-delay:.12s}.tile:nth-child(7){animation-delay:.14s}.tile:nth-child(8){animation-delay:.16s}.tile:nth-child(9){animation-delay:.18s}.tile:nth-child(10){animation-delay:.2s}.tile-interactive{cursor:pointer}.tile-interactive:hover{box-shadow:var(--tile-hover-shadow);border-color:var(--tile-hover-border);transform:translateY(-2px)}.tile-intro{flex-direction:column;grid-column:span 1;justify-content:space-between;min-height:200px;padding:28px;display:flex}.intro-logo{opacity:.8;width:32px;height:32px}.intro-name{letter-spacing:-.03em;color:var(--fg);margin-bottom:4px;font-size:1.25rem;font-weight:700}.intro-title{color:var(--fg-secondary);font-size:.82rem;font-weight:400}.intro-badge{color:var(--accent);background:var(--accent-soft);letter-spacing:.02em;border-radius:100px;align-items:center;gap:6px;width:fit-content;margin-top:18px;padding:4px 11px;font-size:.68rem;font-weight:500;display:inline-flex}.intro-badge-dot{background:var(--accent);border-radius:50%;width:5px;height:5px;animation:2.5s ease-in-out infinite shimmer}.tile-project{border:none;flex-direction:column;justify-content:flex-end;min-height:180px;padding:22px;display:flex;position:relative;overflow:hidden}.tile-interactive.tile-project:hover{box-shadow:0 6px 24px #2d241814}.tile-project-icon{letter-spacing:-.05em;opacity:.12;color:var(--fg);-webkit-user-select:none;user-select:none;font-size:2.8rem;font-weight:800;line-height:1;transition:opacity .3s;position:absolute;top:22px;right:22px}.tile-interactive.tile-project:hover .tile-project-icon{opacity:.18}.tile-project-line{background:var(--fg);opacity:.15;border-radius:1px;width:24px;height:2px;position:absolute;top:20px;left:22px}.tile-project-name{color:var(--fg);letter-spacing:-.01em;margin-bottom:3px;font-size:.95rem;font-weight:600}.tile-project-type{color:var(--fg-secondary);text-transform:uppercase;letter-spacing:.06em;font-size:.7rem;font-weight:400}.tile-project-desc{color:var(--fg-muted);opacity:0;max-height:0;margin-top:4px;font-size:.73rem;font-weight:400;line-height:1.4;transition:max-height .35s cubic-bezier(.4,0,.2,1),opacity .25s;overflow:hidden}.tile-interactive.tile-project:hover .tile-project-desc{opacity:1;max-height:40px}.tile-project-featured{grid-column:span 2;min-height:220px}.tile-project-featured .tile-project-icon{font-size:4rem}.tile-socials{flex-direction:column;justify-content:space-between;gap:16px;padding:24px;display:flex}.socials-label{text-transform:uppercase;letter-spacing:.1em;color:var(--fg-muted);font-size:.68rem;font-weight:600}.socials-links{gap:4px;display:flex}.social-link{border-radius:var(--radius-xs);width:36px;height:36px;color:var(--fg-secondary);justify-content:center;align-items:center;transition:color .2s,background .2s,transform .2s;display:flex}.social-link:hover{color:var(--fg);background:var(--tag-bg);transform:translateY(-1px)}.social-link svg{width:18px;height:18px}.tile-tech{flex-direction:column;grid-column:span 2;justify-content:center;gap:12px;padding:22px;display:flex}.tech-label{text-transform:uppercase;letter-spacing:.1em;color:var(--fg-muted);font-size:.68rem;font-weight:600}.tech-pills{flex-wrap:wrap;gap:5px;display:flex}.tech-pill{background:var(--tag-bg);color:var(--tag-fg);border-radius:100px;padding:4px 11px;font-size:.7rem;font-weight:500}.tile-contact{flex-direction:column;grid-column:span 2;justify-content:center;align-items:flex-start;gap:10px;padding:24px;display:flex}.contact-label{text-transform:uppercase;letter-spacing:.1em;color:var(--fg-muted);font-size:.68rem;font-weight:600}.contact-email{border-radius:var(--radius-xs);background:var(--accent);color:#fff;align-items:center;gap:7px;padding:8px 16px;font-size:.8rem;font-weight:500;transition:background .2s,transform .2s;display:inline-flex}.contact-email:hover{background:var(--accent-hover);transform:translateY(-1px)}.contact-email svg{width:15px;height:15px}.contact-hint{color:var(--fg-muted);letter-spacing:.01em;font-size:.7rem}.overlay{z-index:200;background:var(--overlay-bg);-webkit-backdrop-filter:blur(8px);justify-content:center;align-items:center;padding:24px;animation:.2s fadeIn;display:flex;position:fixed;inset:0}.overlay.closing{animation:.18s forwards fadeOut}.overlay-card{background:var(--bg);border:1px solid var(--tile-border);border-radius:var(--radius);width:100%;max-width:580px;max-height:88vh;animation:.25s cubic-bezier(.4,0,.2,1) scaleIn;overflow-y:auto;box-shadow:0 16px 48px #2d24181f}.overlay.closing .overlay-card{animation:.18s forwards scaleOut}.overlay-card::-webkit-scrollbar{width:4px}.overlay-card::-webkit-scrollbar-track{background:0 0}.overlay-card::-webkit-scrollbar-thumb{background:var(--divider);border-radius:2px}.overlay-carousel{aspect-ratio:16/9;background:var(--bg-secondary);width:100%;position:relative;overflow:hidden}.overlay-carousel-track{cursor:grab;-webkit-user-select:none;user-select:none;width:100%;height:100%;display:flex}.overlay-carousel-track:active{cursor:grabbing}.overlay-carousel-slide{flex:0 0 100%;width:100%;height:100%;position:relative}.overlay-carousel-slide img{pointer-events:none}.overlay-carousel-skeleton{width:100%;height:100%;position:absolute;inset:0}.intro-logo-wrapper{border-radius:6px;flex-shrink:0;width:32px;height:32px;margin-bottom:20px}.overlay-carousel-arrow{color:#fff;z-index:5;background:#2d241899;border-radius:50%;justify-content:center;align-items:center;width:30px;height:30px;padding:0;transition:background .2s;display:flex;position:absolute;top:50%;transform:translateY(-50%)}.overlay-carousel-arrow:hover{background:#2d2418cc}.overlay-carousel-arrow svg{width:14px;height:14px}.overlay-carousel-arrow-left{left:10px}.overlay-carousel-arrow-right{right:10px}.overlay-carousel-dots{z-index:5;gap:5px;display:flex;position:absolute;bottom:10px;left:50%;transform:translate(-50%)}.overlay-carousel-dot{background:#fff6;border-radius:50%;width:6px;height:6px;padding:0;transition:background .2s,transform .2s}.overlay-carousel-dot.active{background:#fff;transform:scale(1.3)}.overlay-close{color:#fff;z-index:5;background:#2d241880;border-radius:50%;justify-content:center;align-items:center;width:30px;height:30px;padding:0;transition:background .2s,transform .2s;display:flex;position:absolute;top:10px;right:10px}.overlay-close:hover{background:#2d2418b3;transform:scale(1.05)}.overlay-close svg{width:14px;height:14px}.overlay-body{padding:28px}.overlay-accent{border-radius:1px;width:28px;height:2px;margin-bottom:16px}.overlay-title{letter-spacing:-.03em;margin-bottom:5px;font-size:1.3rem;font-weight:700}.overlay-type{color:var(--fg-muted);text-transform:uppercase;letter-spacing:.07em;margin-bottom:16px;font-size:.72rem;font-weight:500}.overlay-desc{color:var(--fg-secondary);margin-bottom:22px;font-size:.9rem;line-height:1.75}.overlay-meta{grid-template-columns:1fr 1fr;gap:14px;margin-bottom:22px;display:grid}.overlay-meta-item{flex-direction:column;gap:2px;display:flex}.overlay-meta-label{text-transform:uppercase;letter-spacing:.07em;color:var(--fg-muted);font-size:.65rem;font-weight:600}.overlay-meta-value{font-size:.85rem;font-weight:500}.overlay-tags{flex-wrap:wrap;gap:5px;margin-bottom:22px;display:flex}.overlay-tag{background:var(--tag-bg);color:var(--tag-fg);border-radius:100px;padding:4px 11px;font-size:.7rem;font-weight:500}.overlay-links{flex-wrap:wrap;gap:8px;display:flex}.overlay-link{border-radius:var(--radius-xs);align-items:center;gap:6px;padding:8px 16px;font-size:.8rem;font-weight:500;transition:all .2s;display:inline-flex}.overlay-link svg{width:14px;height:14px}.overlay-link-primary{background:var(--accent);color:#fff}.overlay-link-primary:hover{background:var(--accent-hover);transform:translateY(-1px)}.overlay-link-secondary{border:1px solid var(--tile-border);color:var(--fg)}.overlay-link-secondary:hover{border-color:var(--tile-hover-border);background:var(--tag-bg)}@media (max-width:860px){.bento-wrapper{align-items:flex-start;padding:16px}.bento-grid{grid-template-rows:auto;grid-template-columns:repeat(2,1fr);gap:10px}.tile-project-featured,.tile-tech,.tile-contact{grid-column:span 2}.tile-intro{min-height:160px;padding:24px}.tile-project{min-height:150px;padding:18px}.tile-project-featured{min-height:180px}.tile-project-icon{font-size:2.2rem;top:18px;right:18px}.tile-project-featured .tile-project-icon{font-size:3rem}.tile-project-line{top:16px;left:18px}.tile-socials{padding:20px}.overlay-card{max-width:520px}}@media (max-width:680px){.bento-grid{gap:8px}.intro-name{font-size:1.1rem}.tile-project{min-height:130px;padding:16px}.tile-project-featured{min-height:150px}.tile-project-icon{font-size:1.8rem;top:16px;right:16px}.tile-project-featured .tile-project-icon{font-size:2.4rem}.tile-project-name{font-size:.88rem}.tile-project-type{font-size:.65rem}.tile-tech,.tile-contact{padding:18px}.overlay-card{max-width:100%}.overlay-body{padding:22px}}@media (max-width:500px){.bento-wrapper{padding:10px}.bento-grid{grid-template-columns:1fr;gap:8px}.tile-project-featured,.tile-tech,.tile-contact{grid-column:span 1}.tile{border-radius:var(--radius-sm)}.tile-intro{flex-direction:row;align-items:center;gap:14px;min-height:auto;padding:20px}.intro-logo{width:28px;height:28px;margin-bottom:0}.intro-name{margin-bottom:2px;font-size:1rem}.intro-title{font-size:.75rem}.intro-badge{margin-top:10px;padding:3px 9px;font-size:.65rem}.tile-project{min-height:110px;padding:16px}.tile-project-featured{min-height:130px}.tile-project-icon{font-size:1.6rem;top:14px;right:14px}.tile-project-featured .tile-project-icon{font-size:2rem}.tile-project-line{width:18px;top:14px;left:16px}.tile-project-name{margin-bottom:2px;font-size:.85rem}.tile-project-type{font-size:.62rem}.tile-project-desc{opacity:.7;max-height:40px;font-size:.7rem}.tile-socials{flex-direction:row;justify-content:space-between;align-items:center;gap:0;padding:18px}.socials-links{gap:2px}.social-link{width:34px;height:34px}.tile-tech{gap:8px;padding:16px}.tech-pill{padding:3px 9px;font-size:.65rem}.tile-contact{gap:8px;padding:16px}.contact-email{padding:7px 14px;font-size:.75rem}.contact-hint{font-size:.65rem}.overlay{align-items:flex-end;padding:0}.overlay-card{border-radius:var(--radius-sm)var(--radius-sm)0 0;max-height:92vh;animation:.25s cubic-bezier(.4,0,.2,1) slideUp}.overlay-body{padding:18px}.overlay-title{font-size:1.1rem}.overlay-desc{font-size:.84rem}.overlay-meta{grid-template-columns:1fr 1fr;gap:10px}.overlay-tags{gap:4px}.overlay-tag{padding:3px 9px;font-size:.65rem}.overlay-links{gap:6px}}@media (max-width:380px){.bento-wrapper{padding:8px}.bento-grid{gap:6px}.tile-project{min-height:100px}.overlay-meta{grid-template-columns:1fr}}
@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/2c55a0e60120577a-s.2a48534a.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:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/9c72aa0f40e4eef8-s.18a48cbc.woff2)format("woff2");unicode-range:U+301,U+400-45F,U+490-491,U+4B0-4B1,U+2116}@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/ad66f9afd8947f86-s.7a40eb73.woff2)format("woff2");unicode-range:U+1F??}@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/5476f68d60460930-s.c995e352.woff2)format("woff2");unicode-range:U+370-377,U+37A-37F,U+384-38A,U+38C,U+38E-3A1,U+3A3-3FF}@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/2bbe8d2671613f1f-s.76dcb0b2.woff2)format("woff2");unicode-range:U+102-103,U+110-111,U+128-129,U+168-169,U+1A0-1A1,U+1AF-1B0,U+300-301,U+303-304,U+308-309,U+323,U+329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/1bffadaabf893a1e-s.7cd81963.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:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/83afe278b6a6bb3c-s.p.3a6ba036.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:Inter Fallback;src:local(Arial);ascent-override:90.44%;descent-override:22.52%;line-gap-override:0.0%;size-adjust:107.12%}.inter_2fe1ab3d-module__-T-KAq__className{font-family:Inter,Inter Fallback;font-style:normal}.inter_2fe1ab3d-module__-T-KAq__variable{--font-inter:"Inter","Inter Fallback"}
