body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}*,:after,:before{box-sizing:border-box}:root{--bg:#fff;--text:#111827;--muted:#444;--link:#0077b6;--link-hover:#005f87;--nav:#282c34;--accent:#61dafb;--card:#0f172a;--cardText:#e5e7eb;--chipBg:#ffffff24;--ring:#61dafb;--radius:16px;--shadow:0 6px 18px #0000001f;--shadow-lg:0 12px 28px #00000038}html{scroll-behavior:smooth}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#fff;background:var(--bg);color:#111827;color:var(--text);font-family:system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;line-height:1.5;margin:0}@media (prefers-reduced-motion:reduce){*,:after,:before{animation:none!important;transition:none!important}}.container{margin-inline:auto;max-width:1200px;padding-inline:16px;width:100%}nav{background-color:#282c34;background-color:var(--nav);padding:10px;position:-webkit-sticky;position:sticky;text-align:center;top:0;z-index:1000}nav a{color:#fff;font-size:18px;margin:0 15px;outline-offset:2px;text-decoration:none;transition:color .2s ease}nav a:hover{color:#61dafb;color:var(--accent)}nav a:focus-visible{border-radius:6px;outline:2px solid #61dafb;outline:2px solid var(--accent)}nav a.active{font-weight:700;text-decoration:underline}.hero{padding:48px 16px 16px;text-align:center}.hero h1{font-size:clamp(28px,3.8vw,42px);margin:0 0 10px}.hero p{color:#444;color:var(--muted);font-size:clamp(16px,1.4vw,18px);margin:0 auto 16px;max-width:720px}.hero-ctas{display:flex;flex-wrap:wrap;gap:12px;justify-content:center}.hero-ctas .btn{background:#0077b6;background:var(--link);border-radius:10px;color:#fff;display:inline-block;padding:.7rem 1.1rem;text-decoration:none;transition:background .2s ease,transform .15s ease}.hero-ctas .btn:hover{background:#005f87;background:var(--link-hover);transform:translateY(-1px)}.hero-ctas .btn:focus-visible{outline:2px solid #61dafb;outline:2px solid var(--ring);outline-offset:2px}.projects-container{align-items:center;display:flex;flex-direction:column;padding:24px 16px}.projects{grid-gap:24px;display:grid;gap:24px;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));max-width:1200px;width:100%}.project-card-outer{background:#0f172a;background:var(--card);border-radius:16px;border-radius:var(--radius);border-top:4px solid #0000;box-shadow:0 6px 18px #0000001f;box-shadow:var(--shadow);color:#e5e7eb;color:var(--cardText);min-height:180px;padding:16px;position:relative;transition:transform .18s ease,box-shadow .18s ease}.project-card-outer:hover{box-shadow:0 12px 28px #00000038;box-shadow:var(--shadow-lg);transform:translateY(-4px)}.card-title{color:#fff;font-size:18px;font-weight:800;margin:4px 0 6px}.card-summary{color:#cbd5e1;font-size:14px;margin:0 0 10px}.topic-badge{background:#ffffff26;border-radius:999px;color:#fff;font-size:11px;padding:4px 8px;position:absolute;right:12px;top:12px}.chip-row{display:flex;flex-wrap:wrap;gap:6px}.chip{background:#ffffff24;background:var(--chipBg);border-radius:999px;color:#fff;font-size:12px;padding:4px 8px}.chip.subtle{opacity:.85}.project-card{aspect-ratio:16/9;background:#0f172a;background:var(--card);border-radius:16px;border-radius:var(--radius);box-shadow:0 6px 18px #0000001f;box-shadow:var(--shadow);cursor:pointer;overflow:hidden;position:relative;transition:transform .18s ease,box-shadow .18s ease}.project-card:hover{box-shadow:0 12px 28px #00000038;box-shadow:var(--shadow-lg);transform:translateY(-4px)}.project-card img{display:block;filter:saturate(1.05) contrast(1.02);height:100%;object-fit:cover;transition:transform .25s ease;width:100%}.project-card:hover img{transform:scale(1.02)}.project-card:after{background:linear-gradient(0deg,#0000008c 0,#0000 60%);content:"";inset:0;pointer-events:none;position:absolute}.project-title{bottom:12px;color:#fff;font-size:clamp(16px,2.2vw,22px);font-weight:800;letter-spacing:.2px;text-shadow:0 2px 8px #0009}.card-meta,.project-title{left:16px;position:absolute}.card-meta{bottom:44px;display:flex;flex-wrap:wrap;gap:6px;opacity:0;transform:translateY(6px);transition:all .18s ease}.project-card:hover .card-meta{opacity:1;transform:translateY(0)}.meta-chip{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#ffffff24;background:var(--chipBg);border-radius:999px;color:#fff;font-size:12px;padding:4px 8px}.tile-btn{background:#0000;border:0;color:inherit;cursor:pointer;display:block;height:100%;padding:0;text-align:inherit;width:100%}.tile-btn:focus-visible{outline:none}.tile-btn:focus-visible .project-card,.tile-btn:focus-visible .project-card-outer{outline:2px solid #61dafb;outline:2px solid var(--ring);outline-offset:2px}.project-summary{bottom:12px;color:#d1d5db;font-size:14px;left:16px;line-height:1.35;margin:0;position:absolute;right:16px}.filter-bar{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;margin:10px 0 22px}.filter-chip{background:#fff;border:1px solid #d1d5db;border-radius:999px;color:#111827;cursor:pointer;font-size:14px;padding:6px 10px;transition:border-color .15s ease,transform .1s ease}.filter-chip:hover{transform:translateY(-1px)}.filter-chip.active{border-color:#111827;font-weight:700}.topic-dot{border-radius:999px;display:inline-block;height:10px;margin-right:6px;width:10px}.topic-section{margin:0 auto 24px;max-width:1200px;width:100%}.topic-header{align-items:center;display:flex;font-size:18px;gap:10px;margin:6px 0 12px 4px}.topic-pill{border-radius:999px;height:14px;width:14px}.about{margin:0 auto;max-width:820px;padding:24px 16px;text-align:center}.about p{color:#444;color:var(--muted);font-size:16px;line-height:1.55;margin:0 auto 12px;max-width:70ch}.about-link{background:#0077b6;background:var(--link);border-radius:8px;color:#fff;display:inline-block;margin:0 10px;padding:10px 20px;text-decoration:none;transition:background .2s ease,transform .15s ease}.about-link:hover{background:#005f87;background:var(--link-hover);transform:translateY(-1px)}.about-link:focus-visible{outline:2px solid #61dafb;outline:2px solid var(--ring);outline-offset:2px}.overlay{background:#000000bf;inset:0;position:fixed;z-index:999}.modal{background:#fff;border-radius:8px;box-shadow:0 4px 8px #0003;color:#111;inset:50% auto auto 50%;max-height:80vh;overflow-y:auto;padding:20px;position:fixed;transform:translate(-50%,-50%);width:min(90%,700px);z-index:1000}.close-button{background:#282c34;background:var(--nav);border:none;border-radius:4px;color:#fff;cursor:pointer;padding:8px 16px;position:absolute;right:10px;top:10px;transition:background .2s ease}.close-button:hover{background:#50575d}.close-button:focus-visible{outline:2px solid #61dafb;outline:2px solid var(--ring);outline-offset:2px}.modal img{display:block;height:auto;margin:0 auto 16px;width:100%}.modal-content{text-align:left}.modal-content h1{font-size:24px;margin-bottom:12px}.modal-content p{font-size:16px;margin-bottom:10px}.modal-topic{margin-top:-4px}.modal-chips,.modal-topic{color:#374151}@media (max-width:600px){nav a{font-size:16px}.hero{padding-top:36px}.modal{max-height:90vh;padding:15px}}
/*# sourceMappingURL=main.e5de1126.css.map*/