:root{--bg-primary:#050405;--bg-card:#0d0b0f;--bg-card-rgb:13, 11, 15;--text-primary:#eae5ec;--text-secondary:#8a8490;--accent:#b48cde;--accent-secondary:#7c5caa;--glow:#b48cde4d;--border-soft:#b48cde1f;--intro-bg:#050405;--font-heading:"Outfit", sans-serif;--font-body:"Inter", sans-serif;--section-padding:clamp(80px, 12vh, 160px) clamp(24px, 5vw, 80px);--container-max:1200px;--transition-fast:.2s ease;--transition-medium:.4s ease;--transition-slow:.8s ease}:root[data-theme=light]{--bg-primary:#fafafa;--bg-card:#fff;--bg-card-rgb:255, 255, 255;--text-primary:#1a1520;--text-secondary:#6b6272;--accent:#7c5caa;--accent-secondary:#b48cde;--glow:#7c5caa38;--border-soft:#7c5caa2e;--intro-bg:#fafafa}body,.navbar,.hero-section,.about-section,.skills-section,.portfolio-section,.social-3d-section,.education-section,.contact-section,.skill-tag,.education-card,.timeline-entry,.portfolio-stage,.portfolio-outro-cta{transition:background-color .4s,color .4s,border-color .4s}.intro-overlay{z-index:9999;background:var(--bg-primary);justify-content:center;align-items:center;transition:opacity 1s,visibility 1s;display:flex;position:fixed;inset:0}.intro-overlay.fade-out{opacity:0;visibility:hidden}.loader-wrapper{font-family:var(--font-heading);color:var(--text-primary);text-transform:uppercase;letter-spacing:.2em;justify-content:center;align-items:center;gap:.15rem;font-size:clamp(1.2rem,3vw,2rem);font-weight:700;display:flex;position:relative}.loader-letter{opacity:.4;animation:2s ease-in-out infinite loader-letter-anim;display:inline-block}.loader-letter:first-child{animation-delay:0s}.loader-letter:nth-child(2){animation-delay:.1s}.loader-letter:nth-child(3){animation-delay:.2s}.loader-letter:nth-child(4){animation-delay:.3s}.loader-letter:nth-child(5){animation-delay:.4s}.loader-letter:nth-child(6){animation-delay:.5s}.loader-letter:nth-child(7){animation-delay:.6s}.loader-letter:nth-child(8){animation-delay:.7s}.loader-letter:nth-child(9){animation-delay:.8s}.loader-letter:nth-child(10){animation-delay:.9s}.loader{pointer-events:none;z-index:-1;border-radius:50%;width:14rem;height:14rem;animation:3s linear infinite loader-rotate;position:absolute}@keyframes loader-rotate{0%{box-shadow:0 10px 20px 0 #eae5ec33 inset, 0 20px 30px 0 var(--accent) inset, 0 60px 60px 0 var(--accent-secondary) inset;transform:rotate(90deg)}50%{transform:rotate(270deg);box-shadow:inset 0 10px 20px #eae5ec33,inset 0 20px 10px #b48cde99,inset 0 40px 60px #7c5caacc}to{box-shadow:0 10px 20px 0 #eae5ec33 inset, 0 20px 30px 0 var(--accent) inset, 0 60px 60px 0 var(--accent-secondary) inset;transform:rotate(450deg)}}@keyframes loader-letter-anim{0%,to{opacity:.4;transform:translateY(0)}20%{opacity:1;transform:scale(1.15)}40%{opacity:.7;transform:translateY(0)}}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;width:100%;overflow-x:hidden}body{font-family:var(--font-body);color:var(--text-primary);background-color:var(--bg-primary);background-image:radial-gradient(80% 50% at 50% 0,#b48cde0a 0%,#0000 60%),radial-gradient(60% 40% at 70%,#7c5caa08 0%,#0000 50%);width:100%;font-weight:300;line-height:1.6;position:relative;overflow-x:hidden}:root[data-theme=light] body{background-image:radial-gradient(80% 50% at 50% 0,#7c5caa14 0%,#0000 60%),radial-gradient(60% 40% at 70%,#b48cde0f 0%,#0000 50%)}a{color:inherit;text-decoration:none}ul,ol{list-style:none}img{max-width:100%;height:auto;display:block}h1,h2,h3,h4,h5,h6{font-family:var(--font-heading);color:var(--text-primary);font-weight:700;line-height:1.1}p{color:var(--text-secondary);font-size:clamp(.95rem,1.2vw,1.1rem);font-weight:300;line-height:1.7}.container{max-width:var(--container-max);width:100%;margin:0 auto}.section-padding{padding:var(--section-padding)}.glass{background:rgba(var(--bg-card-rgb), .6);-webkit-backdrop-filter:blur(12px);border:1px solid #b48cde14}.section-heading{font-family:var(--font-heading);color:var(--text-primary);margin-bottom:3rem;font-size:clamp(2rem,5vw,3.5rem);font-weight:700;transition:color .6s,text-shadow .6s,opacity .6s,transform .8s cubic-bezier(.22,1,.36,1)}.section-heading-outline{font-family:var(--font-heading);color:#0000;-webkit-text-stroke:1.5px var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;z-index:2;pointer-events:none;margin-bottom:3rem;font-size:clamp(2.5rem,6vw,5rem);font-weight:900;transition:-webkit-text-stroke-color .6s,color .6s,text-shadow .6s,opacity .8s,transform .9s cubic-bezier(.22,1,.36,1);position:relative}.section-heading-outline:not(.is-revealed),.section-heading:not(.is-revealed){opacity:0;transform:translateY(40px)}.section-heading.is-revealed{opacity:1;transform:translateY(0)}.section-heading.is-lit{color:var(--accent);text-shadow:0 0 28px var(--glow), 0 0 56px #b48cde40}.section-heading-outline.is-revealed{opacity:1;-webkit-text-stroke-color:var(--accent);transform:translateY(0)}.section-heading-outline.is-lit{text-shadow:0 0 28px var(--glow), 0 0 56px #b48cde4d;-webkit-text-stroke-color:var(--accent)}.section-heading-outline{background-image:linear-gradient(100deg,#0000 0% 42%,#b48cded9 50%,#0000 58% 100%);background-position:150% 0;background-size:250% 100%;-webkit-background-clip:text;background-clip:text}.section-heading-outline.is-revealed{animation:1.4s cubic-bezier(.22,1,.36,1) forwards heading-laser-sweep}@keyframes heading-laser-sweep{0%{background-position:150% 0}to{background-position:-50% 0}}@media (prefers-reduced-motion:reduce){.section-heading-outline,.section-heading{transition:none;transform:none!important}.section-heading-outline.is-revealed{animation:none}}.navbar{z-index:1000;width:100%;transition:background var(--transition-medium), backdrop-filter var(--transition-medium), border-color var(--transition-medium);background:0 0;border-bottom:1px solid #0000;padding:1.2rem 2rem;position:fixed;top:0;left:0}.navbar.scrolled{background:rgba(var(--bg-card-rgb), .85);-webkit-backdrop-filter:blur(16px);border-bottom:1px solid var(--border-soft)}:root[data-theme=light] .navbar{-webkit-backdrop-filter:blur(14px)saturate(140%);border-bottom:1px solid var(--border-soft);background:#ffffffb8}:root[data-theme=light] .navbar.scrolled{background:#ffffffeb;box-shadow:0 6px 24px #3c285a0f}.theme-switch{--toggle-size:14px;--container-width:5.625em;--container-height:2.5em;--container-radius:6.25em;--container-light-bg:#8aa8c9;--container-night-bg:#1a1320;--circle-container-diameter:3.375em;--sun-moon-diameter:2.125em;--sun-bg:#eccaff;--moon-bg:#d8c9ee;--spot-color:#8a6fb0;--circle-container-offset:calc((var(--circle-container-diameter) - var(--container-height)) / 2 * -1);--stars-color:#f3eaff;--clouds-color:#f8f3ff;--back-clouds-color:#b48cde;--transition:.5s cubic-bezier(0, -.02, .4, 1.25);--circle-transition:.3s cubic-bezier(0, -.02, .35, 1.17);cursor:pointer;align-items:center;margin-left:.5rem;display:inline-flex}.theme-switch,.theme-switch *,.theme-switch :before,.theme-switch :after{box-sizing:border-box;font-size:var(--toggle-size);margin:0;padding:0}.theme-switch__container{width:var(--container-width);height:var(--container-height);background-color:var(--container-light-bg);border-radius:var(--container-radius);cursor:pointer;transition:var(--transition);position:relative;overflow:hidden;box-shadow:0 -.062em .062em #00000040,0 .062em .125em #ffffff80}.theme-switch__container:before{content:"";z-index:1;border-radius:var(--container-radius);position:absolute;inset:0;box-shadow:inset 0 .05em .187em #00000040,inset 0 .05em .187em #00000040}.theme-switch__checkbox{display:none}.theme-switch__circle-container{width:var(--circle-container-diameter);height:var(--circle-container-diameter);left:var(--circle-container-offset);top:var(--circle-container-offset);border-radius:var(--container-radius);transition:var(--circle-transition);pointer-events:none;background-color:#ffffff1a;display:flex;position:absolute;box-shadow:inset 0 0 0 3.375em #ffffff1a,inset 0 0 0 3.375em #ffffff1a,0 0 0 .625em #ffffff1a,0 0 0 1.25em #ffffff1a}.theme-switch__sun-moon-container{pointer-events:auto;z-index:2;width:var(--sun-moon-diameter);height:var(--sun-moon-diameter);border-radius:var(--container-radius);background-color:var(--sun-bg);filter:drop-shadow(.062em .125em .125em #00000040)drop-shadow(0 .062em .125em #00000040);transition:var(--transition);margin:auto;position:relative;overflow:hidden;box-shadow:inset .062em .062em .062em 0 #feffef9c,inset 0 -.062em .062em 0 #a176c7}.theme-switch__moon{background-color:var(--moon-bg);border-radius:inherit;width:100%;height:100%;transition:var(--transition);position:relative;transform:translate(100%);box-shadow:inset .062em .062em .062em 0 #feffef9c,inset 0 -.062em .062em 0 #9c8bb5}.theme-switch__spot{border-radius:var(--container-radius);background-color:var(--spot-color);width:.75em;height:.75em;position:absolute;top:.75em;left:.312em;box-shadow:inset 0 .0312em .062em #00000040}.theme-switch__spot:nth-of-type(2){width:.375em;height:.375em;top:.937em;left:1.375em}.theme-switch__spot:nth-last-of-type(3){width:.25em;height:.25em;top:.312em;left:.812em}.theme-switch__clouds{background-color:var(--clouds-color);border-radius:var(--container-radius);width:1.25em;height:1.25em;box-shadow:.937em .312em var(--clouds-color), -.312em -.312em var(--back-clouds-color), 1.437em .375em var(--clouds-color), .5em -.125em var(--back-clouds-color), 2.187em 0 var(--clouds-color), 1.25em -.062em var(--back-clouds-color), 2.937em .312em var(--clouds-color), 2em -.312em var(--back-clouds-color), 3.625em -.062em var(--clouds-color), 2.625em 0em var(--back-clouds-color), 4.5em -.312em var(--clouds-color), 3.375em -.437em var(--back-clouds-color), 4.625em -1.75em 0 .437em var(--clouds-color), 4em -.625em var(--back-clouds-color), 4.125em -2.125em 0 .437em var(--back-clouds-color);transition:all .5s cubic-bezier(0,-.02,.4,1.25);position:absolute;bottom:-.625em;left:.312em}.theme-switch__stars-container{color:var(--stars-color);width:2.75em;height:auto;transition:var(--transition);position:absolute;top:-100%;left:.312em}.theme-switch__checkbox:checked+.theme-switch__container{background-color:var(--container-night-bg)}.theme-switch__checkbox:checked+.theme-switch__container .theme-switch__circle-container{left:calc(100% - var(--circle-container-offset) - var(--circle-container-diameter))}.theme-switch__checkbox:checked+.theme-switch__container .theme-switch__circle-container:hover{left:calc(100% - var(--circle-container-offset) - var(--circle-container-diameter) - .187em)}.theme-switch__circle-container:hover{left:calc(var(--circle-container-offset) + .187em)}.theme-switch__checkbox:checked+.theme-switch__container .theme-switch__moon{transform:translate(0)}.theme-switch__checkbox:checked+.theme-switch__container .theme-switch__clouds{bottom:-4.062em}.theme-switch__checkbox:checked+.theme-switch__container .theme-switch__stars-container{top:50%;transform:translateY(-50%)}.theme-switch:focus-within .theme-switch__container{outline:2px solid var(--accent);outline-offset:2px}.nav-container{max-width:var(--container-max);justify-content:space-between;align-items:center;margin:0 auto;display:flex}.nav-logo{font-family:var(--font-heading);color:var(--text-primary);letter-spacing:.02em;font-size:1.1rem;font-weight:700}.nav-email{color:var(--text-secondary);transition:color var(--transition-fast);font-size:.85rem}.nav-email:hover{color:var(--accent)}.nav-links{gap:2rem;display:flex}.nav-link{letter-spacing:.05em;text-transform:uppercase;color:var(--text-secondary);transition:color var(--transition-fast);padding-bottom:4px;font-size:.875rem;font-weight:500;position:relative}.nav-link:after{content:"";background:var(--accent);width:0;height:1.5px;transition:width .3s;position:absolute;bottom:0;left:0}.nav-link:hover{color:var(--text-primary)}.nav-link:hover:after{width:100%}.hero-section{justify-content:center;align-items:center;min-height:100vh;padding:6rem 2rem 4rem;display:flex;position:relative;overflow:hidden}.hero-canvas{z-index:0;width:100%;height:100%;position:absolute;top:0;left:0}.hero-container{max-width:var(--container-max);z-index:2;grid-template-columns:1fr auto 1fr;align-items:center;gap:3rem;width:100%;display:grid;position:relative}.hero-text-left{text-align:right}.hero-greeting{font-family:var(--font-body);color:var(--text-secondary);margin-bottom:.75rem;font-size:clamp(.9rem,1.2vw,1.1rem);font-weight:400;display:block}.hero-name{font-family:var(--font-heading);text-transform:uppercase;letter-spacing:.02em;color:var(--text-primary);font-size:clamp(2.2rem,5vw,4.5rem);font-weight:900;line-height:1.05}.hero-photo-wrapper{justify-content:center;align-items:center;display:flex;position:relative}.hero-photo{object-fit:cover;z-index:2;border:3px solid #b48cde4d;border-radius:50%;width:clamp(200px,22vw,320px);height:clamp(200px,22vw,320px);animation:4s ease-in-out infinite photoPulse;position:relative;box-shadow:0 0 40px #b48cde33,0 0 80px #b48cde1a}@keyframes photoPulse{0%,to{box-shadow:0 0 40px #b48cde33,0 0 80px #b48cde1a}50%{box-shadow:0 0 60px #b48cde59,0 0 120px #b48cde26}}.hero-photo-glow{z-index:1;filter:blur(30px);background:radial-gradient(circle,#b48cde26 0%,#0000 70%);border-radius:50%;width:clamp(250px,28vw,400px);height:clamp(250px,28vw,400px);position:absolute}.hero-text-right{text-align:left}.hero-creative-label{font-family:var(--font-body);color:var(--text-secondary);margin-bottom:.5rem;font-size:clamp(.9rem,1.2vw,1.1rem);font-weight:400;display:block}.hero-role-switcher{overflow:hidden}.hero-role{font-family:var(--font-heading);color:var(--accent);font-size:clamp(1.8rem,4vw,3.5rem);font-weight:800;line-height:1.2;display:block}.floating-orb{filter:blur(60px);z-index:0;pointer-events:none;will-change:transform;background:radial-gradient(circle,#b48cde1f 0%,#0000 70%);border-radius:50%;width:300px;height:300px;animation:16s ease-in-out infinite orbFloat;position:absolute;top:50%;left:50%}@keyframes orbFloat{0%{transform:translate(-80%,-60%)}25%{transform:translate(30%,-10%)}50%{transform:translate(-20%,20%)}75%{transform:translate(40%,-40%)}to{transform:translate(-80%,-60%)}}.about-section{width:100vw;margin-left:0;margin-right:0;position:relative;left:50%;overflow:hidden;transform:translate(-50%)}.about-content{padding:var(--section-padding);max-width:var(--container-max);z-index:2;margin:0 auto;position:relative}.about-boxes-canvas{z-index:0;pointer-events:auto;width:100%;height:100%;position:absolute;top:0;left:0}.about-boxes-mask{z-index:1;background:var(--bg-primary);pointer-events:none;transition:background-color .4s;position:absolute;inset:0;-webkit-mask-image:radial-gradient(80% 70%,#0000 35%,#000 100%);mask-image:radial-gradient(80% 70%,#0000 35%,#000 100%)}.about-intro{z-index:2;pointer-events:none;grid-template-columns:1fr 1fr;align-items:center;gap:3rem;margin-bottom:4rem;display:grid;position:relative}.about-summary{max-width:720px}.about-summary p{color:var(--text-secondary);font-size:clamp(1rem,1.3vw,1.15rem);line-height:1.8}.about-summary a,.about-summary p{pointer-events:auto}.about-robot{aspect-ratio:1;background:rgba(var(--bg-card-rgb), .4);pointer-events:auto;border:1px solid #b48cde14;border-radius:20px;width:100%;max-height:480px;transition:background .4s,border-color .4s,box-shadow .4s;position:relative;overflow:hidden}:root[data-theme=light] .about-robot{background:radial-gradient(at 50% 40%,#2a1f3d 0%,#130b1f 65%,#0a0612 100%);border:1px solid #7c5caa59;box-shadow:0 20px 60px #3c285a2e,0 8px 24px #3c285a1f,inset 0 1px #ffffff0a}:root[data-theme=light] .about-robot:before{content:"";border-radius:inherit;-webkit-mask-composite:xor;pointer-events:none;z-index:2;background:linear-gradient(140deg,#b48cde80,#7c5caa1a 40%,#0000 70%);padding:1px;position:absolute;inset:-1px;-webkit-mask-image:linear-gradient(#000 0 0),linear-gradient(#000 0 0);mask-image:linear-gradient(#000 0 0),linear-gradient(#000 0 0);-webkit-mask-position:0 0,0 0;mask-position:0 0,0 0;-webkit-mask-size:auto,auto;mask-size:auto,auto;-webkit-mask-repeat:repeat,repeat;mask-repeat:repeat,repeat;-webkit-mask-clip:content-box,border-box;mask-clip:content-box,border-box;-webkit-mask-origin:content-box,border-box;mask-origin:content-box,border-box;-webkit-mask-composite:xor;mask-composite:exclude;-webkit-mask-source-type:auto,auto;mask-mode:match-source,match-source}.robot-viewer{width:100%;height:100%;display:block}.robot-loading{z-index:2;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.robot-spinner{border:3px solid #b48cde26;border-top-color:var(--accent);border-radius:50%;width:36px;height:36px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.timeline{z-index:2;pointer-events:none;padding:2rem 0;position:relative}.timeline a{pointer-events:auto}.timeline-line{background:linear-gradient(to bottom, transparent, var(--accent-secondary) 20%, var(--accent) 80%, transparent);width:2px;box-shadow:0 0 12px var(--glow);position:absolute;top:0;bottom:0;left:50%;transform:translate(-50%)}.timeline-entry{grid-template-columns:1fr auto 1fr;align-items:start;gap:2rem;padding:2rem 0;display:grid;position:relative}.timeline-left{text-align:right;padding-right:2rem}.timeline-role{font-family:var(--font-heading);color:var(--text-primary);margin-bottom:.3rem;font-size:clamp(1.1rem,1.5vw,1.35rem);font-weight:700}.timeline-company{color:var(--accent);font-size:.95rem;font-weight:400}.timeline-center{z-index:2;flex-direction:column;justify-content:center;align-items:center;gap:.5rem;min-width:80px;display:flex;position:relative}.timeline-year{font-family:var(--font-heading);color:var(--text-primary);opacity:.2;font-size:clamp(1.5rem,2.5vw,2rem);font-weight:800;transition:opacity .5s,color .5s,text-shadow .5s}.timeline-dot{background:var(--accent);width:12px;height:12px;box-shadow:0 0 12px var(--glow), 0 0 24px #b48cde26;border-radius:50%;flex-shrink:0;transition:box-shadow .5s,transform .5s;position:relative}.timeline-right{padding-left:2rem}.timeline-right p{font-size:.95rem;line-height:1.7;transition:color .5s,opacity .5s}.timeline-role,.timeline-company{transition:color .5s,text-shadow .5s,opacity .5s}.timeline-entry .timeline-role,.timeline-entry .timeline-right p{opacity:.55}.timeline-entry .timeline-company{opacity:.7}.timeline-entry.is-lit .timeline-year{opacity:1;color:var(--accent);text-shadow:0 0 24px var(--glow), 0 0 48px #b48cde40}.timeline-entry.is-lit .timeline-role{opacity:1;color:var(--text-primary);text-shadow:0 0 20px #b48cde2e}.timeline-entry.is-lit .timeline-company{opacity:1;text-shadow:0 0 14px var(--glow)}.timeline-entry.is-lit .timeline-right p{opacity:1;color:var(--text-primary)}.timeline-entry.is-lit .timeline-dot{box-shadow:0 0 16px var(--accent), 0 0 36px var(--glow), 0 0 64px #b48cde59;transform:scale(1.15)}.timeline:after{content:"";background:var(--accent);width:8px;height:8px;box-shadow:0 0 16px var(--glow), 0 0 32px #b48cde33;border-radius:50%;position:absolute;bottom:0;left:50%;transform:translate(-50%)}.skills-section{padding:var(--section-padding);max-width:var(--container-max);isolation:isolate;margin:0 auto;padding-top:0;position:relative}.lamp{pointer-events:none;z-index:0;justify-content:center;align-items:center;width:100%;height:22rem;margin-top:-10rem;margin-bottom:-6rem;display:flex;position:relative;overflow:hidden}.lamp-stage{isolation:isolate;justify-content:center;align-items:center;width:100%;height:100%;display:flex;position:relative}.lamp-cone{opacity:0;filter:blur(24px);will-change:width, opacity;width:15rem;height:28rem;transition:width 1s cubic-bezier(.22,1,.36,1),opacity 1s cubic-bezier(.22,1,.36,1);position:absolute;top:50%}.lamp-cone-left{background:conic-gradient(from 70deg at center top, var(--accent) 0deg, rgba(var(--bg-card-rgb), 0) 60deg, rgba(var(--bg-card-rgb), 0) 360deg);-webkit-mask-composite:source-in;right:50%;-webkit-mask-image:linear-gradient(#000 0% 60%,#0000 100%),linear-gradient(90deg,#fff,#0000);mask-image:linear-gradient(#000 0% 60%,#0000 100%),linear-gradient(90deg,#fff,#0000);-webkit-mask-composite:source-in;mask-composite:intersect}.lamp-cone-right{background:conic-gradient(from 290deg at center top, rgba(var(--bg-card-rgb), 0) 0deg, rgba(var(--bg-card-rgb), 0) 300deg, var(--accent) 360deg);-webkit-mask-composite:source-in;left:50%;-webkit-mask-image:linear-gradient(#000 0% 60%,#0000 100%),linear-gradient(270deg,#fff,#0000);mask-image:linear-gradient(#000 0% 60%,#0000 100%),linear-gradient(270deg,#fff,#0000);-webkit-mask-composite:source-in;mask-composite:intersect}.lamp-top-mask{background:var(--bg-primary);z-index:5;position:absolute;inset:0 0 50%}.lamp-floor{background:radial-gradient(ellipse at center, #b48cde4d, rgba(var(--bg-card-rgb), 0) 65%);filter:blur(28px);opacity:0;z-index:1;width:40rem;height:22rem;transition:opacity 1.2s ease-out;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);-webkit-mask-image:linear-gradient(90deg,#0000,#000 20% 80%,#0000);mask-image:linear-gradient(90deg,#0000,#000 20% 80%,#0000)}.lamp-spotlight{background:radial-gradient(circle at center, var(--accent), rgba(var(--bg-card-rgb), 0) 70%);filter:blur(40px);opacity:0;z-index:2;border-radius:50%;width:14rem;height:14rem;transition:opacity 1.2s ease-out;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.lamp-line{background:var(--accent);width:8rem;height:2px;box-shadow:0 0 24px 2px var(--accent), 0 0 48px 6px #b48cde99;opacity:0;z-index:3;transition:width 1s cubic-bezier(.22,1,.36,1),opacity .8s ease-out;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.lamp.is-lit .lamp-cone{opacity:.85;width:30rem}.lamp.is-lit .lamp-line{opacity:1;width:16rem}.lamp.is-lit .lamp-spotlight,.lamp.is-lit .lamp-floor{opacity:1}.skills-heading{z-index:4;position:relative}@media (width<=768px){.lamp{height:16rem;margin-top:-5rem;margin-bottom:-3rem}.lamp-cone{height:20rem}.lamp.is-lit .lamp-cone{width:20rem}.lamp.is-lit .lamp-line{width:10rem}.lamp-floor{width:22rem;height:16rem}.lamp-spotlight{width:10rem;height:10rem}}.skills-grid{flex-wrap:wrap;justify-content:center;gap:1rem;display:flex}.skill-tag{font-family:var(--font-body);color:var(--text-secondary);background:rgba(var(--bg-card-rgb), .4);transition:all var(--transition-fast);cursor:default;white-space:nowrap;animation:6s ease-in-out infinite skillFloat;animation-delay:var(--float-delay,0s);border:1px solid #b48cde1f;border-radius:50px;padding:.65rem 1.5rem;font-size:.95rem;font-weight:400}.skill-tag:nth-child(odd){--float-delay:0s}.skill-tag:nth-child(2n){--float-delay:-3s}.skill-tag:nth-child(3n){--float-delay:-1.5s}@keyframes skillFloat{0%,to{transform:translateY(0)}50%{transform:translateY(-4px)}}.skill-tag:hover{color:var(--text-primary);border-color:var(--accent);background:#b48cde14;animation-play-state:paused;box-shadow:0 0 20px #b48cde26,0 0 40px #b48cde0d}.parallax{background:var(--bg-primary);width:100%;position:relative;overflow:hidden}.parallax__header{width:100%;height:100vh;min-height:520px;max-height:780px;position:relative}.parallax__visuals{width:100%;height:100%;position:relative;overflow:hidden}.parallax__layers{width:100%;height:100%;position:absolute;inset:0}.parallax__layer{will-change:transform;justify-content:center;align-items:center;width:100%;height:100%;display:flex;position:absolute;inset:0}.parallax__layer--nebula{filter:blur(30px);background:radial-gradient(70% 50% at 30% 40%,#7c5caa59,#0000 60%),radial-gradient(60% 45% at 75% 65%,#b48cde40,#0000 65%),radial-gradient(90% 60% at 50% 100%,#b48cde2e,#0000 70%)}.parallax__layer--icons{opacity:.16}.parallax__icon-grid{grid-template-rows:repeat(2,1fr);grid-template-columns:repeat(4,1fr);place-items:center;gap:clamp(2rem,6vw,6rem);width:min(86%,1100px);height:60%;display:grid}.parallax__icon-grid img{object-fit:contain;filter:brightness(0)saturate()invert(72%)sepia(27%)saturate(579%)hue-rotate(227deg)brightness(91%)contrast(91%);width:clamp(3rem,6vw,5.5rem);height:clamp(3rem,6vw,5.5rem)}.parallax__icon-grid img:nth-child(odd){transform:translateY(-1rem)}.parallax__icon-grid img:nth-child(2n){transform:translateY(1rem)}.parallax__layer--title{z-index:2}.parallax__title{font-family:var(--font-heading);letter-spacing:-.03em;text-transform:uppercase;color:#0000;-webkit-text-stroke:2px var(--accent);text-shadow:0 0 80px #b48cde40;-webkit-user-select:none;user-select:none;font-size:clamp(5rem,18vw,16rem);font-weight:900;line-height:1}.parallax__layer--haze{z-index:3;background:linear-gradient(to bottom, transparent 0%, rgba(var(--bg-card-rgb), .2) 50%, rgba(var(--bg-card-rgb), .75) 100%);pointer-events:none}.parallax__haze-orb{filter:blur(40px);background:radial-gradient(circle,#b48cde59,#0000 60%);border-radius:50%;width:min(60vw,40rem);height:min(60vw,40rem);position:absolute;bottom:-8rem;left:50%;transform:translate(-50%)}.parallax__edge-top{background:linear-gradient(to bottom, var(--bg-primary), transparent);z-index:4;pointer-events:none;height:20%;position:absolute;top:0;left:0;right:0}.parallax__fade{background:linear-gradient(to top, var(--bg-primary), transparent);z-index:4;pointer-events:none;height:30%;position:absolute;bottom:0;left:0;right:0}:root[data-theme=light] .parallax__title{-webkit-text-stroke-color:var(--accent-secondary);text-shadow:0 0 60px #7c5caa2e}:root[data-theme=light] .parallax__layer--nebula{opacity:.7}:root[data-theme=light] .parallax__layer--icons{opacity:.2}@media (width<=768px){.parallax__header{height:75vh;min-height:420px}.parallax__icon-grid{grid-template-rows:repeat(3,1fr);grid-template-columns:repeat(3,1fr);gap:2.5rem}}.skills-hero{grid-template-columns:minmax(0,1fr) minmax(0,1.1fr);align-items:center;gap:3rem;margin-top:2rem;display:grid}.skills-hero-left{flex-direction:column;gap:1.5rem;padding-right:1rem;display:flex}.skills-hero-title{font-family:var(--font-heading);color:var(--text-primary);letter-spacing:-.01em;font-size:clamp(1.8rem,3.4vw,2.8rem);font-weight:800;line-height:1.1}.skills-hero-meta{flex-direction:column;gap:.15rem;display:flex}.skills-hero-meta p{color:var(--text-secondary);margin:0;font-size:1rem}.skills-tools-pills{flex-wrap:wrap;gap:.5rem;margin-top:.5rem;display:flex}.tool-pill{font-family:var(--font-body);color:var(--text-primary);border:1px solid var(--border-soft);background:rgba(var(--bg-card-rgb), .5);cursor:default;transition:all var(--transition-fast);letter-spacing:.02em;border-radius:999px;padding:.55rem 1.1rem;font-size:.85rem;font-weight:500;position:relative;overflow:hidden}.tool-pill:hover{color:#fff;border-color:var(--accent);background:linear-gradient(135deg, var(--accent), var(--accent-secondary));box-shadow:0 0 20px var(--glow), 0 0 40px #b48cde1a;transform:translateY(-1px)}:root[data-theme=light] .tool-pill:hover{color:#fff}.skills-hero-right{border-radius:0;flex-direction:column;gap:1rem;width:auto;margin-right:-100vw;padding:.5rem 100vw .5rem 0;display:flex;position:relative;overflow:hidden}.marquee{--duration:32s;gap:1rem;display:flex;overflow:hidden}.marquee-track{min-width:100%;animation:marquee-scroll var(--duration) linear infinite;will-change:transform;flex-shrink:0;gap:1rem;display:flex}.marquee:hover .marquee-track{animation-play-state:paused}.marquee-reverse .marquee-track{animation-direction:reverse}@keyframes marquee-scroll{0%{transform:translate(0)}to{transform:translate(calc(-100% - 1rem))}}.marquee-edge{z-index:2;pointer-events:none;width:5rem;position:absolute;top:0;bottom:0}.marquee-edge-left{background:linear-gradient(to right, var(--bg-primary), rgba(var(--bg-card-rgb), 0));left:0}.marquee-edge-right{background:linear-gradient(to left, var(--bg-primary), rgba(var(--bg-card-rgb), 0));right:0}.tool-card{border:1px solid var(--border-soft);background:rgba(var(--bg-card-rgb), .6);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-radius:1.25rem;flex-direction:column;flex-shrink:0;justify-content:center;align-items:center;gap:.6rem;width:9.5rem;height:9.5rem;padding:1rem;transition:transform .4s cubic-bezier(.22,1,.36,1),border-color .3s,box-shadow .3s;display:flex;position:relative;overflow:hidden}.tool-card:before{content:"";border-radius:inherit;background:radial-gradient(circle at 50% 120%, var(--glow), transparent 60%);opacity:.5;pointer-events:none;transition:opacity .4s;position:absolute;inset:0}.tool-card:hover{border-color:var(--accent);box-shadow:0 12px 30px #00000040, 0 0 0 1px var(--accent), 0 0 28px var(--glow);transform:translateY(-4px)}.tool-card:hover:before{opacity:.9}.tool-card img{object-fit:contain;filter:brightness(0)saturate()invert(72%)sepia(27%)saturate(579%)hue-rotate(227deg)brightness(91%)contrast(91%);z-index:1;width:2.8rem;height:2.8rem;transition:filter .4s,transform .4s;position:relative}.tool-card:hover img{transform:scale(1.08)}.tool-card span{font-family:var(--font-body);color:var(--text-secondary);letter-spacing:.04em;text-transform:uppercase;z-index:1;font-size:.78rem;font-weight:500;position:relative}.tool-card:hover span{color:var(--text-primary)}:root[data-theme=light] .tool-card img{filter:brightness(0)saturate()invert(36%)sepia(45%)saturate(726%)hue-rotate(237deg)brightness(86%)contrast(91%)}:root[data-theme=light] .marquee-edge-left{background:linear-gradient(to right, var(--bg-primary), #fafafa00)}:root[data-theme=light] .marquee-edge-right{background:linear-gradient(to left, var(--bg-primary), #fafafa00)}@media (width<=900px){.skills-hero{grid-template-columns:1fr;gap:2rem}.skills-hero-left{padding-right:0}.skills-hero-right{width:100vw;margin:0;padding-right:0;position:relative;left:50%;transform:translate(-50%)}.tool-card{width:8rem;height:8rem}.tool-card img{width:2.2rem;height:2.2rem}.marquee-edge{width:3rem}}@media (width<=480px){.tool-card{border-radius:1rem;width:7rem;height:7rem}.tool-card img{width:2rem;height:2rem}.tool-card span{font-size:.7rem}}.focus-rail-section{padding:var(--section-padding) 0;max-width:100%;margin:0;overflow:hidden}.focus-rail-section .section-heading-outline{text-align:center;margin-bottom:2rem}.focus-rail{color:#fff;-webkit-user-select:none;user-select:none;background-color:#000;outline:none;flex-direction:column;width:100%;height:600px;display:flex;position:relative;overflow:hidden}.focus-rail-bg{z-index:0;pointer-events:none;transition:opacity .8s ease-out;position:absolute;inset:0}.focus-rail-bg-img{object-fit:cover;filter:blur(24px)saturate(2);opacity:.4;width:100%;height:100%;transition:opacity .8s ease-out}.focus-rail-bg-overlay{background:linear-gradient(#0000 0%,#00000080 50%,#000 100%);position:absolute;inset:0}.focus-rail-stage{z-index:10;flex-direction:column;flex:1;justify-content:center;padding:0 2rem;display:flex;position:relative}.focus-rail-track{perspective:1200px;cursor:grab;justify-content:center;align-items:center;width:100%;max-width:1152px;height:360px;margin:0 auto;display:flex;position:relative}.focus-rail-track:active{cursor:grabbing}.focus-rail-card{aspect-ratio:3/4;width:260px;transform-style:preserve-3d;will-change:transform, opacity, filter;background-color:#1a1a1a;border-top:1px solid #fff3;border-radius:1rem;position:absolute;overflow:hidden;box-shadow:0 25px 50px -12px #00000040}@media (width>=768px){.focus-rail-card{width:300px}}.focus-rail-card img{object-fit:cover;pointer-events:none;width:100%;height:100%}.focus-rail-card-lights{pointer-events:none;background:linear-gradient(#ffffff1a,#0000);position:absolute;inset:0}.focus-rail-card-shadow{mix-blend-mode:multiply;pointer-events:none;background:#0000001a;position:absolute;inset:0}.focus-rail-footer{z-index:10;pointer-events:auto;flex-direction:column;justify-content:space-between;align-items:center;gap:1.5rem;width:100%;max-width:896px;margin:3rem auto;display:flex;position:relative}@media (width>=768px){.focus-rail-footer{flex-direction:row;align-items:flex-start}}.focus-rail-info{text-align:center;flex-direction:column;flex:1;justify-content:center;align-items:center;height:8rem;display:flex}@media (width>=768px){.focus-rail-info{text-align:left;align-items:flex-start}}.focus-rail-meta{text-transform:uppercase;letter-spacing:.05em;color:#34d399;margin-bottom:.5rem;font-size:.75rem;font-weight:500}.focus-rail-title{letter-spacing:-.025em;margin-bottom:.5rem;font-size:1.875rem;font-weight:700;line-height:1.2}@media (width>=768px){.focus-rail-title{font-size:2.25rem}}.focus-rail-desc{color:#a3a3a3;max-width:28rem}.focus-rail-controls{align-items:center;gap:1rem;display:flex}.focus-rail-nav{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background-color:#171717cc;border-radius:9999px;align-items:center;gap:.25rem;padding:.25rem;display:flex;box-shadow:0 0 0 1px #ffffff1a}.focus-rail-nav button{color:#a3a3a3;cursor:pointer;background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;padding:.75rem;transition:all .2s;display:flex}.focus-rail-nav button:hover{color:#fff;background-color:#ffffff1a}.focus-rail-nav button:active{transform:scale(.95)}.focus-rail-counter{text-align:center;color:#737373;min-width:40px;font-family:monospace;font-size:.75rem}.focus-rail-explore{color:#000;background-color:#fff;border-radius:9999px;align-items:center;gap:.5rem;padding:.75rem 1.25rem;font-size:.875rem;font-weight:600;text-decoration:none;transition:transform .2s;display:flex}.focus-rail-explore:hover{transform:scale(1.05)}.focus-rail-explore:active{transform:scale(.95)}.focus-rail-explore svg{transition:transform .2s}.focus-rail-explore:hover svg{transform:translateY(-2px)translate(2px)}.testimonials-wrapper{max-width:var(--container-max);padding:var(--section-padding);text-align:center;margin:0 auto;padding-top:4rem;overflow:hidden}.testimonials-header{margin-bottom:3rem}.testimonials-title{font-family:var(--font-heading);color:var(--text-primary);margin-bottom:1rem;font-size:clamp(2rem,5vw,3.5rem);font-weight:400}.testimonials-subtitle{font-family:var(--font-body);color:var(--text-secondary);max-width:600px;margin:0 auto;font-size:1.1rem;line-height:1.6}.testimonials-fade-mask{width:100%;padding:1rem 0;position:relative;overflow:hidden;-webkit-mask-image:linear-gradient(90deg,#0000 0%,#000 15% 85%,#0000 100%);mask-image:linear-gradient(90deg,#0000 0%,#000 15% 85%,#0000 100%)}.testimonials-track{gap:1.5rem;width:max-content;animation:30s linear infinite x-slider;display:flex}.testimonials-track:hover{animation-play-state:paused}@keyframes x-slider{0%{transform:translate(0%)}to{transform:translate(calc(-50% - .75rem))}}.testimonial-card{border:1px solid var(--border-soft);text-align:left;width:600px;transition:transform var(--transition-fast), border-color var(--transition-fast);background:linear-gradient(145deg,#17131a66,#291f331a);border-radius:12px;flex-direction:column;flex:none;justify-content:space-between;padding:2rem;display:flex}.testimonial-card:hover{border-color:var(--accent)}.testimonial-quote{font-family:var(--font-body);color:var(--text-primary);margin-bottom:2.5rem;font-size:1.1rem;font-weight:300;line-height:1.6}.testimonial-author{border-top:1px solid #b48cde14;align-items:center;gap:1rem;padding-top:1.5rem;display:flex}.testimonial-avatar{background-color:var(--bg-card);border:1px solid var(--border-soft);width:48px;height:48px;font-family:var(--font-heading);color:var(--accent);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:1.25rem;font-weight:600;display:flex}.testimonial-info{flex-direction:column;gap:4px;display:flex}.testimonial-name{font-family:var(--font-heading);color:var(--text-primary);margin:0;font-size:1.05rem;font-weight:500}.testimonial-role{font-family:var(--font-body);color:var(--text-secondary);margin:0;font-size:.9rem}@media (width<=768px){.testimonial-card{width:300px;padding:1.5rem}.testimonial-quote{font-size:1rem}}.contact-section{padding:var(--section-padding);max-width:var(--container-max);border-top:1px solid #b48cde14;margin:0 auto;padding-bottom:clamp(40px,6vh,80px)}.contact-heading{font-family:var(--font-heading);color:var(--text-primary);margin-bottom:3rem;font-size:clamp(2.5rem,6vw,4.5rem);font-weight:900}.contact-grid{grid-template-columns:1fr 1fr 1fr;gap:2rem;margin-bottom:4rem;display:grid}.contact-col{flex-direction:column;gap:.6rem;display:flex}.contact-label{text-transform:uppercase;letter-spacing:.08em;color:var(--text-secondary);opacity:.6;font-size:.8rem;font-weight:500}.contact-value{color:var(--text-primary);transition:color var(--transition-fast);font-size:1rem}a.contact-value:hover{color:var(--accent)}.contact-link{color:var(--text-primary);transition:color var(--transition-fast);align-items:center;gap:.3rem;font-size:1rem;display:inline-flex}.contact-link:hover{color:var(--accent)}.contact-link .arrow{transition:transform var(--transition-fast);font-size:.85rem;display:inline-block}.contact-link:hover .arrow{transform:translate(3px,-3px)}.footer-credit{text-align:center;border-top:1px solid #b48cde0f;padding-top:2rem}.footer-credit p{color:var(--text-secondary);opacity:.5;font-size:.85rem}.igloo-social-bar{z-index:100;flex-direction:row;align-items:center;gap:1.5rem;display:flex;position:fixed;bottom:2rem;left:50%;transform:translate(-50%)}.igloo-link{color:var(--text-secondary);cursor:pointer;font-family:var(--font-body);letter-spacing:.05em;transition:color var(--transition-fast);justify-content:center;align-items:center;padding:.5rem 1rem;font-size:.85rem;font-weight:500;text-decoration:none;display:inline-flex;position:relative}.social-3d-track .igloo-link{opacity:0;visibility:hidden;transition:opacity .5s ease, visibility .5s ease, color var(--transition-fast)}.social-3d-track .igloo-link.active{opacity:1;visibility:visible}.igloo-link:hover,.igloo-link:focus{color:var(--text-primary);outline:none}.igloo-link:before,.igloo-link:after,.igloo-corners:before,.igloo-corners:after{content:"";border:1.5px solid var(--accent);opacity:0;pointer-events:none;width:6px;height:6px;transition:all .3s cubic-bezier(.4,0,.2,1);position:absolute}.igloo-link:before{border-bottom:none;border-right:none;top:0;left:0;transform:translate(-4px,-4px)}.igloo-link:after{border-top:none;border-left:none;bottom:0;right:0;transform:translate(4px,4px)}.igloo-corners:before{border-bottom:none;border-left:none;top:0;right:0;transform:translate(4px,-4px)}.igloo-corners:after{border-top:none;border-right:none;bottom:0;left:0;transform:translate(-4px,4px)}.igloo-link:hover:before,.igloo-link:hover:after,.igloo-link:hover .igloo-corners:before,.igloo-link:hover .igloo-corners:after{opacity:1;transform:translate(0)}@media (width<=1024px){.hero-container{grid-template-columns:1fr auto 1fr;gap:2rem}.hero-name{font-size:clamp(1.8rem,4vw,3rem)}.hero-role{font-size:clamp(1.5rem,3.5vw,2.5rem)}}@media (width<=768px){.nav-email{display:none}.nav-container{padding:0 .5rem}.nav-links{gap:1.2rem}.hero-section{padding:7rem 1.5rem 3rem}.hero-container{text-align:center;grid-template-columns:1fr;justify-items:center;gap:2rem}.hero-text-left{text-align:center;order:2}.hero-photo-wrapper{order:1}.hero-text-right{text-align:center;order:3}.hero-name{font-size:clamp(2rem,8vw,3rem)}.hero-role{font-size:clamp(1.5rem,6vw,2.2rem)}.floating-orb{width:200px;height:200px}.about-intro{grid-template-columns:1fr;gap:2rem}.about-robot{max-height:360px}.timeline{padding-left:1rem}.timeline-line{left:1rem;transform:translate(-50%)}.timeline:after{left:1rem}.timeline-entry{flex-direction:column;gap:.5rem;padding-top:0;padding-bottom:2.5rem;padding-left:3rem;display:flex;position:relative}.timeline-left{text-align:left;order:2;padding-right:0}.timeline-center{order:1;min-width:auto;margin-bottom:.25rem;display:block;position:static}.timeline-year{text-align:left;opacity:.4;font-size:clamp(1.8rem,5vw,2.2rem)}.timeline-dot{position:absolute;top:.8rem;left:1rem;transform:translate(-50%)}.timeline-right{order:3;padding-top:.5rem;padding-left:0}.skills-grid{gap:.75rem}.skill-tag{padding:.5rem 1.1rem;font-size:.85rem}.education-grid{grid-template-columns:1fr}.contact-grid{grid-template-columns:1fr;gap:1.5rem}.contact-heading{font-size:clamp(2rem,8vw,3rem)}.igloo-social-bar{gap:.75rem;bottom:1.5rem}.igloo-link{padding:.4rem .6rem;font-size:.75rem}}@media (width<=480px){.navbar{padding:1rem}.nav-logo{font-size:.95rem}.nav-link{font-size:.75rem}.section-heading-outline{font-size:clamp(2rem,10vw,3rem)}}.preloader-transition{z-index:10000;flex-direction:column;justify-content:center;align-items:center;width:100%;height:100vh;display:flex;position:absolute;inset:0}.preloader-text{color:var(--text-primary);z-index:10001;align-items:center;font-size:clamp(2rem,5vw,4rem);font-weight:500;display:flex;position:absolute}.preloader-word{margin:0}.preloader-dot{background-color:var(--text-primary);border-radius:50%;width:10px;height:10px;margin-right:15px;display:block}.preloader-svg{z-index:9999;pointer-events:none;width:100%;height:calc(100vh + 300px);position:absolute;top:0;left:0}.social-3d-section{flex-direction:column;justify-content:flex-end;align-items:center;width:100%;height:60vh;min-height:400px;padding-bottom:2rem;display:flex;position:relative;overflow:hidden}#social-3d-canvas-container{z-index:1;width:100%;height:100%;position:absolute;top:0;left:0}.social-3d-controls{z-index:10;background:rgba(var(--bg-card-rgb), .4);-webkit-backdrop-filter:blur(8px);border:1px solid #b48cde1a;border-radius:100px;align-items:center;gap:1rem;padding:.5rem 1rem;display:flex;position:relative}.social-3d-track{justify-content:center;align-items:center;width:140px;height:40px;display:flex;position:relative;overflow:hidden}.social-arrow{cursor:pointer;color:var(--text-secondary);background:0 0;border:none;justify-content:center;align-items:center;padding:.5rem;transition:color .3s;display:flex}.social-arrow:hover{color:var(--accent)}.social-3d-track .igloo-social-bar{white-space:nowrap;place-items:center;gap:0;display:grid!important;position:relative!important;bottom:auto!important;left:auto!important;transform:none!important}.social-3d-track .igloo-social-bar .igloo-link{grid-area:1/1}.social-3d-section .igloo-social-bar{z-index:auto}.portfolio-section{padding:var(--section-padding);max-width:var(--container-max);margin:0 auto;padding-bottom:0}#portfolio+.social-3d-section,.portfolio-section+.social-3d-section{margin-top:clamp(-40px,-4vh,-16px);padding-top:0}.portfolio-stage{--stage-color:#c8b6e2;background:radial-gradient(ellipse at center, color-mix(in srgb, var(--stage-color) 35%, transparent) 0%, transparent 70%), var(--bg-primary);border:none;border-radius:0;width:100vw;height:100vh;min-height:600px;margin-top:2rem;transition:background .4s;position:relative;left:50%;overflow:hidden;transform:translate(-50%)}.portfolio-intro,.portfolio-outro{text-align:center;pointer-events:none;z-index:2;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.portfolio-intro-title{font-family:var(--font-heading,"Outfit", sans-serif);color:var(--text-primary);letter-spacing:-.02em;margin-bottom:.75rem;font-size:clamp(1.5rem,3vw,2.5rem)}.portfolio-intro-sub{font-family:var(--font-body,"Inter", sans-serif);letter-spacing:.3em;color:var(--text-secondary);font-size:.75rem}.portfolio-outro{opacity:0;top:12%;transform:translate(-50%)}.portfolio-outro-title{font-family:var(--font-heading,"Outfit", sans-serif);color:var(--text-primary);margin-bottom:.5rem;font-size:clamp(1.5rem,3vw,2.5rem)}.portfolio-outro-sub{font-family:var(--font-body,"Inter", sans-serif);color:var(--text-secondary);letter-spacing:.15em;margin-bottom:1.5rem;font-size:.85rem}.portfolio-outro-cta{pointer-events:auto;border:1px solid var(--accent);color:var(--text-primary);font-family:var(--font-body,"Inter", sans-serif);transition:all var(--transition-fast,.3s ease);border-radius:999px;padding:.75rem 1.75rem;font-size:.9rem;text-decoration:none;display:inline-block}.portfolio-outro-cta:hover{background:var(--accent);color:var(--bg-primary);box-shadow:0 0 32px var(--glow)}.portfolio-cards{z-index:3;width:0;height:0;position:absolute;top:50%;left:50%}.portfolio-card{width:90px;height:128px;transform-style:preserve-3d;perspective:1000px;cursor:pointer;will-change:transform;color:inherit;text-decoration:none;display:block;position:absolute;top:-64px;left:-45px}.portfolio-card:focus-visible{outline:2px solid var(--accent);outline-offset:4px;border-radius:12px}.portfolio-card-inner{width:100%;height:100%;transform-style:preserve-3d;transition:transform .6s cubic-bezier(.22,1,.36,1);position:relative}.portfolio-card:hover .portfolio-card-inner{transform:rotateY(180deg)}.portfolio-card-face{backface-visibility:hidden;border-radius:10px;position:absolute;inset:0;overflow:hidden;box-shadow:0 12px 30px #00000073,0 0 0 1px #ffffff0a}.portfolio-card-front img{object-fit:cover;width:100%;height:100%;display:block}.portfolio-card-back{background:var(--card-color,#111);color:#fff;text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:.4rem;padding:.5rem;display:flex;transform:rotateY(180deg)}.portfolio-card-project{font-family:var(--font-heading,"Outfit", sans-serif);letter-spacing:.08em;font-size:.75rem;font-weight:700}.portfolio-card-view{letter-spacing:.3em;opacity:.8;font-size:.6rem}.portfolio-caption{text-align:center;z-index:4;pointer-events:none;flex-direction:column;gap:.25rem;display:flex;position:absolute;bottom:8%;left:50%;transform:translate(-50%)}.portfolio-caption-project{font-family:var(--font-heading,"Outfit", sans-serif);color:var(--text-primary);letter-spacing:-.01em;font-size:clamp(1.25rem,2.5vw,2rem)}.portfolio-caption-desc{font-family:var(--font-body,"Inter", sans-serif);color:var(--text-secondary);letter-spacing:.08em;font-size:.85rem}@media (width<=768px){.portfolio-section{padding-left:clamp(12px,4vw,24px);padding-right:clamp(12px,4vw,24px)}.portfolio-stage{border-radius:0;height:85vh;min-height:520px}.portfolio-card{width:58px;height:82px;top:-41px;left:-29px}.portfolio-intro-title,.portfolio-outro-title{font-size:1.35rem}.portfolio-intro-sub{letter-spacing:.25em;font-size:.65rem}.portfolio-caption{padding:0 1rem;bottom:5%}.portfolio-caption-project{font-size:1.1rem}.portfolio-caption-desc{letter-spacing:.05em;font-size:.72rem}.portfolio-outro{width:88%;top:8%}.portfolio-outro-cta{padding:.6rem 1.25rem;font-size:.8rem}#portfolio+.social-3d-section,.portfolio-section+.social-3d-section{margin-top:-16px}}@media (width<=480px){.portfolio-stage{height:78vh;min-height:460px}.portfolio-card{width:52px;height:74px;top:-37px;left:-26px}.portfolio-card-project{font-size:.65rem}.portfolio-card-view{letter-spacing:.2em;font-size:.55rem}}.custom-cursor{pointer-events:none;mix-blend-mode:difference;z-index:9999;opacity:0;will-change:transform;background:#e6d4ff;border-radius:50%;transition:opacity .3s,background .3s;position:fixed;top:0;left:0}.custom-cursor.is-hovering{background:var(--accent)}body.has-custom-cursor,body.has-custom-cursor *{cursor:none!important}@media (hover:none),(pointer:coarse){.custom-cursor{display:none}body.has-custom-cursor,body.has-custom-cursor *{cursor:auto!important}}.cta-footer{isolation:isolate;background:radial-gradient(80% 60% at 50% 100%,#b48cde2e,#0000 70%),linear-gradient(#0000,#b48cde0a 40%,#0000);padding:9rem 2rem 7rem;position:relative;overflow:hidden}.cta-footer__veil{pointer-events:none;z-index:-2;background:radial-gradient(60% 40%,#b48cde1a,#0000 70%);position:absolute;inset:0}.cta-footer__grid{pointer-events:none;z-index:-1;opacity:.6;background-image:linear-gradient(#b48cde0f 1px,#0000 1px),linear-gradient(90deg,#b48cde0f 1px,#0000 1px);background-size:60px 60px;position:absolute;inset:0;-webkit-mask-image:radial-gradient(70% 60%,#000 40%,#0000 80%);mask-image:radial-gradient(70% 60%,#000 40%,#0000 80%)}.cta-footer__glow{filter:blur(40px);pointer-events:none;z-index:-1;background:radial-gradient(#b48cde59,#0000 65%);width:800px;height:400px;position:absolute;bottom:-200px;left:50%;transform:translate(-50%)}.cta-footer__inner{text-align:center;flex-direction:column;align-items:center;gap:1.5rem;max-width:960px;margin:0 auto;display:flex;position:relative}.cta-footer__eyebrow{color:var(--accent);letter-spacing:.2em;text-transform:uppercase;opacity:0;background:#b48cde0f;border:1px solid #b48cde4d;border-radius:999px;align-items:center;gap:.6rem;margin:0;padding:.4rem 1rem;font-size:.75rem;font-weight:500;display:inline-flex;transform:translateY(20px)}.cta-footer.is-visible .cta-footer__eyebrow{opacity:1;transition:opacity .8s,transform .8s;transform:translateY(0)}.cta-footer__dot{background:var(--accent);width:6px;height:6px;box-shadow:0 0 12px var(--accent);border-radius:50%;animation:2s ease-in-out infinite cta-pulse}@keyframes cta-pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(1.3)}}.cta-footer__title{font-family:var(--font-display,"Playfair Display", serif);color:var(--text-primary);letter-spacing:-.02em;margin:0;font-size:clamp(2.2rem,6vw,4.5rem);font-weight:500;line-height:1.1}.cta-footer__line{opacity:0;display:block;transform:translateY(30px)}.cta-footer.is-visible .cta-footer__line{opacity:1;transition:opacity 1s .15s,transform 1s .15s;transform:translateY(0)}.cta-footer.is-visible .cta-footer__line--accent{transition-delay:.3s}.cta-footer__line--accent{background:linear-gradient(90deg, var(--accent) 0%, #d4b5ff 50%, var(--accent) 100%);-webkit-text-fill-color:transparent;background-size:200%;-webkit-background-clip:text;background-clip:text;font-style:italic;animation:6s linear infinite cta-shimmer}@keyframes cta-shimmer{0%{background-position:0%}to{background-position:200%}}.cta-footer__sub{color:var(--text-secondary);opacity:0;max-width:38ch;margin:0;font-size:1rem;transform:translateY(20px)}.cta-footer.is-visible .cta-footer__sub{opacity:1;transition:opacity .8s .45s,transform .8s .45s;transform:translateY(0)}.cta-footer__actions{opacity:0;flex-wrap:wrap;justify-content:center;gap:1rem;margin-top:1rem;display:flex;transform:translateY(20px)}.cta-footer.is-visible .cta-footer__actions{opacity:1;transition:opacity .8s .6s,transform .8s .6s;transform:translateY(0)}.cta-btn{letter-spacing:.02em;cursor:pointer;will-change:transform;border-radius:999px;padding:0;font-family:inherit;font-size:.95rem;font-weight:500;text-decoration:none;transition:transform .3s,box-shadow .3s;display:inline-block;position:relative}.cta-btn__inner{border-radius:999px;align-items:center;gap:.6rem;padding:.95rem 1.8rem;transition:background .3s,color .3s;display:inline-flex}.cta-btn__icon{flex-shrink:0;width:18px;height:18px}.cta-btn__arrow{transition:transform .3s;display:inline-block}.cta-btn:hover .cta-btn__arrow{transform:translate(4px)}.cta-btn--primary{background:linear-gradient(135deg, var(--accent), #d4b5ff);color:#1a1320;box-shadow:0 10px 30px #b48cde59,0 0 0 1px #b48cde66}.cta-btn--primary:hover{box-shadow:0 14px 40px #b48cde80,0 0 0 1px #b48cde99}.cta-btn--ghost{color:var(--text-primary);background:#b48cde0f;border:1px solid #b48cde4d}.cta-btn--ghost:hover .cta-btn__inner{color:var(--accent);background:#b48cde1f}.cta-footer__marquee{opacity:0;width:100%;margin-top:3rem;overflow:hidden;-webkit-mask-image:linear-gradient(90deg,#0000,#000 15% 85%,#0000);mask-image:linear-gradient(90deg,#0000,#000 15% 85%,#0000)}.cta-footer.is-visible .cta-footer__marquee{opacity:1;transition:opacity 1s .9s}.cta-footer__marquee-track{white-space:nowrap;font-family:var(--font-display,"Playfair Display", serif);color:#0000;-webkit-text-stroke:1px #b48cde59;align-items:center;gap:2.5rem;font-size:clamp(2.5rem,6vw,4rem);font-style:italic;animation:28s linear infinite cta-marquee;display:inline-flex}.cta-footer__marquee-track span:nth-child(2n){color:var(--accent);-webkit-text-stroke:0;font-size:.6em;font-style:normal}@keyframes cta-marquee{0%{transform:translate(0)}to{transform:translate(-50%)}}[data-theme=light] .cta-footer{background:radial-gradient(80% 60% at 50% 100%,#7c5caa26,#0000 70%)}[data-theme=light] .cta-btn--primary{color:#fff;background:linear-gradient(135deg,#7c5caa,#a583d4)}@media (width<=640px){.cta-footer{padding:6rem 1.25rem 5rem}.cta-footer__actions{flex-direction:column;width:100%;max-width:320px}.cta-btn{width:100%}.cta-btn__inner{justify-content:center}.cta-footer__marquee{margin-top:2rem}}.hero-twinkles{pointer-events:none;z-index:1;position:absolute;inset:0}.hero-twinkles .twinkle{will-change:transform, opacity;background:radial-gradient(circle,#eae5ecf2 0%,#b48cde99 40%,#0000 70%);border-radius:50%;width:6px;height:6px;animation:1.2s ease-out forwards twinkle-pop;position:absolute;box-shadow:0 0 12px #b48cdeb3}@keyframes twinkle-pop{0%{opacity:0;transform:translate(-50%,-50%)scale(0)rotate(0)}20%{opacity:1;transform:translate(-50%,-50%)scale(1)rotate(45deg)}to{opacity:0;transform:translate(-50%,-50%)scale(.3)rotate(180deg)}}.hero-photo-wrapper[string=magnetic]{transform-style:preserve-3d;perspective:1000px;cursor:pointer;transform:translate(calc(var(--magnetic-x,0) * 0.5%), calc(var(--magnetic-y,0) * 0.5%)) rotateX(calc(var(--magnetic-y,0) * -.5deg)) rotateY(calc(var(--magnetic-x,0) * .5deg));transition:scale .6s cubic-bezier(.86,0,.31,1),rotate .6s cubic-bezier(.86,0,.31,1),translate .6s cubic-bezier(.86,0,.31,1);rotate:0deg;scale:1}.hero-photo-wrapper[string=magnetic]:hover{transition:scale .6s cubic-bezier(.35,.35,0,1),rotate .6s cubic-bezier(.35,.35,0,1),translate .6s cubic-bezier(.35,.35,0,1)}.hero-photo-wrapper[string=magnetic] .hero-photo{transition:transform .5s cubic-bezier(.22,1,.36,1);animation:4s ease-in-out infinite photoPulse,6s ease-in-out infinite photoBreathe}@keyframes photoBreathe{0%,to{transform:scale(1)rotate(0)}50%{transform:scale(1.015)rotate(-.8deg)}}.hero-photo-wrapper[string=magnetic]:hover .hero-photo{animation-play-state:paused;transform:scale(1)rotate(2deg)}.hero-bubble{z-index:4;background:linear-gradient(135deg, var(--accent), #d4b5ff);color:#1a1320;font-family:var(--font-body);white-space:nowrap;opacity:0;transform-origin:0 100%;pointer-events:none;border-radius:999px;padding:.55rem 1rem;font-size:.85rem;font-weight:600;transition:opacity .3s,transform .4s cubic-bezier(.34,1.56,.64,1);position:absolute;top:-8%;right:-8%;transform:translate(10px,10px)scale(.5);box-shadow:0 8px 20px #b48cde66}.hero-bubble:after{content:"";background:inherit;border-radius:2px;width:12px;height:12px;position:absolute;bottom:-6px;left:20px;transform:rotate(45deg)}.hero-photo-wrapper:hover .hero-bubble{opacity:1;animation:1.2s ease-in-out .4s infinite bubble-wiggle;transform:translate(0)scale(1)}@keyframes bubble-wiggle{0%,to{transform:translate(0)rotate(-3deg)}50%{transform:translateY(-4px)rotate(3deg)}}.hero-orbit{pointer-events:none;z-index:0;will-change:transform;border-radius:50%;width:clamp(280px,32vw,460px);height:clamp(280px,32vw,460px);margin-top:calc(clamp(280px,32vw,460px)/-2);margin-left:calc(clamp(280px,32vw,460px)/-2);position:absolute;top:50%;left:50%}.hero-orbit--1{animation:22s linear infinite orbit-spin}.hero-orbit--2{width:clamp(320px,36vw,520px);height:clamp(320px,36vw,520px);margin-top:calc(clamp(320px,36vw,520px)/-2);margin-left:calc(clamp(320px,36vw,520px)/-2);animation:32s linear -5s infinite reverse orbit-spin}.hero-orbit--3{width:clamp(260px,30vw,420px);height:clamp(260px,30vw,420px);margin-top:calc(clamp(260px,30vw,420px)/-2);margin-left:calc(clamp(260px,30vw,420px)/-2);animation:28s linear -10s infinite orbit-spin}.hero-orbit--4{width:clamp(340px,38vw,540px);height:clamp(340px,38vw,540px);margin-top:calc(clamp(340px,38vw,540px)/-2);margin-left:calc(clamp(340px,38vw,540px)/-2);animation:26s linear -14s infinite reverse orbit-spin}.hero-orbit--5{width:clamp(300px,34vw,490px);height:clamp(300px,34vw,490px);margin-top:calc(clamp(300px,34vw,490px)/-2);margin-left:calc(clamp(300px,34vw,490px)/-2);animation:30s linear -3s infinite orbit-spin}.hero-orbit--6{width:clamp(360px,40vw,570px);height:clamp(360px,40vw,570px);margin-top:calc(clamp(360px,40vw,570px)/-2);margin-left:calc(clamp(360px,40vw,570px)/-2);animation:36s linear -18s infinite reverse orbit-spin}.hero-orbit--9{width:clamp(380px,42vw,600px);height:clamp(380px,42vw,600px);margin-top:calc(clamp(380px,42vw,600px)/-2);margin-left:calc(clamp(380px,42vw,600px)/-2);animation:40s linear -12s infinite reverse orbit-spin}@keyframes orbit-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.hero-orbit__dot{background:rgba(var(--bg-card-rgb), .85);-webkit-backdrop-filter:blur(8px);width:44px;height:44px;font-family:var(--font-heading);color:var(--text-primary);pointer-events:auto;border:1px solid #b48cde59;border-radius:12px;justify-content:center;align-items:center;font-size:1rem;font-weight:700;transition:transform .3s,box-shadow .3s;animation:22s linear infinite orbit-counter;display:flex;position:absolute;top:-22px;left:50%;transform:translate(-50%);box-shadow:0 8px 24px #00000059,0 0 20px #b48cde2e}.hero-orbit--2 .hero-orbit__dot{animation:32s linear -5s infinite reverse orbit-counter}.hero-orbit--3 .hero-orbit__dot{animation:28s linear -10s infinite orbit-counter}.hero-orbit--4 .hero-orbit__dot{animation:26s linear -14s infinite reverse orbit-counter}.hero-orbit--5 .hero-orbit__dot{animation:30s linear -3s infinite orbit-counter}.hero-orbit--6 .hero-orbit__dot{animation:36s linear -18s infinite reverse orbit-counter}.hero-orbit--9 .hero-orbit__dot{animation:40s linear -12s infinite reverse orbit-counter}.hero-orbit:has(.hero-orbit__dot:hover){animation-play-state:paused}.hero-orbit:has(.hero-orbit__dot:hover) .hero-orbit__dot{animation-play-state:paused}.hero-orbit .hero-orbit__dot{transition:width .4s cubic-bezier(.34,1.56,.64,1),height .4s cubic-bezier(.34,1.56,.64,1),top .4s cubic-bezier(.34,1.56,.64,1),box-shadow .4s,background .3s,border-color .3s}.hero-orbit .hero-orbit__dot:hover{background:rgba(var(--bg-card-rgb), .95);border-color:var(--accent);z-index:10;width:58px;height:58px;top:-29px;box-shadow:0 14px 40px #00000080,0 0 40px #b48cdebf,0 0 90px #b48cde4d}.hero-orbit .hero-orbit__dot:hover svg{width:28px;height:28px;transition:width .4s cubic-bezier(.34,1.56,.64,1),height .4s cubic-bezier(.34,1.56,.64,1)}.hero-orbit .hero-orbit__dot:hover span{font-size:1.3rem;transition:font-size .4s cubic-bezier(.34,1.56,.64,1)}@keyframes orbit-counter{0%{transform:translate(-50%)rotate(0)}to{transform:translate(-50%)rotate(-360deg)}}.hero-orbit__dot svg{width:22px;height:22px}.hero-orbit__dot--ps{color:#31a8ff}.hero-orbit__dot--ai{color:#ff9a00}.hero-orbit__dot--ae{color:#99f}.hero-orbit__dot--lottie{color:#00ddb3}.hero-orbit__dot--stitch{color:#fbbc04}.hero-orbit__dot--atlassian{color:#0052cc}.hero-name-line{display:block;overflow:visible}.hero-name .letter{will-change:transform;transition:color .3s;display:inline-block}.hero-name[data-letter-wave]:hover .letter{animation:.6s forwards letter-bounce}.hero-name[data-letter-wave]:hover .letter:first-child{animation-delay:0s}.hero-name[data-letter-wave]:hover .letter:nth-child(2){animation-delay:40ms}.hero-name[data-letter-wave]:hover .letter:nth-child(3){animation-delay:80ms}.hero-name[data-letter-wave]:hover .letter:nth-child(4){animation-delay:.12s}.hero-name[data-letter-wave]:hover .letter:nth-child(5){animation-delay:.16s}.hero-name[data-letter-wave]:hover .letter:nth-child(6){animation-delay:.2s}.hero-name[data-letter-wave]:hover .letter:nth-child(7){animation-delay:.24s}.hero-name[data-letter-wave]:hover .letter:nth-child(8){animation-delay:.28s}@keyframes letter-bounce{0%{color:var(--text-primary);transform:translateY(0)scale(1)}40%{color:var(--accent);transform:translateY(-14px)scale(1.1)}to{color:var(--text-primary);transform:translateY(0)scale(1)}}.hero-scroll-hint{color:var(--text-secondary);font-family:var(--font-body);letter-spacing:.28em;text-transform:uppercase;opacity:.75;z-index:5;flex-direction:column;align-items:center;gap:.5rem;font-size:.72rem;text-decoration:none;transition:opacity .3s,color .3s;display:inline-flex;position:absolute;bottom:1.8rem;left:50%;transform:translate(-50%)}.hero-scroll-hint:hover{opacity:1;color:var(--accent)}.hero-scroll-hint__label{letter-spacing:.14em;text-transform:none;color:var(--accent);opacity:.85;font-size:.78rem;font-style:italic;font-weight:400}.hero-scroll-hint__chevron{width:26px;height:26px;animation:2s ease-in-out infinite hint-bounce;display:inline-flex}.hero-scroll-hint__chevron svg{width:100%;height:100%}@keyframes hint-bounce{0%,to{opacity:.5;transform:translateY(0)}50%{opacity:1;transform:translateY(6px)}}[data-theme=light] .hero-orbit__dot{background:#ffffffe6;border-color:#7c5caa4d}[data-theme=light] .hero-bubble{color:#fff;background:linear-gradient(135deg,#7c5caa,#a583d4)}@media (prefers-reduced-motion:reduce){.hero-orbit,.hero-orbit__dot,.hero-photo,.hero-scroll-hint__chevron,.hero-photo-wrapper[string=magnetic] .hero-photo{animation:none!important}}@media (width<=900px){.hero-orbit--5,.hero-orbit--6,.hero-orbit--9{display:none}.hero-orbit__dot{width:38px;height:38px;font-size:.9rem}.hero-bubble{padding:.4rem .8rem;font-size:.75rem}.hero-scroll-hint{font-size:.6rem}}@media (width<=600px){.hero-orbit--4{display:none}.hero-orbit__dot{width:34px;height:34px;font-size:.8rem}.hero-orbit__dot svg{width:18px;height:18px}}::view-transition-old(root){mix-blend-mode:normal;animation:none}::view-transition-new(root){mix-blend-mode:normal;animation:none}::view-transition-old(root){z-index:1}::view-transition-new(root){z-index:2;animation:.72s cubic-bezier(.22,1,.36,1) forwards theme-circle-in}@keyframes theme-circle-in{0%{clip-path:circle(0 at var(--tt-x,50%) var(--tt-y,50%))}to{clip-path:circle(var(--tt-r,150vmax) at var(--tt-x,50%) var(--tt-y,50%))}}@media (prefers-reduced-motion:reduce){::view-transition-new(root){animation:none}}
