@font-face{font-family:Space Grotesk;font-style:normal;font-weight:300;font-display:swap;src:url(../media/32687112bd2dd8db-s.cfdd66c2.woff2)format("woff2");unicode-range:U+102-103,U+110-111,U+128-129,U+168-169,U+1A0-1A1,U+1AF-1B0,U+300-301,U+303-304,U+308-309,U+323,U+329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Space Grotesk;font-style:normal;font-weight:300;font-display:swap;src:url(../media/28868e710e86be81-s.c30238d4.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Space Grotesk;font-style:normal;font-weight:300;font-display:swap;src:url(../media/0c89a48fa5027cee-s.p.4564287c.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Space Grotesk;font-style:normal;font-weight:400;font-display:swap;src:url(../media/32687112bd2dd8db-s.cfdd66c2.woff2)format("woff2");unicode-range:U+102-103,U+110-111,U+128-129,U+168-169,U+1A0-1A1,U+1AF-1B0,U+300-301,U+303-304,U+308-309,U+323,U+329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Space Grotesk;font-style:normal;font-weight:400;font-display:swap;src:url(../media/28868e710e86be81-s.c30238d4.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Space Grotesk;font-style:normal;font-weight:400;font-display:swap;src:url(../media/0c89a48fa5027cee-s.p.4564287c.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Space Grotesk;font-style:normal;font-weight:500;font-display:swap;src:url(../media/32687112bd2dd8db-s.cfdd66c2.woff2)format("woff2");unicode-range:U+102-103,U+110-111,U+128-129,U+168-169,U+1A0-1A1,U+1AF-1B0,U+300-301,U+303-304,U+308-309,U+323,U+329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Space Grotesk;font-style:normal;font-weight:500;font-display:swap;src:url(../media/28868e710e86be81-s.c30238d4.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Space Grotesk;font-style:normal;font-weight:500;font-display:swap;src:url(../media/0c89a48fa5027cee-s.p.4564287c.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Space Grotesk;font-style:normal;font-weight:600;font-display:swap;src:url(../media/32687112bd2dd8db-s.cfdd66c2.woff2)format("woff2");unicode-range:U+102-103,U+110-111,U+128-129,U+168-169,U+1A0-1A1,U+1AF-1B0,U+300-301,U+303-304,U+308-309,U+323,U+329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Space Grotesk;font-style:normal;font-weight:600;font-display:swap;src:url(../media/28868e710e86be81-s.c30238d4.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Space Grotesk;font-style:normal;font-weight:600;font-display:swap;src:url(../media/0c89a48fa5027cee-s.p.4564287c.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Space Grotesk;font-style:normal;font-weight:700;font-display:swap;src:url(../media/32687112bd2dd8db-s.cfdd66c2.woff2)format("woff2");unicode-range:U+102-103,U+110-111,U+128-129,U+168-169,U+1A0-1A1,U+1AF-1B0,U+300-301,U+303-304,U+308-309,U+323,U+329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Space Grotesk;font-style:normal;font-weight:700;font-display:swap;src:url(../media/28868e710e86be81-s.c30238d4.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Space Grotesk;font-style:normal;font-weight:700;font-display:swap;src:url(../media/0c89a48fa5027cee-s.p.4564287c.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Space Grotesk Fallback;src:local(Arial);ascent-override:89.71%;descent-override:26.62%;line-gap-override:0.0%;size-adjust:109.69%}.space_grotesk_2c742848-module__A4pgAG__className{font-family:Space Grotesk,Space Grotesk Fallback;font-style:normal}.space_grotesk_2c742848-module__A4pgAG__variable{--font-space-grotesk:"Space Grotesk","Space Grotesk Fallback"}
:root{--color-text:#18181b;--color-text-muted:#71717a;--color-bg:#fff;--color-bg-alt:#fafafa;--color-border:#e4e4e7;--color-card-bg:#fff;--color-nav-bg:#ffffffe0;--color-input-bg:#f4f4f5;--color-accent-soft:#f4f4f5;--shadow-color:#18181b0f;--ink:#111113;--ink-mid:#1c1c1f;--ink-text:#ffffffd9;--ink-muted:#ffffff73;--ink-border:#ffffff1a;--ink-input-bg:#ffffff0f;--font-sans:var(--font-space-grotesk),"Space Grotesk",system-ui,-apple-system,sans-serif;--font-mono:"Fira Code","Monaco","Courier New",monospace;--ease-out:cubic-bezier(.16,1,.3,1);--duration-fast:.14s;--duration-base:.24s;--duration-theme:.32s;--radius:8px;--radius-lg:14px;--radius-full:9999px}[data-theme=dark]{--color-text:#f4f4f5;--color-text-muted:#a1a1aa;--color-bg:#09090b;--color-bg-alt:#111113;--color-border:#27272a;--color-card-bg:#18181b;--color-nav-bg:#09090be0;--color-input-bg:#18181b;--color-accent-soft:#f4f4f514;--shadow-color:#00000059}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;font-size:17px}body{font-family:var(--font-sans);color:var(--color-text);background:var(--color-bg);-webkit-font-smoothing:antialiased;transition:background-color var(--duration-theme)ease,color var(--duration-theme)ease;font-size:1rem;line-height:1.65;overflow-x:hidden}.container{max-width:1080px;margin:0 auto;padding:0 2rem}header nav,nav{background:var(--color-nav-bg);-webkit-backdrop-filter:blur(20px);z-index:1000;width:100%;height:60px;transition:border-color var(--duration-base)ease,background-color var(--duration-theme)ease;border-bottom:1px solid #0000;align-items:center;padding:0;display:flex;position:fixed;top:0}nav.scrolled{border-bottom-color:var(--color-border)}.nav-container{justify-content:space-between;align-items:center;width:100%;display:flex}.logo{color:var(--color-text);letter-spacing:-.01em;font-size:.95rem;font-weight:700;font-family:var(--font-sans);text-decoration:none}.nav-links{gap:.25rem;list-style:none;display:flex}.nav-links a{color:var(--color-text-muted);border-radius:var(--radius-full);transition:color var(--duration-fast)ease,background-color var(--duration-fast)ease;padding:.4rem .75rem;font-size:.85rem;font-weight:500;text-decoration:none;display:block}.nav-links a:hover{color:var(--color-text);background:var(--color-accent-soft)}.back-link{color:var(--color-text-muted);transition:color var(--duration-fast)ease;align-items:center;gap:.4rem;font-size:.875rem;font-weight:500;text-decoration:none;display:inline-flex}.back-link:hover{color:var(--color-text)}.mobile-menu-toggle{cursor:pointer;background:0 0;border:none;flex-direction:column;gap:5px;padding:.5rem;display:none}.hamburger-line{background:var(--color-text);width:20px;height:1.5px;transition:transform var(--duration-base)ease,opacity var(--duration-base)ease;border-radius:2px}.mobile-menu-toggle.active .hamburger-line:first-child{transform:rotate(45deg)translate(4.5px,6.5px)}.mobile-menu-toggle.active .hamburger-line:nth-child(2){opacity:0;transform:scaleX(0)}.mobile-menu-toggle.active .hamburger-line:nth-child(3){transform:rotate(-45deg)translate(4.5px,-6.5px)}.theme-toggle{border:1px solid var(--color-border);border-radius:var(--radius-full);cursor:pointer;width:36px;height:36px;transition:border-color var(--duration-fast)ease,background-color var(--duration-fast)ease;background:0 0;flex-shrink:0;justify-content:center;align-items:center;display:flex;position:relative;overflow:hidden}.theme-toggle:hover{border-color:var(--color-text);background:var(--color-accent-soft)}.theme-toggle .icon{transition:transform .4s var(--ease-out),opacity .25s ease;font-size:1rem;position:absolute}[data-theme=light] .theme-toggle .sun-icon,:root:not([data-theme]) .theme-toggle .sun-icon{opacity:1;transform:rotate(0)scale(1)}[data-theme=light] .theme-toggle .moon-icon,:root:not([data-theme]) .theme-toggle .moon-icon{opacity:0;transform:rotate(-90deg)scale(.5)}[data-theme=dark] .theme-toggle .sun-icon{opacity:0;transform:rotate(90deg)scale(.5)}[data-theme=dark] .theme-toggle .moon-icon{opacity:1;transform:rotate(0)scale(1)}.hero{background:var(--color-bg);align-items:center;min-height:100vh;display:flex;position:relative;overflow:hidden}.hero:before{content:"";background-image:radial-gradient(circle,var(--color-border)1px,transparent 1px);pointer-events:none;opacity:.7;z-index:0;transition:opacity var(--duration-theme)ease;background-size:28px 28px;position:absolute;inset:0}[data-theme=dark] .hero:before{opacity:.35}.hero-content{z-index:2;max-width:680px;position:relative}.hero-eyebrow{letter-spacing:.1em;text-transform:uppercase;color:var(--color-text-muted);align-items:center;gap:.5rem;margin-bottom:1.5rem;font-size:.72rem;font-weight:600;display:inline-flex}.hero-eyebrow:before{content:"";background:var(--color-text-muted);width:24px;height:1px;display:block}.hero h1{letter-spacing:-.035em;color:var(--color-text);margin-bottom:1.25rem;font-size:clamp(2.75rem,6.5vw,5rem);font-weight:700;line-height:1.04}.hero .nickname{display:none}.hero .tagline{color:var(--color-text-muted);max-width:480px;margin-bottom:2.5rem;font-size:1rem;font-weight:400;line-height:1.8}.cta-button{background:var(--color-text);color:var(--color-bg);border-radius:var(--radius-full);font-family:var(--font-sans);letter-spacing:.01em;transition:background-color var(--duration-base)ease,color var(--duration-base)ease,border-color var(--duration-base)ease,transform var(--duration-base)var(--ease-out);border:1px solid var(--color-text);cursor:pointer;align-items:center;gap:.4rem;padding:.65rem 1.5rem;font-size:.875rem;font-weight:600;text-decoration:none;display:inline-flex}.cta-button:hover{color:var(--color-text);background:0 0;transform:translateY(-1px)}.cta-button.secondary,.cta-button-outline{color:var(--color-text);border-color:var(--color-border);background:0 0}.cta-button.secondary:hover,.cta-button-outline:hover{border-color:var(--color-text);background:var(--color-accent-soft);transform:translateY(-1px)}.cta-button-full{justify-content:center;width:100%}.hero-buttons{flex-wrap:wrap;gap:.75rem;display:flex}main section,section{padding:6rem 0}.section-label{letter-spacing:.1em;text-transform:uppercase;color:var(--color-text-muted);justify-content:center;align-items:center;gap:.5rem;width:100%;margin-bottom:.75rem;font-size:.7rem;font-weight:600;display:inline-flex}.section-label:before,.section-label:after{content:"";background:var(--color-border);width:20px;height:1px;display:block}.section-title{letter-spacing:-.03em;color:var(--color-text);text-align:center;margin-bottom:.65rem;font-size:clamp(1.75rem,3.5vw,2.25rem);font-weight:700;line-height:1.1}.section-subtitle{text-align:center;color:var(--color-text-muted);max-width:480px;margin:0 auto 4rem;font-size:.95rem;line-height:1.75}.section-content p{color:var(--color-text-muted);margin-bottom:1rem;line-height:1.8}.about-grid{grid-template-columns:240px 1fr;align-items:start;gap:4rem;display:grid}.about-image{aspect-ratio:1;background:var(--color-bg-alt);border:1px solid var(--color-border);border-radius:var(--radius-lg);justify-content:center;align-items:center;width:100%;display:flex;overflow:hidden}.about-photo{object-fit:cover;object-position:center top;width:100%;height:100%;display:block}.about-content h3{color:var(--color-text);letter-spacing:-.015em;margin-bottom:.875rem;font-size:1.1rem;font-weight:600;line-height:1.3}.about-content p{color:var(--color-text-muted);margin-bottom:1.25rem;font-size:.925rem;line-height:1.8}.stats{border:1px solid var(--color-border);border-radius:var(--radius-lg);background:var(--color-border);grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:1px;margin-top:3rem;display:grid;overflow:hidden}.stat{background:var(--color-bg);transition:background-color var(--duration-theme)ease;padding:1.5rem 1.75rem}[data-theme=dark] .stat{background:var(--color-card-bg)}.stat-number{color:var(--color-text);letter-spacing:-.03em;margin-bottom:.4rem;font-size:1.6rem;font-weight:700;line-height:1;display:block}.stat-label{color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.07em;font-size:.75rem;font-weight:600}.projects{background:var(--color-bg-alt)}.projects-grid{border:1px solid var(--color-border);border-radius:var(--radius-lg);background:var(--color-border);grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1px;display:grid;overflow:hidden}.project-card{background:var(--color-card-bg);transition:background-color var(--duration-theme)ease;cursor:default;overflow:hidden}.project-card:hover{background:var(--color-bg-alt)}[data-theme=dark] .project-card:hover{background:#1c1c1f}.project-image{background:var(--color-bg-alt);height:190px;color:var(--color-text-muted);border-bottom:1px solid var(--color-border);justify-content:center;align-items:center;font-size:.875rem;font-weight:500;display:flex;overflow:hidden}.project-image img{object-fit:cover;width:100%;height:100%;transition:transform .4s var(--ease-out)}.project-card:hover .project-image img{transform:scale(1.03)}.project-image-mobile{justify-content:center;align-items:center;padding:1.5rem;display:flex;overflow:hidden;height:340px!important}.project-image-mobile img{max-width:100%;margin:0 auto;display:block;object-fit:contain!important;width:auto!important;height:100%!important}.project-content{padding:1.5rem 1.75rem}.project-title{color:var(--color-text);letter-spacing:-.015em;margin-bottom:.5rem;font-size:1rem;font-weight:600;line-height:1.35}.project-description{color:var(--color-text-muted);margin-bottom:1.25rem;font-size:.875rem;line-height:1.7}.tech-stack{flex-wrap:wrap;gap:.35rem;margin-bottom:1.25rem;display:flex}.tech-tag{color:var(--color-text-muted);border:1px solid var(--color-border);border-radius:var(--radius-full);letter-spacing:.02em;font-size:.72rem;font-weight:500;font-family:var(--font-sans);background:0 0;padding:.15rem .6rem}.project-links{gap:1rem;display:flex}.project-link{color:var(--color-text);letter-spacing:.01em;transition:opacity var(--duration-fast)ease;align-items:center;gap:.3rem;font-size:.825rem;font-weight:600;text-decoration:none;display:inline-flex}.project-link:hover{opacity:.55}.project-badge{color:var(--color-text-muted);border:1px solid var(--color-border);border-radius:var(--radius-full);letter-spacing:.06em;text-transform:uppercase;background:0 0;margin-bottom:.6rem;padding:.15rem .6rem;font-size:.68rem;font-weight:600;display:inline-block}.project-note{color:var(--color-text-muted);opacity:.65;margin-top:.65rem;font-size:.78rem}.project-card-link{color:inherit;text-decoration:none;display:block}.project-image-featured,.project-image-secondary{background:var(--color-bg-alt)}.project-badge-secondary{opacity:.7}.experience-timeline{max-width:760px;margin:0 auto;position:relative}.experience-timeline:before{content:"";background:var(--color-border);width:1px;position:absolute;top:0;bottom:0;left:50%;transform:translate(-50%)}.timeline-item{width:44%;margin-bottom:2rem;position:relative}.timeline-item:nth-child(odd){left:0}.timeline-item:nth-child(2n){left:56%}.timeline-content{background:var(--color-card-bg);border-radius:var(--radius);border:1px solid var(--color-border);transition:background-color var(--duration-theme)ease;padding:1.25rem 1.5rem;position:relative}.timeline-content:before{content:"";background:var(--color-text);border:2px solid var(--color-bg);width:7px;height:7px;transition:background-color var(--duration-theme)ease,border-color var(--duration-theme)ease;border-radius:50%;position:absolute;top:1rem}.timeline-item:nth-child(odd) .timeline-content:before{right:-22px}.timeline-item:nth-child(2n) .timeline-content:before{left:-22px}.timeline-date{color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.07em;margin-bottom:.4rem;font-size:.7rem;font-weight:600}.timeline-title{color:var(--color-text);letter-spacing:-.01em;margin-bottom:.2rem;font-size:.95rem;font-weight:600}.timeline-company{color:var(--color-text-muted);margin-bottom:.6rem;font-size:.825rem;font-weight:500}.timeline-description{color:var(--color-text-muted);font-size:.825rem;line-height:1.7}#certifications .stat{border:1px solid #d9775733;position:relative;overflow:hidden}#certifications .stat:before{content:"";background:linear-gradient(90deg,#d97757,#e8a87c);height:2px;position:absolute;top:0;left:0;right:0}#certifications .stat-number{color:#d97757;letter-spacing:0;font-size:.95rem;font-weight:600;line-height:1.4;text-decoration:none;display:block}#certifications .stat-label{margin-top:.25rem;font-size:.78rem}.contact{background:var(--ink);color:var(--ink-text)}.contact .section-label{color:#ffffff59}.contact .section-label:before,.contact .section-label:after{background:#ffffff1f}.contact .section-title{color:#fff}.contact .section-subtitle{color:var(--ink-muted)}.contact-form{max-width:520px;margin:0 auto}.form-group{margin-bottom:1.25rem}.form-group label{text-transform:uppercase;letter-spacing:.06em;color:var(--ink-muted);font-size:.8rem;font-weight:500;font-family:var(--font-sans);margin-bottom:.4rem;display:block}.form-group input,.form-group textarea{border:1px solid var(--ink-border);border-radius:var(--radius);background:var(--ink-input-bg);color:#fff;width:100%;font-size:.9rem;font-family:var(--font-sans);transition:border-color var(--duration-fast)ease;outline:none;padding:.8rem 1rem}.form-group input::placeholder,.form-group textarea::placeholder{color:#ffffff40}.form-group input:focus,.form-group textarea:focus{border-color:#ffffff59}.contact .cta-button{color:var(--ink);background:#fff;border-color:#fff}.contact .cta-button:hover{color:#fff;background:0 0;border-color:#ffffff80}.social-links{flex-wrap:wrap;justify-content:center;gap:.75rem;margin-top:2.5rem;display:flex}.social-link{background:var(--ink-input-bg);border:1px solid var(--ink-border);border-radius:var(--radius-full);color:#ffffffa6;letter-spacing:.03em;transition:background-color var(--duration-base)ease,color var(--duration-base)ease,border-color var(--duration-base)ease;justify-content:center;align-items:center;padding:.55rem 1.1rem;font-size:.8rem;font-weight:600;text-decoration:none;display:inline-flex}.social-link span{font-size:.8rem;font-weight:600}.social-link:hover{color:#fff;background:#ffffff1a;border-color:#ffffff40}.contact-email{text-align:center;color:var(--ink-muted);margin-top:1rem;font-size:.825rem}.contact-email a{color:#ffffffa6;transition:color var(--duration-fast)ease;text-decoration:none}.contact-email a:hover{color:#fff}footer{background:var(--ink-mid);color:#ffffff59;text-align:center;font-size:.78rem;font-family:var(--font-sans);letter-spacing:.02em;border-top:1px solid #ffffff0f;padding:1.5rem 0}footer a{color:#ffffff8c;transition:color var(--duration-fast)ease;text-decoration:none}footer a:hover{color:#ffffffe6}.skill-bubble{border:1px solid var(--color-border);border-radius:var(--radius-full);color:var(--color-text-muted);cursor:default;transition:background-color var(--duration-fast)ease,color var(--duration-fast)ease,border-color var(--duration-fast)ease;font-size:.8rem;font-weight:500;font-family:var(--font-sans);background:0 0;margin:.2rem;padding:.3rem .75rem;display:inline-block}.skill-bubble:hover{background:var(--color-text);color:var(--color-bg);border-color:var(--color-text)}.terminal{color:#86efac;border-radius:var(--radius);font-family:var(--font-mono);white-space:pre-wrap;word-break:break-all;background:#0d0d0f;border:1px solid #1a1a1e;margin:1.25rem 0;padding:1rem 1.25rem;font-size:.775rem;line-height:1.65;overflow-x:auto}.terminal:before{content:"$ ";color:#4ade80;font-weight:600}.terminal-cursor{vertical-align:text-bottom;background:#86efac;width:6px;height:1em;animation:1.1s step-end infinite blink;display:inline-block}@keyframes blink{50%{opacity:0}}.skills-section{margin-top:1.5rem}.skills-section h4{color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.08em;font-size:.7rem;font-weight:600;font-family:var(--font-sans);margin-bottom:.65rem}.skills-container{flex-wrap:wrap;gap:.35rem;display:flex}.fade-in{opacity:0;transition:opacity .55s,transform .55s;transform:translateY(16px)}.fade-in.visible{opacity:1;transform:translateY(0)}.magnetic{transition:transform 80ms}.project-hero{background:var(--ink);color:#fff;padding:8rem 0 5rem;position:relative;overflow:hidden}.project-hero:before{content:"";pointer-events:none;background-image:radial-gradient(circle,#ffffff0f 1px,#0000 1px);background-size:28px 28px;position:absolute;inset:0}.project-hero .hero-content{z-index:2;position:relative}.badge{color:#ffffffbf;border-radius:var(--radius-full);letter-spacing:.08em;text-transform:uppercase;font-size:.7rem;font-weight:600;font-family:var(--font-sans);background:#ffffff14;border:1px solid #ffffff26;margin-bottom:1.25rem;padding:.3rem .8rem;display:inline-block}.project-hero h1{letter-spacing:-.03em;color:#fff;margin-bottom:1rem;font-size:clamp(2rem,5vw,3.25rem);font-weight:700;line-height:1.05}.project-hero .subtitle{opacity:.65;max-width:580px;font-size:1rem;line-height:1.8}.hero-links{flex-wrap:wrap;gap:.75rem;margin-top:2rem;display:flex}.hero-btn{border-radius:var(--radius-full);transition:transform var(--duration-base)var(--ease-out),background-color var(--duration-base)ease;font-size:.85rem;font-weight:600;font-family:var(--font-sans);padding:.65rem 1.4rem;text-decoration:none;display:inline-block}.hero-btn.primary{color:var(--ink);background:#fff}.hero-btn.primary:hover{transform:translateY(-1px)}.hero-btn.secondary{color:#ffffffbf;background:0 0;border:1px solid #fff3}.hero-btn.secondary:hover{background:#ffffff0f;border-color:#ffffff80}.overview-grid{border:1px solid var(--color-border);border-radius:var(--radius);background:var(--color-border);grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1px;margin-top:2rem;display:grid;overflow:hidden}.overview-card{background:var(--color-card-bg);text-align:center;transition:background-color var(--duration-theme)ease;padding:1.1rem 1.25rem}.overview-card .label{color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.08em;font-size:.68rem;font-weight:600;font-family:var(--font-sans);margin-bottom:.35rem}.overview-card .value{color:var(--color-text);font-size:.95rem;font-weight:700}.highlight-box{border-radius:var(--radius);margin:1.1rem 0;padding:1.1rem 1.4rem}.highlight-box.problem{background:#fff5f5;border-left:3px solid #e53e3e}.highlight-box.solution{background:#f0fff4;border-left:3px solid #38a169}[data-theme=dark] .highlight-box.problem{background:#e53e3e12}[data-theme=dark] .highlight-box.solution{background:#38a16912}.highlight-box h3{margin-bottom:.5rem;font-size:.95rem;font-weight:600}.highlight-box.problem h3{color:#c53030}.highlight-box.solution h3{color:#276749}.highlight-box p,.highlight-box li{color:var(--color-text-muted);font-size:.875rem}.highlight-box ul{margin:.35rem 0 0 1rem}.highlight-box li{margin-bottom:.35rem}.features-grid{border:1px solid var(--color-border);border-radius:var(--radius-lg);background:var(--color-border);grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:1px;margin-top:2rem;display:grid;overflow:hidden}.feature-card{background:var(--color-card-bg);transition:background-color var(--duration-theme)ease;padding:1.5rem}.feature-card:hover{background:var(--color-bg-alt)}[data-theme=dark] .feature-card:hover{background:#1c1c1f}.feature-icon{margin-bottom:.65rem;font-size:1.35rem}.feature-card h4{color:var(--color-text);margin-bottom:.35rem;font-size:.95rem;font-weight:600}.feature-card p{color:var(--color-text-muted);font-size:.85rem;line-height:1.65}.screenshots-section{background:var(--color-bg-alt)}.screenshots-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.25rem;margin-top:2rem;display:grid}.screenshot-card{border-radius:var(--radius);border:1px solid var(--color-border);transition:transform var(--duration-base)var(--ease-out);overflow:hidden}.screenshot-card:hover{transform:translateY(-2px)}.screenshot-card img{width:100%;height:auto;display:block}.screenshot-card .caption{background:var(--color-card-bg);color:var(--color-text);border-top:1px solid var(--color-border);padding:.75rem 1rem;font-size:.825rem;font-weight:600}.tech-section{background:var(--color-bg-alt)}.tech-category{margin-bottom:1.5rem}.tech-category h4{color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.08em;font-size:.7rem;font-weight:600;font-family:var(--font-sans);margin-bottom:.65rem}.tech-grid{flex-wrap:wrap;gap:.5rem;display:flex}.learning-item{border-bottom:1px solid var(--color-border);gap:1.1rem;padding:1.1rem 0;display:flex}.learning-item:last-child{border-bottom:none}.learning-number{background:var(--color-text);width:28px;height:28px;color:var(--color-bg);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:.75rem;font-weight:700;display:flex}.learning-content h4{color:var(--color-text);margin-bottom:.35rem;font-size:.95rem;font-weight:600}.learning-content p{color:var(--color-text-muted);font-size:.875rem;line-height:1.7}.role-box{background:var(--color-card-bg);border-radius:var(--radius-lg);border:1px solid var(--color-border);transition:background-color var(--duration-theme)ease;margin-top:1.25rem;padding:1.5rem 1.75rem}.role-box h3{color:var(--color-text);margin-bottom:.65rem;font-size:1rem;font-weight:600}.role-box ul{color:var(--color-text-muted);margin:.65rem 0 0 1rem}.role-box li{margin-bottom:.35rem;font-size:.875rem;line-height:1.65}.cta-section{background:var(--ink);color:#fff;text-align:center}.cta-section h2{letter-spacing:-.03em;color:#fff;margin-bottom:.6rem;font-size:1.65rem;font-weight:700}.cta-section p{color:var(--ink-muted);margin-bottom:2rem;font-size:.95rem}.cta-buttons{flex-wrap:wrap;justify-content:center;gap:.75rem;display:flex}.cta-btn{border-radius:var(--radius-full);transition:opacity var(--duration-base)ease,transform var(--duration-base)var(--ease-out);font-size:.875rem;font-weight:600;font-family:var(--font-sans);padding:.65rem 1.5rem;text-decoration:none;display:inline-block}.cta-btn.primary{color:var(--ink);background:#fff}.cta-btn.primary:hover{opacity:.9;transform:translateY(-1px)}.cta-btn.secondary{color:#ffffffb3;background:0 0;border:1px solid #ffffff2e}.cta-btn.secondary:hover{border-color:#ffffff73}@media (max-width:1024px){.container{padding:0 1.5rem}.about-grid{grid-template-columns:1fr;gap:2.5rem}.about-image{max-width:220px;margin:0 auto}.stats{grid-template-columns:repeat(2,1fr)}.projects-grid{grid-template-columns:1fr 1fr}.timeline-item{width:44%}}@media (max-width:768px){.mobile-menu-toggle{display:flex}.nav-container{position:relative}.nav-links{background:var(--color-nav-bg);-webkit-backdrop-filter:blur(20px);width:100%;height:calc(100vh - 60px);transition:right var(--duration-base)ease;flex-direction:column;justify-content:center;align-items:center;gap:2rem;position:fixed;top:60px;right:-100%}.nav-links.active{right:0}.nav-links li{font-size:1.1rem}.theme-toggle{height:36px;margin:auto;position:absolute;top:0;bottom:0;right:50px}main section,section{padding:4rem 0}.hero h1{font-size:2.35rem}.hero .tagline{font-size:.9rem}.hero-buttons{flex-direction:column;gap:.6rem}.cta-button{justify-content:center;width:100%}.about-grid{text-align:center}.about-image{max-width:200px}.stats{grid-template-columns:repeat(2,1fr)}.projects-grid{grid-template-columns:1fr}.section-title{font-size:1.65rem}.timeline-item,.timeline-item:nth-child(2n){width:100%;padding-left:32px;left:0}.experience-timeline:before{left:10px}.timeline-content:before,.timeline-item:nth-child(2n) .timeline-content:before{left:-25px}.timeline-content{padding:1.1rem}.social-links{gap:.6rem}.project-hero{padding:6rem 0 3rem}.project-hero h1{font-size:1.85rem}.overview-grid{grid-template-columns:repeat(2,1fr)}.features-grid,.screenshots-grid{grid-template-columns:1fr}.hero-links{flex-direction:column}.hero-btn{text-align:center}.learning-item{flex-direction:column;gap:.65rem}.cta-buttons{flex-direction:column;align-items:center}.cta-btn{text-align:center;width:100%;max-width:260px}}@media (max-width:480px){.container{padding:0 1rem}.hero h1{font-size:1.9rem}.hero-eyebrow{font-size:.65rem}.stats{grid-template-columns:1fr 1fr}.overview-grid{grid-template-columns:1fr}.project-content{padding:1.25rem}footer{padding:1.25rem 0;font-size:.72rem}}
