:root{--bg:#f5f5f3;--surface:#ffffff;--surface-soft:#f1f1ee;--surface-strong:#e8e8e4;--text:#191919;--muted:#666666;--line:#dddddd;--accent:#5a5a5a;--accent-strong:#2c2c2c;--shadow:0 18px 36px rgba(0,0,0,0.06)}body.dark{--bg:#1c1c1c;--surface:#262626;--surface-soft:#2f2f2f;--surface-strong:#383838;--text:#f2f2f2;--muted:#bdbdbd;--line:#434343;--accent:#8d8d8d;--accent-strong:#d5d5d5;--shadow:0 18px 38px rgba(0,0,0,0.22)}*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:var(--bg);color:var(--text);transition:background .35s ease,color .35s ease}a{color:inherit}img{max-width:100%;display:block}.container{width:min(1080px,calc(100% - 2rem));margin:0 auto}.page-shell{padding:1rem 0 2rem}.topbar{justify-content:space-between;gap:1rem;padding:.35rem 0 1rem;position:-webkit-sticky;position:sticky;top:0;z-index:30;background:color-mix(in srgb,var(--bg) 90%,transparent);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.brand,.topbar{display:flex;align-items:center}.brand{gap:.9rem;text-decoration:none}.brand span,.brand strong{display:block}.brand span:last-child{color:var(--muted);font-size:.92rem}.brand-avatar{width:42px;height:42px;border-radius:14px;object-fit:cover;border:1px solid var(--line);animation:pulseSoft 4s ease-in-out infinite}.nav{display:flex;gap:1.1rem;align-items:center}.footer-links a,.nav a{color:var(--muted);text-decoration:none;transition:color .2s ease,transform .2s ease}.footer-links a:hover,.nav a:hover{color:var(--text);transform:translateY(-1px)}.toolbar-actions{display:flex;gap:.75rem;align-items:center}.music-control{display:flex;align-items:center;gap:.65rem}.volume-wrap{display:inline-flex;align-items:center;gap:.6rem;min-height:42px;padding:0 .8rem;border-radius:12px;border:1px solid var(--line);background:var(--surface);color:var(--muted);font-size:.9rem}.volume-wrap input{width:90px;accent-color:var(--accent-strong)}.button,.theme-toggle,.toolbar-button{min-height:42px;padding:0 1rem;border-radius:12px;border:1px solid var(--line);background:var(--surface);color:var(--text);font-weight:600;text-decoration:none;cursor:pointer;transition:transform .25s ease,border-color .25s ease,background .25s ease,box-shadow .25s ease}.button:hover,.hover-rise:hover,.theme-toggle:hover,.toolbar-button:hover{transform:translateY(-2px);box-shadow:var(--shadow)}.button{display:inline-flex;align-items:center;justify-content:center}.button--primary{background:var(--accent-strong);border-color:var(--accent-strong);color:#fff}.theme-toggle--icon{position:relative;width:78px;padding:0;overflow:hidden}.theme-track{position:relative;width:100%;height:100%;display:flex;align-items:center;justify-content:space-between;padding:0 .7rem}.theme-track:before{content:"";position:absolute;left:6px;top:6px;width:30px;height:30px;border-radius:50%;background:linear-gradient(135deg,#ffd76a,#ffb84d);transition:transform .35s ease,background .35s ease}.theme-toggle--icon.is-dark .theme-track:before{transform:translateX(34px);background:linear-gradient(135deg,#f3f3f3,#9d9d9d)}.theme-icon{position:relative;z-index:1;font-size:1rem;transition:transform .35s ease,opacity .35s ease}.theme-toggle--icon.is-dark .theme-icon--sun{opacity:.35;transform:rotate(-20deg) scale(.94)}.theme-toggle--icon:not(.is-dark) .theme-icon--moon{opacity:.35;transform:rotate(20deg) scale(.94)}.main-layout{display:grid;grid-gap:1.75rem;gap:1.75rem}.hero{display:grid;grid-template-columns:minmax(0,1.35fr) minmax(280px,.75fr);grid-gap:1.25rem;gap:1.25rem}.hero-minimal{padding-top:2.2rem;align-items:start}.hero-copy{padding-top:.5rem}.eyebrow,.section-label{margin:0 0 .8rem;font-size:.78rem;text-transform:uppercase;letter-spacing:.08em;font-weight:700;color:var(--accent)}h1,h2,h3,p{margin-top:0}h1{font-size:clamp(3rem,7vw,5.3rem);line-height:.96;letter-spacing:-.05em;margin-bottom:1rem}h2{font-size:clamp(1.55rem,3vw,2.35rem);line-height:1.15;margin-bottom:.9rem}h3{font-size:1.08rem;margin-bottom:.7rem}li,p{color:var(--muted);line-height:1.75}.lead{color:var(--text);font-size:1.08rem;max-width:42rem}.hero-actions{display:flex;gap:.8rem;flex-wrap:wrap;margin-top:1.4rem}.card{background:var(--surface);border:1px solid var(--line);border-radius:20px;padding:1.4rem;box-shadow:var(--shadow);transition:transform .28s ease,box-shadow .28s ease,border-color .28s ease,background .28s ease}.card--soft{background:var(--surface-soft)}.card--featured{background:linear-gradient(180deg,var(--surface),var(--surface-soft))}.card--compact{align-self:start}.profile-card{display:grid;grid-gap:1rem;gap:1rem}.profile-head{display:flex;align-items:center;gap:1rem}.profile-head h2{margin-bottom:.25rem}.profile-head p{margin:0}.avatar{width:84px;height:84px;border-radius:20px;object-fit:cover;border:1px solid var(--line)}.mini-tags,.tags{display:flex;flex-wrap:wrap;gap:.6rem}.mini-tags span,.tags span{display:inline-flex;align-items:center;padding:.45rem .78rem;border-radius:999px;background:var(--surface);border:1px solid var(--line);color:var(--text);font-size:.9rem}.tech-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));grid-gap:.9rem;gap:.9rem;margin-top:.35rem}.tech-chip{display:flex;align-items:center;gap:.75rem;padding:.9rem 1rem;border:1px solid var(--line);border-radius:14px;background:var(--surface);min-height:58px}.tech-chip img{width:22px;height:22px;object-fit:contain;flex-shrink:0}.tech-chip span{color:var(--text);font-size:.94rem;line-height:1.35}.footer,.section-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));grid-gap:1.2rem;gap:1.2rem}.section-grid--wide{align-items:start}.section-block{display:grid;grid-gap:1rem;gap:1rem}.section-block--spacious{gap:1.1rem}.section-header{display:grid;grid-template-columns:minmax(0,1fr) minmax(250px,.75fr);grid-gap:1rem;gap:1rem;align-items:end}.section-header--minimal{align-items:start}.project-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));grid-gap:1rem;gap:1rem}.project-grid--clean{gap:1rem}.project-card{height:100%}.process-list,.stack-list{display:grid;grid-gap:1rem;gap:1rem}.process-step strong,.stack-list strong{display:block;color:var(--text);margin-bottom:.35rem}.process-step{display:grid;grid-template-columns:52px 1fr;grid-gap:.9rem;gap:.9rem;align-items:start}.process-step span{width:52px;height:52px;display:grid;place-items:center;border-radius:16px;background:var(--surface-soft);border:1px solid var(--line);color:var(--accent-strong);font-weight:700}.list-simple{margin:0;padding-left:1.1rem}.list-simple li{margin-bottom:.65rem}.footer{margin-top:1.6rem;align-items:center}.footer-links{display:grid;grid-gap:.75rem;gap:.75rem}[data-reveal]{opacity:0;transform:translateY(26px) scale(.985);transition:opacity .8s ease,transform .8s ease}[data-reveal].is-visible{opacity:1;transform:translateY(0) scale(1)}.card.is-visible,.footer.is-visible,.project-card.is-visible{animation:liftIn .85s ease both}@keyframes liftIn{0%{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}@keyframes pulseSoft{0%,to{transform:scale(1)}50%{transform:scale(1.04)}}@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}*,:after,:before{animation:none!important;transition:none!important}[data-reveal]{opacity:1;transform:none}}@media (max-width:940px){.footer,.hero,.project-grid,.section-grid,.section-header{grid-template-columns:1fr}.hero-minimal{gap:1rem}.topbar{gap:.9rem}.nav,.topbar{flex-wrap:wrap}.nav{order:3;width:100%;justify-content:space-between;padding:.25rem 0 0}}@media (max-width:760px){.page-shell{padding-top:.65rem}.main-layout{gap:1.2rem}.toolbar-actions{width:100%;display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:center;grid-gap:.75rem;gap:.75rem}.volume-wrap{width:100%;min-height:44px;padding:.7rem .85rem;justify-content:space-between}.volume-wrap input{width:100%;max-width:160px}.hero-minimal{padding-top:1.2rem}.hero-copy{padding-top:0}.footer,.section-block,.section-grid{gap:1rem}.tech-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:.75rem}}@media (max-width:620px){.container{width:min(100%,calc(100% - 1rem))}.topbar{padding-bottom:.85rem}.brand{gap:.75rem;align-items:center}.brand strong{font-size:.98rem}.brand span:last-child{font-size:.85rem}.nav{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));grid-gap:.55rem;gap:.55rem;font-size:.92rem}.nav a{text-align:center;padding:.7rem .5rem;border:1px solid var(--line);border-radius:12px;background:var(--surface)}.toolbar-actions{grid-template-columns:1fr}.theme-toggle--icon{width:100%;max-width:84px;justify-self:end}.card{padding:1.15rem;border-radius:18px}h1{font-size:clamp(2.35rem,11vw,3.45rem);line-height:1}h2{font-size:clamp(1.35rem,7vw,1.9rem)}.lead{font-size:1rem}.hero-actions{flex-direction:column;align-items:stretch}.button{width:100%}.process-step,.profile-head{grid-template-columns:1fr}.profile-head{gap:.85rem}.avatar{width:74px;height:74px}.tech-grid{grid-template-columns:1fr}.tech-chip{min-height:54px;padding:.8rem .9rem}.process-step span{width:44px;height:44px}}