.hero-header-shell{position:relative;z-index:2}.hero-header-shell .hero-wave-layer{position:absolute;top:0;right:0;bottom:0;left:0;z-index:0;pointer-events:none;overflow:hidden}.hero-header-shell .hero-wave-layer canvas{width:100%;height:100%;display:block;opacity:.42}.hero-header-shell .header{position:sticky;top:0;z-index:1000;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#09131f8f;display:flex;align-items:center;justify-content:space-between;padding:14px 18px;height:var(--header-height)}[data-theme=light] .hero-header-shell .header,[data-theme=light] .hero-header-shell .hero{background:#ffffffd1}.hero-header-shell .header-actions{display:flex;gap:10px;align-items:center}.hero-header-shell .hero{display:grid;grid-template-columns:1fr 1fr;gap:22px;align-items:stretch;padding-top:0;padding-bottom:0;position:relative;isolation:isolate;z-index:2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#09131f70;border-bottom:1px solid var(--line);min-height:calc(100vh - var(--header-height))}.hero-header-shell .hero-left,.hero-header-shell .hero-right{position:relative;z-index:1}.hero-header-shell .hero-left{display:flex;flex-direction:column;justify-content:center;align-items:flex-start;text-align:left;padding-left:clamp(14px,3vw,36px)}.hero-header-shell .hero-right{display:flex;justify-content:center;align-items:flex-end;padding-right:0}.hero-header-shell .tag{display:inline-flex;padding:8px 12px;border:1px solid var(--line);border-radius:999px;background:linear-gradient(120deg,#21b4a838,#ffffff0a);color:var(--muted);font-weight:600;margin:0 0 12px}.hero-header-shell .hero h1{margin:0 0 10px;font-size:clamp(3.1rem,8.4vw,8.8rem);line-height:1.02;letter-spacing:.4px}.hero-header-shell .sub{margin:0 0 16px;color:var(--muted);font-size:1.08rem;max-width:52ch}.hero-header-shell .cta{display:flex;gap:10px;margin-bottom:16px;flex-wrap:wrap}.hero-header-shell .meta{display:flex;gap:10px;flex-wrap:wrap}.hero-header-shell .hero-left .cta,.hero-header-shell .hero-left .meta{justify-content:flex-start}.hero-header-shell .avatar{width:min(48vw,760px);height:100%;max-height:calc(100vh - var(--header-height));display:flex;align-items:center;justify-content:center;font-weight:900;font-size:1.55rem;border-radius:0;overflow:visible;position:relative;transform:none;background:transparent;border:none;box-shadow:none;transition:transform .4s ease}.hero-header-shell .houssam{width:100%;height:100%;-o-object-fit:contain;object-fit:contain;-o-object-position:center bottom;object-position:center bottom;border-radius:0;display:block;position:relative;z-index:1}.hero-header-shell .hero-right .avatar:after{content:none}@media (max-width: 980px){.hero-header-shell .hero{grid-template-columns:1fr}.hero-header-shell .hero-right{justify-content:center;padding-right:0}.hero-header-shell .hero-left{align-items:center;text-align:center;padding-left:0}.hero-header-shell .hero-left .cta,.hero-header-shell .hero-left .meta{justify-content:center}.hero-header-shell .hero-right .avatar{width:min(70vw,520px);height:min(58vh,520px);transform:none}}@media (max-width: 560px){.hero-header-shell .hero{gap:16px;display:flex;flex-direction:column-reverse}.hero-header-shell .hero-right{width:100%}.hero-header-shell .hero-right .avatar{width:min(84vw,360px);height:min(42vh,360px);transform:none;margin:0 auto}.hero-header-shell .hero h1{font-size:clamp(2.6rem,11vw,4rem);line-height:1.1}.hero-header-shell .sub{font-size:1rem}.hero-header-shell .cta{flex-direction:column;width:100%}}*,: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:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,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!important}.visible{visibility:visible}.absolute{position:absolute}.inset-x-0{left:0;right:0}.top-0{top:0}.w-\[2px\]{width:2px}.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}.rounded-full{border-radius:9999px}.bg-gradient-to-t{background-image:linear-gradient(to top,var(--tw-gradient-stops))}.from-purple-500{--tw-gradient-from: #a855f7 var(--tw-gradient-from-position);--tw-gradient-to: rgb(168 85 247 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)}.from-\[0\%\]{--tw-gradient-from-position: 0%}.via-blue-500{--tw-gradient-to: rgb(59 130 246 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), #3b82f6 var(--tw-gradient-via-position), var(--tw-gradient-to)}.via-\[10\%\]{--tw-gradient-via-position: 10%}.to-transparent{--tw-gradient-to: transparent var(--tw-gradient-to-position)}.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)}:root{--bg: #09131f;--panel: #101d2d;--text: #e7f0fb;--muted: #9db1c8;--line: rgba(255,255,255,.1);--accent: #21b4a8;--accent-2: #f29a4a;--shadow: 0 16px 50px rgba(0,0,0,.35);--radius: 18px;--max: 80%;--tooltip-bg: rgba(0,0,0,.85);--text-secondary: #ffffff;--header-height: 72px}[data-theme=light]{--bg: #f5f7fa;--panel: #edf2f7;--text: #0f1b2d;--muted: #445a74;--line: rgba(17,24,39,.12);--accent: #0e9f95;--accent-2: #de7e2f;--shadow: 0 16px 50px rgba(17,24,39,.1);--tooltip-bg: rgba(255,255,255,.95);--text-secondary: #111827}html,body{overflow-x:hidden;width:100%;position:relative}*{box-sizing:border-box;overflow-wrap:break-word}html{scroll-behavior:smooth}body{margin:0;font-family:Trebuchet MS,Lucida Sans Unicode,Segoe UI,sans-serif;background:radial-gradient(1000px 620px at 14% -10%,rgba(33,180,168,.18),transparent 60%),radial-gradient(900px 500px at 94% 4%,rgba(242,154,74,.14),transparent 60%),radial-gradient(700px 420px at 50% 100%,rgba(37,99,235,.12),transparent 60%),var(--bg);color:var(--text);line-height:1.5}a{color:inherit;text-decoration:none}.muted{color:var(--muted)}.small{font-size:.92rem}.accent{color:var(--accent)}[data-theme=light] .bottom-bar{background:#ffffffd1;box-shadow:0 18px 40px #1118271f}.logo{display:flex;align-items:center;gap:8px;font-weight:800;letter-spacing:.4px;font-size:1rem}.logo-dot{width:12px;height:12px;border-radius:999px;background:var(--accent);box-shadow:0 0 0 6px #7c5cff2e}.nav{display:flex;gap:14px}.bottom-bar{position:fixed;bottom:16px;left:50%;transform:translate(-50%,20px);z-index:2500;display:inline-flex;gap:8px;padding:8px 12px;border-radius:999px;background:#10131ab3;border:1px solid var(--line);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);box-shadow:0 18px 40px #00000059;opacity:0;pointer-events:none;transition:opacity .35s ease,transform .35s ease;max-width:min(92vw,980px);overflow-x:auto;white-space:nowrap;scrollbar-width:none}.bottom-bar::-webkit-scrollbar{display:none}.bottom-bar.show{opacity:1;pointer-events:auto;transform:translate(-50%)}.bottom-bar a{padding:8px 12px;border-radius:999px;color:var(--muted);border:1px solid transparent;font-weight:700;transition:all .25s ease}.bottom-bar a:hover{color:var(--text);border-color:var(--line);background:#ffffff0a}.bottom-bar a.active{color:var(--text);background:#7c5cff2e;border-color:#7c5cff73;box-shadow:0 8px 24px #7c5cff40}.nav a{padding:8px 10px;border-radius:999px;color:var(--muted);border:1px solid transparent;position:relative;overflow:hidden}.nav a:hover{color:var(--text);border-color:var(--line);background:#ffffff0a}.nav a:after{content:"";position:absolute;bottom:0;left:50%;width:0;height:2px;background:var(--accent);transition:all .3s ease;transform:translate(-50%)}.nav a:hover:after{width:80%}.main{max-width:min(1600px,94vw);width:100%;margin:0 auto;padding:22px 18px 60px;position:relative;z-index:1}.section{padding:34px 0}.section-head{margin-bottom:16px;position:relative;display:inline-block}.section-head h2{margin:0 0 6px;font-size:clamp(1.5rem,2.6vw,2rem);letter-spacing:.2px}.section-head p{margin:0}.floating-ana{content:"";position:fixed;top:68px;left:-126px;width:min(72vw,880px);height:min(124vh,1120px);background-image:var(--hero-bg-image-opposite);background-repeat:no-repeat;background-position:left top;background-size:contain;opacity:.14;pointer-events:none;z-index:0;filter:drop-shadow(0 0 26px rgba(124,92,255,.24));transition:opacity .35s ease,transform .35s ease}body.experience-active .floating-ana{opacity:.06;transform:translateY(-28px) scale(.97)}body.after-skills .floating-ana{opacity:0;transform:translateY(-40px) scale(.95)}.floating-hs{content:"";position:fixed;top:86px;right:-92px;width:min(44vw,560px);height:min(92vh,860px);background-image:var(--hero-bg-image);background-repeat:no-repeat;background-position:right top;background-size:contain;opacity:0;transform:translateY(20px) scale(.98);pointer-events:none;z-index:0;filter:drop-shadow(0 0 28px rgba(124,92,255,.26));transition:opacity .35s ease,transform .35s ease}body.experience-active .floating-hs{opacity:.2;transform:none}#experience{position:relative;isolation:isolate}#about{position:relative;z-index:1}#experience>*{position:relative;z-index:1}.decode-text{font-family:monospace;display:inline-block}.about-type-line{margin:0 0 10px;color:var(--muted);font-weight:700}.about-type-value{color:var(--accent);border-right:2px solid currentColor;padding-right:4px;animation:about-caret-blink .8s steps(1,end) infinite}@keyframes about-caret-blink{0%,49%{border-right-color:currentColor}50%,to{border-right-color:transparent}}.chip{border:1px solid var(--line);padding:8px 10px;border-radius:999px;color:var(--muted);background:linear-gradient(120deg,#21b4a821,#ffffff08);transition:all .3s ease}.chip:hover{background:linear-gradient(120deg,#21b4a838,#21b4a812);border-color:#21b4a873;transform:translateY(-2px)}.card{background:linear-gradient(180deg,#ffffff14,#ffffff06);border:1px solid var(--line);border-radius:var(--radius);padding:18px;box-shadow:var(--shadow);transition:transform .3s ease,box-shadow .3s ease,border-color .3s ease;position:relative;overflow:hidden}.card:hover{border-color:#21b4a859}@media (hover: hover){.card:hover{transform:translateY(-6px);box-shadow:0 20px 60px #7c5cff26,var(--shadow)}}.btn{display:inline-flex;align-items:center;justify-content:center;gap:10px;padding:10px 14px;border-radius:999px;background:linear-gradient(120deg,var(--accent),#0e8e87);border:1px solid rgba(255,255,255,.15);color:#fff;font-weight:700;cursor:pointer;position:relative;overflow:hidden;transition:all .3s ease}.btn:before{content:"";position:absolute;top:50%;left:50%;width:0;height:0;border-radius:50%;background:#fff3;transform:translate(-50%,-50%);transition:width .6s ease,height .6s ease}.btn:hover:before{width:300px;height:300px}.btn:hover{transform:translateY(-2px);box-shadow:0 10px 30px #21b4a852}.btn.ghost{background:transparent;color:var(--text);border:1px solid var(--line)}.btn.ghost:hover{background:#21b4a81a;border-color:#21b4a873;color:var(--accent)}.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:16px}.list{margin:12px 0 0;padding-left:18px;color:var(--muted)}.mini-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:14px}.mini{border:1px dashed var(--line);border-radius:14px;padding:12px;overflow:hidden;word-wrap:break-word;overflow-wrap:break-word}.mini-title{font-weight:800;margin-bottom:6px}p,h1,h2,h3,.muted,a,span{max-width:100%}.skills{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px}.pills{display:flex;flex-wrap:wrap;gap:8px;margin-top:8px}.pill{padding:6px 10px;border-radius:999px;border:1px solid var(--line);background:#ffffff0a;font-weight:700;font-size:.92rem;transition:all .3s ease}.muted-pill{opacity:.65}.skill:hover h3{color:var(--accent);transform:translate(5px)}.skill h3{transition:all .3s ease}.skill:hover .pill{background:#7c5cff1a;border-color:#7c5cff4d}.hero-right .profile-card{display:flex;flex-direction:column;gap:12px;transition:all .4s ease}.profile-head{display:flex;align-items:center;justify-content:space-between;gap:12px}.profile-links{display:flex;flex-direction:column;gap:10px}.link.profile-link-item{display:inline-flex;align-items:center;gap:12px;width:100%;padding:10px 12px;border-radius:12px;border:1px solid var(--line);background:#ffffff08;transition:transform .28s ease,background .28s ease,border-color .28s ease,box-shadow .28s ease}.profile-link-item:after{display:none}.link-text{margin-left:2px}.profile-link-item:hover{transform:translate(6px);background:linear-gradient(90deg,#7c5cff29,#7c5cff0d);border-color:#7c5cff73;box-shadow:0 10px 26px #7c5cff2e}.link-icon{width:24px;height:24px;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;font-size:.68rem;font-weight:800;border:1px solid rgba(124,92,255,.45);background:#7c5cff1f;color:var(--accent);transition:transform .25s ease,background .25s ease,border-color .25s ease}.link-icon svg{width:13px;height:13px;fill:currentColor;display:block}.profile-link-item:hover .link-icon{transform:scale(1.08);background:#7c5cff38;border-color:#7c5cff99}.link{color:var(--accent);font-weight:800;position:relative;display:inline-block}.link:after{content:"";position:absolute;width:100%;height:2px;bottom:-2px;left:0;background:var(--accent);transform:scaleX(0);transform-origin:bottom right;transition:transform .3s ease}.link:hover:after{transform:scaleX(1);transform-origin:bottom left}.note{border-top:1px solid var(--line);padding-top:10px;margin:0}.projects{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:18px}.project-card{position:relative;overflow:hidden;min-height:0;padding:0;border-radius:20px;border:1px solid rgba(148,163,184,.24);background:linear-gradient(180deg,#ffffff17,#ffffff05);box-shadow:var(--shadow);transition:transform .25s ease,border-color .25s ease,box-shadow .25s ease}.project-card:before{content:none}.project-card:hover:before{opacity:0}.project-card:hover{transform:translateY(-4px);border-color:#21b4a89e;box-shadow:0 14px 34px #02061759,0 0 0 1px #21b4a847 inset}.project-visual{height:auto;aspect-ratio:16 / 10;min-height:0;overflow:hidden;border-radius:inherit;background:#0206178c;border:0}.project-visual img{width:100%;height:100%;-o-object-fit:contain;object-fit:contain;-o-object-position:center;object-position:center;background:#0b1220;transform:translateZ(0);transform-origin:center center;backface-visibility:hidden;transition:transform .6s cubic-bezier(.2,.8,.2,1);will-change:transform}.project-card:hover .project-visual img{transform:scale(1.03)}.project-body{padding:14px;display:flex;flex-direction:column;gap:10px}.project-header h3{margin:0 0 4px}.project-header .small{line-height:1.4}.project-pills{gap:8px}.project-features{margin:6px 0 0;padding-left:16px;display:grid;gap:4px}.project-title{margin:0;font-size:1.02rem;line-height:1.35}.project-description{margin:0}.project-tech{display:flex;flex-wrap:wrap;gap:8px}.project-links{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.parallax-layer{will-change:transform}.badge{font-weight:800;font-size:.86rem;padding:6px 10px;border-radius:999px;border:1px solid var(--line);background:#ffffff08;color:var(--muted);transition:all .3s ease}.timeline{display:flex;flex-direction:column;gap:12px}.timeline-item{display:grid;grid-template-columns:180px 1fr;gap:14px;align-items:start;position:relative;transition:all .3s ease}.timeline-item:before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--accent);transform:scaleY(0);transition:transform .3s ease;border-radius:3px}.timeline-item:hover:before{transform:scaleY(1)}.timeline-item:hover{transform:translate(10px);background:linear-gradient(90deg,rgba(124,92,255,.05),transparent)}.timeline-item:hover .timeline-date{color:var(--accent);transform:scale(1.1)}.timeline-date{color:var(--muted);font-weight:900;padding-top:4px;transition:all .3s ease}.timeline-content h3{margin:0 0 6px}.timeline-content p{margin:0;color:var(--muted)}.vt-timeline{position:relative;padding:20px 0}.vt-timeline:before{content:"";position:absolute;left:50%;top:0;bottom:0;width:3px;background:linear-gradient(180deg,var(--accent),rgba(124,92,255,.15));transform:translate(-50%);border-radius:3px}.vt-item{position:relative;width:50%;padding:0 40px 40px}.vt-left{left:0;text-align:right}.vt-right{left:50%;text-align:left}.vt-dot{position:absolute;top:6px;width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.1rem;z-index:2;border:3px solid var(--bg);box-shadow:0 0 0 3px var(--accent),0 4px 16px #7c5cff40;transition:transform .3s ease,box-shadow .3s ease}.vt-item:hover .vt-dot{transform:scale(1.2);box-shadow:0 0 0 5px var(--accent),0 8px 28px #7c5cff66}.vt-dot--education,.vt-dot--personal{background:#6d28d9}.vt-dot--project{background:#0891b2}.vt-dot--certificate{background:#d97706}.vt-dot--experience{background:#059669}.vt-dot--default{background:var(--accent)}.vt-left .vt-dot{right:-20px}.vt-right .vt-dot{left:-20px}.vt-card{background:linear-gradient(180deg,#ffffff0f,#ffffff05);border:1px solid var(--line);border-radius:var(--radius);padding:18px;box-shadow:var(--shadow);transition:transform .3s ease,box-shadow .3s ease,border-color .3s ease;position:relative;overflow:visible}.vt-card:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:inherit;padding:1px;background:linear-gradient(120deg,transparent,rgba(124,92,255,.6),transparent);opacity:0;transition:opacity .3s ease;-webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);-webkit-mask-composite:xor;mask-composite:exclude;pointer-events:none}.vt-item:hover .vt-card{transform:translateY(-4px);box-shadow:0 16px 48px #7c5cff26,var(--shadow);border-color:#7c5cff59}.vt-item:hover .vt-card:before{opacity:1;animation:vt-border-sweep 1.6s linear infinite}.vt-item{position:relative}.vt-hover-photo{position:absolute;right:-320px;bottom:-6px;width:340px;height:220px;border-radius:28px 12px;overflow:hidden;border:2px solid rgba(5,150,105,.72);background:#0c0c128c;box-shadow:0 26px 70px #000000b8,0 0 70px #05966947;opacity:0;transform:translateY(18px) scale(.94);transition:opacity .35s ease,transform .35s ease,box-shadow .35s ease;pointer-events:none;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);z-index:50}.vt-right .vt-hover-photo{right:auto;left:0;top:-250px;bottom:auto}.vt-left .vt-hover-photo{right:auto;left:0;top:calc(100% + 16px);bottom:auto}.vt-item--last .vt-hover-photo{left:0;right:auto;top:auto;bottom:130px}.vt-hover-photo:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(circle at 78% 18%,rgba(5,150,105,.35),transparent 58%);z-index:1;pointer-events:none}.vt-hover-photo img{position:relative;z-index:0;width:100%;height:100%;-o-object-fit:cover;object-fit:cover;transform:scale(1.08);transition:transform .45s ease;filter:saturate(1.14) contrast(1.08)}.vt-item:hover .vt-hover-photo{opacity:1;transform:translateY(0) scale(1);box-shadow:0 30px 88px #000000c7,0 0 82px #05966959}.vt-item:hover .vt-hover-photo img{transform:scale(1.02)}@media (max-width: 900px){.vt-hover-photo{display:none}}@keyframes vt-border-sweep{0%{background-position:0% 50%}to{background-position:200% 50%}}.vt-left .vt-card:after{content:"";position:absolute;top:14px;right:-8px;width:16px;height:16px;background:linear-gradient(135deg,transparent 50%,rgba(255,255,255,.06) 50%);border:1px solid var(--line);border-left:none;border-bottom:none;transform:rotate(45deg);border-radius:0 4px 0 0}.vt-right .vt-card:after{content:"";position:absolute;top:14px;left:-8px;width:16px;height:16px;background:linear-gradient(315deg,transparent 50%,rgba(255,255,255,.06) 50%);border:1px solid var(--line);border-right:none;border-top:none;transform:rotate(45deg);border-radius:0 0 0 4px}.vt-type{display:inline-block;padding:3px 10px;border-radius:999px;font-size:.75rem;font-weight:800;text-transform:uppercase;letter-spacing:.06em;margin-bottom:6px}.vt-type--education,.vt-type--personal{background:#6d28d933;color:#a78bfa}.vt-type--project{background:#0891b233;color:#22d3ee}.vt-type--certificate{background:#d9770633;color:#fbbf24}.vt-type--experience{background:#05966933;color:#34d399}.vt-type--default{background:#7c5cff26;color:var(--accent)}.vt-date{color:var(--accent);font-weight:900;font-size:.95rem;margin-bottom:4px}.vt-title{margin:0 0 6px;font-size:1.1rem}.vt-desc{margin:0;color:var(--muted);font-size:.95rem;line-height:1.5}.cert-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px}.cert-card{display:flex;flex-direction:column;overflow:hidden}.cert-card:hover{transform:translateY(-6px);box-shadow:0 20px 60px #7c5cff26,var(--shadow);border-color:#7c5cff4d}.cert-preview{height:140px;display:flex;align-items:center;justify-content:center;background:#7c5cff0f;border-bottom:1px solid var(--line);border-radius:var(--radius) var(--radius) 0 0;overflow:hidden}.cert-preview img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;transition:transform .4s ease}.cert-card:hover .cert-preview img{transform:scale(1.06)}.cert-placeholder{font-size:3rem;opacity:.4;transition:transform .3s ease,opacity .3s ease}.cert-card:hover .cert-placeholder{transform:scale(1.15) rotate(-5deg);opacity:.7}.cert-body{padding:14px 16px 16px;flex:1;display:flex;flex-direction:column;gap:4px}.cert-top-row{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.cert-info{min-width:0;flex:1}.cert-title{margin:0;font-size:1.05rem}.cert-issuer{margin:0;font-size:.9rem}.cert-year{display:inline-block;font-weight:800;font-size:.8rem;color:var(--accent);padding:2px 8px;border:1px solid rgba(124,92,255,.3);border-radius:999px;width:-moz-fit-content;width:fit-content;margin:4px 0 8px}.cert-qr-wrap{margin:0;width:-moz-fit-content;width:fit-content;display:flex;flex-direction:column;align-items:center;gap:6px;flex-shrink:0}.cert-qr{width:90px;height:90px;border-radius:10px;border:1px solid var(--line);background:var(--bg);-o-object-fit:cover;object-fit:cover}.cert-qr-label{font-size:.75rem;color:var(--muted);font-weight:700}.cert-dl{margin-top:12px;font-size:.88rem;padding:8px 12px;text-align:center}.form label{display:block;font-weight:800;margin-bottom:10px}.form input,.form textarea{width:100%;margin-top:6px;padding:10px 12px;border-radius:12px;border:1px solid var(--line);background:#ffffff08;color:var(--text);outline:none;transition:all .3s ease}[data-theme=light] .form input,[data-theme=light] .form textarea{background:#fffc}.form input:focus,.form textarea:focus{border-color:#7c5cff99;box-shadow:0 0 0 4px #7c5cff2e;transform:translateY(-2px)}.contact-list{display:flex;flex-direction:column;gap:10px;margin-top:12px}.contact-item{display:grid;grid-template-columns:auto auto 1fr;align-items:center;gap:10px;padding:10px 12px;border:1px solid var(--line);border-radius:14px;background:#ffffff08;transition:all .3s ease}.contact-item:hover{transform:translate(8px);border-color:#21b4a873;background:#21b4a814}.contact-label{color:var(--muted);font-weight:900}.contact-item .link{justify-self:end}.footer{border-top:1px solid var(--line);padding-top:18px;margin-top:18px;text-align:center}#mouse-glow{position:fixed;top:0;left:0;width:600px;height:600px;pointer-events:none;border-radius:50%;background:radial-gradient(circle at center,rgba(124,92,255,.35),rgba(124,92,255,.15),transparent 60%);transform:translate(-50%,-50%);filter:blur(40px);z-index:-1;transition:opacity .3s ease}.velocity-skew{transition:transform .1s ease-out;will-change:transform}.scrolling-down .velocity-skew{transform:skewY(-1deg)}.scrolling-up .velocity-skew{transform:skewY(1deg)}.blur-section{filter:blur(10px);opacity:.3;transform:scale(.95);transition:all .8s cubic-bezier(.25,.46,.45,.94)}.blur-section.in-view{filter:blur(0);opacity:1;transform:scale(1)}.line-draw{position:relative}.line-draw:before{content:"";position:absolute;left:0;bottom:0;width:0;height:2px;background:linear-gradient(90deg,var(--accent),var(--accent-2));transition:width 1s cubic-bezier(.77,0,.175,1)}.line-draw.drawn:before{width:100%}.progress-ring-container{position:fixed;bottom:30px;right:30px;width:60px;height:60px;z-index:100;mix-blend-mode:difference;display:flex;align-items:center;justify-content:center}.progress-ring{transition:opacity .4s ease,transform .4s ease}.progress-ring circle{transition:stroke-dashoffset .1s;transform:rotate(-90deg);transform-origin:50% 50%}.whatsapp-btn{position:absolute;width:50px;height:50px;background-color:#25d366;border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 12px #0003;opacity:0;transform:scale(.5);pointer-events:none;transition:opacity .4s ease,transform .4s cubic-bezier(.175,.885,.32,1.275)}.progress-ring-container.at-bottom{mix-blend-mode:normal}.progress-ring-container.at-bottom .progress-ring{opacity:0;transform:scale(.8);pointer-events:none}.progress-ring-container.at-bottom .whatsapp-btn{opacity:1;transform:scale(1);pointer-events:all}.whatsapp-btn:hover{transform:scale(1.1);box-shadow:0 6px 16px #0000004d}.cursor-glow{position:fixed;width:20px;height:20px;border:2px solid rgba(33,180,168,.9);border-radius:50%;pointer-events:none;z-index:9999;transition:transform .15s ease,width .3s ease,height .3s ease;transform:translate(-50%,-50%)}.cursor-glow.hovering{width:50px;height:50px;background:#21b4a81f}.decrypt-tooltip{position:fixed;background:var(--tooltip-bg);padding:8px 14px;border-radius:6px;font-size:.75rem;color:var(--text-secondary);pointer-events:none;z-index:9999;opacity:0;transform:translate(-50%,-100%) translateY(-10px);transition:opacity .2s ease;border:1px solid rgba(255,255,255,.1);white-space:nowrap;font-family:monospace;letter-spacing:.05em}.decrypt-tooltip.visible{opacity:1;transform:translate(-50%,-100%) translateY(0)}.reveal-scale{opacity:0;transform:none;transition:opacity .35s ease}.reveal-scale.active{opacity:1}.stagger-1{transition-delay:.1s}.stagger-2{transition-delay:.2s}.stagger-3{transition-delay:.3s}.stagger-4{transition-delay:.4s}.stagger-5{transition-delay:.5s}@media (max-width: 980px){.floating-ana{width:min(78vw,620px);height:min(94vh,760px);left:-126px;top:84px;opacity:.16}.floating-hs{width:min(56vw,420px);height:min(66vh,560px);right:-70px;top:100px}.projects{grid-template-columns:1fr 1fr}.project-card{aspect-ratio:16 / 11}.skills,.grid-2,.timeline-item{grid-template-columns:1fr}.vt-timeline:before{left:20px}.vt-item{width:100%;left:0!important;text-align:left!important;padding:0 0 30px 60px}.vt-hover-photo{position:relative;right:auto;bottom:auto;margin-top:12px;width:100%;height:160px;opacity:1;transform:none}.vt-left .vt-dot,.vt-right .vt-dot{left:0;right:auto}.vt-left .vt-card:after,.vt-right .vt-card:after{left:-8px;right:auto;background:linear-gradient(315deg,transparent 50%,rgba(255,255,255,.06) 50%);border:1px solid var(--line);border-right:none;border-top:none;border-radius:0 0 0 4px}.cert-grid{grid-template-columns:1fr 1fr}}@media (max-width: 768px){#mouse-glow,.cursor-glow{display:none}.progress-ring-container:not(.at-bottom){display:none}.progress-ring-container.at-bottom{bottom:20px;right:20px}}@media (max-width: 560px){.nav{display:none}.bottom-bar{display:none!important}.main{padding:16px 14px 50px}.projects,.skills,.cert-grid,.grid-2,.mini-grid{grid-template-columns:1fr!important}.project-visual{aspect-ratio:16 / 11}.floating-ana{width:88vw;height:68vh;left:-118px;top:108px;opacity:.11}.floating-hs{width:74vw;height:52vh;right:-62px;top:138px}.btn{width:100%;justify-content:center}.contact-item{flex-direction:column;align-items:flex-start;gap:4px;overflow:hidden}.contact-item .link{word-break:break-all;font-size:.9rem;width:100%;display:block}.timeline-item{gap:8px}.card,.vt-card{padding:14px;width:100%;max-width:100%}.badge,.pill{max-width:100%;white-space:normal;text-align:center}}@media (prefers-reduced-motion: reduce){.velocity-skew,.tilt-card,.blur-section,.card,.btn,.chip,.contact-item,.timeline-item,.vt-item,.vt-card,.vt-dot,.cert-card{transform:none!important;filter:none!important;transition:none!important}}@media (hover: none){.card:hover,.btn:hover,.chip:hover,.profile-card:hover,.project-card:hover,.skill:hover,.contact-item:hover,.timeline-item:hover,.vt-item:hover .vt-card,.cert-card:hover,.project-card:hover .project-visual img{transform:none!important}}.menu-btn{display:none}@media (max-width: 560px){.nav{display:none}.menu-btn{display:inline-flex}}.mobile-menu{position:fixed;top:80px;left:18px;right:18px;background:var(--panel);border:1px solid var(--line);border-radius:20px;padding:10px;z-index:2000;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);box-shadow:0 20px 40px #0006;opacity:0;visibility:hidden;transform:translateY(-20px) scale(.95);transition:all .4s cubic-bezier(.165,.84,.44,1);display:block}.mobile-menu.open{opacity:1;visibility:visible;transform:translateY(0) scale(1)}.mobile-menu a{display:block;padding:16px 20px;border-radius:14px;font-weight:700;transition:all .2s ease;color:var(--muted)}.mobile-menu a:hover{background:#7c5cff1f;color:var(--accent);transform:translate(5px)}
