#app-container{min-height:100vh;display:flex;flex-direction:column}#app-shell{flex:1}header{position:sticky;top:0;z-index:50;background:var(--banner-bg);color:#fff;padding:.5rem .75rem;border-bottom:6px solid var(--banner-accent);display:flex;align-items:center;justify-content:center;min-height:56px}.header-links{display:none}.header-links ul{margin:0;padding:0;list-style:none;display:flex;gap:1rem}.header-links a{color:#fff;text-decoration:none}.header-links a:hover{text-decoration:underline}.mobile-nav{display:flex;gap:10px}.mobile-nav__link{width:44px;height:44px;display:inline-flex;align-items:center;justify-content:center;color:#fff;text-decoration:none;background:var(--banner-bg);border:2px solid var(--r4-ink);border-radius:12px;box-shadow:4px 4px 0 var(--r4-ink);transition:transform .12s ease,box-shadow .12s ease,background .12s ease,color .12s ease}.mobile-nav__link:hover{transform:translate(-2px,-2px);box-shadow:8px 8px 0 var(--r4-ink);background:var(--banner-accent);color:#111}.mobile-nav__link.is-active{background:var(--banner-accent);color:#111}.hero-banner{background:var(--bg);border-bottom:6px solid var(--banner-accent);margin:0;padding-block:var(--hero-pad-y);min-height:18rem;display:grid;place-items:center}.hero-text{font-family:var(--font-heading);font-weight:700;font-size:10rem;color:var(--hero-text);margin:0 auto;paint-order:stroke fill}main{padding-bottom:3rem;display:flex;flex-direction:column;align-items:stretch}#upper-content,#lower-content{display:flex;flex-direction:row;justify-content:center;align-items:flex-start;width:min(95%,100%);margin:0 auto;gap:2rem}#lower-content .app-divs{width:100%}.app-divs{background-color:color-mix(in srgb,var(--bg-elev) 80%,transparent);margin:2rem;position:relative;border:4px solid var(--r4-ink);border-radius:12px;padding:2rem;box-shadow:8px 8px 0 var(--r4-ink)}.app-divs:before{content:"";position:absolute;inset:12px;border-radius:9px;pointer-events:none}.app-divs:after{content:"";position:absolute;left:16px;right:16px;top:10px;height:6px;background:repeating-linear-gradient(90deg,var(--r4-ink) 0 22px,transparent 22px 30px);opacity:.25;pointer-events:none}#app-sidebar{flex:1;max-width:300px;display:flex;flex-direction:column}#app-main-content{flex:3;min-width:0}section{width:min(1100px,100%);margin:2rem auto;color:var(--text);border-radius:2rem;padding:clamp(1.25rem,3vw,2.5rem) clamp(1rem,2.5vw,2rem);display:flex;flex-direction:column;align-items:center;box-sizing:border-box}section.section--wide{width:min(1280px,100%)}section.section--narrow{width:min(900px,100%)}.content{width:100%;display:flex;flex-direction:column;align-items:center}footer{background:var(--banner-bg);color:#fff;text-align:center;padding:1rem;border-top:6px solid var(--banner-accent)}.sidebar-nav{position:fixed;top:110px;right:24px;display:none;flex-direction:column;gap:var(--sidebar-gap);z-index:70}.sidebar-nav__link{width:var(--sidebar-w);height:var(--sidebar-w);display:flex;align-items:center;justify-content:center;color:#fff;background:var(--banner-bg);border:3px solid var(--r4-ink);border-radius:14px;box-shadow:6px 6px 0 var(--r4-ink);text-decoration:none;transition:transform .12s ease,box-shadow .12s ease,background .12s ease}.sidebar-nav__link:hover{transform:translate(-2px,-2px);box-shadow:10px 10px 0 var(--r4-ink);background:var(--banner-accent);color:#111}.sidebar-nav__link.is-active{background:var(--banner-accent);color:#111}.sidebar-nav__link:after{content:attr(aria-label);position:absolute;right:calc(100% + 10px);top:50%;transform:translateY(-50%) translate(6px);opacity:0;pointer-events:none;background:#fff;color:#111;border:2px solid var(--r4-ink);border-radius:8px;padding:.25rem .5rem;white-space:nowrap;box-shadow:4px 4px 0 var(--r4-ink);transition:opacity .12s ease,transform .12s ease}.sidebar-nav__link:hover:after{opacity:1;transform:translateY(-50%) translate(0)}@media (max-width: 768px){section{margin:1.25rem auto;border-radius:1.25rem}}@media (max-width: 1200px){#upper-content,#lower-content{flex-direction:column;align-items:center}#app-sidebar{max-width:none;width:100%}#app-main-content{width:100%}.hero-text{font-size:3rem}}@media (min-width: 1200px){.mobile-nav{display:none}.sidebar-nav{display:flex}#app-shell{padding-right:calc(var(--sidebar-w) + 40px)}}.projects-layout{display:grid;grid-template-columns:260px 1fr;gap:1.5rem;width:min(1100px,100%);margin:0 auto}#projects{width:100%;margin-top:0;padding:0}.projects-section{display:flex;flex-direction:row;grid-template-columns:260px 1fr;gap:1.5rem;width:min(1100px,100%);margin:0 auto;align-items:flex-start}.projects-filters{position:sticky;top:92px;align-self:start}.filters{background:var(--bg-elev);border-radius:14px;border-color:var(--bg);border-width:2px;border-style:solid;margin:0 2rem 0 0;padding:1rem;box-shadow:var(--shadow);flex:2}.project-grid-wrapper{flex:7}.filters__title{margin:0 0 .75rem;font-family:EurostileX,sans-serif;color:var(--accent-2)}.filters__group{margin:1rem 0}.filters__label{font-weight:600;margin-bottom:.5rem;color:var(--text)}.filters__hint{color:var(--text-dim);font-size:.9rem}.filters__list{list-style:none;padding:0;margin:0;display:grid;gap:.25rem}.filters__check{display:flex;gap:.5rem;align-items:center}.filters__chips,.filters__row{display:flex;gap:.5rem;flex-wrap:wrap}.filters__chip{background:var(--accent);color:#111;border:0;border-radius:999px;padding:.3rem .6rem;cursor:pointer}.filters__chip.is-active{outline:2px solid #fff2}.filters__reset{width:100%;margin-top:.5rem;background:transparent;border:1px solid #fff3;color:var(--text);border-radius:8px;padding:.45rem .6rem;cursor:pointer}.project-grid{display:flex;flex-wrap:wrap;justify-content:center;gap:1.5rem;margin-top:2rem}.project-card{white-space:normal;word-break:break-word;background:var(--card-bg);width:25rem;height:20rem;box-sizing:border-box;box-shadow:var(--shadow);border-radius:var(--radius);padding:2rem;margin:10px;max-width:320px;min-width:0;display:flex;flex-direction:column}.project-card h3{margin:0;font-family:EurostileX,sans-serif;color:var(--accent-2)}.project-meta{display:flex;gap:.75rem;flex-wrap:wrap;font-size:.85rem;color:var(--muted);margin:0;padding:0}.project-links{margin-top:auto;display:flex;gap:.75rem}.project-links a{text-decoration:none;border:1px solid var(--line);padding:.45rem .7rem;border-radius:10px}#repo-button,#site-button{background:var(--accent);color:#fff}@media (max-width: 768px){.project-card{flex:0 1 calc(50% - 1rem)}}@media (max-width: 480px){.project-card{flex:0 1 100%}}@media (max-width: 1200px){.projects-section{flex-direction:column;align-items:center}}.filter-panel--desktop{display:block;flex:3}.filter-panel--mobile{display:none}@media (max-width: 1200px){.projects-section{flex-direction:column;align-items:center}.filter-panel--desktop{display:none}.filter-panel--mobile{display:block;width:100%}}.filters-mobile{width:100%;margin:.5rem 0 1rem;border:1px solid var(--line);border-radius:12px;background:var(--bg-elev);box-shadow:var(--shadow);overflow:hidden}.filters-mobile__summary{list-style:none;cursor:pointer;display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;font-weight:600;color:var(--text);-webkit-user-select:none;user-select:none}.filters-mobile__summary::-webkit-details-marker{display:none}.filters-mobile[open] .chev{transform:rotate(180deg)}.chev{transition:transform .2s ease}.filters-mobile__content{padding:.75rem 1rem 1rem;border-top:1px solid var(--line)}@media (max-width: 1200px){.projects-filters{position:static;top:auto}}.projects-carousel-wrapper{margin:0 auto}.carousel__viewport{display:flex;align-items:center;overflow-x:auto;overflow-y:hidden;scrollbar-width:none;-ms-overflow-style:none;border:1px solid rgb(43,43,43);border-radius:8px}.carousel__viewport::-webkit-scrollbar{display:none}.carousel-slide{display:flex}:root{--bg: #fb9b05;--bg-elev: #f4f4f4;--text: #1E1E65;--text-outline: #ffffff;--text-dim: #9e9e9e;--hero-text: #1E1E65;--banner-bg: #1E1E65;--card-bg: #fff;--banner-accent: #fb9b05;--accent: #D99E88;--accent-2: #1e1e65;--alert: #ff2a06;--r4-ink: #0b0b0b;--r4-orange: #fb9b05;--r4-cream: #ead8bd;--r4-paper: #fff;--line: #2a2b2d;--muted: #606060;--radius: 20px;--shadow: 0 8px 24px rgba(0,0,0,.25);--speed: .18s;--sidebar-w: 64px;--sidebar-gap: 12px;--hero-pad-y: clamp(1rem, 2vw, 2rem);--font-heading: "Space Grotesk", system-ui, sans-serif}@font-face{font-family:EurostileX;src:url(../public/fonts/EuroStyle\ Normal.woff) format("woff2");font-weight:200;font-style:normal;font-display:swap}@font-face{font-family:EurostileX;src:url(../public/fonts/eurostile.woff) format("woff2");font-weight:200;font-style:normal;font-display:swap}*{box-sizing:border-box}html,body,#root{height:100%}html,body{margin:0;padding:0;background-color:var(--bg);color:var(--text);font-family:Arial,sans-serif;line-height:1.6}#root{min-height:100%;display:flex;flex-direction:column}main{flex:1}ul{list-style:none;padding:0}
