@import"https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@300;400;600;700&display=swap";:root{--bg:#0b1020;--card:#0f172a;--muted:#a3b1c6;--accent:#111827;--accent-2:#111827;--glass: rgba(255,255,255,.04);--neutral-1: #f7f7f8;--neutral-2: #f1f1f2;--text-strong: #e8edf3;--line: rgba(11,17,32,.06);--soft-shadow: 0 6px 20px rgba(11,17,32,.06);--ease-standard: cubic-bezier(.2,.9,.2,1);--ease-fast: cubic-bezier(.4,0,.2,1);--rhythm: 20px;--container-width: 1100px;--base-font-size: 16px;--lead-line-height: 1.6;--card-border: rgba(255,255,255,.12);--pill-bg: rgba(255,255,255,.08);--btn-bg: rgba(255,255,255,.08);--btn-color: #e8edf3;--overlay: rgba(11,17,32,.55);--nav-bg: rgba(2,6,23,.6);--nav-btn-height: 36px}*{box-sizing:border-box}html,body,#root{height:100%}body{margin:0;font-family:Space Grotesk,Inter,system-ui,-apple-system,Segoe UI,Roboto,Helvetica Neue,Arial;background:var(--bg);color:var(--text-strong);-webkit-font-smoothing:antialiased;letter-spacing:.01em;font-size:var(--base-font-size);line-height:var(--lead-line-height);transition:background-color .32s var(--ease-standard),color .32s var(--ease-standard)}body{font-size:var(--base-font-size);line-height:var(--lead-line-height)}.h1,.hero h1{font-size:clamp(32px,5vw,56px);line-height:1.04}.h2,h2{font-size:clamp(20px,3.2vw,28px)}.hero-bio{font-size:clamp(15px,2.2vw,17px)}.container{max-width:var(--container-width);margin:0 auto;padding:calc(var(--rhythm) * 1)}.project-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:18px;margin-top:18px}.detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px;align-items:start}.portfolio-root{min-height:100%;display:flex;flex-direction:column}.nav{display:flex;align-items:center;justify-content:space-between;padding:18px 40px;border-bottom:1px solid var(--card-border);background:var(--nav-bg);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);border-radius:12px;margin:12px 20px;position:relative;z-index:800}.skip-link{position:absolute;left:-9999px;top:auto;width:1px;height:1px;overflow:hidden}.skip-link:focus{left:20px;top:20px;width:auto;height:auto;padding:8px 12px;background:var(--pill-bg);border-radius:8px}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.logo{display:flex;align-items:center;gap:10px}.logo-mark{width:40px;height:40px;border-radius:12px;background:var(--pill-bg);display:flex;align-items:center;justify-content:center;color:var(--text-strong);font-weight:700;box-shadow:var(--soft-shadow)}.logo-name{font-weight:600;letter-spacing:.18em;color:var(--text-strong);text-transform:lowercase}.nav-links{display:flex;gap:12px;align-items:center}.nav-links a{color:var(--text-strong);text-decoration:none;opacity:.9}.btn{background:linear-gradient(180deg,#ffffff0f,#ffffff05);color:var(--btn-color);padding:10px 14px;border-radius:12px;border:1px solid var(--card-border);cursor:pointer;box-shadow:0 8px 24px #0b11200f;transition:transform .18s var(--ease-fast),box-shadow .24s var(--ease-standard),background-color .24s var(--ease-standard)}.btn:hover{transform:translateY(-2px);box-shadow:0 16px 44px #0b11201f}.btn:active{transform:translateY(0)}.btn:focus-visible{outline:3px solid rgba(125,91,255,.18)}.btn.large{padding:14px 20px;border-radius:14px;font-weight:600}.btn.ghost{background:transparent;border:1px solid var(--card-border);color:var(--text-strong)}.hero{display:flex;align-items:center;justify-content:space-between;padding:84px 48px;gap:36px}.hero-left{max-width:720px}.hero h1{font-size:56px;margin:0 0 8px;line-height:1.02;font-weight:600;letter-spacing:-.02em}.hero-sub{color:var(--muted);font-weight:600;margin:0 0 12px;opacity:.95}.hero-bio{color:var(--muted);margin:0 0 18px;font-size:17px}.hero-cta{display:flex;gap:12px;align-items:center}.hero-cta .btn.large{background:linear-gradient(90deg,#111827,#222e4d);box-shadow:0 18px 44px #0b11201f;padding:16px 24px;border-radius:14px}.hero-right{flex:0 0 380px;display:flex;justify-content:center}.hero-avatar{width:260px;height:260px;border-radius:24px;object-fit:cover;border:1px solid var(--line);box-shadow:var(--soft-shadow)}.hero-right{display:flex;flex-direction:column;align-items:center;gap:14px}.hero-right lottie-player{width:180px;height:180px;border-radius:12px}.hero-morph{display:none}.project-card{display:block;text-decoration:none;color:inherit}.project-inner{background:var(--card);padding:20px;border-radius:14px;transition:transform .28s var(--ease-standard),box-shadow .28s var(--ease-standard),background-color .32s var(--ease-standard);border:1px solid var(--card-border);box-shadow:var(--soft-shadow);color:var(--text-strong);will-change:transform}.project-inner:focus-within{outline:2px solid var(--card-border);transform:translateY(-6px);transition:transform .24s var(--ease-fast)}.project-inner:after{content:"";position:absolute;left:0;right:0;top:0;bottom:0;border-radius:10px;pointer-events:none;background:var(--glass);opacity:0;transition:opacity .28s var(--ease-standard)}.project-card{position:relative}.project-card:hover .project-inner:after{opacity:.12}.project-title{font-weight:700;font-size:18px}.project-desc{color:var(--muted);margin-top:8px}.project-tags{margin-top:12px}.tag{display:inline-block;background:transparent;padding:6px 8px;border-radius:999px;font-size:12px;margin-right:8px;color:var(--muted);border:1px solid var(--card-border)}.project-card .project-inner{display:flex;flex-direction:column;justify-content:space-between;min-height:160px}.hero-sub{display:inline-block;padding:6px 10px;border-radius:999px;background:var(--pill-bg);color:var(--text-strong);font-weight:600}.portfolio-root{opacity:1;transform:none}@keyframes enter{to{opacity:1;transform:none}}.page-fade{opacity:0;transform:translateY(6px);animation:fadeIn .44s var(--ease-standard) forwards}@keyframes fadeIn{to{opacity:1;transform:none}}.reveal{opacity:0;transform:translateY(20px)}.reveal.visible{animation:slideInFromBottom .6s var(--ease-standard) forwards}.stagger-1{animation-delay:.12s}.stagger-2{animation-delay:.24s}.stagger-3{animation-delay:.36s}.stagger-4{animation-delay:.48s}.theme-toggle-btn:hover{animation:bounce .6s ease}.btn:focus-visible{animation:pulse 1.5s ease infinite}.project-inner{transform-style:preserve-3d}.project-card:hover .project-inner{transform:translateY(-10px) rotateX(2deg) rotateY(-2deg);box-shadow:0 28px 60px #0b11201f}.project-card{perspective:1200px}.project-card .case-overlay{opacity:0}.project-card:hover .case-overlay{opacity:1}.project-inner{border-radius:12px;overflow:hidden}.project-inner>div{position:relative}.nav{transition:box-shadow .24s var(--ease-fast),background .24s var(--ease-fast);will-change:box-shadow}.nav.scrolled{box-shadow:0 10px 30px #0b11200a;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.separator{height:1px;background:var(--card-border);margin:28px 0}.project-card:focus-visible .project-inner,.btn:focus-visible{outline:3px solid var(--card-border);box-shadow:0 8px 30px #00000014}.about{margin-top:40px;background:linear-gradient(90deg,rgba(0,0,0,.02),transparent);padding:18px;border-radius:12px}.about .project-inner{box-shadow:none}.contact{margin-top:12px;color:var(--muted);display:flex;gap:20px}.footer{padding:48px;text-align:center;color:var(--muted);border-top:1px solid var(--card-border);margin-top:80px}.socials{display:flex;gap:12px;justify-content:center;margin-top:8px}.socials a{display:inline-flex;width:36px;height:36px;border-radius:8px;align-items:center;justify-content:center;border:1px solid var(--card-border);background:var(--card);color:var(--text-strong);text-decoration:none;box-shadow:var(--soft-shadow)}.skip-link{left:-9999px}a{color:var(--text-strong)}.btn:focus{outline:3px solid rgba(125,91,255,.14)}.modal{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--overlay);display:flex;align-items:center;justify-content:center;z-index:1000}.modal-card{background:var(--card);padding:20px;border-radius:12px;min-width:320px;max-width:720px;box-shadow:var(--soft-shadow);color:var(--text-strong);border:1px solid var(--card-border)}.modal-card h2{margin:0 0 12px}.modal-card label{display:block;margin:8px 0;color:var(--muted)}.modal-card input,.modal-card textarea{width:100%;padding:10px;border-radius:8px;border:1px solid var(--card-border);background:transparent;color:var(--text-strong)}.modal-actions{display:flex;gap:8px;justify-content:flex-end;margin-top:12px}.bg-blobs{position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:0}.bg-pattern{position:absolute;top:0;right:0;bottom:0;left:0;background-image:radial-gradient(circle,rgba(255,255,255,.04) 1px,transparent 1px);background-size:28px 28px;opacity:.15;will-change:auto}.mobile-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#020617b3;display:flex;align-items:flex-start;justify-content:flex-end;padding:40px;z-index:900}.mobile-menu{width:320px;background:var(--card);color:var(--text-strong);border-radius:12px;padding:24px;display:flex;flex-direction:column;gap:12px;box-shadow:var(--soft-shadow);border:1px solid var(--card-border)}.mobile-menu a{color:var(--text-strong);text-decoration:none;padding:10px 0}.admin-panel{position:relative;z-index:700;max-width:var(--container-width);margin:80px auto 40px;background:var(--card);color:var(--text-strong);border:1px solid var(--card-border);border-radius:12px;padding:20px;box-shadow:var(--soft-shadow)}.admin-panel h2{margin:0 0 12px}.admin-panel section{margin-top:12px}.admin-panel input{background:transparent;color:var(--text-strong)}@media (max-width:900px){.nav{padding:14px 12px;margin:8px 10px}.nav-links{display:flex;gap:8px;align-items:center;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;max-width:70vw}.nav-links::-webkit-scrollbar{display:none}.nav-links .btn{scroll-snap-align:start}.hamburger{display:inline-flex;background:transparent;border:none;padding:8px;border-radius:8px}.hero{flex-direction:column;align-items:flex-start;padding:36px 20px;gap:18px}.hero-right{align-self:center}.hero-cta{width:100%;flex-direction:column;align-items:stretch}.project-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:12px}.btn{min-height:44px}.hero-avatar{width:200px;height:200px}.about{margin:20px 0}.skills{margin-top:16px}}@media (max-width:768px){.hero{padding:32px 16px}.hero h1{font-size:48px}.hero-sub,.hero-bio{font-size:16px}.project-grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px}.container{padding:0 16px}.nav{margin:6px}}@media (max-width:700px){.detail-grid{grid-template-columns:1fr}.detail-image{height:240px}.project-grid{grid-template-columns:repeat(auto-fit,minmax(180px,1fr))}}@media (max-width:520px){.nav{padding:12px calc(12px + env(safe-area-inset-right));margin:6px 8px}.hero{padding:16px}.hero-avatar{width:140px;height:140px}.project-inner{padding:12px}.mobile-menu{width:100%;border-radius:0;padding:18px}.footer{padding:28px}.hero h1{font-size:34px}.nav-links{max-width:60vw}.hero-cta{gap:8px}.btn{font-size:14px}.tag{font-size:11px;padding:4px 6px}.socials{gap:16px}.socials a{width:40px;height:40px}}@media (hover: none) and (pointer: coarse){.project-card:hover .project-inner,.btn:hover{transform:none}.project-card:active .project-inner{transform:translateY(-4px)}.btn:active{transform:translateY(-2px)}}@media (prefers-contrast: high){.btn,.project-inner,.tag{border-width:2px}}.modal{opacity:0;animation:modal-in .24s var(--ease-fast) forwards}@keyframes modal-in{to{opacity:1}}.modal-card{opacity:0;transform:translateY(6px);animation:card-in .28s var(--ease-standard) forwards}@keyframes card-in{to{opacity:1;transform:none}}.project-detail{opacity:0;transform:translateY(8px);animation:reveal .36s var(--ease-standard) forwards}@media (prefers-reduced-motion: reduce){.reveal,.portfolio-root,.project-inner{animation:none!important;transition:none!important}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes bounce{0%,20%,50%,80%,to{transform:translateY(0)}40%{transform:translateY(-6px)}60%{transform:translateY(-3px)}}@keyframes pulse{0%{opacity:1}50%{opacity:.7}to{opacity:1}}@keyframes slideInFromBottom{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}@keyframes slideInFromLeft{0%{transform:translate(-20px);opacity:0}to{transform:translate(0);opacity:1}}@keyframes slideInFromRight{0%{transform:translate(20px);opacity:0}to{transform:translate(0);opacity:1}}a{position:relative}a:after{content:"";position:absolute;left:0;right:auto;bottom:-2px;height:2px;background:var(--text-strong);width:0;transition:width .28s var(--ease-standard)}a:hover:after{width:100%}.nav-links .btn{display:inline-flex;align-items:center;gap:6px;height:var(--nav-btn-height);padding:0 14px;border-radius:999px;font-weight:600}.nav-links .btn.ghost{background:transparent;border:1px solid var(--card-border);color:var(--text-strong)}.nav-links .btn:hover{transform:none;box-shadow:0 8px 24px #0b112014;background:#ffffff0d}.nav-links .btn:active{transform:translateY(0)}
