@import"https://fonts.googleapis.com/css2?family=Outfit:wght@300;400;500;600&display=swap";*{box-sizing:border-box}*,*:before,*:after{margin:0;padding:0}:root{--background: #ffffff;--foreground: #000000;--muted: #65728d;--line: #0f0f0f;--soft-line: #d4d7dd;--overlay: rgba(0, 0, 0, .78);--project-row-height: 36px;--project-row-gap: 8px}html,body,#root{min-height:100%}body{font-family:Outfit,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:var(--background);color:var(--foreground);line-height:1.5;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}button,a{font:inherit}button{color:inherit}a{color:inherit;text-decoration:none}svg{display:block}.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}.home-page{min-height:100svh;overflow:hidden;background:var(--background);padding:clamp(28px,4vw,56px)}.home-page--loading{display:grid;place-items:center}.loading-spinner{width:34px;aspect-ratio:1;border:2px solid var(--soft-line);border-top-color:var(--foreground);border-radius:50%;animation:loading-spin .78s linear infinite}@keyframes loading-spin{to{transform:rotate(360deg)}}.site-shell{position:relative;min-height:calc(100svh - (clamp(28px,4vw,56px)*2))}.corner,.site-logo-wrap{position:absolute;z-index:1}.corner--top-left{top:0;left:0}.corner--top-right{top:0;right:0}.corner--bottom-left{bottom:0;left:0}.corner--bottom-right{right:0;bottom:0}.section-label{color:var(--muted);font-size:clamp(.76rem,.72rem + .14vw,.88rem);font-weight:500;letter-spacing:.34em;line-height:1.2;text-transform:uppercase}.profile-intro{display:flex;align-items:center;gap:18px}.profile-intro__portrait{width:clamp(64px,5vw,88px);height:clamp(64px,5vw,88px);border-radius:50%;filter:grayscale(1);object-fit:cover}.profile-intro__name{margin-top:4px;font-size:clamp(1.25rem,1.02rem + .55vw,1.7rem);font-weight:600;line-height:1.05}.bio-block{max-width:min(30vw,460px);text-align:right}.bio-block p{margin-top:14px;font-size:clamp(1rem,.9rem + .28vw,1.35rem);font-weight:400;line-height:1.45}.site-logo-wrap{inset:0;display:grid;place-items:center;pointer-events:none;z-index:0}.site-logo{width:clamp(220px,33vw,560px);max-height:52svh;object-fit:contain;-webkit-user-select:none;user-select:none}.projects-panel{width:min(82vw,320px)}.projects-panel .section-label,.contact-panel .section-label{margin-bottom:14px}.projects-panel__scroll{max-height:calc((var(--project-row-height) * 3.5) + (var(--project-row-gap) * 3));overflow-y:auto;padding-right:10px;scrollbar-color:var(--foreground) transparent;scrollbar-width:thin}.projects-panel__scroll::-webkit-scrollbar{width:4px}.projects-panel__scroll::-webkit-scrollbar-thumb{background:var(--foreground)}.projects-list{display:grid;gap:var(--project-row-gap);list-style:none}.project-button{display:grid;grid-template-columns:var(--project-row-height) 1fr;align-items:center;min-height:var(--project-row-height);gap:14px;border:0;background:transparent;cursor:pointer;font-size:clamp(1rem,.94rem + .2vw,1.25rem);line-height:1.2;text-align:left}.project-button span:last-child{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.project-button:hover,.project-button:focus-visible,.social-link:hover,.social-link:focus-visible,.project-dialog__links a:hover,.project-dialog__links a:focus-visible{opacity:.62}.project-button:focus-visible,.social-link:focus-visible,.dialog-close:focus-visible,.project-dialog__links a:focus-visible{outline:2px solid var(--foreground);outline-offset:4px}.project-logo{display:inline-grid;width:var(--project-row-height);height:var(--project-row-height);place-items:center;flex:0 0 auto;overflow:hidden}.project-logo__media{width:100%;height:100%;object-fit:contain}.project-logo__initials{font-size:.76rem;font-weight:600;line-height:1}.contact-panel{text-align:right}.social-links{display:flex;justify-content:flex-end;gap:18px}.social-link{display:inline-grid;width:24px;height:24px;place-items:center;transition:opacity .16s ease}.social-link svg{width:20px;height:20px;fill:currentColor}.dialog-backdrop{position:fixed;inset:0;z-index:10;display:grid;place-items:center;padding:24px;background:var(--overlay)}.project-dialog{position:relative;width:min(92vw,640px);max-height:min(86svh,760px);overflow-y:auto;border:1px solid var(--soft-line);border-radius:8px;background:var(--background);padding:clamp(22px,3vw,34px);box-shadow:0 18px 60px #0000003d}.dialog-close{position:absolute;top:16px;right:16px;display:grid;width:34px;height:34px;place-items:center;border:1px solid #aab2c0;border-radius:50%;background:transparent;cursor:pointer;transition:opacity .16s ease}.dialog-close svg{width:22px;height:22px;fill:none;stroke:currentColor;stroke-width:1.8;stroke-linecap:round}.project-dialog__header{display:flex;align-items:center;gap:18px;padding-right:42px}.project-dialog__header .project-logo{--project-row-height: 56px}.project-dialog__header h2{font-size:clamp(1.35rem,1.14rem + .6vw,1.85rem);line-height:1.1}.project-dialog__description{margin-top:24px;color:#303030;font-size:clamp(1rem,.95rem + .2vw,1.22rem);line-height:1.55}.project-dialog__links{display:flex;flex-wrap:wrap;gap:18px;margin-top:26px}.project-dialog__links a{display:inline-flex;align-items:center;gap:9px;font-size:1rem;transition:opacity .16s ease}.project-dialog__links svg{width:20px;height:20px;fill:currentColor}.project-dialog__links svg:not(:first-child),.project-dialog__links a:nth-child(2) svg{fill:none;stroke:currentColor;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}.admin-page{min-height:100svh;background:#f7f7f4;color:var(--foreground);padding:clamp(22px,4vw,48px)}.admin-page--centered{display:grid;place-items:center}.admin-header{display:flex;align-items:flex-start;justify-content:space-between;gap:24px;margin-bottom:28px}.admin-header h1,.admin-login h1{margin-top:8px;font-size:clamp(2rem,1.45rem + 1.7vw,3.4rem);line-height:1}.admin-actions,.admin-button-row{display:flex;flex-wrap:wrap;gap:10px}.admin-actions a,.admin-actions button,.admin-button-row button,.admin-login button{min-height:42px;border:1px solid var(--line);border-radius:6px;background:var(--foreground);color:var(--background);cursor:pointer;padding:0 16px;font-weight:600}.admin-actions a,.admin-actions button{display:inline-flex;align-items:center;background:transparent;color:var(--foreground)}.admin-button-row button:disabled{cursor:wait;opacity:.58}.admin-button-row .admin-danger{border-color:#9c1d1d;background:#9c1d1d}.admin-panel-header{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:18px}.admin-panel-header h2{margin-bottom:0}.admin-panel-header button,.admin-project-row button{min-height:40px;border:1px solid var(--line);border-radius:6px;background:var(--foreground);color:var(--background);cursor:pointer;padding:0 14px;font-weight:600}.admin-layout{display:grid;grid-template-columns:minmax(180px,240px) minmax(0,1fr);gap:18px;align-items:start}.admin-sidebar,.admin-panel,.admin-login{border:1px solid #d6d4cb;border-radius:8px;background:var(--background)}.admin-sidebar{display:grid;gap:6px;padding:8px;position:sticky;top:24px}.admin-sidebar button{min-height:40px;border:0;border-radius:5px;background:transparent;cursor:pointer;padding:0 12px;text-align:left}.admin-sidebar button:hover,.admin-sidebar button:focus-visible,.admin-sidebar button.is-selected{background:#ededdf}.admin-panel{padding:clamp(18px,2.5vw,28px)}.admin-panel+.admin-panel{grid-column:2}.admin-panel h2{margin-bottom:18px;font-size:clamp(1.3rem,1.08rem + .6vw,1.9rem);line-height:1.1}.admin-project-list{display:grid;gap:10px}.admin-project-row{display:grid;grid-template-columns:44px minmax(0,1fr) auto auto;align-items:center;gap:14px;border:1px solid var(--soft-line);border-radius:8px;padding:12px}.admin-grid--two{grid-template-columns:repeat(2,minmax(0,1fr))}.admin-project-order{display:flex;gap:6px}.admin-project-order button:disabled{cursor:not-allowed;opacity:.42}.admin-project-row .project-logo{--project-row-height: 44px}.admin-project-row h3{font-size:1rem;line-height:1.2}.admin-project-row p{display:-webkit-box;margin-top:3px;overflow:hidden;color:#4c5465;font-size:.92rem;-webkit-box-orient:vertical;-webkit-line-clamp:2}.admin-form{display:grid;gap:18px}.admin-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px}.admin-form label,.admin-login label{display:grid;gap:7px;color:#384055;font-size:.9rem;font-weight:600}.admin-form input,.admin-form select,.admin-form textarea,.admin-login input{width:100%;border:1px solid #bfc3cf;border-radius:6px;background:#fff;color:var(--foreground);font:inherit;font-weight:400;padding:10px 12px}.admin-form textarea{resize:vertical}.admin-logo-preview{width:88px;height:88px;border-radius:6px;object-fit:contain}.admin-login{display:grid;width:min(100%,420px);gap:18px;padding:clamp(22px,4vw,34px)}.admin-home-link{color:var(--muted);font-weight:600}.admin-message,.admin-muted{margin-bottom:18px;color:#384055;font-weight:600}@media(max-width:900px){.home-page{overflow:visible;padding:28px}.site-shell{display:grid;grid-template-columns:minmax(0,1fr) auto;grid-template-areas:"profile profile" "bio bio" "logo logo" "projects contact";min-height:auto;gap:36px;align-items:start}.corner,.site-logo-wrap{position:static;width:100%}.site-logo-wrap{min-height:34svh;margin:16px 0}.site-logo{width:min(70vw,380px);max-height:34svh}.corner--top-left{grid-area:profile}.profile-intro{justify-content:space-between}.profile-intro__portrait{order:2}.corner--top-right{grid-area:bio}.site-logo-wrap{grid-area:logo}.corner--bottom-left{grid-area:projects}.corner--bottom-right{grid-area:contact;justify-self:end;width:auto}.bio-block{max-width:min(100%,36ch);text-align:left}.projects-panel{width:min(62vw,280px)}.contact-panel{text-align:right}.social-links{flex-direction:column;align-items:flex-end;justify-content:flex-end;gap:14px}.admin-layout{grid-template-columns:1fr}.admin-sidebar,.admin-panel+.admin-panel{grid-column:auto}.admin-sidebar{position:static}.admin-grid{grid-template-columns:1fr}.admin-project-row{grid-template-columns:44px minmax(0,1fr)}.admin-project-order{grid-column:2}.admin-project-row button{grid-column:2;justify-self:start}}@media(max-width:520px){.home-page{padding:22px}.profile-intro{gap:14px}.projects-panel{width:min(62vw,260px)}.project-dialog{padding:18px}.project-dialog__header{gap:14px}}
