:root{--bg-primary:#0C0C0E;--bg-elevated:#161618;--bg-subtle:#1E1E21;--bg-glass:rgba(22,22,24,0.72);--text-primary:#F0EDE8;--text-secondary:#9A9490;--text-tertiary:#6B6560;--accent:#D4A574;--accent-hover:#E8C09A;--accent-subtle:rgba(212,165,116,0.12);--accent-glow:rgba(212,165,116,0.25);--border:rgba(255,255,255,0.06);--border-accent:rgba(212,165,116,0.2);--success:#7BC67E;--error:#E57373;--font-heading:"Outfit",system-ui,-apple-system,sans-serif;--font-body:"Inter",system-ui,-apple-system,sans-serif;--font-mono:"JetBrains Mono","Fira Code",monospace;--text-display:clamp(3rem,6vw,5.5rem);--text-h1:clamp(2rem,4vw,3.5rem);--text-h2:clamp(1.5rem,2.5vw,2rem);--text-h3:clamp(1.125rem,1.5vw,1.375rem);--text-body:1.0625rem;--text-small:0.875rem;--text-xs:0.75rem;--text-mono:0.8125rem;--leading-tight:1.1;--leading-snug:1.3;--leading-normal:1.65;--tracking-tight:-0.03em;--tracking-normal:-0.01em;--tracking-wide:0.08em;--space-xs:0.25rem;--space-sm:0.5rem;--space-md:1rem;--space-lg:1.5rem;--space-xl:2rem;--space-2xl:3rem;--space-3xl:4rem;--space-4xl:6rem;--space-section:clamp(5rem,12vh,8rem);--max-width:1280px;--nav-height:4.5rem;--radius-sm:0.375rem;--radius-md:0.625rem;--radius-lg:1rem;--radius-xl:1.5rem;--radius-full:9999px;--shadow-sm:0 1px 2px rgba(0,0,0,0.3);--shadow-md:0 4px 12px rgba(0,0,0,0.4);--shadow-lg:0 8px 32px rgba(0,0,0,0.5);--shadow-glow:0 0 40px var(--accent-glow);--ease-out:cubic-bezier(0.16,1,0.3,1);--ease-spring:cubic-bezier(0.34,1.56,0.64,1);--duration-fast:150ms;--duration-normal:300ms;--duration-slow:600ms;--z-base:1;--z-nav:100;--z-overlay:200;--z-modal:300;--nav-panel-bg:rgba(10,14,20,0.78);--nav-panel-bg-scrolled:rgba(8,12,18,0.9);--nav-panel-shadow:0 12px 30px rgba(0,0,0,0.35),inset 0 0 0 1px rgba(255,255,255,0.02);--nav-divider:rgba(212,165,116,0.2);--nav-icon-bg:rgba(255,255,255,0.03);--nav-link-color:rgba(240,237,232,0.9)}:root[data-theme=light]{--bg-primary:#f6f2ea;--bg-elevated:#ffffff;--bg-subtle:#ece5d9;--bg-glass:rgba(255,255,255,0.74);--text-primary:#1f1b16;--text-secondary:#5e564d;--text-tertiary:#83786c;--accent:#b87b3d;--accent-hover:#9f692f;--accent-subtle:rgba(184,123,61,0.12);--accent-glow:rgba(184,123,61,0.22);--border:rgba(39,31,22,0.12);--border-accent:rgba(184,123,61,0.35);--shadow-sm:0 1px 2px rgba(64,46,24,0.08);--shadow-md:0 8px 24px rgba(64,46,24,0.12);--shadow-lg:0 20px 36px rgba(64,46,24,0.16);--nav-panel-bg:rgba(255,251,243,0.8);--nav-panel-bg-scrolled:rgba(255,248,238,0.92);--nav-panel-shadow:0 12px 24px rgba(64,46,24,0.12),inset 0 0 0 1px rgba(255,255,255,0.85);--nav-divider:rgba(184,123,61,0.28);--nav-icon-bg:rgba(184,123,61,0.1);--nav-link-color:rgba(31,27,22,0.88)}*,:after,:before{margin:0;padding:0;box-sizing:border-box}html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility}body{font-family:var(--font-body);font-size:var(--text-body);line-height:var(--leading-normal);color:var(--text-primary);background-color:var(--bg-primary);letter-spacing:var(--tracking-normal);overflow-x:hidden}img,svg,video{display:block;max-width:100%;height:auto}a{color:var(--accent);text-decoration:none;transition:color var(--duration-fast) var(--ease-out)}a:hover{color:var(--accent-hover)}button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}ol,ul{list-style:none}h1,h2,h3,h4,h5,h6{font-family:var(--font-heading);font-weight:600;line-height:var(--leading-tight);letter-spacing:var(--tracking-tight);color:var(--text-primary)}:focus-visible{outline:2px solid var(--accent);outline-offset:3px;border-radius:var(--radius-sm)}.skip-link{position:absolute;top:-100%;left:var(--space-md);padding:var(--space-sm) var(--space-md);background:var(--accent);color:var(--bg-primary);font-weight:600;font-size:var(--text-small);border-radius:var(--radius-sm);z-index:var(--z-modal);transition:top var(--duration-fast) var(--ease-out)}.skip-link:focus{top:var(--space-md)}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:var(--bg-primary)}::-webkit-scrollbar-thumb{background:var(--bg-subtle);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--text-tertiary)}::selection{background:var(--accent-subtle);color:var(--text-primary)}@media (prefers-reduced-motion:reduce){*,:after,:before{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}}.site-background{position:fixed;inset:0;z-index:0;pointer-events:none}.site-shell{position:relative;z-index:var(--z-base)}.container{width:100%;max-width:var(--max-width);margin:0 auto;padding:0 var(--space-xl)}@media (max-width:640px){.container{padding:0 var(--space-md)}}.section{padding:var(--space-section) 0;position:relative}.section--flush{padding:0}.grid{display:grid;grid-gap:var(--space-xl);gap:var(--space-xl)}.grid--2{grid-template-columns:repeat(2,1fr)}.grid--3{grid-template-columns:repeat(3,1fr)}.grid--4{grid-template-columns:repeat(4,1fr)}@media (max-width:1024px){.grid--3,.grid--4{grid-template-columns:repeat(2,1fr)}}@media (max-width:640px){.grid--2,.grid--3,.grid--4{grid-template-columns:1fr}}.divider{width:100%;height:1px;background:var(--border);border:none}.about__grid{display:grid;grid-template-columns:1fr 1.2fr;grid-gap:var(--space-3xl);gap:var(--space-3xl);align-items:center}.about__image-wrap{position:relative;border-radius:var(--radius-lg);overflow:hidden;aspect-ratio:4/5;background:var(--bg-elevated)}.about__image{width:100%;height:100%;object-fit:cover;object-position:center;display:block}.about__image-placeholder{width:100%;height:100%;background:linear-gradient(135deg,var(--bg-subtle) 0,var(--bg-elevated) 50%,var(--accent-subtle) 100%);display:flex;align-items:center;justify-content:center}.about__image-placeholder span{font-family:var(--font-mono);font-size:var(--text-small);color:var(--text-tertiary)}.about__image-accent{position:absolute;top:-1px;right:-1px;bottom:-1px;width:4px;background:linear-gradient(to bottom,var(--accent),transparent);border-radius:0 var(--radius-lg) var(--radius-lg) 0}.about__text{display:flex;flex-direction:column;gap:var(--space-lg)}.about__paragraph{color:var(--text-secondary);line-height:var(--leading-normal)}.about__paragraph strong{color:var(--text-primary);font-weight:500}.about__stats{display:grid;grid-template-columns:repeat(3,1fr);grid-gap:var(--space-lg);gap:var(--space-lg);padding-top:var(--space-xl);border-top:1px solid var(--border);margin-top:var(--space-md)}.about__stat-value{font-family:var(--font-heading);font-size:var(--text-h2);font-weight:700;color:var(--accent);margin-bottom:var(--space-xs)}.about__stat-label{font-size:var(--text-small);color:var(--text-tertiary)}.about__contributions{margin-top:var(--space-2xl);border:1px solid #30363d;border-radius:6px;background:#0d1117;padding:14px 16px 12px;overflow:hidden}.github-contrib__status{color:#8b949e;font-size:12px;line-height:1.5}.github-contrib__status--error{color:#f85149}.github-contrib__chart{overflow-x:auto;padding-bottom:2px}.github-contrib__canvas{min-width:760px;width:-moz-fit-content;width:fit-content}.github-contrib__months{position:relative;height:16px;margin-left:34px;margin-bottom:4px}.github-contrib__month{position:absolute;top:0;transform:translateX(-1px);font-size:12px;color:#c9d1d9;font-family:var(--font-body);line-height:1}.github-contrib__heatmap-row{display:flex;gap:8px}.github-contrib__day-labels{width:28px;display:grid;grid-template-rows:repeat(7,11px);grid-gap:3px;gap:3px;font-size:12px;color:#c9d1d9;font-family:var(--font-body);font-weight:600;text-align:right;line-height:1}.github-contrib__day-labels span{align-self:center}.github-contrib__grid{display:grid;grid-template-columns:repeat(var(--weeks),11px);grid-template-rows:repeat(7,11px);grid-gap:3px;gap:3px}.github-contrib__cell{width:11px;height:11px;border-radius:2px;border:1px solid #f0f6fc;background:transparent;box-sizing:border-box}.github-contrib__cell--level-0{background:transparent;border-color:#f0f6fc}.github-contrib__cell--level-1{background:#0e4429;border-color:#0e4429}.github-contrib__cell--level-2{background:#006d32;border-color:#006d32}.github-contrib__cell--level-3{background:#26a641;border-color:#26a641}.github-contrib__cell--level-4{background:#39d353;border-color:#39d353}.github-contrib__cell--outside{visibility:hidden}.github-contrib__footer{margin-top:10px;display:flex;align-items:center;justify-content:space-between;gap:12px}.github-contrib__help-link{font-size:12px;color:#8b949e;text-decoration:none;white-space:nowrap;margin-left:6px}.github-contrib__help-link:hover{color:#c9d1d9;text-decoration:underline}.github-contrib__fallback-wrap{overflow-x:auto;padding-bottom:2px}.github-contrib__fallback-image{display:block;min-width:720px;width:100%;height:auto;border:0}.github-contrib__legend{display:flex;align-items:center;gap:6px;color:#8b949e;font-size:12px;white-space:nowrap}.github-contrib__legend-scale{display:flex;gap:3px}:root[data-theme=light] .about__contributions{border-color:#d0d7de;background:#ffffff}:root[data-theme=light] .github-contrib__day-labels,:root[data-theme=light] .github-contrib__month{color:#1f2328}:root[data-theme=light] .github-contrib__help-link,:root[data-theme=light] .github-contrib__legend,:root[data-theme=light] .github-contrib__status{color:#57606a}:root[data-theme=light] .github-contrib__help-link:hover{color:#24292f}:root[data-theme=light] .github-contrib__fallback-image{filter:saturate(.95)}:root[data-theme=light] .github-contrib__cell,:root[data-theme=light] .github-contrib__cell--level-0{border-color:#d0d7de}@media (max-width:768px){.about__grid{grid-template-columns:1fr}.about__image-wrap{max-width:360px;margin:0 auto}.about__stats{grid-template-columns:repeat(3,1fr);text-align:center}.about__contributions{padding:12px}.github-contrib__canvas{min-width:640px}.github-contrib__footer{flex-direction:column;align-items:flex-start}}.contact__inner{display:grid;grid-template-columns:1fr 1fr;grid-gap:var(--space-3xl);gap:var(--space-3xl);align-items:start}.contact__info{display:flex;flex-direction:column;gap:var(--space-xl)}.contact__description{color:var(--text-secondary);line-height:var(--leading-normal);max-width:420px}.contact__links{display:flex;flex-direction:column;gap:var(--space-md)}.contact__link{display:inline-flex;align-items:center;gap:var(--space-sm);color:var(--text-secondary);font-size:var(--text-small);transition:color var(--duration-fast) var(--ease-out)}.contact__link:hover{color:var(--accent)}.contact__link-icon{width:20px;height:20px;color:var(--accent)}.contact__form{gap:var(--space-lg)}.contact__field,.contact__form{display:flex;flex-direction:column}.contact__field{gap:var(--space-sm)}.contact__label{font-family:var(--font-mono);font-size:var(--text-xs);color:var(--text-tertiary);letter-spacing:var(--tracking-wide);text-transform:uppercase}.contact__input,.contact__textarea{width:100%;padding:var(--space-md);background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-primary);font-family:var(--font-body);font-size:var(--text-small);transition:border-color var(--duration-fast) var(--ease-out),box-shadow var(--duration-fast) var(--ease-out)}.contact__input:focus,.contact__textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-subtle)}.contact__input::placeholder,.contact__textarea::placeholder{color:var(--text-tertiary)}.contact__textarea{min-height:140px;resize:vertical}.contact__submit{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-sm);padding:.875rem 2rem;background:var(--accent);color:var(--bg-primary);font-family:var(--font-body);font-size:var(--text-small);font-weight:600;letter-spacing:var(--tracking-wide);text-transform:uppercase;border-radius:var(--radius-full);border:none;cursor:pointer;transition:background var(--duration-fast) var(--ease-out),transform var(--duration-fast) var(--ease-out),box-shadow var(--duration-fast) var(--ease-out);align-self:flex-start}.contact__submit:hover{background:var(--accent-hover);transform:translateY(-2px);box-shadow:var(--shadow-glow)}.contact__submit:disabled{opacity:.7;cursor:not-allowed;transform:none;box-shadow:none}.contact__status{margin:0;font-size:var(--text-small);line-height:var(--leading-normal)}.contact__status--success{color:var(--text-secondary)}.contact__status--error{color:#f87171}@media (max-width:768px){.contact__inner{grid-template-columns:1fr}}.experience__timeline{display:flex;flex-direction:column;gap:var(--space-xl);position:relative;padding-left:var(--space-2xl)}.experience__timeline:before{content:"";position:absolute;left:7px;top:8px;bottom:8px;width:2px;background:linear-gradient(to bottom,var(--accent),var(--border))}.experience__item{position:relative;background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-xl);transition:border-color var(--duration-normal) var(--ease-out)}.experience__item:hover{border-color:var(--border-accent)}.experience__item:before{content:"";position:absolute;left:calc(-1 * var(--space-2xl) + 3px);top:var(--space-xl);width:10px;height:10px;background:var(--accent);border-radius:var(--radius-full);border:2px solid var(--bg-primary)}.experience__header{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--space-md);margin-bottom:var(--space-sm);flex-wrap:wrap}.experience__role{font-size:var(--text-h3);font-weight:600}.experience__badge{padding:.2rem .625rem;font-family:var(--font-mono);font-size:var(--text-xs);color:var(--accent);background:var(--accent-subtle);border:1px solid var(--border-accent);border-radius:var(--radius-full);letter-spacing:var(--tracking-wide);text-transform:uppercase;white-space:nowrap}.experience__company{font-size:var(--text-small);color:var(--accent);margin:0}.experience__company-row{display:flex;align-items:center;gap:var(--space-sm);margin-bottom:var(--space-xs)}.experience__company-logo{width:42px;height:42px;object-fit:contain;border-radius:var(--radius-sm);background:#ffffff;border:1px solid var(--border);flex-shrink:0}.experience__meta{display:flex;align-items:center;gap:var(--space-md);font-size:var(--text-xs);color:var(--text-tertiary);font-family:var(--font-mono);letter-spacing:var(--tracking-wide);margin-bottom:var(--space-md)}.experience__description{font-size:var(--text-small);color:var(--text-secondary);line-height:var(--leading-normal);margin-bottom:var(--space-md)}.experience__tags{display:flex;flex-wrap:wrap;gap:var(--space-xs)}.experience__tag{padding:.2rem .5rem;background:var(--bg-subtle);border-radius:var(--radius-full);font-family:var(--font-mono);font-size:var(--text-xs);color:var(--text-tertiary)}.education__grid{display:grid;grid-template-columns:repeat(2,1fr);grid-gap:var(--space-xl);gap:var(--space-xl);margin-top:var(--space-3xl)}.education__card{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-xl);transition:border-color var(--duration-normal) var(--ease-out)}.education__card:hover{border-color:var(--border-accent)}.education__degree{font-size:var(--text-h3);font-weight:600;margin-bottom:var(--space-xs)}.education__school{font-size:var(--text-small);color:var(--accent);margin-bottom:var(--space-xs)}.education__school-row{display:flex;align-items:center;gap:var(--space-sm);margin-bottom:var(--space-xs)}.education__school-logo{width:36px;height:36px;object-fit:contain;border-radius:var(--radius-sm);background:#ffffff;border:1px solid var(--border);flex-shrink:0}.education__school-row .education__school{margin-bottom:0}.education__dates{font-size:var(--text-xs);font-family:var(--font-mono);color:var(--text-tertiary);letter-spacing:var(--tracking-wide)}@media (max-width:768px){.education__grid{grid-template-columns:1fr}}.footer{padding:var(--space-3xl) 0;border-top:1px solid var(--border)}.footer__inner{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:var(--space-lg)}.footer__copy{font-size:var(--text-small);color:var(--text-tertiary)}.footer__copy-accent{color:var(--accent)}.footer__socials{display:flex;align-items:center;gap:var(--space-md)}.footer__social-link{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:var(--radius-full);color:var(--text-tertiary);background:var(--bg-subtle);transition:color var(--duration-fast) var(--ease-out),background var(--duration-fast) var(--ease-out),transform var(--duration-fast) var(--ease-out)}.footer__social-link:hover{color:var(--accent);background:var(--accent-subtle);transform:translateY(-2px)}@media (max-width:640px){.footer__inner{flex-direction:column;text-align:center}}.hero{min-height:100vh;display:flex;overflow:hidden;padding-top:var(--nav-height);isolation:isolate}.hero,.hero__inner{align-items:center;position:relative}.hero__inner{display:grid;grid-template-columns:1fr;grid-gap:var(--space-3xl);gap:var(--space-3xl);width:100%;z-index:var(--z-base)}.hero__content{position:relative;z-index:calc(var(--z-base) + 1);max-width:720px}.hero__badge{display:inline-flex;align-items:center;gap:var(--space-sm);padding:var(--space-xs) var(--space-md);background:var(--accent-subtle);border:1px solid var(--border-accent);font-family:var(--font-mono);font-size:var(--text-xs);color:var(--accent);letter-spacing:var(--tracking-wide);text-transform:uppercase;margin-bottom:var(--space-xl)}.hero__badge,.hero__badge-dot{border-radius:var(--radius-full)}.hero__badge-dot{width:6px;height:6px;background:var(--accent);animation:pulse-dot 2s ease-in-out infinite}.hero__title{font-size:var(--text-display);font-weight:700;line-height:1.05;letter-spacing:-.04em;margin-bottom:var(--space-lg)}.hero__title-accent{color:var(--accent);position:relative;display:inline-block}.hero__title-accent:after{content:"";position:absolute;bottom:.05em;left:0;right:0;height:.08em;background:var(--accent);opacity:.3;border-radius:var(--radius-full)}.hero__subtitle{font-size:clamp(1rem,1.5vw,1.25rem);color:var(--text-secondary);line-height:var(--leading-normal);max-width:480px;margin-bottom:var(--space-2xl)}.hero__actions{display:flex;align-items:center;gap:var(--space-md);flex-wrap:wrap}.hero__btn{display:inline-flex;align-items:center;gap:var(--space-sm);padding:.875rem 2rem;font-family:var(--font-body);font-size:var(--text-small);font-weight:600;letter-spacing:var(--tracking-wide);text-transform:uppercase;border-radius:var(--radius-full);transition:all var(--duration-normal) var(--ease-out);text-decoration:none}.hero__btn--primary{background:var(--accent);color:var(--bg-primary)}.hero__btn--primary:hover{background:var(--accent-hover);color:var(--bg-primary);transform:translateY(-2px);box-shadow:var(--shadow-glow)}.hero__btn--secondary{background:transparent;color:var(--text-primary);border:1px solid var(--border)}.hero__btn--secondary:hover{border-color:var(--accent);color:var(--accent);transform:translateY(-2px)}.hero__btn-icon{transition:transform var(--duration-fast) var(--ease-out)}.hero__btn:hover .hero__btn-icon{transform:translateX(3px)}@keyframes pulse-dot{0%,to{transform:scale(1);opacity:.7}50%{transform:scale(1.25);opacity:1}}@media (max-width:1024px){.hero__inner{text-align:center}.hero__subtitle{margin-left:auto;margin-right:auto}.hero__actions{justify-content:center}}.navbar{position:fixed;top:0;left:0;right:0;z-index:var(--z-nav);pointer-events:none}.navbar__inner{height:var(--nav-height);display:flex;align-items:center;justify-content:center}.navbar__panel{pointer-events:auto;display:inline-flex;align-items:center;gap:var(--space-sm);padding:.45rem .7rem;border-radius:var(--radius-full);background:var(--nav-panel-bg);border:1px solid rgba(212,165,116,.18);box-shadow:var(--nav-panel-shadow);backdrop-filter:blur(14px) saturate(1.2);-webkit-backdrop-filter:blur(14px) saturate(1.2)}.navbar.scrolled .navbar__panel{background:var(--nav-panel-bg-scrolled);border-color:rgba(212,165,116,.22)}.navbar__divider{width:1px;height:22px;background:var(--nav-divider)}.navbar__home,.navbar__theme{width:34px;height:34px;display:inline-flex;align-items:center;justify-content:center;border-radius:var(--radius-full);border:1px solid rgba(212,165,116,.22);background:var(--nav-icon-bg);color:var(--text-primary);text-decoration:none;transition:border-color var(--duration-fast) var(--ease-out),color var(--duration-fast) var(--ease-out),background var(--duration-fast) var(--ease-out),transform var(--duration-fast) var(--ease-out)}.navbar__theme{cursor:pointer;position:relative;overflow:hidden}.navbar__theme-icon{position:absolute;transition:opacity var(--duration-fast) var(--ease-out),transform var(--duration-fast) var(--ease-out)}:root[data-theme=dark] .navbar__theme-icon--sun{opacity:1;transform:scale(1)}:root[data-theme=dark] .navbar__theme-icon--moon,:root[data-theme=light] .navbar__theme-icon--sun{opacity:0;transform:scale(.75)}:root[data-theme=light] .navbar__theme-icon--moon{opacity:1;transform:scale(1)}.navbar__home:hover,.navbar__theme:hover{border-color:rgba(212,165,116,.45);color:var(--accent-hover);background:rgba(212,165,116,.08);transform:translateY(-1px)}.navbar__links{display:flex;align-items:center;gap:.2rem}.navbar__link{display:inline-flex;align-items:center;gap:.48rem;padding:.48rem .72rem;border-radius:var(--radius-full);color:var(--nav-link-color);text-decoration:none;font-size:.94rem;font-weight:600;transition:color var(--duration-fast) var(--ease-out),background var(--duration-fast) var(--ease-out)}.navbar__link span{line-height:1}.navbar__link:hover{color:var(--accent-hover);background:rgba(212,165,116,.08)}.navbar__home.is-active,.navbar__link.is-active{color:var(--accent-hover);border-color:rgba(212,165,116,.45);background:rgba(212,165,116,.1)}@media (max-width:980px){.navbar__panel{width:min(100%,760px);justify-content:space-between;padding:.4rem .55rem}.navbar__link{font-size:.87rem;gap:.38rem;padding:.44rem .6rem}}@media (max-width:720px){.navbar__link span{display:none}.navbar__link{padding:.5rem;min-width:32px;justify-content:center}}.projects__grid{display:grid;grid-template-columns:repeat(2,1fr);grid-gap:var(--space-xl);gap:var(--space-xl)}.project-card{position:relative;background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;transition:transform var(--duration-normal) var(--ease-out),border-color var(--duration-normal) var(--ease-out),box-shadow var(--duration-normal) var(--ease-out)}.project-card:hover{transform:translateY(-4px);border-color:var(--border-accent);box-shadow:var(--shadow-lg),0 0 60px rgba(212,165,116,.06)}.project-card__image{width:100%;aspect-ratio:16/10;overflow:hidden;position:relative;background:var(--bg-subtle)}.project-card__image--banner{aspect-ratio:16/6}.project-card__image--showcase{aspect-ratio:16/7}.project-card__image-asset{width:100%;height:100%;object-fit:cover;object-position:center;display:block}.project-card__image-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-family:var(--font-mono);font-size:var(--text-xs);color:var(--text-tertiary);letter-spacing:var(--tracking-wide)}.project-card__image-placeholder--a{background:linear-gradient(135deg,#1a1520,#2a1f35 50%,#1e1828)}.project-card__image-placeholder--b{background:linear-gradient(135deg,#151a1d,#1a2830 50%,#182025)}.project-card__image-placeholder--c{background:linear-gradient(135deg,#1a1a15,#28251a 50%,#201e18)}.project-card__image-placeholder--d{background:linear-gradient(135deg,#151a15,#1a281a 50%,#18201a)}.project-card__overlay{position:absolute;inset:0;background:linear-gradient(0deg,rgba(12,12,14,.8) 0,transparent 50%);opacity:0;transition:opacity var(--duration-normal) var(--ease-out);display:flex;align-items:flex-end;justify-content:flex-end;padding:var(--space-md)}.project-card:hover .project-card__overlay{opacity:1}.project-card__view-btn{display:inline-flex;align-items:center;gap:var(--space-xs);padding:var(--space-sm) var(--space-md);background:var(--accent);color:var(--bg-primary);font-size:var(--text-xs);font-weight:600;letter-spacing:var(--tracking-wide);text-transform:uppercase;border-radius:var(--radius-full);transform:translateY(8px);transition:transform var(--duration-normal) var(--ease-out)}.project-card:hover .project-card__view-btn{transform:translateY(0)}.project-card__body{padding:var(--space-lg)}.project-card__title{font-size:var(--text-h3);margin-bottom:var(--space-sm)}.project-card__desc{font-size:var(--text-small);color:var(--text-secondary);line-height:var(--leading-normal);margin-bottom:var(--space-md)}.project-card__tags{display:flex;flex-wrap:wrap;gap:var(--space-xs)}.project-card__tag{padding:.25rem .625rem;background:var(--bg-subtle);border-radius:var(--radius-full);font-family:var(--font-mono);font-size:var(--text-xs);color:var(--text-tertiary);letter-spacing:var(--tracking-wide)}@media (max-width:768px){.projects__grid{grid-template-columns:1fr}.project-card__image--banner,.project-card__image--showcase{aspect-ratio:16/8}}:root[data-theme=light] .project-card__image-placeholder{color:rgba(64,46,24,.7)}:root[data-theme=light] .project-card__image-placeholder--a{background:linear-gradient(135deg,#f5e8f2,#f8ecf5 50%,#f2e3ed)}:root[data-theme=light] .project-card__image-placeholder--b{background:linear-gradient(135deg,#e8f2f5,#edf6f8 50%,#e3eef2)}:root[data-theme=light] .project-card__image-placeholder--c{background:linear-gradient(135deg,#f5f1e8,#f8f4ec 50%,#f0eadf)}:root[data-theme=light] .project-card__image-placeholder--d{background:linear-gradient(135deg,#e8f3e8,#edf7ed 50%,#e1eddf)}:root[data-theme=light] .project-card__overlay{background:linear-gradient(0deg,rgba(31,27,22,.44) 0,transparent 50%)}.section-heading{margin-bottom:var(--space-3xl)}.section-heading--center{text-align:center}.section-heading__label{display:inline-flex;align-items:center;gap:var(--space-sm);font-family:var(--font-mono);font-size:var(--text-xs);color:var(--accent);letter-spacing:var(--tracking-wide);text-transform:uppercase;margin-bottom:var(--space-md)}.section-heading__label:before{content:"";display:inline-block;width:24px;height:1px;background:var(--accent)}.section-heading--center .section-heading__label:before{display:none}.section-heading__title{font-size:var(--text-h1);margin-bottom:var(--space-md)}.section-heading__subtitle{font-size:clamp(1rem,1.3vw,1.125rem);color:var(--text-secondary);max-width:580px;line-height:var(--leading-normal)}.section-heading--center .section-heading__subtitle{margin-left:auto;margin-right:auto}.skills__categories{display:grid;grid-template-columns:repeat(3,1fr);grid-gap:var(--space-xl);gap:var(--space-xl)}.skills__category{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-xl);transition:border-color var(--duration-normal) var(--ease-out)}.skills__category:hover{border-color:var(--border-accent)}.skills__category-icon{width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:var(--accent-subtle);border-radius:var(--radius-md);margin-bottom:var(--space-lg);color:var(--accent)}.skills__category-title{font-size:var(--text-h3);margin-bottom:var(--space-md)}.skills__list{flex-direction:column}.skills__item,.skills__list{display:flex;gap:var(--space-sm)}.skills__item{align-items:center;font-size:var(--text-small);color:var(--text-secondary);padding:var(--space-xs) 0}.skills__item-logo{color:var(--skill-color,var(--accent));flex-shrink:0}@media (max-width:768px){.skills__categories{grid-template-columns:1fr}}.system-canvas{position:relative;width:100%;aspect-ratio:16/10;min-height:320px;border-radius:var(--radius-xl);border:1px solid rgba(212,165,116,.14);background:linear-gradient(160deg,#0b0d12,#0a0d13 48%,#090b11);box-shadow:inset 0 0 0 1px rgba(255,255,255,.02),0 18px 40px rgba(0,0,0,.32);overflow:hidden}.system-canvas--hero-bg{width:100%;height:100%;min-height:100%;aspect-ratio:auto;border:none;border-radius:0;background:linear-gradient(160deg,#090c12,#090b11 48%,#080a10);box-shadow:none}.system-canvas:before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 76% 54%,rgba(212,165,116,.08),transparent 56%);pointer-events:none}.system-canvas--hero-bg:before{background:radial-gradient(circle at 84% 52%,rgba(212,165,116,.1),transparent 60%)}.system-canvas:after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(255,255,255,.015),transparent 34%);pointer-events:none}.system-canvas--hero-bg:after{background:linear-gradient(180deg,rgba(255,255,255,.01),transparent 32%)}.system-canvas__surface{display:block;width:100%;height:100%}:root[data-theme=light] .system-canvas{border-color:rgba(184,123,61,.22);background:linear-gradient(160deg,#f7f2e8,#f4ecdd 48%,#f0e8d9);box-shadow:inset 0 0 0 1px rgba(255,255,255,.75),0 18px 40px rgba(64,46,24,.12)}:root[data-theme=light] .system-canvas--hero-bg{background:linear-gradient(160deg,#f6f0e4,#f3ebdc 48%,#efe5d5)}:root[data-theme=light] .system-canvas:before{background:radial-gradient(circle at 76% 54%,rgba(184,123,61,.12),transparent 56%)}:root[data-theme=light] .system-canvas--hero-bg:before{background:radial-gradient(circle at 84% 52%,rgba(184,123,61,.14),transparent 60%)}:root[data-theme=light] .system-canvas:after{background:linear-gradient(180deg,rgba(255,255,255,.42),transparent 34%)}@media (max-width:1024px){.system-canvas{min-height:300px}.system-canvas--hero-bg{min-height:100%}}@media (max-width:640px){.system-canvas{aspect-ratio:5/4;min-height:260px}.system-canvas--hero-bg{aspect-ratio:auto;min-height:100%}}