*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #09090f;--surface: #111118;--border: #1e1e2e;--accent: #4f8ef7;--accent2: #a78bfa;--green: #34d399;--amber: #fbbf24;--red: #f87171;--text: #e2e8f0;--muted: #64748b;--subtle: #1e293b}html{scroll-behavior:smooth}body{background:var(--bg);color:var(--text);font-family:DM Sans,sans-serif;font-weight:300;min-height:100vh;background-image:linear-gradient(rgba(79,142,247,.03) 1px,transparent 1px),linear-gradient(90deg,rgba(79,142,247,.03) 1px,transparent 1px);background-size:40px 40px}h1,h2,h3{font-family:Syne,sans-serif;font-weight:700}p{line-height:1.7}a{color:inherit;text-decoration:none}.reveal{opacity:0;transform:translateY(24px);transition:opacity .6s ease,transform .6s ease}.reveal.visible{opacity:1;transform:translateY(0)}.reveal-delay-1{transition-delay:.1s}.reveal-delay-2{transition-delay:.2s}.reveal-delay-3{transition-delay:.3s}.reveal-delay-4{transition-delay:.4s}.section-label{font-family:DM Mono,monospace;font-size:.6rem;letter-spacing:.2em;text-transform:uppercase;color:var(--accent);margin-bottom:.7rem;display:flex;align-items:center;gap:.5rem}.section-label:after{content:"";flex:1;height:1px;background:var(--border)}.tech-tags{display:flex;flex-wrap:wrap;gap:.5rem}.tag{font-family:DM Mono,monospace;font-size:.68rem;padding:.3rem .7rem;border-radius:2px;letter-spacing:.05em}.tag.aws{background:#fbbf2414;color:#fbbf24;border:1px solid rgba(251,191,36,.2)}.tag.lang{background:#4f8ef714;color:#93c5fd;border:1px solid rgba(79,142,247,.2)}.tag.tool{background:#a78bfa14;color:#c4b5fd;border:1px solid rgba(167,139,250,.2)}.tag.other{background:#34d39914;color:#6ee7b7;border:1px solid rgba(52,211,153,.2)}.link-btn{display:inline-flex;align-items:center;gap:.4rem;font-family:DM Mono,monospace;font-size:.68rem;letter-spacing:.08em;text-transform:uppercase;padding:.55rem 1.1rem;border-radius:2px;text-decoration:none;transition:all .15s;white-space:nowrap;cursor:pointer}.link-btn.primary{background:var(--accent);color:#fff;border:1px solid var(--accent)}.link-btn.primary:hover{background:#6ea5ff;border-color:#6ea5ff}.link-btn.ghost{border:1px solid var(--border);color:var(--muted);background:transparent}.link-btn.ghost:hover{border-color:var(--accent);color:var(--accent)}.status-badge{display:inline-flex;align-items:center;gap:.4rem;font-family:DM Mono,monospace;font-size:.65rem;letter-spacing:.1em;text-transform:uppercase;padding:.3rem .75rem;border-radius:2px;border:1px solid}.status-badge.live{color:var(--green);border-color:#34d3994d;background:#34d3990f}.status-badge.wip{color:var(--amber);border-color:#fbbf244d;background:#fbbf240f}.status-badge:before{content:"●";font-size:.5rem}.section{max-width:860px;margin:0 auto;padding:6rem 1.5rem}.section-divider{max-width:860px;margin:0 auto;height:1px;background:linear-gradient(to right,transparent,var(--border),transparent)}.section-eyebrow{font-family:DM Mono,monospace;font-size:.65rem;letter-spacing:.25em;color:var(--accent);text-transform:uppercase;margin-bottom:.75rem}.section-title{font-family:Syne,sans-serif;font-size:clamp(1.8rem,4vw,2.6rem);font-weight:800;color:#fff;letter-spacing:-.02em;line-height:1.1;margin-bottom:1.5rem}.nav{position:fixed;top:0;left:0;right:0;z-index:100;padding:1.1rem 2rem;display:flex;align-items:center;justify-content:space-between;gap:1rem;transition:background .3s,backdrop-filter .3s,border-color .3s;border-bottom:1px solid transparent}.nav.scrolled{background:#09090fe0;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom-color:var(--border)}.nav-logo{font-family:Syne,sans-serif;font-size:1.15rem;font-weight:800;color:#fff;letter-spacing:-.03em;text-decoration:none}.nav-logo span{color:var(--accent)}.nav-links{display:flex;align-items:center;gap:.25rem;list-style:none}.nav-links a{font-family:DM Mono,monospace;font-size:.68rem;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);padding:.4rem .7rem;border-radius:2px;transition:color .15s;text-decoration:none}.nav-links a:hover{color:var(--text)}.nav-right{display:flex;align-items:center;gap:.75rem}.nav-hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:.3rem;background:none;border:none}.nav-hamburger span{display:block;width:22px;height:1.5px;background:var(--muted);transition:all .2s}.nav-hamburger.open span:nth-child(1){transform:translateY(6.5px) rotate(45deg)}.nav-hamburger.open span:nth-child(2){opacity:0}.nav-hamburger.open span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}.hero{position:relative;min-height:100vh;display:flex;align-items:center;justify-content:center;text-align:center;overflow:hidden;padding:8rem 1.5rem 4rem}.hero-glow{position:absolute;width:700px;height:700px;border-radius:50%;background:radial-gradient(circle,rgba(79,142,247,.07) 0%,transparent 70%);top:50%;left:50%;transform:translate(-50%,-50%);animation:heroGlow 8s ease-in-out infinite alternate;pointer-events:none}@keyframes heroGlow{0%{transform:translate(-50%,-50%) scale(.85);opacity:.5}to{transform:translate(-50%,-50%) scale(1.2);opacity:1}}.hero-inner{position:relative;max-width:700px}.hero-eyebrow{font-family:DM Mono,monospace;font-size:.65rem;letter-spacing:.3em;color:var(--accent);text-transform:uppercase;margin-bottom:1.5rem;animation:heroFadeUp .8s .1s ease both}.hero-name{font-family:Syne,sans-serif;font-size:clamp(2.8rem,8vw,5rem);font-weight:800;color:#fff;letter-spacing:-.03em;line-height:1;margin-bottom:1rem;animation:heroFadeUp .8s .25s ease both}.hero-title{font-family:DM Mono,monospace;font-size:clamp(.75rem,2vw,.9rem);letter-spacing:.2em;color:var(--muted);text-transform:uppercase;margin-bottom:1.5rem;animation:heroFadeUp .8s .4s ease both}.hero-tagline{font-size:clamp(1rem,2.5vw,1.15rem);color:#94a3b8;line-height:1.7;max-width:540px;margin:0 auto 2.5rem;font-style:italic;animation:heroFadeUp .8s .55s ease both}.hero-ctas{display:flex;gap:.75rem;justify-content:center;flex-wrap:wrap;animation:heroFadeUp .8s .7s ease both}.hero-ctas .link-btn{padding:.75rem 1.5rem;font-size:.72rem}.hero-scroll-hint{position:absolute;bottom:2.5rem;left:50%;transform:translate(-50%);font-family:DM Mono,monospace;font-size:.6rem;letter-spacing:.2em;color:var(--muted);text-transform:uppercase;animation:heroFadeUp .8s 1s ease both,bounce 2s 2s ease-in-out infinite}@keyframes heroFadeUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes bounce{0%,to{transform:translate(-50%) translateY(0)}50%{transform:translate(-50%) translateY(6px)}}.about-body{display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:start}.about-bio p{font-size:.95rem;line-height:1.85;color:#94a3b8;margin-bottom:1.25rem}.about-bio p:last-child{margin-bottom:0}.about-stack .section-label{margin-bottom:1rem}.stack-group{margin-bottom:1.25rem}.stack-group-label{font-family:DM Mono,monospace;font-size:.58rem;letter-spacing:.15em;color:var(--muted);text-transform:uppercase;margin-bottom:.5rem}.timeline{position:relative;padding-left:2rem}.timeline:before{content:"";position:absolute;left:3px;top:.6rem;bottom:1rem;width:1px;background:linear-gradient(to bottom,var(--accent),transparent)}.timeline-item{position:relative;padding-bottom:2.5rem}.timeline-item:last-child{padding-bottom:0}.timeline-dot{position:absolute;left:-1.85rem;top:.55rem;width:9px;height:9px;border-radius:50%;background:var(--accent);border:2px solid var(--bg);box-shadow:0 0 0 1px var(--accent)}.timeline-dot.muted-dot{background:var(--border);box-shadow:0 0 0 1px var(--border)}.timeline-date{font-family:DM Mono,monospace;font-size:.63rem;letter-spacing:.12em;color:var(--amber);text-transform:uppercase;margin-bottom:.35rem}.timeline-role{font-family:Syne,sans-serif;font-size:1.05rem;font-weight:700;color:#fff;margin-bottom:.2rem;line-height:1.3}.timeline-company{font-family:DM Mono,monospace;font-size:.7rem;color:var(--muted);letter-spacing:.05em;margin-bottom:.6rem}.timeline-desc{font-size:.88rem;line-height:1.75;color:#64748b}.timeline-muted{font-family:DM Mono,monospace;font-size:.72rem;color:var(--border);font-style:italic;letter-spacing:.05em;padding-left:0}.cert-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}.cert-card{background:var(--surface);border:1px solid var(--border);border-radius:2px;padding:1.6rem;position:relative;overflow:hidden;transition:border-color .2s,transform .2s;text-decoration:none;display:block}.cert-card:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(to right,var(--accent),var(--accent2))}.cert-card:hover{border-color:#4f8ef766;transform:translateY(-2px)}.cert-badge-img{width:52px;height:52px;object-fit:contain;margin-bottom:1.1rem;display:block}.cert-badge-placeholder{width:52px;height:52px;background:var(--subtle);border:1px solid var(--border);border-radius:2px;display:flex;align-items:center;justify-content:center;font-family:DM Mono,monospace;font-size:.55rem;color:var(--amber);letter-spacing:.1em;margin-bottom:1.1rem;text-transform:uppercase}.cert-name{font-family:Syne,sans-serif;font-size:.9rem;font-weight:700;color:#fff;line-height:1.3;margin-bottom:.5rem}.cert-date{font-family:DM Mono,monospace;font-size:.62rem;color:var(--muted);letter-spacing:.1em;text-transform:uppercase;margin-bottom:.9rem}.cert-note{font-size:.82rem;color:#64748b;line-height:1.65}.cert-verify{display:inline-flex;align-items:center;gap:.3rem;font-family:DM Mono,monospace;font-size:.6rem;letter-spacing:.1em;color:var(--accent);text-transform:uppercase;margin-top:1rem}.projects-section{padding:6rem 0}.projects-section-header{max-width:860px;margin:0 auto 3rem;padding:0 1.5rem}.project-card{max-width:860px;margin:0 auto 4rem;border:1px solid var(--border);border-radius:2px;overflow:hidden;position:relative;width:100%;scroll-margin-top:7rem}.project-card img{max-width:100%;height:auto;display:block}.project-card:before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:linear-gradient(to bottom,var(--accent),var(--accent2))}.card-header{padding:2.2rem 2.5rem 1.8rem 2.8rem;background:var(--surface);border-bottom:1px solid var(--border);display:grid;grid-template-columns:1fr auto;gap:1rem;align-items:start}.project-number{font-family:DM Mono,monospace;font-size:.65rem;letter-spacing:.15em;color:var(--accent);text-transform:uppercase;margin-bottom:.5rem}.project-title{font-family:Syne,sans-serif;font-size:clamp(1.6rem,3vw,2.1rem);font-weight:800;line-height:1.1;letter-spacing:-.02em;color:#fff;margin-bottom:.4rem}.project-subtitle{font-size:.9rem;color:var(--muted);font-style:italic;margin-bottom:1rem}.header-links{display:flex;gap:.6rem;flex-shrink:0;flex-direction:column;align-items:flex-end}.card-body{padding:2rem 2.8rem 2.5rem;display:grid;grid-template-columns:1fr 1fr;gap:2rem 3rem;min-width:0}.card-body>*{min-width:0}.full-width{grid-column:1 / -1}.summary-text{font-size:.92rem;line-height:1.75;color:#cbd5e1}.problem-block{background:var(--subtle);border-left:2px solid var(--accent2);padding:.9rem 1rem;border-radius:0 2px 2px 0;font-size:.88rem;line-height:1.7;color:#94a3b8;font-style:italic}.metrics-grid{display:grid;grid-template-columns:1fr 1fr;gap:.8rem}.metric{background:var(--subtle);border:1px solid var(--border);padding:.8rem 1rem;border-radius:2px}.metric-value{font-family:Syne,sans-serif;font-size:1.4rem;font-weight:700;color:var(--accent);line-height:1;margin-bottom:.2rem}.metric-label{font-family:DM Mono,monospace;font-size:.6rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted)}.highlights-list{list-style:none;display:flex;flex-direction:column;gap:.6rem}.highlights-list li{display:flex;gap:.7rem;font-size:.88rem;line-height:1.6;color:#94a3b8}.highlights-list li:before{content:"→";color:var(--accent);font-family:DM Mono,monospace;flex-shrink:0;margin-top:.05em}.arch-placeholder{grid-column:1 / -1;border:1px dashed var(--border);border-radius:2px;padding:2rem;text-align:center;background:#4f8ef705;color:var(--muted);font-family:DM Mono,monospace;font-size:.75rem;letter-spacing:.1em}.arch-diagram{grid-column:1 / -1;border:1px solid var(--border);border-radius:2px;overflow:hidden}.arch-diagram img{width:100%;height:auto;object-fit:contain;display:block;border-radius:2px;border:none}.arch-flow{margin-top:.6rem;font-family:DM Mono,monospace;font-size:.68rem;color:var(--muted);letter-spacing:.05em;opacity:.7}.learnings-list{list-style:none;display:flex;flex-direction:column;gap:.5rem}.learnings-list li{display:flex;gap:.7rem;font-size:.85rem;line-height:1.6;color:#64748b}.learnings-list li:before{content:"◆";color:var(--accent2);font-size:.5rem;flex-shrink:0;margin-top:.35em}.card-footer{padding:1rem 2.8rem;border-top:1px solid var(--border);background:var(--surface);display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap}.footer-meta{font-family:DM Mono,monospace;font-size:.65rem;letter-spacing:.1em;color:var(--muted);text-transform:uppercase}.footer-meta span{color:var(--accent)}.screenshot-strip{grid-column:1 / -1;display:flex;gap:.75rem;overflow-x:auto;padding-bottom:.5rem;scrollbar-width:thin;scrollbar-color:var(--border) transparent}.screenshot-strip img{height:160px;border-radius:2px;border:1px solid var(--border);object-fit:cover;flex-shrink:0;cursor:pointer;transition:border-color .15s}.screenshot-strip img:hover{border-color:var(--accent)}.card-divider{max-width:860px;margin:0 auto 4rem;height:1px;background:linear-gradient(to right,transparent,var(--border),transparent)}.contact-section{background:var(--surface);border-top:1px solid var(--border);padding:6rem 1.5rem}.contact-inner{max-width:860px;margin:0 auto}.contact-lmia{font-family:DM Mono,monospace;font-size:.75rem;color:var(--muted);line-height:1.7;margin-bottom:2.5rem;letter-spacing:.02em}.contact-links{display:flex;gap:.75rem;flex-wrap:wrap;margin-bottom:4rem}.contact-link{display:inline-flex;align-items:center;gap:.5rem;font-family:DM Mono,monospace;font-size:.68rem;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);text-decoration:none;padding:.6rem 1.1rem;border:1px solid var(--border);border-radius:2px;transition:all .15s}.contact-link:hover{color:var(--accent);border-color:var(--accent)}.contact-link.primary{background:var(--accent);color:#fff;border-color:var(--accent)}.contact-link.primary:hover{background:#6ea5ff;border-color:#6ea5ff;color:#fff}.site-footer{border-top:1px solid var(--border);padding:1.5rem 0 0;display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap}.site-footer p{font-family:DM Mono,monospace;font-size:.62rem;letter-spacing:.12em;color:var(--border);text-transform:uppercase}.site-footer span{color:var(--muted)}.modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#000000b3;display:flex;align-items:center;justify-content:center;opacity:0;visibility:hidden;transition:opacity .3s ease-out,visibility .3s ease-out;z-index:1000}.modal-overlay.visible{opacity:1;visibility:visible}.modal-overlay.visible .modal-dialog{animation:slideIn .3s ease-out}.modal-dialog{position:relative;width:90%;max-width:800px;max-height:90vh;background:var(--surface);border:1px solid var(--border);border-radius:.5rem;padding:2rem;overflow-y:auto;box-shadow:0 4px 20px #00000080}@keyframes slideIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;border-bottom:1px solid var(--border);padding-bottom:1rem}.modal-header h2{margin:0}.modal-close{background:none;border:none;font-size:1.5rem;cursor:pointer;color:var(--text);opacity:.6;transition:opacity .2s;padding:.25rem;display:flex;align-items:center;justify-content:center;width:2rem;height:2rem}.modal-close:hover{opacity:1}.modal-content h1,.modal-content h2,.modal-content h3{font-family:var(--font-syne);color:var(--text);margin-top:1.5rem;margin-bottom:.5rem;line-height:1.3}.modal-content h1{font-size:1.5rem}.modal-content h2{font-size:1.25rem}.modal-content h3{font-size:1.1rem}.modal-content p{color:var(--text);line-height:1.6;margin:.5rem 0 1rem}.modal-content code{background:var(--subtle);padding:.2em .4em;border-radius:.25rem;font-family:var(--font-mono);font-size:.9em;color:var(--accent)}.modal-content pre{background:var(--bg);border:1px solid var(--border);border-radius:.5rem;padding:1rem;overflow-x:auto;margin:1rem 0}.modal-content pre code{background:none;padding:0;color:var(--green);font-size:.85em;line-height:1.5}.modal-content ul,.modal-content ol{margin:1rem 0;padding-left:2rem}.modal-content li{color:var(--text);margin:.5rem 0;line-height:1.6}.modal-content blockquote{border-left:3px solid var(--accent);padding-left:1rem;margin:1rem 0;color:var(--muted);font-style:italic}.modal-content table{width:100%;border-collapse:collapse;margin:1rem 0;font-size:.9em}.modal-content th,.modal-content td{border:1px solid var(--border);padding:.75rem;text-align:left}.modal-content th{background:var(--subtle);color:var(--text);font-weight:600}@media (max-width: 768px){.nav-links{display:none;flex-direction:column}.nav-links.open{display:flex;position:absolute;top:100%;left:0;right:0;background:#09090ff7;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--border);padding:1rem 1.5rem;gap:.25rem}.nav-links.open li{width:100%}.nav-links.open a{display:block;padding:.6rem .5rem}.nav-hamburger{display:flex}.nav-right .link-btn{display:none}.about-body{grid-template-columns:1fr;gap:2rem}.cert-grid,.card-body,.card-header{grid-template-columns:1fr}.header-links{flex-direction:row;align-items:flex-start;flex-wrap:wrap}.full-width{grid-column:1}.contact-links{flex-direction:column}.contact-link{justify-content:center}.site-footer{flex-direction:column;gap:.5rem}.modal-dialog{width:95%;max-height:85vh;padding:1.5rem}}@media (max-width: 480px){.section{padding:4rem 1rem}.projects-section{padding:4rem 0}.card-body{padding:1.5rem 1.5rem 2rem}.card-header{padding:1.6rem 1.5rem 1.4rem 1.8rem}.card-footer{padding:.8rem 1.5rem}.cert-grid{gap:.75rem}}
