*,:before,:after{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }::backdrop{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }*,:before,:after{box-sizing:border-box;border-width:0;border-style:solid;border-color:#e5e7eb}:before,:after{--tw-content: ""}html,:host{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;font-family:ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji",Segoe UI Symbol,"Noto Color Emoji";font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent}body{margin:0;line-height:inherit}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:SF Mono,Fira Code,Fira Mono,Roboto Mono,monospace;font-feature-settings:normal;font-variation-settings:normal;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-family:inherit;font-feature-settings:inherit;font-variation-settings:inherit;font-size:100%;font-weight:inherit;line-height:inherit;letter-spacing:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:transparent;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dl,dd,h1,h2,h3,h4,h5,h6,hr,figure,p,pre{margin:0}fieldset{margin:0;padding:0}legend{padding:0}ol,ul,menu{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::-moz-placeholder,textarea::-moz-placeholder{opacity:1;color:#9ca3af}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}button,[role=button]{cursor:pointer}:disabled{cursor:default}img,svg,video,canvas,audio,iframe,embed,object{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]:where(:not([hidden=until-found])){display:none}.container{width:100%}@media(min-width:640px){.container{max-width:640px}}@media(min-width:768px){.container{max-width:768px}}@media(min-width:1024px){.container{max-width:1024px}}@media(min-width:1280px){.container{max-width:1280px}}@media(min-width:1536px){.container{max-width:1536px}}.visible{visibility:visible}.static{position:static}.hidden{display:none}.transform{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.resize{resize:both}.text-\[2rem\]{font-size:2rem}.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.transition{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.ease-in-out{transition-timing-function:cubic-bezier(.4,0,.2,1)}.ease-out{transition-timing-function:cubic-bezier(0,0,.2,1)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}html{scroll-behavior:smooth;scroll-padding-top:var(--header-height);font-size:14px;line-height:1.6;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}@media(min-width:768px){html{font-size:15px}}body{font-family:var(--font-primary);background-color:var(--navy);color:var(--slate);overflow-x:hidden;margin:0;padding:0;min-height:100dvh;position:relative;transition:background-color .5s var(--transition-smooth),color .5s var(--transition-smooth)}[data-theme=light],[data-theme=dark]{background-color:var(--navy)}section[data-theme]{background-color:inherit}:root{--navy: #0a192f;--light-navy: #112240;--lightest-navy: #233554;--slate: #8892b0;--light-slate: #a8b2d1;--lightest-slate: #ccd6f6;--green: #64ffda;--green-tint: rgba(100, 255, 218, .1);--green-glow: rgba(100, 255, 218, .3);--accent-purple: #7c3aed;--accent-blue: #3b82f6;--accent-cyan: #06b6d4;--gradient-primary: linear-gradient(135deg, var(--navy) 0%, var(--light-navy) 100%);--gradient-hero: linear-gradient(135deg, var(--navy) 0%, #0f2746 50%, var(--light-navy) 100%);--gradient-accent: linear-gradient(135deg, var(--green) 0%, var(--accent-cyan) 100%);--gradient-card: linear-gradient(145deg, var(--light-navy) 0%, #1a2f4d 100%);--gradient-glass: linear-gradient(135deg, rgba(255,255,255,.1) 0%, rgba(255,255,255,.05) 100%);--font-primary: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", system-ui, sans-serif;--font-mono: "SF Mono", "Fira Code", "Fira Mono", "Roboto Mono", "Cascadia Code", monospace;--font-display: "Calibre", "Inter", -apple-system, sans-serif;--header-height: 70px;--header-height-scrolled: 60px;--section-padding: 2rem 0;--container-max-width: 1200px;--border-radius: 8px;--border-radius-lg: 12px;--border-radius-xl: 16px;--space-3xs: .125rem;--space-2xs: .25rem;--space-xs: .5rem;--space-sm: .75rem;--space-md: 1rem;--space-lg: 1.25rem;--space-xl: 1.5rem;--space-2xl: 2rem;--space-3xl: 2.5rem;--transition-base: all .3s cubic-bezier(.4, 0, .2, 1);--transition-smooth: all .5s cubic-bezier(.645, .045, .355, 1);--transition-bounce: all .6s cubic-bezier(.68, -.55, .265, 1.55);--transition-slow: all .8s cubic-bezier(.25, .46, .45, .94);--transition-morph: all .8s cubic-bezier(.34, 1.56, .64, 1);--shadow-sm: 0 2px 8px rgba(0, 0, 0, .1);--shadow-md: 0 4px 16px rgba(0, 0, 0, .15);--shadow-lg: 0 8px 32px rgba(0, 0, 0, .2);--shadow-xl: 0 16px 48px rgba(0, 0, 0, .25);--shadow-2xl: 0 24px 64px rgba(0, 0, 0, .3);--shadow-glow: 0 0 20px var(--green-glow);--shadow-glow-lg: 0 0 40px rgba(100, 255, 218, .3);--z-hidden: -1;--z-base: 1;--z-elevated: 10;--z-floating: 50;--z-sticky: 100;--z-fixed: 200;--z-modal: 300;--z-overlay: 400;--z-preloader: 9999;--mobile: 480px;--tablet: 768px;--desktop: 1024px;--wide: 1440px}[data-theme=light]{--navy: #0a192f;--light-navy: #112240;--lightest-navy: #233554;--slate: #8892b0;--light-slate: #a8b2d1;--lightest-slate: #ccd6f6;--green: #64ffda;--green-tint: rgba(100, 255, 218, .1);--green-glow: rgba(100, 255, 218, .3);--gradient-primary: linear-gradient(135deg, var(--navy) 0%, var(--light-navy) 100%);--gradient-hero: linear-gradient(135deg, var(--navy) 0%, #0f2746 50%, var(--light-navy) 100%);--gradient-card: linear-gradient(145deg, var(--light-navy) 0%, #1a2f4d 100%);--gradient-glass: linear-gradient(135deg, rgba(255,255,255,.1) 0%, rgba(255,255,255,.05) 100%)}[data-theme=dark]{--navy: #0a0a0a;--light-navy: #1a1a1a;--lightest-navy: #2a2a2a;--slate: #a0a0a0;--light-slate: #c0c0c0;--lightest-slate: #e0e0e0;--green: #00ffcc;--green-tint: rgba(0, 255, 204, .15);--green-glow: rgba(0, 255, 204, .4);--gradient-primary: linear-gradient(135deg, #0a0a0a 0%, #1a1a1a 100%);--gradient-hero: linear-gradient(135deg, #0a0a0a 0%, #151515 50%, #1a1a1a 100%);--gradient-card: linear-gradient(145deg, #1a1a1a 0%, #252525 100%);--gradient-glass: linear-gradient(135deg, rgba(255,255,255,.05) 0%, rgba(255,255,255,.02) 100%);--shadow-sm: 0 2px 8px rgba(0, 0, 0, .3);--shadow-md: 0 4px 16px rgba(0, 0, 0, .4);--shadow-lg: 0 8px 32px rgba(0, 0, 0, .5);--shadow-xl: 0 16px 48px rgba(0, 0, 0, .6);--shadow-2xl: 0 24px 64px rgba(0, 0, 0, .7)}h1,h2,h3,h4,h5,h6{color:var(--lightest-slate);font-weight:700;line-height:1.1;margin-bottom:1rem;font-family:var(--font-display)}h1{font-size:clamp(2rem,6vw,3rem);font-weight:800;letter-spacing:-.02em;background:linear-gradient(135deg,var(--lightest-slate) 0%,var(--green) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}h2{font-size:clamp(1.5rem,4vw,2rem);letter-spacing:-.01em;position:relative}h3{font-size:clamp(1.2rem,3vw,1.5rem);font-weight:600}h4{font-size:clamp(1rem,2.5vw,1.25rem)}p{margin-bottom:1rem;line-height:1.6;font-size:clamp(.9rem,2vw,1rem)}a{color:var(--green);text-decoration:none;transition:all .3s ease;position:relative}a:hover{color:var(--lightest-slate)}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.text-center{text-align:center}.text-left{text-align:left}.text-right{text-align:right}.mb-0{margin-bottom:0}.mt-0{margin-top:0}.mb-sm{margin-bottom:var(--space-sm)}.mt-sm{margin-top:var(--space-sm)}.mb-md{margin-bottom:var(--space-md)}.mt-md{margin-top:var(--space-md)}.mb-lg{margin-bottom:var(--space-lg)}.mt-lg{margin-top:var(--space-lg)}.p-0{padding:0}.p-sm{padding:var(--space-sm)}.p-md{padding:var(--space-md)}.p-lg{padding:var(--space-lg)}.w-full{width:100%}.h-full{height:100%}.min-h-screen{min-height:100vh}.min-h-screen-dvh{min-height:100dvh}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.flex-wrap{flex-wrap:wrap}.flex-1{flex:1}.gap-xs{gap:var(--space-xs)}.gap-sm{gap:var(--space-sm)}.gap-md{gap:var(--space-md)}.gap-lg{gap:var(--space-lg)}.relative{position:relative}.absolute{position:absolute}.fixed{position:fixed}.sticky{position:sticky}.overflow-hidden{overflow:hidden}.overflow-auto{overflow:auto}.overflow-x-auto{overflow-x:auto}.overflow-y-auto{overflow-y:auto}.pointer-events-none{pointer-events:none}.pointer-events-auto{pointer-events:auto}.select-none{-webkit-user-select:none;-moz-user-select:none;user-select:none}.select-text{-webkit-user-select:text;-moz-user-select:text;user-select:text}.opacity-0{opacity:0}.opacity-50{opacity:.5}.opacity-100{opacity:1}.visibility-hidden{visibility:hidden}.visibility-visible{visibility:visible}.transition-all{transition:all .3s ease}.transition-colors{transition:color .3s ease,background-color .3s ease}.transition-transform{transition:transform .3s ease}.transform{transform:translate(0) translateY(0) rotate(0) scale(1)}.transform-gpu{transform:translateZ(0)}.hover-lift:hover{transform:translateY(-2px);transition:transform .3s ease}.hover-glow:hover{box-shadow:var(--shadow-glow);transition:box-shadow .3s ease}.focus-ring:focus-visible{outline:2px solid var(--green);outline-offset:2px;border-radius:2px}.glass-effect{background:#ffffff1a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.2)}.gradient-text{background:linear-gradient(135deg,var(--lightest-slate) 0%,var(--green) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.btn{display:inline-flex;align-items:center;gap:var(--space-sm);padding:var(--space-md) var(--space-lg);border:2px solid;border-radius:var(--border-radius);font-family:var(--font-mono);font-size:.85rem;text-decoration:none;transition:var(--transition-smooth);cursor:pointer;position:relative;overflow:hidden;font-weight:600;letter-spacing:.02em}.btn:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);transition:left .6s}.btn:hover:before{left:100%}.btn-primary{border-color:var(--green);color:var(--navy);background-image:radial-gradient(circle at center,var(--green) 0%,var(--green-glow) 100%);box-shadow:0 10px 30px #00000080}.btn-primary:hover{transform:translateY(-3px);box-shadow:0 0 20px var(--green-glow);background:transparent;color:var(--green);background-image:radial-gradient(circle at center,transparent 0%,transparent 100%)}.btn-secondary{background:transparent;border-color:var(--green);color:var(--green);box-shadow:0 10px 30px #00000080}.btn-secondary:hover{color:var(--navy);transform:translateY(-3px);box-shadow:0 0 20px var(--green-glow);background-image:radial-gradient(circle at center,var(--green) 0%,var(--green-glow) 100%)}.btn i{font-size:.85rem;transition:all .3s ease}.btn:hover i{transform:translate(2px)}.hero-cta{display:flex;gap:var(--space-md);flex-wrap:wrap;opacity:0;visibility:hidden}@media(max-width:480px){.hero-cta{flex-direction:column;align-items:flex-start}.hero-cta .btn{width:100%;max-width:200px;justify-content:center}}.contact-card,.social-card{background:var(--gradient-card);text-decoration:none;color:inherit;border:1px solid rgba(255,255,255,.1);display:flex;align-items:center;gap:var(--space-md);position:relative;overflow:hidden;flex:1 1 auto;min-width:-moz-fit-content;min-width:fit-content;width:200px;min-height:100px;border-radius:var(--border-radius-lg);padding:var(--space-sm);transition:var(--transition-base);transform-style:preserve-3d;perspective:1000px;box-shadow:0 4px 20px #00000026,inset 0 1px #ffffff1a,0 0 0 1px #ffffff0d}.contact-card:before,.social-card:before{content:"";position:absolute;inset:0 0 0 -100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,var(--green-tint),transparent);transition:left .6s ease-in-out;border-radius:var(--border-radius-lg);opacity:0;pointer-events:none}.contact-card:hover:before,.social-card:hover:before{left:100%;opacity:.6}.contact-card:hover,.social-card:hover{border-color:var(--green-glow);transform:translateY(-8px) rotateX(5deg) rotateY(2deg);box-shadow:0 25px 50px #00000040,inset 0 1px #ffffff26,0 0 20px var(--green-glow)}.contact-card:hover:after,.social-card:hover:after{opacity:.3}.contact-card:after,.social-card:after{content:"";position:absolute;inset:-2px;background:linear-gradient(180deg,var(--green) 0%,var(--green-glow) 25%,var(--green-tint) 50%,var(--green-glow) 75%,var(--accent-cyan) 100%);border-radius:calc(var(--border-radius-lg) + 2px);opacity:0;transition:opacity .4s ease;z-index:-1;filter:blur(8px)}.contact-card:active,.social-card:active{transform:translateY(-4px) rotateX(2deg) rotateY(1deg);transition-duration:.1s}.contact-icon,.social-icon{width:48px;height:48px;background:var(--green-tint);border-radius:50%;display:grid;align-items:center;justify-content:center;color:var(--navy);font-size:1.8rem;flex-shrink:0;position:relative;z-index:2;transition:var(--transition-base);background-image:radial-gradient(circle at center,var(--green) 0%,var(--navy) 100%);box-shadow:0 2px 5px #00000080}.contact-card:hover .contact-icon,.social-card:hover .social-icon{color:var(--green);background-image:radial-gradient(circle at center,var(--green-tint) 0%,var(--green-glow) 50%,var(--green) 100%);box-shadow:0 0 20px var(--green-glow)}.contact-info,.social-info{display:flex;flex-direction:column;flex-wrap:wrap;text-align:left;flex-grow:1;position:relative;z-index:2;min-width:0;overflow:hidden}.contact-type,.social-platform{font-size:.95rem;color:var(--lightest-slate);font-weight:700;margin-bottom:var(--space-xs);white-space:normal;overflow:visible;text-overflow:unset;line-height:1.2}.contact-value,.social-username{font-size:.85rem;color:var(--light-slate);font-weight:500;white-space:normal;overflow:visible;text-overflow:unset;line-height:1.3}.contact-description-small{font-size:.75rem;color:var(--slate);margin-top:var(--space-xs);margin-bottom:0;font-style:italic;white-space:normal;overflow:visible;text-overflow:unset;line-height:1.2}.project-card{background:var(--gradient-card);border-radius:var(--border-radius);padding:var(--space-lg);transition:var(--transition-bounce);border:1px solid rgba(255,255,255,.1);width:300px;flex-shrink:0;min-height:280px;display:flex;flex-direction:column;position:relative;overflow:hidden}.project-card:hover{transform:translateY(-5px);border-color:var(--green);box-shadow:var(--shadow-lg)}.project-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-md);position:relative;z-index:2}.project-featured-badge{background:var(--green);color:var(--navy);padding:var(--space-xs) var(--space-sm);border-radius:6px;font-size:.6rem;font-family:var(--font-mono);font-weight:700;text-align:center;letter-spacing:.05em}.project-links{display:flex;gap:var(--space-sm)}.project-link{color:var(--light-slate);font-size:1.1rem;transition:var(--transition-base);padding:var(--space-xs);border-radius:4px;position:relative;z-index:2}.project-title{font-size:1.1rem;margin-bottom:var(--space-sm);color:var(--lightest-slate);position:relative;z-index:2;font-weight:700}.project-description{color:var(--light-slate);line-height:1.5;flex-grow:1;margin-bottom:var(--space-md);position:relative;z-index:2;font-size:.85rem}.project-technologies{display:flex;flex-wrap:wrap;gap:var(--space-xs);position:relative;z-index:2}.technology-tag{background:var(--navy);color:var(--green);padding:var(--space-xs) var(--space-sm);border-radius:12px;font-size:.65rem;font-family:var(--font-mono);border:1px solid var(--green-tint);font-weight:500}.card-3d{position:relative;background:var(--gradient-card);border-radius:var(--border-radius-lg);padding:var(--space-sm);transition:all .6s cubic-bezier(.23,1,.32,1);border:1px solid rgba(255,255,255,.1);transform-style:preserve-3d;perspective:1000px;box-shadow:0 4px 20px #00000026,inset 0 1px #ffffff1a,0 0 0 1px #ffffff0d}.card-3d:before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,rgba(255,255,255,.1) 0%,transparent 25%,transparent 75%,rgba(255,255,255,.05) 100%);border-radius:var(--border-radius-lg);opacity:0;transition:opacity .4s ease;pointer-events:none}.card-3d:after{content:"";position:absolute;inset:-2px;background:linear-gradient(135deg,var(--green) 0%,transparent 30%,transparent 70%,var(--accent-cyan) 100%);border-radius:calc(var(--border-radius-lg) + 2px);opacity:0;transition:opacity .4s ease;z-index:-1;filter:blur(8px)}.card-3d:hover{transform:translateY(-8px) rotateX(5deg) rotateY(2deg);box-shadow:0 25px 50px #00000040,inset 0 1px #ffffff26,0 0 20px var(--green-glow);border-color:#64ffda4d}.card-3d:hover:before{opacity:1}.card-3d:hover:after{opacity:.6}.card-3d:active{transform:translateY(-4px) rotateX(2deg) rotateY(1deg);transition-duration:.1s}.card-3d-project{min-height:320px;display:flex;flex-direction:column}.card-3d-contact{min-height:-moz-fit-content;min-height:fit-content;display:flex;align-items:center}.card-3d-skill{padding:var(--space-xl)}.card-3d-timeline{min-height:180px;display:flex;flex-direction:column;justify-content:center}.card-3d-content{position:relative;z-index:2;transform:translateZ(20px);height:100%;display:flex;flex-direction:column}.card-3d-contact .card-3d-content{position:relative;z-index:2;transform:translateZ(20px);height:100%;width:auto;display:grid;grid-template-columns:1fr 3fr}.card-3d-contact:hover .contact-icon,.card-3d-contact:hover .social-icon{background:var(--green);color:var(--navy);transform:scale(1.1)}.card-3d:focus-within{outline:2px solid var(--green);outline-offset:2px}@keyframes cardAppear{0%{opacity:0;transform:translateY(30px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.card-3d-appear{animation:cardAppear .6s cubic-bezier(.34,1.56,.64,1) forwards}@media(min-width:768px){.card-3d:hover{transform:translateY(-4px);box-shadow:0 15px 30px #0003,inset 0 1px #ffffff1a}.card-3d:after{display:none}}@media(prefers-reduced-motion:reduce){.card-3d{transition:transform .3s ease,box-shadow .3s ease}.card-3d:hover{transform:translateY(-2px)}}.nav-desktop{display:none}@media(min-width:768px){.nav-desktop{display:flex;align-items:center;gap:1.5rem}}.nav-list{display:flex;list-style:none;gap:1.5rem;align-items:center}.nav-link{color:var(--lightest-slate);font-size:.8rem;font-family:var(--font-mono);text-decoration:none;padding:.5rem .75rem;transition:all .3s ease;position:relative;font-weight:500;letter-spacing:.02em}.nav-link:before{content:"▹";color:var(--green);margin-right:.25rem;font-size:.7rem;transition:all .3s ease}.nav-link:after{content:"";position:absolute;bottom:0;left:50%;width:0;height:2px;background:var(--green);transition:all .3s ease;transform:translate(-50%)}.nav-link:hover:before{transform:translate(-2px)}.nav-link:hover:after{width:80%}.nav-link:hover,.nav-link.active{color:var(--green)}.nav-link.active:after{width:80%}.theme-toggle{background:var(--green-tint);border:none;color:var(--navy);cursor:pointer;padding:.5rem;border-radius:50%;transition:var(--transition-base);width:40px;height:40px;display:flex;align-items:center;padding-top:10px;justify-content:center;position:relative;overflow:hidden;margin-left:1rem;background-image:radial-gradient(circle at center,var(--green) 0%,var(--navy) 100%);box-shadow:0 5px 10px #00000080}.theme-toggle:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);transition:left .6s}.theme-toggle:hover:before{left:100%}.theme-toggle:hover{color:var(--green);box-shadow:0 0 20px var(--green-glow);background-image:radial-gradient(circle at center,var(--navy) 0%,var(--green) 100%)}.theme-toggle i{font-size:1.1rem;transition:all .3s ease}.mobile-menu-button{display:block;background:none;border:none;color:var(--green);font-size:1.5rem;cursor:pointer;padding:.75rem;z-index:var(--z-modal);position:relative;width:44px;height:44px;transition:var(--transition-base);border-radius:8px;display:flex;align-items:center;justify-content:center}.mobile-menu-button:hover{background:var(--green-tint);transform:scale(1.05);box-shadow:0 0 20px var(--green-glow)}.mobile-menu-button i{transition:all .3s ease}@media(min-width:768px){.mobile-menu-button{display:none}}.mobile-menu-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:var(--navy);backdrop-filter:blur(15px);-webkit-backdrop-filter:blur(15px);z-index:9998;opacity:0;visibility:hidden}.mobile-menu-overlay.active{opacity:1;visibility:visible}.mobile-menu{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%) scale(.9);width:min(70dvw,300px);max-height:80dvh;background:var(--light-navy);border-radius:12px;z-index:9999;padding:2rem;box-shadow:0 24px 64px #0000004d;opacity:0;visibility:hidden;transition:all .5s cubic-bezier(.34,1.56,.64,1);border:1px solid rgba(100,255,218,.2);overflow:hidden;display:flex;flex-direction:column}.mobile-menu:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--green),transparent)}.mobile-menu.active{transform:translate(-50%,-50%) scale(1);opacity:1;visibility:visible}.mobile-menu.hidden{transform:translate(-50%,-50%) scale(.9);opacity:0;visibility:hidden}.mobile-menu-header{display:grid;grid-template-columns:1fr auto auto;align-items:center;gap:1.5rem;padding-bottom:1.5rem;border-bottom:1px solid rgba(255,255,255,.1);position:absolute;top:3rem;left:10%;right:10%;flex-shrink:0}.mobile-menu-theme-toggle{background:var(--green-tint);border:none;color:var(--navy);font-size:1.1rem;cursor:pointer;width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:var(--transition-morph);position:absolute;top:-20%;right:90%;overflow:hidden;background-image:radial-gradient(circle at center,var(--green) 0%,var(--navy) 100%);box-shadow:0 5px 15px #00000080}.mobile-menu-theme-toggle:hover{background-image:radial-gradient(circle at center,var(--navy) 0%,var(--green) 100%);box-shadow:0 0 20px var(--green-glow);color:var(--green)}.mobile-menu-title{margin-left:3rem;color:var(--green);font-family:var(--font-mono);font-size:.9rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;text-align:center}.mobile-menu-close{background:var(--green-tint);border:none;color:var(--navy);font-size:1.1rem;cursor:pointer;width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:var(--transition-morph);position:absolute;left:90%;top:-20%;overflow:hidden;background-image:radial-gradient(circle at center,var(--green) 0%,var(--navy) 100%);box-shadow:0 5px 15px #00000080}.mobile-menu-close:hover{color:var(--green);background-image:radial-gradient(circle at center,var(--green-tint) 0%,var(--green-glow) 50%,var(--green) 100%);box-shadow:0 0 20px var(--green-glow)}.mobile-nav-list{list-style:none;display:flex;flex-direction:column;gap:.5rem;overflow-y:auto;max-height:50dvh;padding:1.5rem;margin-top:4rem}.mobile-nav-list::-webkit-scrollbar{width:4px}.mobile-nav-list::-webkit-scrollbar-track{background:#ffffff1a;border-radius:2px}.mobile-nav-list::-webkit-scrollbar-thumb{background:var(--green);border-radius:2px}.mobile-nav-link{color:var(--lightest-slate);font-size:1rem;font-family:var(--font-primary);text-decoration:none;padding:1rem 1.5rem;border-radius:8px;transition:var(--transition-base);display:flex;align-items:center;gap:1.5rem;background:#ffffff08;border:1px solid transparent;position:relative;overflow:hidden;font-weight:500;min-height:54px;box-shadow:0 2px 5px #00000080}.mobile-nav-link:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,var(--green-tint),transparent);transition:left .6s}.mobile-nav-link:after{content:"→";position:absolute;right:1.5rem;opacity:0;transform:translate(-10px);transition:all .3s ease;color:var(--green)}.mobile-nav-link i{width:20px;text-align:center;font-size:1.1rem;color:var(--green);transition:all .3s ease;position:relative;z-index:2}.mobile-nav-link span{position:relative;z-index:2;transition:all .3s ease;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.mobile-nav-link:hover:before{left:100%}.mobile-nav-link:hover:after{opacity:1;transform:translate(0)}.mobile-nav-link:hover,.mobile-nav-link.active{background:var(--green-tint);color:var(--green);transform:translate(2px) scale(1.02);border-color:var(--green);box-shadow:0 2px 5px #00000080;background:linear-gradient(180deg,var(--green) 0%,var(--green-glow) 25%,var(--green-tint) 50%,var(--green-glow) 75%,var(--accent-cyan) 100%);opacity:.6;transition:var(--transition-morph);z-index:1}.mobile-nav-link:hover{box-shadow:0 0 20px var(--green-glow)}.mobile-nav-link:hover i,.mobile-nav-link.active i{transform:scale(1.1);color:var(--lightest-slate)}.mobile-nav-link:hover span,.mobile-nav-link.active span{color:var(--lightest-slate)}.header{z-index:1000}.header.menu-open{background:#0a192ff2!important;-webkit-backdrop-filter:blur(20px) saturate(200%)!important;backdrop-filter:blur(20px) saturate(200%)!important}.form-group{margin-bottom:1.5rem}.form-label{display:block;margin-bottom:.5rem;color:var(--lightest-slate);font-weight:600;font-size:.9rem}.form-input,.form-textarea,.form-select{width:100%;padding:1rem 1.25rem;background:var(--light-navy);border:1px solid rgba(255,255,255,.1);border-radius:8px;color:var(--lightest-slate);font-family:var(--font-primary);font-size:.95rem;transition:all .3s ease}.form-input:focus,.form-textarea:focus,.form-select:focus{outline:none;border-color:var(--green);box-shadow:0 0 0 3px var(--green-tint)}.form-textarea{min-height:120px;resize:vertical}.form-select{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24' stroke='%2364ffda'%3E%3Cpath stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M19 9l-7 7-7-7'%3E%3C/path%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 1rem center;background-size:1rem}.form-checkbox{display:flex;align-items:center;gap:.75rem;cursor:pointer}.form-checkbox input[type=checkbox]{width:18px;height:18px;accent-color:var(--green)}.form-radio{display:flex;align-items:center;gap:.75rem;cursor:pointer}.form-radio input[type=radio]{width:18px;height:18px;accent-color:var(--green)}.form-error{color:#ff6b6b;font-size:.8rem;margin-top:.5rem;display:flex;align-items:center;gap:.5rem}.form-success{color:var(--green);font-size:.9rem;padding:1rem;background:var(--green-tint);border-radius:8px;border:1px solid var(--green)}#preloader{position:fixed;top:0;left:0;width:100%;height:100%;background:var(--gradient-primary);z-index:var(--z-preloader);display:flex;justify-content:center;align-items:center;transition:opacity .8s cubic-bezier(.645,.045,.355,1),visibility .8s}#preloader.hidden{opacity:0;visibility:hidden;pointer-events:none}.preloader-content{text-align:center;position:relative}.preloader-spinner{width:60px;height:60px;border:3px solid transparent;border-top:3px solid var(--green);border-right:3px solid var(--accent-cyan);border-bottom:3px solid var(--accent-purple);border-left:3px solid var(--accent-blue);border-radius:50%;animation:spinMorph 2s cubic-bezier(.68,-.55,.265,1.55) infinite;margin:0 auto var(--space-lg);position:relative;filter:drop-shadow(0 0 10px var(--green-glow))}.preloader-spinner:before{content:"";position:absolute;inset:-6px;border:2px solid var(--green-tint);border-radius:50%;animation:pulse 2s ease-in-out infinite;opacity:.6}.preloader-spinner:after{content:"";position:absolute;inset:-12px;border:1px solid var(--green-tint);border-radius:50%;animation:pulse 3s ease-in-out infinite;opacity:.3}.preloader-text{color:var(--green);font-family:var(--font-mono);font-size:.9rem;font-weight:500;letter-spacing:.1em;text-transform:uppercase;position:relative}.preloader-text:after{content:"";position:absolute;bottom:-4px;left:0;width:100%;height:2px;background:var(--green);transform:scaleX(0);animation:loadingBar 2s ease-in-out infinite}.map-section{display:flex;flex-direction:column;align-items:center;width:100%}.map-toggle{background:transparent;border:2px solid var(--green);color:var(--green);padding:var(--space-md) var(--space-lg);border-radius:var(--border-radius);font-family:var(--font-mono);font-size:.85rem;cursor:pointer;transition:all .6s cubic-bezier(.68,-.55,.265,1.55);display:inline-flex;align-items:center;gap:var(--space-sm);font-weight:600}.map-toggle:hover{background:var(--green);color:var(--navy);transform:translateY(-2px);box-shadow:var(--shadow-glow)}.map-container{width:100%;transition:linear .5s cubic-bezier(.4,0,.2,1);max-height:0;overflow:hidden;opacity:0;transform-origin:left top 1px}.map-container.active{max-height:500px;opacity:1;transform:scaleY(1) translateY(20px);padding:1rem 0}.map-iframe{width:100%;height:400px;border:none;border-radius:12px;box-shadow:0 10px 30px #0000004d;transition:all .4s ease .1s;opacity:0;transform:translateY(10px)}.map-container.active .map-iframe{opacity:1;transform:translateY(0)}@keyframes slideDownClose{0%{transform:scaleY(1) translateY(0);opacity:1}to{transform:scaleY(0) translateY(20px);opacity:0}}@keyframes slideUpOpen{0%{transform:scaleY(0) translateY(20px);opacity:0}to{transform:scaleY(1) translateY(0);opacity:1}}.map-container.closing{animation:slideDownClose .5s cubic-bezier(.4,0,.2,1) forwards}.map-container.opening{animation:slideUpOpen .5s cubic-bezier(.4,0,.2,1) forwards}@media(max-width:767px){.map-iframe{height:300px}.map-container.active{max-height:300px}}#header:after{content:"";position:absolute;bottom:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--green),transparent)}.header{position:fixed;top:0;left:0;width:100%;height:var(--header-height);backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);border-bottom:1px solid rgba(255,255,255,.08);z-index:var(--z-fixed)}.header-container{display:flex;align-items:center;justify-content:space-between;height:100%;position:relative}.logo{font-size:1.3rem;font-weight:800;color:var(--lightest-slate);text-decoration:none;transition:all .3s ease;font-family:var(--font-display);position:relative;z-index:var(--z-sticky);display:flex;align-items:center;gap:.25rem}.logo:hover{color:var(--green);transform:translateY(-1px)}.logo-accent{color:var(--green);position:relative}.logo-accent:after{content:"";position:absolute;bottom:2px;left:0;width:100%;height:2px;background:var(--green);transform:scaleX(0);transition:transform .3s ease}.logo:hover .logo-accent:after{transform:scaleX(1)}.section:after{content:"";position:absolute;bottom:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--green),transparent)}.section{min-height:calc(100dvh - var(--header-height) - 1px);display:flex;position:relative;padding:var(--section-padding);justify-content:center;align-items:center}.section-content{width:100%;position:relative;z-index:var(--z-base)}.section-title{position:relative;margin-top:0;margin-bottom:var(--space-lg);display:flex;align-items:center;gap:var(--space-sm);font-family:var(--font-display)}.section-title:before{content:attr(data-number);color:var(--green);font-family:var(--font-mono);font-size:.8rem;font-weight:500;letter-spacing:.05em}.section-title:after{content:"";display:block;flex:1;max-width:200px;height:1px;background:linear-gradient(90deg,var(--green),transparent);margin-left:var(--space-md)}.container{width:100%;max-width:var(--container-max-width);margin:0 auto;padding:0 1rem}.container-narrow{max-width:1000px}.container-wide{max-width:1600px}.grid{display:grid}.grid-cols-1{grid-template-columns:1fr}.grid-cols-2{grid-template-columns:repeat(2,1fr)}.grid-cols-3{grid-template-columns:repeat(3,1fr)}.grid-cols-4{grid-template-columns:repeat(4,1fr)}@media(min-width:768px){.grid-cols-md-2{grid-template-columns:repeat(2,1fr)}.grid-cols-md-3{grid-template-columns:repeat(3,1fr)}.grid-cols-md-4{grid-template-columns:repeat(4,1fr)}}.footer{background:var(--light-navy);border-top:1px solid rgba(255,255,255,.1);padding:var(--space-sm) 0;text-align:center;position:relative;min-height:auto}.footer-content{display:flex;flex-direction:column;align-items:center;gap:var(--space-md);padding:0}.footer-text{color:var(--light-slate);font-size:.9rem;margin:0}.footer-links{display:flex;gap:var(--space-lg);margin:var(--space-sm) 0}.footer-link{color:var(--light-slate);font-size:.85rem;text-decoration:none;transition:var(--transition-base);padding:var(--space-xs) var(--space-sm);border-radius:var(--border-radius);font-weight:500}.footer-link:hover{color:var(--green);background:var(--green-tint)}.footer-credits{margin-top:var(--space-sm)}.footer-credits p{color:var(--slate);font-size:.8rem;margin:0;font-family:var(--font-mono)}#hero.section.full-height{background:var(--gradient-hero);padding:calc(var(--header-height) + 2rem) 0 2rem;transition:min-height .6s cubic-bezier(.25,.46,.45,.94);overflow:hidden}#hero:before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 20% 80%,rgba(100,255,218,.1) 0%,transparent 50%),radial-gradient(circle at 80% 20%,rgba(59,130,246,.05) 0%,transparent 50%);pointer-events:none}.hero-content{max-width:600px;position:relative;z-index:1;padding:0 1rem}@media(min-width:768px){.hero-content{padding:0}}.hero-greeting{color:var(--green);font-family:var(--font-mono);font-size:clamp(.9rem,3vw,1rem);margin-bottom:1rem;opacity:0;animation:fadeInUp .8s cubic-bezier(.645,.045,.355,1) .2s forwards;font-weight:500;letter-spacing:.05em;min-height:1.4em;visibility:hidden}.hero-title{font-size:clamp(1.75rem,8vw,2.5rem);font-weight:800;line-height:1.05;margin-bottom:.5rem;opacity:0;animation:fadeInUp .8s cubic-bezier(.645,.045,.355,1) .4s forwards;letter-spacing:-.02em;min-height:1.2em;color:var(--lightest-slate);visibility:hidden}.hero-subtitle{font-size:clamp(1.15rem,3vw,1.4rem);color:var(--light-slate);margin-bottom:1.5rem;opacity:0;animation:fadeInUp .8s cubic-bezier(.645,.045,.355,1) .6s forwards;font-weight:600;min-height:1.3em;visibility:hidden}.hero-description{font-size:clamp(.9rem,2.5vw,1rem);max-width:500px;margin-bottom:2rem;opacity:0;line-height:1.6;color:var(--slate);min-height:4em;visibility:hidden}.hero-cta{display:flex;flex-direction:row;gap:1.5rem;flex-wrap:wrap;opacity:0;visibility:hidden}@media(max-width:480px){.hero-cta{flex-direction:row;align-items:center}.hero-cta .btn{display:flex;width:100%;max-width:180px;justify-content:center}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}#about{background:var(--navy)}.about-grid{display:flex;flex-direction:row;flex-wrap:nowrap;gap:var(--space-3xl)}.about-content{display:flex;flex-direction:column;gap:var(--space-lg)}.about-text{font-size:.95rem;line-height:1.7;color:var(--light-slate)}.about-text p{margin-bottom:var(--space-md)}.about-text p:last-child{margin-bottom:0}.about-stats{text-align:center;display:flex;flex-direction:row;flex-wrap:nowrap;position:relative;overflow:hidden;gap:var(--space-sm);padding:1.5rem}.stat-item{display:flex;flex-direction:column;width:100%;text-align:center;padding:var(--space-md);background:var(--gradient-card);border-radius:var(--border-radius);border:1px solid rgba(255,255,255,.1);transition:var(--transition-base);position:relative;overflow:hidden;max-height:-moz-fit-content;max-height:fit-content}.stat-item:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,var(--green-tint),transparent);transition:left .6s}.stat-item:hover:before{left:100%}.stat-item:hover{transform:translateY(-2px);box-shadow:0 0 20px var(--green-glow)}.stat-icon{margin-bottom:var(--space-sm);position:relative;z-index:2;width:45px;height:45px;border-radius:50%;display:grid;align-self:center;align-items:center;justify-content:center;color:var(--navy);font-size:1.6rem;flex-shrink:0;transition:none;background-image:radial-gradient(circle at center,var(--green) 0%,var(--navy) 100%);box-shadow:0 10px 30px #00000080}.stat-item:hover .stat-icon{color:var(--green);background-image:radial-gradient(circle at center,var(--green-tint) 0%,var(--green-glow) 50%,var(--green) 100%);box-shadow:0 0 20px var(--green-glow)}.stat-number{display:block;font-size:1.5rem;font-weight:800;color:var(--green);margin-bottom:var(--space-xs);position:relative;z-index:2;font-family:var(--font-display)}.stat-label{font-size:.75rem;color:var(--light-slate);line-height:1.3;position:relative;z-index:2;font-weight:500}.about-image{position:relative;display:flex;justify-content:center;align-items:center}.image-container{top:0;left:0;width:35cqw;height:65cqh;border-radius:var(--border-radius);position:relative;display:flex;justify-content:center;align-items:center;overflow:hidden;box-shadow:var(--shadow-lg);border:2px solid var(--green);transition:var(--transition-smooth)}.image-container:before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,var(--green-tint) 0%,transparent 50%);opacity:0;transition:var(--transition-base);z-index:2}.image-container:hover:before{opacity:1}.image-container:hover{box-shadow:var(--shadow-glow);transform:scale(1.02)}.profile-image{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;-o-object-position:center 20%;object-position:center 20%;transition:var(--transition-slow);filter:grayscale(100%) contrast(1.1)}.image-container:hover .profile-image{transform:scale(1.05);filter:grayscale(0%) contrast(1)}.image-placeholder{width:100%;height:100%;background:var(--gradient-card);display:flex;flex-direction:column;align-items:center;justify-content:center;color:var(--green);font-family:var(--font-mono);gap:var(--space-sm);font-size:.8rem}.image-placeholder i{font-size:2rem}@media(min-width:768px){.image-container{max-width:60cqw;max-height:35cqh}}@media(max-width:767px){.about-grid{flex-wrap:wrap;justify-content:center}}@media(min-width:1024px){.image-container{margin-top:-4cqw;max-width:35cqw;max-height:65cqh}}#skills{background:var(--light-navy);flex-direction:column}.skills-grid{display:grid;grid-template-columns:1fr;gap:var(--space-2xl);margin-bottom:var(--space-2xl)}@media(min-width:768px){.skills-grid{grid-template-columns:1fr 1fr;gap:var(--space-3xl);margin-bottom:var(--space-3xl)}}.skills-category{background:var(--gradient-card);border-radius:var(--border-radius-lg);padding:var(--space-xl);border:1px solid rgba(255,255,255,.08);transition:all .3s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden}.skills-category:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,var(--green-tint),transparent);transition:left .6s ease}.skills-category:hover:before{left:100%}.skills-category:hover{border-color:var(--green);transform:translateY(-2px);box-shadow:var(--shadow-lg)}.skills-category-title{display:flex;align-items:center;gap:var(--space-md);margin-bottom:var(--space-lg);font-size:1.1rem;color:var(--lightest-slate);font-weight:700;position:relative;z-index:2}.skills-category-icon{color:var(--green);font-size:1.1rem;width:20px;text-align:center}.skill-item{margin-bottom:var(--space-lg);position:relative;z-index:2}.skill-item:last-child{margin-bottom:0}.skill-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-xs)}.skill-name{color:var(--lightest-slate);font-size:.9rem;font-weight:600;letter-spacing:.3px}.skill-percentage{color:var(--green);font-family:var(--font-mono);font-size:.75rem;font-weight:700;background:#64ffda1a;padding:var(--space-xs) var(--space-sm);border-radius:6px;border:1px solid rgba(100,255,218,.2)}.skill-bar-container{width:100%;height:5px;background:var(--navy);border-radius:8px;overflow:hidden;position:relative;border:1px solid rgba(255,255,255,.05)}.skill-bar{height:100%;background:linear-gradient(90deg,var(--green) 0%,var(--accent-cyan) 50%,var(--green) 100%);border-radius:8px;transition:width 1.2s cubic-bezier(.25,.46,.45,.94);width:0%;position:relative;box-shadow:0 0 8px #64ffda33}.skill-bar:before{content:"";position:absolute;inset:0;background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent);animation:skillShimmer 2s infinite;border-radius:8px}@keyframes skillShimmer{0%{transform:translate(-100%)}to{transform:translate(100%)}}.skill-description{font-size:.75rem;color:var(--slate);margin-top:var(--space-xs);line-height:1.4;font-style:italic;padding-left:var(--space-sm);border-left:1px solid var(--green-tint)}.skills-tags{background:var(--gradient-card);border-radius:var(--border-radius-lg);padding:var(--space-xl);border:1px solid rgba(255,255,255,.08);text-align:center;position:relative;overflow:hidden}.skills-tags:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(100,255,218,.05),transparent);transition:left .6s ease}.skills-tags:hover:before{left:100%}.skills-tags-title{margin-bottom:var(--space-lg);font-size:1.1rem;color:var(--lightest-slate);font-weight:700;position:relative;z-index:2}.tags-grid{display:flex;flex-wrap:wrap;gap:var(--space-sm);justify-content:center;position:relative;z-index:2}.tag{background:linear-gradient(135deg,var(--navy) 0%,var(--light-navy) 100%);color:var(--lightest-slate);padding:var(--space-xs) var(--space-md);border-radius:16px;font-size:.8rem;font-family:var(--font-mono);border:1px solid rgba(100,255,218,.15);transition:all .2s cubic-bezier(.4,0,.2,1);display:flex;align-items:center;gap:var(--space-xs);font-weight:600;position:relative;overflow:hidden}.tag:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,var(--green-tint),transparent);transition:left .4s ease}.tag:hover:before{left:100%}.tag:hover{border-color:var(--green);transform:translateY(-2px);box-shadow:0 2px 8px #64ffda1a,0 0 0 1px #64ffda0d;color:var(--green)}.tag-icon{font-size:.7rem;color:var(--green);transition:all .2s ease}.tag:hover .tag-icon{transform:scale(1.1);color:var(--accent-cyan)}@media(max-width:767px){.skills-grid{gap:var(--space-xl);margin-bottom:var(--space-xl)}.skills-category,.skills-tags{padding:var(--space-lg)}.tags-grid{gap:var(--space-xs)}.tag{padding:calc(var(--space-xs) - 2px) var(--space-sm);font-size:.75rem}.skill-item{margin-bottom:var(--space-md)}}@media(min-width:1024px){.skills-grid{gap:var(--space-3xl)}.skills-category{padding:var(--space-xl)}}@media(min-width:1440px){.skills-grid{gap:var(--space-4xl)}}.skill-item{opacity:0;transform:translateY(15px);animation:fadeInUpCompact .5s ease forwards}.skill-item:nth-child(1){animation-delay:.05s}.skill-item:nth-child(2){animation-delay:.1s}.skill-item:nth-child(3){animation-delay:.15s}.skill-item:nth-child(4){animation-delay:.2s}.skill-item:nth-child(5){animation-delay:.25s}.skill-item:nth-child(6){animation-delay:.3s}@keyframes fadeInUpCompact{to{opacity:1;transform:translateY(0)}}.skill-item.highlight .skill-bar{box-shadow:0 0 10px #64ffda66}.skill-item.highlight .skill-percentage{background:#64ffda26;border-color:var(--green)}.skills-category--compact{padding:var(--space-lg)}.skills-category--compact .skill-item{margin-bottom:var(--space-md)}.skills-category--compact .skills-category-title{margin-bottom:var(--space-md);font-size:1rem}.compact-mode .skills-grid{gap:var(--space-xl);margin-bottom:var(--space-xl)}.compact-mode .skills-category{padding:var(--space-lg)}.compact-mode .skill-item{margin-bottom:var(--space-md)}.compact-mode .tags-grid{gap:var(--space-xs)}.compact-mode .tag{padding:calc(var(--space-xs) - 1px) var(--space-sm);font-size:.75rem}@media(max-width:380px){.skill-name{font-size:.85rem}.skill-percentage{font-size:.7rem;padding:calc(var(--space-xs) - 1px) calc(var(--space-sm) - 2px)}.tag{font-size:.7rem;padding:calc(var(--space-xs) - 2px) calc(var(--space-sm) - 2px)}}@media(prefers-reduced-motion:reduce){.skill-bar{transition:width .8s ease}.skill-bar:before{animation:none}.skill-item{animation:none;opacity:1;transform:none}.tag:hover,.skills-category:hover{transform:none}}#projects{background:var(--navy)}.projects-grid{display:grid;grid-template-columns:repeat(4,auto);gap:1rem;overflow-x:auto;padding:1px;align-items:safe;justify-content:space-evenly;scrollbar-width:thin;scrollbar-color:var(--green) var(--navy)}.projects-grid::-webkit-scrollbar-thumb:hover{background:#4fd3b0}@media(max-width:767px){.projects-grid{grid-template-columns:auto auto}}@media(max-width:601px){.projects-grid{grid-template-columns:repeat(1,auto);grid-template-rows:repeat(4,auto)}}.project-card{background:var(--gradient-card);border-radius:8px;transition:all .6s cubic-bezier(.68,-.55,.265,1.55);border:1px solid #ffffff1a;width:auto;height:auto;display:grid;grid-template-rows:auto;position:relative;overflow:hidden}.project-card:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,var(--green-tint),transparent);transition:left .6s}.project-card:hover:before{left:100%}.project-card:hover{transform:translateY(-5px);border-color:var(--green);box-shadow:0 8px 32px #0003}.project-card-featured{border-color:var(--green);position:relative}.project-header{display:grid;grid-template-columns:auto auto auto;align-items:center;gap:1rem;margin-bottom:1.5rem;position:relative;z-index:2}.project-icon{color:var(--green);font-size:1.3rem}.project-featured-badge{background:var(--green);color:var(--navy);padding:.25rem .75rem;border-radius:6px;font-size:.6rem;font-family:var(--font-mono);font-weight:700;text-align:center;letter-spacing:.05em;justify-content:space-evenly;background-image:radial-gradient(circle at center,var(--green) 0%,var(--green-glow) 50%,var(--navy) 100%);box-shadow:0 10px 30px #00000080}.project-links{display:grid;grid-template-columns:auto;gap:0;justify-self:end}.project-link{color:var(--light-slate);font-size:1.1rem;transition:all .3s ease;padding:0;border-radius:4px;position:relative;z-index:2}.project-link:hover{color:var(--green);transform:translateY(-1px);background:var(--green-tint)}.project-title{font-size:1.1rem;margin-bottom:1rem;color:var(--lightest-slate);position:relative;z-index:2;font-weight:700}.project-description{color:var(--light-slate);line-height:1.5;flex-grow:1;margin-bottom:1.5rem;position:relative;z-index:2;font-size:.85rem}.project-technologies{display:flex;flex-wrap:wrap;align-items:center;position:relative;gap:.5rem;z-index:2}.technology-tag{background:var(--navy);color:var(--green);padding:.125rem .5rem;border-radius:12px;font-size:.65rem;font-family:var(--font-mono);border:1px solid var(--green-tint);font-weight:500}#timeline{background:var(--light-navy)}#timeline-title{padding-bottom:var(--space-xs)}.timeline-desktop{display:none}.timeline-tag{background:var(--green-tint);color:var(--green);padding:4px 8px;border-radius:10px;font-size:.65rem;font-family:var(--font-mono);font-weight:600;white-space:nowrap}@media(min-width:768px){.timeline-desktop{display:block;position:relative;width:100%;max-width:1200px;margin:0 auto;padding:var(--space-3xs) 0}.timeline-line{position:absolute;left:50%;top:0;bottom:0;width:2px;background:linear-gradient(to bottom,transparent 0%,var(--green) 10%,var(--green) 90%,transparent 100%);transform:translate(-50%);z-index:1}.timeline-items{position:relative;z-index:2;display:grid;grid-template-columns:1fr auto 1fr;grid-auto-rows:minmax(120px,auto);align-items:center;gap:0}.timeline-item{position:relative;display:flex;flex:1 1 auto;cursor:pointer;transition:var(--transition-base);flex-direction:column;padding:0;min-height:116px}.timeline-item-left,.timeline-item:nth-child(odd){grid-column:1;justify-self:end;text-align:right;margin-right:var(--space-3xl);width:calc(100% - 40px)}.timeline-item-right,.timeline-item:nth-child(2n){grid-column:3;justify-self:start;text-align:left;margin-left:var(--space-3xl);width:calc(100% - 40px);top:50%}.timeline-item:before{content:"";grid-column:2;justify-self:center}.timeline-dot{position:absolute;top:50%;width:16px;height:16px;background:var(--light-navy);border-radius:50%;transform:translateY(-50%);border:3px solid var(--green);box-shadow:0 0 0 3px var(--light-navy);transition:var(--transition-bounce);z-index:2}.timeline-item-left .timeline-dot{right:-45px}.timeline-item-right .timeline-dot{left:-46px}.timeline-item:hover .timeline-dot{transform:translateY(-50%) scale(1.3);background:var(--green);box-shadow:var(--shadow-glow)}.timeline-content{background:var(--gradient-card);padding:var(--space-lg);border-radius:var(--border-radius-lg);border:1px solid rgba(255,255,255,.1);transition:var(--transition-bounce);cursor:pointer;position:relative;overflow:hidden;width:100%;min-height:130px;display:flex;flex-direction:column;justify-content:center}.timeline-content:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,var(--green-tint),transparent);transition:left .6s}.timeline-content:hover:before{left:100%}.timeline-content:hover{border-color:var(--green);transform:translateY(-3px);box-shadow:var(--shadow-lg)}.timeline-content.active{border-color:var(--green);transform:translateY(-3px);box-shadow:var(--shadow-xl)}.timeline-content-header{display:flex;align-items:flex-start;margin-bottom:var(--space-md);width:100%}.timeline-item-left .timeline-content-header{flex-direction:row;justify-content:space-between}.timeline-item-left .timeline-content-icon{order:1;margin-left:var(--space-lg);margin-right:0;flex-shrink:0}.timeline-item-left .timeline-content-text{order:2;text-align:right;flex:1}.timeline-item-right .timeline-content-header{flex-direction:row;justify-content:space-between}.timeline-item-right .timeline-content-icon{order:2;margin-right:var(--space-lg);margin-left:0;flex-shrink:0}.timeline-item-right .timeline-content-text{order:1;text-align:left;flex:1}.timeline-content-icon{color:var(--green);font-size:2rem;margin-top:var(--space-xs);flex-shrink:0}.timeline-date{color:var(--green);font-family:var(--font-mono);font-size:.85rem;margin-bottom:var(--space-xs);font-weight:600}.timeline-title{font-size:1.2rem;margin-bottom:var(--space-xs);color:var(--lightest-slate);font-weight:700;line-height:1.2}.timeline-subtitle{color:var(--green);font-size:.9rem;margin-bottom:var(--space-sm);font-family:var(--font-mono);font-weight:600}.timeline-description{color:var(--light-slate);line-height:1.5;margin-bottom:var(--space-md);font-size:.9rem}.timeline-content-tags{display:flex;flex-wrap:wrap;gap:var(--space-xs)}.timeline-item-left .timeline-content-tags{justify-content:flex-end}}@media(min-width:768px){.timeline-item:nth-child(odd){margin-bottom:1.5rem}.timeline-item:nth-child(2n){margin-bottom:1.5rem}.timeline-item:nth-child(2n){margin-top:0}}.timeline-mobile{display:block;width:100%}.timeline-item-mobile{background:var(--gradient-card);border-radius:var(--border-radius-lg);padding:var(--space-xl);margin-bottom:var(--space-lg);border-left:4px solid var(--green);transition:var(--transition-bounce);cursor:pointer;position:relative;overflow:hidden}.timeline-item-mobile:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,var(--green-tint),transparent);transition:left .6s}.timeline-item-mobile:hover:before{left:100%}.timeline-item-mobile:hover,.timeline-item-mobile.hover{transform:translate(8px);box-shadow:var(--shadow-lg);border-left-color:var(--accent-cyan)}.timeline-item-mobile.active{transform:translate(8px);border-left-color:var(--green);box-shadow:var(--shadow-xl)}.timeline-item-header{display:flex;align-items:center;gap:var(--space-md);margin-bottom:var(--space-md);position:relative;z-index:2}.timeline-icon{color:var(--green);font-size:1.3rem}.timeline-date{color:var(--green);font-family:var(--font-mono);font-size:.8rem;font-weight:600;position:relative;z-index:2}.timeline-title{font-size:1.2rem;margin-bottom:var(--space-xs);color:var(--lightest-slate);font-weight:700;position:relative;z-index:2}.timeline-subtitle{color:var(--green);font-size:.85rem;margin-bottom:var(--space-sm);font-family:var(--font-mono);font-weight:600;position:relative;z-index:2}.timeline-description{color:var(--light-slate);line-height:1.6;margin-bottom:var(--space-md);font-size:.85rem;position:relative;z-index:2}.timeline-tags{display:flex;flex-wrap:wrap;gap:var(--space-xs);position:relative;z-index:2;justify-content:flex-start}@keyframes pulseGlow{0%,to{box-shadow:0 0 5px var(--green-glow)}50%{box-shadow:0 0 20px var(--green-glow)}}.timeline-content.active:after{content:"";position:absolute;inset:-2px;border:2px solid var(--green);border-radius:var(--border-radius-lg);animation:pulseGlow 2s infinite}@media(min-width:768px){.timeline-mobile{display:none}.timeline-item-left{margin-right:19px}.timeline-item-right{margin-left:19px}}@media(min-width:1200px){.timeline-desktop{max-width:1300px}}@media(min-width:1400px){.timeline-desktop{max-width:1200px}.timeline-item{width:calc(100% - 50px)}@media(min-width:1600px){.timeline-desktop{max-width:1400px}.timeline-item{width:calc(50% - 60px)}}}#contact{background:var(--navy)}.contact-content{max-width:800px;margin:0 auto;text-align:center;width:100%}.contact-description{font-size:.95rem;margin-bottom:var(--space-xl);color:var(--light-slate);line-height:1.6;max-width:100%}.contact-section{display:flex;flex-direction:column;align-items:center;gap:var(--space-xl);margin-bottom:var(--space-3xl);width:100%}.contact-subsection{display:flex;flex-direction:column;align-items:center;gap:var(--space-md);width:100%}.contact-subtitle{font-size:1.2rem;color:var(--lightest-slate);margin-bottom:var(--space-3xs);font-weight:600}.contact-grid{display:grid;grid-template-columns:repeat(2,1fr);align-items:center;justify-content:center;gap:var(--space-lg);max-width:100%;margin:0 auto}.social-grid{display:grid;grid-template-columns:repeat(3,auto);justify-content:center;gap:var(--space-lg);max-width:100%;margin:0 auto}@media(max-width:767px){.contact-grid,.social-grid{display:grid;grid-template-columns:repeat(2,1fr);grid-auto-flow:column;gap:var(--space-md);min-width:220px}.contact-card,.social-card{width:100%;max-width:240px;max-height:90px;padding:var(--space-md)}.contact-icon,.social-icon{width:42px;height:42px;font-size:1.6rem}.contact-type,.social-platform{font-size:.9rem}.contact-value,.social-username{font-size:.8rem}}@media(max-width:480px){.contact-grid,.social-grid{display:grid;grid-template-columns:1fr;grid-auto-flow:row;max-width:100%}.contact-card,.social-card{max-width:100%;min-height:85px;padding:var(--space-md)}.contact-icon,.social-icon{width:38px;height:38px;font-size:1.4rem}.contact-grid,.social-grid{gap:var(--space-sm)}}@keyframes spinMorph{0%{transform:rotate(0) scale(1);border-top-color:var(--green);border-right-color:var(--accent-cyan);border-bottom-color:var(--accent-purple);border-left-color:var(--accent-blue)}25%{transform:rotate(90deg) scale(1.1);border-top-color:var(--accent-cyan);border-right-color:var(--accent-purple);border-bottom-color:var(--accent-blue);border-left-color:var(--green)}50%{transform:rotate(180deg) scale(1);border-top-color:var(--accent-purple);border-right-color:var(--accent-blue);border-bottom-color:var(--green);border-left-color:var(--accent-cyan)}75%{transform:rotate(270deg) scale(1.1);border-top-color:var(--accent-blue);border-right-color:var(--green);border-bottom-color:var(--accent-cyan);border-left-color:var(--accent-purple)}to{transform:rotate(360deg) scale(1);border-top-color:var(--green);border-right-color:var(--accent-cyan);border-bottom-color:var(--accent-purple);border-left-color:var(--accent-blue)}}@keyframes pulse{0%,to{transform:scale(1);opacity:.6}50%{transform:scale(1.1);opacity:.3}}@keyframes loadingBar{0%{transform:scaleX(0)}50%{transform:scaleX(1)}to{transform:scaleX(0)}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInLeft{0%{opacity:0;transform:translate(-30px)}to{opacity:1;transform:translate(0)}}@keyframes fadeInRight{0%{opacity:0;transform:translate(30px)}to{opacity:1;transform:translate(0)}}@keyframes shimmer{0%{transform:translate(-100%)}to{transform:translate(100%)}}@keyframes typewriter{0%{width:0}to{width:100%}}@keyframes blink{0%,50%{opacity:1}51%,to{opacity:0}}.animate-fade-in-up{animation:fadeInUp .6s cubic-bezier(.645,.045,.355,1) forwards}.animate-fade-in-left{animation:fadeInLeft .6s cubic-bezier(.645,.045,.355,1) forwards}.animate-fade-in-right{animation:fadeInRight .6s cubic-bezier(.645,.045,.355,1) forwards}.typewriter-complete:after{content:"|";animation:blink 1s infinite}@media(max-width:767px){:root{--header-height: 70px;--section-padding: 2.5rem 0}.container,.hero-content{padding:0 var(--space-md)}.hero-title,.hero-subtitle,.hero-description{text-align:left}.hero-cta{justify-content:flex-start;gap:var(--space-sm)}.about-stats{grid-template-columns:repeat(2,1fr);gap:var(--space-sm)}.skills-grid{gap:var(--space-lg)}.project-card{width:280px;padding:var(--space-lg)}.contact-grid,.social-grid{flex-direction:column;align-items:center}.contact-card,.social-card{width:100%;max-width:100%}.section-title:after{max-width:150px}html{-webkit-overflow-scrolling:touch}body{overflow-x:hidden;position:relative}.section{min-height:100dvh;height:auto;overflow:visible}}@media(max-width:480px){:root{--section-padding: 2rem 0}.container{padding:0 var(--space-sm)}.btn{padding:var(--space-md) var(--space-lg);font-size:.85rem}.image-container{width:180px;height:180px}.project-card{padding:var(--space-md);width:260px}.contact-card,.social-card{min-height:90px;padding:var(--space-md)}.section-title:after{max-width:120px}.hero-cta{flex-direction:column}.hero-cta .btn{width:100%;max-width:100%}}@media(prefers-contrast:high){:root{--green: #00ff00;--slate: #ffffff;--light-slate: #f0f0f0;--lightest-slate: #ffffff}}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--navy);border-radius:4px}::-webkit-scrollbar-thumb{background:var(--green);border-radius:4px;border:2px solid var(--navy)}::-webkit-scrollbar-thumb:hover{background:#4fd3b0}::-webkit-scrollbar-corner{background:var(--navy)}*{scrollbar-width:thin;scrollbar-color:var(--green) var(--navy)}.projects-grid::-webkit-scrollbar{height:6px}.projects-grid::-webkit-scrollbar-track{background:var(--navy);border-radius:3px}.projects-grid::-webkit-scrollbar-thumb{background:var(--green);border-radius:3px}@media print{.header,.mobile-menu-button,.footer,.hero-cta,.map-section,.theme-toggle,.project-links,.btn{display:none!important}.section{min-height:auto!important;padding:1rem 0!important;page-break-inside:avoid}body{background:#fff!important;color:#000!important;font-size:12pt!important;line-height:1.4!important}a{color:#00e!important;text-decoration:underline!important}h1,h2,h3,h4,h5,h6{color:#000!important;page-break-after:avoid}.container{max-width:100%!important;padding:0!important}.skill-bar-container{background:#ccc!important}.skill-bar{background:#666!important}img{max-width:100%!important;height:auto!important;page-break-inside:avoid}.project-card,.timeline-item-mobile,.contact-card,.social-card{page-break-inside:avoid}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}}:focus-visible{outline:2px solid var(--green);outline-offset:2px;border-radius:2px}.skip-link{position:absolute;top:-40px;left:6px;background:var(--green);color:var(--navy);padding:8px;border-radius:var(--border-radius);text-decoration:none;font-weight:600;z-index:var(--z-preloader);transition:top .3s ease}.skip-link:focus{top:6px}@media(prefers-contrast:high){:root{--green: #00ff00;--navy: #000000;--light-navy: #111111;--slate: #ffffff;--light-slate: #f0f0f0;--lightest-slate: #ffffff}.skill-bar{background:var(--green)!important}}@media(prefers-reduced-motion:reduce){.hero-greeting,.hero-title,.hero-subtitle,.hero-description,.hero-cta{animation:none!important;opacity:1!important;visibility:visible!important}.preloader-spinner{animation:none!important}.typewriter-complete:after{animation:none!important;opacity:0!important}}::selection{background:var(--green-tint);color:var(--green);text-shadow:none}::-moz-selection{background:var(--green-tint);color:var(--green);text-shadow:none}.loading{opacity:.7;pointer-events:none;position:relative}.loading:after{content:"";position:absolute;top:50%;left:50%;width:18px;height:18px;border:2px solid var(--green-tint);border-top:2px solid var(--green);border-radius:50%;animation:spin 1s linear infinite;transform:translate(-50%,-50%)}.will-change{will-change:transform,opacity}
