:root{--bg: #0a0b10;--bg-card: #12141c;--bg-card-hi: #161925;--text: #edeef5;--text-dim: #9aa0b4;--text-mute: #646b80;--line: rgba(255, 255, 255, .07);--line-hi: rgba(255, 255, 255, .14);--amber: #ffb547;--green: #4ef19a;--purple: #a78bfa;--gray: #8b91a4;--font-display: "Chakra Petch", system-ui, sans-serif;--font-body: "IBM Plex Sans", system-ui, sans-serif;--font-mono: "JetBrains Mono", monospace}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html{-webkit-font-smoothing:antialiased;scroll-behavior:smooth}body{background:var(--bg);color:var(--text);font-family:var(--font-body);min-height:100vh;overflow-x:hidden}body:before{content:"";position:fixed;inset:0;background:radial-gradient(ellipse 60% 50% at 75% 0%,rgba(255,181,71,.05),transparent 60%),radial-gradient(ellipse 50% 45% at 10% 100%,rgba(167,139,250,.045),transparent 60%);pointer-events:none;z-index:0}.wrap{position:relative;z-index:1;max-width:1080px;margin:0 auto;padding:0 24px 100px}.topbar{display:flex;align-items:center;justify-content:space-between;padding:22px 0;margin-bottom:36px}.back-home{font-family:var(--font-mono);font-size:12.5px;letter-spacing:.5px;color:var(--text-dim);text-decoration:none;padding:7px 12px;border:1px solid var(--line);border-radius:8px;transition:color .15s,border-color .15s,background .15s}.back-home:hover{color:var(--text);border-color:var(--line-hi);background:var(--bg-card)}.topbar-brand{font-family:var(--font-mono);font-size:11px;letter-spacing:2px;color:var(--text-mute);text-transform:uppercase}.hero{margin-bottom:40px}.hero-eyebrow{display:inline-flex;align-items:center;gap:8px;font-family:var(--font-mono);font-size:11.5px;letter-spacing:2px;text-transform:uppercase;color:var(--amber);margin-bottom:16px}.hero-eyebrow .dot{width:7px;height:7px;border-radius:50%;background:var(--green);box-shadow:0 0 8px var(--green)}.hero h1{font-family:var(--font-display);font-size:clamp(38px,6vw,66px);font-weight:700;letter-spacing:-1.5px;line-height:1.02;margin-bottom:18px}.hero p{font-size:16px;font-weight:300;color:var(--text-dim);line-height:1.7;max-width:620px}.tabs{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:32px;padding-bottom:4px}.tab{font-family:var(--font-mono);font-size:12.5px;letter-spacing:.3px;color:var(--text-dim);background:var(--bg-card);border:1px solid var(--line);border-radius:999px;padding:8px 16px;cursor:pointer;transition:color .15s,border-color .15s,background .15s;white-space:nowrap}.tab:hover{color:var(--text);border-color:var(--line-hi)}.tab.active{color:var(--amber);border-color:#ffb54766;background:#ffb54714}.tab-count{margin-left:6px;font-size:10.5px;opacity:.6}.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:20px}.grid-empty{grid-column:1 / -1;text-align:center;color:var(--text-mute);font-family:var(--font-mono);font-size:13px;padding:60px 0}.project-card{display:flex;flex-direction:column;text-align:left;background:var(--bg-card);border:1px solid var(--line);border-radius:16px;overflow:hidden;cursor:pointer;text-decoration:none;color:inherit;font:inherit;width:100%;transition:transform .22s ease,border-color .22s ease,box-shadow .22s ease,background .22s ease}.project-card:hover{transform:translateY(-5px);border-color:var(--line-hi);background:var(--bg-card-hi);box-shadow:0 16px 40px -12px #0009,0 0 0 1px #ffb5470f}.project-card:focus-visible{outline:2px solid var(--amber);outline-offset:2px}.card-media{position:relative;aspect-ratio:16 / 9;overflow:hidden;background:#0d0f16;border-bottom:1px solid var(--line)}.card-media img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;display:block;transition:transform .35s ease}.project-card:hover .card-media img{transform:scale(1.04)}.project-badge{position:absolute;top:12px;right:12px;font-family:var(--font-mono);font-size:11px;font-weight:600;letter-spacing:.2px;padding:4px 10px;border-radius:999px;backdrop-filter:blur(6px);border:1px solid transparent}.badge--green{color:var(--green);background:#4ef19a1f;border-color:#4ef19a4d}.badge--amber{color:var(--amber);background:#ffb5471f;border-color:#ffb5474d}.badge--purple{color:var(--purple);background:#a78bfa24;border-color:#a78bfa52}.badge--gray{color:var(--gray);background:#8b91a424;border-color:#8b91a44d}.card-body{padding:18px 18px 20px;display:flex;flex-direction:column;gap:10px;flex:1}.card-title{font-family:var(--font-display);font-size:18px;font-weight:600;letter-spacing:-.2px;display:flex;align-items:center;gap:7px}.card-arrow{color:var(--text-mute);font-size:14px;transition:color .2s,transform .2s}.project-card:hover .card-arrow{color:var(--amber);transform:translate(2px,-2px)}.card-summary{font-size:13.5px;font-weight:300;color:var(--text-dim);line-height:1.6;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.card-tech{list-style:none;display:flex;flex-wrap:wrap;gap:6px;margin-top:auto;padding-top:4px}.tech-pill{font-family:var(--font-mono);font-size:10.5px;letter-spacing:.2px;color:var(--text-mute);background:#ffffff0a;border:1px solid var(--line);border-radius:6px;padding:3px 8px}.modal-overlay{position:fixed;inset:0;z-index:500;display:flex;align-items:center;justify-content:center;padding:24px;background:#05060ac7;backdrop-filter:blur(6px);opacity:0;pointer-events:none;transition:opacity .22s ease}.modal-overlay.open{opacity:1;pointer-events:auto}.modal{position:relative;width:100%;max-width:540px;max-height:90vh;overflow-y:auto;background:var(--bg-card);border:1px solid var(--line-hi);border-radius:18px;box-shadow:0 30px 80px -20px #000c;transform:translateY(12px) scale(.985);transition:transform .24s ease}.modal-overlay.open .modal{transform:translateY(0) scale(1)}.modal-close{position:absolute;top:12px;right:12px;z-index:2;display:grid;place-items:center;width:34px;height:34px;border-radius:9px;color:var(--text);background:#0a0b1099;border:1px solid var(--line);cursor:pointer;transition:background .15s,border-color .15s}.modal-close:hover{background:#0a0b10e6;border-color:var(--line-hi)}.modal-media{aspect-ratio:16 / 9;overflow:hidden;border-bottom:1px solid var(--line);border-radius:18px 18px 0 0;background:#0d0f16}.modal-media img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;display:block}.modal-body{padding:22px 24px 26px;display:flex;flex-direction:column;gap:14px}.modal-title{font-family:var(--font-display);font-size:24px;font-weight:700;letter-spacing:-.5px}.modal-summary{font-size:14.5px;font-weight:300;color:var(--text-dim);line-height:1.75}.modal-tech{list-style:none;display:flex;flex-wrap:wrap;gap:7px}.modal-cta{align-self:flex-start;margin-top:6px;font-family:var(--font-mono);font-size:13px;font-weight:600;color:var(--bg);background:var(--amber);border-radius:9px;padding:11px 20px;text-decoration:none;transition:transform .15s,box-shadow .15s,filter .15s}.modal-cta:hover{filter:brightness(1.06);transform:translateY(-1px);box-shadow:0 8px 20px -8px #ffb54780}.reveal{opacity:0;transform:translateY(16px);transition:opacity .5s ease,transform .5s ease}.reveal.in{opacity:1;transform:none}@media (max-width: 640px){.grid{grid-template-columns:1fr;gap:16px}.wrap{padding:0 18px 80px}.tabs{gap:6px}.tab{padding:7px 13px;font-size:12px}}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.001ms!important;transition-duration:.001ms!important;scroll-behavior:auto!important}.reveal{opacity:1;transform:none}}
