.mobile-header{z-index:var(--z-navbar);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border-bottom:1px solid var(--clr-border);opacity:0;transition:transform var(--transition-slow), opacity var(--transition-slow);background:#f9fbffeb;justify-content:space-between;align-items:center;padding:.85rem 1rem;display:flex;position:fixed;top:0;left:0;right:0;transform:translateY(-100%)}.mobile-header--visible{opacity:1;transform:translateY(0)}.mobile-header__brand{font-family:var(--font-display);font-size:1.02rem;font-weight:var(--font-semibold);color:var(--clr-primary-700);cursor:pointer;background:0 0;border:none;padding:0}.mobile-header__burger{padding:var(--space-1);z-index:calc(var(--z-navbar) + 20);cursor:pointer;background:0 0;border:none;flex-direction:column;gap:5px;display:inline-flex}.mobile-header__burger span{background:var(--clr-text-primary);width:22px;height:2px;transition:transform var(--transition-base), opacity var(--transition-base);border-radius:999px;display:block}.mobile-header__burger--open span:first-child{transform:translateY(7px)rotate(45deg)}.mobile-header__burger--open span:nth-child(2){opacity:0}.mobile-header__burger--open span:nth-child(3){transform:translateY(-7px)rotate(-45deg)}.mobile-menu{z-index:calc(var(--z-navbar) + 10);opacity:0;pointer-events:none;transition:opacity var(--transition-slow);background:linear-gradient(150deg,#f8fbff 0%,#eef4ff 100%);flex-direction:column;display:flex;position:fixed;inset:0}.mobile-menu--open{opacity:1;pointer-events:auto}.mobile-menu__inner{min-height:100%;padding:78px var(--space-6) var(--space-8);gap:var(--space-5);flex-direction:column;display:flex}.mobile-menu__close{border:1px solid var(--clr-border);width:40px;height:40px;color:var(--clr-text-secondary);cursor:pointer;transition:background var(--transition-fast), border-color var(--transition-fast);background:0 0;border-radius:50%;justify-content:center;align-items:center;display:flex;position:absolute;top:1rem;right:1rem}.mobile-menu__close:hover{background:var(--clr-surface);border-color:var(--clr-primary-300)}.mobile-menu__links{gap:var(--space-2);flex-direction:column;flex:1;justify-content:center;display:flex}.mobile-menu__links li{opacity:0;transform:translate(-16px)}.mobile-menu--open .mobile-menu__links li{animation:.35s forwards slideInLeft}.mobile-menu--open .mobile-menu__item--1{animation-delay:55ms}.mobile-menu--open .mobile-menu__item--2{animation-delay:.11s}.mobile-menu--open .mobile-menu__item--3{animation-delay:.165s}.mobile-menu--open .mobile-menu__item--4{animation-delay:.22s}.mobile-menu--open .mobile-menu__item--5{animation-delay:.275s}.mobile-menu--open .mobile-menu__item--6{animation-delay:.33s}.mobile-menu__link{align-items:baseline;gap:var(--space-3);border:0;border-bottom:1px solid var(--clr-border);text-align:left;width:100%;font-family:var(--font-display);font-size:clamp(1.5rem,8vw,2.2rem);font-weight:var(--font-semibold);color:var(--clr-text-primary);transition:color var(--transition-fast);cursor:pointer;background:0 0;padding:.5rem 0;display:flex}.mobile-menu__link:hover,.mobile-menu__link--active{color:var(--clr-primary-600)}.mobile-menu__num{font-size:var(--text-xs);font-family:var(--font-body);font-weight:var(--font-semibold);color:var(--clr-text-muted);min-width:24px}.mobile-menu__socials{gap:var(--space-2);flex-wrap:wrap;display:flex}.mobile-menu__social-btn{border:1.5px solid var(--clr-border);width:40px;height:40px;color:var(--clr-text-secondary);transition:all var(--transition-fast);border-radius:50%;justify-content:center;align-items:center;text-decoration:none;display:flex}.mobile-menu__social-btn:hover{color:var(--clr-primary-600);border-color:var(--clr-primary-300)}.mobile-menu__email{font-size:var(--text-sm);color:var(--clr-text-muted);font-weight:var(--font-medium);transition:color var(--transition-fast);text-decoration:none}.mobile-menu__email:hover{color:var(--clr-primary-600)}.navbar{display:none}@media (min-width:768px){.mobile-header,.mobile-menu{display:none}.navbar{top:var(--space-4);transform:translateX(-50%) translateY(calc(-100% - var(--space-4)));z-index:var(--z-navbar);opacity:0;pointer-events:none;transition:transform var(--transition-slow), opacity var(--transition-slow);width:max-content;max-width:calc(100vw - var(--space-8));display:block;position:fixed;left:50%}.navbar--visible{opacity:1;pointer-events:auto;transform:translate(-50%)translateY(0)}.navbar__inner{align-items:center;gap:var(--space-5);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);border:1px solid var(--clr-primary-200);border-radius:var(--radius-full);box-shadow:var(--shadow-md);background:#f9fbffe0;padding:.45rem 1rem;display:flex}.navbar__brand{font-family:var(--font-display);font-size:1rem;font-weight:var(--font-semibold);color:var(--clr-primary-700);white-space:nowrap;cursor:pointer;background:0 0;border:none;padding:0}.navbar__links{align-items:center;gap:.15rem;list-style:none;display:flex}.navbar__link{font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--clr-text-secondary);border-radius:var(--radius-full);cursor:pointer;transition:color var(--transition-fast), background var(--transition-fast);background:0 0;border:none;padding:.45rem .7rem}.navbar__link:hover{color:var(--clr-primary-600);background:var(--clr-primary-100)}.navbar__link--active{color:var(--clr-primary-700);background:var(--clr-primary-200);font-weight:var(--font-semibold)}}
.footer{background:var(--clr-text-primary);padding-top:var(--space-16)}.footer__inner{gap:var(--space-8);padding-bottom:var(--space-10);border-bottom:1px solid #ffffff14;grid-template-columns:1fr;display:grid}.footer__logo{font-family:var(--font-display);font-size:var(--text-2xl);font-weight:var(--font-semibold);color:var(--clr-primary-400);letter-spacing:-.01em;margin-bottom:var(--space-3);text-align:left;cursor:default;transition:transform var(--transition-fast);background:0 0;border:none;padding:0;display:block}.footer__logo:hover{color:var(--clr-primary-400)}.footer__logo:active{transform:translateY(1px)scale(.985)}.footer__tagline{font-size:var(--text-sm);color:#ffffff80;max-width:240px;margin-bottom:var(--space-2);line-height:1.65}.footer__location{font-size:var(--text-xs);color:#ffffff47;font-weight:var(--font-semibold);letter-spacing:.04em}.footer__nav-title{font-size:var(--text-xs);font-weight:var(--font-bold);color:#ffffff59;letter-spacing:.1em;text-transform:uppercase;margin-bottom:var(--space-4)}.footer__nav-list{gap:var(--space-3);flex-direction:column;list-style:none;display:flex}.footer__nav-link{font-size:var(--text-sm);color:#ffffff8c;font-family:var(--font-body);font-weight:var(--font-medium);cursor:pointer;text-align:left;transition:color var(--transition-fast);background:0 0;border:none;padding:0}.footer__nav-link:hover{color:var(--clr-primary-400)}.footer__admin-link{text-underline-offset:4px;-webkit-text-decoration:underline #c1b6f266;text-decoration:underline #c1b6f266;color:var(--clr-primary-400)!important;font-weight:var(--font-semibold)!important}.footer__admin-link:hover{color:var(--clr-pink-400)!important}.footer__contact-list{gap:var(--space-2);margin-bottom:var(--space-5);flex-direction:column;display:flex}.footer__contact-item{font-size:var(--text-sm);color:#ffffff8c;font-weight:var(--font-medium);text-decoration:none}.footer__contact-item--link{transition:color var(--transition-fast)}.footer__contact-item--link:hover{color:var(--clr-primary-400)}.footer__socials{gap:var(--space-2);display:flex}.footer__social-btn{color:#ffffffb3;width:38px;height:38px;transition:background var(--transition-fast), color var(--transition-fast), transform var(--transition-fast);background:#ffffff0d;border:none;border-radius:50%;justify-content:center;align-items:center;text-decoration:none;display:flex}.footer__social-btn:hover{background:var(--clr-primary-600);color:#fff;transform:translateY(-2px)}.footer__bottom{padding-top:var(--space-5);padding-bottom:var(--space-8);justify-content:space-between;align-items:center;display:flex}.footer__copy,.footer__credit{font-size:var(--text-xs);color:#fff6}.footer__credit a{color:var(--clr-primary-400);font-weight:var(--font-semibold);transition:color var(--transition-fast);text-decoration:none}.footer__credit a:hover{color:var(--clr-primary-300);text-decoration:underline}@media (min-width:768px){.footer__inner{gap:var(--space-10);grid-template-columns:1.6fr 1fr 1.6fr}}@media (max-width:768px){.footer__bottom{gap:var(--space-2);text-align:center;flex-direction:column}}
#home{margin:0;padding:0}.home{--home-gap:clamp(.45rem, 1.45vw, .95rem);--home-ticker-width:clamp(44px, 12vw, 62px);--home-ticker-height:clamp(94px, 20vw, 128px);gap:var(--home-gap);grid-template-rows:minmax(0,1fr) auto minmax(0,1fr);grid-template-columns:1fr;width:100%;min-height:100dvh;padding:clamp(.35rem,1vw,.72rem);display:grid;overflow:clip visible}.home__panel-wrap{min-width:0;display:flex;position:relative;overflow:hidden}.home__panel-wrap--visual{flex-direction:row;order:1;grid-row:1}.home__socials{background:var(--clr-bg);flex-wrap:wrap;order:2;grid-row:2;justify-content:center;align-items:center;gap:clamp(.45rem,2.2vw,.9rem);padding:.22rem 0;display:flex}.home__panel-wrap--content{flex-direction:row;order:3;grid-row:3}.home__panel{background:var(--clr-bg);box-shadow:var(--shadow-inset);border:1px solid #14203321;position:relative;overflow:hidden}.home__panel--visual{width:100%;min-width:0;margin-left:calc(var(--home-ticker-width) + var(--home-gap));border-radius:0 0 0 132px;flex:1;justify-content:center;align-items:flex-end;padding:clamp(.95rem,3vw,1.4rem) clamp(.75rem,2vw,1.2rem) 0;display:flex}.home__photo{filter:drop-shadow(0 12px 28px #14203333);-webkit-user-select:none;user-select:none;width:min(100%,clamp(226px,74vw,345px));height:auto;display:block}.home__panel--content{width:100%;min-width:0;margin-right:calc(var(--home-ticker-width) + var(--home-gap));border-radius:0 132px 40px 0;flex-direction:column;flex:1;justify-content:center;gap:clamp(.55rem,1.8vw,.9rem);padding:clamp(1rem,3vw,1.45rem) clamp(.95rem,3.2vw,1.45rem);display:flex}.home__eyebrow{color:var(--clr-text-secondary);text-transform:uppercase;letter-spacing:.12em;font-size:clamp(.76rem,2.4vw,.9rem);font-weight:var(--font-semibold)}.home__title{font-family:var(--font-display);color:var(--clr-text-primary);font-size:clamp(1.52rem,7.1vw,2.5rem);line-height:1.08;font-weight:var(--font-bold);letter-spacing:-.02em}.home__description{color:var(--clr-text-secondary);max-width:44ch;font-size:clamp(.82rem,2.9vw,.94rem);line-height:1.64}.home__cta{flex-wrap:wrap;gap:.52rem;margin-top:.1rem;display:flex}.btn-home-cta{border:1.4px solid var(--clr-primary-600);min-height:38px;font-size:clamp(.72rem,2.35vw,.82rem);font-weight:var(--font-semibold);white-space:nowrap;transition:transform var(--transition-fast), color var(--transition-base), background var(--transition-base), border-color var(--transition-base), box-shadow var(--transition-base);cursor:pointer;border-radius:12px;padding:.44rem .84rem;line-height:1}.btn-home-cta:hover{transform:translateY(-1px)}.btn-home-cta--primary{background:var(--clr-primary-600);color:#fff}.btn-home-cta--primary:hover{background:var(--clr-primary-700);border-color:var(--clr-primary-700);box-shadow:var(--shadow-md)}.btn-home-cta--secondary{color:var(--clr-primary-700);background:0 0}.btn-home-cta--secondary:hover{background:var(--clr-primary-600);border-color:var(--clr-primary-600);color:#fff}.home__social-btn{border:1px solid var(--clr-border);width:44px;height:44px;color:var(--clr-text-secondary);background:var(--clr-card);transition:transform var(--transition-fast), border-color var(--transition-base), box-shadow var(--transition-base), color var(--transition-base), background var(--transition-base);border-radius:50%;justify-content:center;align-items:center;text-decoration:none;display:inline-flex;position:relative;overflow:hidden}.home__social-icon{width:20px;height:20px}.home__social-btn:hover{box-shadow:var(--shadow-sm);border-color:#6b81b566;transform:translateY(-2px)}.home__social-btn:active{transform:translateY(1px)}.home__social-btn[data-platform=instagram]:hover{color:#fff;background:#c73f72;border-color:#c73f72}.home__social-btn[data-platform=linkedin]:hover{color:#fff;background:#245fb8;border-color:#245fb8}.home__social-btn[data-platform=tiktok]:hover{color:#fff;background:#101827;border-color:#101827}.home__social-btn[data-platform=twitter]:hover{color:#fff;background:#1a2333;border-color:#1a2333}.home__ticker-wrap{width:var(--home-ticker-width);border-radius:14px;flex-shrink:0;position:absolute;top:0;bottom:0;overflow:hidden;-webkit-mask-image:linear-gradient(#0000 0%,#000 8% 92%,#0000 100%);mask-image:linear-gradient(#0000 0%,#000 8% 92%,#0000 100%)}.home__ticker-wrap--left{left:0}.home__ticker-wrap--right{right:0}.home__ticker{will-change:transform;flex-direction:column;animation:36s linear infinite homeTickerVertical;display:flex}.home__ticker--reverse{animation-direction:reverse}.home__ticker-group{flex-direction:column;display:flex}.home__ticker-item{min-height:var(--home-ticker-height);font-size:clamp(.66rem,2.55vw,.9rem);font-weight:var(--font-semibold);color:var(--clr-text-primary);white-space:nowrap;transform-origin:50%;letter-spacing:.05em;justify-content:center;align-items:center;gap:.56rem;padding:1.25rem .88rem;display:inline-flex;transform:rotate(90deg)}.home__ticker-content--text{align-items:center;gap:.56rem;display:inline-flex}.home__ticker-content--icon{display:none}.home__ticker-icon-img{object-fit:contain;opacity:.85;width:28px;height:28px}.home__ticker--right .home__ticker-item{transform:rotate(180deg)}.home__ticker-dot{background:var(--clr-primary-600);border-radius:50%;flex-shrink:0;width:6px;height:6px}@media (max-width:899.98px){.home{--home-gap:clamp(.5rem, 1.65vw, .95rem);--home-ticker-width:clamp(46px, 10vw, 66px);--home-ticker-height:clamp(80px, 18vw, 110px);grid-template-rows:auto auto auto}.home__ticker-item{min-height:var(--home-ticker-height);padding:clamp(.8rem,2vw,1rem) 0;transform:none}.home__ticker-content--text{display:none}.home__ticker-content--icon{justify-content:center;align-items:center;display:flex}.home__ticker--right .home__ticker-item{transform:none}}@media (max-width:430px){.home{--home-ticker-width:clamp(42px, 12.8vw, 56px);--home-ticker-height:clamp(114px, 30vw, 150px);padding:.3rem}.home__panel--visual{border-radius:30px 0 0 96px;padding-top:.75rem}.home__panel--content{border-radius:0 96px 0 30px;padding:.9rem .85rem}.home__description{max-width:39ch}.home__cta{gap:.45rem}.btn-home-cta{min-height:36px;padding-inline:.72rem}.home__ticker-item{padding:.8rem 0}.home__ticker-icon-img{width:24px;height:24px}}@media (max-width:360px){.home__title{font-size:1.42rem}.home__description{font-size:.78rem;line-height:1.56}}@media (max-height:460px) and (max-width:932px) and (orientation:landscape){.home{grid-template-rows:minmax(0,1fr) auto minmax(0,1fr);grid-template-columns:1fr;gap:.42rem;padding:.42rem}.home__socials{background:var(--clr-bg);gap:.45rem;padding:.2rem 0}.home__panel-wrap--visual,.home__panel-wrap--content{flex-direction:row}.home__panel--visual{padding-top:.5rem}.home__panel--content{gap:.42rem;padding:.7rem .82rem}.home__title{font-size:clamp(1.1rem,3.2vw,1.38rem)}.home__description{font-size:.72rem;line-height:1.45}.btn-home-cta{min-height:32px;font-size:.66rem}.home__social-btn{width:40px;height:40px}.home__social-icon{width:16px;height:16px}.home__ticker-item{letter-spacing:.05em;gap:.5rem;min-height:92px;padding:.9rem .72rem;font-size:.6rem}}@media (min-width:900px) and (min-height:620px){.home{grid-template-rows:1fr;grid-template-columns:minmax(0,1fr) auto minmax(360px,43%);gap:.65rem;min-height:100dvh;padding:.7rem .65rem .65rem}.home__panel-wrap--content{flex-direction:column;order:1;grid-area:1/1}.home__socials{background:0 0;flex-direction:column;order:2;grid-area:1/2;justify-content:center;gap:.65rem;padding:0}.home__panel-wrap--visual{flex-direction:column;order:3;grid-area:1/3}.home__panel--visual{border-radius:44px 0 0 180px;margin-left:0;padding:clamp(5rem,12vh,7rem) 0 0}.home__panel--content{border-radius:0 180px 44px 0;gap:1.15rem;margin-right:0;padding:clamp(2.2rem,5vh,3.4rem) clamp(2rem,4vw,4.5rem)}.home__eyebrow{font-size:.94rem}.home__title{font-size:clamp(2.56rem,4.7vw,4rem)}.home__description{max-width:52ch;font-size:clamp(1rem,1.2vw,1.15rem)}.home__cta{gap:.8rem}.btn-home-cta{min-width:160px;min-height:48px;padding:0 1.22rem;font-size:1rem}.home__photo{width:min(100%,clamp(300px,76%,500px))}.home__social-btn{width:46px;height:46px}.home__ticker-wrap{border-radius:20px;width:100%;height:56px;position:static;-webkit-mask-image:linear-gradient(90deg,#0000 0%,#000 8% 92%,#0000 100%);mask-image:linear-gradient(90deg,#0000 0%,#000 8% 92%,#0000 100%)}.home__ticker{flex-direction:row;width:max-content;animation-name:homeTickerHorizontal}.home__ticker-group{flex-direction:row}.home__ticker-item{height:56px;min-height:unset;letter-spacing:.02em;padding:0 1.45rem;font-size:.94rem;line-height:56px;transform:none}.home__ticker--right .home__ticker-item{transform:none}}
.about{padding:var(--section-py) 0;background-color:#f9fbff}.about__shell{gap:.75rem;max-width:1120px;margin-inline:auto;display:grid}.about__banner{border:1px solid var(--clr-border);background:var(--clr-primary-200);border-radius:38px 38px 10px 10px;width:100%;overflow:hidden}.about__banner-image{width:100%;height:auto;display:block}.about__card{background:var(--clr-card);border:1px solid var(--clr-border);box-shadow:var(--shadow-lg);border-radius:10px 10px 38px 38px;grid-template-columns:1fr;display:grid;overflow:hidden}.about__lanyard-wrap{height:280px;box-shadow:var(--shadow-inset);background-color:#f4f7fd;position:relative;overflow:hidden}.about__lanyard-wrap .lanyard-wrapper{position:absolute;inset:0;height:100%!important}.about__lanyard-status{z-index:5;color:var(--clr-primary-700);letter-spacing:.02em;text-transform:uppercase;background:#3b67bf1f;border-radius:999px;justify-content:center;align-items:center;gap:.35rem;padding:.4rem .7rem;font-size:.7rem;font-weight:700;display:inline-flex;position:absolute;top:1rem;left:1rem}.about__lanyard-status-dot{border-radius:50%;width:6px;height:6px;display:inline-block}.about__lanyard-status-dot.is-open{background-color:#10b981;animation:1.5s ease-in-out infinite blinkStatus;box-shadow:0 0 8px #10b98199}.about__lanyard-status-dot.is-closed{background-color:#ef4444;box-shadow:0 0 8px #ef444499}@keyframes blinkStatus{0%{opacity:1}50%{opacity:.35}to{opacity:1}}.about__lanyard-loader{opacity:.86;background:linear-gradient(135deg,#e5eefc,#d3e4ff);position:absolute;inset:0}.about__info{flex-direction:column;gap:1rem;padding:1.1rem;display:flex}.about__name{font-family:var(--font-display);font-size:clamp(1.2rem,5vw,1.5rem);font-weight:var(--font-semibold);color:var(--clr-text-primary);letter-spacing:-.01em;margin-bottom:2px}.about__role{font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--clr-primary-600);min-height:1.4em}.about__role-typewriter:after{content:"";vertical-align:-.12em;background:currentColor;width:1px;height:1em;margin-left:3px;animation:1s ease-in-out infinite blinkStatus;display:inline-block}.about__bio-wrap{position:relative}.about__bio{color:var(--clr-text-secondary);font-size:.9rem;line-height:1.75}.about__bio-container{position:relative}.about__bio-checkbox{opacity:0;position:absolute;left:-9999px}.about__bio-label{cursor:pointer;color:var(--clr-primary-600);font-size:.82rem;font-weight:var(--font-semibold);transition:color var(--transition-fast);margin-top:.5rem;display:block}.about__bio-label:hover{color:var(--clr-primary-700)}.about__bio-label:before{content:"View more"}.about__bio-content{max-height:4.8em;transition:max-height .45s cubic-bezier(.44,.99,.48,1);overflow:hidden;-webkit-mask-image:linear-gradient(#000 50%,#0000 100%);mask-image:linear-gradient(#000 50%,#0000 100%)}.about__bio-checkbox:checked~.about__bio-content{max-height:800px;-webkit-mask-image:none;mask-image:none}.about__bio-checkbox:checked~.about__bio-label:before{content:"View less"}.about__bottom{gap:var(--space-4);grid-template-columns:1fr;display:grid}.about__contacts{flex-direction:column;gap:.6rem;display:flex}.about__contact-item{font-size:var(--text-sm);color:var(--clr-text-secondary);font-weight:var(--font-medium);align-items:center;gap:.65rem;display:flex}.about__contact-icon{border:1px solid var(--clr-border);width:32px;height:32px;color:var(--clr-primary-600);background:var(--clr-primary-100);border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;display:flex}.about__cv-btn{white-space:nowrap;color:var(--clr-primary-700);border:1.6px solid var(--clr-primary-400);border-radius:var(--radius-full);font-size:var(--text-sm);font-weight:var(--font-semibold);cursor:pointer;transition:background var(--transition-base), color var(--transition-base), border-color var(--transition-base);background:0 0;justify-content:center;align-self:start;align-items:center;padding:.55rem 1.1rem;font-family:inherit;text-decoration:none;display:inline-flex}.about__cv-btn:hover{background:var(--clr-primary-600);color:#fff;border-color:var(--clr-primary-600)}@media (min-width:768px){.about__lanyard-wrap{height:340px}.about__info{padding:clamp(1.4rem,2.3vw,2rem)}.about__bottom{grid-template-columns:minmax(0,1fr) auto;align-items:end}.about__cv-btn{align-self:end}}@media (min-width:980px){.about__card{grid-template-columns:minmax(340px,420px) 1fr}.about__lanyard-wrap{height:100%}}
.contact{padding:var(--section-py) 0;background-color:#f6f2f8}.contact__grid{gap:var(--space-8);grid-template-columns:1fr;align-items:stretch;display:grid}.contact__info{gap:var(--space-5);flex-direction:column;display:flex}.contact__info-title{font-family:var(--font-display);font-size:var(--text-2xl);font-weight:var(--font-semibold);color:var(--clr-text-primary);letter-spacing:-.01em}.contact__info-text{font-size:var(--text-sm);color:var(--clr-text-secondary);line-height:1.75}.contact__details{background:var(--clr-card);border:1.5px solid var(--clr-border);border-radius:var(--radius-xl);flex-direction:column;display:flex;overflow:hidden}.contact__detail-row{justify-content:space-between;align-items:center;gap:var(--space-4);padding:var(--space-3) var(--space-5);border-bottom:1px solid var(--clr-border);display:flex}.contact__detail-row:last-child{border-bottom:none}.contact__detail-label{font-weight:var(--font-bold);color:var(--clr-text-muted);font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.06em;flex-shrink:0}.contact__detail-val{color:var(--clr-text-secondary);font-weight:var(--font-semibold);font-size:var(--text-sm);text-align:right;word-break:break-all;text-decoration:none}.contact__detail-val--link{transition:color var(--transition-fast)}.contact__detail-val--link:hover{color:var(--clr-primary-600)}.contact__socials{gap:var(--space-2);display:flex}.contact__social-btn{border:1.5px solid var(--clr-border);width:40px;height:40px;color:var(--clr-text-secondary);transition:all var(--transition-fast);border-radius:50%;place-items:center;text-decoration:none;display:grid}.contact__social-btn--instagram:hover{color:#e1306c;border-color:#e1306c}.contact__social-btn--linkedin:hover{color:#0a66c2;border-color:#0a66c2}.contact__social-btn--tiktok:hover{color:#000;border-color:#000}.contact__social-btn--twitter:hover{color:var(--clr-primary-600);border-color:var(--clr-primary-600)}.contact__form-wrap{background:var(--clr-card);border:1.5px solid var(--clr-border);border-radius:var(--radius-2xl);padding:var(--space-6);box-shadow:var(--shadow-card)}.contact__form{gap:var(--space-5);flex-direction:column;display:flex}.form-row{gap:var(--space-4);grid-template-columns:1fr;display:grid}.form-group{gap:var(--space-2);flex-direction:column;display:flex}.form-label{font-size:var(--text-xs);font-weight:var(--font-bold);color:var(--clr-text-secondary);letter-spacing:.04em;text-transform:uppercase}.form-input,.form-textarea{width:100%;padding:var(--space-3) var(--space-4);border:1.5px solid var(--clr-border);border-radius:var(--radius-lg);font-size:var(--text-sm);color:var(--clr-text-primary);resize:none;font-family:var(--font-body);transition:border-color var(--transition-fast), box-shadow var(--transition-fast);background-color:#fafafa;outline:none}.form-input::placeholder,.form-textarea::placeholder{color:var(--clr-text-muted)}.form-input:focus,.form-textarea:focus{border-color:var(--clr-primary-400);box-shadow:0 0 0 3px var(--clr-primary-100)}.form-input--error{border-color:var(--clr-pink-600);box-shadow:0 0 0 3px var(--clr-pink-100)}.form-meta{justify-content:space-between;align-items:center;min-height:18px;display:flex}.form-error{font-size:var(--text-xs);color:var(--clr-pink-600);font-weight:var(--font-semibold)}.form-counter{font-size:var(--text-xs);color:var(--clr-text-muted);margin-left:auto}.contact__submit{align-self:flex-end}.contact__success{align-items:center;gap:var(--space-4);text-align:center;padding:var(--space-12) var(--space-6);animation:fadeInUp var(--transition-slow) ease;flex-direction:column;display:flex}.contact__success-icon{color:#16a34a;background:#f0fdf4;border:2px solid #bbf7d0;border-radius:50%;justify-content:center;align-items:center;width:56px;height:56px;display:flex}.contact__success-title{font-family:var(--font-display);font-size:var(--text-2xl);font-weight:var(--font-semibold);color:var(--clr-text-primary)}.contact__success-text{font-size:var(--text-sm);color:var(--clr-text-secondary);max-width:300px;line-height:1.7}@media (min-width:768px){.contact__grid{gap:var(--space-10);grid-template-columns:1fr 1fr}.form-row{grid-template-columns:1fr 1fr}.contact__form-wrap{padding:var(--space-8)}}
.skeleton-section{width:100%;padding:clamp(3rem,6vw,5rem) 0}.skeleton-label{border-radius:12px;width:100px;height:20px;margin:0 auto 16px}.skeleton-title{border-radius:8px;width:250px;height:40px;margin:0 auto 8px}.skeleton-subtitle{border-radius:8px;width:350px;height:20px;margin:0 auto 48px}.skeleton-content{grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:24px;display:grid}.skeleton-card{border-radius:16px;width:100%;height:220px}.shimmer{background:#18181b linear-gradient(90deg,#fff0 0,#ffffff0d 20%,#ffffff1a 60%,#fff0) 0 0/200% 100%;animation:1.5s linear infinite shimmer}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}
.skills{padding:var(--section-py) 0;background-color:#f9fbff;min-height:100dvh}.skills__tabs{scrollbar-width:none;justify-content:flex-start;gap:.45rem;margin-bottom:1rem;padding-bottom:.45rem;display:flex;overflow-x:auto}.skills__tabs::-webkit-scrollbar{display:none}.skills__tab{border-radius:var(--radius-full);font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--clr-text-secondary);border:1px solid var(--clr-border);white-space:nowrap;cursor:pointer;transition:background var(--transition-base), color var(--transition-base), border-color var(--transition-base), transform var(--transition-fast);background:#fff;padding:.5rem .92rem}.skills__tab:hover{transform:translateY(-1px)}.skills__tab--active{background:var(--clr-primary-600);color:#fff;border-color:var(--clr-primary-600)}.skills__grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:.68rem;display:grid}.skill-card{text-align:left;border:1px solid var(--clr-border);border-radius:var(--radius-xl);box-shadow:var(--shadow-card);cursor:pointer;transition:border-color var(--transition-base), box-shadow var(--transition-base), transform var(--transition-fast);background:#fff;flex-direction:column;gap:.45rem;padding:.9rem;display:flex}.skill-card:hover{border-color:var(--clr-primary-300);box-shadow:var(--shadow-md);transform:translateY(-2px)}.skill-card__icon{width:28px;height:28px;color:var(--clr-primary-600);flex-shrink:0}.skill-card__icon svg,.skill-card__icon img{object-fit:contain;width:100%;height:100%}.skill-card__title{font-family:var(--font-display);font-size:.88rem;font-weight:var(--font-semibold);color:var(--clr-text-primary);line-height:1.25}.skill-card__desc{color:var(--clr-text-secondary);-webkit-line-clamp:3;text-overflow:ellipsis;-webkit-box-orient:vertical;min-height:3.4em;font-size:.74rem;line-height:1.5;display:-webkit-box;overflow:hidden}.skill-card__bar-wrap{align-items:center;gap:.4rem;display:flex}.skill-card__progress{border-radius:var(--radius-full);border:none;width:100%;height:6px;overflow:hidden}.skill-card__progress::-webkit-progress-bar{background:var(--clr-primary-100);border-radius:var(--radius-full)}.skill-card__progress::-webkit-progress-value{background:linear-gradient(90deg, var(--clr-primary-400), var(--clr-primary-600));border-radius:var(--radius-full)}.skill-card__progress::-moz-progress-bar{background:linear-gradient(90deg, var(--clr-primary-400), var(--clr-primary-600));border-radius:var(--radius-full)}.skill-card__percent{color:var(--clr-primary-600);font-size:.68rem;font-weight:var(--font-semibold);white-space:nowrap}.skills-modal-overlay{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);z-index:var(--z-modal);animation:fadeIn var(--transition-base) ease;overscroll-behavior:contain;background:#1420338f;justify-content:center;align-items:center;padding:.6rem;display:flex;position:fixed;inset:0}.skills-modal{background:var(--clr-bg);border:1px solid var(--clr-border);border-radius:var(--radius-2xl);width:min(680px,100vw - 1.2rem);max-height:min(90dvh,820px);box-shadow:var(--shadow-xl);animation:scaleIn var(--transition-base) ease;flex-direction:column;display:flex;overflow:hidden}.skills-modal--detail{height:auto}.skills-modal__header{justify-content:space-between;align-items:center;gap:var(--space-3);padding:var(--space-5);border-bottom:1px solid var(--clr-border);flex-shrink:0;display:flex}.skills-modal__title{font-family:var(--font-display);font-size:var(--text-lg);font-weight:var(--font-semibold);color:var(--clr-text-primary)}.skills-modal__header-actions{align-items:center;gap:var(--space-2);display:flex}.skills-modal__header-link{color:var(--clr-primary-600);font-size:var(--text-sm);font-weight:var(--font-semibold);cursor:pointer;transition:color var(--transition-fast);background:0 0;border:0;align-items:center;gap:.35rem;display:inline-flex}.skills-modal__header-icon{margin-top:-1px}.skills-modal__header-link.is-open{color:var(--clr-primary-700)}.skills-modal__close{border:1px solid var(--clr-border);width:34px;height:34px;color:var(--clr-text-secondary);cursor:pointer;background:0 0;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;display:flex}.skills-modal__dropdown{opacity:0;border-bottom:0 solid var(--clr-border);max-height:0;transition:max-height var(--transition-slow), opacity var(--transition-base), transform var(--transition-base), border-bottom-width var(--transition-base);overflow:hidden;transform:translateY(-8px)}.skills-modal__dropdown.is-open{opacity:1;border-bottom-width:1px;max-height:400px;transform:translateY(0)}.skills-modal__dropdown.is-retracted{max-height:85px}.skills-modal__list-label{font-size:.72rem;font-weight:var(--font-bold);letter-spacing:.08em;text-transform:uppercase;color:var(--clr-text-muted);padding:var(--space-3) var(--space-4) var(--space-2)}.skills-modal__list-tabs{scrollbar-width:none;padding:0 var(--space-4) var(--space-3);border-bottom:1px solid #f0f4fb;flex-wrap:nowrap;gap:.35rem;display:flex;overflow-x:auto}.skills-modal__list-tabs::-webkit-scrollbar{display:none}.skills-modal__list-tab{text-align:left;color:var(--clr-text-secondary);font-size:.72rem;font-weight:var(--font-medium);cursor:pointer;background-color:#0000;border:none;border-radius:10px;padding:.45rem .55rem}.skills-modal__list-tab.is-active{color:var(--clr-primary-700)}.skills-modal__list-scroll{max-height:220px;padding:0 var(--space-4) var(--space-4);transition:opacity var(--transition-base), transform var(--transition-base);flex-direction:column;gap:.3rem;display:flex;overflow-y:auto}.skills-modal__dropdown.is-retracted .skills-modal__list-scroll{opacity:0;pointer-events:none;transform:translateY(-8px)}.skills-modal__numbered-list{margin:0;padding:0;list-style:none}.skills-modal__numbered-item{color:var(--clr-text-secondary);align-items:center;margin-bottom:2px;font-size:.78rem;display:flex}.skills-modal__number{width:1.4rem;font-weight:var(--font-semibold);color:var(--clr-text-muted);flex-shrink:0}.skills-modal__item{text-align:left;color:var(--clr-text-secondary);cursor:pointer;background:0 0;border:1px solid #0000;border-radius:10px;width:100%;padding:.4rem .52rem;font-size:.78rem}.skills-modal__item.is-active{color:var(--clr-primary-700);font-weight:var(--font-semibold)}.skills-modal__body{padding:var(--space-5);min-height:0;overflow-y:auto}.skills-detail{gap:var(--space-4);flex-direction:column;display:flex}.skills-detail__head{align-items:center;gap:var(--space-3);display:flex}.skills-detail__icon{width:30px;height:30px;color:var(--clr-primary-600)}.skills-detail__icon svg,.skills-detail__icon img{width:100%;height:100%}.skills-detail__name{font-family:var(--font-display);font-size:1.1rem;font-weight:var(--font-semibold);color:var(--clr-text-primary)}.skills-detail__desc{font-size:var(--text-sm);color:var(--clr-text-secondary);line-height:1.65}.skills-detail__confidence{flex-direction:column;gap:.3rem;display:flex}.skills-detail__progress-label{color:var(--clr-text-muted);text-transform:uppercase;letter-spacing:.06em;font-size:.72rem}.skills-detail__progress{border-radius:var(--radius-full);border:none;width:100%;height:6px;overflow:hidden}.skills-detail__progress::-webkit-progress-bar{background:var(--clr-primary-100)}.skills-detail__progress::-webkit-progress-value{background:linear-gradient(90deg, var(--clr-primary-400), var(--clr-primary-600))}.skills-detail__progress::-moz-progress-bar{background:linear-gradient(90deg, var(--clr-primary-400), var(--clr-primary-600))}.skills-detail__progress-value{color:var(--clr-primary-700);font-size:.74rem;font-weight:var(--font-semibold)}.skills-detail__exp{flex-direction:column;gap:.45rem;display:flex}.skills-detail__exp-title{font-size:.8rem;font-weight:var(--font-semibold);color:var(--clr-text-primary)}.skills-detail__exp-list{flex-direction:column;gap:.4rem;display:flex}.btn-exp-link{text-align:left;cursor:pointer;transition:color var(--transition-fast);background:0 0;border:none;font-family:inherit}.btn-exp-link:hover{color:var(--clr-primary-600);text-decoration:underline}.skills-detail__exp-item{font-size:var(--text-sm);color:var(--clr-text-secondary);padding-left:1rem;line-height:1.5;position:relative}.skills-detail__exp-item:before{content:"";background:var(--clr-primary-500);border-radius:50%;width:5px;height:5px;position:absolute;top:.55rem;left:0}.skills-detail__exp-item--more{font-weight:var(--font-semibold);color:var(--clr-primary-600)}.skills-detail__exp-item--more:before{display:none}.skills-detail__exp-item--more{margin-top:.2rem;padding-left:0}.skills-detail__exp-empty{font-size:var(--text-sm);color:var(--clr-text-muted);font-style:italic}@media (max-width:767px){.skills-modal{border-radius:18px;width:calc(100vw - 1rem)}}@media (min-width:768px){.skills__tabs{margin-bottom:var(--space-8);justify-content:center;overflow:visible}.skills__grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:1rem}}
.journey{padding:var(--section-py) 0;background:#f7f9fc;min-height:100dvh}.journey__stack{overflow-anchor:none;gap:1rem;display:grid}.journey-panel{background:#fff;border:1px solid #14203314;border-radius:12px;overflow:hidden;box-shadow:0 4px 12px #14203305}.journey-panel__head{text-align:left;cursor:pointer;background:#fff;border:0;justify-content:space-between;align-items:center;gap:.8rem;width:100%;padding:1.2rem 1.5rem;transition:background .2s;display:flex}.journey-panel__head:hover{background:#fcfcfd}.journey-panel__head-left{align-items:center;gap:.8rem;display:flex}.journey-panel__icon{background:var(--clr-primary-100);width:36px;height:36px;color:var(--clr-primary-600);border-radius:8px;justify-content:center;align-items:center;display:flex}.journey-panel__title{font-family:var(--font-display);color:var(--clr-text-primary);font-size:1.1rem;font-weight:700}.journey-chevron{color:#fff;width:24px;height:24px;transition:transform var(--transition-base), background var(--transition-base);background:#333;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;display:inline-flex}.journey-panel.is-open .journey-chevron{transform:rotate(180deg)}.journey-panel__body-wrap{opacity:0;grid-template-rows:0fr;transition:grid-template-rows .38s cubic-bezier(.4,0,.2,1),opacity .25s cubic-bezier(.4,0,.2,1);display:grid;overflow:hidden}.journey-panel__body-wrap.is-open{opacity:1;grid-template-rows:1fr;transition:grid-template-rows .42s cubic-bezier(.4,0,.2,1),opacity .32s cubic-bezier(.4,0,.2,1)}.journey-panel__body{flex-direction:column;gap:1.5rem;min-height:0;padding:0 1.5rem 1.5rem;display:flex;overflow:hidden}.journey-group{gap:1rem;padding-bottom:1.5rem;display:flex;position:relative}.journey-group:last-child{border-bottom:none;padding-bottom:0}.journey-group:last-child .journey-role--last .journey-role__content{border-bottom:none}.journey-group__left{flex-direction:column;flex-shrink:0;align-items:center;width:48px;display:flex}.journey-group__logo{z-index:2;background-color:#e5e7eb;border:1px solid #d1d5db;border-radius:8px;flex-shrink:0;width:48px;height:48px;overflow:hidden}.journey-group__right{border-bottom:1px solid #f0f0f0;flex:1;min-width:0;padding-top:.2rem}.journey-group__head{flex-direction:column;gap:.2rem;margin-bottom:.5rem;display:flex}.journey-group__title{color:var(--clr-text-primary);font-size:.95rem;font-weight:700;line-height:1.3}.journey-group__subtitle{color:var(--clr-text-secondary);font-size:.85rem}.journey-group__roles{flex-direction:column;gap:1.5rem;margin-top:1.5rem;display:flex}.journey-role{cursor:pointer;transition:transform var(--transition-fast), border-color var(--transition-fast);flex-direction:column;gap:1rem;display:flex;position:relative}.journey-role:hover{transform:translate(4px)}.journey-role__content{flex:1;min-width:0}.journey-role--last .journey-role__content{border-bottom:1px dashed #00000014;padding-bottom:1.5rem}.journey-role__head{flex-direction:column;gap:.2rem;margin-bottom:.5rem;display:flex}.journey-role__title{color:var(--clr-text-primary);transition:color var(--transition-fast);font-size:.95rem;font-weight:600}.journey-role:hover .journey-role__title{color:var(--clr-primary-600)}.journey-role__period{color:var(--clr-text-muted);font-size:.75rem}.journey-role__desc{color:var(--clr-text-secondary);-webkit-line-clamp:3;text-overflow:ellipsis;-webkit-box-orient:vertical;margin-bottom:.8rem;font-size:.85rem;line-height:1.6;display:-webkit-box;overflow:hidden}.journey-media-overview{margin-bottom:.8rem}.journey-skills-overview{background:var(--clr-primary-50);border:1px solid var(--clr-primary-200);border-radius:var(--radius-full);align-items:center;gap:.4rem;padding:.3rem .6rem;display:inline-flex}.journey-skills__text{color:var(--clr-primary-700);font-size:.72rem;font-weight:600}.journey-skills-overview svg{color:var(--clr-primary-600)}.journey-view-btn{color:var(--clr-primary-700);cursor:pointer;text-align:center;background:0 0;border:0;width:100%;padding:.5rem 0;font-size:.85rem;font-weight:600;transition:color .2s}.journey-view-btn:hover{color:var(--clr-primary-900)}.journey-modal-overlay{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);z-index:var(--z-modal);animation:fadeIn var(--transition-base) ease;overscroll-behavior:contain;background:#1420338f;justify-content:center;align-items:center;padding:.5rem;display:flex;position:fixed;inset:0}.journey-modal{background:var(--clr-bg);border:1px solid var(--clr-border);border-radius:var(--radius-2xl);width:min(720px,100vw - 1rem);height:min(86dvh,800px);box-shadow:var(--shadow-xl);animation:scaleIn var(--transition-base) ease;flex-direction:column;display:flex;overflow:hidden}.journey-modal__header{justify-content:space-between;align-items:flex-start;gap:var(--space-4);padding:var(--space-5);border-bottom:1px solid var(--clr-border);flex-shrink:0;display:flex}.journey-modal__close{border:1px solid var(--clr-border);width:34px;height:34px;color:var(--clr-text-secondary);cursor:pointer;transition:background var(--transition-fast);background:0 0;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;display:flex}.journey-modal__close:hover{background:var(--clr-surface)}.journey-modal__body{min-height:0;padding:var(--space-5);gap:var(--space-4);overscroll-behavior:contain;flex-direction:column;flex:1;display:flex;overflow-y:auto}.journey-modal__period{color:var(--clr-primary-700);font-size:.75rem;font-weight:var(--font-semibold)}.journey-modal__title{font-family:var(--font-display);font-size:1.1rem;font-weight:var(--font-semibold);color:var(--clr-text-primary);line-height:1.3}.journey-modal__institution{color:var(--clr-text-secondary);font-size:.85rem;font-weight:var(--font-medium)}.journey-modal__desc{font-size:var(--text-sm);color:var(--clr-text-secondary);line-height:1.7}.journey-modal__skills-title{font-size:.8rem;font-weight:var(--font-semibold);color:var(--clr-text-primary);margin-bottom:.5rem}.journey-modal__skill-group+.journey-modal__skill-group{margin-top:var(--space-4)}.journey-modal__skill-tags{flex-wrap:wrap;gap:.4rem;display:flex}.journey-modal__skill-tag{border:1px solid var(--clr-primary-300);color:var(--clr-primary-700);font-size:.72rem;font-weight:var(--font-medium);border-radius:var(--radius-full);cursor:pointer;transition:background var(--transition-fast), color var(--transition-fast);background:0 0;padding:.3rem .6rem}.journey-modal__skill-tag:hover{background:var(--clr-primary-600);color:#fff;border-color:var(--clr-primary-600)}.journey-highlight{animation:2s pulse-bg}@keyframes pulse-bg{0%{background-color:rgba(var(--clr-primary-rgb), .1)}to{background-color:#0000}}.mg-grid{border-radius:8px;flex-direction:column;flex-shrink:0;gap:4px;max-width:240px;display:flex}.mg-row{gap:4px;display:flex}.mg-thumb{cursor:pointer;outline:1px solid rgba (20, 32, 51, .1);outline-offset:0;background:#e5e7eb;border:none;border-radius:6px;flex:0 80px;min-width:0;padding:0;transition:opacity .2s;display:block;overflow:hidden}.mg-thumb:hover:not(.mg-thumb--no-hover) .mg-thumb__img{transform:scale(1.04)}.mg-thumb--no-hover{cursor:default;pointer-events:none}.mg-thumb__ratio{background:#d1d5db;border-radius:6px;width:100%;padding-top:100%;position:relative;overflow:hidden}.mg-thumb__img{object-fit:cover;object-position:center;border:2px solid #d1d5db;border-radius:6px;width:100%;height:100%;transition:transform .3s;position:absolute;inset:0}.mg-thumb__overlay{color:#fff;background:#00000080;justify-content:center;align-items:center;font-size:1.1rem;font-weight:700;display:flex;position:absolute;inset:0}.mg-caption__text{color:#ffffffe0;font-size:.88rem;line-height:1.6}.mg-caption__link{color:inherit;word-break:break-all;font-weight:600;text-decoration:underline}.mg-caption__toggle{color:#fff9;cursor:pointer;background:0 0;border:none;margin-left:.4rem;padding:0;font-size:.82rem;font-weight:600;transition:color .2s;display:inline-block}.mg-caption__toggle:hover{color:#fff}.media-slider-overlay{z-index:9999;animation:fadeIn var(--transition-fast) ease;overscroll-behavior:contain;background:#000000e6;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.media-slider-container{justify-content:center;align-items:center;width:100%;height:100%;display:flex;position:relative}.media-slider__close{color:#fff;cursor:pointer;z-index:2;background:#ffffff1a;border:none;border-radius:50%;justify-content:center;align-items:center;width:44px;height:44px;transition:background .2s;display:flex;position:absolute;top:1.5rem;right:1.5rem}.media-slider__close:hover{background:#fff3}.media-slider__close svg,.media-slider__nav svg{pointer-events:none}.media-slider__nav{color:#fff;cursor:pointer;z-index:2;background:#ffffff1a;border:none;border-radius:50%;justify-content:center;align-items:center;width:50px;height:50px;transition:background .2s;display:flex;position:absolute;top:50%;transform:translateY(-50%)}.media-slider__nav:hover{background:#fff3}.media-slider__nav--prev{left:1.5rem}.media-slider__nav--next{right:1.5rem}.media-slider__content{flex-direction:column;justify-content:center;align-items:center;width:100%;max-width:90vw;height:100%;max-height:90vh;display:flex}.media-slider__image-wrapper{flex-direction:column;align-items:center;min-width:min(300px,100%);max-width:100%;display:inline-flex;position:relative}.media-slider__image{border-radius:4px;width:auto;max-width:100%;height:auto;max-height:70vh;display:block;box-shadow:0 4px 20px #0000004d}.mg-caption{text-align:left;word-wrap:break-word;width:0;min-width:100%;max-height:25vh;margin-top:1rem;padding-right:8px;overflow-y:auto}.mg-caption::-webkit-scrollbar{width:4px}.mg-caption::-webkit-scrollbar-track{background:#ffffff1a;border-radius:4px}.mg-caption::-webkit-scrollbar-thumb{background:#fff6;border-radius:4px}@media (min-width:768px){.journey__stack{gap:1.5rem}.journey-group__head,.journey-role__head{flex-direction:row;justify-content:space-between;align-items:flex-start}.journey-role__period{text-align:right}}
.portfolio{padding:var(--section-py) 0;background:#f9fbff;min-height:100dvh}.portfolio__tabs{scrollbar-width:none;justify-content:flex-start;gap:.45rem;margin-bottom:1rem;padding-bottom:.45rem;display:flex;overflow-x:auto}.portfolio__tabs::-webkit-scrollbar{display:none}.port-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:.68rem;display:grid}.port-card{text-align:left;border-radius:var(--radius-xl);border:1px solid var(--clr-border);box-shadow:var(--shadow-card);cursor:pointer;transition:box-shadow var(--transition-base), border-color var(--transition-base), transform var(--transition-fast);background:#fff;flex-direction:column;min-width:0;height:214px;padding:0;display:flex;overflow:hidden}.port-card:hover{box-shadow:var(--shadow-md);border-color:var(--clr-primary-300);transform:translateY(-2px)}.port-card__img-wrap{flex-shrink:0;height:142px;position:relative;overflow:hidden}.port-card__img{object-fit:cover;width:100%;height:100%;transition:transform var(--transition-slow), filter var(--transition-slow)}.port-card__placeholder{background:linear-gradient(135deg, var(--clr-primary-100), #fff);width:100%;height:100%;color:var(--clr-primary-600);place-items:center;display:grid}.port-card__shade{opacity:1;height:100%;transition:opacity var(--transition-base);pointer-events:none;background:linear-gradient(#0000 0%,#14203314 44%,#14203357 100%);position:absolute;inset:0}.port-card__content{flex-direction:column;flex:0 0 72px;justify-content:center;gap:.08rem;min-width:0;height:72px;padding:.7rem .75rem;display:flex;overflow:hidden}.port-card__meta{color:var(--clr-primary-700);font-size:.68rem;font-weight:var(--font-medium);white-space:nowrap;text-overflow:ellipsis;max-width:100%;margin:0;line-height:1.2;display:block;overflow:hidden}.port-card__title{font-family:var(--font-display);color:var(--clr-text-primary);font-size:.88rem;line-height:1.25;font-weight:var(--font-semibold);white-space:nowrap;text-overflow:ellipsis;max-width:100%;margin:0;overflow:hidden}.port-card__year{color:var(--clr-text-muted);font-size:.64rem;font-weight:var(--font-medium);white-space:nowrap;text-overflow:ellipsis;max-width:100%;margin:0;line-height:1.2;display:block;overflow:hidden}.portfolio-modal-overlay{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);z-index:var(--z-modal);animation:fadeIn var(--transition-base) ease;overscroll-behavior:contain;background:#1420338f;justify-content:center;align-items:center;padding:.6rem;display:flex;position:fixed;inset:0;overflow:hidden}.portfolio-modal{background:var(--clr-bg);border:1px solid var(--clr-border);border-radius:var(--radius-2xl);width:min(720px,100vw - 1.2rem);max-height:min(90dvh,840px);box-shadow:var(--shadow-xl);animation:scaleIn var(--transition-base) ease;flex-direction:column;display:flex;overflow:hidden}.portfolio-modal__header{justify-content:space-between;align-items:center;gap:var(--space-3);padding:var(--space-5);border-bottom:1px solid var(--clr-border);flex-shrink:0;display:flex}.portfolio-modal__title{font-family:var(--font-display);font-size:var(--text-lg);font-weight:var(--font-semibold);color:var(--clr-text-primary)}.portfolio-modal__header-actions{align-items:center;gap:var(--space-2);display:flex}.portfolio-modal__header-link{border:1px solid var(--clr-border);border-radius:var(--radius-full);min-height:34px;color:var(--clr-primary-600);font-size:var(--text-sm);font-weight:var(--font-semibold);cursor:pointer;transition:color var(--transition-fast), border-color var(--transition-fast), background var(--transition-fast);background:#fff;justify-content:center;align-items:center;gap:.3rem;padding:0 .75rem;line-height:1;display:inline-flex}.portfolio-modal__header-link.is-open{color:var(--clr-primary-700);border-color:var(--clr-primary-300);background:var(--clr-primary-100)}.portfolio-modal__header-icon{flex-shrink:0;display:block}.portfolio-modal__close{border:1px solid var(--clr-border);width:34px;height:34px;color:var(--clr-text-secondary);cursor:pointer;background:0 0;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;display:flex}.portfolio-modal__dropdown{opacity:0;border-bottom:0 solid var(--clr-border);max-height:0;transition:max-height var(--transition-slow), opacity var(--transition-base), transform var(--transition-base), border-bottom-width var(--transition-base);overflow:clip;transform:translateY(-8px)}.portfolio-modal__dropdown.is-open{opacity:1;border-bottom-width:1px;max-height:480px;transform:translateY(0)}.portfolio-modal__dropdown.is-retracted{max-height:88px}.portfolio-modal__list-label{font-size:.72rem;font-weight:var(--font-bold);letter-spacing:.08em;text-transform:uppercase;color:var(--clr-text-muted);padding:var(--space-3) var(--space-4) var(--space-2)}.portfolio-modal__list-tabs{scrollbar-width:none;padding:0 var(--space-4) var(--space-3);border-bottom:1px solid #f0f4fb;flex-wrap:nowrap;gap:.35rem;display:flex;overflow-x:auto}.portfolio-modal__list-tabs::-webkit-scrollbar{display:none}.portfolio-modal__list-tab{text-align:left;color:var(--clr-text-secondary);font-size:.72rem;font-weight:var(--font-medium);cursor:pointer;transition:background var(--transition-fast), color var(--transition-fast), border-color var(--transition-fast);background:0 0;border:#0000;border-radius:10px;padding:.45rem .55rem}.portfolio-modal__list-tab.is-active{color:var(--clr-primary-700);background:0 0;border-color:#0000}.portfolio-modal__list-scroll{overscroll-behavior:contain;height:200px;max-height:200px;padding:0 var(--space-4) var(--space-4);flex-direction:column;gap:.3rem;display:flex;overflow-y:auto}.portfolio-modal__dropdown.is-retracted .portfolio-modal__list-scroll{opacity:0;pointer-events:none;transition:opacity var(--transition-base), transform var(--transition-base);transform:translateY(-8px)}.portfolio-modal__numbered-list{margin:0;padding:0;list-style:none}.portfolio-modal__numbered-item{color:var(--clr-text-secondary);align-items:stretch;min-width:0;margin-bottom:2px;font-size:.78rem;display:flex}.portfolio-modal__number{width:1.4rem;font-weight:var(--font-semibold);color:var(--clr-text-muted);flex-shrink:0;padding-top:.52rem}.portfolio-modal__item{text-align:left;color:var(--clr-text-secondary);cursor:pointer;background:0 0;border:1px solid #0000;border-radius:10px;width:100%;min-width:0;padding:.42rem .52rem;font-size:.78rem}.portfolio-modal__item.is-active{color:var(--clr-primary-700);font-weight:var(--font-semibold);background:0 0}.portfolio-modal__item-title{white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.portfolio-modal__item-sub{color:var(--clr-text-muted);white-space:nowrap;text-overflow:ellipsis;margin-top:.12rem;font-size:.68rem;display:block;overflow:hidden}.portfolio-modal__body{overscroll-behavior:contain;padding:var(--space-5);flex:1;min-height:0;overflow-y:auto}.portfolio-detail{gap:var(--space-4);flex-direction:column;display:flex}.portfolio-detail__gallery{margin-bottom:var(--space-2)}.portfolio-detail__meta{color:var(--clr-primary-700);font-size:.72rem;font-weight:var(--font-medium);margin:0 0 .2rem}.portfolio-detail__meta-block{flex-direction:column;gap:.08rem;margin-bottom:.25rem;display:flex}.portfolio-detail__year{color:var(--clr-text-muted);font-size:.7rem;font-weight:var(--font-medium);margin:0}.portfolio-detail__title{font-family:var(--font-display);font-size:1.1rem;font-weight:var(--font-semibold);color:var(--clr-text-primary);margin-bottom:.35rem;line-height:1.3}.portfolio-detail__desc{font-size:var(--text-sm);color:var(--clr-text-secondary);line-height:1.65}.portfolio-detail__skills{flex-direction:column;gap:.75rem;display:flex}.portfolio-detail__skill-group{flex-direction:column;gap:.35rem;display:flex}.portfolio-detail__skill-title{font-size:.76rem;font-weight:var(--font-semibold);color:var(--clr-text-secondary);text-transform:uppercase;letter-spacing:.05em}.portfolio-detail__skill-list{flex-wrap:wrap;gap:.38rem;display:flex}.portfolio-detail__skill-btn{border:1px solid var(--clr-primary-300);color:var(--clr-primary-700);font-size:.72rem;font-weight:var(--font-medium);border-radius:var(--radius-full);cursor:pointer;background:0 0;padding:.28rem .58rem}.portfolio-detail__highlights-title{font-size:.8rem;font-weight:var(--font-semibold);color:var(--clr-text-primary);margin-bottom:.4rem}.portfolio-detail__highlights-list{flex-direction:column;gap:.35rem;display:flex}.portfolio-detail__highlight-item{font-size:var(--text-sm);color:var(--clr-text-secondary);padding-left:.9rem;line-height:1.55;position:relative}.portfolio-detail__highlight-item:before{content:"";background:var(--clr-primary-500);border-radius:50%;width:5px;height:5px;position:absolute;top:.52rem;left:0}@media (max-width:767px){.portfolio-modal{border-radius:18px;width:calc(100vw - 1rem);max-height:calc(100dvh - 1rem)}.portfolio-modal__header{padding:var(--space-4);align-items:flex-start}.portfolio-modal__header-actions{flex-wrap:wrap;justify-content:flex-end}.portfolio-modal__header-link span{display:none}.portfolio-modal__header-link{width:34px;padding:0}}@media (min-width:768px){.portfolio__tabs{margin-bottom:var(--space-8);justify-content:center;overflow:visible}.port-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:1rem}.port-card__img-wrap{height:178px}.port-card{height:250px}.port-card:hover .port-card__img{filter:blur(1.5px)brightness(.75);transform:scale(1.06)}}
