:root{--bg:#08160f;--bg-soft:#0f2519;--bg-light:#f5fff8;--bg-soft-light:#eaf8ef;--card:#ffffff0f;--text:#e8f3ec;--muted:#808080de;--primary:#62d47f;--primary-2:#8df2b8;--glow-strong:#62d47f38;--glow-soft:#8df2b82b;--glow-strong-light:#4dc67a33;--glow-soft-light:#1f9f4b21;--primary-soft:#62d47f29;--primary-soft-strong:#62d47f3d;--matrix-fade-dark:#08160f13;--matrix-fade-light:#f5fff811;--matrix-chars-dark:#8df2b840;--matrix-chars-light:#1f9f4b38;--border:#ffffff29;--shadow:0 14px 32px #00000047}*,:before,:after{box-sizing:border-box}:not(.typing-caret),:not(.typing-caret):before,:not(.typing-caret):after{transition-property:transform,opacity!important}html{scroll-behavior:smooth}body{color:var(--text);background:radial-gradient(circle at 20% 20%, var(--glow-strong), transparent 40%), radial-gradient(circle at 80% 0%, var(--glow-soft), transparent 35%), var(--bg);margin:0;font-family:Inter,Segoe UI,Roboto,sans-serif;line-height:1.6}body.theme-switching *,body.theme-switching :before,body.theme-switching :after,html.theme-switching *,html.theme-switching :before,html.theme-switching :after{transition:none!important}body.light-mode{--bg:var(--bg-light);--bg-soft:var(--bg-soft-light);--card:#ffffffc7;--text:#0f2a1c;--border:#1826372e;--shadow:0 12px 28px #1826371f;background:radial-gradient(circle at 20% 20%, var(--glow-strong-light), transparent 40%), radial-gradient(circle at 80% 0%, var(--glow-soft-light), transparent 35%), var(--bg)}body.light-mode .navbar{background:#ffffffe6}body.light-mode nav a{color:#24402f}body.light-mode button.active-lang,body.light-mode .brand,body.light-mode .primary{background:var(--btn)}body.light-mode .typing-role,body.light-mode .eyebrow,body.light-mode a svg{color:var(--btn)}body.light-mode .brand-icon{color:#fff}body.light-mode nav a:hover,body.light-mode nav a.active-link{color:#0f2a1c}body.light-mode .mobile-home-menu nav{background:#fffffff2;box-shadow:0 18px 30px #18263724}body.light-mode .timeline-item span{color:var(--btn)}body.light-mode .scroll-top{color:#0f2a1c;background:#ffffffe6}body.light-mode .color-dropdown button{color:#173325}body.light-mode .color-current{color:#0f2a1c;background:#00000008}body.light-mode .glass-card{color:#0f2a1c;background:#ffffffe6}body.light-mode .project-card,body.light-mode .timeline-item,body.light-mode .post-card{background:#fff;border:1px solid #18402e57;box-shadow:0 16px 34px #18263724}body.light-mode .project-card:hover,.timeline-item:hover{background:color-mix(in srgb, var(--bg-soft))}body.light-mode .chatbot-messages{background:#fff}body.light-mode .chatbot-avatar,body.light-mode .chatbot-title,body.light-mode .chatbot-form,body.light-mode .chatbot-header,body.light-mode .chatbot-input-group input,body.light-mode .message-icon,body.light-mode .message-bubble.assistant{background:var(--bg);color:#000}body.light-mode .chatbot-header{border-bottom:1px solid gray}body.light-mode .chatbot-form{border-top:1px solid gray}body.light-mode .carousel-btn{color:#153324;border-color:color-mix(in srgb, var(--primary) 45%, #18402e33);background:#fffffff0}body.light-mode .carousel-dot{background:#15332447}body.light-mode .glass-card button{color:#0f2a1c}body.light-mode .tech{color:#000;font-weight:600}body.light-mode .color-dropdown button{background:#fffffff0}a{color:inherit;text-decoration:none}#app{min-height:100svh}.navbar{z-index:20;border:1px solid var(--border);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#000000a8;border-radius:999px;justify-content:space-between;align-items:center;gap:1rem;margin-top:1rem;padding:.85rem 1rem;display:flex;position:sticky;top:1rem}.nav-actions{align-items:center;gap:.7rem;display:flex}.menu-controls{flex-wrap:wrap;justify-content:flex-end;align-items:center;gap:.6rem;display:flex}.burger{border:1px solid var(--border);cursor:pointer;background:#ffffff12;border-radius:.6rem;flex-direction:column;justify-content:center;align-items:center;gap:.2rem;width:2.2rem;height:2.2rem;transition:background .18s,transform .18s;display:none}.burger span{background:var(--text);border-radius:999px;width:1rem;height:2px;transition:transform .18s,opacity .18s}.burger:hover{background:#ffffff24;transform:translateY(-1px)}.burger.is-open span:first-child{transform:translateY(6px)rotate(45deg)}.burger.is-open span:nth-child(2){opacity:0}.burger.is-open span:nth-child(3){transform:translateY(-6px)rotate(-45deg)}.brand{background:var(--primary);border-radius:999px;justify-content:center;align-items:center;width:2.8rem;height:2.8rem;font-size:1.55rem;font-weight:800;display:flex}.brand-icon{width:1.35rem;height:1.35rem;color:var(--bg);font-size:1.9rem;font-weight:700;line-height:1;display:block}nav{flex-wrap:wrap;gap:1rem;display:flex}.theme-toggle{border:1px solid var(--border);cursor:pointer;background:#ffffff12;border-radius:999px;place-items:center;width:2.2rem;height:2.2rem;font-size:1rem;transition:transform .18s,background .18s;display:grid}.lang-switcher{border:1px solid var(--border);background:#ffffff0d;border-radius:999px;display:inline-flex;overflow:hidden}.lang-switcher button{color:var(--muted);cursor:pointer;background:0 0;border:none;padding:.3rem .6rem;font-size:.75rem;font-weight:700}.lang-switcher button.active-lang{color:var(--bg);background:var(--primary)}.theme-toggle:hover{background:#ffffff26;transform:translateY(-1px)}nav a{color:var(--muted);border-radius:.45rem;padding:.28rem .52rem;transition:color .18s,background .18s}nav a:hover{color:var(--text)}nav a.active-link{color:var(--text);background:var(--primary-soft)}.mobile-home-menu{display:none}.hero-section{grid-template-columns:repeat(2,minmax(0,1fr));align-items:center;gap:2rem;min-height:calc(100svh - 5rem);padding:3rem 0;display:grid}.eyebrow{color:var(--primary);text-transform:uppercase;letter-spacing:.18em;font-size:.78rem}h1{margin:.2rem 0;font-size:clamp(2.2rem,5vw,4rem);line-height:1.05}h2{color:var(--primary);margin-top:0;font-weight:500}.typing-role{min-height:1.6em}.typing-caret{background:var(--primary-2);vertical-align:-.08em;width:.08em;height:1em;margin-left:.1em;animation:1s step-end infinite blink-caret;display:inline-block}.hero-cta{flex-wrap:wrap;gap:.8rem;margin:1.4rem 0 1.2rem;display:flex}.btn{border:1px solid var(--border);border-radius:.7rem;padding:.75rem 1.2rem;transition:transform .18s,box-shadow .18s}.btn:hover{box-shadow:var(--shadow);transform:translateY(-2px)}.primary{background:var(--primary);color:var(--bg-soft);border:none;font-weight:700}.secondary{background:#ffffff0d}.contact-row{flex-wrap:wrap;gap:.7rem;display:flex}.contact-row a{border:1px solid var(--border);color:var(--muted);border-radius:999px;align-items:center;gap:.2rem;padding:.55rem .8rem;transition:all .18s;display:flex}.contact-row svg{width:20px;color:var(--primary)}.contact-row a:hover{color:var(--text);background:#ffffff14}.hero-visual{place-items:center;min-height:320px;display:grid;position:relative}.blob-frame{aspect-ratio:1;border:1px solid var(--border);background:linear-gradient(120deg, var(--primary), var(--primary-2));border-radius:40% 60% 64% 36%/40% 40% 60% 60%;width:min(340px,80vw);animation:6s ease-in-out infinite float;overflow:hidden}.blob-photo{object-fit:cover;width:100%;height:100%;display:block}.glass-card{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);isolation:isolate;background:#0000008a;border:1px solid #0000;border-radius:.9rem;padding:1rem 1.2rem;font-weight:700;position:absolute;bottom:1rem;right:1rem;overflow:hidden}.glass-card:before{content:"";border-radius:inherit;background:linear-gradient(90deg, transparent 0%, transparent 40%, var(--primary) 50%, var(--primary-2) 55%, transparent 65%, transparent 100%);-webkit-mask-composite:xor;pointer-events:none;background-size:300% 100%;padding:2px;animation:6s linear infinite snakeMove;position:absolute;inset:0;-webkit-mask-image:linear-gradient(#000 0 0),linear-gradient(#000 0 0);-webkit-mask-position:0 0,0 0;-webkit-mask-size:auto,auto;-webkit-mask-repeat:repeat,repeat;-webkit-mask-clip:content-box,border-box;-webkit-mask-origin:content-box,border-box;-webkit-mask-composite:xor;mask-composite:exclude;-webkit-mask-source-type:auto,auto;mask-mode:match-source,match-source}@keyframes snakeMove{0%{background-position:0 0}to{background-position:300% 0}}.glass-card>*{z-index:1;position:relative}.glass-card button{color:inherit;cursor:pointer;background:0 0;border:none;position:relative}.copied-label{background:linear-gradient(120deg, var(--primary), var(--primary-2));opacity:0;color:#000;border-radius:10px;padding:2px;font-size:.75rem;font-weight:600;animation:1.5s fadeInOut;position:absolute;top:-1rem;right:0}@keyframes fadeInOut{0%{opacity:0;transform:translateY(4px)}20%{opacity:1;transform:translateY(0)}80%{opacity:1}to{opacity:0;transform:translateY(-4px)}}.section{padding:2rem 0 1rem;scroll-margin-top:clamp(5.4rem,9vw,7rem)}h3{margin-bottom:1.2rem;font-size:clamp(1.7rem,3vw,2.2rem)}#certification{flex-wrap:wrap;justify-content:center;align-items:center;gap:15px;display:flex}#certification img{object-fit:cover;width:150px;height:150px}.project-carousel{grid-template-columns:auto minmax(0,1fr) auto;align-items:center;gap:.8rem;width:100%;display:grid}.disabled{opacity:.5;cursor:not-allowed}.project-track-viewport{width:100%;overflow:hidden}.project-track{touch-action:pan-y;width:100%;display:block}.project-track swiper-slide{height:auto;padding-top:.2rem}.project-track .project-slide{height:auto}.project-track .project-card{min-width:0;height:100%}.project-card,.post-card,.timeline-item{border:1px solid color-mix(in srgb, var(--primary-2) 48%, transparent);background:#000;border-radius:1rem;padding:1.2rem;transition:transform .18s,border-color .18s,box-shadow .18s,background .18s;position:relative;box-shadow:0 18px 36px #00000057}.timeline-item h5{border:1px solid color-mix(in srgb, var(--primary-2) 40%, transparent);background:color-mix(in srgb, var(--bg-soft) 82%, var(--primary));border-radius:.5rem;margin:0;padding:0 10px;position:absolute;top:-12px}.project-card{text-align:left;flex-direction:column;justify-content:space-between;gap:.9rem;display:flex}.project-card:hover,.timeline-item:hover{border-color:var(--primary-2);background:color-mix(in srgb, var(--bg-soft) 78%, black);transform:translateY(-2px);box-shadow:0 22px 44px #0000007a}.project-card-active{min-height:420px}.project-preview{aspect-ratio:16/10;object-fit:cover;border:1px solid color-mix(in srgb, var(--primary-2) 56%, transparent);border-radius:.8rem;width:100%;margin-bottom:1rem}.carousel-btn{border:1px solid color-mix(in srgb, var(--primary-2) 62%, transparent);width:2.7rem;height:2.7rem;color:var(--text);cursor:pointer;background:#08130ee0;border-radius:999px;font-size:1.2rem;transition:transform .18s,background .18s,border-color .18s}.carousel-btn:hover{background:color-mix(in srgb, var(--bg-soft) 92%, black);border-color:var(--primary-2);transform:translateY(-2px)}.carousel-btn:disabled{opacity:.45;cursor:not-allowed;transform:none}.carousel-dots{justify-content:center;gap:.5rem;margin-top:.9rem;display:flex}.carousel-dot{border:1px solid color-mix(in srgb, var(--primary-2) 62%, transparent);cursor:pointer;background:#fff3;border-radius:999px;width:.62rem;height:.62rem;padding:0}.carousel-dot.active-dot{border-color:var(--primary-2);background:linear-gradient(120deg, var(--primary), var(--primary-2));width:1.5rem}.project-card h4,.timeline-item h4{margin:.5rem 0;font-size:1.08rem;line-height:1.35}.project-card p,.timeline-item p{color:var(--text)}.project-card p{max-height:7.4rem;margin:.3rem 0 0;line-height:1.55;overflow-y:auto}.project-card p::-webkit-scrollbar{width:5px}.project-card p::-webkit-scrollbar-thumb{background:var(--bg);border-radius:10px}.tech{flex-wrap:wrap;gap:5px;width:100%;display:flex}.badge{background:var(--bg-soft);border-radius:10px;padding:0 5px;font-size:.85rem}.project-links{gap:.9rem;display:flex}.project-links a{color:var(--primary);border-bottom:1px solid #0000;font-size:.92rem}.project-links a:hover{color:var(--primary-2);border-bottom-color:color-mix(in srgb, var(--primary-2) 80%, transparent)}body.light-mode .project-links a{color:#174331;border-bottom-color:#17433147;font-weight:600}body.light-mode .project-links a:hover{color:#0d2f22;border-bottom-color:var(--primary)}.timeline{border-left:1px solid var(--border);gap:1.5rem;padding-left:1rem;display:grid}.timeline-item span{color:var(--primary-2);font-size:.88rem;font-weight:500}.education p{padding:none!important;margin:none!important}.education{flex-direction:row;justify-content:center;display:flex}.education .timeline-item{text-align:center;flex-direction:column;flex:1;align-items:center;padding:1.5rem .75rem;display:flex}.post-card{flex-direction:column;justify-content:space-between;height:100%;display:flex}.post-card h4{margin:0}.footer{border-top:1px solid var(--border);color:var(--muted);justify-items:center;gap:.9rem;margin-top:4rem;padding-top:1.5rem;display:grid}.reveal{opacity:0;transition:opacity .6s,transform .6s;transform:translateY(20px)}.reveal.visible{opacity:1;transform:translateY(0)}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-12px)}}@keyframes blink-caret{0%,49%{opacity:1}50%,to{opacity:0}}@keyframes glass-border-spin{to{transform:rotate(1turn)}}@media (width<=800px){.navbar{border-radius:.9rem;align-items:center;top:.6rem}.nav-actions{display:none}.burger{order:-1;margin-right:.4rem;display:inline-flex}.brand{display:none}.menu-controls{justify-content:flex-end;gap:.45rem;width:auto;margin-left:0}.mobile-home-menu{z-index:19;margin-top:.35rem;display:block;position:sticky;top:4.35rem}.mobile-home-menu nav{border:1px solid var(--border);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:linear-gradient(160deg,#141a2ef7,#0c1222f2);border-radius:1rem;flex-direction:column;gap:.45rem;padding:.9rem;display:flex;box-shadow:0 18px 30px #00000059}.mobile-home-menu nav a{text-align:center;background:#ffffff05;border:1px solid #0000;border-radius:.5rem;width:100%;padding:.55rem .8rem;font-size:.98rem;font-weight:500}.mobile-home-menu nav a.active-link{border-color:var(--primary-soft-strong);background:var(--primary-soft)}.hero-section{grid-template-columns:1fr;min-height:auto;padding-top:2.3rem}#certification img{object-fit:cover;width:100px;height:100px}.project-carousel{grid-template-columns:1fr;gap:.7rem}.project-track,.project-track .project-card{width:100%}.project-card-active,.project-card h4,.project-card p{min-height:auto}.carousel-btn-prev,.carousel-btn-next{display:none}.carousel-btn{justify-self:center}.education{flex-direction:column;justify-content:center;align-items:center;display:flex}.education .timeline-item{width:100%}.timeline{border-left:none;padding-left:0}}.scroll-top.svelte-1y5g30{border:1px solid var(--border);width:2.4rem;height:2.4rem;color:var(--text);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);cursor:pointer;z-index:30;background:#141a2ed9;border-radius:999px;font-size:1rem;transition:transform .18s,background .18s;position:fixed;bottom:1.4rem;right:1.2rem}.scroll-top.svelte-1y5g30:hover{background:var(--primary-soft-strong);transform:translateY(-2px)}.sr-only.svelte-m466h8{clip:rect(0, 0, 0, 0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.color-trigger.svelte-m466h8{border:1px solid var(--border);color:var(--text);cursor:pointer;background:#ffffff0f;border-radius:999px;place-items:center;width:2.2rem;height:2.2rem;font-size:1rem;font-weight:700;display:grid}.color-trigger.svelte-m466h8:hover{background:#ffffff24}.color-dropdown.svelte-m466h8{border:1px solid var(--border);background:var(--bg);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:.7rem;gap:.25rem;min-width:9.5rem;padding:.45rem;display:grid;position:absolute;top:calc(100% + .45rem);right:0;box-shadow:0 14px 26px #00000042}.color-dropdown.svelte-m466h8 button:where(.svelte-m466h8){color:var(--text);cursor:pointer;text-align:left;background:#ffffff0d;border:1px solid #0000;border-radius:.45rem;align-items:center;gap:.45rem;padding:.35rem .58rem;font-size:.72rem;font-weight:700;display:flex}.color-dropdown.svelte-m466h8 button.active-color:where(.svelte-m466h8){color:#052012;background:linear-gradient(120deg, var(--primary), var(--primary-2))}.swatch.svelte-m466h8{border:1px solid #ffffff59;border-radius:999px;flex:none;width:.65rem;height:.65rem}.swatch-green.svelte-m466h8{background:#62d47f}.swatch-black.svelte-m466h8{background:#1c1c1c}.swatch-purple.svelte-m466h8{background:#7a4cff}.swatch-yellow.svelte-m466h8{background:#f4c542}.swatch-blue.svelte-m466h8{background:#8abcfd}@media (width<=800px){.color-trigger.svelte-m466h8,.color-dropdown.svelte-m466h8 button:where(.svelte-m466h8){font-size:.68rem}.color-trigger.svelte-m466h8{width:2rem;height:2rem;font-size:.92rem}}.chatbot-widget{z-index:50;position:fixed;bottom:4.5rem;right:1.2rem}.chatbot-panel{background:#09090b;border:1px solid #ffffff1a;border-radius:1.5rem;flex-direction:column;width:calc(100vw - 3rem);max-width:24rem;height:50vh;margin-left:1.5rem;display:flex;overflow:hidden;box-shadow:0 25px 50px -12px #00000080,0 0 0 1px #ffffff08}@media (width>=640px){.chatbot-panel{max-width:28rem}}@media (width>=768px){.chatbot-panel{width:32rem;max-width:32rem;height:40rem}}.chatbot-header{background:#18181b;border-bottom:1px solid #ffffff1a;justify-content:space-between;align-items:center;padding:1rem 1.5rem;display:flex}.chatbot-header-left{align-items:center;gap:.75rem;display:flex}.chatbot-avatar{background-color:var(--bg);width:2.5rem;height:2.5rem;color:var(--primary);border-radius:9999px;justify-content:center;align-items:center;display:flex}.chatbot-avatar svg{width:1.5rem!important;height:1.5rem!important}.chatbot-title{color:#fff;margin:0;font-size:1rem;font-weight:600}.chatbot-subtitle{color:#a1a1aa;margin:0;font-size:.875rem}.chatbot-close{color:#d4d4d8;cursor:pointer;background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;width:2rem;height:2rem;padding:0;transition:background-color .2s,color .2s;display:flex}.chatbot-close:hover{background:var(--primary-2)}.chatbot-close-icon{flex-shrink:0;width:1rem!important;height:1rem!important;font-size:1rem!important}.chatbot-messages{flex:1;padding:1.5rem 1rem;overflow-y:auto}@media (width>=640px){.chatbot-messages{padding:1.5rem}}.chatbot-messages-list{flex-direction:column;gap:1.5rem;display:flex}.message-row{display:flex}.message-row.user{justify-content:flex-end}.message-row.assistant{justify-content:flex-start}.message-wrapper{align-items:flex-start;gap:.75rem;max-width:85%;display:flex}.message-wrapper.user{flex-direction:row-reverse}.message-icon{border-radius:9999px;flex-shrink:0;justify-content:center;align-items:center;width:2.25rem;height:2.25rem;margin-top:.25rem;display:flex}.message-icon.user{background:var(--primary);color:var(--textBot)}.message-icon svg{width:1.2rem!important;height:1.2rem!important}.message-icon.assistant{color:#d4d4d8;background:#27272a}.message-bubble{white-space:pre-wrap;word-break:break-word;border-radius:1rem;padding:.75rem 1rem;font-size:.875rem;line-height:1.6;box-shadow:0 10px 20px #00000040}.message-bubble p{margin:0}.message-bubble.user{background:var(--primary);color:var(--textBot)}.message-bubble.assistant{color:#f4f4f5;background:#18181b;border:1px solid #ffffff0d}.loading-content{align-items:center;gap:.5rem;font-size:.875rem;display:flex}.loading-content svg{flex-shrink:0;width:1rem!important;height:1rem!important;font-size:1rem!important}.chatbot-send .spin svg,.loading-content svg{font-size:12px;animation:1s linear infinite spin}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.chatbot-form{background:#18181b;border-top:1px solid #ffffff1a;padding:1rem}.chatbot-input-group{align-items:flex-end;gap:.75rem;display:flex}.chatbot-input{color:#fff;background:#09090b;border:1px solid #ffffff1a;border-radius:1rem;outline:none;flex:1;padding:.75rem 1rem;font-size:.875rem}.chatbot-input::placeholder{color:#71717a}.chatbot-input:focus{border-color:var(--primary)}.chatbot-input:disabled{opacity:.6}.chatbot-send{background:var(--primary);width:2.5rem;height:2.5rem;color:var(--textBot);cursor:pointer;border:none;border-radius:1rem;justify-content:center;align-items:center;transition:background .2s,opacity .2s;display:flex}.chatbot-send:hover:not(:disabled){background:var(--primary)}.chatbot-send:disabled{opacity:.5;cursor:not-allowed}.chatbot-toggle{background:var(--primary);width:3rem;height:3rem;color:var(--textBot);cursor:pointer;border:none;border-radius:9999px;justify-content:center;align-items:center;font-size:1.75rem;transition:transform .2s,background .2s;display:flex;box-shadow:0 10px 25px #0000004d}.chatbot-toggle:hover{background:var(--primary-2);transform:scale(1.05)}.chatbot-toggle svg{width:2rem!important;height:2rem!important}svg.svelte-1n3xayn{stroke:currentColor;fill:currentColor;stroke-width:0;width:100%;height:auto;max-height:100%}.matrix-bg.svelte-1n46o8q{z-index:0;pointer-events:none;opacity:.8;width:100%;height:100%;position:fixed;inset:0}.site-shell.svelte-1n46o8q{z-index:1;margin:0 auto;padding-bottom:2.5rem;position:relative;max-width:1180px!important}@media (width<=800px){.site-shell.svelte-1n46o8q{padding:0 1.5rem}}
