*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg:#f4f4f5;--bg-card:#fff;--bg-card-hover:#fafafa;--border:#e4e4e7;--text:#18181b;--text-muted:#52525b;--text-subtle:#71717a;--accent:#4f46e5;--accent-hover:#6366f1;--accent-faint:#4f46e514;--nav-bg:#f4f4f5e6;--font:"Inter", system-ui, -apple-system, sans-serif;--radius:12px;--radius-sm:8px;--max-w:920px;--nav-h:60px;--shadow:0 4px 24px #00000014}[data-theme=dark]{--bg:#0f0f11;--bg-card:#18181b;--bg-card-hover:#1f1f23;--border:#27272a;--text:#e4e4e7;--text-muted:#71717a;--text-subtle:#52525b;--accent:#6366f1;--accent-hover:#818cf8;--accent-faint:#6366f11f;--nav-bg:#0f0f11e6;--shadow:0 4px 24px #0000004d}html{scroll-behavior:smooth;scroll-padding-top:var(--nav-h)}body{font-family:var(--font);background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;line-height:1.6;transition:background .2s,color .2s}a{color:inherit;text-decoration:none}ul{list-style:none}img{max-width:100%;display:block}.nav{z-index:100;flex-wrap:wrap;align-items:center;padding:0 1.25rem;transition:background .2s,border-color .2s;display:flex;position:fixed;top:0;left:0;right:0}.nav--scrolled,.nav--open{background:var(--nav-bg);-webkit-backdrop-filter:blur(14px);border-bottom:1px solid var(--border)}.nav__logo{height:var(--nav-h);color:var(--accent);letter-spacing:-.02em;flex:1;align-items:center;font-size:1.1rem;font-weight:800;display:flex}.nav__menu{display:none}.nav__actions{height:var(--nav-h);align-items:center;gap:.25rem;display:flex}.nav__icon-btn{width:36px;height:36px;color:var(--text-muted);border-radius:var(--radius-sm);cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;transition:color .15s,background .15s;display:flex}.nav__icon-btn:hover{color:var(--text);background:var(--accent-faint)}.nav--open .nav__menu{border-top:1px solid var(--border);width:100%;padding:.5rem 0 1rem;display:block}.nav__links{flex-direction:column;display:flex}.nav__links a{color:var(--text-muted);border-bottom:1px solid var(--border);padding:.75rem 0;font-size:1rem;font-weight:500;transition:color .15s;display:block}.nav__links a:hover{color:var(--text)}@media (width>=680px){.nav{flex-wrap:nowrap}.nav__logo{flex:none}.nav__menu{border:none;flex:1;justify-content:center;align-items:center;width:auto;padding:0;display:flex!important}.nav__links{flex-direction:row;gap:2rem}.nav__links a{border:none;padding:0;font-size:.9rem}.nav__hamburger{display:none}}.section{padding:5rem 1.25rem}.section__inner{max-width:var(--max-w);margin:0 auto}.section__title{letter-spacing:-.03em;margin-bottom:2.5rem;font-size:clamp(1.6rem,5vw,2.25rem);font-weight:700}.section__title:after{content:".";color:var(--accent)}.hero{min-height:100svh;padding:calc(var(--nav-h) + 3rem) 1.25rem 4rem;align-items:center;display:flex}.hero__content{max-width:var(--max-w);width:100%;margin:0 auto}.hero__greeting{color:var(--accent);letter-spacing:.02em;align-items:center;gap:.4rem;margin-bottom:.75rem;font-size:.95rem;font-weight:600;display:inline-flex}.hero__name{letter-spacing:-.04em;margin-bottom:.5rem;font-size:clamp(2.75rem,10vw,5.5rem);font-weight:800;line-height:1.03}.hero__title{color:var(--text-muted);margin-bottom:1.25rem;font-size:clamp(1.1rem,4vw,1.75rem);font-weight:400}.hero__tagline{max-width:480px;color:var(--text-muted);margin-bottom:2.25rem;font-size:1rem;line-height:1.65}.hero__cta{flex-wrap:wrap;gap:.75rem;display:flex}.btn{border-radius:var(--radius-sm);cursor:pointer;white-space:nowrap;border:1px solid #0000;align-items:center;gap:.4rem;padding:.6rem 1.35rem;font-size:.9rem;font-weight:500;transition:background .15s,color .15s,border-color .15s,opacity .15s;display:inline-flex}.btn--primary{background:var(--accent);color:#fff}.btn--primary:hover{background:var(--accent-hover)}.btn--outline{border-color:var(--border);color:var(--text)}.btn--outline:hover{border-color:var(--text-muted);background:var(--accent-faint)}.btn--lg{padding:.8rem 1.75rem;font-size:1rem}.about__grid{flex-direction:column;gap:2.5rem;display:flex}.about__text p{color:var(--text-muted);line-height:1.7}.about__text p+p{margin-top:1rem}.about__skills h3{text-transform:uppercase;letter-spacing:.1em;color:var(--text-subtle);margin-bottom:1rem;font-size:.78rem}.skills{flex-wrap:wrap;gap:.5rem;display:flex}.skills__tag{border:1px solid var(--border);color:var(--text-muted);background:var(--bg-card);border-radius:999px;padding:.3rem .85rem;font-size:.83rem;transition:border-color .15s,color .15s}.skills__tag:hover{border-color:var(--accent);color:var(--accent)}@media (width>=680px){.about__grid{grid-template-columns:1fr 1fr;gap:3rem;display:grid}}.projects__grid{grid-template-columns:1fr;gap:1.25rem;display:grid}@media (width>=520px){.projects__grid{grid-template-columns:repeat(2,1fr)}}@media (width>=860px){.projects__grid{grid-template-columns:repeat(3,1fr)}}.card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);flex-direction:column;transition:transform .2s,box-shadow .2s,border-color .2s;display:flex;overflow:hidden}.card:hover{border-color:var(--accent);transform:translateY(-3px);box-shadow:0 8px 32px #6366f126}.card__header{background:var(--card-accent);flex-shrink:0;height:110px;position:relative;overflow:hidden}.card__header-img{object-fit:cover;object-position:top;z-index:1;width:100%;height:100%;display:block;position:relative}.card__header:before,.card__header:after{content:"";background:#ffffff1f;border-radius:50%;position:absolute}.card__header:before{width:90px;height:90px;bottom:-28px;right:-18px}.card__header:after{width:55px;height:55px;top:-15px;right:55px}.card__body{flex-direction:column;flex:1;gap:.6rem;padding:1.25rem 1.25rem .75rem;display:flex}.card__title{letter-spacing:-.01em;font-size:1rem;font-weight:650}.card__desc{color:var(--text-muted);flex:1;font-size:.875rem;line-height:1.6}.card__tags{flex-wrap:wrap;gap:.35rem;padding-top:.25rem;display:flex}.card__tags li{color:var(--accent);background:var(--accent-faint);border-radius:999px;padding:.2rem .6rem;font-size:.72rem;font-weight:500}.card__links{border-top:1px solid var(--border);align-items:center;gap:1rem;padding:.9rem 1.25rem;display:flex}.card__link{color:var(--text-muted);align-items:center;gap:.35rem;font-size:.82rem;font-weight:500;transition:color .15s;display:inline-flex}.card__link:hover{color:var(--accent)}.contact__split{flex-direction:column;gap:3rem;display:flex}@media (width>=720px){.contact__split{grid-template-columns:1fr 1fr;align-items:start;gap:4rem;display:grid}}.contact__info{flex-direction:column;gap:0;display:flex}.contact__sub{color:var(--text-muted);margin-bottom:1.75rem;line-height:1.7}.contact__email{color:var(--text-muted);word-break:break-all;align-items:center;gap:.5rem;margin-bottom:1.5rem;font-size:.9rem;font-weight:500;transition:color .15s;display:inline-flex}.contact__email:hover{color:var(--accent)}.contact__social{color:var(--text-subtle);align-items:center;gap:.75rem;font-size:.9rem;display:flex}.contact__social a{color:var(--text-muted);transition:color .15s}.contact__social a:hover{color:var(--accent)}.contact__form-wrap{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:1.75rem}.form{flex-direction:column;gap:1.1rem;display:flex}.form__row{grid-template-columns:1fr 1fr;gap:1rem;display:grid}@media (width<=480px){.form__row{grid-template-columns:1fr}}.form__group{flex-direction:column;gap:.4rem;display:flex}.form__label{color:var(--text-muted);letter-spacing:.03em;font-size:.8rem;font-weight:600}.form__input{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);width:100%;color:var(--text);font-family:var(--font);-webkit-appearance:none;outline:none;padding:.65rem .9rem;font-size:.9rem;transition:border-color .15s,box-shadow .15s}.form__input::placeholder{color:var(--text-subtle)}.form__input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-faint)}.form__input:disabled{opacity:.5;cursor:not-allowed}.form__textarea{resize:vertical;min-height:120px}.form__error{color:#f87171;border-radius:var(--radius-sm);background:#f8717114;border:1px solid #f8717133;padding:.6rem .85rem;font-size:.82rem}.btn--full{justify-content:center;width:100%}.form__success{text-align:center;flex-direction:column;align-items:center;gap:.75rem;padding:3rem 1.5rem;display:flex}.form__success h3{letter-spacing:-.02em;font-size:1.2rem;font-weight:700}.form__success p{color:var(--text-muted);margin-bottom:.5rem;font-size:.9rem}.form__success-icon{color:#4ade80;background:#4ade801a;border:1px solid #4ade804d;border-radius:50%;justify-content:center;align-items:center;width:52px;height:52px;margin-bottom:.25rem;font-size:1.4rem;display:flex}.footer{border-top:1px solid var(--border);flex-direction:column;align-items:center;gap:.75rem;padding:1.75rem 2rem;display:flex}.footer__copy{color:var(--text-subtle);font-size:.82rem}.theme-toggle{border:1px solid var(--border);color:var(--text-subtle);font-family:var(--font);cursor:pointer;background:0 0;border-radius:999px;align-items:center;gap:.4rem;padding:.35rem .85rem;font-size:.78rem;transition:color .15s,border-color .15s,background .15s;display:inline-flex}.theme-toggle:hover{color:var(--text);border-color:var(--text-muted);background:var(--accent-faint)}.back-to-top{background:var(--accent);color:#fff;cursor:pointer;opacity:0;pointer-events:none;z-index:90;border:none;border-radius:50%;justify-content:center;align-items:center;width:44px;height:44px;transition:opacity .25s,transform .25s,background .15s;display:flex;position:fixed;bottom:2rem;right:2rem;transform:translateY(12px);box-shadow:0 4px 16px #6366f166}.back-to-top--visible{opacity:1;pointer-events:auto;transform:translateY(0)}.back-to-top:hover{background:var(--accent-hover)}@media (prefers-reduced-motion:reduce){*{transition:none!important;animation:none!important}}
