.astro-route-announcer{position:absolute;left:0;top:0;clip:rect(0 0 0 0);clip-path:inset(50%);overflow:hidden;white-space:nowrap;width:1px;height:1px}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #090909;--bg-card: #111;--bg-card-hover: #161616;--border: #1e1e1e;--border-hover: #2e2e2e;--orange: #f97316;--orange-dim: rgba(249, 115, 22, .12);--blue: #3b82f6;--blue-dim: rgba(59, 130, 246, .12);--text: #e8e8e8;--text-muted: #666;--text-sub: #999}html{scroll-behavior:smooth}body{font-family:system-ui,-apple-system,sans-serif;background:var(--bg);color:var(--text);line-height:1.7;min-height:100vh}a{color:inherit;text-decoration:none}nav{position:fixed;top:0;left:0;right:0;z-index:100;display:flex;align-items:center;justify-content:space-between;padding:1rem 2.5rem;background:#090909d9;backdrop-filter:blur(12px);border-bottom:1px solid var(--border)}.nav-logo{font-weight:700;font-size:1.1rem;color:var(--orange);letter-spacing:-.02em}.nav-links{display:flex;gap:2rem;list-style:none}.nav-links a{color:var(--text-sub);font-size:.9rem;transition:color .2s}.nav-links a:hover{color:var(--text)}.nav-links a.active{color:var(--orange)}main{padding-top:5rem}.hero{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;min-height:calc(100vh - 5rem);padding:4rem 2rem}.hero-tag{display:inline-block;background:var(--orange-dim);color:var(--orange);font-size:.8rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;padding:.3rem .9rem;border-radius:999px;border:1px solid rgba(249,115,22,.25);margin-bottom:1.5rem}.hero h1{font-size:clamp(2.5rem,6vw,5rem);font-weight:800;letter-spacing:-.03em;line-height:1.1;margin-bottom:1.25rem}.hero h1 span.orange{color:var(--orange)}.hero h1 span.blue{color:var(--blue)}.hero p{font-size:1.15rem;color:var(--text-sub);max-width:520px;margin-bottom:2.5rem}.btn-group{display:flex;gap:1rem;flex-wrap:wrap;justify-content:center}.btn{display:inline-block;padding:.7rem 1.6rem;border-radius:8px;font-weight:600;font-size:.95rem;transition:all .2s}.btn-primary{background:var(--orange);color:#000}.btn-primary:hover{background:#ea6c0a}.btn-secondary{background:transparent;color:var(--text);border:1px solid var(--border-hover)}.btn-secondary:hover{border-color:var(--blue);color:var(--blue)}.section{max-width:960px;margin:0 auto;padding:5rem 2rem}.section-label{font-size:.8rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--blue);margin-bottom:.75rem}.section h2{font-size:2rem;font-weight:700;letter-spacing:-.02em;margin-bottom:1rem}.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.25rem;margin-top:2.5rem}.card{display:block;background:var(--bg-card);border:1px solid var(--border);border-radius:12px;padding:1.75rem;transition:border-color .2s,background .2s,transform .2s;cursor:pointer;view-transition-name:var(--transition-name)}.card:hover{border-color:var(--orange);background:var(--bg-card-hover);transform:translateY(-2px)}.card-icon{width:40px;height:40px;border-radius:8px;background:var(--orange-dim);border:1px solid rgba(249,115,22,.2);display:flex;align-items:center;justify-content:center;margin-bottom:1rem;font-size:1.2rem}.card h2{font-size:1.1rem;font-weight:600;margin-bottom:.4rem}.card p{font-size:.9rem;color:var(--text-sub);margin-bottom:1.25rem}.card-meta{display:flex;justify-content:space-between;align-items:center}.date{font-size:.8rem;color:var(--text-muted)}.tags{display:flex;gap:.4rem;flex-wrap:wrap}.tag{background:var(--blue-dim);color:var(--blue);border-radius:4px;padding:.15rem .55rem;font-size:.72rem;font-weight:500}.project-hero{padding:4rem 2rem 2rem;max-width:800px;margin:0 auto}.project-hero h1{font-size:clamp(1.8rem,4vw,3rem);font-weight:800;letter-spacing:-.03em;margin:1rem 0 .75rem}.project-hero p.lead{font-size:1.1rem;color:var(--text-sub);margin-bottom:1.5rem}.project-meta{display:flex;gap:.75rem;align-items:center;flex-wrap:wrap;margin-bottom:2rem}.divider{border:none;border-top:1px solid var(--border);max-width:800px;margin:0 auto}.project-body{max-width:800px;margin:0 auto;padding:2.5rem 2rem}.project-body h2{font-size:1.4rem;font-weight:700;margin:2rem 0 .75rem;color:var(--orange)}.project-body h3{font-size:1.1rem;font-weight:600;margin:1.5rem 0 .5rem}.project-body p{margin-bottom:1rem;color:var(--text-sub)}.project-body ul,.project-body ol{padding-left:1.5rem;margin-bottom:1rem;color:var(--text-sub)}.project-body li{margin-bottom:.3rem}.project-body code{background:#1a1a1a;border:1px solid var(--border);border-radius:4px;padding:.1rem .4rem;font-size:.85em;color:var(--orange)}.project-body pre{background:#111;border:1px solid var(--border);border-radius:8px;padding:1.25rem;overflow-x:auto;margin-bottom:1.5rem}.project-body pre code{background:none;border:none;padding:0;color:var(--text)}.download-section{max-width:800px;margin:0 auto;padding:2rem;border-top:1px solid var(--border)}.download-btn{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1.75rem;background:var(--orange);color:#000;border-radius:8px;font-weight:700;font-size:.95rem;transition:background .2s}.download-btn:hover{background:#ea6c0a}.project-comment{font-size:.95rem;color:var(--text-muted);font-style:italic;margin-bottom:1.25rem;padding-left:1rem;border-left:2px solid var(--orange)}.about-content{max-width:680px}.about-content p{color:var(--text-sub);margin-bottom:1.25rem;font-size:1.05rem}.skill-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:.75rem;margin-top:1.5rem}.skill-item{background:var(--bg-card);border:1px solid var(--border);border-radius:8px;padding:.75rem 1rem;font-size:.85rem;color:var(--text-sub);transition:border-color .2s,color .2s}.skill-item:hover{border-color:var(--blue);color:var(--blue)}footer{border-top:1px solid var(--border);padding:2rem;text-align:center;color:var(--text-muted);font-size:.85rem}.back-link{display:inline-flex;align-items:center;gap:.4rem;color:var(--text-muted);font-size:.9rem;transition:color .2s}.back-link:hover{color:var(--orange)}
