li{list-style:none}ul{padding:0}::-webkit-scrollbar{display:none}*{-ms-overflow-style:none;scrollbar-width:none}html,body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;-webkit-text-size-adjust:100%;margin:0;font-family:Bebas Neue,sans-serif;background-color:#fff!important}#root{box-sizing:border-box;flex-direction:column;width:100%;min-height:100vh;margin:0 auto;display:flex}.tooltip-wrapper{display:inline-flex;position:relative}.tooltip{color:#fff;white-space:nowrap;opacity:0;visibility:hidden;pointer-events:none;z-index:100;background:#404040;border-radius:4px;padding:.375rem .75rem;font-size:.75rem;font-weight:500;transition:opacity .2s,visibility .2s;position:absolute;bottom:calc(100% + 8px);left:50%;transform:translate(-50%)}.tooltip:after{content:"";border:6px solid #0000;border-top-color:#404040;position:absolute;top:100%;left:50%;transform:translate(-50%)}.tooltip-wrapper:hover .tooltip,.tooltip--visible{opacity:1;visibility:visible}.portfolio-loading-container{background:#fff;flex-direction:column;flex:1;justify-content:center;align-items:center;min-height:100vh;padding:3rem 2rem;display:flex;position:relative}.portfolio-loading-close-btn{z-index:1000;position:fixed;top:2rem;right:2rem}.portfolio-loading-content{text-align:center;flex-direction:column;justify-content:center;align-items:center;max-width:640px;display:flex}.portfolio-loading-label{letter-spacing:3px;text-transform:uppercase;color:#87329f;margin-bottom:2rem;font-size:16px;font-weight:600}.portfolio-loading-hero{flex-direction:column;align-items:center;gap:1.5rem;margin-bottom:1.5rem;display:flex}.portfolio-loading-spinner{justify-content:center;align-items:center;width:80px;height:80px;display:flex}.spinner-track{border:3px solid #e3e3e3;border-top-color:#87329f;border-radius:50%;width:80px;height:80px;animation:1.2s linear infinite portfolio-loading-spin}@keyframes portfolio-loading-spin{to{transform:rotate(360deg)}}.portfolio-loading-title{letter-spacing:2px;color:#000;text-transform:uppercase;margin:0;font-size:clamp(48px,12vw,80px);line-height:1}.portfolio-loading-subtitle{color:#404040;margin-bottom:2rem;font-size:16px;line-height:1.7}.portfolio-loading-progress{justify-content:center;display:flex}.portfolio-loading-progress-track{background:#e3e3e3;width:160px;height:2px;overflow:hidden}.portfolio-loading-progress-bar{will-change:transform, width;backface-visibility:hidden;background:linear-gradient(90deg,#87329f);width:40%;height:100%;animation:1.8s ease-in-out infinite portfolio-loading-progress-slide;transform:translateZ(0)}@keyframes portfolio-loading-progress-slide{0%{width:30%;transform:translate(-100%)}50%{width:50%}to{width:30%;transform:translate(350%)}}@media (width<=768px){.portfolio-loading-container{padding:2rem 1rem}.portfolio-loading-close-btn{width:40px;height:40px;top:1rem;right:1rem}.portfolio-loading-close-btn svg{width:20px;height:20px}.portfolio-loading-label,.portfolio-loading-subtitle{font-size:14px}.portfolio-loading-spinner,.spinner-track{width:60px;height:60px}}.button{cursor:pointer;background:0 0;border:none;border-radius:12px;justify-content:center;align-items:center;padding:0;font-family:inherit;transition:border-color .2s,color .2s,transform .2s;display:flex}.button svg{width:20px;height:20px}.button--close{color:#000;outline-offset:3px;border-radius:9999px;outline:2px solid #000;width:36px;height:36px;font-size:24px;line-height:1}.button--close:hover{color:#87329f;outline:2px solid #87329f}.button--close:focus-visible{outline-offset:3px;border-radius:9999px;outline:2px solid #87329f}.button--close:active{transform:scale(.95)}.button--close svg{width:24px;height:24px}.button--social{color:#000;border:1px solid #e3e3e3;border-radius:50%;width:44px;height:44px}.button--social:hover{color:#87329f;border-color:#87329f;transform:translateY(-2px)}.button--social:focus-visible{outline-offset:3px;border-radius:50%;outline:2px solid #87329f}.button--social:active{transform:scale(.95)}.button--primary{color:#fff;letter-spacing:.5px;cursor:pointer;background:#000;border:none;border-radius:12px;margin-top:1rem;padding:14px 32px;font-family:inherit;font-size:16px;font-weight:600;transition:background .2s,transform .2s}.button--primary:hover{background:#87329f;border-color:#87329f}.button--primary:focus-visible{outline-offset:3px;color:#fff;background:#87329f;border-color:#87329f;border-radius:12px;outline:2px solid #87329f}.button--primary:active{transform:scale(.95)}.portfolio-light-container{--color-primary:#3525cd;--color-secondary:#712ae2;--color-tertiary:#004d70;--color-background:#faf8ff;--color-surface:#faf8ff;--color-surface-bright:#faf8ff;--color-surface-container-lowest:#fff;--color-surface-container-low:#f2f3ff;--color-surface-container:#eaedff;--color-surface-container-high:#e2e7ff;--color-surface-container-highest:#dae2fd;--color-surface-variant:#dae2fd;--color-surface-dim:#d2d9f4;--color-on-surface:#131b2e;--color-on-surface-variant:#464555;--color-on-background:#131b2e;--color-on-primary:#fff;--color-on-secondary:#fff;--color-on-tertiary:#fff;--color-primary-container:#e2dfff;--color-on-primary-container:#0f0069;--color-primary-fixed:#e2dfff;--color-on-primary-fixed:#0f0069;--color-primary-fixed-dim:#c3c0ff;--color-on-primary-fixed-variant:#3323cc;--color-secondary-container:#8a4cfc;--color-on-secondary-container:#fffbff;--color-secondary-fixed:#eaddff;--color-on-secondary-fixed:#25005a;--color-secondary-fixed-dim:#d2bbff;--color-on-secondary-fixed-variant:#5a00c6;--color-tertiary-container:#006693;--color-on-tertiary-container:#b8e0ff;--color-tertiary-fixed:#c9e6ff;--color-on-tertiary-fixed:#001e2f;--color-tertiary-fixed-dim:#89ceff;--color-on-tertiary-fixed-variant:#004c6e;--color-error:#ba1a1a;--color-on-error:#fff;--color-error-container:#ffdad6;--color-on-error-container:#93000a;--color-outline:#777587;--color-outline-variant:#c7c4d8;--color-inverse-surface:#283044;--color-inverse-on-surface:#eef0ff;--color-inverse-primary:#c3c0ff;--color-focus:#7c3ed1;--font-headline:"Manrope", sans-serif;--font-body:"Inter", sans-serif;--font-label:"Space Grotesk", sans-serif;--transition-default:all .3s ease;--transition-fast:all .15s ease;--z-nav:50;background-color:var(--color-background);color:var(--color-on-background);font-family:var(--font-body);overflow-x:hidden}.portfolio-light-container ::selection{background-color:var(--color-primary-fixed);color:var(--color-on-primary-fixed)}.material-symbols-outlined{font-variation-settings:"FILL" 0, "wght" 400, "GRAD" 0, "opsz" 24;vertical-align:middle;text-align:center;box-sizing:content-box;justify-content:center;align-items:center;width:1em;height:1em;line-height:1;display:inline-flex;overflow:hidden}.text-accent{color:var(--color-primary);font-style:italic}.portfolio-light-container a:focus-visible:not(.btn-primary):not(.btn-secondary):not(.contact-social-link),.footer-legal-link:focus-visible{outline:2px solid var(--color-focus);outline-offset:2px;border-radius:4px}.portfolio-light-container button:focus-visible:not(.footer-legal-link),.portfolio-light-container .btn-primary:focus-visible,.portfolio-light-container .btn-secondary:focus-visible,.portfolio-light-container input:focus-visible,.portfolio-light-container textarea:focus-visible,.portfolio-light-container select:focus-visible,.portfolio-light-container [role=button]:focus-visible,.contact-social-link:focus-visible{outline:2px solid var(--color-focus);outline-offset:2px;border-radius:12px}.portfolio-light-container input:focus,.portfolio-light-container textarea:focus,.portfolio-light-container select:focus{outline:2px solid var(--color-focus);outline-offset:2px;border-radius:4px}.top-nav{width:100%;z-index:var(--z-nav);-webkit-backdrop-filter:blur(24px);backdrop-filter:blur(24px);background-color:#faf8ffb3;position:fixed;top:0;box-shadow:0 4px 30px #131b2e0f}.nav-content{justify-content:space-between;align-items:center;max-width:1280px;margin:0 auto;padding:16px 32px;display:flex}.nav-brand{font-family:var(--font-headline);background:linear-gradient(to right, var(--color-primary), var(--color-secondary));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:20px;font-weight:900;text-decoration:none}.nav-links{align-items:center;gap:32px;display:none}@media (width>=768px){.nav-links{display:flex}}.nav-link{font-family:var(--font-body);color:var(--color-on-surface-variant);border-bottom:2px solid #0000;padding-bottom:4px;font-weight:500;text-decoration:none;transition:color .3s}.nav-link:hover{color:var(--color-primary)}.nav-link:focus-visible,.nav-link:focus{color:var(--color-primary);outline:none}.nav-link-active{color:var(--color-primary);border-bottom-color:var(--color-primary)}.nav-cta{background:linear-gradient(to bottom right, var(--color-primary), var(--color-secondary));color:var(--color-on-primary);font-family:var(--font-headline);border-radius:4px;align-items:center;padding:10px 24px;font-size:14px;font-weight:700;text-decoration:none;transition:transform .15s,box-shadow .15s;display:inline-flex;box-shadow:0 4px 15px #3525cd33}.nav-cta:hover{transform:scale(1.05);box-shadow:0 6px 20px #3525cd4d}.nav-cta:active{transform:scale(.95)}.nav-cta:focus-visible,.nav-cta:focus{outline:none}.nav-mobile-toggle{cursor:pointer;color:var(--color-on-surface);box-sizing:border-box;background:0 0;border:none;justify-content:center;align-items:center;width:48px;height:48px;padding:8px;display:flex}.nav-mobile-toggle:focus-visible,.nav-mobile-toggle:focus{outline:none}.nav-mobile-toggle svg{width:48px;height:48px}@media (width>=768px){.nav-mobile-toggle{display:none}}.nav-mobile-menu{background-color:var(--color-surface-container-lowest);border-top:1px solid var(--color-outline-variant);flex-direction:column;padding:16px 32px 24px;display:flex}.nav-mobile-link{font-family:var(--font-body);color:var(--color-on-surface-variant);border-bottom:1px solid var(--color-outline-variant);padding:12px 0;font-weight:500;text-decoration:none;transition:color .3s}.nav-mobile-link:last-child{border-bottom:none}.nav-mobile-link:focus-visible,.nav-mobile-link:focus{color:var(--color-primary);outline:none}.nav-mobile-link:hover,.nav-mobile-link-active{color:var(--color-primary)}.main-content{width:100%;padding-top:80px}.hero-section{background:radial-gradient(circle,#3525cd0d 0%,#faf8ff00 70%);min-height:841px;padding:24px 16px;display:flex;position:relative;overflow:hidden}@media (width>=768px){.hero-section{padding:48px 64px}}.hero-grid{z-index:10;grid-template-columns:1fr auto;align-items:center;width:100%;max-width:1280px;margin:0 auto;display:grid;position:relative}@media (width>=768px){.hero-grid{grid-template-columns:repeat(12,1fr);align-items:center;gap:32px}}.hero-text{display:contents}@media (width>=768px){.hero-text{flex-direction:column;grid-column:span 7;gap:24px;display:flex}}.hero-title{font-family:var(--font-headline);letter-spacing:-.05em;color:var(--color-on-surface);grid-area:1/1;font-size:48px;font-weight:800;line-height:1.1}@media (width>=768px){.hero-title{grid-area:auto;font-size:64px}}@media (width>=1024px){.hero-title{font-size:72px}}.hero-title-accent{background:linear-gradient(to right, var(--color-primary), var(--color-secondary));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.hero-description{color:var(--color-on-surface-variant);grid-area:2/1/auto/-1;max-width:512px;margin:0;font-size:20px;line-height:1.6}.hero-actions{flex-wrap:wrap;grid-area:3/1/auto/-1;gap:16px;display:flex}.btn-primary{background:linear-gradient(to bottom right, var(--color-primary), var(--color-secondary));color:var(--color-on-primary);font-family:var(--font-headline);cursor:pointer;border:none;border-radius:12px;align-items:center;gap:8px;padding:16px 32px;font-size:16px;font-weight:700;text-decoration:none;transition:box-shadow .15s;display:inline-flex;box-shadow:0 4px 15px #3525cd33}.btn-secondary{background-color:var(--color-surface-container-highest);color:var(--color-primary);font-family:var(--font-headline);cursor:pointer;border:none;border-radius:12px;align-items:center;gap:8px;padding:16px 32px;font-size:16px;font-weight:700;text-decoration:none;transition:background-color .15s,color .15s;display:inline-flex}.btn-secondary:hover{background-color:var(--color-primary);color:var(--color-on-primary)}.hero-image-wrapper{grid-area:1/2;justify-content:center;display:flex;position:relative}@media (width>=768px){.hero-image-wrapper{grid-area:auto/span 5;justify-content:flex-end}}.hero-image-container{aspect-ratio:4/5;max-width:150px;margin:0 auto;position:relative}@media (width>=768px){.hero-image-container{max-width:300px}}.hero-image-container:before{content:"";background:linear-gradient(to bottom right,#3525cd33,#712ae233);border-radius:12px;position:absolute;inset:0;transform:rotate(6deg)}.hero-image{object-fit:cover;filter:grayscale();border-radius:12px;width:100%;height:100%;transition:filter .4s;position:relative;box-shadow:0 24px 50px #00000026}.hero-image-wrapper:hover .hero-image{filter:grayscale(0%)}.hero-decoration{pointer-events:none;border-radius:50%;position:absolute}.hero-decoration-1{filter:blur(64px);background:#3525cd0d;width:256px;height:256px;top:25%;left:-160px}.hero-decoration-2{filter:blur(64px);background:#712ae20d;width:384px;height:384px;bottom:25%;right:-192px}.about-section{background-color:var(--color-surface-container-low);padding:96px 32px}.about-container{max-width:960px;margin:0 auto}.section-header{text-align:center;margin-bottom:64px}.section-title{font-family:var(--font-headline);color:var(--color-on-surface);margin-bottom:16px;font-size:36px;font-weight:700}@media (width>=768px){.section-title{font-size:48px}}.section-divider{background:linear-gradient(to right, var(--color-primary), var(--color-secondary));border-radius:3px;width:80px;height:6px;margin:0 auto}.skills-section{background-color:var(--color-background);padding:96px 32px}.skills-container{max-width:1280px;margin:0 auto}.skills-header{justify-content:space-between;align-items:center;margin-bottom:32px;display:flex}.skills-subtitle{color:var(--color-on-surface-variant);margin-top:8px;font-size:18px}.skills-legend-toggle{background:var(--color-primary);color:var(--color-on-primary);cursor:pointer;border:none;border-radius:12px;justify-content:center;align-items:center;width:40px;height:40px;font-size:24px;font-weight:700;transition:all .3s;display:flex}.skills-legend-toggle:hover{background:var(--color-secondary);transform:scale(1.1)}.skills-legend{background-color:var(--color-surface-container-lowest);border:1px solid #c7c4d833;border-radius:12px;gap:24px;margin-bottom:32px;padding:16px;animation:.3s slideDown;display:flex}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.skills-legend-item{color:var(--color-on-surface);align-items:center;gap:8px;font-size:14px;font-weight:500;display:flex}.skills-legend-dot{border-radius:12px;width:12px;height:12px;display:inline-block}.skills-legend-dot.advanced{box-shadow:none;background-color:#7c3aed}.skills-legend-dot.intermediate{box-shadow:none;background-color:#a855f7}.skills-legend-dot.beginner{box-shadow:none;background-color:#d8b4fe}.skills-grid{grid-template-columns:1fr;gap:16px;display:grid}@media (width>=768px){.skills-grid{grid-template-columns:repeat(3,1fr);gap:16px}}.skill-card-title{font-family:var(--font-headline);color:var(--color-on-surface);align-items:center;gap:8px;margin-bottom:12px;font-size:14px;font-weight:600;display:flex}.skill-tag-glow{color:#4a1a99;font-family:var(--font-label);box-shadow:none;z-index:10;background-color:#712ae21f;border:1px solid #712ae240;border-radius:9999px;padding:6px 12px;font-size:11px;font-weight:600;position:relative}.projects-section{background-color:var(--color-background);padding:96px 32px}.projects-container{max-width:1280px;margin:0 auto}.projects-header{flex-direction:column;gap:24px;margin-bottom:64px;display:flex}@media (width>=768px){.projects-header{flex-direction:row;justify-content:space-between;align-items:flex-end}}.projects-subtitle{color:var(--color-on-surface-variant);margin-top:8px;font-size:18px}.projects-archive-link{color:var(--color-primary);font-family:var(--font-headline);align-items:center;gap:8px;font-weight:700;text-decoration:none;transition:gap .3s;display:none}@media (width>=768px){.projects-archive-link{display:flex}}.projects-archive-link:hover{gap:16px}.projects-archive-link .material-symbols-outlined{width:20px;height:20px;font-size:20px}.projects-grid{grid-template-columns:1fr;gap:32px;display:grid}@media (width>=768px){.projects-grid{grid-template-columns:repeat(2,1fr)}}@media (width>=1024px){.projects-grid{grid-template-columns:repeat(2,1fr)}}.project-image img{object-fit:cover;height:100%;transition:transform .7s}.project-tags{gap:8px;display:flex}.project-link .material-symbols-outlined{width:16px;height:16px;font-size:16px}.contributor-title{color:var(--color-primary);text-transform:uppercase;letter-spacing:.05em;overflow-wrap:anywhere;word-break:break-word;font-size:12px;font-weight:600}.project-card-coming-soon{text-align:center;background:linear-gradient(135deg,#3525cd0d 0%,#712ae208 100%);border:2px dashed #3525cd4d;border-radius:12px;flex-direction:column;justify-content:center;align-items:center;min-height:400px;padding:40px 20px;transition:all .3s;display:flex}.project-coming-soon-title{font-family:var(--font-headline);color:var(--color-on-surface);margin-bottom:8px;font-size:24px;font-weight:700}.project-coming-soon-text{color:var(--color-on-surface-variant);max-width:280px;font-size:16px;line-height:1.6}.contact-section{background-color:var(--color-surface-container-low);padding:96px 32px}.contact-container{grid-template-columns:1fr;gap:64px;max-width:1280px;margin:0 auto;display:grid}@media (width>=768px){.contact-container{grid-template-columns:auto 1fr;align-items:center;gap:96px}}.contact-info .section-title{text-align:left}.contact-description{color:var(--color-on-surface-variant);max-width:512px;font-size:18px;line-height:1.6}.contact-links{flex-direction:column;justify-content:flex-start;justify-self:end;align-items:flex-end;gap:24px;display:flex}.contact-link{color:var(--color-on-surface);align-items:center;gap:16px;font-size:18px;font-weight:700;text-decoration:none;transition:color .3s;display:flex}.contact-link:hover{color:var(--color-primary)}.contact-email-icon rect,.contact-email-icon path{stroke:currentColor}.contact-link:hover .contact-link-icon{background-color:var(--color-primary);color:var(--color-on-primary)}.contact-link:hover .contact-email-icon rect,.contact-link:hover .contact-email-icon path{stroke:var(--color-on-primary)}.contact-social{gap:16px;display:flex}.contact-social-link{background-color:var(--color-surface-container-highest);width:48px;height:48px;color:var(--color-primary);border-radius:12px;justify-content:center;align-items:center;text-decoration:none;transition:background-color .3s,color .3s;display:flex}.contact-social-link svg{stroke:var(--color-primary);color:var(--color-primary)}.contact-social-link:hover{background-color:var(--color-primary);color:var(--color-on-primary)}.contact-social-link:hover svg{stroke:var(--color-on-primary);color:var(--color-on-primary)}.footer{background-color:var(--color-surface-container-lowest);border-top:1px solid #c7c4d81a;padding:48px 32px}.footer-container{flex-direction:column;align-items:center;gap:16px;max-width:1280px;margin:0 auto;display:flex}@media (width>=768px){.footer-container{flex-direction:row;justify-content:space-between;align-items:center}}.footer-brand{font-family:var(--font-headline);color:var(--color-on-surface);font-size:18px;font-weight:700}.footer-copyright{font-family:var(--font-body);color:var(--color-on-surface-variant);font-size:14px}.footer-links{gap:32px;display:flex}.footer-links a{font-family:var(--font-body);color:var(--color-on-surface-variant);font-size:14px;text-decoration:none;transition:color .2s,transform .2s}.footer-links a:hover{color:var(--color-primary);transform:translateY(-2px)}.footer-legal{justify-content:center;align-items:center;gap:12px;display:flex}.footer-legal-link{color:var(--color-on-surface-variant);font-size:14px;font-family:var(--font-body);cursor:pointer;font:inherit;background:0 0;border:none;padding:0;text-decoration:none;transition:color .2s}.footer-legal-link:hover{color:var(--color-primary)}.footer-legal-divider{color:#c7c4d84d}.footer-login-link{opacity:.3;justify-content:center;align-items:center;margin-top:.5rem;transition:opacity .2s;display:flex}.footer-login-link:hover{opacity:.6}.footer-login-link .wip-icon-btn{pointer-events:none;color:#c7c4d8cc;width:24px;height:24px}.footer-login-link .wip-icon-btn svg{width:24px;height:24px}.workflow-section{background-color:var(--color-surface-container);padding:96px 32px}.workflow-container{max-width:1280px;margin:0 auto}.workflow-subtitle{color:var(--color-on-surface-variant);text-align:center;max-width:640px;margin:16px auto 0;line-height:1.6}.wf-legend{flex-wrap:wrap;justify-content:center;gap:24px;margin-bottom:40px;display:flex}.wf-legend-item{font-family:var(--font-label);letter-spacing:.04em;background-color:var(--color-surface-container-lowest);border:1px solid var(--color-outline-variant);border-radius:12px;align-items:center;gap:8px;padding:6px 14px;font-size:13px;font-weight:600;display:inline-flex}.wf-legend-item svg{width:18px;height:18px}.wf-legend-designer{color:var(--color-primary)}.wf-legend-ai{color:var(--color-secondary)}.wf-legend-developer{color:var(--color-tertiary)}.wf-flow{flex-direction:column;align-items:center;max-width:720px;margin:0 auto;display:flex}.wf-pill{font-family:var(--font-label);text-transform:uppercase;letter-spacing:.1em;color:#fff;border-radius:12px;padding:8px 28px;font-size:13px;font-weight:700}.wf-pill-start{background:linear-gradient(135deg, var(--color-primary), var(--color-secondary))}.wf-pill-end{background:linear-gradient(135deg, var(--color-primary), var(--color-secondary));padding:12px 32px;font-size:14px;box-shadow:0 2px 10px #3525cd4d}.wf-arrow{flex-shrink:0;width:24px;height:40px;display:block}.wf-arrow-h{flex-shrink:0;align-self:center;width:40px;height:24px;display:block}.wf-node{background-color:var(--color-surface-container-lowest);border:1px solid var(--color-outline-variant);border-radius:12px;align-items:center;gap:14px;width:100%;max-width:420px;padding:16px 20px;display:flex;box-shadow:0 2px 8px #0000000a}.wf-node-compact{max-width:420px}.wf-node-icon{color:#fff;border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:42px;min-width:42px;height:42px;display:flex}.wf-node-icon svg{width:22px;height:22px}.wf-bg-designer{background:linear-gradient(135deg, var(--color-primary), #4a3ad4)}.wf-bg-ai{background:linear-gradient(135deg, var(--color-secondary), #9147f5)}.wf-bg-developer{background:linear-gradient(135deg, var(--color-tertiary), #006693)}.wf-bg-dual{background:linear-gradient(135deg, var(--color-tertiary), var(--color-secondary));gap:2px}.wf-bg-dual svg{width:16px;height:16px}.wf-node-body{flex-direction:column;gap:2px;min-width:0;display:flex}.wf-node-role{font-family:var(--font-label);text-transform:uppercase;letter-spacing:.1em;color:var(--color-on-surface-variant);font-size:10px;font-weight:600}.wf-node-title{font-family:var(--font-headline);color:var(--color-on-surface);font-size:14px;font-weight:700;line-height:1.3}.wf-node-description{font-family:var(--font-body);color:var(--color-on-surface-variant);margin-top:4px;font-size:12px;font-weight:400;line-height:1.4}.wf-loop{border:2px dashed var(--color-primary);background-color:#3525cd05;border-radius:16px;flex-direction:column;align-items:center;width:100%;max-width:520px;padding:36px 20px 24px;display:flex;position:relative}.wf-loop-label{background-color:var(--color-surface-container);font-family:var(--font-label);color:var(--color-primary);text-transform:uppercase;letter-spacing:.08em;border-radius:6px;padding:2px 14px;font-size:12px;font-weight:700;position:absolute;top:-13px;left:24px}.wf-loop-nodes{flex-direction:column;align-items:center;gap:12px;width:100%;display:flex}.wf-decision{flex-direction:column;align-items:center;gap:12px;display:flex}.wf-diamond{background-color:var(--color-surface-container-lowest);border:2px solid var(--color-primary);border-radius:12px;justify-content:center;align-items:center;width:80px;height:80px;display:flex;transform:rotate(45deg);box-shadow:0 2px 10px #3525cd1a}.wf-diamond span{font-family:var(--font-label);color:var(--color-primary);text-align:center;font-size:11px;font-weight:700;line-height:1.2;transform:rotate(-45deg)}.wf-branches{gap:16px;display:flex}.wf-branch{background-color:var(--color-surface-container-lowest);border:1px solid var(--color-outline-variant);border-radius:12px;flex-direction:row;align-items:center;gap:12px;min-width:140px;padding:14px 18px;display:flex;box-shadow:0 2px 8px #0000000a}.wf-branch-content{flex-direction:column;align-items:center;gap:4px;display:flex}.wf-branch-tag{font-family:var(--font-label);text-transform:uppercase;letter-spacing:.06em;border-radius:9999px;padding:3px 14px;font-size:11px;font-weight:800}.wf-branch-no .wf-branch-tag{color:var(--color-on-error-container);background-color:#dc26261a}.wf-branch-yes .wf-branch-tag{color:#166534;background-color:#1665341a}.wf-branch-no{border-color:#dc262640}.wf-branch-yes{border-color:#16653440}.wf-branch-text{font-family:var(--font-label);color:var(--color-on-surface-variant);text-align:center;font-size:12px;font-weight:500;line-height:1.3}.wf-branch-arrow{width:16px;height:28px;color:var(--color-outline-variant);flex-shrink:0}.wf-branch-no .wf-branch-arrow{color:var(--color-on-error-container)}.wf-branch-yes .wf-branch-arrow{color:#166534}.wf-qa-group{background-color:var(--color-surface-container-lowest);border:1px solid var(--color-outline-variant);border-radius:12px;width:100%;max-width:480px;padding:24px;position:relative}.wf-qa-label{background-color:var(--color-surface-container);font-family:var(--font-label);color:var(--color-tertiary);text-transform:uppercase;letter-spacing:.08em;border-radius:6px;padding:2px 12px;font-size:12px;font-weight:700;position:absolute;top:-11px;left:20px}.wf-qa-items{flex-direction:column;gap:12px;display:flex}.wf-qa-item{font-family:var(--font-body);color:var(--color-on-surface);background-color:var(--color-surface-container-low);border:1px solid var(--color-outline-variant);border-radius:8px;align-items:center;gap:12px;padding:10px 14px;font-size:13px;font-weight:500;display:flex}.wf-qa-icon{text-align:center;flex-shrink:0;width:24px;font-size:18px}.wf-final-row{flex-direction:column;align-items:center;gap:12px;width:100%;display:flex}@media (width>=768px){.wf-final-row{flex-direction:row;justify-content:center;gap:0}.wf-final-row .wf-node{max-width:220px}.wf-final-row .wf-node .wf-node-icon{border-radius:8px;width:36px;min-width:36px;height:36px}.wf-final-row .wf-node .wf-node-icon svg{width:18px;height:18px}.wf-final-row .wf-node .wf-node-title{font-size:13px}.wf-final-row .wf-arrow-h{display:block}}@media (width<=767px){.wf-final-row .wf-arrow-h{width:24px;height:40px;transform:rotate(90deg)}}.wf-node-wrapper{align-items:flex-start;width:100%;max-width:420px;display:flex;position:relative}.wf-node-wrapper .wf-node{position:relative}.wf-info-btn{border:1.5px solid var(--color-outline-variant);background-color:var(--color-surface-container-low);width:24px;height:24px;color:var(--color-on-surface-variant);font-family:var(--font-label);cursor:pointer;border-radius:50%;justify-content:center;align-items:center;padding:0;font-size:13px;font-style:italic;font-weight:700;line-height:1;transition:background-color .15s,border-color .15s,color .15s;display:flex;position:absolute;top:8px;right:8px}.wf-info-btn:hover{background-color:var(--color-primary);border-color:var(--color-primary);color:#fff}.wf-node-toggle{border:1.5px solid var(--color-outline-variant);background-color:var(--color-surface-container-low);width:24px;height:24px;color:var(--color-on-surface-variant);cursor:pointer;justify-content:center;align-items:center;padding:0;line-height:1;transition:background-color .15s,border-color .15s,color .15s;display:flex;position:absolute;top:-6px;right:9px;border-radius:12px!important}.wf-node-toggle:hover,.wf-node-toggle:focus-visible{background-color:var(--color-secondary);border-color:var(--color-secondary);color:#fff}.wf-info-panel{box-sizing:border-box;background-color:var(--color-surface-container-lowest);border:1px solid var(--color-outline-variant);z-index:50;border-radius:12px;padding:0 24px 24px;animation:.2s ease-out wf-info-fade-in;position:fixed;box-shadow:0 4px 20px #00000014}.wf-info-panel-close{border:1.5px solid var(--color-outline-variant);background-color:var(--color-surface-container-low);width:24px;height:24px;color:var(--color-on-surface-variant);cursor:pointer;border-radius:50%;justify-content:center;align-items:center;padding:0;line-height:1;transition:background-color .15s,border-color .15s,color .15s;display:flex;position:absolute;top:-6px;right:9px}.wf-info-panel-close:hover,.wf-info-panel-close:focus-visible{background-color:var(--color-secondary);border-color:var(--color-secondary);color:#fff}.wf-info-panel-content{font-family:var(--font-body);color:var(--color-on-surface);padding-top:18px;font-size:13px;line-height:1.6}@keyframes wf-info-fade-in{0%{opacity:0;transform:translate(-8px)}to{opacity:1;transform:translate(0)}}.wf-info-overlay{z-index:999;background-color:#0006;animation:.2s ease-out wf-overlay-in;position:fixed;inset:0}.wf-info-sheet{background-color:var(--color-surface-container-lowest);z-index:1000;border-radius:20px 20px 0 0;max-height:70vh;padding:12px 24px 32px;animation:.25s ease-out wf-sheet-up;position:fixed;bottom:0;left:0;right:0;overflow-y:auto;box-shadow:0 -4px 24px #0000001f}.wf-info-sheet-handle{display:none}.wf-info-sheet-close{border:1.5px solid var(--color-outline-variant);background-color:var(--color-surface-container-low);width:28px;height:28px;color:var(--color-on-surface-variant);cursor:pointer;border-radius:50%;justify-content:center;align-items:center;padding:0;line-height:1;transition:background-color .15s,border-color .15s,color .15s;display:flex;position:absolute;top:-6px;right:9px}.wf-info-sheet-close:hover{background-color:var(--color-secondary);border-color:var(--color-secondary);color:#fff}.wf-info-sheet-content{font-family:var(--font-body);color:var(--color-on-surface);font-size:14px;line-height:1.6}@keyframes wf-overlay-in{0%{opacity:0}to{opacity:1}}@keyframes wf-sheet-up{0%{transform:translateY(100%)}to{transform:translateY(0)}}@keyframes icon-spin{0%{transform:rotate(0)scale(1)}50%{transform:rotate(180deg)scale(1.1)}to{transform:rotate(360deg)scale(1)}}.wip-icon-btn{cursor:pointer;color:#000;background:0 0;border:none;justify-content:center;align-items:center;width:56px;height:56px;padding:0;transition:opacity .2s;display:flex}.wip-icon-btn:hover{opacity:.8;color:#87329f}.wip-icon-btn:focus-visible{color:#87329f;outline-offset:5px;border-radius:9999px;outline:2px solid #87329f}.wip-icon-btn:active{opacity:.7}.wip-icon-btn svg{width:56px;height:56px;display:block}.wip-icon-btn--animate svg{animation:.6s cubic-bezier(.68,-.55,.265,1.55) icon-spin}.timeline{flex-direction:column;gap:48px;display:flex}.timeline-item{gap:32px;width:100%;min-width:0;display:flex}.timeline-marker{flex-direction:column;align-items:center;display:flex}.timeline-icon{background-color:var(--color-surface-container-lowest);width:48px;height:48px;color:var(--color-primary);border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;display:flex;box-shadow:0 2px 8px #00000014}.timeline-icon .material-symbols-outlined{width:24px;height:24px;font-size:24px}.timeline-line{background-color:var(--color-outline-variant);opacity:.3;flex:1;width:2px;margin-top:8px}.timeline-item:last-child .timeline-line{display:none}.timeline-content{overflow-wrap:anywhere;word-break:break-word;flex:1;min-width:0;padding-bottom:8px}.timeline-date{font-family:var(--font-label);letter-spacing:.1em;text-transform:uppercase;color:var(--color-primary);font-size:12px;font-weight:700}.timeline-title{font-family:var(--font-headline);color:var(--color-on-surface);overflow-wrap:anywhere;word-break:break-word;margin-top:4px;margin-bottom:12px;font-size:24px;font-weight:700}.timeline-description{color:var(--color-on-surface-variant);overflow-wrap:anywhere;word-break:break-word;max-width:100%;margin-block-end:16px;font-size:16px;line-height:1.6}.timeline-description-link{color:var(--color-primary);overflow-wrap:anywhere;word-break:break-word;padding-bottom:3px;font-weight:700;text-decoration:none;transition:color .3s}.timeline-skill-tags{flex-wrap:wrap;gap:8px;display:flex}.timeline-skill-tag{background-color:var(--color-surface-container-lowest);color:var(--color-on-surface);font-family:var(--font-label);border-radius:12px;padding:8px 16px;font-size:12px}.skill-card{background-color:var(--color-surface-container-lowest);border:1px solid #c7c4d81a;border-radius:12px;padding:20px 16px;box-shadow:0 2px 8px #0000000a}.skill-card-highlight{background-color:var(--color-surface-container-lowest)}.skill-card-title{font-family:var(--font-headline);color:var(--color-on-surface);align-items:center;gap:8px;margin-top:-4px;margin-bottom:16px;font-size:14px;font-weight:600;display:flex}.skill-card-title .material-symbols-outlined{color:var(--color-primary);width:16px;height:16px}.skill-card-icon{color:var(--color-primary);justify-content:center;align-items:center;width:18px;height:18px;display:inline-flex}.skill-card-icon svg{width:18px;height:18px}.skill-tags{flex-wrap:wrap;gap:8px;display:flex}.skill-tag{background-color:var(--color-surface-container-low);color:var(--color-on-surface);font-family:var(--font-label);border-radius:4px;padding:8px 16px;font-size:12px;transition:all .2s}.skill-tag-advanced{color:#1a0a7a;font-family:var(--font-label);box-shadow:none;background-color:#3525cd26;border:1px solid #3525cd4d;border-radius:4px;padding:6px 12px;font-size:11px;font-weight:600}.skill-tag-intermediate{color:#4a1a99;font-family:var(--font-label);box-shadow:none;background-color:#712ae21f;border:1px solid #712ae240;border-radius:4px;padding:6px 12px;font-size:11px;font-weight:600}.skill-tag-beginner{color:#6d36a0;font-family:var(--font-label);box-shadow:none;background-color:#9d5ddd1a;border:1px solid #9d5ddd40;border-radius:4px;padding:6px 12px;font-size:11px;font-weight:600}.skill-tag-default{background-color:var(--color-surface-container-low);color:var(--color-on-surface);font-family:var(--font-label);border-radius:9999px;padding:8px 16px;font-size:12px}.skill-tag-glow{color:#4a1a99;font-family:var(--font-label);background-color:#712ae21f;border:1px solid #712ae240;padding:6px 12px;font-size:11px;font-weight:600}.project-card{background-color:var(--color-surface-container-lowest);border:1px solid #c7c4d81a;border-radius:12px;flex-direction:column;transition:box-shadow .5s,transform .5s;display:flex;overflow:hidden}.project-image{aspect-ratio:16/9;overflow:hidden}.project-image img{object-fit:cover;object-position:left;width:100%;height:100%;transition:transform .7s}.image-credit{color:var(--color-on-surface);border-top:1px solid var(--color-surface-container-high);margin-top:auto;padding:12px 32px;font-size:11px;display:block}.image-credit a{color:var(--color-on-surface);text-decoration:underline}.image-credit a:hover{text-decoration:underline}.project-content{flex-direction:column;flex:1;gap:16px;padding:32px 32px 0;display:flex}.project-tags{flex-wrap:wrap;gap:8px;display:flex}.project-tag{text-transform:uppercase;letter-spacing:.05em;color:var(--color-primary);background-color:#3525cd1a;border-radius:4px;padding:4px 8px;font-size:10px;font-weight:700}.project-title{font-family:var(--font-headline);color:var(--color-on-surface);font-size:24px;font-weight:700;transition:color .3s}.project-description{color:var(--color-on-surface-variant);-webkit-line-clamp:4;line-clamp:4;-webkit-box-orient:vertical;font-size:14px;line-height:1.6;display:-webkit-box;overflow:hidden}.project-link{color:var(--color-primary);align-items:center;gap:8px;font-weight:700;text-decoration:none;transition:gap .3s;display:inline-flex}.project-link svg{width:16px;height:16px}.contributor-section{background-color:#3525cd0d;border:1px solid #3525cd1a;border-radius:8px;flex-direction:column;gap:12px;padding:16px;display:flex}.contributor-header{align-items:center;gap:12px;display:flex}.contributor-avatar{object-fit:cover;border:2px solid var(--color-primary);border-radius:50%;width:40px;height:40px}.contributor-info{overflow-wrap:anywhere;word-break:break-word;flex-direction:column;gap:2px;min-width:0;display:flex}.contributor-title{color:var(--color-primary);text-transform:uppercase;letter-spacing:.05em;overflow-wrap:anywhere;word-break:break-word;font-size:12px;font-weight:600;text-decoration:none;transition:color .3s}.contributor-title:hover{color:var(--color-secondary)}.contributor-name{color:var(--color-on-surface);overflow-wrap:anywhere;word-break:break-word;font-size:14px;font-weight:600}.contributor-stats{pointer-events:none;flex-wrap:wrap;justify-content:space-evenly;gap:16px;display:flex}.contributor-stat{flex-direction:column;align-items:center;gap:4px;display:flex}.stat-number{color:var(--color-primary);font-size:14px;font-weight:700;font-family:var(--font-label)}.stat-label{color:var(--color-on-surface-variant);letter-spacing:.05em;font-size:11px;font-weight:500}.modal-overlay{z-index:1000;background:#131b2e80;justify-content:center;align-items:center;padding:2rem;animation:.3s modal-fade-in;display:flex;position:fixed;inset:0}@keyframes modal-fade-in{0%{opacity:0}to{opacity:1}}.modal-container{background:#faf8ff;border-radius:12px;width:100%;max-width:600px;max-height:90vh;padding:3rem 2rem;animation:.3s modal-slide-up;position:relative;overflow-y:auto;box-shadow:0 20px 60px #131b2e26}@keyframes modal-slide-up{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.modal-close-btn{cursor:pointer;color:#464555;z-index:1001;background:0 0;border:none;border-radius:12px;outline:2px solid #c7c4d8;justify-content:center;align-items:center;width:40px;height:40px;padding:8px;transition:color .2s,transform .2s;display:flex;position:absolute;top:1.5rem;right:1.5rem}.modal-close-btn:hover{color:#3525cd;outline-color:#3525cd;transform:scale(1.1)}.modal-close-btn:focus-visible{outline-offset:2px;border-radius:12px;outline:2px solid #7c3ed1}.modal-close-btn:active{transform:scale(.95)}.modal-close-btn svg{width:24px;height:24px}.modal-title{color:#3525cd;margin:0 0 1.5rem;font-size:32px;font-weight:600}.modal-content{color:#464555;font-size:16px;line-height:1.6}@media (width<=768px){.modal-overlay{padding:1rem}.modal-container{border-radius:12px;padding:2rem 1.5rem}.modal-close-btn{border-radius:12px;width:36px;height:36px;top:1rem;right:1rem}.modal-close-btn svg{width:20px;height:20px}.modal-title{font-size:24px}}.form-honeypot{width:1px;height:1px;position:absolute;left:-9999px;overflow:hidden}.contact-form-container{background-color:var(--color-surface-container-lowest);border:1px solid #c7c4d81a;border-radius:12px;padding:40px;box-shadow:0 8px 32px #00000014}.contact-form{flex-direction:column;gap:24px;display:flex}.form-row{grid-template-columns:1fr;gap:32px;display:grid}@media (width>=768px){.form-row{grid-template-columns:repeat(2,1fr)}}.form-group{flex-direction:column;gap:8px;display:flex}.form-label{font-family:var(--font-label);text-transform:uppercase;letter-spacing:.1em;color:var(--color-on-surface-variant);font-size:12px;font-weight:600}.form-input,.form-textarea{box-sizing:border-box;background-color:var(--color-surface-container-low);width:100%;font-family:var(--font-body);color:var(--color-on-surface);border:none;border-radius:8px;padding:16px;font-size:16px;transition:box-shadow .3s}.form-input:focus,.form-textarea:focus{box-shadow:none}.form-input::placeholder,.form-textarea::placeholder{color:var(--color-on-surface-variant);opacity:.5;font-style:italic}.btn-submit{border-radius:12px;width:100%}.btn-submit:disabled{cursor:not-allowed;opacity:.6}.btn-submit-disabled{border-radius:12px;transition:transform .2s,opacity .2s;position:relative}.btn-submit-disabled:hover{animation:.4s forwards run-away}.form-status-success{color:#166534;font-family:var(--font-body);background-color:#16653414;border:1px solid #16653440;border-radius:10px;align-items:center;gap:12px;padding:24px;font-size:15px;font-weight:500;display:flex}.form-status-success svg{flex-shrink:0}.form-status-error{font-family:var(--font-body);color:var(--color-on-error-container);background-color:#dc262614;border:1px solid #dc262633;border-radius:8px;padding:10px 14px;font-size:13px}@keyframes run-away{0%{transform:translate(0)}25%{transform:translate(-8px)}50%{transform:translate(6px)}75%{transform:translate(-4px)}to{transform:translate(0)}}.dark-portfolio-container{--color-tertiary-dim:#00deec;--color-surface-container-low:#091328;--color-on-primary-container:#4a5e00;--color-surface-container-high:#141f38;--color-primary-fixed-dim:#beee00;--color-on-primary-fixed-variant:#526900;--color-on-secondary:#47001d;--color-surface-bright:#1f2b49;--color-secondary-container:#bb0058;--color-on-error:#450900;--color-on-primary-fixed:#3a4a00;--color-on-secondary-fixed:#6d0030;--color-on-surface-variant:#a3aac4;--color-error-dim:#d53d18;--color-tertiary-fixed-dim:#00deec;--color-on-tertiary-fixed-variant:#005e64;--color-outline-variant:#40485d;--color-secondary-fixed-dim:#ffadc0;--color-surface-variant:#192540;--color-on-tertiary-fixed:#003f43;--color-secondary:#ff6b98;--color-outline:#6d758c;--color-surface-container:#0f1930;--color-inverse-primary:#516700;--color-tertiary:#8ff5ff;--color-error:#ff7351;--color-on-background:#dee5ff;--color-surface-container-lowest:#000;--color-background:#060e20;--color-on-primary:#516700;--color-on-secondary-fixed-variant:#a1004b;--color-error-container:#b92902;--color-tertiary-fixed:#00eefc;--color-primary-container:#cafd00;--color-surface-dim:#060e20;--color-on-tertiary-container:#005359;--color-on-secondary-container:#fff5f6;--color-tertiary-container:#00eefc;--color-primary-fixed:#cafd00;--color-primary:#f3ffca;--color-surface-tint:#f3ffca;--color-on-error-container:#ffd2c8;--color-secondary-fixed:#ffc1ce;--color-primary-dim:#beee00;--color-surface-container-highest:#192540;--color-on-surface:#dee5ff;--color-inverse-on-surface:#4d556b;--color-surface:#060e20;--color-inverse-surface:#faf8ff;--color-secondary-dim:#e4006c;--color-on-tertiary:#005d63;--font-headline:"Space Grotesk", sans-serif;--font-body:"Manrope", sans-serif;--font-label:"Inter", sans-serif;--transition-default:all .3s ease;--transition-fast:all .15s ease;--z-nav:50;background-color:var(--color-background);color:var(--color-on-background);font-family:var(--font-body);overflow-x:hidden}.dark-portfolio-container ::selection{background-color:var(--color-primary-container);color:var(--color-on-primary-container)}.dark-material-symbols-outlined{font-variation-settings:"FILL" 0, "wght" 400, "GRAD" 0, "opsz" 24}.dark-stencil-text{-webkit-text-stroke:1px currentColor;color:#0000}.dark-spray-glow{filter:drop-shadow(0 0 15px #cf06)}.dark-cyber-grid{background-image:radial-gradient(circle at 1px 1px, var(--color-outline-variant) 1px, transparent 0);background-size:40px 40px}.dark-paint-drip{clip-path:polygon(0% 0%,100% 0%,100% 70%,85% 90%,70% 70%,55% 100%,40% 75%,25% 95%,10% 70%,0% 85%)}.dark-top-app-bar{-webkit-backdrop-filter:blur(24px);backdrop-filter:blur(24px);z-index:50;background-color:#060e2099;border-bottom:1px solid #40485d26;justify-content:space-between;align-items:center;width:100%;padding:16px 24px;display:flex;position:fixed;top:0;box-shadow:0 4px 30px #ccff000d}.dark-top-app-bar-brand{font-family:var(--font-headline);color:var(--color-primary-fixed);letter-spacing:-.05em;text-transform:uppercase;font-size:24px;font-style:italic;font-weight:900}.dark-top-app-bar-nav{align-items:center;gap:32px;display:none}@media (width>=768px){.dark-top-app-bar-nav{display:flex}}.dark-top-app-bar-nav a{font-family:var(--font-headline);letter-spacing:-.05em;text-transform:uppercase;color:var(--color-on-background);font-size:12px;font-weight:700;text-decoration:none;transition:color .3s}.dark-top-app-bar-nav a:hover{color:var(--color-primary-fixed)}.dark-top-app-bar-actions{gap:16px;display:flex}.dark-top-app-bar-actions button{cursor:pointer;color:var(--color-primary-fixed);background:0 0;border:none;padding:0;transition:transform .15s}.dark-top-app-bar-actions button:hover{transform:scale(1.1)}.dark-top-app-bar-actions button:active{transform:scale(.95)}.dark-main-content{padding-top:96px}.dark-hero-section{align-items:center;min-height:825px;padding:24px;display:flex;position:relative;overflow:hidden}@media (width>=768px){.dark-hero-section{padding:24px 48px}}.dark-hero-grid{z-index:10;grid-template-columns:1fr;align-items:center;gap:24px;width:100%;max-width:1280px;margin:0 auto;display:grid;position:relative}@media (width>=768px){.dark-hero-grid{grid-template-columns:repeat(12,1fr);gap:32px}}.dark-hero-text{display:contents}@media (width>=768px){.dark-hero-text{flex-direction:column;grid-column:span 7;gap:24px;display:flex}}.dark-hero-status-badge{background-color:var(--color-secondary);color:var(--color-on-secondary);font-family:var(--font-label);letter-spacing:.15em;text-transform:uppercase;padding:4px 12px;font-size:10px;font-weight:700;display:inline-block}.dark-hero-title{font-family:var(--font-headline);letter-spacing:-.05em;text-transform:uppercase;order:1;font-size:48px;font-weight:900;line-height:1}@media (width>=768px){.dark-hero-title{order:auto;font-size:72px}}@media (width>=1024px){.dark-hero-title{font-size:96px}}.dark-hero-title-primary{color:var(--color-primary-container);font-style:italic}.dark-hero-description{border-left:2px solid var(--color-primary-container);max-width:512px;color:var(--color-on-surface-variant);order:3;padding-top:8px;padding-bottom:8px;padding-left:24px;font-size:18px;line-height:1.6}.dark-hero-actions{flex-wrap:wrap;order:4;gap:16px;padding-top:24px;display:flex}.dark-btn-primary{background-color:var(--color-primary);color:var(--color-on-primary);font-family:var(--font-headline);letter-spacing:-.05em;text-transform:uppercase;cursor:pointer;transition:var(--transition-default);border:none;align-items:center;gap:8px;padding:16px 32px;font-size:14px;font-weight:900;display:flex}.dark-btn-primary:hover{background-color:var(--color-primary-container)}.dark-btn-secondary{font-family:var(--font-headline);letter-spacing:-.05em;text-transform:uppercase;color:var(--color-on-surface);cursor:pointer;transition:var(--transition-default);background-color:#0000;border:1px solid #40485d4d;align-items:center;gap:8px;padding:16px 32px;font-size:14px;font-weight:900;display:flex}.dark-btn-secondary:hover{background-color:var(--color-surface-container-high)}.dark-hero-image-wrapper{order:2;justify-content:center;max-width:140px;margin:0 auto;display:flex;position:relative}@media (width>=768px){.dark-hero-image-wrapper{order:auto;grid-column:span 5;justify-content:flex-end;max-width:none;margin:0}}.dark-hero-image-stencil{opacity:.1;pointer-events:none;font-size:144px;font-weight:900;position:absolute;top:-40px;right:-40px}.dark-hero-image-border{z-index:10;border:12px solid var(--color-surface-container-high);position:relative}.dark-hero-image{aspect-ratio:4/5;object-fit:cover;filter:grayscale();width:100%;transition:filter .7s}.dark-hero-image:hover{filter:grayscale(0)}.dark-hero-image-badge{background-color:var(--color-primary-container);color:var(--color-on-primary-container);font-family:var(--font-headline);padding:16px;font-size:24px;font-style:italic;font-weight:900;position:absolute;bottom:-24px;left:-24px}.dark-hero-image-glow{filter:blur(48px);background-color:#ff6b9833;border-radius:50%;width:192px;height:192px;position:absolute;bottom:-48px;right:-48px}.dark-about-section{background-color:var(--color-surface-container-low);padding:96px 24px;position:relative}.dark-about-container{max-width:1280px;margin:0 auto}.dark-about-header{justify-content:space-between;align-items:flex-end;margin-bottom:64px;display:flex}.dark-about-header-label{font-family:var(--font-label);letter-spacing:.15em;text-transform:uppercase;color:var(--color-secondary);margin-bottom:8px;font-size:14px;font-weight:700}.dark-about-header-title{font-family:var(--font-headline);letter-spacing:-.05em;text-transform:uppercase;font-size:48px;font-weight:900}@media (width>=768px){.dark-about-header-title{font-size:64px}}.dark-about-header-time{font-family:var(--font-label);color:var(--color-outline-variant);text-transform:uppercase;letter-spacing:.15em;font-size:10px;display:none}@media (width>=768px){.dark-about-header-time{display:block}}.dark-timeline{padding-left:44px;position:relative}.dark-timeline:before{content:"";background:linear-gradient(to bottom, var(--color-primary-container), transparent);width:2px;height:100%;position:absolute;top:0;left:11px}.dark-timeline-item{margin-bottom:48px;padding-left:48px;position:relative}.dark-timeline-item:last-child{margin-bottom:0}.dark-timeline-dot{background-color:var(--color-background);border:4px solid var(--color-primary-container);z-index:10;width:24px;height:24px;position:absolute;top:4px;left:0}.dark-timeline-item-secondary .dark-timeline-dot{border-color:var(--color-secondary)}.dark-timeline-card{background-color:var(--color-surface-container-high);transition:var(--transition-default);grid-template-columns:1fr;gap:16px;padding:32px;display:grid}@media (width>=768px){.dark-timeline-card{grid-template-columns:repeat(4,1fr);gap:16px}}.dark-timeline-card:hover{background-color:var(--color-surface-bright)}.dark-timeline-year{font-family:var(--font-headline);color:var(--color-primary-container);font-size:32px;font-style:italic;font-weight:900}.dark-timeline-item-secondary .dark-timeline-year{color:var(--color-secondary)}.dark-timeline-year-label{font-family:var(--font-label);color:var(--color-outline-variant);text-transform:uppercase;letter-spacing:.15em;margin-top:4px;font-size:10px}@media (width>=768px){.dark-timeline-year{grid-column:span 1}.dark-timeline-content{grid-column:span 3}}.dark-timeline-title{font-family:var(--font-headline);text-transform:uppercase;letter-spacing:-.05em;color:var(--color-on-surface);margin-bottom:8px;font-size:24px;font-weight:700}.dark-timeline-description{color:var(--color-on-surface-variant);max-width:640px;line-height:1.6}.dark-skills-section{background-color:var(--color-background);padding:96px 24px}.dark-skills-container{max-width:1280px;margin:0 auto}.dark-skills-title-wrapper{text-align:center;margin-bottom:64px}.dark-skills-title{font-family:var(--font-headline);letter-spacing:-.05em;text-transform:uppercase;border-bottom:8px solid var(--color-primary-container);padding-bottom:8px;font-size:48px;font-weight:900;display:inline-block}.dark-skills-grid{grid-template-columns:1fr;gap:40px;display:grid}@media (width>=768px){.dark-skills-grid{grid-template-columns:repeat(3,1fr);gap:40px}}.dark-skills-category{flex-direction:column;gap:24px;display:flex}.dark-skills-category-header{align-items:center;gap:12px;display:flex}.dark-skills-category-title{font-family:var(--font-headline);text-transform:uppercase;letter-spacing:.15em;font-size:20px;font-weight:700}.dark-skills-tags{flex-wrap:wrap;gap:8px;display:flex}.dark-skills-tag{background-color:var(--color-surface-container-high);color:var(--color-on-surface);font-family:var(--font-label);border-left:4px solid var(--color-primary-container);padding:8px 16px;font-size:10px;font-weight:700}.dark-skills-tag-secondary{border-left-color:var(--color-secondary)}.dark-skills-tag-glow{background-color:var(--color-primary-container);color:var(--color-on-primary);font-family:var(--font-label);padding:8px 16px;font-size:10px;font-weight:900;box-shadow:0 0 15px #ccff004d}.dark-skills-category-special{background-color:#1925404d;border:1px solid #cf03;padding:32px;position:relative;overflow:hidden}.dark-skills-category-special:before{content:"";filter:blur(48px);background-color:#ccff001a;width:96px;height:96px;position:absolute;top:0;right:0}.dark-projects-section{background-color:var(--color-background);padding:96px 24px}.dark-projects-container{max-width:1280px;margin:0 auto}.dark-projects-header{flex-direction:column;gap:24px;margin-bottom:64px;display:flex}@media (width>=768px){.dark-projects-header{flex-direction:row;justify-content:space-between;align-items:flex-start;gap:24px}}.dark-projects-title{font-family:var(--font-headline);letter-spacing:-.05em;text-transform:uppercase;color:#cf03;font-size:72px;font-weight:900}.dark-projects-subtitle{font-family:var(--font-label);color:var(--color-on-surface-variant);text-transform:uppercase;letter-spacing:.15em;text-align:right;max-width:320px;font-size:10px;display:none}@media (width>=768px){.dark-projects-subtitle{display:block}}.dark-projects-grid{grid-template-columns:1fr;gap:32px;display:grid}@media (width>=768px){.dark-projects-grid{grid-template-columns:repeat(2,1fr)}}@media (width>=1024px){.dark-projects-grid{grid-template-columns:repeat(3,1fr)}}.dark-project-card{background-color:var(--color-surface-container-high);border-top:2px solid var(--color-primary-container);flex-direction:column;display:flex}.dark-project-card-secondary{border-top-color:var(--color-secondary)}.dark-project-card-tertiary{border-top-color:var(--color-tertiary)}.dark-project-image-wrapper{aspect-ratio:16/9;position:relative;overflow:hidden}.dark-project-image{object-fit:cover;opacity:.6;width:100%;height:100%;transition:var(--transition-default)}.dark-project-card:hover .dark-project-image{opacity:1;transform:scale(1.1)}.dark-project-image-overlay{background:linear-gradient(to top, var(--color-surface-container-high), transparent);position:absolute;inset:0}.dark-project-content{flex-direction:column;gap:16px;padding:32px;display:flex}.dark-project-header{justify-content:space-between;align-items:center;display:flex}.dark-project-category{font-family:var(--font-label);letter-spacing:.15em;text-transform:uppercase;color:var(--color-primary-container);font-size:10px}.dark-project-card-secondary .dark-project-category{color:var(--color-secondary)}.dark-project-card-tertiary .dark-project-category{color:var(--color-tertiary)}.dark-project-title{font-family:var(--font-headline);text-transform:uppercase;letter-spacing:-.05em;font-size:24px;font-weight:900}.dark-project-description{color:var(--color-on-surface-variant);font-size:14px;line-height:1.6}.dark-project-tags{gap:8px;padding-top:8px;display:flex}.dark-project-tag{color:var(--color-on-surface);border:1px solid #40485d4d;padding:4px 8px;font-size:10px;font-weight:700}.dark-workflow-section{background-color:var(--color-surface-container-low);padding:96px 24px;position:relative;overflow:hidden}.dark-workflow-container{z-index:10;max-width:1280px;margin:0 auto;position:relative}.dark-workflow-header{text-align:center;margin-bottom:80px}.dark-workflow-label{font-family:var(--font-label);letter-spacing:.15em;text-transform:uppercase;color:var(--color-primary-container);margin-bottom:8px;font-size:14px;font-weight:700}.dark-workflow-title{font-family:var(--font-headline);letter-spacing:-.05em;text-transform:uppercase;font-size:48px;font-weight:900}@media (width>=768px){.dark-workflow-title{font-size:64px}}.dark-workflow-pipeline{flex-direction:column;justify-content:space-between;align-items:center;gap:32px;display:flex;position:relative}@media (width>=768px){.dark-workflow-pipeline{flex-direction:row}}.dark-workflow-connector{background:linear-gradient(90deg,#0000,#cf03,#0000);width:100%;height:1px;display:none;position:absolute;top:50%;left:0;transform:translateY(-50%)}@media (width>=768px){.dark-workflow-connector{display:block}}.dark-workflow-node{background-color:var(--color-surface-container-high);border-left:4px solid var(--color-outline-variant);text-align:center;z-index:20;width:100%;padding:32px;position:relative}@media (width>=768px){.dark-workflow-node{width:256px}}.dark-workflow-node-core{background-color:var(--color-surface-container-highest);border:4px solid var(--color-primary-container);text-align:center;z-index:20;width:100%;padding:40px;position:relative}@media (width>=768px){.dark-workflow-node-core{width:320px}}.dark-workflow-node-core .dark-spray-glow{filter:drop-shadow(0 0 15px #cf06)}.dark-workflow-node-badge{background-color:var(--color-primary-container);color:var(--color-on-primary-container);text-transform:uppercase;padding:4px 12px;font-size:10px;font-weight:900;position:absolute;top:-16px;right:-16px}.dark-workflow-node-icon{color:var(--color-on-surface-variant);margin-bottom:16px}.dark-workflow-node-core .dark-workflow-node-icon{color:var(--color-primary-container);font-size:48px}.dark-workflow-node-title{font-family:var(--font-headline);text-transform:uppercase;letter-spacing:-.05em;font-size:18px;font-weight:900}.dark-workflow-node-core .dark-workflow-node-title{color:var(--color-primary-container);font-size:24px}.dark-workflow-node-label{font-family:var(--font-label);color:var(--color-outline-variant);text-transform:uppercase;letter-spacing:.15em;margin-top:8px;font-size:10px}.dark-workflow-node-core .dark-workflow-node-label{color:var(--color-primary-container);letter-spacing:.2em}.dark-workflow-arrow{color:var(--color-primary-container);transform:rotate(90deg)}@media (width>=768px){.dark-workflow-arrow{transform:rotate(0)}}.dark-cta-section{background-color:var(--color-surface-container-low);padding:96px 24px}.dark-cta-container{text-align:center;max-width:1024px;margin:0 auto}.dark-cta-border{background:linear-gradient(to right, var(--color-primary-container), var(--color-secondary), var(--color-tertiary));padding:2px;display:inline-block}.dark-cta-inner{background-color:var(--color-surface-container-low);padding:48px}@media (width>=768px){.dark-cta-inner{padding:64px 48px}}.dark-cta-title{font-family:var(--font-headline);text-transform:uppercase;letter-spacing:-.05em;margin-bottom:24px;font-size:36px;font-weight:900}@media (width>=768px){.dark-cta-title{font-size:48px}}.dark-cta-description{color:var(--color-on-surface-variant);max-width:512px;margin:0 auto 40px;line-height:1.6}.dark-cta-button{background-color:var(--color-primary);color:var(--color-on-primary);font-family:var(--font-headline);letter-spacing:-.05em;text-transform:uppercase;transition:var(--transition-default);padding:20px 48px;font-size:14px;font-weight:900;text-decoration:none;display:inline-block}.dark-cta-button:hover{background-color:var(--color-primary-container)}.dark-footer{background-color:var(--color-surface-container-low);border-top:1px solid #40485d4d;padding:48px 40px}.dark-footer-container{flex-direction:column;gap:24px;width:100%;max-width:1280px;margin:0 auto;display:flex}@media (width>=768px){.dark-footer-container{flex-direction:row;justify-content:space-between;align-items:center;gap:40px}}.dark-footer-brand{font-family:var(--font-headline);color:var(--color-primary-fixed);text-transform:uppercase;font-size:18px;font-style:italic;font-weight:900}.dark-footer-copyright{font-family:var(--font-label);letter-spacing:.2em;text-transform:uppercase;color:var(--color-outline-variant);font-size:10px}.dark-footer-links{gap:32px;display:flex}.dark-footer-links a{font-family:var(--font-label);letter-spacing:.2em;text-transform:uppercase;color:var(--color-outline-variant);font-size:10px;text-decoration:none;transition:color .2s}.dark-footer-links a:hover{color:var(--color-secondary)}.login-wrapper{position:relative}.login-form{flex-direction:column;gap:1.5rem;display:flex}.login-form-group{flex-direction:column;gap:.5rem;display:flex}.login-input{color:#000;background:#fff;border:1px solid #e3e3e3;border-radius:8px;padding:14px 16px;font-family:inherit;font-size:16px;transition:border-color .2s,box-shadow .2s}.login-input:-webkit-autofill{-webkit-text-fill-color:#000!important;box-shadow:inset 0 0 0 30px #fff!important}.login-input:-webkit-autofill:hover{-webkit-text-fill-color:#000!important;box-shadow:inset 0 0 0 30px #fff!important}.login-input:-webkit-autofill:focus{-webkit-text-fill-color:#000!important;box-shadow:inset 0 0 0 30px #fff!important}.login-input:-webkit-autofill:active{-webkit-text-fill-color:#000!important;box-shadow:inset 0 0 0 30px #fff!important}.login-input::placeholder{color:#b0b0b0}.login-input:focus{border-color:#87329f;outline:none;box-shadow:0 0 0 3px #87329f1a}.login-input:disabled{color:#9e9e9e;cursor:not-allowed;background-color:#f5f5f5;border-color:#e0e0e0}.login-submit-btn{color:#fff;letter-spacing:.5px;cursor:pointer;background:#000;border:none;border-radius:9999px;margin-top:1rem;padding:14px 32px;font-family:inherit;font-size:16px;font-weight:600;transition:background .2s,transform .2s}.login-submit-btn:hover:not(:disabled){background:#87329f}.login-submit-btn:focus-visible{outline-offset:3px;outline:2px solid #87329f}.login-submit-btn:active:not(:disabled){transform:scale(.98)}.login-submit-btn:disabled{color:#707070;cursor:not-allowed;background-color:#ccc}.login-error{color:#d32f2f;text-align:center;margin-top:1rem;font-size:14px;line-height:1.5}.login-error-overlay{-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:10;background:#fffffff2;border-radius:8px;flex-direction:column;justify-content:center;align-items:center;gap:1rem;animation:.3s error-overlay-fade-in;display:flex;position:absolute;inset:0}@keyframes error-overlay-fade-in{0%{opacity:0}to{opacity:1}}.login-error-icon{color:#d32f2f;justify-content:center;align-items:center;width:80px;height:80px;display:flex}.login-error-icon svg{width:100%;height:100%}.login-error-message{color:#424242;text-align:center;max-width:250px;margin:0;padding:0 1rem;font-size:14px;font-weight:500;line-height:1.6}.login-wrapper--error{opacity:.5;pointer-events:none}@media (width<=640px){.login-input{font-size:16px}.login-submit-btn{font-size:14px}.login-error-icon{width:64px;height:64px}.login-error-message{max-width:220px;font-size:13px}}
