@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800;900&family=JetBrains+Mono:wght@400;500;600&display=swap";:root{--bg-page:#eef2ff;--bg-surface:#fff;--bg-nav:#eef2ffe6;--bg-tag:#0048c80f;--bg-hover:#0048c817;--text-primary:#050e20;--text-secondary:#172b4d;--text-muted:#5a6e8c;--accent:#0048c8;--accent-bright:#1a6dff;--accent-hover:#003aa0;--accent-light:#0048c812;--accent-glow:#0048c83d;--cyan:#00aecc;--cyan-glow:#00aecc38;--border:#0048c824;--border-mid:#0048c852;--border-vivid:#0048c8a6;--gb-idle:linear-gradient(135deg, #0048c8b3 0%, #00aecc66 45%, #0048c81a 100%);--gb-hover:linear-gradient(135deg, #0048c8 0%, #00aeccbf 45%, #0048c859 100%);--shadow-sm:0 1px 4px #00288c0f;--shadow-md:0 4px 20px #00288c14;--glow-idle:0 0 28px #0048c817, 0 4px 16px #00288c12;--glow-active:0 0 44px #0048c838, 0 8px 32px #00288c1c;--radius-sm:4px;--radius-md:8px;--radius-lg:14px;--font-sans:"Inter", system-ui, -apple-system, sans-serif;--font-mono:"JetBrains Mono", ui-monospace, Consolas, monospace;--t:.22s ease;--t-slow:.42s ease}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{font-family:var(--font-sans);color:var(--text-secondary);background:var(--bg-page);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:16px;line-height:1.6}#root{width:100%}a{color:inherit;text-decoration:none}img{max-width:100%;display:block}button{cursor:pointer;font-family:inherit}.container{max-width:1160px;margin:0 auto;padding:0 40px}.section{padding:100px 0}.glow-border{background:linear-gradient(var(--bg-surface), var(--bg-surface)) padding-box, var(--gb-idle) border-box;box-shadow:var(--glow-idle);transition:box-shadow var(--t), background var(--t), transform var(--t);border:1.5px solid #0000}.glow-border:hover{background:linear-gradient(var(--bg-surface), var(--bg-surface)) padding-box, var(--gb-hover) border-box;box-shadow:var(--glow-active)}.section-label{font-family:var(--font-mono);letter-spacing:.18em;text-transform:uppercase;color:var(--cyan);margin-bottom:10px;font-size:11px;font-weight:500}.section-header{margin-bottom:60px}.section-header__title{letter-spacing:-.03em;color:var(--text-primary);margin-bottom:0;font-size:38px;font-weight:800}.section-header__title:after{content:"";background:linear-gradient(90deg, var(--accent), var(--cyan));border-radius:2px;width:52px;height:2px;margin-top:10px;display:block}.section-header__sub{color:var(--text-muted);max-width:480px;margin-top:14px;font-size:15px}.intro{z-index:9999;background:#050e20;justify-content:center;align-items:center;transition:transform .95s cubic-bezier(.76,0,.24,1);display:flex;position:fixed;inset:0;overflow:hidden}.intro--leaving{transform:translateY(-100%)}.intro__orb{pointer-events:none;filter:blur(60px);border-radius:50%;animation:5s ease-in-out infinite alternate intro-orb-pulse;position:absolute}.intro__orb--1{background:radial-gradient(circle,#00aecc38 0%,#0000 65%);width:700px;height:700px;animation-duration:4.5s;top:-250px;right:-180px}.intro__orb--2{background:radial-gradient(circle,#0048c847 0%,#0000 65%);width:600px;height:600px;animation-delay:-2s;bottom:-200px;left:-150px}@keyframes intro-orb-pulse{0%{opacity:.6;transform:scale(1)}to{opacity:1;transform:scale(1.18)}}.intro__content{z-index:1;text-align:center;animation:.9s cubic-bezier(.16,1,.3,1) forwards intro-content-rise;position:relative}@keyframes intro-content-rise{0%{opacity:0;transform:translateY(36px)scale(.96)}to{opacity:1;transform:translateY(0)scale(1)}}.intro__monogram{font-family:var(--font-sans);letter-spacing:-.05em;background:linear-gradient(135deg,#fff 0%,#00aeccd9 45%,#0048c8b3 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin-bottom:18px;font-size:clamp(90px,16vw,140px);font-weight:900;line-height:1;animation:2.2s ease-in-out infinite alternate intro-glow}@keyframes intro-glow{0%{filter:drop-shadow(0 0 22px #00aecc66)}to{filter:drop-shadow(0 0 70px #00aecce6)drop-shadow(0 0 120px #0048c873)}}.intro__name{font-family:var(--font-mono);letter-spacing:.38em;text-transform:uppercase;color:#fff0;margin-bottom:44px;font-size:clamp(11px,1.4vw,13px);font-weight:400;animation:1.1s cubic-bezier(.16,1,.3,1) .35s forwards intro-name-spread}@keyframes intro-name-spread{0%{color:#fff0;letter-spacing:.7em}to{color:#ffffff61;letter-spacing:.38em}}.intro__bar{background:#ffffff1a;border-radius:2px;width:200px;height:1px;margin:0 auto;overflow:hidden}.intro__bar-fill{background:linear-gradient(90deg,#0048c8e6,#00aecc);border-radius:2px;width:0;height:100%;animation:2.5s .3s forwards intro-bar-fill;box-shadow:0 0 14px #00aecccc}@keyframes intro-bar-fill{0%{width:0}to{width:100%}}.nav{z-index:100;width:max-content;transition:opacity .3s,transform .3s,box-shadow .3s;position:fixed;top:18px;left:50%;transform:translate(-50%)}.nav--hidden{opacity:0;pointer-events:none;transform:translate(-50%)translateY(-24px)}.nav--scrolled .nav__inner{box-shadow:0 8px 32px #00288c24,0 2px #0048c81f,inset 0 1px #ffffff8c}.nav__inner{-webkit-backdrop-filter:blur(22px)saturate(1.5);background:#d7e1ff73;border:1px solid #b4c8ff80;border-radius:999px;justify-content:center;align-items:center;height:44px;padding:0 28px;transition:box-shadow .3s;display:flex;box-shadow:0 4px 20px #00288c14,inset 0 1px #ffffff73}.nav__links{align-items:center;gap:28px;list-style:none;display:flex}.nav__link{font-family:var(--font-mono);letter-spacing:.1em;text-transform:uppercase;color:var(--text-muted);transition:color var(--t);padding-bottom:3px;font-size:11px;font-weight:500;position:relative}.nav__link:after{content:"";background:linear-gradient(90deg, var(--accent), var(--cyan));width:0;height:1.5px;transition:width var(--t);position:absolute;bottom:-2px;left:0}.nav__link:hover,.nav__link.active{color:var(--text-primary)}.nav__link:hover:after,.nav__link.active:after{width:100%}.hero{align-items:center;min-height:100vh;padding-top:64px;display:flex;position:relative;overflow:hidden}.hero:before{content:"";pointer-events:none;background-image:radial-gradient(circle,#0048c81c 1px,#0000 1px);background-size:32px 32px;position:absolute;inset:0}.hero__orb{pointer-events:none;filter:blur(90px);border-radius:50%;position:absolute}.hero__orb--1{background:radial-gradient(circle,#00aecc42 0%,#0000 68%);width:640px;height:640px;animation:14s ease-in-out infinite hero-orb-1;top:-200px;right:-140px}.hero__orb--2{background:radial-gradient(circle,#0048c838 0%,#0000 68%);width:520px;height:520px;animation:18s ease-in-out infinite hero-orb-2;bottom:-140px;left:-110px}.hero__orb--3{filter:blur(60px);background:radial-gradient(circle,#1a6dff24 0%,#0000 68%);width:320px;height:320px;animation:22s ease-in-out infinite hero-orb-3;top:44%;left:36%}@keyframes hero-orb-1{0%,to{transform:translate(0)scale(1)}33%{transform:translate(-48px,38px)scale(1.08)}66%{transform:translate(32px,-24px)scale(.93)}}@keyframes hero-orb-2{0%,to{transform:translate(0)scale(1)}40%{transform:translate(58px,-46px)scale(1.1)}70%{transform:translate(-28px,34px)scale(.94)}}@keyframes hero-orb-3{0%,to{transform:translate(0)scale(1)}30%{transform:translate(-65px,48px)scale(1.12)}65%{transform:translate(48px,-58px)scale(.88)}}.hero-canvas{pointer-events:none;z-index:0;width:100%;height:100%;position:absolute;inset:0}.hero__geo{pointer-events:none;z-index:0;border-radius:6px;position:absolute}.hero__geo--a{border:1px solid #0048c821;width:110px;height:110px;animation:22s ease-in-out infinite geo-float-a;top:14%;left:6%}.hero__geo--b{border:1px solid #00aecc29;width:64px;height:64px;animation:17s ease-in-out infinite geo-float-b;bottom:18%;right:8%}.hero__geo--c{border:1px solid #0048c81a;width:38px;height:38px;animation:26s ease-in-out infinite geo-float-c;top:66%;left:20%}.hero__geo--d{border:1px solid #00aecc17;border-radius:50%;width:80px;height:80px;animation:19s ease-in-out infinite geo-float-d;top:30%;right:28%}@keyframes geo-float-a{0%,to{opacity:.55;transform:translateY(0)rotate(0)}33%{opacity:.9;transform:translateY(-22px)rotate(42deg)}66%{opacity:.65;transform:translateY(14px)rotate(-18deg)}}@keyframes geo-float-b{0%,to{opacity:.5;transform:translateY(0)rotate(0)}40%{opacity:.85;transform:translateY(20px)rotate(-38deg)}70%{opacity:.6;transform:translateY(-16px)rotate(56deg)}}@keyframes geo-float-c{0%,to{opacity:.45;transform:translateY(0)rotate(0)}30%{opacity:.8;transform:translateY(-26px)rotate(72deg)}65%{opacity:.5;transform:translateY(14px)rotate(-44deg)}}@keyframes geo-float-d{0%,to{opacity:.4;transform:translate(0)scale(1)}35%{opacity:.72;transform:translate(-18px,22px)scale(1.15)}70%{opacity:.45;transform:translate(22px,-14px)scale(.88)}}.hero:after{content:"";pointer-events:none;z-index:0;border:1px solid #0048c81a;border-radius:50%;width:180px;height:180px;animation:6s ease-in-out infinite pulse-ring;position:absolute;bottom:12%;left:5%}@keyframes pulse-ring{0%,to{opacity:.35;transform:scale(1)}50%{opacity:0;transform:scale(1.35)}}.hero__reveal{opacity:0;transition:opacity .68s cubic-bezier(.16,1,.3,1),transform .68s cubic-bezier(.16,1,.3,1);transform:translateY(24px)}.hero--ready .hero__reveal{opacity:1;transform:none}.hero--ready .hero__reveal--1{transition-delay:40ms}.hero--ready .hero__reveal--2{transition-delay:.16s}.hero--ready .hero__reveal--3{transition-delay:.28s}.hero--ready .hero__reveal--4{transition-delay:.4s}.hero--ready .hero__reveal--5{transition-delay:.52s}.hero--ready .hero__reveal--6{transition-delay:.65s}.hero--ready .hero__reveal--7{transition-delay:.8s}.hero__inner{z-index:1;grid-template-columns:1fr 400px;align-items:center;gap:80px;width:100%;max-width:1160px;margin:0 auto;padding:0 40px;display:grid;position:relative}.hero__eyebrow{font-family:var(--font-mono);letter-spacing:.2em;text-transform:uppercase;color:var(--cyan);margin-bottom:14px;font-size:11px;font-weight:500}.hero__name{letter-spacing:-.04em;color:var(--text-primary);margin-bottom:14px;font-size:clamp(44px,5.5vw,72px);font-weight:900;line-height:1.03}.hero__role-row{align-items:center;gap:10px;min-height:28px;margin-bottom:24px;display:flex}.hero__role-prefix{color:var(--text-muted);font-size:15px}.hero__role{font-family:var(--font-mono);color:var(--accent);font-size:15px;font-weight:600}.hero__role--fade-in{animation:.35s forwards fadeIn}.hero__role--fade-out{animation:.35s forwards fadeOut}@keyframes fadeIn{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeOut{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(-6px)}}.hero__description{color:var(--text-muted);max-width:520px;margin-bottom:40px;font-size:17px;line-height:1.72}.hero__stats{border-radius:var(--radius-lg);background:linear-gradient(var(--bg-surface), var(--bg-surface)) padding-box, var(--gb-idle) border-box;box-shadow:var(--glow-idle);border:1.5px solid #0000;gap:0;margin-bottom:40px;display:flex;overflow:hidden}.hero__stat{border-right:1px solid var(--border);text-align:center;flex:1;padding:18px 24px}.hero__stat:last-child{border-right:none}.hero__stat-value{font-family:var(--font-mono);color:var(--text-primary);margin-bottom:4px;font-size:24px;font-weight:700;line-height:1}.hero__stat-label{font-family:var(--font-mono);letter-spacing:.13em;text-transform:uppercase;color:var(--text-muted);font-size:10px;font-weight:500}.hero__actions{flex-wrap:wrap;gap:10px;display:flex}.hero__visual{flex-direction:column;gap:16px;display:flex}.hero__card{border-radius:var(--radius-lg);padding:28px}.hero__profile-placeholder{aspect-ratio:3/4;border-radius:var(--radius-md);border:1px dashed var(--border-mid);background:linear-gradient(145deg, var(--bg-page) 0%, #0048c80f 100%);justify-content:center;align-items:center;width:100%;margin-bottom:20px;display:flex;position:relative;overflow:hidden}.hero__profile-placeholder:before{content:"";background-image:radial-gradient(circle,#0048c814 1px,#0000 1px);background-size:20px 20px;position:absolute;inset:0}.hero__profile-placeholder img{object-fit:cover;border-radius:var(--radius-md);width:100%;height:100%;position:absolute;inset:0}.hero__profile-text{font-family:var(--font-mono);letter-spacing:.1em;color:var(--text-muted);text-transform:uppercase;z-index:1;font-size:11px;position:relative}.hero__tags{flex-wrap:wrap;gap:8px;display:flex}.hero__tag{font-family:var(--font-mono);letter-spacing:.06em;text-transform:lowercase;color:var(--accent);background:var(--accent-light);border:1px solid var(--border-mid);border-radius:var(--radius-sm);padding:4px 10px;font-size:11px;font-weight:500}.btn{border-radius:var(--radius-md);font-family:var(--font-mono);letter-spacing:.08em;text-transform:uppercase;white-space:nowrap;transition:all var(--t);border:none;align-items:center;gap:8px;padding:10px 22px;font-size:11.5px;font-weight:600;display:inline-flex}.btn--primary{background:linear-gradient(135deg, var(--accent), var(--accent-bright));color:#fff;box-shadow:0 4px 16px var(--accent-glow)}.btn--primary:hover{background:linear-gradient(135deg, var(--accent-bright), var(--accent));box-shadow:0 6px 24px var(--accent-glow);transform:translateY(-1px)}.btn--outline{background:var(--bg-surface);color:var(--text-primary);border:1.5px solid var(--border-mid)}.btn--outline:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-light);box-shadow:0 0 16px var(--accent-glow)}.btn--ghost{color:var(--text-muted);border:1px solid var(--border);background:0 0;padding:10px 16px}.btn--ghost:hover{color:var(--text-primary);background:var(--bg-hover);border-color:var(--border-mid)}.experience{background:var(--bg-surface);border-top:1px solid var(--border);border-bottom:1px solid var(--border);position:relative}.experience:before{content:"";pointer-events:none;background:linear-gradient(#0048c808 0%,#0000 30% 70%,#0048c808 100%);position:absolute;inset:0}.timeline{flex-direction:column;display:flex}.timeline__item{grid-template-columns:1fr 40px 200px;align-items:start;gap:0 28px;padding-bottom:52px;display:grid}.timeline__item:last-child{padding-bottom:0}.timeline__body{padding-top:2px}.timeline__connector{justify-content:center;align-self:stretch;padding-top:6px;display:flex;position:relative}.timeline__connector:after{content:"";background:linear-gradient(to bottom, var(--accent), var(--cyan));width:1.5px;position:absolute;top:0;bottom:-52px;left:50%;transform:translate(-50%)}.timeline__item:first-child .timeline__connector:after{top:13px}.timeline__item:last-child .timeline__connector:after{display:none}.timeline__dot{border:2px solid var(--border-mid);background:var(--bg-surface);width:14px;height:14px;transition:all var(--t);z-index:1;border-radius:50%;flex-shrink:0;position:relative}.timeline__dot--active{border-color:var(--accent);background:var(--accent);box-shadow:0 0 0 4px var(--accent-light), 0 0 14px var(--accent-glow)}.timeline__title{color:var(--text-primary);margin-bottom:5px;font-size:18px;font-weight:700}.timeline__company-row{flex-wrap:wrap;align-items:center;gap:10px;margin-bottom:12px;display:flex}.timeline__company{color:var(--text-secondary);font-size:14px;font-weight:500}.timeline__type{font-family:var(--font-mono);letter-spacing:.09em;text-transform:uppercase;color:var(--accent);background:var(--accent-light);border:1px solid var(--border-mid);border-radius:var(--radius-sm);padding:2px 8px;font-size:10.5px;font-weight:500}.timeline__dates{font-family:var(--font-mono);color:var(--text-muted);white-space:nowrap;text-align:left;padding-top:6px;font-size:12px}.timeline__current{font-family:var(--font-mono);letter-spacing:.08em;text-transform:uppercase;color:#047857;border-radius:var(--radius-sm);background:#ecfdf5;border:1px solid #a7f3d0;padding:2px 8px;font-size:10.5px;font-weight:500}.timeline__description{color:var(--text-muted);margin-bottom:8px;font-size:15px;line-height:1.72}.timeline__description:last-child{margin-bottom:0}.timeline__section-label{font-family:var(--font-mono);letter-spacing:.15em;text-transform:uppercase;color:var(--cyan);margin:16px 0 6px;font-size:10.5px;font-weight:600}.timeline__section-label:first-child{margin-top:4px}@media (width<=640px){.timeline__item{grid-template-rows:auto auto;grid-template-columns:24px 1fr}.timeline__body{grid-area:1/2}.timeline__connector{grid-area:1/1/3;padding-top:6px}.timeline__connector:after{bottom:-52px}.timeline__dates{text-align:left;grid-area:2/2;margin-bottom:12px;padding-top:4px}}.projects__grid{grid-template-columns:repeat(2,1fr);gap:24px;display:grid}.project-card{border-radius:var(--radius-lg);flex-direction:column;padding:26px;display:flex}.project-card__top{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.project-card__meta{align-items:center;gap:10px;display:flex}.project-card__number{font-family:var(--font-mono);color:var(--text-muted);font-size:12px;font-weight:500}.project-card__sep{background:var(--border-mid);width:1px;height:12px}.project-card__category{font-family:var(--font-mono);letter-spacing:.13em;text-transform:uppercase;color:var(--cyan);font-size:10.5px;font-weight:500}.project-card__year{font-family:var(--font-mono);color:var(--text-muted);font-size:11px}.project-card__carousel{aspect-ratio:16/9;border-radius:var(--radius-md);border:1px solid var(--border);width:100%;margin-bottom:18px;position:relative;overflow:hidden}.carousel__track{width:100%;height:100%}.carousel__img{object-fit:cover;width:100%;height:100%;display:block}.carousel__placeholder{background:linear-gradient(135deg, var(--bg-page), #0048c80f);justify-content:center;align-items:center;width:100%;height:100%;display:flex;position:relative}.carousel__placeholder:before{content:"";background-image:radial-gradient(circle,#0048c814 1px,#0000 1px);background-size:14px 14px;position:absolute;inset:0}.carousel__btn{z-index:2;-webkit-backdrop-filter:blur(6px);width:28px;height:28px;color:var(--text-primary);cursor:pointer;transition:background var(--t), border-color var(--t);background:#ffffff9e;border:1px solid #ffffff8c;border-radius:50%;justify-content:center;align-items:center;padding:0;font-size:20px;line-height:1;display:flex;position:absolute;top:50%;transform:translateY(-50%)}.carousel__btn:hover{border-color:var(--border-mid);background:#ffffffeb}.carousel__btn--prev{left:8px}.carousel__btn--next{right:8px}.carousel__dots{z-index:2;gap:5px;display:flex;position:absolute;bottom:8px;left:50%;transform:translate(-50%)}.carousel__dot{cursor:pointer;width:6px;height:6px;transition:background var(--t), transform var(--t);background:#ffffff73;border:none;border-radius:50%;padding:0}.carousel__dot--active{background:#fff;transform:scale(1.35)}.project-card__image-text{font-family:var(--font-mono);letter-spacing:.1em;text-transform:uppercase;color:var(--border-vivid);z-index:1;font-size:10px;position:relative}.project-card__title{letter-spacing:-.02em;color:var(--text-primary);margin-bottom:3px;font-size:16px;font-weight:700}.project-card__subtitle{font-family:var(--font-mono);color:var(--text-muted);margin-bottom:12px;font-size:11.5px}.project-card__desc{color:var(--text-muted);scrollbar-width:thin;scrollbar-color:var(--border-mid) transparent;max-height:100px;margin-bottom:18px;padding-right:4px;font-size:13.5px;line-height:1.68;overflow-y:auto}.project-card__desc::-webkit-scrollbar{width:3px}.project-card__desc::-webkit-scrollbar-track{background:0 0}.project-card__desc::-webkit-scrollbar-thumb{background:var(--border-mid);border-radius:99px}.project-card__footer{flex-wrap:wrap;justify-content:space-between;align-items:flex-end;gap:10px;margin-top:auto;display:flex}.project-card__tags{flex-wrap:wrap;gap:6px;display:flex}.tag{font-family:var(--font-mono);letter-spacing:.04em;color:var(--text-secondary);background:var(--bg-tag);border:1px solid var(--border);border-radius:var(--radius-sm);transition:all var(--t);padding:3px 9px;font-size:10.5px;font-weight:500}.tag:hover{background:var(--accent-light);border-color:var(--border-mid);color:var(--accent)}.project-card__link{font-family:var(--font-mono);letter-spacing:.08em;text-transform:uppercase;color:var(--accent);white-space:nowrap;transition:color var(--t);font-size:11px;font-weight:600}.project-card__link:hover{color:var(--cyan)}.pmodal__backdrop{z-index:500;-webkit-backdrop-filter:blur(6px);background:#0a0e28b8;justify-content:center;align-items:center;padding:20px;animation:.18s pmodal-in;display:flex;position:fixed;inset:0}@keyframes pmodal-in{0%{opacity:0}to{opacity:1}}.pmodal{background:var(--bg-surface);border:1px solid var(--border-mid);border-radius:var(--radius-lg);width:100%;max-width:860px;max-height:90vh;animation:.2s pmodal-up;position:relative;overflow-y:auto;box-shadow:0 24px 80px #00288c2e,0 4px 24px #0000001f}@keyframes pmodal-up{0%{opacity:0;transform:translateY(18px)scale(.98)}to{opacity:1;transform:translateY(0)scale(1)}}.pmodal__close{z-index:1;border:1px solid var(--border-mid);background:var(--bg-page);width:30px;height:30px;color:var(--text-secondary);cursor:pointer;transition:background var(--t), color var(--t);border-radius:50%;justify-content:center;align-items:center;font-size:14px;display:flex;position:absolute;top:14px;right:16px}.pmodal__close:hover{background:var(--accent-light);color:var(--accent)}.project-card__carousel--modal{aspect-ratio:16/9;border-radius:var(--radius-lg) var(--radius-lg) 0 0;border:none;border-bottom:1px solid var(--border);margin-bottom:0}.project-card__carousel--modal .carousel__btn{width:36px;height:36px;font-size:26px}.pmodal__body{padding:24px 28px 28px}.pmodal__meta{align-items:center;gap:10px;margin-bottom:10px;display:flex}.pmodal__year{font-family:var(--font-mono);color:var(--text-muted);margin-left:auto;font-size:11px}.pmodal__title{letter-spacing:-.02em;color:var(--text-primary);margin-bottom:4px;font-size:22px;font-weight:700}.pmodal__subtitle{font-family:var(--font-mono);color:var(--text-muted);margin-bottom:16px;font-size:12px}.pmodal__desc{color:var(--text-muted);margin-bottom:20px;font-size:14px;line-height:1.72}.pmodal__footer{flex-wrap:wrap;justify-content:space-between;align-items:flex-end;gap:10px;display:flex}.forge{background:var(--bg-surface);border-top:1px solid var(--border);border-bottom:1px solid var(--border)}.forge__categories{flex-direction:column;gap:32px;display:flex}.forge__category-label{font-family:var(--font-mono);letter-spacing:.14em;text-transform:uppercase;color:var(--accent);border-bottom:1px solid var(--border);margin-bottom:14px;padding-bottom:8px;font-size:10.5px;font-weight:600}.forge__cards{flex-wrap:wrap;justify-content:center;gap:14px;display:flex}.forge__card{border-radius:var(--radius-lg);background:linear-gradient(var(--bg-surface), var(--bg-surface)) padding-box, var(--gb-idle) border-box;width:96px;box-shadow:var(--glow-idle);transition:box-shadow var(--t), background var(--t), transform var(--t);cursor:default;border:1.5px solid #0000;flex-direction:column;align-items:center;gap:10px;padding:20px 10px 14px;display:flex}.forge__card:hover{background:linear-gradient(var(--bg-surface), var(--bg-surface)) padding-box, var(--gb-hover) border-box;box-shadow:var(--glow-active);transform:translateY(-4px)}.forge__icon{border-radius:var(--radius-md);background:var(--bg-page);width:44px;height:44px;transition:background var(--t);justify-content:center;align-items:center;display:flex}.forge__card:hover .forge__icon{background:var(--accent-light)}.forge__icon-text{font-family:var(--font-mono);letter-spacing:.04em;text-align:center;font-size:10px;font-weight:700;line-height:1.2}.forge__name{font-family:var(--font-mono);letter-spacing:.04em;color:var(--text-secondary);text-align:center;white-space:nowrap;text-overflow:ellipsis;max-width:80px;font-size:10px;font-weight:500;overflow:hidden}.contact__inner{grid-template-columns:1fr 1fr;align-items:start;gap:80px;display:grid}.contact__header{margin-bottom:36px}.contact__availability{font-family:var(--font-mono);letter-spacing:.1em;text-transform:uppercase;color:#047857;border-radius:var(--radius-sm);background:#ecfdf5;border:1px solid #a7f3d0;margin-bottom:32px;padding:4px 12px;font-size:11px;font-weight:500;display:inline-block}.contact__detail-label{font-family:var(--font-mono);letter-spacing:.14em;text-transform:uppercase;color:var(--text-muted);margin-bottom:4px;font-size:10px;font-weight:500}.contact__detail-value{color:var(--text-secondary);margin-bottom:24px;font-size:15px}.contact__social-links{flex-wrap:wrap;gap:10px;margin-top:32px;display:flex}.contact__social-link{font-family:var(--font-mono);letter-spacing:.08em;text-transform:uppercase;color:var(--text-secondary);border:1px solid var(--border-mid);border-radius:var(--radius-md);background:var(--bg-surface);transition:all var(--t);padding:8px 18px;font-size:11px;font-weight:500}.contact__social-link:hover{color:var(--accent);border-color:var(--accent);background:var(--accent-light);box-shadow:0 0 14px var(--accent-glow)}.contact__form{border-radius:var(--radius-lg);padding:36px}.contact__form-title{color:var(--text-primary);margin-bottom:4px;font-size:18px;font-weight:700}.contact__form-sub{color:var(--text-muted);margin-bottom:28px;font-size:14px}.form-field{margin-bottom:18px}.form-label{font-family:var(--font-mono);letter-spacing:.12em;text-transform:uppercase;color:var(--text-muted);margin-bottom:6px;font-size:10.5px;font-weight:500;display:block}.form-input,.form-textarea{width:100%;font-family:var(--font-sans);color:var(--text-primary);background:var(--bg-page);border:1.5px solid var(--border);border-radius:var(--radius-md);resize:none;transition:border-color var(--t), box-shadow var(--t);outline:none;padding:10px 14px;font-size:15px}.form-input:focus,.form-textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow);background:var(--bg-surface)}.form-textarea{min-height:120px}.form__submit{width:100%;font-family:var(--font-mono);letter-spacing:.1em;text-transform:uppercase;color:#fff;background:linear-gradient(135deg, var(--accent), var(--accent-bright));border-radius:var(--radius-md);cursor:pointer;transition:all var(--t);border:none;padding:12px;font-size:12px;font-weight:700}.form__submit:hover{background:linear-gradient(135deg, var(--accent-bright), var(--accent));box-shadow:0 4px 20px var(--accent-glow);transform:translateY(-1px)}.form__submit:disabled{opacity:.7;cursor:not-allowed;transform:none}.form__status{text-align:center;border-radius:var(--radius-md);margin-top:12px;padding:10px;font-size:13px}.form__status--success{color:#047857;background:#ecfdf5;border:1px solid #a7f3d0}.form__status--error{color:#dc2626;background:#fef2f2;border:1px solid #fecaca}.footer{border-top:1px solid var(--border);text-align:center;padding:28px 0}.footer__copy{font-family:var(--font-mono);color:var(--text-muted);font-size:12px}.fab{z-index:300;width:56px;height:56px;position:fixed}.fab__btn{-webkit-backdrop-filter:blur(14px)saturate(1.5);cursor:grab;z-index:2;background:#d7e1ff8c;border:2px solid #0048c859;border-radius:50%;justify-content:center;align-items:center;width:56px;height:56px;transition:background .2s,box-shadow .2s;display:flex;position:relative;box-shadow:0 4px 20px #00288c24,inset 0 1px #ffffff80}.fab__btn:active{cursor:grabbing}.fab__btn:hover{background:#d7e1ffc7}.fab__plus{color:var(--accent);margin-top:-2px;font-size:26px;font-weight:300;line-height:1;transition:transform .25s;display:block}.fab__btn--open .fab__plus{transform:rotate(45deg)}.fab__action{-webkit-backdrop-filter:blur(12px);width:44px;height:44px;color:var(--fc,var(--accent));opacity:0;pointer-events:none;background:#e6ecffb8;border:1.5px solid #ffffff8c;border-radius:50%;justify-content:center;align-items:center;text-decoration:none;transition:transform .22s,opacity .22s;display:flex;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)scale(.5);box-shadow:0 2px 12px #00288c1f}.fab__action--open{opacity:1;pointer-events:all}.fab__action--open.fab__action--1{transition-delay:0s;transform:translate(-50%,calc(-50% - 62px))scale(1)}.fab__action--open.fab__action--2{transition-delay:40ms;transform:translate(-50%,calc(-50% - 116px))scale(1)}.fab__action--open.fab__action--3{transition-delay:80ms;transform:translate(-50%,calc(-50% - 170px))scale(1)}.fab__action--open.fab__action--4{transition-delay:.12s;transform:translate(-50%,calc(-50% - 224px))scale(1)}.fab__action:hover{background:#ffffffeb}@media (width<=1050px){.projects__grid{grid-template-columns:1fr}}@media (width<=900px){.container{padding:0 24px}.section{padding:72px 0}.nav__inner{padding:0 24px}.nav__links{gap:18px}.hero__inner{grid-template-columns:1fr;gap:48px;padding:32px 24px 0}.hero__visual{display:none}.hero__name{font-size:clamp(36px,8vw,52px)}.contact__inner{grid-template-columns:1fr;gap:48px}.footer__inner{padding:0 24px}}@media (width<=640px){.nav__links{display:none}.projects__grid,.skills__grid{grid-template-columns:1fr}.hero__actions{gap:8px}.hero__stats{flex-direction:column}.hero__stat{border-right:none;border-bottom:1px solid var(--border)}.hero__stat:last-child{border-bottom:none}}
