:root{--color-bg:#101018;--color-panel:#181824;--color-ink:#f4f1de;--color-ink-soft:#b8b5a6;--color-accent:#88c070;--color-accent-2:#f2cc8f;--color-emphasis:#e07a5f;--color-border:#2f3045;--font-display:"Bangers", "Press Start 2P", system-ui, sans-serif;--font-body:"Inter", "Atkinson Hyperlegible", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;--fs-xs:.78rem;--fs-sm:.9rem;--fs-base:1rem;--fs-lg:1.25rem;--fs-xl:1.6rem;--fs-2xl:2.2rem;--fs-3xl:clamp(2.4rem, 6vw, 4rem);--space-1:.25rem;--space-2:.5rem;--space-3:1rem;--space-4:1.5rem;--space-5:2.5rem;--space-6:4rem;--container:1080px;--radius:4px;--border-ink:2px solid var(--color-ink);--border-panel:1px solid var(--color-border);--shadow-panel:4px 4px 0 var(--color-border);--transition:.16s ease}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{background-color:var(--color-bg);color:var(--color-ink);font-family:var(--font-body);font-size:var(--fs-base);-webkit-font-smoothing:antialiased;text-rendering:optimizelegibility;min-height:100vh;line-height:1.6}body:before{content:"";z-index:-1;pointer-events:none;opacity:.4;background-image:radial-gradient(var(--color-border) 1px, transparent 1px);background-size:14px 14px;position:fixed;inset:0}h1,h2,h3{font-family:var(--font-display);letter-spacing:.02em;font-weight:400;line-height:1.1}h1{font-size:var(--fs-3xl)}h2{font-size:var(--fs-2xl)}h3{font-size:var(--fs-xl)}a{color:var(--color-accent);transition:color var(--transition);text-decoration:none}a:hover{color:var(--color-accent-2)}img{max-width:100%;display:block}:focus-visible{outline:3px solid var(--color-accent-2);outline-offset:2px}.skip-link{background:var(--color-accent-2);color:var(--color-bg);padding:var(--space-2) var(--space-3);z-index:100;font-weight:700;position:absolute;top:0;left:-999px}.skip-link:focus{left:var(--space-3);top:var(--space-3)}.container{width:100%;max-width:var(--container);padding-inline:var(--space-3);margin-inline:auto}.page{padding-block:var(--space-6);min-height:60vh}@media (prefers-reduced-motion:reduce){*,:before,:after{scroll-behavior:auto!important;transition:none!important;animation:none!important}}.navbar{z-index:50;background:var(--color-bg);border-bottom:var(--border-ink);position:sticky;top:0}.navbar__inner{justify-content:space-between;align-items:center;gap:var(--space-3);padding-block:var(--space-3);display:flex}.navbar__brand{font-family:var(--font-display);font-size:var(--fs-lg);color:var(--color-ink);letter-spacing:.04em}.navbar__brand:hover{color:var(--color-ink)}.navbar__brand-ext{color:var(--color-emphasis)}.navbar__links{gap:var(--space-3);flex-wrap:wrap;list-style:none;display:flex}.navbar__link{color:var(--color-ink-soft);font-size:var(--fs-sm);padding:var(--space-1) 0;border-bottom:2px solid #0000;font-weight:600}.navbar__link:hover{color:var(--color-ink)}.navbar__link.is-active{color:var(--color-ink);border-bottom-color:var(--color-accent)}@media (width<=600px){.navbar__inner{flex-direction:column;align-items:flex-start}}.footer{border-top:var(--border-ink);margin-top:var(--space-6);background:var(--color-panel)}.footer__inner{justify-content:space-between;align-items:center;gap:var(--space-3);padding-block:var(--space-4);flex-wrap:wrap;display:flex}.footer__note{color:var(--color-ink-soft);font-size:var(--fs-sm)}.footer__links{gap:var(--space-4);list-style:none;display:flex}.footer__links a{font-weight:600;font-size:var(--fs-sm)}.btn{justify-content:center;align-items:center;gap:var(--space-2);font-family:var(--font-body);text-align:center;cursor:pointer;border-radius:var(--radius);border:var(--border-ink);transition:transform var(--transition), box-shadow var(--transition), background var(--transition), color var(--transition);-webkit-user-select:none;user-select:none;white-space:nowrap;font-weight:700;display:inline-flex}.btn--md{padding:var(--space-2) var(--space-4);font-size:var(--fs-base)}.btn--sm{padding:var(--space-1) var(--space-3);font-size:var(--fs-sm)}.btn--primary{background:var(--color-accent);color:var(--color-bg);box-shadow:var(--shadow-panel)}.btn--primary:hover{color:var(--color-bg);background:var(--color-accent-2);box-shadow:6px 6px 0 var(--color-border);transform:translate(-2px,-2px)}.btn--primary:active{box-shadow:1px 1px 0 var(--color-border);transform:translate(2px,2px)}.btn--ghost{color:var(--color-ink);background:0 0}.btn--ghost:hover{color:var(--color-bg);background:var(--color-ink)}.card{background:var(--color-panel);border:var(--border-ink);border-radius:var(--radius);box-shadow:var(--shadow-panel);padding:var(--space-4);transition:transform var(--transition), box-shadow var(--transition)}.card:hover{box-shadow:6px 6px 0 var(--color-border);transform:translate(-2px,-2px)}.card--featured{border-color:var(--color-accent);box-shadow:6px 6px 0 var(--color-accent);padding:var(--space-5)}.card--featured:hover{box-shadow:9px 9px 0 var(--color-accent)}.badge{font-size:var(--fs-xs);letter-spacing:.02em;padding:2px var(--space-2);border-radius:var(--radius);border:1px solid var(--color-border);background:var(--color-bg);color:var(--color-ink-soft);white-space:nowrap;font-weight:700;display:inline-block}.badge--accent{border-color:var(--color-accent);color:var(--color-accent)}.badge--accent-2{border-color:var(--color-accent-2);color:var(--color-accent-2)}.badge--emphasis{border-color:var(--color-emphasis);color:var(--color-emphasis)}.bubble{background:var(--color-panel);color:var(--color-ink);border:var(--border-ink);padding:var(--space-3) var(--space-4);border-radius:12px;max-width:60ch;line-height:1.5;display:inline-block;position:relative}.bubble:before,.bubble:after{content:"";border-style:solid;width:0;height:0;position:absolute}.bubble--bottom-left:before{border-width:18px 16px 0 0;border-color:var(--color-ink) transparent transparent transparent;bottom:-18px;left:32px}.bubble--bottom-left:after{border-width:14px 12px 0 0;border-color:var(--color-panel) transparent transparent transparent;bottom:-13px;left:34px}.bubble--bottom-right:before{border-width:18px 0 0 16px;border-color:var(--color-ink) transparent transparent transparent;bottom:-18px;right:32px}.bubble--bottom-right:after{border-width:14px 0 0 12px;border-color:var(--color-panel) transparent transparent transparent;bottom:-13px;right:34px}.project-card{height:100%;padding:0;overflow:hidden}.project-card__link{height:100%;color:inherit;flex-direction:column;display:flex}.project-card__link:hover{color:inherit}.project-card__media{border-bottom:var(--border-ink);background:var(--color-bg);aspect-ratio:16/10;overflow:hidden}.project-card__media img{object-fit:cover;width:100%;height:100%;transition:transform var(--transition)}.project-card__link:hover .project-card__media img{transform:scale(1.03)}.project-card__body{padding:var(--space-4);gap:var(--space-2);flex-direction:column;flex:1;display:flex}.project-card__chapter{font-family:var(--font-display);font-size:var(--fs-xs);letter-spacing:.08em;color:var(--color-emphasis)}.project-card__head{justify-content:space-between;align-items:center;gap:var(--space-2);display:flex}.project-card__title{font-size:var(--fs-lg)}.project-card__tagline{color:var(--color-ink-soft);font-size:var(--fs-sm);flex:1}.project-card__tech{gap:var(--space-2);margin-top:var(--space-2);flex-wrap:wrap;display:flex}.state{border:var(--border-panel);border-radius:var(--radius);background:var(--color-panel);padding:var(--space-5);text-align:center;align-items:center;gap:var(--space-3);flex-direction:column;display:flex}.state__message{color:var(--color-ink-soft)}.state__spinner{border:3px solid var(--color-border);border-top-color:var(--color-accent);border-radius:50%;width:28px;height:28px;animation:.8s linear infinite state-spin}@keyframes state-spin{to{transform:rotate(360deg)}}.state--error{border-color:var(--color-emphasis)}.state__title{font-family:var(--font-display);font-size:var(--fs-xl);letter-spacing:.04em;color:var(--color-emphasis)}.state__actions{gap:var(--space-2);flex-wrap:wrap;justify-content:center;display:flex}.gh{margin-top:var(--space-6)}.gh__head{justify-content:space-between;align-items:center;gap:var(--space-2);margin-bottom:var(--space-4);padding-bottom:var(--space-2);border-bottom:var(--border-panel);flex-wrap:wrap;display:flex}.gh__title{font-size:var(--fs-2xl)}.gh__grid{gap:var(--space-3);grid-template-columns:repeat(auto-fill,minmax(240px,1fr));list-style:none;display:grid}.gh__repo{gap:var(--space-2);height:100%;padding:var(--space-3);background:var(--color-panel);border:var(--border-panel);border-radius:var(--radius);color:inherit;transition:border-color var(--transition), transform var(--transition);flex-direction:column;display:flex}.gh__repo:hover{color:inherit;border-color:var(--color-accent);transform:translateY(-2px)}.gh__repo-name{font-size:var(--fs-base);color:var(--color-accent);word-break:break-word}.gh__repo-desc{font-size:var(--fs-sm);color:var(--color-ink-soft);flex:1}.gh__repo-meta{align-items:center;gap:var(--space-2);display:flex}.gh__stars{font-size:var(--fs-xs);color:var(--color-accent-2)}.gh__empty{border:var(--border-panel);border-radius:var(--radius);background:var(--color-panel);padding:var(--space-5);text-align:center;color:var(--color-ink-soft)}.home__hero{padding-block:var(--space-4) var(--space-6)}.home__chapter{font-family:var(--font-display);font-size:var(--fs-sm);letter-spacing:.08em;color:var(--color-emphasis);margin-bottom:var(--space-2)}.home__title{margin-bottom:var(--space-4)}.home__name{color:var(--color-accent)}.home__bubble{margin-bottom:var(--space-5)}.home__cta{gap:var(--space-3);margin-top:var(--space-4);flex-wrap:wrap;display:flex}.home__section-title{margin-bottom:var(--space-4);padding-bottom:var(--space-2);border-bottom:var(--border-panel)}.home__featured-card h3{margin-bottom:var(--space-2)}.home__badges{gap:var(--space-2);margin-top:var(--space-3);flex-wrap:wrap;display:flex}.home__more{margin-top:var(--space-6)}.home__grid{gap:var(--space-4);margin-bottom:var(--space-4);grid-template-columns:repeat(auto-fill,minmax(260px,1fr));list-style:none;display:grid}.about__chapter{font-family:var(--font-display);letter-spacing:.08em;color:var(--color-emphasis);margin-bottom:var(--space-1)}.about__lead{max-width:70ch;margin-top:var(--space-3);margin-bottom:var(--space-5)}.about__block{margin-bottom:var(--space-5);max-width:70ch}.about__block h2{font-size:var(--fs-xl);margin-bottom:var(--space-3);padding-bottom:var(--space-2);border-bottom:var(--border-panel)}.about__block p{color:var(--color-ink-soft)}.about__badges{gap:var(--space-2);flex-wrap:wrap;display:flex}.projects__header{margin-bottom:var(--space-4)}.projects__chapter{font-family:var(--font-display);letter-spacing:.08em;color:var(--color-emphasis);margin-bottom:var(--space-1)}.projects__intro{color:var(--color-ink-soft);max-width:60ch;margin-top:var(--space-2)}.projects__controls{justify-content:space-between;align-items:center;gap:var(--space-3);margin-bottom:var(--space-3);flex-wrap:wrap;display:flex}.projects__filters{gap:var(--space-2);flex-wrap:wrap;display:flex}.projects__filter{font-family:var(--font-body);font-size:var(--fs-sm);color:var(--color-ink-soft);background:var(--color-panel);border:var(--border-panel);border-radius:var(--radius);padding:var(--space-1) var(--space-3);cursor:pointer;transition:color var(--transition), border-color var(--transition), background var(--transition);font-weight:600}.projects__filter:hover{color:var(--color-ink);border-color:var(--color-ink-soft)}.projects__filter.is-active{color:var(--color-bg);background:var(--color-accent);border-color:var(--color-accent)}.projects__search input{font-family:var(--font-body);font-size:var(--fs-sm);color:var(--color-ink);background:var(--color-panel);border:var(--border-panel);border-radius:var(--radius);padding:var(--space-2) var(--space-3);min-width:240px}.projects__search input::placeholder{color:var(--color-ink-soft)}.projects__count{font-size:var(--fs-sm);color:var(--color-ink-soft);margin-bottom:var(--space-4)}.projects__grid{gap:var(--space-4);grid-template-columns:repeat(auto-fill,minmax(280px,1fr));list-style:none;display:grid}.projects__item{display:flex}.projects__item--featured{grid-column:1/-1}@media (width<=600px){.projects__item--featured{grid-column:auto}}.projects__empty{border:var(--border-panel);border-radius:var(--radius);background:var(--color-panel);padding:var(--space-5);text-align:center;color:var(--color-ink-soft);align-items:center;gap:var(--space-3);flex-direction:column;display:flex}.projects__empty-title{font-family:var(--font-display);font-size:var(--fs-xl);color:var(--color-ink);letter-spacing:.04em}.sr-only{clip:rect(0, 0, 0, 0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.detail__back{margin-bottom:var(--space-4);font-size:var(--fs-sm)}.detail__header{margin-bottom:var(--space-5)}.detail__head-row{align-items:center;gap:var(--space-3);margin-bottom:var(--space-3);flex-wrap:wrap;display:flex}.detail__description{max-width:70ch;color:var(--color-ink-soft)}.detail__tech,.detail__links{gap:var(--space-2);margin-top:var(--space-4);flex-wrap:wrap;display:flex}.detail__shots{gap:var(--space-4);margin-bottom:var(--space-6);grid-template-columns:repeat(auto-fit,minmax(280px,1fr));display:grid}.detail__shot{border:var(--border-ink);border-radius:var(--radius);box-shadow:var(--shadow-panel);background:var(--color-bg);overflow:hidden}.detail__shot img{width:100%;height:auto}.detail__case{gap:var(--space-5);margin-bottom:var(--space-6);display:grid}.detail__case-section{border-left:3px solid var(--color-accent);padding-left:var(--space-4)}.detail__case-section h2{font-size:var(--fs-xl);margin-bottom:var(--space-2)}.detail__case-section p{max-width:70ch;color:var(--color-ink-soft)}.detail__std{gap:var(--space-5);margin-bottom:var(--space-5);display:grid}.detail__block{margin-bottom:var(--space-5)}.detail__block h2{font-size:var(--fs-xl);margin-bottom:var(--space-3);padding-bottom:var(--space-2);border-bottom:var(--border-panel)}.detail__block ul{padding-left:var(--space-4);color:var(--color-ink-soft)}.detail__block li{margin-bottom:var(--space-1)}.detail__highlights{columns:2;column-gap:var(--space-5)}@media (width<=560px){.detail__highlights{columns:1}}.tech__header{margin-bottom:var(--space-5)}.tech__chapter{font-family:var(--font-display);letter-spacing:.08em;color:var(--color-emphasis);margin-bottom:var(--space-1)}.tech__intro{color:var(--color-ink-soft);max-width:65ch;margin-top:var(--space-2)}.tech__list{gap:var(--space-4);grid-template-columns:repeat(auto-fill,minmax(320px,1fr));display:grid}.tech__name{font-size:var(--fs-lg);margin-bottom:var(--space-3);color:var(--color-accent)}.tech__why,.tech__how,.tech__related{margin-bottom:var(--space-2);font-size:var(--fs-sm)}.tech__why strong,.tech__how strong,.tech__related strong{color:var(--color-ink)}.tech__why,.tech__how{color:var(--color-ink-soft)}
