:root{--bg:#fbfbf9;--surface:#fff;--ink:#0b0b0c;--ink-soft:#34343a;--muted:#6e6e76;--muted-2:#9a9aa0;--line:#e7e7e2;--line-strong:#d8d8d2;--accent:#0a84ff;--accent-ink:#006fe6;--maxw:1180px;--gutter:clamp(20px,5vw,64px);--radius:16px;--radius-sm:10px;--ease:cubic-bezier(0.22,1,0.36,1);--ease-soft:cubic-bezier(0.4,0,0.2,1);--shadow-sm:0 1px 2px rgba(11,11,12,.04),0 4px 16px rgba(11,11,12,.04);--shadow-md:0 2px 6px rgba(11,11,12,.06),0 18px 50px rgba(11,11,12,.1)}*,:after,:before{box-sizing:border-box}body,html{margin:0;padding:0}html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}body{background:var(--bg);color:var(--ink);font-family:DM Sans,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;font-size:17px;line-height:1.55;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}a{color:inherit;text-decoration:none}img{max-width:100%;display:block}button{font-family:inherit;cursor:pointer}::selection{background:var(--accent);color:#fff}:focus-visible{outline:2px solid var(--accent);outline-offset:3px;border-radius:4px}.wrap{width:100%;max-width:var(--maxw);margin:0 auto;padding-left:var(--gutter);padding-right:var(--gutter)}.page{min-height:100vh;display:flex;flex-direction:column}.page-main{flex:1 0 auto}.eyebrow{font-size:12px;font-weight:500;letter-spacing:.16em;text-transform:uppercase;color:var(--muted)}.nav{position:fixed;inset:0 0 auto 0;z-index:50;height:64px;display:flex;align-items:center;transition:background .4s var(--ease-soft),border-color .4s var(--ease-soft),-webkit-backdrop-filter .4s var(--ease-soft);transition:background .4s var(--ease-soft),border-color .4s var(--ease-soft),backdrop-filter .4s var(--ease-soft);transition:background .4s var(--ease-soft),border-color .4s var(--ease-soft),backdrop-filter .4s var(--ease-soft),-webkit-backdrop-filter .4s var(--ease-soft);border-bottom:1px solid transparent}.nav--scrolled{background:color-mix(in srgb,var(--bg) 72%,transparent);-webkit-backdrop-filter:saturate(180%) blur(20px);backdrop-filter:saturate(180%) blur(20px);border-bottom:1px solid var(--line)}.nav-inner{width:100%;max-width:var(--maxw);margin:0 auto;padding-left:var(--gutter);padding-right:var(--gutter);display:flex;align-items:center;justify-content:space-between}.nav-mark{font-weight:700;font-size:19px;letter-spacing:-.02em}.nav-links{display:flex;align-items:center;gap:30px}.nav-link{font-size:15px;font-weight:500;color:var(--muted);transition:color .2s var(--ease-soft)}.nav-link--active,.nav-link:hover{color:var(--ink)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;height:46px;padding:0 24px;border-radius:999px;font-size:15px;font-weight:600;border:1px solid transparent;transition:transform .18s var(--ease),background .2s var(--ease-soft),box-shadow .2s var(--ease-soft),border-color .2s var(--ease-soft)}.btn:active{transform:scale(.97)}.btn--primary{background:var(--ink);color:var(--bg)}.btn--primary:hover{box-shadow:var(--shadow-md)}.btn--ghost{background:transparent;color:var(--ink);border-color:var(--line-strong)}.btn--ghost:hover{border-color:var(--ink)}.btn--accent{background:var(--accent);color:#fff}.btn--accent:hover{background:var(--accent-ink)}.hero{min-height:100svh;display:flex;flex-direction:column;justify-content:center;position:relative;padding-top:64px}.hero-eyebrow{margin:0 0 22px}.hero-title{margin:0;font-weight:500;font-size:clamp(2.8rem,11vw,7.4rem);line-height:.98;letter-spacing:-.04em}.hero-title .accentword{position:relative;font-weight:700;white-space:nowrap}.hero-title .accentword:after{content:"";position:absolute;left:0;bottom:.06em;height:.07em;width:100%;background:var(--accent);transform:scaleX(0);transform-origin:left;border-radius:2px}.hero-sub{margin:28px 0 0;max-width:44ch;font-size:clamp(1.05rem,2.2vw,1.35rem);color:var(--ink-soft);font-weight:400;line-height:1.5}.hero-actions{margin-top:38px;display:flex;flex-wrap:wrap;gap:14px}.scroll-indicator{position:absolute;bottom:34px;left:var(--gutter);display:inline-flex;align-items:center;gap:14px;color:var(--muted);font-size:12px;letter-spacing:.16em;text-transform:uppercase;font-weight:500}.scroll-track{position:relative;width:1px;height:46px;background:var(--line-strong);overflow:hidden}.scroll-track:after{content:"";position:absolute;left:0;top:-40%;width:1px;height:40%;background:var(--ink);animation:scrollDrop 2.1s var(--ease-soft) infinite}@keyframes scrollDrop{0%{transform:translateY(0)}to{transform:translateY(280%)}}.enter{opacity:0;transform:translateY(18px);animation:enterUp .9s var(--ease) forwards}.enter-1{animation-delay:.05s}.enter-2{animation-delay:.18s}.enter-3{animation-delay:.31s}.enter-4{animation-delay:.44s}.enter-5{animation-delay:.57s}@keyframes enterUp{to{opacity:1;transform:translateY(0)}}.underline-draw:after{animation:drawUnderline .7s var(--ease) .7s forwards}@keyframes drawUnderline{to{transform:scaleX(1)}}.section{padding-top:clamp(72px,11vw,140px);padding-bottom:clamp(72px,11vw,140px)}.section-head{display:flex;align-items:flex-end;justify-content:space-between;gap:24px;margin-bottom:clamp(32px,5vw,56px)}.section-title{margin:10px 0 0;font-size:clamp(1.8rem,4.5vw,2.8rem);font-weight:600;letter-spacing:-.03em;line-height:1.05}.section-link{font-size:15px;font-weight:600;color:var(--accent);white-space:nowrap;transition:opacity .2s var(--ease-soft)}.section-link:hover{opacity:.65}.page-top-pad{padding-top:130px}.lead{max-width:60ch;font-size:clamp(1.05rem,2.2vw,1.3rem);color:var(--ink-soft)}.gallery{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));grid-gap:clamp(8px,1vw,14px);gap:clamp(8px,1vw,14px)}.work{position:relative;border-radius:var(--radius);overflow:hidden;background:var(--surface);border:1px solid var(--line);aspect-ratio:16/9;box-shadow:var(--shadow-sm);transition:transform .4s var(--ease),box-shadow .4s var(--ease)}.work:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}.work-img{width:100%;height:100%;object-fit:contain;transition:transform .6s var(--ease)}.work:hover .work-img{transform:scale(1.04)}.work-overlay{position:absolute;inset:0;display:flex;flex-direction:column;justify-content:flex-end;padding:20px;background:linear-gradient(0deg,rgba(7,7,9,.74) 0,rgba(7,7,9,.18) 46%,rgba(7,7,9,0) 70%);opacity:0;transition:opacity .4s var(--ease-soft)}.work:focus-within .work-overlay,.work:hover .work-overlay{opacity:1}.work-title{color:#fff;font-weight:600;font-size:1.1rem;letter-spacing:-.01em;transform:translateY(8px);transition:transform .4s var(--ease)}.work:hover .work-title{transform:translateY(0)}.work-tags{margin-top:8px;display:flex;flex-wrap:wrap;gap:6px;transform:translateY(8px);transition:transform .45s var(--ease)}.work:hover .work-tags{transform:translateY(0)}.tag{font-size:11px;font-weight:500;letter-spacing:.04em;padding:3px 9px;border-radius:999px;background:hsla(0,0%,100%,.16);color:#fff;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.projects{display:grid;grid-template-columns:1fr;grid-gap:clamp(14px,1.6vw,20px);gap:clamp(14px,1.6vw,20px)}@media (min-width:760px){.projects{grid-template-columns:1fr 1fr}}.project{display:flex;flex-direction:column;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm);transition:transform .35s var(--ease),box-shadow .35s var(--ease),border-color .35s var(--ease)}.project:hover{transform:translateY(-3px);box-shadow:var(--shadow-md);border-color:var(--line-strong)}.project-cover{aspect-ratio:16/9;overflow:hidden;background:#f0f0ec}.project-cover img{width:100%;height:100%;object-fit:cover}.project-body{padding:24px 24px 26px;display:flex;flex-direction:column;gap:12px;flex:1 1}.project-title{margin:0;font-size:1.35rem;font-weight:600;letter-spacing:-.02em}.project-desc{margin:0;color:var(--muted);font-size:.98rem;line-height:1.55}.project-tags{display:flex;flex-wrap:wrap;gap:7px;margin-top:2px}.tag-quiet{font-size:11px;font-weight:500;letter-spacing:.03em;padding:3px 10px;border-radius:999px;background:var(--bg);border:1px solid var(--line);color:var(--ink-soft)}.project-link{margin-top:auto;padding-top:10px;font-size:14px;font-weight:600;color:var(--accent);display:inline-flex;align-items:center;gap:6px}.project-link span{transition:transform .25s var(--ease)}.project:hover .project-link span{transform:translateX(3px)}.contact{display:grid;grid-gap:clamp(28px,5vw,56px);gap:clamp(28px,5vw,56px);grid-template-columns:1fr}@media (min-width:820px){.contact{grid-template-columns:1.1fr .9fr;align-items:start}}.contact-big{font-size:clamp(2rem,6vw,3.6rem);font-weight:600;letter-spacing:-.035em;line-height:1.04;margin:0}.contact-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:28px;box-shadow:var(--shadow-sm)}.contact-row{display:flex;align-items:center;justify-content:space-between;padding:16px 0;border-bottom:1px solid var(--line)}.contact-row:last-child{border-bottom:none}.contact-row-label{font-size:13px;color:var(--muted);letter-spacing:.02em}.contact-row-value{font-weight:600;font-size:15px}.contact-actions{margin-top:22px;display:flex;flex-wrap:wrap;gap:12px}.footer{border-top:1px solid var(--line);padding:40px 0;margin-top:40px}.footer-inner{display:flex;align-items:center;justify-content:space-between;gap:18px;flex-wrap:wrap}.footer-mark{font-weight:700;letter-spacing:-.02em}.footer-meta{font-size:13px;color:var(--muted)}.footer-links{display:flex;gap:22px;font-size:14px;font-weight:500;color:var(--muted)}.footer-links a:hover{color:var(--ink)}.empty{border:1px dashed var(--line-strong);border-radius:var(--radius);padding:56px 28px;text-align:center;color:var(--muted);background:var(--surface)}.empty strong{display:block;color:var(--ink);font-size:1.15rem;font-weight:600;margin-bottom:6px}.reveal{opacity:0;transform:translateY(26px);transition:opacity .7s var(--ease),transform .7s var(--ease);will-change:opacity,transform}.reveal.is-visible{opacity:1;transform:none}.admin-shell{padding-top:120px;padding-bottom:90px}.admin-grid{display:grid;grid-gap:28px;gap:28px;grid-template-columns:1fr}@media (min-width:960px){.admin-grid{grid-template-columns:1fr 1fr}}.panel{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:26px;box-shadow:var(--shadow-sm)}.panel h2{margin:0 0 4px;font-size:1.3rem;font-weight:600;letter-spacing:-.02em}.panel-hint{margin:0 0 20px;font-size:14px;color:var(--muted)}.field{display:flex;flex-direction:column;gap:7px;margin-bottom:16px}.field label{font-size:13px;font-weight:600;color:var(--ink-soft)}.field input[type=text],.field input[type=url],.field textarea{width:100%;font-family:inherit;font-size:15px;color:var(--ink);background:var(--bg);border:1px solid var(--line-strong);border-radius:var(--radius-sm);padding:11px 13px;transition:border-color .2s var(--ease-soft),box-shadow .2s var(--ease-soft)}.field textarea{min-height:92px;resize:vertical}.field input:focus,.field textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px color-mix(in srgb,var(--accent) 18%,transparent)}.dropzone{border:1.5px dashed var(--line-strong);border-radius:var(--radius-sm);padding:22px;text-align:center;color:var(--muted);font-size:14px;background:var(--bg);transition:border-color .2s var(--ease-soft),background .2s var(--ease-soft)}.dropzone:hover{border-color:var(--accent)}.preview{margin-top:12px;border-radius:var(--radius-sm);overflow:hidden;border:1px solid var(--line);aspect-ratio:4/3;background:#f0f0ec}.preview img{width:100%;height:100%;object-fit:cover}.notice{font-size:14px;border-radius:var(--radius-sm);padding:11px 14px;margin-bottom:16px}.notice--ok{background:color-mix(in srgb,#1f9d57 12%,var(--surface));color:#167a43}.notice--err{background:color-mix(in srgb,#e5484d 12%,var(--surface));color:#c2363b}.admin-list{display:flex;flex-direction:column;gap:10px;margin-top:20px}.admin-item{display:flex;align-items:center;gap:12px;padding:10px;border:1px solid var(--line);border-radius:var(--radius-sm)}.admin-thumb{width:56px;height:44px;border-radius:7px;object-fit:cover;background:#f0f0ec;flex:none}.admin-item-body{flex:1 1;min-width:0}.admin-item-title{font-weight:600;font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.admin-item-meta{font-size:12px;color:var(--muted)}.icon-btn{border:1px solid var(--line-strong);background:var(--surface);color:var(--muted);border-radius:8px;height:34px;padding:0 12px;font-size:13px;font-weight:600;transition:color .2s,border-color .2s}.icon-btn:hover{color:#c2363b;border-color:#e5484d}.signin-card{max-width:440px;margin:0 auto;text-align:center;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:44px 32px;box-shadow:var(--shadow-sm)}.signin-card h1{margin:0 0 8px;font-size:1.6rem;font-weight:600;letter-spacing:-.02em}.signin-card p{margin:0 0 24px;color:var(--muted)}.admin-bar{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:30px;flex-wrap:wrap}.admin-bar h1{margin:0;font-size:clamp(1.6rem,4vw,2.2rem);font-weight:600;letter-spacing:-.03em}.admin-who{display:flex;align-items:center;gap:10px;font-size:14px;color:var(--muted)}.admin-who img{width:30px;height:30px;border-radius:50%}@media (max-width:620px){.nav-links{gap:18px}.nav-link{font-size:14px}.section-head{flex-direction:column;align-items:flex-start;gap:12px}}@media (prefers-reduced-motion:reduce){*,:after,:before{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important;scroll-behavior:auto!important}.enter{opacity:1;transform:none}.hero-title .accentword:after{transform:scaleX(1)}.reveal{opacity:1;transform:none}}[data-theme=dark]{--bg:#0c0c0e;--surface:#161618;--ink:#f4f4f2;--ink-soft:#c7c7c9;--muted:#8a8a90;--muted-2:#6a6a70;--line:#25252a;--line-strong:#34343a;--accent:#0a84ff;--accent-ink:#409cff}