@import "https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&display=swap";:root{--color-background:#f7f8fa;--color-surface:#fff;--color-text:#1f2937;--color-text-secondary:#4b5563;--color-text-muted:#6b7280;--color-primary:#2563eb;--color-primary-hover:#1d4ed8;--color-border:#e5e7eb;--color-border-strong:#d1d5db;--color-tag-background:#eff6ff;--color-tag-text:#1d4ed8;--color-tag-neutral-background:#f3f4f6;--color-tag-neutral-text:#374151;--shadow-soft:0 4px 20px #0f172a0f;--shadow-card-hover:0 10px 30px #0f172a14;--shadow-modal:0 20px 60px #0f172a40;--radius-card:18px;--radius-large:24px;--radius-pill:999px;--container-width:1200px;--section-spacing:6rem;--section-spacing-mobile:4.5rem;--transition-fast:.2s ease}*,:before,:after{box-sizing:border-box}html{scroll-behavior:smooth}body,h1,h2,h3,h4,p,ul,ol{margin:0}ul,ol{padding:0;list-style:none}body{background-color:var(--color-background);min-width:320px;color:var(--color-text);text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;font-family:Inter,sans-serif;line-height:1.6}img,picture,svg{max-width:100%;display:block}a{color:inherit;text-decoration:none}button,input,textarea,select{font:inherit}button{background:0 0;border:none}main{width:100%}section{scroll-margin-top:110px}:focus-visible{outline:2px solid var(--color-primary);outline-offset:3px}::selection{background-color:#2563eb29}.container{width:min(100% - 2rem, var(--container-width));margin-inline:auto}.section-eyebrow{text-transform:uppercase;letter-spacing:.08em;color:var(--color-primary);margin-bottom:.75rem;font-size:.95rem;font-weight:700}.section-title{letter-spacing:-.03em;color:var(--color-text);margin-bottom:1rem;font-size:clamp(2rem,4vw,3rem);line-height:1.15}.section-intro{max-width:62ch;color:var(--color-text-secondary);font-size:1.02rem}.surface-card{background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-card);box-shadow:var(--shadow-soft)}.intro,.about,.skills,.projects,.contact{padding:var(--section-spacing) 0}.about,.skills,.projects,.contact{position:relative}.about__container,.skills__container,.projects__container,.contact__container,.header__container,.intro__container,.footer__container{width:min(100% - 2rem, var(--container-width));margin-inline:auto}h1,h2,h3,h4{letter-spacing:-.02em;line-height:1.15}p{color:var(--color-text-secondary)}a,button{transition:color var(--transition-fast), background-color var(--transition-fast), border-color var(--transition-fast), transform var(--transition-fast), box-shadow var(--transition-fast)}@media (width<=768px){.intro,.about,.skills,.projects,.contact{padding:var(--section-spacing-mobile) 0}.section-title{font-size:clamp(1.8rem,8vw,2.5rem)}.section-intro{font-size:1rem}}.header{z-index:1000;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);border-bottom:1px solid var(--color-border);background-color:#f7f8fad1;position:sticky;top:0}.header__container{justify-content:space-between;align-items:center;gap:2rem;min-height:78px;display:flex}.header__logo{letter-spacing:-.02em;color:var(--color-text);font-size:1.05rem;font-weight:800}.header__logo:hover,.header__logo:focus-visible{color:var(--color-primary)}.header__nav{align-items:center;display:flex}.header__list{align-items:center;gap:2rem;margin:0;padding:0;list-style:none;display:flex}.header__list a{min-height:44px;color:var(--color-text-secondary);align-items:center;font-size:.95rem;font-weight:500;display:inline-flex;position:relative}.header__list a:after{content:"";background-color:var(--color-primary);transform-origin:0;width:100%;height:2px;transition:transform var(--transition-fast);position:absolute;bottom:.45rem;left:0;transform:scaleX(0)}.header__list a:hover,.header__list a:focus-visible{color:var(--color-primary)}.header__list a:hover:after,.header__list a:focus-visible:after{transform:scaleX(1)}.header__list a:focus-visible{border-radius:4px}@media (width<=768px){.header__container{flex-direction:column;justify-content:center;gap:.75rem;min-height:auto;padding:1rem 0}.header__list{flex-wrap:wrap;justify-content:center;gap:.5rem 1.25rem}}.intro{background:linear-gradient(#e8f0ff 0%,#f7f8fa 100%);align-items:center;min-height:calc(100vh - 78px);padding:5.5rem 0 5rem;display:flex;position:relative;overflow:hidden}.intro__container{z-index:1;position:relative}.intro__content{max-width:760px}.intro__eyebrow{text-transform:uppercase;letter-spacing:.08em;color:var(--color-primary);margin-bottom:1rem;font-size:.95rem;font-weight:700}.intro__title{letter-spacing:-.05em;color:var(--color-text);margin-bottom:1.5rem;font-size:clamp(3rem,6vw,4.8rem);line-height:.98}.intro__title span{color:var(--color-primary)}.intro__text{max-width:56ch;color:var(--color-text-secondary);margin-bottom:2.25rem;font-size:1.08rem}.intro__actions{flex-wrap:wrap;gap:1rem;display:flex}.intro__button{border-radius:var(--radius-pill);min-height:50px;box-shadow:none;border:1px solid #0000;justify-content:center;align-items:center;padding:.9rem 1.4rem;font-size:.98rem;font-weight:700;display:inline-flex}.intro__button:hover{transform:translateY(-2px)}.intro__button--primary{background-color:var(--color-primary);color:#fff;box-shadow:0 10px 25px #2563eb2e}.intro__button--primary:hover{background-color:var(--color-primary-hover)}.intro__button--secondary{background-color:var(--color-surface);color:var(--color-text);border-color:var(--color-border-strong)}.intro__button--secondary:hover{border-color:var(--color-primary);color:var(--color-primary);box-shadow:var(--shadow-soft)}@media (width<=1024px){.intro{min-height:auto;padding:6rem 0 5rem}.intro__title{font-size:clamp(2.8rem,8vw,4.4rem)}}@media (width<=768px){.intro{align-items:flex-start;padding:5rem 0 4.5rem}.intro__content{max-width:100%}.intro__title{font-size:clamp(2.5rem,11vw,3.5rem);line-height:1.02}.intro__text{font-size:1rem}.intro__actions{gap:.85rem}.intro__button{width:100%}}.about{padding:5rem 0}.about__container{width:min(100% - 2rem,1200px);margin-inline:auto}.about__header{max-width:760px;margin-bottom:2.5rem}.about__eyebrow{text-transform:uppercase;letter-spacing:.08em;color:#2563eb;margin-bottom:.75rem;font-size:.95rem;font-weight:600}.about__title{color:#1f2937;font-size:clamp(1.8rem,4vw,2.8rem);line-height:1.2}.about__content{grid-template-columns:1.4fr 1fr;align-items:start;gap:2rem;display:grid}.about__text{gap:1rem;display:grid}.about__text p{color:#4b5563;max-width:65ch;font-size:1rem}.about__highlights{gap:1rem;display:grid}.about__card{background-color:#fff;border:1px solid #e5e7eb;border-radius:16px;padding:1.5rem;box-shadow:0 4px 20px #0f172a0f}.about__card h3{color:#1f2937;margin-bottom:.5rem;font-size:1rem}.about__card p{color:#6b7280;font-size:.95rem}@media (width<=900px){.about__content{grid-template-columns:1fr}.about__text p{max-width:none}}.skills{padding:5rem 0}.skills__container{width:min(100% - 2rem,1200px);margin-inline:auto}.skills__header{max-width:760px;margin-bottom:2.5rem}.skills__eyebrow{text-transform:uppercase;letter-spacing:.08em;color:#2563eb;margin-bottom:.75rem;font-size:.95rem;font-weight:600}.skills__title{color:#1f2937;margin-bottom:1rem;font-size:clamp(1.8rem,4vw,2.8rem);line-height:1.2}.skills__intro{color:#4b5563;max-width:65ch}.skills__grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:1.5rem;display:grid}.skills__card{background-color:#fff;border:1px solid #e5e7eb;border-radius:16px;padding:1.5rem;transition:transform .2s,box-shadow .2s,border-color .2s;box-shadow:0 4px 20px #0f172a0f}.skills__card:hover{box-shadow:var(--shadow-card-hover);transform:translateY(-4px)}.skills__card h3{color:#1f2937;margin-bottom:1rem;font-size:1.1rem}.skills__card ul{flex-wrap:wrap;gap:.75rem;display:flex}.skills__card li{color:#1d4ed8;background-color:#eff6ff;border-radius:999px;padding:.5rem .85rem;font-size:.95rem;font-weight:500}@media (width<=900px){.skills__grid{grid-template-columns:1fr}}.projects{padding:5rem 0}.projects__container{width:min(100% - 2rem,1200px);margin-inline:auto}.projects__header{max-width:760px;margin-bottom:2.5rem}.projects__eyebrow{text-transform:uppercase;letter-spacing:.08em;color:#2563eb;margin-bottom:.75rem;font-size:.95rem;font-weight:600}.projects__title{color:#1f2937;margin-bottom:1rem;font-size:clamp(1.8rem,4vw,2.8rem);line-height:1.2}.projects__intro{color:#4b5563;max-width:65ch}.projects__grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:1.5rem;display:grid}@media (width<=1024px){.projects__grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (width<=768px){.projects__grid{grid-template-columns:1fr}}.project-card{background-color:#fff;border:1px solid #e5e7eb;border-radius:16px;height:100%;transition:transform .2s,box-shadow .2s,border-color .2s;box-shadow:0 4px 20px #0f172a0f}.project-card:hover{box-shadow:var(--shadow-card-hover);transform:translateY(-4px)}.project-card__content{flex-direction:column;height:100%;padding:1.5rem;display:flex}.project-card__category{color:#1d4ed8;background-color:#eff6ff;border-radius:999px;align-self:flex-start;padding:.35rem .75rem;font-size:.875rem;font-weight:600;display:inline-flex}.project-card__title{color:#1f2937;margin-bottom:.75rem;font-size:1.2rem}.project-card__description{color:#4b5563;flex-grow:1;margin-bottom:1.25rem}.project-card__technologies{flex-wrap:wrap;gap:.75rem;margin-bottom:1.5rem;display:flex}.project-card__technologies li{color:#374151;background-color:#f3f4f6;border-radius:999px;padding:.45rem .8rem;font-size:.9rem;font-weight:500}.project-card__actions{flex-wrap:wrap;gap:.75rem;margin-top:auto;display:flex}.project-card__link,.project-card__button{border-radius:999px;min-height:44px;padding:.75rem 1rem;font-size:.95rem;font-weight:600;transition:transform .2s,background-color .2s,border-color .2s,color .2s}.project-card__link{color:#fff;background-color:#2563eb;justify-content:center;align-items:center;display:inline-flex}.project-card__link:hover{background-color:#1d4ed8;transform:translateY(-2px)}.project-card__link:focus-visible{outline-offset:4px;outline:2px solid #2563eb}.project-card__button{color:#1f2937;cursor:pointer;background-color:#fff;border:1px solid #d1d5db}.project-card__button:hover{color:#2563eb;border-color:#2563eb;transform:translateY(-2px)}.project-card__button:focus-visible{outline-offset:4px;outline:2px solid #2563eb}.project-card .project-card__top{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:.75rem;margin-bottom:1rem;display:flex}.project-card .project-card__category{color:#1d4ed8;background-color:#eff6ff;border-radius:999px;align-self:flex-start;padding:.35rem .75rem;font-size:.875rem;font-weight:600;display:inline-flex}.project-card .project-card__status{color:#374151;background-color:#f3f4f6;border-radius:999px;align-self:flex-start;padding:.35rem .75rem;font-size:.8rem;font-weight:600;display:inline-flex}.project-modal{z-index:2000;background-color:#0f172a99;justify-content:center;align-items:center;padding:1.5rem;display:flex;position:fixed;inset:0}.project-modal__content{background-color:#fff;border-radius:24px;width:min(100%,820px);max-height:90vh;padding:2rem;position:relative;overflow-y:auto;box-shadow:0 20px 60px #0f172a40}.project-modal__close{color:#1f2937;cursor:pointer;background-color:#f3f4f6;border:none;border-radius:999px;width:44px;height:44px;font-size:1.5rem;line-height:1;position:absolute;top:1rem;right:1rem}.project-modal__close:hover{background-color:#e5e7eb}.project-modal__close:focus-visible{outline-offset:4px;outline:2px solid #2563eb}.project-modal__category{color:#1d4ed8;background-color:#eff6ff;border-radius:999px;margin-bottom:1rem;padding:.35rem .75rem;font-size:.875rem;font-weight:600;display:inline-flex}.project-modal__title{color:#1f2937;margin-bottom:1rem;padding-right:3rem;font-size:clamp(1.6rem,3vw,2.2rem)}.project-modal__technologies{flex-wrap:wrap;gap:.75rem;margin-bottom:2rem;display:flex}.project-modal__technologies li{color:#374151;background-color:#f3f4f6;border-radius:999px;padding:.45rem .8rem;font-size:.9rem;font-weight:500}.project-modal__sections{gap:1.5rem;margin-bottom:2rem;display:grid}.project-modal__sections section{border-bottom:1px solid #e5e7eb;padding-bottom:1rem}.project-modal__sections h4{color:#1f2937;margin-bottom:.5rem;font-size:1rem}.project-modal__sections p{color:#4b5563}.project-modal__link{color:#fff;background-color:#2563eb;border-radius:999px;justify-content:center;align-items:center;min-height:44px;padding:.8rem 1.2rem;font-weight:600;transition:background-color .2s,transform .2s;display:inline-flex}.project-modal__link:hover{background-color:#1d4ed8;transform:translateY(-2px)}.project-modal__link:focus-visible{outline-offset:4px;outline:2px solid #2563eb}@media (width<=768px){.project-modal{padding:1rem}.project-modal__content{border-radius:20px;padding:1.5rem}}.contact{padding:5rem 0}.contact__container{width:min(100% - 2rem,1200px);margin-inline:auto}.contact__header{max-width:760px;margin-bottom:2.5rem}.contact__eyebrow{text-transform:uppercase;letter-spacing:.08em;color:#2563eb;margin-bottom:.75rem;font-size:.95rem;font-weight:600}.contact__title{color:#1f2937;margin-bottom:1rem;font-size:clamp(1.8rem,4vw,2.8rem);line-height:1.2}.contact__intro{color:#4b5563;max-width:65ch}.contact__grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:1.5rem;display:grid}.contact__card{background-color:#fff;border:1px solid #e5e7eb;border-radius:16px;padding:1.5rem;box-shadow:0 4px 20px #0f172a0f}.contact__card h3{color:#1f2937;margin-bottom:.75rem;font-size:1.1rem}.contact__card p{color:#6b7280;margin-bottom:1rem}.contact__card{transition:transform .2s,box-shadow .2s,border-color .2s}.contact__card:hover{box-shadow:var(--shadow-card-hover);transform:translateY(-4px)}.contact__card a{color:#2563eb;word-break:break-word;font-weight:600}.contact__card a:hover,.contact__card a:focus-visible{color:#1d4ed8}.contact__card a:focus-visible{outline-offset:4px;border-radius:4px;outline:2px solid #2563eb}@media (width<=900px){.contact__grid{grid-template-columns:1fr}}.footer{border-top:1px solid var(--color-border);padding:1.25rem 0 1.5rem}.footer__container{width:min(100% - 2rem, var(--container-width));flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;margin-inline:auto;display:flex}.footer__text{color:var(--color-text-muted);font-size:.95rem}.footer__links{flex-wrap:wrap;align-items:center;gap:1.25rem;margin:0;padding:0;list-style:none;display:flex}.footer__links a{color:var(--color-text-secondary);font-weight:500}.footer__links a:hover,.footer__links a:focus-visible{color:var(--color-primary)}.footer__links a:focus-visible{border-radius:4px}@media (width<=768px){.footer{padding:1.1rem 0 1.35rem}.footer__container{flex-direction:column;align-items:flex-start;gap:.75rem}.footer__links{gap:1rem}}
