@import "https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@300;400;500;600;700&display=swap";:root{--bg:#0a0a0a;--bg-surface:#111;--bg-card:#161616;--text:#f0ede8;--muted:#888880;--border:#ffffff12;--sans:"Space Grotesk", "Avenir Next", "Segoe UI", sans-serif;--blue:#3b82f6;--purple:#8b5cf6;--green:#10b981;--orange:#f97316;--pink:#ec4899;--teal:#14b8a6;--yellow:#eab308;--red:#ef4444;font-family:var(--sans);color:var(--text);background-color:var(--bg);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;font-weight:400;line-height:1.6}*,:before,:after{box-sizing:border-box}html{scroll-behavior:smooth}body{background:var(--bg);min-height:100vh;margin:0}h1,h2,h3,p{margin:0}a{color:inherit;text-decoration:none}.portfolio{width:100%;max-width:760px;margin:0 auto;padding:5rem 1.5rem}.hero{text-align:center;flex-direction:column;align-items:center;gap:1.5rem;padding:3rem 0 4rem;display:flex}.hero-avatar{background:linear-gradient(135deg, var(--purple), var(--blue));color:#fff;letter-spacing:.04em;border-radius:50%;justify-content:center;align-items:center;width:72px;height:72px;font-size:1.2rem;font-weight:700;display:flex;box-shadow:0 0 0 3px #8b5cf64d}.hero-heading{letter-spacing:-.04em;color:var(--text);font-size:clamp(2.8rem,8vw,5.5rem);font-weight:700;line-height:1}.hero-role{background:linear-gradient(135deg, var(--purple) 0%, var(--pink) 50%, var(--orange) 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.hero-sub{max-width:46ch;color:var(--muted);font-size:1.1rem;line-height:1.65}.skills-row{flex-wrap:wrap;justify-content:center;gap:.6rem;margin-top:.5rem;display:flex}.skill-badge{letter-spacing:.01em;border:1px solid #0000;border-radius:999px;align-items:center;padding:.45rem 1rem;font-size:.85rem;font-weight:500;display:inline-flex}.skill-blue{color:#60a5fa;background:#3b82f61f;border-color:#3b82f640}.skill-purple{color:#a78bfa;background:#8b5cf61f;border-color:#8b5cf640}.skill-green{color:#34d399;background:#10b9811f;border-color:#10b98140}.skill-orange{color:#fb923c;background:#f973161f;border-color:#f9731640}.skill-pink{color:#f472b6;background:#ec48991f;border-color:#ec489940}.skill-teal{color:#2dd4bf;background:#14b8a61f;border-color:#14b8a640}.skill-yellow{color:#facc15;background:#eab3081f;border-color:#eab30840}.skill-red{color:#f87171;background:#ef44441f;border-color:#ef444440}.journey-section{padding:2rem 0 4rem}.journey-header{text-align:center;margin-bottom:3.5rem}.journey-title{letter-spacing:-.03em;color:var(--text);margin-bottom:.5rem;font-size:clamp(1.6rem,4vw,2.4rem);font-weight:700}.journey-sub{color:var(--muted);font-size:1rem}.journey-track{padding:0 0 2rem;position:relative}.journey-line{background:linear-gradient(#0000,#8b5cf680 8%,#ec489966 40%,#f9731666 70%,#10b98166 90%,#0000);width:1px;position:absolute;top:0;bottom:0;left:50%;transform:translate(-50%)}.journey-entry{width:100%;margin-bottom:3rem;display:flex;position:relative}.entry-left{flex-direction:row;justify-content:flex-start;padding-right:calc(50% + 2rem)}.entry-right{flex-direction:row-reverse;justify-content:flex-start;padding-left:calc(50% + 2rem)}.entry-dot{background:var(--purple);z-index:1;border-radius:50%;width:10px;height:10px;position:absolute;top:1.4rem;left:50%;transform:translate(-50%,-50%);box-shadow:0 0 0 3px #8b5cf640,0 0 12px #8b5cf64d}.entry-card{background:var(--bg-card);border:1px solid var(--border);border-radius:1.25rem;flex-direction:column;gap:.5rem;width:100%;padding:1.5rem 1.75rem;transition:border-color .2s;display:flex}.entry-card:hover{border-color:#8b5cf64d}.entry-period{text-transform:uppercase;letter-spacing:.14em;color:var(--purple);opacity:.85;font-size:.78rem;font-weight:500}.entry-title{letter-spacing:-.02em;color:var(--text);font-size:1.35rem;font-weight:700;line-height:1.2}.entry-subtitle{color:var(--muted);font-size:.85rem;font-weight:500}.entry-body{color:#aba89e;margin-top:.25rem;font-size:.95rem;line-height:1.7}.entry-callout{border-left:2px solid var(--pink);color:#d4a0bc;background:#ec48990f;border-radius:0 .75rem .75rem 0;margin:.5rem 0 0;padding:.75rem 1rem;font-size:.88rem;font-style:italic;line-height:1.55}.portfolio-footer{border-top:1px solid var(--border);text-align:center;flex-direction:column;align-items:center;gap:1.5rem;padding:4rem 0 2rem;display:flex}.footer-greeting{letter-spacing:-.03em;background:linear-gradient(135deg, var(--text), var(--muted));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:clamp(1.5rem,4vw,2.2rem);font-weight:700}.footer-links{flex-wrap:wrap;justify-content:center;gap:.75rem;display:flex}.footer-link{border:1px solid var(--border);color:var(--muted);border-radius:999px;padding:.6rem 1.25rem;font-size:.9rem;font-weight:500;transition:color .16s,border-color .16s}.footer-link:hover{color:var(--text);border-color:#fff3}.footer-copy{color:#555;font-size:.8rem}.site-nav{z-index:100;border:1px solid var(--border);-webkit-backdrop-filter:blur(16px);background:#161616cc;border-radius:999px;gap:.25rem;padding:.35rem;display:flex;position:fixed;top:1.25rem;left:50%;transform:translate(-50%)}.site-nav-link{color:var(--muted);white-space:nowrap;border-radius:999px;padding:.45rem 1.1rem;font-size:.875rem;font-weight:500;transition:color .16s,background .16s}.site-nav-link:hover{color:var(--text)}.site-nav-active{color:var(--text);background:#ffffff14}.site-nav-logo{border-radius:999px;align-items:center;padding:.2rem .35rem;display:flex}.site-nav-logo:hover{opacity:.85}.site-nav-divider{background:var(--border);width:1px;margin:.25rem .15rem}.portfolio{padding-top:5rem}.projects-hero{text-align:center;flex-direction:column;gap:.75rem;padding:3rem 0 2.5rem;display:flex}.projects-heading{letter-spacing:-.04em;background:linear-gradient(135deg, var(--text) 30%, var(--muted));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:clamp(2.4rem,7vw,4.5rem);font-weight:700;line-height:1}.projects-sub{color:var(--muted);max-width:44ch;margin:0 auto;font-size:1.05rem}.projects-grid{grid-template-columns:1fr;gap:1rem;padding-bottom:5rem;display:grid}@media (width>=640px){.projects-grid{grid-template-columns:repeat(2,1fr)}}.project-card{all:unset;cursor:pointer;background:var(--bg-card);border:1px solid var(--border);text-align:left;border-radius:1.25rem;flex-direction:column;transition:border-color .2s,transform .2s;display:flex;overflow:hidden}.project-card:hover{border-color:color-mix(in srgb, var(--card-accent) 45%, transparent);transform:translateY(-2px)}.project-card-accent-bar{background:var(--card-accent);flex-shrink:0;height:3px}.project-card-body{flex-direction:column;flex:1;gap:.6rem;padding:1.4rem 1.5rem;display:flex}.project-card-top{justify-content:space-between;align-items:center;gap:.5rem;display:flex}.project-year{text-transform:uppercase;letter-spacing:.12em;color:var(--muted);font-size:.78rem;font-weight:500}.project-status{text-transform:uppercase;letter-spacing:.1em;border-radius:999px;padding:.2rem .6rem;font-size:.72rem;font-weight:600}.status-live{color:#34d399;background:#10b9811f}.status-wip{color:#facc15;background:#eab3081f}.status-archived{color:#666;background:#ffffff0f}.project-title{letter-spacing:-.02em;color:var(--text);font-size:1.15rem;font-weight:700;line-height:1.25}.project-tagline{color:var(--muted);font-size:.88rem;line-height:1.55}.project-tags{flex-wrap:wrap;gap:.4rem;margin-top:.25rem;display:flex}.project-tag{border:1px solid var(--border);color:var(--muted);background:#ffffff0d;border-radius:999px;padding:.2rem .6rem;font-size:.75rem;font-weight:500}.modal-backdrop{z-index:200;-webkit-backdrop-filter:blur(6px);background:#000000bf;justify-content:center;align-items:flex-end;padding:0 1rem;animation:.18s fade-in;display:flex;position:fixed;inset:0}@keyframes fade-in{0%{opacity:0}to{opacity:1}}.modal-panel{border:1px solid var(--border);background:#111;border-bottom:none;border-radius:1.5rem 1.5rem 0 0;flex-direction:column;width:100%;max-width:680px;max-height:88vh;animation:.24s cubic-bezier(.22,1,.36,1) slide-up;display:flex;overflow-y:auto}@keyframes slide-up{0%{opacity:0;transform:translateY(100%)}to{opacity:1;transform:translateY(0)}}.modal-accent-bar{background:var(--card-accent);border-radius:1.5rem 1.5rem 0 0;flex-shrink:0;height:3px}.modal-content{flex-direction:column;gap:1.5rem;padding:2rem 2rem 2.5rem;display:flex}.modal-header{justify-content:space-between;align-items:flex-start;gap:1rem;display:flex}.modal-header-left{flex:1;align-items:flex-start;gap:1rem;min-width:0;display:flex}.modal-meta{align-items:center;gap:.75rem;margin-bottom:.5rem;display:flex}.modal-title{letter-spacing:-.03em;color:var(--text);font-size:clamp(1.6rem,4vw,2.2rem);font-weight:700;line-height:1.1}.modal-tagline{color:var(--muted);margin-top:.35rem;font-size:.95rem}.modal-close{all:unset;cursor:pointer;border:1px solid var(--border);width:2.2rem;height:2.2rem;color:var(--muted);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:.8rem;transition:color .16s,border-color .16s;display:flex}.modal-close:hover{color:var(--text);border-color:#fff3}.modal-description{color:#aba89e;font-size:.97rem;line-height:1.75}.modal-section{flex-direction:column;gap:.75rem;display:flex}.modal-section-label{text-transform:uppercase;letter-spacing:.14em;color:var(--muted);margin:0;font-size:.75rem;font-weight:600}.modal-highlights{flex-direction:column;gap:.55rem;margin:0;padding:0;list-style:none;display:flex}.modal-highlights li{color:#aba89e;padding-left:1.25rem;font-size:.92rem;line-height:1.6;position:relative}.modal-highlights li:before{content:"→";color:color-mix(in srgb, var(--card-accent) 80%, transparent);font-size:.85rem;position:absolute;left:0}.modal-links{flex-wrap:wrap;gap:.75rem;display:flex}.modal-link-btn{border-radius:999px;padding:.65rem 1.4rem;font-size:.9rem;font-weight:600;transition:opacity .16s,transform .16s}.modal-link-btn:hover{opacity:.85;transform:translateY(-1px)}.modal-link-primary{background:var(--card-accent);color:#fff}.modal-link-ghost{border:1px solid var(--border);color:var(--muted)}.modal-link-ghost:hover{color:var(--text);opacity:1;border-color:#fff3}.about-page{color:var(--text);flex-direction:column;gap:1rem;padding:5rem 0;display:flex}.about-page h1{letter-spacing:-.04em;font-size:3rem;font-weight:700}@media (width<=640px){.portfolio{padding:5rem 1rem 4rem}.journey-line{left:1.25rem}.journey-entry,.entry-left,.entry-right{flex-direction:column;padding:0 0 0 3rem}.entry-dot{top:1.75rem;left:1.25rem}}
