html,body,#root{margin:0;padding:0;width:100%;min-height:100%}html,body{overflow-x:hidden}body{font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:#fff;color:#e5e7eb;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}img,picture,video,canvas,svg{display:block;max-width:100%}input,button,textarea,select{font:inherit}p,h1,h2,h3,h4,h5,h6{overflow-wrap:break-word}:root{--header-height: clamp(52px, 7vw, 64px);--content-width: min(92vw, 900px);--projects-width: min(94vw, 1100px);--space-xs: clamp(.4rem, .8vw, .6rem);--space-sm: clamp(.75rem, 1.2vw, 1rem);--space-md: clamp(1rem, 2vw, 1.5rem);--space-lg: clamp(1.5rem, 3vw, 2rem);--space-xl: clamp(2rem, 5vw, 4rem);--title-xl: clamp(2rem, 6vw, 5rem);--title-lg: clamp(1.8rem, 4.5vw, 3rem);--title-md: clamp(1.15rem, 2.5vw, 1.75rem);--body-md: clamp(.9rem, 1.5vw, 1rem);--body-sm: clamp(.8rem, 1.2vw, .95rem);--avatar-size: clamp(130px, 22vw, 220px);--social-size: clamp(38px, 6vw, 50px);--social-icon: clamp(1rem, 2.5vw, 1.5rem);--tag-size: clamp(.65rem, 1.2vw, .7rem)}*,*:before,*:after{box-sizing:border-box}html{scroll-behavior:smooth}html,body{margin:0;padding:0;width:100%;overflow-x:hidden}body{font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:#fff;color:#e5e7eb}img{max-width:100%;height:auto}a{color:inherit;text-decoration:none}.page{min-height:100vh;padding-top:var(--header-height)}.site-header{position:fixed;top:0;left:0;right:0;z-index:1000;height:var(--header-height);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#666a61;border-bottom:1px solid #666a61}.site-header__inner{max-width:var(--content-width);margin:0 auto;height:100%;padding:0 var(--space-md);font-weight:800;display:flex;align-items:center;justify-content:center}.site-header__nav{display:flex;gap:clamp(.35rem,1.5vw,1.5rem);flex-wrap:wrap;justify-content:center}.site-header__link{font-size:clamp(.72rem,1.5vw,.95rem);padding:clamp(.22rem,.8vw,.35rem) clamp(.45rem,1.2vw,.75rem);border-radius:999px;transition:background-color .15s ease,color .15s ease;color:#e5e7eb;white-space:nowrap}.site-header__link.active{color:#ffd772;font-weight:800;transition:color .25s ease-in-out}.section{scroll-margin-top:calc(var(--header-height))}.home-section{position:relative;width:100%;min-height:calc(100vh - var(--header-height));background-size:cover;background-position:center;background-repeat:no-repeat;color:#fff;display:flex;align-items:flex-start;padding-top:clamp(3rem,10vw,8rem)}.home-section__inner{max-width:var(--content-width);margin:0 auto;padding:clamp(1.5rem,4vw,3rem) var(--space-md) clamp(2rem,5vw,4rem);text-align:center}.home-section:before{content:"";position:absolute;inset:0;background:#0000000d;z-index:0}.home-section__inner>*{position:relative;z-index:1}.home-section__inner h1{font-size:var(--title-xl);font-weight:600;margin:0;color:#fff;text-shadow:0 1px 4px rgba(0,0,0,.35);line-height:1.05}.home-subtitle{margin-top:var(--space-sm);font-size:var(--title-md);font-weight:600;color:#fff;text-shadow:0 1px 4px rgba(0,0,0,.35)}.home-socials{margin-top:var(--space-lg);display:flex;justify-content:center;gap:clamp(.75rem,2vw,1.5rem)}.home-socials__link{display:flex;align-items:center;justify-content:center;width:var(--social-size);height:var(--social-size);font-size:var(--social-icon);color:#fff;border:2px solid rgba(255,255,255,.4);border-radius:50%;background:#00000040;transition:all .25s ease;flex-shrink:0}.home-socials__link:hover{color:#ffd772;border-color:#ffd772;background:#0006;transform:translateY(-3px) scale(1.05)}button.home-socials__link{cursor:pointer;border:none;outline:none;font:inherit}.copy-popup{position:absolute;top:70%;left:50%;transform:translate(-50%);background:#ffd772;color:#000;padding:.5rem 1rem;border-radius:6px;font-size:clamp(.75rem,1.5vw,.9rem);font-weight:600;box-shadow:0 5px 15px #00000040;animation:fadeInOut 2s ease forwards;white-space:nowrap}@keyframes fadeInOut{0%{opacity:0;transform:translate(-50%,10px)}20%{opacity:1;transform:translate(-50%)}80%{opacity:1}to{opacity:0;transform:translate(-50%,10px)}}.about-section{position:relative;width:100%;background:#3d3f3a;min-height:calc(100vh - var(--header-height));display:flex;align-items:center;padding:clamp(2rem,5vw,4rem) 0}.about-section__inner{max-width:var(--content-width);margin:0 auto;padding:clamp(1.5rem,4vw,3rem) var(--space-md) clamp(2rem,5vw,4rem)}.about-title{text-align:center;font-size:var(--title-lg);font-weight:700;margin-bottom:clamp(2rem,5vw,5rem);color:#fff}.about-avatar{width:var(--avatar-size);height:var(--avatar-size);border-radius:50%;object-fit:cover;margin:0 auto var(--space-lg) auto;display:block;border:4px solid #ffd772;box-shadow:0 8px 20px #00000040}.about-description{max-width:min(100%,700px);margin:0 auto;padding:clamp(1rem,2.5vw,1.5rem) clamp(1rem,3vw,2rem);background:#00000040;border-radius:10px;line-height:1.6;font-size:var(--body-md)}.about-columns{display:flex;gap:clamp(.75rem,2vw,2rem);margin-top:var(--space-lg);justify-content:center;align-items:stretch}.about-box{flex:1 1 0;min-width:0;max-width:350px;background:#00000040;padding:clamp(1rem,2.5vw,1.5rem);border-radius:10px;text-align:left}.about-box h3{color:#ffd772;text-align:center;margin-top:0;margin-bottom:.75rem;font-size:clamp(1rem,2vw,1.2rem)}.about-box ul{list-style:none;padding:0;margin:0}.about-box li{margin-bottom:.5rem;font-size:var(--body-sm);line-height:1.45;word-break:break-word}.info-label{font-weight:700;color:#fff;margin-right:6px}.about-work-experience{margin:var(--space-lg) auto 0;max-width:100%;background:#00000040;padding:clamp(1rem,2.5vw,1.75rem);border-radius:10px;text-align:left}.about-work-experience h3{color:#ffd772;text-align:center;margin-top:0;margin-bottom:1.5rem;font-size:clamp(1rem,2vw,1.2rem)}.experience-item+.experience-item{margin-top:1.25rem;padding-top:1.25rem;border-top:1px solid rgba(255,255,255,.15)}.experience-header{display:flex;justify-content:space-between;gap:1rem;margin-bottom:.75rem;flex-wrap:wrap}.experience-role,.experience-date{font-size:var(--body-sm)}.experience-role{font-weight:700;color:#fff}.experience-date{color:#fff;font-weight:600}.experience-item ul{margin:0;padding-left:1.15rem}.experience-item li{margin-bottom:.5rem;line-height:1.6;font-size:var(--body-sm)}.projects-section{width:100%;min-height:calc(100vh - var(--header-height));color:#111827;background:#e5e7eb;display:flex;align-items:center;padding:clamp(2rem,5vw,4rem) 0}.projects-section__inner{max-width:var(--projects-width);margin:0 auto;padding:clamp(1.5rem,4vw,3rem) var(--space-md) clamp(2rem,5vw,4rem)}.projects-title{text-align:center;font-size:var(--title-lg);font-weight:700;margin-bottom:clamp(2rem,5vw,5rem);color:#3d3f3a}.projects-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:clamp(1rem,2.5vw,2rem);max-width:800px;margin:2rem auto 0}.project-card{display:flex;flex-direction:column;min-width:0}.project-card__title{margin:0 0 1rem;text-align:center;font-size:clamp(1rem,2.4vw,1.75rem);font-weight:800;color:#3d3f3a;letter-spacing:.5px;line-height:1.2}.project-card__image-button{width:100%;aspect-ratio:1 / 1;padding:0;border:none;background:transparent;cursor:pointer;border-radius:14px;overflow:hidden;box-shadow:0 8px 22px #00000024;transition:transform .25s ease,box-shadow .25s ease}.project-card__image-button:hover{transform:translateY(-4px);box-shadow:0 12px 28px #0000002e}.project-card__image{width:100%;height:100%;display:block;object-fit:cover;transition:filter .25s ease,transform .25s ease}.project-card__image-button:hover .project-card__image{filter:brightness(.88);transform:scale(1.01)}.project-card__tags{display:flex;flex-wrap:wrap;justify-content:center;gap:.4rem;margin-top:.8rem}.project-tag{font-size:var(--tag-size);font-weight:600;padding:.3rem .55rem;border-radius:999px;background:#00000014;color:#3d3f3a;transition:all .2s ease}.project-tag:hover{background:#ffd772;color:#000}.project-modal-overlay{position:fixed;inset:0;background:#111827b8;display:flex;align-items:center;justify-content:center;padding:1rem;z-index:1000}.project-modal{position:relative;width:min(92vw,680px);max-height:90vh;aspect-ratio:1 / 1;background:#f6f7f8;border-radius:18px;overflow:hidden;box-shadow:0 20px 50px #00000047;display:flex;flex-direction:column}.project-modal__close{position:absolute;top:.75rem;right:.75rem;width:clamp(34px,6vw,42px);height:clamp(34px,6vw,42px);border:none;border-radius:50%;background:#111827c7;color:#fff;display:flex;align-items:center;justify-content:center;font-size:clamp(.85rem,2vw,1rem);cursor:pointer;z-index:2;transition:transform .2s ease,background .2s ease}.project-modal__close:hover{transform:scale(1.06);background:#111827eb}.project-modal__image-wrap{height:70%;background:#d9dde2;display:flex;align-items:center;justify-content:center}.project-modal__image{width:100%;height:100%;object-fit:contain;display:block}.project-modal__footer{height:30%;padding:clamp(.9rem,2.5vw,1.2rem) clamp(1rem,2.8vw,1.35rem) clamp(1rem,2.8vw,1.3rem);background:#3d3f3a;color:#fff;overflow-y:auto}.project-modal__title{margin:0 0 .65rem;font-size:clamp(1rem,2.5vw,1.25rem);color:#ffd772}.project-modal__description{margin:0;line-height:1.55;font-size:clamp(.82rem,1.8vw,.96rem)}.contact-section{width:100%;background:#2c2f2a;color:#fff;display:flex;align-items:center;justify-content:center;padding:clamp(2rem,5vw,3rem) 0}.contact-section__inner{max-width:var(--content-width);margin:0 auto;text-align:center;position:relative;padding:0 var(--space-md)}.contact-title{font-size:clamp(1.8rem,4vw,2.5rem);font-weight:800;color:#fff;margin-bottom:2rem;letter-spacing:1px}.resume-button{display:inline-block;margin-bottom:2rem;padding:clamp(.55rem,1.5vw,.6rem) clamp(1rem,2.5vw,1.4rem);border-radius:999px;font-weight:700;font-size:clamp(.82rem,1.6vw,.95rem);background:#fff;color:#000;transition:all .25s ease}.resume-button:hover{background:#fff;transform:translateY(-2px)}.contact-socials{display:flex;justify-content:center;gap:clamp(.75rem,2vw,1.2rem)}.contact-socials__link{width:clamp(38px,5.5vw,45px);height:clamp(38px,5.5vw,45px);display:flex;align-items:center;justify-content:center;font-size:clamp(1rem,2vw,1.3rem);border-radius:50%;border:2px solid rgba(255,255,255,.4);color:#fff;background:#00000040;transition:all .25s ease}.contact-socials__link:hover{color:#ffd772;border-color:#ffd772;transform:translateY(-2px)}button.contact-socials__link{border:none;cursor:pointer}.contact-popup{top:85%}@media(max-width:560px){.about-columns{flex-direction:column;align-items:stretch}.about-box{max-width:100%;width:100%}.projects-grid{grid-template-columns:1fr}.experience-header{flex-direction:column;align-items:flex-start}.project-modal{width:94vw;aspect-ratio:auto;max-height:88vh}.project-modal__image-wrap{height:55%}.project-modal__footer{height:45%}}
