@import"https://fonts.googleapis.com/css2?family=Syne:wght@400;500;600;700;800&family=DM+Mono:ital,wght@0,300;0,400;0,500;1,400&family=DM+Sans:ital,opsz,wght@0,9..40,300;0,9..40,400;0,9..40,500;0,9..40,600;1,9..40,400&display=swap";.hero{min-height:100svh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:7rem 2rem 5rem;position:relative;overflow:hidden;background:linear-gradient(135deg,var(--bg) 0%,var(--bg-2) 100%)}.hero-grid{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;background-image:radial-gradient(circle,rgba(255,255,255,.09) 1px,transparent 1px);background-size:40px 40px;-webkit-mask-image:radial-gradient(ellipse 90% 90% at 50% 50%,black 5%,transparent 85%);mask-image:radial-gradient(ellipse 90% 90% at 50% 50%,black 5%,transparent 85%)}.hero-orb{position:absolute;border-radius:50%;filter:blur(80px);animation:orb-float var(--dur, 10s) ease-in-out infinite alternate;pointer-events:none}.orb-1{width:500px;height:500px;background:radial-gradient(circle,rgba(0,229,255,.12),transparent 70%);top:-15%;left:-10%;--dur: 14s}.orb-2{width:360px;height:360px;background:radial-gradient(circle,rgba(255,77,109,.09),transparent 70%);bottom:-5%;right:0%;--dur: 11s;animation-direction:alternate-reverse}.orb-3{width:280px;height:280px;background:radial-gradient(circle,rgba(6,255,165,.06),transparent 70%);top:60%;left:40%;--dur: 17s}@keyframes orb-float{0%{transform:translate(0) scale(1)}50%{transform:translate(30px,-20px) scale(1.05)}to{transform:translate(-20px,30px) scale(.95)}}.hero-scanline{position:absolute;left:0;right:0;height:1px;top:0;pointer-events:none;background:linear-gradient(90deg,transparent 0%,rgba(0,229,255,.3) 30%,rgba(0,229,255,.6) 50%,rgba(0,229,255,.3) 70%,transparent 100%);animation:scanline 10s linear infinite}@keyframes scanline{0%{top:5%;opacity:0}5%{opacity:.5}95%{opacity:.5}to{top:95%;opacity:0}}.hero-corner-deco{position:absolute;width:60px;height:60px;pointer-events:none;z-index:3}.hero-corner-deco.top-left{top:2.5rem;left:2.5rem;border-top:1px solid rgba(0,229,255,.25);border-left:1px solid rgba(0,229,255,.25);border-radius:4px 0 0}.hero-corner-deco.top-left:before{content:"v3.0.0";position:absolute;top:-1px;left:8px;font-family:var(--mono);font-size:.55rem;color:#00e5ff66;letter-spacing:.1em;background:var(--bg);padding:0 4px;transform:translateY(-50%)}.hero-corner-deco.top-right{top:2.5rem;right:2.5rem;border-top:1px solid rgba(0,229,255,.25);border-right:1px solid rgba(0,229,255,.25);border-radius:0 4px 0 0}.hero-corner-deco.top-right:before{content:"2026";position:absolute;top:-1px;right:8px;font-family:var(--mono);font-size:.55rem;color:#00e5ff66;letter-spacing:.1em;background:var(--bg);padding:0 4px;transform:translateY(-50%)}.hero-corner-deco.bottom-right{bottom:4rem;right:2.5rem;border-bottom:1px solid rgba(0,229,255,.15);border-right:1px solid rgba(0,229,255,.15);border-radius:0 0 4px}.hero-inner{max-width:1160px;width:100%;display:grid;grid-template-columns:1fr 480px;gap:4rem;align-items:center;position:relative;z-index:2}@media (max-width: 768px){.hero-inner{grid-template-columns:1fr;gap:2rem;text-align:center}.hero-left{order:2}.hero-orb,.hero-corner-deco{display:none}}.hero-badge{display:inline-flex;align-items:center;gap:8px;background:#06ffa50f;border:1px solid rgba(6,255,165,.2);border-radius:100px;padding:6px 14px 6px 10px;font-family:var(--mono);font-size:.71rem;color:var(--green);margin-bottom:2rem;letter-spacing:.05em;width:fit-content}.badge-dot{width:7px;height:7px;background:var(--green);border-radius:50%;animation:pulse-badge 2s infinite;box-shadow:0 0 8px var(--green)}@keyframes pulse-badge{0%,to{box-shadow:0 0 #06ffa5b3,0 0 8px var(--green)}50%{box-shadow:0 0 0 5px #06ffa500,0 0 4px var(--green)}}.hero-heading{font-family:var(--display);font-size:clamp(3rem,6vw,5.5rem);font-weight:800;line-height:.95;letter-spacing:-.04em;margin-bottom:1.5rem}.hero-heading .line-one{display:block;font-family:var(--mono);font-size:.3em;font-weight:400;letter-spacing:.15em;color:var(--text-2);margin-bottom:.6em;text-transform:uppercase}.hero-heading .line-two{display:block;color:var(--text)}.hero-heading .line-two em{display:inline-block;background:linear-gradient(135deg,var(--cyan) 0%,var(--coral) 60%,var(--gold) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;position:relative}.hero-heading .line-two em:after{content:"";position:absolute;bottom:-4px;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--cyan),var(--coral));border-radius:2px;transform-origin:left;animation:name-ul 1.2s var(--ease) 1.2s both}@keyframes name-ul{0%{transform:scaleX(0)}to{transform:scaleX(1)}}.hero-role{display:flex;align-items:center;gap:.5rem;margin-bottom:1.5rem;font-family:var(--mono);font-size:clamp(.82rem,1.5vw,1rem);color:var(--text-2);min-height:1.6em}.role-prefix{color:var(--cyan);font-weight:500}.role-typed{color:var(--cyan)}.role-cursor{width:2px;height:1.1em;background:var(--cyan);animation:blink .9s step-end infinite;flex-shrink:0;box-shadow:0 0 6px var(--cyan)}@keyframes blink{0%,to{opacity:1}50%{opacity:0}}.hero-bio{font-size:1.05rem;color:var(--text-2);max-width:480px;margin-bottom:2.2rem;line-height:1.8}.hero-actions{display:flex;align-items:center;gap:.85rem;flex-wrap:wrap;margin-bottom:2rem}.btn-primary:hover .btn-arrow{transform:translate(3px)}.hero-socials{display:flex;gap:.5rem;flex-wrap:wrap;margin-bottom:2.5rem}.icon-link{display:inline-flex;align-items:center;gap:.45rem;padding:.42rem .85rem;border:1px solid var(--border);border-radius:var(--r-sm);color:var(--text-2);font-family:var(--mono);font-size:.7rem;letter-spacing:.03em;transition:all var(--t);cursor:none}.icon-link svg{width:13px;height:13px;flex-shrink:0}.icon-link:hover{border-color:var(--border-h);color:var(--cyan);background:var(--cyan-dim);transform:translateY(-2px);box-shadow:0 4px 16px #00e5ff1a}.hero-stats{display:grid;grid-template-columns:1fr 1fr 1fr;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r);overflow:hidden}.hero-stat{display:flex;flex-direction:column;align-items:center;padding:1.1rem .8rem;gap:4px;position:relative;transition:background var(--t)}.hero-stat:hover{background:var(--bg-card-h)}.hero-stat:not(:last-child):after{content:"";position:absolute;right:0;top:20%;bottom:20%;width:1px;background:var(--border)}.stat-num{font-family:var(--display);font-size:1.2rem;font-weight:800;color:var(--cyan);text-shadow:0 0 20px rgba(0,229,255,.35)}.stat-label{font-family:var(--mono);font-size:.57rem;color:var(--text-3);letter-spacing:.07em;text-align:center;text-transform:uppercase}.hero-right{display:flex;flex-direction:column;align-items:center;gap:1rem}.canvas-wrapper{width:100%;aspect-ratio:1 / 1.1;position:relative;border-radius:24px;overflow:visible}.canvas-wrapper canvas{border-radius:24px}.canvas-glow{position:absolute;top:-20px;right:-20px;bottom:-20px;left:-20px;border-radius:50%;background:radial-gradient(ellipse 60% 60% at 50% 50%,rgba(0,229,255,.08),transparent 70%);pointer-events:none;z-index:-1;animation:canvas-pulse 3s ease-in-out infinite alternate}@keyframes canvas-pulse{0%{opacity:.5;transform:scale(.95)}to{opacity:1;transform:scale(1.05)}}.hero-caption{display:flex;align-items:center;gap:.5rem;font-family:var(--mono);font-size:.65rem;color:var(--text-3);letter-spacing:.1em}.caption-dot{width:5px;height:5px;border-radius:50%;background:var(--cyan);box-shadow:0 0 6px var(--cyan);animation:pulse-badge 2s infinite}.hero-scroll-indicator{position:absolute;bottom:2rem;left:2.5rem;display:flex;flex-direction:column;align-items:center;gap:.5rem;z-index:2}.hero-scroll-indicator span{font-family:var(--mono);font-size:.56rem;color:var(--text-3);letter-spacing:.2em;text-transform:uppercase;writing-mode:vertical-rl;transform:rotate(180deg)}.scroll-line{width:1px;height:50px;background:linear-gradient(to bottom,transparent,var(--cyan));animation:scroll-p 2.5s ease-in-out infinite}@keyframes scroll-p{0%,to{opacity:.3;transform:scaleY(1)}50%{opacity:.9;transform:scaleY(.6)}}@media (max-width: 1024px){.hero-inner{grid-template-columns:1fr 380px;gap:2.5rem}}@media (max-width: 768px){.hero-inner{grid-template-columns:1fr;gap:2.5rem}.hero-right{order:-1;max-width:340px;margin:0 auto}.canvas-wrapper{aspect-ratio:1 / .9}.hero-corner-deco{display:none}}.about-layout{display:grid;grid-template-columns:1fr 360px;gap:4.5rem;align-items:start}.about-lead{font-family:var(--display);font-size:1.22rem;color:var(--text);margin-bottom:1.4rem;line-height:1.6;font-weight:600}.about-text p:not(.about-lead){margin-bottom:1.1rem;font-size:1rem;line-height:1.85}.about-cards{display:flex;flex-direction:column;gap:.65rem}.info-card{display:flex;align-items:center;gap:1.1rem;padding:1rem 1.25rem;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r);transition:all var(--t) var(--spring);position:relative;overflow:hidden;box-shadow:0 4px 20px #00000040}.info-card:before{content:"";position:absolute;left:0;top:0;bottom:0;width:2px;background:var(--cyan);transform:scaleY(0);transform-origin:bottom;transition:transform var(--t) var(--spring)}.info-card:hover{border-color:var(--border-h);background:var(--bg-card-h);transform:translate(6px);box-shadow:0 8px 30px #00000059,0 0 0 1px #00e5ff1f}.info-card:hover:before{transform:scaleY(1)}.info-card-highlight{border-color:#06ffa52e;background:#06ffa505}.info-card-highlight:before{background:var(--green)}.info-card-icon{font-size:1.1rem;width:34px;text-align:center;flex-shrink:0}.info-card-label{font-family:var(--mono);font-size:.63rem;color:var(--text-3);letter-spacing:.1em;text-transform:uppercase;margin-bottom:2px}.info-card-value{font-size:.87rem;color:var(--text);font-weight:500;display:flex;align-items:center;gap:6px}.status-dot{width:6px;height:6px;background:var(--green);border-radius:50%;animation:pulse-s 2s infinite;box-shadow:0 0 6px var(--green)}.skills-layout{display:grid;grid-template-columns:repeat(2,1fr);gap:1.4rem}.skill-group{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-lg);padding:1.8rem 2rem;transition:all var(--t);position:relative;overflow:hidden;box-shadow:0 4px 20px #0000004d}.skill-group:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse 80% 80% at 50% 110%,rgba(0,229,255,.06),transparent);opacity:0;transition:opacity .55s}.skill-group:hover{border-color:var(--border-h);transform:translateY(-3px);box-shadow:0 0 0 1px #00e5ff26,0 20px 60px #0006,0 0 50px #00e5ff0a}.skill-group:hover:after{opacity:1}.skill-group-span{grid-column:span 2}.skill-group-iot{border-color:#b069ff26;background:linear-gradient(135deg,rgba(176,105,255,.03),var(--bg-card))}.skill-group-iot:hover{border-color:#b069ff4d;box-shadow:0 0 0 1px #b069ff33,0 20px 60px #0006,0 0 50px #b069ff0d}.skill-group-iot:after{background:radial-gradient(ellipse 80% 80% at 50% 110%,rgba(176,105,255,.07),transparent)}.skill-group-header{display:flex;align-items:center;gap:.7rem;margin-bottom:1.3rem;position:relative;z-index:1}.skill-icon-wrap{width:30px;height:30px;background:#00e5ff14;border:1px solid rgba(0,229,255,.15);border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.skill-icon-wrap svg{width:14px;height:14px;color:var(--cyan)}.skill-icon-iot{background:#b069ff14;border-color:#b069ff33}.skill-icon-iot svg{color:var(--violet)}.skill-group-title{font-family:var(--display);font-size:.82rem;font-weight:700;color:var(--text-2);letter-spacing:.05em;text-transform:uppercase}.skill-pills{display:flex;flex-wrap:wrap;gap:.45rem;position:relative;z-index:1}#experience{background:var(--bg);position:relative}#experience:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background-image:radial-gradient(circle,rgba(176,105,255,.03) 1px,transparent 1px);background-size:36px 36px;-webkit-mask-image:radial-gradient(ellipse 80% 100% at 50% 50%,black 20%,transparent 100%);mask-image:radial-gradient(ellipse 80% 100% at 50% 50%,black 20%,transparent 100%);pointer-events:none;z-index:0}#experience .container{position:relative;z-index:1}.exp-title:after{background:linear-gradient(90deg,var(--violet),transparent)!important}.experience-layout{display:flex;flex-direction:column}.exp-item{display:grid;grid-template-columns:48px 1fr;gap:0 2rem}.exp-left{display:flex;flex-direction:column;align-items:center;padding-top:4px}.exp-dot{width:14px;height:14px;border-radius:50%;border:2px solid var(--violet);background:var(--bg);box-shadow:0 0 12px #b069ff66;flex-shrink:0;z-index:1;transition:background var(--t),box-shadow var(--t)}.exp-item:hover .exp-dot{background:var(--violet);box-shadow:0 0 20px #b069ffb3}.exp-line{width:1px;flex:1;min-height:40px;background:linear-gradient(to bottom,#b069ff59,#b069ff0d);margin-top:6px}.exp-content{padding-bottom:3rem}.exp-meta{display:flex;align-items:center;gap:.75rem;margin-bottom:.75rem;flex-wrap:wrap}.exp-period{font-family:var(--mono);font-size:.7rem;color:var(--text-3);letter-spacing:.08em}.exp-badge{font-family:var(--mono);font-size:.6rem;padding:.2rem .65rem;border-radius:100px;letter-spacing:.05em;font-weight:500;background:var(--violet-dim);color:var(--violet);border:1px solid rgba(176,105,255,.2)}.exp-badge-active{background:var(--green-dim);color:var(--green);border-color:#06ffa533}.exp-role{font-family:var(--display);font-size:1.25rem;font-weight:700;color:var(--text);letter-spacing:-.02em;margin-bottom:.25rem}.exp-org{font-family:var(--mono);font-size:.78rem;color:var(--cyan);opacity:.75;margin-bottom:1rem;letter-spacing:.02em}.exp-desc{font-size:.93rem;color:var(--text-2);line-height:1.8;margin-bottom:1.2rem;max-width:640px}.exp-stack{display:flex;flex-wrap:wrap;gap:.4rem}.exp-stack span{font-family:var(--mono);font-size:.66rem;padding:.22rem .65rem;border-radius:5px;background:#ffffff0a;border:1px solid var(--border);color:var(--text-3);letter-spacing:.04em;transition:all var(--t)}.exp-item:hover .exp-stack span{color:var(--text-2);border-color:#ffffff14}#projects{background:var(--bg);position:relative}#projects:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background-image:linear-gradient(rgba(0,229,255,.025) 1px,transparent 1px),linear-gradient(90deg,rgba(0,229,255,.025) 1px,transparent 1px);background-size:60px 60px;-webkit-mask-image:radial-gradient(ellipse 100% 100% at 50% 50%,black 30%,transparent 100%);mask-image:radial-gradient(ellipse 100% 100% at 50% 50%,black 30%,transparent 100%);pointer-events:none;z-index:0}#projects .container{position:relative;z-index:1}.project-showcase{display:grid;grid-template-columns:1fr 1fr;gap:0;border:1px solid var(--border);border-radius:24px;overflow:hidden;margin-bottom:2rem;background:var(--bg-card);transition:border-color .55s,box-shadow .55s,transform .5s var(--ease);box-shadow:0 0 0 1px #ffffff0a,0 4px 6px #0000004d,0 20px 40px #0006}.project-showcase:hover{transform:translateY(-6px) scale(1.005)}.project-showcase[data-accent=violet]:hover{border-color:#b069ff33;box-shadow:0 0 0 1px #b069ff1f,0 30px 80px #00000080,0 0 80px #b069ff0f}.project-showcase[data-accent=cyan]:hover{border-color:#00e5ff33;box-shadow:0 0 0 1px #00e5ff1f,0 30px 80px #00000080,0 0 80px #00e5ff0f}.project-showcase[data-accent=coral]:hover{border-color:#ff4d6d33;box-shadow:0 0 0 1px #ff4d6d1f,0 30px 80px #00000080,0 0 80px #ff4d6d0f}.project-showcase[data-accent=gold]:hover{border-color:#ffd16633;box-shadow:0 0 0 1px #ffd1661f,0 30px 80px #00000080,0 0 80px #ffd1660f}.project-showcase-flip .ps-visual{order:2}.project-showcase-flip .ps-content{order:1}.ps-visual{background:var(--bg-2);border-right:1px solid var(--border);display:flex;align-items:center;justify-content:center;padding:3rem 2.5rem;min-height:420px;position:relative;overflow:hidden}.project-showcase-flip .ps-visual{border-right:none;border-left:1px solid var(--border)}.project-showcase[data-accent=violet] .ps-visual{background:linear-gradient(135deg,rgba(176,105,255,.06),var(--bg-2))}.project-showcase[data-accent=cyan] .ps-visual{background:linear-gradient(135deg,rgba(0,229,255,.05),var(--bg-2))}.project-showcase[data-accent=coral] .ps-visual{background:linear-gradient(135deg,rgba(255,77,109,.05),var(--bg-2))}.project-showcase[data-accent=gold] .ps-visual{background:linear-gradient(135deg,rgba(255,209,102,.05),var(--bg-2))}.ps-content{padding:3rem;display:flex;flex-direction:column;justify-content:center;position:relative}.ps-meta{display:flex;align-items:center;gap:.7rem;margin-bottom:1.2rem;flex-wrap:wrap;padding-right:5rem}.ps-num{font-family:var(--display)!important;font-size:4rem!important;font-weight:800!important;color:transparent!important;-webkit-text-stroke:1px rgba(255,255,255,.06)!important;position:absolute!important;top:2.5rem!important;right:2.5rem!important;pointer-events:none!important}.ps-badge{font-family:var(--mono);font-size:.68rem;padding:.28rem .85rem;border-radius:100px;letter-spacing:.05em;font-weight:500}.ps-badge-iot{background:var(--violet-dim);color:var(--violet);border:1px solid rgba(176,105,255,.2)}.ps-badge-ai{background:var(--cyan-dim);color:var(--cyan);border:1px solid rgba(0,229,255,.18)}.ps-badge-web{background:var(--coral-dim);color:var(--coral);border:1px solid rgba(255,77,109,.2)}.ps-badge-new{background:var(--gold-dim);color:var(--gold);border:1px solid rgba(255,209,102,.2)}.ps-title{font-family:var(--display);font-size:2rem;font-weight:800;color:var(--text);letter-spacing:-.03em;margin-bottom:.4rem;line-height:1.1}.ps-tagline{font-family:var(--mono);font-size:.8rem;color:var(--cyan);letter-spacing:.03em;margin-bottom:1.2rem;opacity:.8}.project-showcase[data-accent=violet] .ps-tagline{color:var(--violet)}.project-showcase[data-accent=coral] .ps-tagline{color:var(--coral)}.project-showcase[data-accent=gold] .ps-tagline{color:var(--gold)}.ps-desc{font-size:.93rem;color:var(--text-2);line-height:1.8;margin-bottom:1.5rem}.ps-highlights{display:flex;flex-direction:column;gap:.5rem;margin-bottom:1.8rem}.ps-highlights li{display:flex;align-items:flex-start;gap:.7rem;font-size:.86rem;color:var(--text-2);line-height:1.5}.ps-hi-dot{width:5px;height:5px;border-radius:50%;background:var(--cyan);flex-shrink:0;margin-top:.45em;box-shadow:0 0 6px var(--cyan)}.project-showcase[data-accent=violet] .ps-hi-dot{background:var(--violet);box-shadow:0 0 6px var(--violet)}.project-showcase[data-accent=coral] .ps-hi-dot{background:var(--coral);box-shadow:0 0 6px var(--coral)}.project-showcase[data-accent=gold] .ps-hi-dot{background:var(--gold);box-shadow:0 0 6px var(--gold)}.ps-stack{display:flex;flex-wrap:wrap;gap:.4rem}.ps-stack span{font-family:var(--mono);font-size:.66rem;padding:.22rem .65rem;border-radius:5px;background:#ffffff0a;border:1px solid var(--border);color:var(--text-3);letter-spacing:.04em;transition:all var(--t)}.project-showcase:hover .ps-stack span{color:var(--text-2);border-color:#ffffff14}.ps-mockup{width:100%;max-width:340px;border-radius:16px;overflow:hidden;border:1px solid rgba(255,255,255,.08);box-shadow:0 24px 60px #0009}.iot-dashboard{background:#09090f;padding:1.4rem;font-family:var(--mono)}.iot-header{display:flex;align-items:center;gap:.5rem;font-size:.7rem;color:var(--text-3);margin-bottom:1.2rem}.iot-status-dot{width:6px;height:6px;background:var(--green);border-radius:50%;box-shadow:0 0 8px var(--green);animation:pulse-s 1.5s infinite}.iot-metric{display:flex;align-items:baseline;gap:.4rem;margin-bottom:.8rem}.iot-val{font-family:var(--display);font-size:2.4rem;font-weight:800;color:var(--violet);text-shadow:0 0 30px rgba(176,105,255,.4)}.iot-unit{font-size:.75rem;color:var(--text-3)}.iot-bar-label{font-size:.62rem;color:var(--text-3);margin-bottom:.4rem;letter-spacing:.06em}.iot-bar-track{position:relative;height:8px;background:#ffffff0f;border-radius:100px;overflow:hidden;margin-bottom:.3rem}.iot-bar-fill{height:100%;border-radius:100px;background:linear-gradient(90deg,var(--green),var(--gold),var(--coral))}.iot-bar-labels{display:flex;justify-content:space-between;font-size:.55rem;color:var(--text-3);letter-spacing:.04em}.iot-sparkline{margin:1rem 0;color:var(--violet);height:50px}.iot-sparkline svg{width:100%;height:100%}.iot-chips{display:flex;gap:.4rem;flex-wrap:wrap}.iot-chip{display:flex;align-items:center;gap:.3rem;font-size:.6rem;color:var(--text-3);background:#b069ff0f;border:1px solid rgba(176,105,255,.12);border-radius:4px;padding:.18rem .5rem}.iot-chip span{color:var(--violet);font-size:.5rem}.ps-mockup-app{background:#09090f}.app-chrome{border-radius:14px;overflow:hidden;border:1px solid rgba(255,255,255,.07)}.app-chrome-bar{background:#112;padding:.6rem 1rem;display:flex;align-items:center;gap:.8rem;border-bottom:1px solid rgba(255,255,255,.06)}.app-dots{display:flex;gap:5px}.app-dots span{width:10px;height:10px;border-radius:50%;background:#ffffff1f}.app-dots span:nth-child(1){background:#ff5f57}.app-dots span:nth-child(2){background:#febc2e}.app-dots span:nth-child(3){background:#28c840}.app-url{font-family:var(--mono);font-size:.65rem;color:var(--text-3);background:#ffffff0a;border-radius:4px;padding:.2rem .6rem}.app-body{background:#0a0a16;padding:1.2rem;font-family:var(--mono);font-size:.75rem}.app-card{background:#00e5ff0d;border:1px solid rgba(0,229,255,.1);border-radius:8px;padding:.8rem;margin-bottom:.8rem;display:flex;gap:.7rem;align-items:center}.app-card-icon{font-size:1.1rem}.app-card-label{font-size:.6rem;color:var(--text-3);text-transform:uppercase;letter-spacing:.07em;margin-bottom:2px}.app-card-val{color:var(--text-2);font-size:.72rem}.app-progress-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:.4rem}.app-prog-label{font-size:.68rem;color:var(--text-2)}.app-prog-pct{font-size:.68rem;color:var(--cyan);font-weight:600}.app-prog-bar{height:4px;background:#ffffff0f;border-radius:100px;margin-bottom:.8rem;overflow:hidden}.app-prog-fill{height:100%;background:linear-gradient(90deg,var(--cyan),var(--coral));border-radius:100px}.app-quiz-preview{background:#ffffff08;border-radius:8px;padding:.8rem}.app-q{font-size:.72rem;color:var(--text);margin-bottom:.5rem;font-weight:500}.app-opts{display:flex;flex-direction:column;gap:.3rem}.app-opt{font-size:.68rem;color:var(--text-3);padding:.2rem .4rem;border-radius:4px}.app-opt-correct{color:var(--green);background:#06ffa50f;border:1px solid rgba(6,255,165,.12)}.ps-mockup-edu{background:#09090f}.edu-ui{padding:1.2rem;font-family:var(--mono)}.edu-nav{display:flex;justify-content:space-between;align-items:center;font-size:.72rem;color:var(--text-2);margin-bottom:1.2rem;border-bottom:1px solid var(--border);padding-bottom:.8rem}.edu-nav span{color:var(--coral);font-size:.62rem}.edu-hero-text{font-family:var(--display);font-size:1.1rem;font-weight:800;margin-bottom:1.1rem;background:linear-gradient(135deg,var(--coral),var(--gold));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.edu-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:.5rem;margin-bottom:1rem}.edu-card{background:#ffffff0a;border:1px solid rgba(255,255,255,.07);border-radius:8px;padding:.7rem .5rem;display:flex;flex-direction:column;align-items:center;gap:.3rem;font-size:.6rem;color:var(--text-3)}.edu-card span:first-child{font-size:1.1rem}.edu-card-active{background:#ff4d6d14;border-color:#ff4d6d33;color:var(--coral)}.edu-stat-row{display:flex;gap:.5rem}.edu-stat{flex:1;background:#ffffff08;border-radius:8px;padding:.6rem;text-align:center;border:1px solid var(--border)}.edu-stat-n{display:block;font-family:var(--display);font-size:.9rem;font-weight:800;color:var(--coral)}.edu-stat-l{font-size:.55rem;color:var(--text-3);letter-spacing:.05em;text-transform:uppercase}.ps-mockup-ai{background:#09090f}.ai-ui{padding:1.2rem;font-family:var(--mono)}.ai-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;border-bottom:1px solid var(--border);padding-bottom:.8rem}.ai-logo{font-family:var(--display);font-size:.9rem;font-weight:800;color:var(--text)}.ai-role{font-size:.6rem;color:var(--gold);background:var(--gold-dim);padding:.18rem .5rem;border-radius:4px;border:1px solid rgba(255,209,102,.15)}.ai-assignment{background:#ffd1660a;border:1px solid rgba(255,209,102,.12);border-radius:8px;padding:.8rem;margin-bottom:.9rem}.ai-assign-title{font-size:.73rem;color:var(--text);font-weight:600;margin-bottom:.2rem}.ai-assign-sub{font-size:.62rem;color:var(--text-3)}.ai-feedback{margin-bottom:.9rem}.ai-feedback-label{font-size:.62rem;color:var(--text-3);text-transform:uppercase;letter-spacing:.08em;margin-bottom:.4rem}.ai-feedback-item{font-size:.68rem;padding:.28rem .5rem;border-radius:4px;margin-bottom:.25rem}.ai-feedback-item.good{color:var(--green);background:#06ffa50f}.ai-feedback-item.warn{color:var(--gold);background:var(--gold-dim)}.ai-feedback-item.bad{color:var(--coral);background:var(--coral-dim)}.ai-score-row{display:flex;justify-content:space-between;align-items:center;background:#ffffff08;border:1px solid var(--border);border-radius:8px;padding:.6rem .8rem}.ai-score-label{font-size:.65rem;color:var(--text-3);text-transform:uppercase;letter-spacing:.07em}.ai-score-val{font-family:var(--display);font-size:1rem;font-weight:800;color:var(--gold);text-shadow:0 0 16px rgba(255,209,102,.3)}#philosophy{background:var(--bg-2);position:relative}#philosophy:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background-image:radial-gradient(circle,rgba(176,105,255,.04) 1px,transparent 1px);background-size:40px 40px;background-position:20px 20px;pointer-events:none;z-index:0}#philosophy .container{position:relative;z-index:1}.philosophy-layout{display:grid;grid-template-columns:1fr 300px;gap:4rem;align-items:start}.principles{display:flex;flex-direction:column;gap:1px;border:1px solid var(--border);border-radius:var(--r-lg);overflow:hidden}.principle{display:flex;gap:1.5rem;align-items:flex-start;padding:1.6rem 2rem;background:var(--bg-card);transition:all var(--t);border-bottom:1px solid var(--border);position:relative}.principle:before{content:"";position:absolute;left:0;top:0;bottom:0;width:0;background:linear-gradient(180deg,var(--cyan),var(--coral));transition:width var(--t)}.principle:last-child{border-bottom:none}.principle:hover{background:var(--bg-card-h);padding-left:2.5rem}.principle:hover:before{width:3px}.principle-num{font-family:var(--mono);font-size:.66rem;color:var(--cyan);letter-spacing:.1em;font-weight:500;flex-shrink:0;padding-top:3px}.principle h4{font-family:var(--display);font-size:.97rem;font-weight:700;color:var(--text);margin-bottom:.4rem}.principle p{font-size:.86rem;color:var(--text-2);line-height:1.65}.quote-block{position:sticky;top:90px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-lg);padding:2.5rem 2rem;overflow:hidden}.quote-block:before{content:"";position:absolute;top:0;left:20%;right:20%;height:1px;background:linear-gradient(90deg,transparent,rgba(0,229,255,.4),transparent)}.quote-svg{width:36px;color:var(--cyan);margin-bottom:1.1rem;opacity:.3}.quote-block blockquote{font-family:var(--display);font-size:1.45rem;font-weight:800;color:var(--text);line-height:1.2;letter-spacing:-.03em;margin-bottom:1.3rem}.quote-block cite{font-family:var(--mono);font-size:.72rem;color:var(--text-3);letter-spacing:.08em}.footer{background:linear-gradient(180deg,var(--bg) 0%,#050510 100%);padding:7.5rem 0 3rem;position:relative}.footer:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background-image:radial-gradient(circle,rgba(0,229,255,.03) 1px,transparent 1px);background-size:28px 28px;pointer-events:none}.footer .container{position:relative;z-index:1}.footer-main{display:grid;grid-template-columns:1fr auto;gap:4rem;align-items:center;margin-bottom:4rem;padding-bottom:4rem;border-bottom:1px solid var(--border)}.footer-eyebrow{font-family:var(--mono);font-size:.68rem;color:var(--cyan);letter-spacing:.18em;text-transform:uppercase;opacity:.65;margin-bottom:.6rem;display:block}.footer-heading{font-family:var(--display);font-size:clamp(2rem,4vw,3rem);font-weight:800;letter-spacing:-.04em;color:var(--text);line-height:1.1;margin-bottom:1rem}.footer-heading em{background:linear-gradient(135deg,var(--cyan),var(--coral));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;font-style:normal}.footer-sub{font-size:.95rem;color:var(--text-2)}.footer-links{display:flex;flex-direction:column;gap:.65rem}.footer-social-link{display:flex;align-items:center;gap:1rem;padding:.9rem 1.4rem;border:1px solid var(--border);border-radius:var(--r);color:var(--text-2);font-family:var(--mono);font-size:.8rem;transition:all var(--t) var(--spring);min-width:200px}.footer-social-link svg{width:16px;height:16px;flex-shrink:0}.link-arrow{margin-left:auto;opacity:.4;transition:all var(--t)}.footer-social-link:hover{border-color:var(--border-h);color:var(--cyan);transform:translate(6px);box-shadow:0 0 0 1px #00e5ff1f}.footer-social-link:hover .link-arrow{opacity:1;transform:translate(2px,-2px)}.footer-bottom{display:flex;justify-content:space-between;align-items:center}.footer-copy,.footer-built{font-family:var(--mono);font-size:.72rem;color:var(--text-3);letter-spacing:.05em}@media (max-width: 1024px){.about-layout{grid-template-columns:1fr 300px;gap:3rem}.philosophy-layout{grid-template-columns:1fr 260px;gap:2.5rem}}@media (max-width: 900px){.skills-layout{grid-template-columns:1fr}.skill-group-span{grid-column:1}.project-showcase{grid-template-columns:1fr}.project-showcase-flip .ps-visual,.project-showcase-flip .ps-content{order:0}.ps-visual{border-right:none!important;border-left:none!important;border-bottom:1px solid var(--border);min-height:280px}.philosophy-layout{grid-template-columns:1fr}.quote-block{position:static}.footer-main{grid-template-columns:1fr;gap:3rem}.footer-links{flex-direction:row;flex-wrap:wrap}}@media (max-width: 768px){.about-layout{grid-template-columns:1fr;gap:3rem}.exp-item{grid-template-columns:32px 1fr;gap:0 1.2rem}.ps-content{padding:2rem 1.5rem}.ps-title{font-size:1.6rem}.footer-links{flex-direction:column}.footer-bottom{flex-direction:column;gap:.5rem;text-align:center}}:root{--bg: #070710;--bg-2: #0c0c18;--bg-card: #0e0e1c;--bg-card-h: #131328;--cyan: #00e5ff;--cyan-dim: rgba(0,229,255,.08);--coral: #ff4d6d;--coral-dim: rgba(255,77,109,.08);--gold: #ffd166;--gold-dim: rgba(255,209,102,.08);--violet: #b069ff;--violet-dim: rgba(176,105,255,.08);--green: #06ffa5;--green-dim: rgba(6,255,165,.08);--text: #ededf4;--text-2: #787892;--text-3: #3a3a52;--border: rgba(255,255,255,.055);--border-h: rgba(0,229,255,.22);--font: "DM Sans", system-ui, sans-serif;--display: "Syne", system-ui, sans-serif;--mono: "DM Mono", "Courier New", monospace;--r: 14px;--r-sm: 8px;--r-lg: 20px;--ease: cubic-bezier(.4,0,.2,1);--spring: cubic-bezier(.34,1.56,.64,1);--t: .25s;--ts: .55s}[data-theme=light]{--bg: #f8f9fa;--bg-2: #ffffff;--bg-card: #ffffff;--bg-card-h: #f1f3f4;--cyan: #007bff;--cyan-dim: rgba(0,123,255,.08);--coral: #dc3545;--coral-dim: rgba(220,53,69,.08);--gold: #ffc107;--gold-dim: rgba(255,193,7,.08);--violet: #6f42c1;--violet-dim: rgba(111,66,193,.08);--green: #28a745;--green-dim: rgba(40,167,69,.08);--text: #212529;--text-2: #6c757d;--text-3: #adb5bd;--border: rgba(0,0,0,.055);--border-h: rgba(0,123,255,.22)}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;transition-duration:.01ms!important}}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;font-size:16px}body{background:var(--bg);color:var(--text);font-family:var(--font);line-height:1.7;overflow-x:hidden;cursor:none}a{color:inherit;text-decoration:none}ul,ol{list-style:none}img{display:block;max-width:100%}p{color:var(--text-2)}strong{color:var(--text);font-weight:600}mark{background:var(--cyan-dim);color:var(--cyan);padding:1px 5px;border-radius:4px}em{font-style:normal;color:var(--cyan)}::-webkit-scrollbar{width:3px}::-webkit-scrollbar-track{background:var(--bg)}::-webkit-scrollbar-thumb{background:var(--text-3);border-radius:2px}::-webkit-scrollbar-thumb:hover{background:var(--cyan)}::selection{background:#00e5ff2e;color:var(--cyan)}.noise{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1;pointer-events:none;opacity:.028;mix-blend-mode:overlay;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='1'/%3E%3C/svg%3E")}.container{max-width:1160px;margin:0 auto;padding:0 2rem}.section{padding:7.5rem 0;position:relative}.section-dark{background:var(--bg-2)}.section-dark:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--border) 30%,var(--border) 70%,transparent)}.section-header{margin-bottom:4rem}.section-eyebrow{display:block;font-family:var(--mono);font-size:.68rem;color:var(--cyan);letter-spacing:.18em;text-transform:uppercase;opacity:.65;margin-bottom:.6rem}.section-title{font-family:var(--display);font-size:clamp(1.9rem,4vw,2.8rem);font-weight:800;letter-spacing:-.03em;color:var(--text)}.section-title:after{content:"";display:block;width:40px;height:2px;background:linear-gradient(90deg,var(--cyan),transparent);margin-top:.6rem;border-radius:2px}.btn-primary,.btn-secondary{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;border-radius:var(--r);font-family:var(--mono);font-size:.85rem;font-weight:500;letter-spacing:.02em;text-decoration:none;cursor:none;transition:all var(--t) var(--spring);position:relative;overflow:hidden}.btn-primary{background:var(--cyan);color:var(--bg);box-shadow:0 4px 20px #00e5ff4d}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 8px 30px #00e5ff80}.btn-primary:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(45deg,transparent,rgba(255,255,255,.1),transparent);transform:translate(-100%);transition:transform .6s}.btn-primary:hover:before{transform:translate(100%)}.btn-secondary{background:transparent;color:var(--text);border:1px solid var(--border)}.btn-secondary:hover{background:var(--bg-card-h);border-color:var(--border-h);transform:translateY(-1px)}.btn-arrow{transition:transform var(--t)}.btn-primary:hover .btn-arrow{transform:translate(2px)}.section-sep{width:100%;height:1px;background:linear-gradient(90deg,transparent 0%,rgba(0,229,255,.12) 20%,rgba(176,105,255,.12) 50%,rgba(0,229,255,.12) 80%,transparent 100%);position:relative}.section-sep:before{content:"";position:absolute;left:50%;top:-3px;transform:translate(-50%);width:6px;height:6px;border-radius:50%;background:var(--cyan);box-shadow:0 0 10px var(--cyan)}.reveal{opacity:0;transform:translateY(32px);transition:opacity .8s var(--ease),transform .8s var(--ease)}.reveal.visible{opacity:1;transform:translateY(0)}.fade-up{opacity:0;transform:translateY(28px);animation:fu .9s var(--ease) forwards;animation-delay:var(--d, 0ms)}@keyframes fu{to{opacity:1;transform:translateY(0)}}.btn-primary{display:inline-flex;align-items:center;gap:8px;background:var(--cyan);color:#04040e;font-family:var(--display);font-weight:700;font-size:.88rem;padding:.75rem 1.8rem;border-radius:var(--r-sm);letter-spacing:.03em;transition:all var(--t);cursor:none;position:relative;overflow:hidden;border:none}.btn-primary:hover{transform:translateY(-3px);box-shadow:0 12px 40px #00e5ff59}.btn-secondary{display:inline-flex;align-items:center;gap:8px;background:transparent;color:var(--text);font-family:var(--display);font-weight:600;font-size:.88rem;padding:.75rem 1.8rem;border-radius:var(--r-sm);border:1px solid var(--border);letter-spacing:.03em;transition:all var(--t);cursor:none}.btn-secondary:hover{border-color:#00e5ff59;background:var(--cyan-dim);color:var(--cyan);transform:translateY(-3px)}.pill{font-family:var(--mono);font-size:.72rem;padding:.26rem .78rem;background:#ffffff08;border:1px solid var(--border);border-radius:100px;color:var(--text-2);transition:all var(--t) var(--spring);cursor:default}.pill:hover{background:var(--cyan-dim);border-color:#00e5ff47;color:var(--cyan);transform:translateY(-2px) scale(1.04)}.pill-iot:hover{background:var(--violet-dim);border-color:#b069ff4d;color:var(--violet)}.status-dot{width:6px;height:6px;background:var(--green);border-radius:50%;animation:pulse-s 2s infinite;box-shadow:0 0 6px var(--green);display:inline-block}@keyframes pulse-s{0%,to{box-shadow:0 0 #06ffa599,0 0 6px var(--green)}50%{box-shadow:0 0 0 4px #06ffa500,0 0 3px var(--green)}}.cursor{position:fixed;width:8px;height:8px;background:var(--cyan);border-radius:50%;pointer-events:none;z-index:9999;transform:translate(-50%,-50%);box-shadow:0 0 12px var(--cyan);transition:width .2s,height .2s;top:0;left:0}.cursor.hovered{width:14px;height:14px}.cursor-follower{position:fixed;width:30px;height:30px;border:1px solid rgba(0,229,255,.4);border-radius:50%;pointer-events:none;z-index:9998;transform:translate(-50%,-50%);transition:width .2s,height .2s,border-color .2s;top:0;left:0}.cursor-follower.hovered{width:44px;height:44px;border-color:#00e5ffb3}@media (max-width: 640px){body{cursor:auto}.cursor,.cursor-follower{display:none}.section{padding:4.5rem 0}}
