:root{--primary: #C8E6F5;--primary-dark: #A8D5E5;--accent: #A8D5BA;--accent-dark: #8BC4A0;--highlight: #F5D5C8;--highlight-dark: #EBC4B5;--surface: #F9F6F0;--card: #FFFFFF;--text-primary: #2C3E50;--text-secondary: #556B7F;--border: #E8EDF2;--font-display: "Sora", sans-serif;--font-body: "Plus Jakarta Sans", sans-serif;--text-xs: .75rem;--text-sm: .875rem;--text-base: 1rem;--text-lg: 1.125rem;--text-xl: 1.25rem;--text-2xl: 1.5rem;--text-3xl: 1.875rem;--text-4xl: 2.25rem;--text-5xl: 3rem;--spacing-1: .25rem;--spacing-2: .5rem;--spacing-3: .75rem;--spacing-4: 1rem;--spacing-6: 1.5rem;--spacing-8: 2rem;--spacing-10: 2.5rem;--spacing-12: 3rem;--spacing-16: 4rem;--spacing-24: 6rem;--shadow-sm: 0 1px 2px 0 rgba(44, 62, 80, .05);--shadow-md: 0 4px 6px -1px rgba(44, 62, 80, .08), 0 2px 4px -1px rgba(44, 62, 80, .04);--shadow-lg: 0 10px 15px -3px rgba(44, 62, 80, .08), 0 4px 6px -2px rgba(44, 62, 80, .04);--shadow-xl: 0 20px 25px -5px rgba(44, 62, 80, .08), 0 10px 10px -5px rgba(44, 62, 80, .03);--shadow-2xl: 0 25px 50px -12px rgba(44, 62, 80, .18);--ease-out-quart: cubic-bezier(.25, 1, .5, 1);--ease-out-quint: cubic-bezier(.22, 1, .36, 1);--ease-out-expo: cubic-bezier(.16, 1, .3, 1);--ease-in-out: cubic-bezier(.77, 0, .175, 1);--ease-ui: cubic-bezier(.23, 1, .32, 1);--transition-instant: .12s var(--ease-ui);--transition-fast: .16s var(--ease-ui);--transition-base: .22s var(--ease-ui);--transition-slow: .32s var(--ease-out-quint);--z-base: 0;--z-raised: 1;--z-dropdown: 10;--z-sticky: 20;--z-nav: 30;--z-modal: 40;--z-tooltip: 50}[data-theme=dark]{--primary: #1E3A4A;--primary-dark: #2A4F63;--accent: #1A3D2A;--accent-dark: #3a7a55;--highlight: #4A2E25;--highlight-dark: #5E3D32;--surface: #0D1318;--card: #182028;--text-primary: #E6F2F8;--text-secondary: #7FA3B8;--border: #253340;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .35);--shadow-md: 0 4px 8px rgba(0, 0, 0, .4), 0 2px 4px rgba(0, 0, 0, .25);--shadow-lg: 0 10px 20px rgba(0, 0, 0, .45), 0 4px 8px rgba(0, 0, 0, .25);--shadow-xl: 0 20px 30px rgba(0, 0, 0, .5), 0 10px 12px rgba(0, 0, 0, .25);--shadow-2xl: 0 28px 56px rgba(0, 0, 0, .6)}[data-theme=dark] .nav--scrolled{background:#0d1318e0;box-shadow:0 1px 0 var(--border),0 2px 12px #0000004d}[data-theme=dark] .nav__link:hover,[data-theme=dark] .nav__link--active{background:#2a4f6366;color:var(--text-primary)}[data-theme=dark] .nav__links{background:var(--card)}[data-theme=dark] .open-to-work{background:#22c55e12;border-color:#22c55e38;color:#4ade80}[data-theme=dark] .timeline__sub-card{background:#1e303e80;border-left-color:var(--accent-dark)}[data-theme=dark] .form__input,[data-theme=dark] .form__textarea{background:#1e303e80;border-color:var(--border);color:var(--text-primary)}[data-theme=dark] .form__input::placeholder,[data-theme=dark] .form__textarea::placeholder{color:var(--text-secondary);opacity:.6}[data-theme=dark] .form__input:focus,[data-theme=dark] .form__textarea:focus{border-color:var(--primary-dark);background:#2a3f4f99;box-shadow:0 0 0 3px #2a4f6340}[data-theme=dark] .project-slider__prev,[data-theme=dark] .project-slider__next{background:#182028eb;color:var(--text-primary)}[data-theme=dark] .project-slider__prev:hover,[data-theme=dark] .project-slider__next:hover{background:#253340}[data-theme=dark] .skill-card__icon{background:linear-gradient(135deg,var(--primary-dark) 0%,var(--accent-dark) 100%);box-shadow:0 4px 14px #3a7a554d}[data-theme=dark] .project-card__image:after{background:linear-gradient(to right,transparent 65%,var(--card) 100%)}[data-theme=dark] .toast{background:#e6f2f8;color:#0d1318}[data-theme=dark] .toast__icon{background:#16a34a}[data-theme=dark] .feedback-success{background:#15803d26;color:#4ade80;border-color:#4ade804d}[data-theme=dark] .feedback-error{background:#b91c1c26;color:#fca5a5;border-color:#fca5a54d}.theme-toggle .icon-sun{display:none}.theme-toggle .icon-moon,[data-theme=dark] .theme-toggle .icon-sun{display:block}[data-theme=dark] .theme-toggle .icon-moon{display:none}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-body);color:var(--text-primary);background-color:var(--surface);line-height:1.6;overflow-x:hidden;transition:background-color var(--transition-slow),color var(--transition-slow)}img{max-width:100%;height:auto;display:block}input,textarea,button{font-family:inherit;font-size:inherit;color:inherit}ul,ol{list-style:none}a{text-decoration:none;color:inherit}.skip-link{position:absolute;top:-100%;left:var(--spacing-4);padding:var(--spacing-2) var(--spacing-4);background:var(--text-primary);color:var(--card);border-radius:0 0 8px 8px;font-size:var(--text-sm);font-weight:600;z-index:calc(var(--z-nav) + 10);transition:top var(--transition-fast)}.skip-link:focus{top:0}.font-display{font-family:var(--font-display)}.text-xs{font-size:var(--text-xs)}.text-sm{font-size:var(--text-sm)}.text-base{font-size:var(--text-base)}.text-lg{font-size:var(--text-lg)}.text-xl{font-size:var(--text-xl)}.text-2xl{font-size:var(--text-2xl)}.text-3xl{font-size:var(--text-3xl)}.text-4xl{font-size:var(--text-4xl)}.text-5xl{font-size:var(--text-5xl)}.font-medium{font-weight:500}.font-semibold{font-weight:600}.font-bold{font-weight:700}.text-secondary{color:var(--text-secondary)}.text-accent{color:var(--accent-dark)}.container{max-width:1200px;margin:0 auto;padding:0 var(--spacing-6)}.section{padding:var(--spacing-24) 0}.section-header{text-align:center;margin-bottom:var(--spacing-12)}.section-title{font-family:var(--font-display);font-size:var(--text-3xl);font-weight:700;color:var(--text-primary);margin-bottom:var(--spacing-4);letter-spacing:-.02em}.section-subtitle{font-size:var(--text-lg);color:var(--text-secondary);max-width:600px;margin:0 auto;line-height:1.6}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--spacing-2);padding:var(--spacing-3) var(--spacing-8);font-size:var(--text-sm);font-weight:600;border-radius:8px;border:none;cursor:pointer;transition:transform var(--transition-fast),box-shadow var(--transition-fast),background-color var(--transition-fast),border-color var(--transition-fast);text-decoration:none;white-space:nowrap;user-select:none}.btn--primary{background:var(--text-primary);color:var(--card);box-shadow:var(--shadow-md)}@media(hover:hover)and (pointer:fine){.btn--primary:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}}.btn--primary:active{transform:scale(.97) translateY(0);box-shadow:var(--shadow-sm)}.btn--secondary{background:transparent;color:var(--text-primary);border:1px solid var(--border)}@media(hover:hover)and (pointer:fine){.btn--secondary:hover{background:#c8e6f526;border-color:var(--primary-dark);transform:translateY(-2px)}}.btn--secondary:active{transform:scale(.97) translateY(0)}.btn--sm{padding:var(--spacing-2) var(--spacing-4);font-size:var(--text-xs)}.btn:focus{outline:none}.btn:focus-visible{outline:2px solid var(--accent-dark);outline-offset:3px}.text-gradient{background:linear-gradient(135deg,var(--primary-dark),var(--accent-dark));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.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}.custom-cursor{position:fixed;width:20px;height:20px;border:2px solid var(--accent-dark);border-radius:50%;pointer-events:none;z-index:9999;transition:width .24s var(--ease-out-quint),height .24s var(--ease-out-quint),border-color .24s var(--ease-ui),background-color .24s var(--ease-ui);transform:translate(-50%,-50%)}.custom-cursor--active{width:44px;height:44px;border-color:var(--primary-dark);background:#c8e6f514}.toast{position:fixed;bottom:24px;right:24px;background:#1a2530;color:#e8f4f9;padding:10px 16px;border-radius:10px;font-size:.82rem;font-weight:500;display:flex;align-items:center;gap:8px;box-shadow:0 8px 24px #0003;opacity:0;transform:translateY(8px);transition:opacity .22s var(--ease-ui),transform .22s var(--ease-out-quint);pointer-events:none;z-index:9999}.toast.show{opacity:1;transform:translateY(0)}.toast__icon{width:16px;height:16px;background:#22c55e;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0}.feedback-success{background:#e8f5e9;color:#1b5e20;border:1px solid #a5d6a7;padding:var(--spacing-4);border-radius:8px;margin-top:var(--spacing-4);font-size:var(--text-sm);font-weight:500}.feedback-error{background:#fdecea;color:#b71c1c;border:1px solid #ef9a9a;padding:var(--spacing-4);border-radius:8px;margin-top:var(--spacing-4);font-size:var(--text-sm);font-weight:500}#btn-submit.loading{position:relative;color:transparent;pointer-events:none}#btn-submit.loading:after{content:"";position:absolute;width:18px;height:18px;top:50%;left:50%;margin:-9px 0 0 -9px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite}@keyframes fadeIn{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes otw-pulse{0%,to{transform:scale(1);opacity:1}60%{transform:scale(1.8);opacity:0}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}html{scroll-behavior:auto}}@media(min-width:1280px){.container{padding:0 var(--spacing-8)}}@media(max-width:767px){.section{padding:var(--spacing-16) 0}}@media(max-width:479px){:root{--text-3xl: 1.5rem;--text-4xl: 1.875rem;--text-5xl: 2.25rem}.container{padding:0 var(--spacing-4)}.section{padding:var(--spacing-12) 0}.btn{padding:var(--spacing-3) var(--spacing-4)}}.nav{position:fixed;top:0;left:0;right:0;z-index:var(--z-nav);padding:var(--spacing-4) 0;transition:padding var(--transition-slow),backdrop-filter var(--transition-slow),box-shadow var(--transition-slow)}.nav--scrolled{backdrop-filter:blur(14px) saturate(1.4);-webkit-backdrop-filter:blur(14px) saturate(1.4);background:#f9f6f0d1;box-shadow:0 1px 0 var(--border),var(--shadow-sm);padding:var(--spacing-3) 0}.nav__container{display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-4)}.nav__logo{font-family:var(--font-display);font-size:var(--text-xl);font-weight:700;color:var(--text-primary);letter-spacing:-.02em;flex-shrink:0}.nav__links{display:flex;align-items:center;gap:var(--spacing-1)}.nav__link{font-size:var(--text-sm);font-weight:500;color:var(--text-secondary);padding:6px var(--spacing-3);border-radius:6px;transition:color var(--transition-fast),background-color var(--transition-fast);position:relative}@media(hover:hover)and (pointer:fine){.nav__link:hover{color:var(--text-primary);background:#c8e6f540}}.nav__link--active{color:var(--text-primary);background:#c8e6f559}.nav__link:focus{outline:none}.nav__link:focus-visible{outline:2px solid var(--accent-dark);outline-offset:2px}.nav__actions{display:flex;align-items:center;gap:var(--spacing-2);flex-shrink:0}.nav__hamburger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:var(--spacing-2);border-radius:6px;transition:background-color var(--transition-fast)}@media(hover:hover)and (pointer:fine){.nav__hamburger:hover{background:#c8e6f540}}.nav__hamburger:focus{outline:none}.nav__hamburger:focus-visible{outline:2px solid var(--accent-dark);outline-offset:2px}.nav__hamburger span{display:block;width:22px;height:2px;background:var(--text-primary);border-radius:2px;transition:transform var(--transition-base),opacity var(--transition-fast)}.nav__hamburger--open span:nth-child(1){transform:rotate(45deg) translate(4px,5px)}.nav__hamburger--open span:nth-child(2){opacity:0;transform:scaleX(0)}.nav__hamburger--open span:nth-child(3){transform:rotate(-45deg) translate(4px,-5px)}.theme-toggle{display:flex;align-items:center;justify-content:center;width:34px;height:34px;border-radius:8px;background:transparent;border:1px solid var(--border);cursor:pointer;color:var(--text-secondary);transition:color var(--transition-fast),background-color var(--transition-fast),border-color var(--transition-fast),transform var(--transition-fast);flex-shrink:0}@media(hover:hover)and (pointer:fine){.theme-toggle:hover{color:var(--text-primary);background:#c8e6f533;border-color:var(--primary-dark)}}.theme-toggle:active{transform:scale(.93)}.theme-toggle:focus{outline:none}.theme-toggle:focus-visible{outline:2px solid var(--accent-dark);outline-offset:2px}.cv-dropdown{position:relative;display:inline-block}.cv-dropdown__menu{position:absolute;top:50%;left:calc(100% + var(--spacing-3));background:var(--card);border:1px solid var(--border);border-radius:12px;box-shadow:var(--shadow-xl);padding:var(--spacing-2);min-width:190px;opacity:0;visibility:hidden;transform:translateY(-50%) translate(-8px);transition:opacity var(--transition-base),visibility var(--transition-base),transform var(--transition-slow);z-index:var(--z-dropdown)}.cv-dropdown__menu.show{opacity:1;visibility:visible;transform:translateY(-50%) translate(0)}.cv-dropdown__menu .cv-dropdown__arrow{position:absolute;top:50%;right:100%;width:14px;height:14px;margin-right:-1px;transform:translateY(-50%) rotate(180deg);fill:none;stroke:var(--border);stroke-width:2;stroke-linecap:round;stroke-linejoin:round;opacity:0}.cv-dropdown__menu.show .cv-dropdown__arrow{opacity:1;animation:cvArrowPulse 2s var(--ease-in-out) infinite}@keyframes cvArrowPulse{0%,to{transform:translateY(-50%) rotate(180deg) translate(0)}50%{transform:translateY(-50%) rotate(180deg) translate(-5px)}}.cv-dropdown__item{display:flex;align-items:center;gap:var(--spacing-3);padding:var(--spacing-3) var(--spacing-4);border-radius:8px;font-size:var(--text-sm);font-weight:500;color:var(--text-primary);transition:background-color var(--transition-fast)}@media(hover:hover)and (pointer:fine){.cv-dropdown__item:hover{background:var(--surface)}}.cv-dropdown__item:focus{outline:none}.cv-dropdown__item:focus-visible{outline:2px solid var(--accent-dark);outline-offset:-2px}.cv-dropdown__flag{font-size:var(--text-lg);line-height:1}@media(max-width:767px){.nav__links{position:fixed;top:0;right:-100%;width:70%;max-width:300px;height:100vh;background:var(--card);flex-direction:column;align-items:flex-start;padding:var(--spacing-24) var(--spacing-8) var(--spacing-8);gap:0;transition:right var(--transition-slow);box-shadow:var(--shadow-2xl);z-index:var(--z-nav)}.nav__links--open{right:0}.nav__link{width:100%;padding:var(--spacing-3) var(--spacing-2);border-bottom:1px solid var(--border);border-radius:0}.nav__hamburger{display:flex;z-index:calc(var(--z-nav) + 1)}}@media(max-width:479px){.cv-dropdown__menu{top:calc(100% + var(--spacing-2));left:auto;right:0;transform:translateY(-6px)}.cv-dropdown__menu.show{transform:translateY(0)}}.hero{position:relative;min-height:100dvh;display:flex;align-items:center;justify-content:center;padding:var(--spacing-24) var(--spacing-6);overflow:hidden}.hero__bg-shapes{position:absolute;inset:0;pointer-events:none;overflow:hidden}.hero__shape{position:absolute;border-radius:50%;will-change:transform}.hero__shape--1{width:clamp(280px,35vw,420px);height:clamp(280px,35vw,420px);background:radial-gradient(circle at 40% 40%,var(--primary),var(--primary-dark));top:8%;left:-80px;opacity:.55}.hero__shape--2{width:clamp(200px,28vw,320px);height:clamp(200px,28vw,320px);background:radial-gradient(circle at 60% 40%,var(--accent),var(--accent-dark));top:48%;right:-60px;opacity:.5}.hero__shape--3{width:clamp(140px,18vw,220px);height:clamp(140px,18vw,220px);background:radial-gradient(circle at 50% 50%,var(--highlight),var(--highlight-dark));bottom:22%;left:28%;opacity:.45}.hero__content{position:relative;z-index:var(--z-raised);text-align:center;max-width:820px;width:100%}.hero__name{font-family:var(--font-display);font-size:clamp(var(--text-3xl),5vw,var(--text-5xl));font-weight:700;color:var(--text-primary);margin-bottom:var(--spacing-3);line-height:1.15;letter-spacing:-.03em}.hero__role{font-family:var(--font-display);font-size:clamp(var(--text-lg),2.5vw,var(--text-xl));font-weight:500;color:var(--text-secondary);margin-bottom:var(--spacing-4);letter-spacing:.01em}.open-to-work{display:inline-flex;align-items:center;gap:var(--spacing-2);padding:6px var(--spacing-4);background:#22c55e1a;border:1px solid rgba(34,197,94,.28);border-radius:100px;font-size:var(--text-sm);font-weight:600;color:#15803d;margin-bottom:var(--spacing-5);cursor:pointer;transition:background-color var(--transition-fast),transform var(--transition-fast),box-shadow var(--transition-fast);text-decoration:none}@media(hover:hover)and (pointer:fine){.open-to-work:hover{background:#22c55e29;transform:translateY(-2px);box-shadow:0 4px 12px #22c55e26}}.open-to-work:focus{outline:none}.open-to-work:focus-visible{outline:2px solid #22c55e;outline-offset:3px}.open-to-work__dot{width:8px;height:8px;background:#22c55e;border-radius:50%;flex-shrink:0;animation:otw-pulse 2.4s ease-in-out infinite}.hero__summary{font-size:var(--text-base);color:var(--text-secondary);line-height:1.85;max-width:680px;margin:0 auto var(--spacing-8)}.hero__cta{display:flex;align-items:center;justify-content:center;gap:var(--spacing-4);margin-bottom:var(--spacing-8);flex-wrap:wrap}.hero__socials{display:flex;justify-content:center;gap:var(--spacing-3)}.hero__social-link{display:flex;align-items:center;justify-content:center;width:46px;height:46px;border-radius:50%;background:var(--card);color:var(--text-secondary);box-shadow:var(--shadow-md);transition:color var(--transition-fast),transform var(--transition-slow),box-shadow var(--transition-slow)}@media(hover:hover)and (pointer:fine){.hero__social-link:hover{transform:translateY(-4px);color:var(--text-primary);box-shadow:var(--shadow-lg)}}.hero__social-link:active{transform:scale(.94)}.hero__social-link:focus{outline:none}.hero__social-link:focus-visible{outline:2px solid var(--accent-dark);outline-offset:3px}@media(max-width:767px){.hero__cta{flex-direction:column;width:100%}.hero__cta .btn{width:100%}}@media(max-width:479px){.hero{padding:var(--spacing-16) var(--spacing-4)}.hero__name{font-size:var(--text-2xl)}.hero__summary{font-size:var(--text-sm)}}.stack-section{background:var(--card)}.stack__category{margin-bottom:var(--spacing-12)}.stack__category-title{display:flex;align-items:center;gap:var(--spacing-3);font-family:var(--font-display);font-size:var(--text-lg);font-weight:600;color:var(--text-primary);margin-bottom:var(--spacing-6);letter-spacing:-.01em}.stack__grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:var(--spacing-3)}.stack__item{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-2);padding:var(--spacing-6) var(--spacing-3) var(--spacing-4);background:var(--surface);border:1px solid var(--border);border-radius:12px;transition:transform var(--transition-slow),box-shadow var(--transition-slow),border-color var(--transition-base);opacity:0;transform:translateY(18px) scale(.96);cursor:default}@media(hover:hover)and (pointer:fine){.stack__item:hover{transform:translateY(-4px) scale(1);box-shadow:var(--shadow-lg);border-color:var(--primary-dark)}}.stack__item:focus-visible{outline:2px solid var(--accent-dark);outline-offset:2px}.stack__icon{font-size:2.25rem;margin-bottom:var(--spacing-1);line-height:1}.stack__name{font-size:var(--text-xs);font-weight:600;color:var(--text-primary);text-align:center;line-height:1.3}.timeline{position:relative;max-width:800px;margin:0 auto}.timeline:before{content:"";position:absolute;left:50%;transform:translate(-50%);width:2px;height:100%;background:linear-gradient(to bottom,var(--primary-dark),var(--accent-dark));opacity:.6}.timeline__item{position:relative;width:50%;padding:0 var(--spacing-8) var(--spacing-12)}.timeline__item:nth-child(odd){left:0;text-align:right;padding-right:var(--spacing-12)}.timeline__item:nth-child(2n){left:50%;padding-left:var(--spacing-12)}.timeline__dot{position:absolute;width:14px;height:14px;background:var(--card);border:3px solid var(--accent-dark);border-radius:50%;top:4px;transition:border-color var(--transition-fast),transform var(--transition-fast)}.timeline__item:hover .timeline__dot{border-color:var(--primary-dark);transform:scale(1.2)}.timeline__item:nth-child(odd) .timeline__dot{right:-7px}.timeline__item:nth-child(2n) .timeline__dot{left:-7px}.timeline__card{background:var(--card);border-radius:14px;padding:var(--spacing-6);box-shadow:var(--shadow-md);border:1px solid var(--border);transition:box-shadow var(--transition-slow),transform var(--transition-slow),border-color var(--transition-base);position:relative;overflow:hidden}.timeline__card:before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:linear-gradient(to bottom,var(--accent-dark),var(--primary-dark));transform:scaleY(0);transform-origin:top;transition:transform .28s var(--ease-out-quint)}@media(hover:hover)and (pointer:fine){.timeline__card:hover:before{transform:scaleY(1)}.timeline__card:hover{box-shadow:var(--shadow-lg);transform:translateY(-3px);border-color:#a8d5ba66}}.timeline__company{font-family:var(--font-display);font-size:var(--text-lg);font-weight:700;color:var(--text-primary);margin-bottom:var(--spacing-1);letter-spacing:-.01em}.timeline__role{font-size:var(--text-sm);font-weight:600;color:var(--accent-dark);margin-bottom:var(--spacing-2)}.timeline__period{display:inline-block;font-size:var(--text-xs);color:var(--text-secondary);background:var(--surface);padding:3px var(--spacing-3);border-radius:20px;margin-bottom:var(--spacing-3);font-weight:500}.timeline__desc{font-size:var(--text-sm);color:var(--text-secondary);line-height:1.65;margin-bottom:var(--spacing-4)}.timeline__stack{display:flex;flex-wrap:wrap;gap:var(--spacing-2);margin-top:var(--spacing-4)}.timeline__stack-item{font-size:var(--text-xs);font-weight:500;color:var(--text-secondary);background:var(--surface);padding:3px var(--spacing-3);border-radius:20px;border:1px solid var(--border);transition:background-color var(--transition-fast),border-color var(--transition-fast)}@media(hover:hover)and (pointer:fine){.timeline__stack-item:hover{background:var(--primary);border-color:var(--primary-dark)}}.timeline__expand-header{display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-2);padding:var(--spacing-3) 0;font-size:var(--text-sm);font-weight:600;color:var(--accent-dark);cursor:pointer;border-top:1px solid var(--border);margin-top:var(--spacing-4);transition:color var(--transition-fast);user-select:none;border-radius:0;background:none;border-left:none;border-right:none;border-bottom:none;width:100%;text-align:inherit}@media(hover:hover)and (pointer:fine){.timeline__expand-header:hover{color:var(--text-primary)}}.timeline__expand-header:focus{outline:none}.timeline__expand-header:focus-visible{outline:2px solid var(--accent-dark);outline-offset:2px}.timeline__expand-header .arrow{transition:transform var(--transition-base);flex-shrink:0;color:inherit}.timeline__expand-header.open .arrow{transform:rotate(90deg)}.timeline__sub-projects{overflow:hidden;max-height:0;transition:max-height .38s var(--ease-out-quint)}.timeline__sub-projects.show{max-height:2400px}.timeline__sub-card{border-left:3px solid var(--accent);padding:var(--spacing-4) var(--spacing-5);margin-bottom:var(--spacing-3);margin-top:var(--spacing-3);background:var(--surface);border-radius:0 10px 10px 0;transition:border-color var(--transition-fast)}.timeline__sub-card:last-child{margin-bottom:0}@media(hover:hover)and (pointer:fine){.timeline__sub-card:hover{border-color:var(--accent-dark)}}.timeline__sub-card-title{font-family:var(--font-display);font-size:var(--text-sm);font-weight:700;color:var(--text-primary);margin-bottom:var(--spacing-2);letter-spacing:-.01em}.timeline__sub-card-desc{font-size:var(--text-sm);color:var(--text-secondary);line-height:1.6;margin-bottom:var(--spacing-3)}.timeline__bullet-list{list-style:disc;padding-left:var(--spacing-5);margin-bottom:var(--spacing-3)}.timeline__bullet-list li{font-size:var(--text-xs);color:var(--text-secondary);line-height:1.6;margin-bottom:var(--spacing-1)}.timeline__bullet-list li::marker{color:var(--accent-dark)}@media(max-width:1023px){.timeline:before{left:var(--spacing-6)}.timeline__item{width:100%;left:0!important;padding-left:var(--spacing-12)!important;padding-right:0!important;text-align:left!important}.timeline__item:nth-child(odd) .timeline__dot,.timeline__item:nth-child(2n) .timeline__dot{left:calc(var(--spacing-6) - 7px);right:auto}}@media(max-width:479px){.timeline__card{padding:var(--spacing-4)}}.projects-section{background:var(--surface)}.projects__grid{display:grid;gap:var(--spacing-16);max-width:1200px;margin:0 auto}.project-card{display:grid;grid-template-columns:55% 45%;background:var(--card);border-radius:20px;overflow:hidden;box-shadow:var(--shadow-lg);border:1px solid var(--border);transition:all var(--transition-slow);min-height:520px;position:relative}.project-card:after{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(to right,var(--primary-dark),var(--accent-dark));transform:scaleX(0);transform-origin:left;transition:transform .4s ease}.project-card:hover:after{transform:scaleX(1)}.project-card:hover{box-shadow:var(--shadow-2xl);transform:translateY(-6px)}.project-card__image{position:relative;overflow:hidden;min-height:520px}.project-card__image:after{content:"";position:absolute;inset:0;background:linear-gradient(to right,transparent 65%,var(--card) 100%);pointer-events:none;z-index:4}.project-card__content{padding:var(--spacing-12);display:flex;flex-direction:column;justify-content:center;gap:0;border-left:1px solid var(--border)}.project-card__title{font-family:var(--font-display);font-size:var(--text-3xl);font-weight:700;color:var(--text-primary);line-height:1.2;margin-bottom:var(--spacing-6)}.project-card__stack{display:flex;flex-wrap:wrap;gap:var(--spacing-2);margin-bottom:var(--spacing-8)}.project-card__stack-item{font-size:var(--text-xs);font-weight:500;color:var(--text-secondary);background:var(--surface);padding:var(--spacing-2) var(--spacing-4);border-radius:20px;border:1px solid var(--border);transition:all var(--transition-base)}.project-card__stack-item:hover{transform:scale(1.05);border-color:var(--primary-dark);background:var(--primary)}.project-card__desc{font-size:var(--text-base);color:var(--text-secondary);line-height:1.8;margin-bottom:var(--spacing-6)}.project-card__highlights{list-style:disc;padding-left:var(--spacing-6);margin-bottom:var(--spacing-8)}.project-card__highlights li{font-size:var(--text-sm);color:var(--text-secondary);line-height:1.7;margin-bottom:var(--spacing-2)}.project-card__highlights li::marker{color:var(--accent-dark)}.project-card__links{display:flex;gap:var(--spacing-3);flex-wrap:wrap;margin-top:auto;align-items:center}.project-card__badge{display:inline-flex;align-items:center;gap:var(--spacing-2);padding:var(--spacing-2) var(--spacing-4);border-radius:20px;font-size:var(--text-xs);font-weight:500}.project-card__badge--private{background:var(--highlight);color:var(--text-primary)}.project-slider{position:absolute;inset:0;overflow:hidden;background:var(--border)}.project-slider__track{position:relative;width:100%;height:100%}.project-slider__slide{position:absolute;inset:0;opacity:0;transition:opacity .7s ease;pointer-events:none}.project-slider__slide.active{opacity:1;pointer-events:auto}.project-slider__slide img{width:100%;height:100%;object-fit:cover;object-position:center top;display:block;transition:transform .6s ease}.project-card:hover .project-slider__slide.active img{transform:scale(1.04)}.project-slider__overlay{position:absolute;inset:0;display:flex;justify-content:space-between;align-items:center;padding:0 var(--spacing-4);opacity:0;transition:opacity var(--transition-slow);pointer-events:none;z-index:5}.project-slider:hover .project-slider__overlay{opacity:1;pointer-events:auto}.project-slider__prev,.project-slider__next{pointer-events:auto;background:#ffffffeb;border:none;border-radius:50%;width:44px;height:44px;display:flex;justify-content:center;align-items:center;cursor:pointer;transition:all .25s ease;box-shadow:var(--shadow-lg);flex-shrink:0;color:var(--text-primary)}.project-slider__prev:hover,.project-slider__next:hover{background:#fff;transform:scale(1.12);box-shadow:var(--shadow-xl)}.project-slider__dots{position:absolute;bottom:16px;left:0;right:0;display:flex;justify-content:center;gap:8px;z-index:6;pointer-events:auto}.project-slider__dot{width:8px;height:8px;border-radius:50%;background:#ffffff80;border:1px solid rgba(255,255,255,.4);cursor:pointer;transition:all .3s ease;padding:0}.project-slider__dot.active{background:#fff;width:28px;border-radius:4px}@media(max-width:1023px){.project-card{grid-template-columns:1fr;min-height:auto}.project-card__image{min-height:300px;position:relative}.project-card__image:after{background:linear-gradient(to bottom,transparent 65%,var(--card) 100%)}.project-slider{position:absolute;inset:0;min-height:100%;z-index:1}.project-slider__track{position:absolute;inset:0;width:100%;height:100%;z-index:2}.project-slider__slide{position:absolute;inset:0;width:100%;height:100%;z-index:3}.project-slider__slide img{width:100%;height:100%;object-fit:cover;object-position:top center;z-index:4}.project-card__title{font-size:var(--text-2xl);margin-bottom:var(--spacing-4)}.project-card__stack{margin-bottom:var(--spacing-6)}}@media(max-width:767px){.project-card{grid-template-columns:1fr;border-radius:14px;min-height:auto}.project-card__image{min-height:240px;position:relative}.project-slider{position:absolute;inset:0;min-height:100%;z-index:1}.project-slider__track{position:absolute;inset:0;width:100%;height:100%;z-index:2}.project-slider__slide{position:absolute;inset:0;width:100%;height:100%;z-index:3}.project-slider__slide img{width:100%;height:100%;object-fit:cover;object-position:top center;z-index:4}.project-card__content{padding:var(--spacing-6)}.project-card__title{font-size:var(--text-xl);margin-bottom:var(--spacing-3)}.project-card__desc{font-size:var(--text-sm);margin-bottom:var(--spacing-4)}.project-card__stack{margin-bottom:var(--spacing-4)}}.education-section{background:var(--card)}.education__grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-8);align-items:start}.education__card{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:var(--spacing-8);transition:all var(--transition-slow)}.education__card:hover{box-shadow:var(--shadow-lg);transform:translateY(-4px)}.education__degree{font-family:var(--font-display);font-size:var(--text-lg);font-weight:600;color:var(--text-primary);margin-bottom:var(--spacing-2)}.education__school{font-size:var(--text-sm);color:var(--text-secondary);margin-bottom:var(--spacing-2)}.education__period{display:inline-block;font-size:var(--text-xs);color:var(--text-secondary);background:var(--card);padding:var(--spacing-1) var(--spacing-3);border-radius:20px;margin-bottom:var(--spacing-4)}.education__desc{font-size:var(--text-sm);color:var(--text-secondary);line-height:1.6}.certifications__list{display:flex;flex-direction:column;gap:var(--spacing-4)}.certification__item{display:flex;align-items:center;gap:var(--spacing-4);padding:var(--spacing-4);background:var(--surface);border:1px solid var(--border);border-radius:12px;transition:all var(--transition-slow)}.certification__item:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.certification__icon{display:flex;align-items:center;justify-content:center;width:48px;height:48px;background:var(--primary);border-radius:12px;color:var(--text-primary);flex-shrink:0}.certification__info{flex:1}.certification__name{font-family:var(--font-display);font-size:var(--text-sm);font-weight:600;color:var(--text-primary);margin-bottom:var(--spacing-1)}.certification__issuer{font-size:var(--text-xs);color:var(--text-secondary)}@media(max-width:1023px){.education__grid{grid-template-columns:1fr}}@media(max-width:479px){.education__card{padding:var(--spacing-6)}}.skills-section{background:var(--surface)}.skills__grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:var(--spacing-6)}.skill-card{background:var(--card);border:1px solid var(--border);border-radius:14px;padding:var(--spacing-8);text-align:center;transition:box-shadow var(--transition-slow),transform var(--transition-slow),border-color var(--transition-base);position:relative;overflow:hidden}.skill-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(to right,var(--primary-dark),var(--accent-dark));transform:scaleX(0);transition:transform .3s var(--ease-out-quint)}@media(hover:hover)and (pointer:fine){.skill-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-4px);border-color:#a8d5ba66}.skill-card:hover:before{transform:scaleX(1)}}.skill-card__icon{display:flex;align-items:center;justify-content:center;width:60px;height:60px;margin:0 auto var(--spacing-4);background:linear-gradient(135deg,var(--primary) 0%,var(--accent) 100%);border-radius:16px;color:var(--text-primary);box-shadow:0 4px 14px #a8d5ba59;transition:transform var(--transition-slow),box-shadow var(--transition-slow)}@media(hover:hover)and (pointer:fine){.skill-card:hover .skill-card__icon{transform:rotate(6deg) scale(1.08);box-shadow:0 6px 20px #a8d5ba73}}.skill-card__title{font-family:var(--font-display);font-size:var(--text-lg);font-weight:700;color:var(--text-primary);margin-bottom:var(--spacing-2);letter-spacing:-.01em}.skill-card__desc{font-size:var(--text-sm);color:var(--text-secondary);line-height:1.65}@media(max-width:767px){.skills__grid{grid-template-columns:1fr}}@media(max-width:479px){.skill-card{padding:var(--spacing-6)}}.contact-section{background:var(--card)}.contact__grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-12);align-items:start}.contact__form{display:flex;flex-direction:column;gap:var(--spacing-5)}.form__group{display:flex;flex-direction:column;gap:var(--spacing-2)}.form__label{font-size:var(--text-sm);font-weight:600;color:var(--text-primary)}.form__input,.form__textarea{padding:var(--spacing-3) var(--spacing-4);border:1.5px solid var(--border);border-radius:8px;background:var(--surface);font-size:var(--text-sm);color:var(--text-primary);transition:border-color var(--transition-fast),box-shadow var(--transition-fast),background-color var(--transition-fast);outline:none}.form__input::placeholder,.form__textarea::placeholder{color:var(--text-secondary);opacity:.65}.form__input:focus,.form__textarea:focus{border-color:var(--primary-dark);box-shadow:0 0 0 3px #a8d5e540;background:var(--card)}.form__input:invalid:not(:placeholder-shown),.form__textarea:invalid:not(:placeholder-shown){border-color:#ef9a9a}.form__textarea{min-height:120px;resize:vertical}.contact__info{display:flex;flex-direction:column;gap:var(--spacing-6)}.contact__title{font-family:var(--font-display);font-size:var(--text-xl);font-weight:700;color:var(--text-primary);letter-spacing:-.02em}.contact__desc{font-size:var(--text-sm);color:var(--text-secondary);line-height:1.7}.contact__details{display:flex;flex-direction:column;gap:var(--spacing-4)}.contact__item{display:flex;align-items:flex-start;gap:var(--spacing-4)}.contact__item-icon{display:flex;align-items:center;justify-content:center;width:46px;height:46px;background:var(--primary);border-radius:12px;color:var(--text-primary);flex-shrink:0;transition:background-color var(--transition-fast),transform var(--transition-slow)}.contact__item:hover .contact__item-icon{background:var(--primary-dark);transform:scale(1.05)}.contact__item-info{display:flex;flex-direction:column;gap:var(--spacing-1);padding-top:4px}.contact__item-label{font-size:.7rem;font-weight:700;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.08em}.contact__item-value{font-size:var(--text-sm);font-weight:500;color:var(--text-primary);transition:color var(--transition-fast)}.contact__item-value:hover{color:var(--accent-dark)}.contact__email-reveal{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.contact__email-question{font-style:italic;opacity:.7;font-size:var(--text-sm)}.contact__copy-btn{display:inline-flex;align-items:center;gap:5px;padding:4px 10px;border:1.5px solid currentColor;border-radius:20px;background:transparent;color:var(--accent-dark);font-size:.75rem;font-weight:600;cursor:pointer;transition:background-color var(--transition-fast),color var(--transition-fast),transform var(--transition-fast);user-select:none}@media(hover:hover)and (pointer:fine){.contact__copy-btn:hover{background:#8bc4a026;transform:translateY(-1px)}}.contact__copy-btn:active{transform:scale(.95)}.contact__copy-btn:focus{outline:none}.contact__copy-btn:focus-visible{outline:2px solid var(--accent-dark);outline-offset:2px}.contact__copy-btn.copied{opacity:.55}@media(max-width:1023px){.contact__grid{grid-template-columns:1fr}}@media(max-width:479px){.contact__grid{gap:var(--spacing-8)}}.footer{background:#1a2530;color:#e8f4f9;padding:var(--spacing-12) 0 var(--spacing-6)}.footer__content{text-align:center}.footer__logo{font-family:var(--font-display);font-size:var(--text-2xl);font-weight:700;display:inline-block;margin-bottom:var(--spacing-2);color:#fff}.footer__tagline{font-size:var(--text-sm);color:#e8f4f9a6;margin-bottom:var(--spacing-6)}.footer__links{display:flex;justify-content:center;gap:var(--spacing-6);margin-bottom:var(--spacing-8)}.footer__link{font-size:var(--text-sm);color:#e8f4f9bf;transition:color var(--transition-base)}@media(hover:hover)and (pointer:fine){.footer__link:hover{color:var(--primary-dark)}}.footer__copyright{font-size:var(--text-xs);color:#e8f4f966}@media(max-width:767px){.footer__links{flex-direction:column;gap:var(--spacing-3)}}
