@import url("https://fonts.googleapis.com/css2?family=Fraunces:ital,opsz,wght@0,9..144,400;0,9..144,500;1,9..144,300;1,9..144,400;1,9..144,500&display=swap");@import url("https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600&display=swap");@import url("https://fonts.googleapis.com/css2?family=JetBrains+Mono:wght@400;500&display=swap");:root{--color-bg:#faf3e0;--color-bg-card:#f2e8c8;--color-bg-card-hover:#e8ddb8;--color-text:#1e1a14;--color-muted:#6a5f4e;--color-accent:#c01228;--color-accent-soft:#e03858;--color-border:#d4c8a8;--color-border-light:#e4dbc2;--color-nav-bg:#1c1510;--color-nav-text:#f5efe0;--font-display:"Fraunces",Georgia,serif;--font-sans:"Inter",system-ui,sans-serif;--font-mono:"JetBrains Mono",ui-monospace,monospace;--radius:0.75rem}[data-theme=dark]{--color-bg:#0e0c09;--color-bg-card:#181410;--color-bg-card-hover:#221e18;--color-text:#f0e8d8;--color-muted:#8a7a66;--color-accent:#b060ff;--color-accent-soft:#cc90ff;--color-border:#302820;--color-border-light:#261f18;--color-nav-bg:#0a0806;--color-nav-text:#f0e8d8}[data-section=home]{--color-accent:#c01228;--color-accent-soft:#e03858}[data-section=projects]{--color-accent:#1a5cbf;--color-accent-soft:#4080d8}[data-section=creative]{--color-accent:#1a7a40;--color-accent-soft:#38a060}[data-section=blog]{--color-accent:#b8182a;--color-accent-soft:#d83848}[data-section=services]{--color-accent:#c06020;--color-accent-soft:#d88040}[data-theme=dark] [data-section=home]{--color-accent:#b060ff;--color-accent-soft:#cc90ff}[data-theme=dark] [data-section=projects]{--color-accent:#4488ff;--color-accent-soft:#66aaff}[data-theme=dark] [data-section=creative]{--color-accent:#22bb55;--color-accent-soft:#44dd77}[data-theme=dark] [data-section=blog]{--color-accent:#ff4466;--color-accent-soft:#ff7788}[data-theme=dark] [data-section=services]{--color-accent:#ff8822;--color-accent-soft:#ffaa55}*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;font-family:var(--font-sans);color:var(--color-text);line-height:1.65;transition:background-color .3s ease,color .3s ease}[data-theme=dark] body,body{background-color:var(--color-bg)}[data-theme=dark] body{background-image:radial-gradient(ellipse at top left,rgba(176,96,255,.1) 0,transparent 55%),radial-gradient(ellipse at bottom right,rgba(64,100,255,.07) 0,transparent 55%)}a{color:var(--color-accent);text-decoration:none}a:hover{color:var(--color-accent-soft);text-decoration:underline;text-underline-offset:3px}.page{max-width:58rem;margin:0 auto;padding:2.5rem 1.5rem}.nav-header{background:var(--color-nav-bg)}.nav-inner{display:flex;flex-wrap:wrap;gap:1.5rem;align-items:center;max-width:58rem;margin:0 auto;padding:.75rem 1.5rem}.nav-logo{font-family:var(--font-display);font-style:italic;font-weight:400;font-size:1.1rem;margin-right:.5rem;letter-spacing:-.02em;transition:opacity .15s}.nav-logo,.nav-logo:hover{color:var(--color-nav-text);text-decoration:none}.nav-logo:hover{opacity:.8}.nav-link{color:rgba(240,232,216,.65);text-decoration:none;font-size:.8125rem;font-weight:400;transition:color .15s}.nav-link:hover{color:var(--color-nav-text);text-decoration:none}.nav-link--active{color:var(--color-nav-text);font-weight:600}.nav-stripe{height:3px;background:linear-gradient(90deg,var(--color-accent) 0,var(--color-accent-soft) 100%)}.theme-toggle{margin-left:auto;background:none;border:1px solid rgba(240,232,216,.25);border-radius:50%;width:1.875rem;height:1.875rem;display:inline-flex;align-items:center;justify-content:center;color:rgba(240,232,216,.55);cursor:pointer;transition:color .15s,border-color .15s;padding:0;flex-shrink:0}.theme-toggle:hover{color:var(--color-nav-text);border-color:rgba(240,232,216,.6)}.theme-toggle-placeholder{width:1.875rem;height:1.875rem;margin-left:auto;flex-shrink:0}.page--home{position:relative;overflow:hidden;padding-top:3rem;padding-bottom:4rem}.page--home:before{width:420px;height:420px;border-radius:50%;border:1.5px solid var(--color-accent);opacity:.11;top:-100px;right:-80px}.page--home:after,.page--home:before{content:"";position:absolute;pointer-events:none;z-index:0}.page--home:after{width:16px;height:16px;border-radius:50%;background:var(--color-accent);opacity:.14;bottom:5rem;left:.5rem}.home-intro{position:relative;z-index:1;max-width:58rem}.home-title{font-family:var(--font-display);font-weight:400;font-style:italic;font-size:clamp(4rem,10vw,7.5rem);line-height:.95;letter-spacing:-.04em;margin:0 0 2rem;padding-bottom:.18em;background:linear-gradient(135deg,var(--color-accent) 0,var(--color-accent-soft) 45%,var(--color-text) 85%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;display:inline-block}.home-intro-grid{display:grid;grid-template-columns:1fr minmax(200px,300px);grid-gap:3rem;gap:3rem;align-items:start}@media (max-width:768px){.home-intro-grid{grid-template-columns:1fr;gap:2rem}.home-photo-wrap-right{max-width:260px;margin:0 auto}.home-title{font-size:clamp(3.25rem,13vw,5rem)}}.home-intro-text{min-width:0}.home-lead{font-size:1.1rem;color:var(--color-text);margin:0 0 1rem;line-height:1.65}.home-bio{font-size:.9375rem;color:var(--color-muted);margin:0 0 .9rem;line-height:1.72}.home-bio a{color:var(--color-accent);font-weight:500}.home-bio a:hover{color:var(--color-accent-soft)}.home-cta-intro{font-size:.9375rem;color:var(--color-muted);margin:1.5rem 0 1rem}.home-ctas{display:flex;flex-wrap:wrap;gap:.75rem;margin-top:.5rem}.home-cta-btn{font-family:var(--font-sans);font-size:.875rem;font-weight:600;padding:.55rem 1.4rem;border-radius:999px;background:var(--color-accent);color:#fff;text-decoration:none;border:2px solid transparent;transition:background .18s,color .18s,border-color .18s;display:inline-block}.home-cta-btn:hover{background:transparent;border-color:var(--color-accent);color:var(--color-accent);text-decoration:none}.home-photo-wrap-right{display:flex;align-items:flex-start;padding:0 12px 12px 0}.home-photo{position:relative;width:100%;overflow:hidden;background:var(--color-bg-card);border-radius:var(--radius);box-shadow:10px 12px 0 0 var(--color-accent);transition:box-shadow .3s ease}.home-photo:hover{box-shadow:5px 7px 0 0 var(--color-accent)}.home-photo--vertical{aspect-ratio:3/4;max-width:280px}.home-footer{position:relative;z-index:1;margin-top:4rem;padding-top:2rem;border-top:1px solid var(--color-border);font-size:.9rem;color:var(--color-muted);text-align:center}.footer-icons{display:flex;flex-wrap:wrap;gap:.75rem;justify-content:center;margin-bottom:1.25rem}.footer-icon{display:inline-flex;align-items:center;justify-content:center;width:2.5rem;height:2.5rem;border-radius:50%;background:var(--color-bg-card);border:1px solid var(--color-border);color:var(--color-muted);transition:color .2s,background .2s,border-color .2s}.footer-icon:hover{color:var(--color-accent);background:var(--color-bg-card-hover);border-color:var(--color-accent)}.footer-icon:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}.home-footer-copy{margin:0;font-size:.8rem;color:var(--color-muted)}.page-content{padding:2.5rem 0}.page-content .wrapper{max-width:58rem;margin:0 auto;padding:0 1.5rem}.post-header{margin-bottom:2rem;padding-bottom:1.5rem;border-bottom:2px solid var(--color-border)}.post-title{font-family:var(--font-display);font-weight:400;font-style:italic;font-size:clamp(3rem,7vw,5.5rem);margin:0;letter-spacing:-.04em;line-height:.92;padding-bottom:.15em;background:linear-gradient(135deg,var(--color-accent) 0,var(--color-accent-soft) 50%,var(--color-text) 90%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;display:inline-block}.post-intro{font-size:1rem;color:var(--color-muted);line-height:1.7;margin:1.25rem 0 2rem;max-width:52ch}.post-content{margin:0}.project-filters{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:2rem}.project-filter-btn{font-family:var(--font-sans);font-size:.75rem;font-weight:500;padding:.35rem 1rem;border-radius:999px;border:1.5px solid var(--color-border);background:transparent;color:var(--color-muted);cursor:pointer;transition:background .15s,color .15s,border-color .15s}.project-filter-btn:hover{border-color:var(--color-accent);color:var(--color-accent)}.project-filter-btn--active{background:var(--color-accent);border-color:var(--color-accent);color:#fff}.projects{display:grid;grid-template-columns:repeat(2,1fr);grid-gap:1.75rem;gap:1.75rem;align-items:start}@media (max-width:640px){.projects{grid-template-columns:1fr}}.project-box{background:var(--color-bg-card);border:1px solid var(--color-border);border-top:4px solid var(--color-accent);border-radius:var(--radius);overflow:hidden;transition:box-shadow .2s,transform .2s;display:flex;flex-direction:column}.project-box:hover{box-shadow:0 6px 28px rgba(0,0,0,.1);transform:translateY(-2px)}.project-image-box{position:relative;aspect-ratio:16/9;overflow:hidden;background:var(--color-bg-card-hover);flex-shrink:0}.project-image-link{display:block;width:100%;height:100%;text-decoration:none}.project-image-link:hover .project-image{opacity:.88;transform:scale(1.02)}.project-image{object-fit:cover;transition:opacity .25s,transform .35s}.project-image--placeholder{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;color:var(--color-muted);font-size:.65rem;font-family:var(--font-mono);letter-spacing:.12em;text-transform:uppercase}.project-body{padding:1.25rem 1.5rem;display:flex;flex-direction:column;flex:1 1}.project-summary{display:flex;align-items:flex-start;gap:.75rem}.project-summary-text{flex:1 1;min-width:0}.project-title-h2{font-family:var(--font-display);font-weight:400;font-style:italic;font-size:clamp(1.2rem,2vw,1.55rem);margin:0 0 .2rem;letter-spacing:-.025em;line-height:1.1;background:linear-gradient(135deg,var(--color-accent) 0,var(--color-accent-soft) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;display:inline-block}.project-tagline{font-size:.875rem;color:var(--color-muted);margin:0 0 .6rem;line-height:1.45}.project-meta-row{display:flex;flex-wrap:wrap;align-items:center;gap:.4rem}.project-date{font-family:var(--font-mono);font-size:.62rem;color:var(--color-muted);letter-spacing:.06em;margin-right:.15rem}.project-tag{font-size:.62rem;font-weight:500;color:var(--color-accent);border:1px solid var(--color-accent);border-radius:999px;padding:.1em .6em;opacity:.8;line-height:1.7}.project-toggle{font-size:1.35rem;line-height:1;font-weight:300;color:var(--color-muted);background:none;border:none;cursor:pointer;padding:0;flex-shrink:0;transition:color .15s;margin-top:.15rem}.project-toggle:hover{color:var(--color-accent)}.project-details{display:grid;grid-template-rows:0fr;transition:grid-template-rows .28s ease}.project-details--open{grid-template-rows:1fr}.project-details-inner{overflow:hidden;padding-top:0;transition:padding-top .28s ease}.project-details--open .project-details-inner{padding-top:1rem}.project-detail-desc{font-size:.9rem;color:var(--color-muted);line-height:1.72;margin:0 0 .5rem;padding-top:.75rem;border-top:1px solid var(--color-border-light)}.project-role-label,.project-tech-label{font-family:var(--font-mono);font-size:.6rem;letter-spacing:.1em;text-transform:uppercase;color:var(--color-muted);margin:.85rem 0 .3rem;display:block}.project-role-list{margin:0 0 .5rem;padding-left:1.1rem;font-size:.875rem;color:var(--color-text);line-height:1.65}.project-role-list li{margin-bottom:.25rem}.project-tech-stack{font-size:.78rem;color:var(--color-muted);margin:0 0 .75rem!important;font-family:var(--font-mono);letter-spacing:.02em}.project-links{display:flex;gap:1.25rem;margin-top:.5rem;padding-top:.75rem;border-top:1px solid var(--color-border-light)}.project-link{font-size:.825rem;font-weight:600;color:var(--color-accent);text-decoration:none;transition:opacity .15s}.project-link:hover{opacity:.75;text-decoration:none}.photo-placeholder{background:var(--color-bg-card);display:flex;align-items:center;justify-content:center;color:var(--color-muted);font-size:.75rem;font-family:var(--font-mono);overflow:hidden}.photo-placeholder img{width:100%;height:100%;object-fit:cover}.card{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius);padding:1.25rem 1.5rem;transition:background .2s}.card:hover{background:var(--color-bg-card-hover)}.page-accent{border-left:4px solid var(--color-accent);padding-left:1.25rem}.accent-stripe{height:4px;background:linear-gradient(90deg,var(--color-accent) 0,var(--color-accent-soft) 100%)}.about-layout{display:grid;grid-gap:2rem;gap:2rem;grid-template-columns:1fr 280px}@media (max-width:720px){.about-layout{grid-template-columns:1fr}}.about-sidebar{display:flex;flex-direction:column;gap:1rem}.heading{font-family:var(--font-display);font-weight:500;font-style:italic;letter-spacing:-.02em}.label{font-family:var(--font-mono);font-size:.75rem;letter-spacing:.05em;text-transform:uppercase;color:var(--color-muted)}.blog-external-link{display:block;border-left:4px solid var(--color-accent)}