@import"https://fonts.googleapis.com/css2?family=Outfit:wght@300;400;500;600;700;800;900&family=Lora:ital,wght@0,400;1,400;1,600&display=swap";*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}:root{--bg: #08111e;--bg2: #0e1d2f;--bg3: #162840;--ice: #a8d8f0;--ice2: #cceeff;--slate: #4a7fa5;--silver: #c8d8e8;--silver2: #8fa8c0;--dim: #3a5570;--border: rgba(168, 216, 240, .12);--border2: rgba(168, 216, 240, .06);--text: #ddeeff;--text2: #8aaccc;--text3: #4a6a88;--green: #7ed957}html{scroll-behavior:smooth}body{background:var(--bg);color:var(--text);font-family:Outfit,sans-serif;font-size:15px;line-height:1.6;overflow-x:hidden}#root:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:0;background-image:radial-gradient(1px 1px at 15% 12%,rgba(200,216,232,.5) 0%,transparent 100%),radial-gradient(1px 1px at 42% 7%,rgba(200,216,232,.4) 0%,transparent 100%),radial-gradient(1px 1px at 68% 22%,rgba(200,216,232,.3) 0%,transparent 100%),radial-gradient(1px 1px at 83% 5%,rgba(200,216,232,.5) 0%,transparent 100%),radial-gradient(1px 1px at 27% 35%,rgba(200,216,232,.2) 0%,transparent 100%),radial-gradient(1.5px 1.5px at 8% 60%,rgba(168,216,240,.4) 0%,transparent 100%),radial-gradient(1.5px 1.5px at 60% 85%,rgba(168,216,240,.35) 0%,transparent 100%),radial-gradient(1px 1px at 90% 90%,rgba(200,216,232,.3) 0%,transparent 100%)}.wrap{max-width:1500px;margin:0 auto;padding:0 2.5rem;position:relative;z-index:1}.section{padding:6rem 0;position:relative;z-index:1}.sec-eyebrow{font-size:11px;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--slate);margin-bottom:.75rem}.sec-h2{font-family:Outfit,sans-serif;font-size:clamp(2rem,4vw,3.2rem);font-weight:800;letter-spacing:-.03em;line-height:1.1;margin-bottom:3.5rem}.sec-h2 em{font-family:Lora,serif;font-style:italic;font-weight:600;color:var(--ice)}.btn{display:inline-flex;align-items:center;gap:.5rem;padding:.9rem 1.8rem;border-radius:8px;font-family:Outfit,sans-serif;font-size:14px;font-weight:600;text-decoration:none;transition:all .2s;letter-spacing:.01em;cursor:pointer;border:2px solid transparent}.btn-ice{background:var(--ice);color:var(--bg);border-color:var(--ice)}.btn-ice:hover{background:var(--ice2);border-color:var(--ice2);transform:translateY(-2px);box-shadow:0 10px 30px #a8d8f040}.btn-ghost{background:transparent;color:var(--text2);border-color:var(--border2)}.btn-ghost:hover{border-color:var(--ice);color:var(--ice);transform:translateY(-2px)}.reveal{opacity:0;transform:translateY(26px);transition:opacity .65s ease,transform .65s ease}.reveal.visible{opacity:1;transform:translateY(0)}.d1{transition-delay:.08s}.d2{transition-delay:.16s}.d3{transition-delay:.24s}@keyframes fadeUp{0%{opacity:0;transform:translateY(22px)}to{opacity:1;transform:translateY(0)}}.fade-1{animation:fadeUp .5s .1s both}.fade-2{animation:fadeUp .6s .25s both}.fade-3{animation:fadeUp .6s .45s both}@media (max-width: 900px){.hero-body{grid-template-columns:1fr}.hero-right{display:none}.tl-grid,.proj-grid{grid-template-columns:1fr}.proj-card.wide{grid-column:span 1;aspect-ratio:4/3}.testi-grid,.contact-layout{grid-template-columns:1fr}.contact-right{display:none}.skills-grid{grid-template-columns:1fr}}.nav{position:sticky;top:0;z-index:200;padding:1.25rem 0;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#08111ecc;border-bottom:1px solid var(--border)}.nav-inner{display:flex;justify-content:space-between;align-items:center}.nav-logo{font-family:Lora,serif;font-style:italic;font-size:1.3rem;color:var(--ice);text-decoration:none;letter-spacing:-.01em}.nav-logo span{color:var(--silver2);font-style:normal;font-family:Outfit,sans-serif;font-size:.85rem;font-weight:500;margin-left:.5rem}.nav-links{display:flex;align-items:center;gap:2.5rem;list-style:none}.nav-links a{color:var(--text2);text-decoration:none;font-size:13px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;transition:color .2s}.nav-links a:hover{color:var(--ice)}.nav-cta{background:#a8d8f01a;border:1px solid rgba(168,216,240,.3);border-radius:6px;padding:.5rem 1.1rem;color:var(--ice)!important;transition:all .2s!important}.nav-cta:hover{background:#a8d8f033!important;border-color:var(--ice)!important}.hero{min-height:100vh;display:flex;flex-direction:column;justify-content:center;padding:6rem 0 4rem;position:relative;overflow:hidden}.hero-canvas{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;pointer-events:none;z-index:0}.hero-glow{position:absolute;width:700px;height:700px;background:radial-gradient(circle,rgba(74,127,165,.18) 0%,transparent 65%);top:50%;left:50%;transform:translate(-50%,-50%);pointer-events:none;z-index:0}.hero .wrap{position:relative;z-index:1}.hero-badge{display:inline-flex;align-items:center;gap:.5rem;background:#a8d8f014;border:1px solid rgba(168,216,240,.2);border-radius:100px;padding:.4rem 1rem;font-size:12px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--ice);margin-bottom:2rem}.pulse{width:7px;height:7px;background:var(--green);border-radius:50%;animation:pulseAnim 2s infinite}@keyframes pulseAnim{0%,to{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.8)}}.hero-h1{font-family:Outfit,sans-serif;font-size:clamp(3.5rem,8vw,8rem);font-weight:900;line-height:.92;letter-spacing:-.04em;margin-bottom:2rem}.hero-h1 .name-i{font-family:Lora,serif;font-style:italic;font-weight:600;font-size:.9em;color:var(--ice);display:block}.hero-h1 .name-cursor{display:inline-block;width:3px;height:.8em;background:var(--ice);margin-left:4px;vertical-align:middle;border-radius:1px;animation:cursorBlink 1s step-end infinite}@keyframes cursorBlink{0%,to{opacity:1}50%{opacity:0}}.hero-h1 .role{color:var(--dim);font-size:.6em;font-weight:700;letter-spacing:-.02em;display:block}.hero-body{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center;margin-top:3rem}.hero-desc{color:var(--text2);font-size:16px;line-height:1.8;font-weight:300;margin-bottom:2rem}.hero-btns{display:flex;gap:1rem;flex-wrap:wrap}.hero-right{display:flex;flex-direction:column;align-items:center;gap:1rem}.radar-label{font-size:11px;font-weight:700;letter-spacing:.15em;text-transform:uppercase;color:var(--text3)}.radar-hint{font-size:11px;color:var(--text3);text-align:center}.tl-section{background:var(--bg2);border-top:1px solid var(--border);border-bottom:1px solid var(--border)}.tl-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.25rem}.tl-card{background:var(--bg);border:1px solid var(--border);border-radius:14px;padding:1.75rem;position:relative;overflow:hidden;transition:border-color .25s,transform .25s,box-shadow .25s}.tl-card:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--slate),var(--ice));opacity:0;transition:opacity .25s}.tl-card:hover{border-color:#a8d8f04d;transform:translateY(-4px);box-shadow:0 16px 40px #0000004d}.tl-card:hover:before{opacity:1}.tl-date{font-size:10px;font-weight:700;letter-spacing:.15em;text-transform:uppercase;color:var(--slate);margin-bottom:1rem;display:inline-block;background:#4a7fa51f;border:1px solid rgba(74,127,165,.2);border-radius:100px;padding:.2rem .7rem}.tl-role{font-family:Outfit,sans-serif;font-size:1.05rem;font-weight:700;color:var(--text);margin-bottom:.25rem;letter-spacing:-.01em;line-height:1.3}.tl-company{font-size:12px;font-weight:600;color:var(--ice);margin-bottom:.85rem}.tl-desc{font-size:13px;color:var(--text2);line-height:1.7;margin-bottom:1rem}.tl-tags{display:flex;flex-wrap:wrap;gap:.4rem}.tl-tag{font-size:10px;font-weight:700;letter-spacing:.08em;color:var(--text3);background:#ffffff0a;border:1px solid var(--border);border-radius:4px;padding:.2rem .55rem}.proj-section{background:var(--bg)}.proj-hint{color:var(--text3);font-size:13px;margin-top:-2.5rem;margin-bottom:2.5rem}.proj-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.25rem}.proj-card{position:relative;border-radius:14px;overflow:hidden;text-decoration:none;color:inherit;aspect-ratio:4/3;display:block;border:1px solid var(--border);opacity:0;transform:perspective(800px) translateY(40px);transition:opacity .6s ease var(--stagger, 0ms),transform .6s cubic-bezier(.22,1,.36,1) var(--stagger, 0ms),border-color .25s ease;will-change:transform,opacity;transform-style:preserve-3d}.proj-card.wide{grid-column:span 2;aspect-ratio:16/7}.proj-card.proj-card-visible{opacity:1;transform:perspective(800px) translateY(0)}.proj-card:hover{border-color:#a8d8f066}.proj-shimmer{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(115deg,transparent 0%,transparent 40%,rgba(168,216,240,.08) 50%,transparent 60%,transparent 100%);background-size:250% 100%;background-position:200% 0;z-index:10;pointer-events:none;transition:background-position 0s}.proj-card:hover .proj-shimmer{background-position:-50% 0;transition:background-position .6s ease}.proj-canvas{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;transition:transform .55s cubic-bezier(.4,0,.2,1)}.proj-card:hover .proj-canvas{transform:scale(1.06)}.proj-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(to top,#060e1af7,#060e1ab3 40%,#060e1a26);transition:background .35s}.proj-card:hover .proj-overlay{background:linear-gradient(to top,#060e1afa,#060e1ae0 55%,#060e1a8c)}.proj-content{position:absolute;top:0;right:0;bottom:0;left:0;padding:1.6rem;display:flex;flex-direction:column;justify-content:flex-end;z-index:5}.proj-kind{font-size:10px;font-weight:700;letter-spacing:.15em;text-transform:uppercase;color:var(--ice);margin-bottom:.4rem;opacity:.7;transition:opacity .3s}.proj-card:hover .proj-kind{opacity:1}.proj-name{font-size:1.05rem;font-weight:700;letter-spacing:-.02em;color:var(--text);margin-bottom:0;transition:margin-bottom .35s}.proj-card.wide .proj-name{font-size:1.3rem}.proj-card:hover .proj-name{margin-bottom:.6rem}.proj-blurb{font-size:12.5px;color:var(--text2);line-height:1.6;max-height:0;overflow:hidden;opacity:0;transition:max-height .4s ease,opacity .35s ease}.proj-card:hover .proj-blurb{max-height:80px;opacity:1;margin-bottom:.75rem}.proj-pills{display:flex;flex-wrap:wrap;gap:.35rem;max-height:0;overflow:hidden;opacity:0;transition:max-height .4s ease .05s,opacity .3s ease .05s}.proj-card:hover .proj-pills{max-height:60px;opacity:1}.proj-pill{font-size:10px;font-weight:600;color:var(--silver2);background:#a8d8f01a;border:1px solid rgba(168,216,240,.2);border-radius:4px;padding:.18rem .55rem}.proj-arrow{position:absolute;top:1.2rem;right:1.2rem;width:32px;height:32px;border-radius:50%;background:#a8d8f01a;border:1px solid rgba(168,216,240,.2);display:flex;align-items:center;justify-content:center;font-size:.9rem;color:var(--text3);transition:all .25s;opacity:0;z-index:6}.proj-card:hover .proj-arrow{opacity:1;color:var(--ice);background:#a8d8f026;transform:translate(2px,-2px)}.proj-num{position:absolute;top:1.2rem;left:1.4rem;font-family:Lora,serif;font-style:italic;font-size:1.1rem;color:#a8d8f04d;transition:opacity .3s;z-index:6}.proj-card:hover .proj-num{opacity:0}.proj-corner-tl{position:absolute;top:0;left:0;width:28px;height:28px;z-index:8;pointer-events:none}.proj-corner-tl:before,.proj-corner-tl:after{content:"";position:absolute;background:var(--ice);border-radius:1px;opacity:0;transition:opacity .3s,width .35s ease,height .35s ease}.proj-corner-tl:before{top:0;left:0;height:2px;width:0}.proj-corner-tl:after{top:0;left:0;width:2px;height:0}.proj-corner-br{position:absolute;bottom:0;right:0;width:28px;height:28px;z-index:8;pointer-events:none}.proj-corner-br:before,.proj-corner-br:after{content:"";position:absolute;background:var(--ice);border-radius:1px;opacity:0;transition:opacity .3s,width .35s ease,height .35s ease}.proj-corner-br:before{bottom:0;right:0;height:2px;width:0}.proj-corner-br:after{bottom:0;right:0;width:2px;height:0}.proj-card:hover .proj-corner-tl:before,.proj-card:hover .proj-corner-tl:after,.proj-card:hover .proj-corner-br:before,.proj-card:hover .proj-corner-br:after{opacity:1}.proj-card:hover .proj-corner-tl:before,.proj-card:hover .proj-corner-br:before{width:28px}.proj-card:hover .proj-corner-tl:after,.proj-card:hover .proj-corner-br:after{height:28px}@media (max-width: 900px){.proj-grid{grid-template-columns:1fr}.proj-card.wide{grid-column:span 1;aspect-ratio:4/3}}.testi-section{background:var(--bg2);border-top:1px solid var(--border);border-bottom:1px solid var(--border)}.testi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}.testi-card{background:var(--bg3);border:1px solid var(--border);border-radius:14px;padding:2rem;transition:transform .2s,box-shadow .2s}.testi-card:hover{transform:translateY(-4px);box-shadow:0 16px 40px #0000004d}.testi-stars{color:var(--ice);font-size:11px;letter-spacing:.1em;margin-bottom:.5rem}.testi-quote{font-family:Lora,serif;font-style:italic;font-size:4rem;line-height:.8;color:#a8d8f026;margin-bottom:.5rem;display:block}.testi-text{font-size:14px;color:var(--silver);line-height:1.75;margin-bottom:1.5rem;font-style:italic}.testi-author{display:flex;align-items:center;gap:.75rem}.testi-avatar{width:38px;height:38px;border-radius:50%;background:linear-gradient(135deg,var(--bg3),var(--slate));border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:.9rem;font-weight:700;color:var(--ice);flex-shrink:0}.testi-name{font-size:13px;font-weight:700;color:var(--text);margin-bottom:.1rem}.testi-title{font-size:11px;color:var(--text3)}.skills-section{background:var(--bg);position:relative;overflow:hidden}.skills-aurora{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;pointer-events:none;z-index:0}.skills-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:2rem}.skill-block{background:#0e1d2fbf;border:1px solid var(--border);border-radius:14px;padding:2rem;transition:border-color .25s,transform .25s,box-shadow .25s;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}.skill-block:hover{border-color:#a8d8f04d;transform:translateY(-3px);box-shadow:0 12px 40px #00000040}.skill-block-title{font-size:12px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--slate);margin-bottom:1.25rem;display:flex;align-items:center;gap:.5rem}.skill-block-title span{font-size:1rem}.skill-rows{display:flex;flex-direction:column;gap:.85rem}.skill-row-item{display:flex;align-items:center;gap:.85rem}.skill-row-left{display:flex;align-items:center;gap:.5rem;width:150px;flex-shrink:0}.skill-row-logo{width:18px;height:18px;object-fit:contain;filter:brightness(.9) saturate(.8);flex-shrink:0}.skill-row-logo.invert{filter:invert(.8) brightness(.9)}.skill-row-name{font-size:13px;font-weight:500;color:var(--text2)}.skill-bar-bg{flex:1;height:3px;background:#ffffff0f;border-radius:3px;overflow:hidden;position:relative}.skill-bar-fill{height:100%;border-radius:3px;background:linear-gradient(90deg,var(--slate),var(--ice));width:0;transition:width 1.4s cubic-bezier(.4,0,.2,1);position:relative}.skill-bar-fill:after{content:"";position:absolute;top:0;left:-100%;width:60%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.4),transparent);animation:barShimmer 2.5s 1.6s ease-in-out infinite}@keyframes barShimmer{0%{left:-60%}to{left:120%}}.skill-pct{font-size:11px;color:var(--text3);width:28px;text-align:right;flex-shrink:0}.terminal{background:#05101a;border:1px solid var(--border);border-radius:12px;overflow:hidden;font-family:Outfit,monospace}.term-bar{background:var(--bg3);padding:.75rem 1rem;display:flex;align-items:center;gap:.5rem;border-bottom:1px solid var(--border)}.t-dot{width:10px;height:10px;border-radius:50%}.term-title{font-size:11px;color:var(--text3);margin-left:.5rem;letter-spacing:.05em}.term-body{padding:1.25rem 1.5rem;min-height:260px;max-height:300px;overflow-y:auto}.t-line{font-size:13px;line-height:1.7;color:var(--silver);margin-bottom:.1rem}.t-prompt{color:var(--ice);font-weight:700}.t-cmd{color:var(--silver2)}.t-out{color:var(--text2)}.t-ok{color:#4ec9b0}.t-hi{color:var(--ice2)}.t-dim{color:var(--text3)}.term-input-row{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;border-top:1px solid var(--border);background:#05101a}.term-input-row .t-prompt{font-size:13px;white-space:nowrap}.term-input{flex:1;background:transparent;border:none;outline:none;font-family:Outfit,sans-serif;font-size:13px;color:var(--silver);caret-color:var(--ice)}.term-input::placeholder{color:var(--text3)}.contact-section{background:var(--bg2);border-top:1px solid var(--border)}.contact-layout{display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:start}.contact-h2{margin-bottom:1rem!important}.contact-sub{color:var(--text2);font-size:15px;line-height:1.75;font-weight:300;margin-bottom:2.5rem}.c-rows{display:flex;flex-direction:column}.c-row{display:flex;align-items:center;justify-content:space-between;padding:1.1rem 0;border-bottom:1px solid var(--border);text-decoration:none;color:var(--text);transition:padding-left .2s}.c-row:first-child{border-top:1px solid var(--border)}.c-row:hover{padding-left:.75rem}.c-row-type{font-size:10px;font-weight:700;letter-spacing:.15em;text-transform:uppercase;color:var(--text3);margin-bottom:.15rem}.c-row-val{font-size:14px;font-weight:600;transition:color .2s}.c-row:hover .c-row-val{color:var(--ice)}.c-arrow{color:var(--text3);transition:all .2s}.c-row:hover .c-arrow{color:var(--ice);transform:translate(4px,-4px)}.footer{background:var(--bg);border-top:1px solid var(--border);padding:2rem 0}.footer-inner{display:flex;justify-content:space-between;align-items:center}.foot-l{font-size:12px;color:var(--text3)}.foot-r{display:flex;gap:1.5rem}.foot-r a{font-size:12px;color:var(--text3);text-decoration:none;transition:color .2s}.foot-r a:hover{color:var(--ice)}
