:root{--bg:#faf7f2;--surface:#f1ece4;--card:#fff;--text:#2d2926;--text-secondary:#756c62;--border:#e4d8c6;--accent:#b55239;--accent-hover:#964430;--burgundy:#6e7f64;--gold:#d4b483;--space-1:4px;--space-2:8px;--space-3:12px;--space-4:16px;--space-5:20px;--space-6:24px;--space-8:32px;--space-10:40px;--space-12:48px;--space-16:64px;--space-24:96px;--radius-sm:6px;--radius-md:10px;--radius-lg:14px;--radius-xl:16px;--radius-pill:20px;--container-max:1280px;--reading-max:520px;--font-sans:"Inter", sans-serif;--font-body:"IBM Plex Sans", sans-serif;--transition:.25s cubic-bezier(.4, 0, .2, 1);--transition-slow:.45s cubic-bezier(.4, 0, .2, 1)}[data-theme=dark]{--bg:#221e1b;--surface:#2d2926;--card:#353029;--text:#faf7f2;--text-secondary:#c9bfb1;--border:#463f37;--accent:#d4795c;--accent-hover:#e08f73;--burgundy:#8fa284}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;overflow-x:hidden}body{font-family:var(--font-sans);background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;transition:background var(--transition), color var(--transition);width:100%;line-height:1.6;overflow-x:hidden}a{color:inherit;text-decoration:none}button{font-family:inherit}img{max-width:100%;display:block}::selection{background:#b5523929}::-webkit-scrollbar{width:5px}::-webkit-scrollbar-track{background:var(--bg)}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-secondary)}.container{max-width:var(--container-max);padding:0 var(--space-10);margin:0 auto}.section{padding:var(--space-24) 0;border-top:1px solid var(--border)}.section--surface{background:var(--surface)}@media (width<=1024px){.container{padding:0 var(--space-8)}}@media (width<=768px){.container{padding:0 var(--space-5)}.section{padding:72px 0}}@media (width<=480px){.container{padding:0 var(--space-4)}.section{padding:56px 0}}.navbar{z-index:100;background:var(--card);border:1px solid var(--border);width:calc(100% - 32px);max-width:90%;transition:box-shadow var(--transition), border-color var(--transition), background var(--transition);border-radius:999px;margin:auto;position:fixed;top:18px;left:0;right:0;transform:translate(-50%);box-shadow:0 8px 28px #2d292612}.navbar--scrolled{border-color:var(--gold);box-shadow:0 12px 34px #2d29261f}.navbar__inner{justify-content:space-between;align-items:center;height:60px;padding:0 8px;display:flex}.navbar__logo{cursor:pointer;background:0 0;border:none;align-items:center;padding:0;display:flex}.navbar__logo-img{object-fit:cover;width:45px;height:45px;transition:transform var(--transition);border-radius:50%;display:block}.navbar__logo:hover .navbar__logo-img{transform:scale(1.06)}.navbar__links{align-items:center;gap:2px;display:flex}.navbar__link{cursor:pointer;font-family:var(--font-sans);color:var(--text-secondary);letter-spacing:.01em;transition:color var(--transition), background var(--transition);background:0 0;border:none;border-radius:999px;padding:8px 14px;font-size:13.5px;font-weight:500}.navbar__link:hover{color:var(--text);background:var(--surface)}.navbar__link--active{color:var(--accent);background:var(--surface)}.navbar__actions{align-items:center;gap:8px;display:flex}.navbar__resume{font-family:var(--font-sans);background:var(--accent);color:#fff;cursor:pointer;letter-spacing:.01em;transition:background var(--transition), transform var(--transition);border:none;border-radius:999px;align-items:center;gap:6px;padding:7px 18px;font-size:13px;font-weight:600;text-decoration:none;display:inline-flex}.navbar__resume:hover{background:var(--accent-hover);transform:translateY(-1px)}.navbar__theme-btn{background:var(--surface);border:1px solid var(--border);cursor:pointer;width:36px;height:36px;transition:background var(--transition), border-color var(--transition);border-radius:50%;justify-content:center;align-items:center;font-size:16px;display:flex}.navbar__theme-btn:hover{background:var(--card);border-color:var(--accent)}.navbar__hamburger{background:var(--surface);border:1px solid var(--border);cursor:pointer;border-radius:50%;flex-direction:column;justify-content:center;align-items:center;gap:4px;width:36px;height:36px;display:none}.navbar__hamburger-bar{background:var(--text);height:1.5px;transition:width var(--transition);border-radius:2px;display:block}.navbar__mobile-menu{background:var(--card);border:1px solid var(--border);border-radius:24px;flex-direction:column;gap:0;padding:10px 22px 14px;display:flex;position:absolute;top:calc(100% + 10px);left:0;right:0;box-shadow:0 12px 34px #2d29261f}.navbar__mobile-link{border:none;border-bottom:1px solid var(--border);cursor:pointer;font-family:var(--font-sans);color:var(--text);text-align:left;transition:color var(--transition);background:0 0;padding:12px 0;font-size:15px;font-weight:500}.navbar__mobile-link:hover{color:var(--accent)}.navbar__mobile-resume{color:var(--accent);cursor:pointer;font-size:15px;font-weight:600;font-family:var(--font-sans);text-align:left;background:0 0;border:none;margin-top:8px;padding:10px 0}@media (width<=768px){.navbar__links{display:none}.navbar__hamburger{display:flex}}.hero{align-items:center;min-height:100vh;padding-top:100px;padding-bottom:80px;display:flex}.hero__grid{grid-template-columns:400px 1fr;align-items:center;gap:64px;display:grid}.hero__badge{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-pill);color:var(--text-secondary);letter-spacing:.06em;text-transform:uppercase;align-items:center;gap:7px;margin-bottom:20px;padding:5px 14px;font-size:11.5px;font-weight:600;display:inline-flex}.hero__badge-dot{background:var(--burgundy);border-radius:50%;flex-shrink:0;width:6px;height:6px}.hero__name{font-family:var(--font-sans);letter-spacing:-.04em;color:var(--text);margin-bottom:18px;font-size:clamp(52px,8vw,88px);font-weight:800;line-height:.97}.hero__name-accent{color:var(--accent);display:block}.hero__tagline{font-family:var(--font-body);color:var(--text-secondary);max-width:520px;margin-bottom:20px;font-size:clamp(16px,2.5vw,21px);font-style:italic;font-weight:400;line-height:1.5}.hero__intro{font-family:var(--font-body);color:var(--text-secondary);max-width:500px;margin-bottom:40px;font-size:clamp(14px,1.8vw,15.5px);line-height:1.8}.hero__ctas{flex-wrap:wrap;gap:12px;margin-bottom:48px;display:flex}.hero__cta-primary{border-radius:var(--radius-md);font-family:var(--font-sans);background:var(--accent);color:#fff;cursor:pointer;letter-spacing:.02em;transition:background var(--transition), transform var(--transition);border:none;align-items:center;padding:13px 28px;font-size:14px;font-weight:600;text-decoration:none;display:inline-flex}.hero__cta-primary:hover{background:var(--accent-hover);transform:translateY(-1px)}.hero__cta-secondary{border-radius:var(--radius-md);font-family:var(--font-sans);color:var(--text);border:1.5px solid var(--border);cursor:pointer;letter-spacing:.02em;transition:border-color var(--transition), color var(--transition), transform var(--transition);background:0 0;align-items:center;padding:13px 28px;font-size:14px;font-weight:600;text-decoration:none;display:inline-flex}.hero__cta-secondary:hover{border-color:var(--accent);color:var(--accent);transform:translateY(-1px)}.hero__socials{align-items:center;gap:16px;display:flex}.hero__social-label{letter-spacing:.1em;text-transform:uppercase;color:var(--text-secondary);font-size:11px;font-weight:700}.hero__social-links{gap:8px;display:flex}.hero__social-link{border-radius:var(--radius-sm);font-family:var(--font-sans);color:var(--text-secondary);background:var(--surface);border:1px solid var(--border);transition:color var(--transition), border-color var(--transition), background var(--transition);padding:6px 14px;font-size:12.5px;font-weight:500}.hero__social-link:hover{color:var(--accent);border-color:var(--accent);background:var(--card)}.hero__photo-col{flex-direction:column;align-items:center;gap:20px;display:flex}.hero__photo-frame{aspect-ratio:3/4;border:1px solid var(--border);background:var(--surface);border-radius:20px;width:100%;max-height:480px;position:relative;overflow:hidden}.hero__photo-frame img{object-fit:cover;object-position:center top;width:100%;height:100%}.hero__photo-placeholder{background:linear-gradient(135deg,#b5523914,#6e7f640d);flex-direction:column;justify-content:center;align-items:center;gap:12px;width:100%;height:100%;display:flex}.hero__photo-placeholder-icon{background:var(--border);width:64px;height:64px;color:var(--text-secondary);border-radius:50%;justify-content:center;align-items:center;font-size:28px;display:flex}.hero__photo-placeholder-text{font-family:var(--font-sans);color:var(--text-secondary);letter-spacing:.04em;font-size:12px;font-weight:500}.hero__photo-stat{background:var(--card);border:1px solid var(--border);border-radius:var(--radius-lg);justify-content:space-between;align-items:center;width:100%;padding:16px 20px;display:flex}.hero__photo-stat-val{font-family:var(--font-sans);color:var(--accent);letter-spacing:-.02em;font-size:22px;font-weight:800}.hero__photo-stat-label{font-family:var(--font-body);color:var(--text-secondary);margin-top:2px;font-size:12px}@media (width<=900px){.hero__grid{grid-template-columns:1fr;gap:48px}.hero__photo-col{flex-direction:row;align-items:flex-start}.hero__photo-frame{aspect-ratio:1;width:180px;max-height:unset;border-radius:var(--radius-xl);flex-shrink:0}.hero__photo-stat{flex:1}}@media (width<=600px){.hero__photo-col{flex-direction:column}.hero__photo-frame{border-radius:50%;width:140px;height:140px}.hero__socials{flex-direction:column;align-items:flex-start}}.about__grid{grid-template-columns:1fr 1fr;align-items:start;gap:64px;display:grid}.about__heading{font-family:var(--font-sans);letter-spacing:-.03em;color:var(--text);margin-bottom:24px;font-size:clamp(26px,4vw,42px);font-weight:800;line-height:1.15}.about__heading-accent{color:var(--accent)}.about__body{font-family:var(--font-body);color:var(--text-secondary);margin-bottom:16px;font-size:15.5px;line-height:1.8}.about__body strong{color:var(--text);font-weight:600}.about__cards{flex-direction:column;gap:16px;margin-top:28px;display:flex}.about__right{flex-direction:column;gap:16px;height:100%;display:flex}.about__photo-frame{border-radius:var(--radius-xl);border:1px solid var(--border);background:var(--surface);width:100%;height:560px;position:relative;overflow:hidden}.about__photo-frame img{object-fit:cover;object-position:center top;width:100%;height:100%}.about__photo-placeholder{background:linear-gradient(135deg,#b5523914,#6e7f640d);flex-direction:column;justify-content:center;align-items:center;gap:10px;width:100%;height:100%;display:flex}.about__photo-placeholder-icon{color:var(--text-secondary);font-size:36px}.about__photo-label{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-radius:var(--radius-md);background:#00000073;justify-content:space-between;align-items:center;padding:10px 14px;display:flex;position:absolute;bottom:14px;left:14px;right:14px}.about__photo-label-name{font-family:var(--font-sans);color:#fff;font-size:13px;font-weight:600}.about__photo-label-role{font-family:var(--font-body);color:#ffffffb3;margin-top:1px;font-size:11px}.about__card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius-lg);transition:border-color var(--transition), transform var(--transition);padding:22px 24px}.about__card:hover{border-color:var(--accent);transform:translateY(-1px)}.about__card-label{letter-spacing:.13em;text-transform:uppercase;color:var(--text-secondary);margin-bottom:14px;font-size:10.5px;font-weight:700}.about__tags{flex-wrap:wrap;gap:7px;display:flex}.about__tag{border-radius:var(--radius-sm);background:var(--surface);border:1px solid var(--border);font-family:var(--font-sans);color:var(--text);padding:5px 12px;font-size:12.5px;font-weight:500}@media (width<=768px){.about__grid{grid-template-columns:1fr;gap:36px}.about__photo-frame{height:360px}}.skills__heading{font-family:var(--font-sans);letter-spacing:-.03em;color:var(--text);margin-bottom:48px;font-size:clamp(26px,4vw,40px);font-weight:800;line-height:1.1}.skills__marquee{flex-direction:column;gap:0;display:flex}.skills__marquee-row{width:100%;max-width:100%;overflow:hidden;-webkit-mask-image:linear-gradient(90deg,#0000,#000 6% 94%,#0000);mask-image:linear-gradient(90deg,#0000,#000 6% 94%,#0000)}.skills__marquee-track{gap:18px;width:max-content;animation:34s linear infinite skills-marquee-left;display:flex}.skills__marquee-row:hover .skills__marquee-track{animation-play-state:paused}.skills__marquee-pill{background:var(--card);border:1px solid var(--border);font-family:var(--font-sans);color:var(--text);white-space:nowrap;transition:border-color var(--transition), color var(--transition), transform var(--transition);border-radius:999px;align-items:center;gap:12px;padding:20px 32px;font-size:17px;font-weight:600;display:inline-flex;box-shadow:0 4px 14px #2d29260d}.skills__marquee-pill:hover{border-color:var(--accent);transform:translateY(-2px)}.skills__marquee-logo{flex-shrink:0;width:24px;height:24px;display:inline-block;-webkit-mask-position:50%;mask-position:50%;-webkit-mask-size:contain;mask-size:contain;-webkit-mask-repeat:no-repeat;mask-repeat:no-repeat}@keyframes skills-marquee-left{0%{transform:translate(0)}to{transform:translate(-50%)}}@media (width<=640px){.skills__marquee-pill{gap:10px;padding:14px 22px;font-size:15px}.skills__marquee-logo{width:20px;height:20px}}@media (prefers-reduced-motion:reduce){.skills__marquee-track{animation:none}}.projects__header{flex-wrap:wrap;justify-content:space-between;align-items:flex-end;gap:16px;margin-bottom:56px;display:flex}.projects__heading{font-family:var(--font-sans);letter-spacing:-.03em;color:var(--text);font-size:clamp(26px,4vw,40px);font-weight:800;line-height:1.1}.projects__all-link{font-family:var(--font-sans);color:var(--accent);transition:gap var(--transition), color var(--transition);white-space:nowrap;align-items:center;gap:5px;font-size:13.5px;font-weight:600;display:inline-flex}.projects__all-link:hover{color:var(--accent-hover);gap:9px}.projects__list{flex-direction:column;gap:20px;display:flex}.project-card{border:1px solid var(--border);border-radius:var(--radius-xl);background:var(--card);min-height:360px;transition:box-shadow var(--transition), transform var(--transition), border-color var(--transition);grid-template-columns:1fr 1fr;display:grid;overflow:hidden}.project-card:hover{border-color:var(--accent);transform:translateY(-2px);box-shadow:0 10px 40px #00000017}.project-card--flipped .project-card__content{border-left:1px solid var(--border);border-right:none;order:2}.project-card--flipped .project-card__visual{order:1}.project-card__content{border-right:1px solid var(--border);flex-direction:column;padding:40px 44px;display:flex}.project-card__meta{align-items:center;gap:10px;margin-bottom:14px;display:flex}.project-card__symbol{font-size:26px;line-height:1}.project-card__eyebrow{font-family:var(--font-sans);letter-spacing:.13em;text-transform:uppercase;color:var(--text-secondary);font-size:10.5px;font-weight:700}.project-card__title{font-family:var(--font-sans);letter-spacing:-.02em;color:var(--text);margin-bottom:4px;font-size:22px;font-weight:800;line-height:1.2}.project-card__tagline{font-family:var(--font-body);color:var(--text-secondary);margin-bottom:22px;font-size:13.5px;font-style:italic}.project-card__section-label{letter-spacing:.1em;text-transform:uppercase;color:var(--text-secondary);margin-bottom:5px;font-size:10.5px;font-weight:700}.project-card__text{font-family:var(--font-body);color:var(--text-secondary);margin-bottom:14px;font-size:13.5px;line-height:1.7}.project-card__tags{flex-wrap:wrap;gap:6px;margin-top:auto;padding-top:16px;display:flex}.project-card__tag{border-radius:var(--radius-sm);background:var(--surface);border:1px solid var(--border);font-family:var(--font-sans);color:var(--text-secondary);padding:3px 10px;font-size:11.5px;font-weight:500}.project-card__visual{flex-direction:column;display:flex}.project-card__image-area{background:var(--surface);flex:1;min-height:200px;position:relative;overflow:hidden}.project-card__image-area img{object-fit:cover;object-position:top left;width:100%;height:100%;transition:transform .4s}.project-card:hover .project-card__image-area img{transform:scale(1.02)}.project-card__image-placeholder{flex-direction:column;justify-content:center;align-items:center;gap:14px;width:100%;height:100%;min-height:200px;padding:24px;display:flex}.project-card__placeholder-symbol{opacity:.25;font-size:56px;line-height:1}.project-card__placeholder-hint{font-family:var(--font-sans);color:var(--text-secondary);letter-spacing:.08em;text-transform:uppercase;text-align:center;opacity:.7;font-size:11px;font-weight:600}.project-card__bottom{border-top:1px solid var(--border);flex-direction:column;padding:16px 20px;display:flex}.project-card__links{gap:8px;display:flex}.project-card__link{text-align:center;border-radius:var(--radius-md);font-family:var(--font-sans);border:1.5px solid var(--border);color:var(--text);background:var(--card);transition:border-color var(--transition), color var(--transition);cursor:pointer;flex:1;padding:9px 12px;font-size:12.5px;font-weight:600}.project-card__link:hover{border-color:var(--accent);color:var(--accent)}.project-card__link--primary{background:var(--accent);border-color:var(--accent);color:#fff}.project-card__link--primary:hover{background:var(--accent-hover);border-color:var(--accent-hover);color:#fff}@media (width<=900px){.project-card{min-height:unset;grid-template-columns:1fr}.project-card__content{border-top:1px solid var(--border);padding:28px;border-left:none!important;border-right:none!important;order:2!important}.project-card__visual{order:1!important}.project-card__image-area{height:220px;min-height:unset}}@media (width<=480px){.project-card__content{padding:22px 20px}.project-card__image-area{height:180px}}.certs__heading{font-family:var(--font-sans);letter-spacing:-.03em;color:var(--text);margin-bottom:36px;font-size:clamp(26px,4vw,40px);font-weight:800;line-height:1.1}.certs__grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:12px;display:grid}.cert-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius-md);transition:border-color var(--transition), transform var(--transition), box-shadow var(--transition);padding:20px;text-decoration:none;display:block}.cert-card:hover{border-color:var(--accent);transform:translateY(-2px);box-shadow:0 10px 24px #2d292612}.cert-card:hover .cert-card__view{opacity:1}.cert-card__dot{background:var(--burgundy);border-radius:50%;width:7px;height:7px;margin-bottom:12px}.cert-card__title{font-family:var(--font-sans);color:var(--text);letter-spacing:-.01em;margin-bottom:4px;font-size:13.5px;font-weight:600}.cert-card__issuer{font-family:var(--font-body);color:var(--text-secondary);font-size:12px}.cert-card__view{font-family:var(--font-sans);color:var(--accent);opacity:0;transition:opacity var(--transition);margin-top:12px;font-size:11.5px;font-weight:600;display:block}.education__heading{font-family:var(--font-sans);letter-spacing:-.03em;color:var(--text);margin-bottom:48px;font-size:clamp(26px,4vw,40px);font-weight:800;line-height:1.1}.education__grid{grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:16px;display:grid}.edu-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius-lg);transition:transform var(--transition), border-color var(--transition), box-shadow var(--transition);padding:30px;position:relative;overflow:hidden}.edu-card:hover{border-color:var(--accent);transform:translateY(-2px);box-shadow:0 8px 24px #00000012}.edu-card__current-badge{border-radius:var(--radius-pill);color:var(--accent);font-size:10.5px;font-weight:600;font-family:var(--font-sans);letter-spacing:.05em;background:#b552391a;border:1px solid #b5523938;padding:3px 10px;position:absolute;top:14px;right:14px}.edu-card__score{font-family:var(--font-sans);color:var(--accent);letter-spacing:-.02em;margin-bottom:4px;font-size:38px;font-weight:800;line-height:1}.edu-card__period{font-family:var(--font-body);color:var(--text-secondary);margin-bottom:20px;font-size:12px}.edu-card__school{font-family:var(--font-sans);color:var(--text);letter-spacing:-.01em;margin-bottom:4px;font-size:15px;font-weight:700}.edu-card__degree{font-family:var(--font-body);color:var(--text-secondary);font-size:12.5px}.contact__inner{max-width:700px}.contact__heading{font-family:var(--font-sans);letter-spacing:-.04em;color:var(--text);margin-bottom:20px;font-size:clamp(32px,5vw,60px);font-weight:800;line-height:1.05}.contact__heading-accent{color:var(--accent)}.contact__intro{font-family:var(--font-body);color:var(--text-secondary);max-width:460px;margin-bottom:40px;font-size:15.5px;line-height:1.8}.contact__email-btn{border-radius:var(--radius-md);background:var(--accent);color:#fff;font-family:var(--font-sans);letter-spacing:.01em;transition:background var(--transition), transform var(--transition);cursor:pointer;border:none;align-items:center;gap:12px;margin-bottom:48px;padding:16px 32px;font-size:14.5px;font-weight:600;text-decoration:none;display:inline-flex}.contact__email-btn:hover{background:var(--accent-hover);transform:translateY(-1px)}.contact__divider{border-top:1px solid var(--border);padding-top:32px}.contact__links-label{font-family:var(--font-sans);letter-spacing:.12em;text-transform:uppercase;color:var(--text-secondary);margin-bottom:16px;font-size:11px;font-weight:700}.contact__links{flex-wrap:wrap;gap:12px;display:flex}.contact__link-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);min-width:140px;transition:border-color var(--transition), transform var(--transition);flex-direction:column;padding:14px 20px;text-decoration:none;display:flex}.contact__link-card:hover{border-color:var(--accent);transform:translateY(-2px)}.contact__link-name{font-family:var(--font-sans);color:var(--text);margin-bottom:2px;font-size:14px;font-weight:600}.contact__link-handle{font-family:var(--font-body);color:var(--text-secondary);font-size:12px}.footer{border-top:1px solid var(--border);background:var(--surface);padding:24px 0}.footer__inner{flex-wrap:wrap;justify-content:space-evenly;align-items:center;gap:12px;display:flex}.footer__copy{font-family:var(--font-sans);color:var(--text-secondary);font-size:13px}.footer__built{font-family:var(--font-body);color:var(--text-secondary);font-size:13px}.section-label{align-items:center;gap:12px;margin-bottom:44px;display:flex}.section-label__bar{background:var(--burgundy);border-radius:2px;flex-shrink:0;width:3px;height:20px}.section-label__text{font-family:var(--font-sans);letter-spacing:.14em;text-transform:uppercase;color:var(--text-secondary);font-size:11px;font-weight:700}
