@import "https://fonts.googleapis.com/css2?family=Playfair+Display:wght@700;800;900&family=Syne:wght@400;600;700;800&family=DM+Sans:ital,wght@0,300;0,400;0,500;1,300&display=swap";@import "https://fonts.googleapis.com/css2?family=Playfair+Display:wght@700;800;900&family=Syne:wght@400;600;700;800&family=DM+Sans:ital,wght@0,300;0,400;0,500;1,300&display=swap";*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--font-display:"Syne", sans-serif;--font-body:"DM Sans", sans-serif;--text:#1a1a1a;--text-muted:#555;--bg:#faf8f5}html{scroll-behavior:smooth}body{background:var(--bg);color:var(--text);font-family:var(--font-body);font-weight:300;line-height:1.6;overflow-x:hidden}h1,h2,h3{font-family:var(--font-display)}a{color:inherit;text-decoration:none}.dock{z-index:100;-webkit-backdrop-filter:blur(24px)saturate(180%);background:linear-gradient(135deg,#3c3c3c80 0%,#1e1e1e4d 50%,#3c3c3c66 100%);border:1px solid #ffffff1a;border-radius:999px;align-items:center;gap:.25rem;padding:.4rem .75rem;display:flex;position:fixed;bottom:2rem;left:50%;transform:translate(-50%);box-shadow:inset 0 1px #ffffff1a,inset 0 -1px #0003,0 4px 16px #0000004d}.dock__item{letter-spacing:.04em;color:#fff;cursor:pointer;background:0 0;border:none;border-radius:999px;justify-content:center;align-items:center;padding:.4rem .85rem;font-family:Syne,sans-serif;font-size:.8rem;font-weight:600;transition:background .2s,color .2s;display:flex;position:relative}.dock__item:hover{color:#fff;background:#ffffff1a}.dock__item.active{color:#fff;background:#00000026;font-weight:700}@media (width<=768px){.dock{bottom:1.5rem}.dock__item{padding:.35rem .65rem;font-size:.72rem}}.hero{background:var(--bg);max-width:760px;min-height:100vh;margin:0 auto;padding:4rem 3rem;position:relative}.hero__photo-wrap{width:140px;height:140px;margin-bottom:2.5rem;position:relative}.hero__photo{object-fit:cover;border-radius:12px;width:140px;height:140px;display:block}.hero__name-wrap{margin-top:1.5rem;margin-bottom:.75rem}.hero__name-svg{width:clamp(200px,45vw,520px);overflow:visible}.hero__name-text{fill:none;stroke:var(--text);stroke-width:1.5px;font-family:Playfair Display,serif;font-size:96px;font-weight:900}.name-letter{fill:none;fill-opacity:0}.hero__tagline{color:var(--text-muted);margin-top:.25rem;font-family:Syne,sans-serif;font-size:clamp(.9rem,2.5vw,1.2rem)}.hero__divider{background:var(--text);border-radius:2px;width:40px;height:3px;margin-bottom:2.5rem}.hero__bio{color:var(--text);margin-bottom:1.25rem;font-size:1.15rem;line-height:1.9}.hero__link{color:var(--text);border-bottom:1px solid var(--text);padding-bottom:1px;transition:opacity .2s}.hero__link:hover{opacity:.75}.hero__inline-logo-link{color:var(--text);border-bottom:none;align-items:center;gap:.35rem;display:inline-flex}.hero__inline-logo-link:hover{opacity:1}.hero__inline-logo-wrap{justify-content:center;align-items:center;display:inline-flex;position:relative}.hero__inline-logo{object-fit:contain;vertical-align:middle;border-radius:6px;width:30px;height:30px;transition:transform .2s}.hero__inline-circle{display:none}.hero__inline-logo-link:hover .hero__inline-logo{transform:scale(1.2)translateY(-3px)}.hero__contact{border-top:1px solid #0000001a;flex-direction:column;gap:.75rem;margin-top:3rem;padding-top:2rem;display:flex}.hero__contact-link{color:var(--text);font-size:1.05rem;text-decoration:none;transition:opacity .2s}.hero__contact-link span{color:#ff9500}.hero__contact-link:hover{opacity:.7}.projects{background:var(--bg);width:100%;padding:8rem 0;position:relative;overflow:hidden}.projects__inner{max-width:1100px;margin:0 auto;padding:0 3rem}.projects__header{opacity:0;margin-bottom:2rem;transition:opacity .6s,transform .6s;transform:translateY(30px)}.projects__header.in-view{opacity:1;transform:translateY(0)}.projects__header-divider{background:#0000001a;width:100%;height:1px;margin-top:1.5rem}.projects__list{flex-direction:column;gap:2rem;margin-top:3rem;display:flex}.project-card{opacity:0;background:#fff;border:1px solid #00000014;border-radius:16px;transition:opacity .7s,transform .7s cubic-bezier(.34,1.56,.64,1);overflow:hidden;transform:translateY(60px);box-shadow:0 4px 20px #0000000d}.project-card.in-view{opacity:1;transform:translateY(0)}.project-card:hover{border-color:#a78bda;transition:border-color .2s,box-shadow .2s;box-shadow:0 8px 32px #a78bda26}.project-card__inner{grid-template-columns:1fr 1fr;min-height:340px;display:grid}.project-card__left{flex-direction:column;order:1;gap:.5rem;padding:2.5rem;display:flex}.project-card__top-row{align-items:center;gap:.75rem;margin-bottom:.25rem;display:flex}.project-card__number{color:var(--text-muted);letter-spacing:.1em;font-family:Syne,sans-serif;font-size:.85rem;font-weight:700}.project-card__status{letter-spacing:.08em;text-transform:uppercase;color:#a78bda;border:1px solid #a78bda;border-radius:999px;align-items:center;gap:.4rem;padding:.2rem .65rem;font-family:Syne,sans-serif;font-size:.7rem;font-weight:600;display:inline-flex}.project-card__status-dot{background:#a78bda;border-radius:50%;width:6px;height:6px}.project-card__date{color:var(--text-muted);font-family:Syne,sans-serif;font-size:.8rem}.project-card__type{letter-spacing:.2em;text-transform:uppercase;color:var(--text-muted);margin-bottom:.25rem;font-size:.75rem}.project-card__title{color:#111;margin-bottom:.5rem;font-family:Playfair Display,serif;font-size:1.5rem;font-weight:800;line-height:1.3}.project-card__tags{flex-wrap:wrap;gap:.4rem;margin-bottom:.5rem;display:flex}.project-card__tag{letter-spacing:.08em;color:#a78bda;background:#a78bda0f;border:1px solid #a78bda66;border-radius:999px;padding:.25rem .7rem;font-size:.7rem}.project-card__metrics{gap:2rem;margin-top:auto;padding-top:1rem;display:flex}.project-card__metric{flex-direction:column;gap:.2rem;display:flex}.project-card__metric-value{color:#111;font-family:Playfair Display,serif;font-size:1.75rem;font-weight:800;line-height:1}.project-card__metric-label{color:var(--text-muted);font-size:.75rem;line-height:1.3}.project-card__link{color:#a78bda;letter-spacing:.05em;font-family:Syne,sans-serif;font-size:.85rem;font-weight:600;transition:opacity .2s}.project-card__link:hover{opacity:.7}.project-card__right{background:linear-gradient(135deg,#f5f5f5,#ececec);order:2;justify-content:center;align-items:center;display:flex;position:relative}.project-card__placeholder{justify-content:center;align-items:center;width:100%;height:100%;display:flex}.project-card__placeholder-num{color:#0000000f;font-family:Playfair Display,serif;font-size:6rem;font-weight:800}.project-card__arrow{color:#111;background:#fff;border:1px solid #0000001a;border-radius:50%;justify-content:center;align-items:center;width:42px;height:42px;font-size:1.1rem;text-decoration:none;transition:background .2s,transform .2s,border-color .2s;display:flex;position:absolute;bottom:1.5rem;right:1.5rem;box-shadow:0 2px 8px #00000014}.project-card:hover .project-card__arrow{color:#fff;background:#a78bda;border-color:#a78bda;transform:scale(1.1)}.projects .section-label{letter-spacing:.2em;text-transform:uppercase;color:#000;margin-bottom:.5rem;font-size:.75rem}.projects .section-title{color:var(--text);font-family:Playfair Display,serif;font-size:clamp(2.5rem,6vw,4.5rem);font-weight:900;line-height:1.1}.title-char{opacity:0;color:var(--text);display:inline-block}.wave{z-index:50;pointer-events:none;opacity:1;position:absolute;inset:0;overflow:hidden}.wave__svg{width:100%;height:100%;position:absolute;inset:0}.wave__path{transition:none}@media (width<=768px){.project-card__inner{grid-template-columns:1fr}.project-card__left{order:1;padding:1.75rem}.project-card__right{order:2;min-height:220px}.projects__inner{padding:0 1.5rem}}.story{background:var(--bg);width:100%;padding:8rem 0}.story__inner{max-width:1100px;margin:0 auto;padding:0 3rem}.story__header{margin-bottom:5rem}.story__eyebrow{letter-spacing:.2em;text-transform:uppercase;color:#000;margin-bottom:.5rem;font-size:.75rem}.story__heading{color:var(--text);margin-bottom:1.5rem;font-family:Playfair Display,serif;font-size:clamp(2.5rem,6vw,4.5rem);font-weight:900;line-height:1.1}.story__divider{background:#0000001a;width:100%;height:1px}.story__body{grid-template-columns:1fr 1fr;align-items:start;gap:6rem;display:grid}.story__left{flex-direction:column;gap:2.5rem;display:flex}.story__bio{flex-direction:column;gap:1.25rem;display:flex}.story__bio p{color:var(--text);font-size:1.05rem;line-height:1.85}.story__cv-btn{letter-spacing:.08em;color:var(--text);border:1px solid var(--text);border-radius:999px;align-items:center;gap:.4rem;width:fit-content;padding:.5rem 1.25rem;font-family:Syne,sans-serif;font-size:.85rem;font-weight:600;text-decoration:none;transition:background .2s,color .2s;display:inline-flex}.story__cv-btn:hover{background:var(--text);color:var(--bg)}.story__right{flex-direction:column;gap:3rem;display:flex}.story__section{flex-direction:column;display:flex}.story__section-label{letter-spacing:.25em;text-transform:uppercase;color:var(--text-muted);margin-bottom:1rem;font-size:.7rem}.story__row{opacity:0;border-bottom:1px solid #00000014;justify-content:space-between;align-items:flex-start;padding:1rem 0;transition:opacity .5s,transform .5s;display:flex;transform:translateY(16px)}.story__row.in-view{opacity:1;transform:translateY(0)}.story__row-left{flex-direction:column;gap:.2rem;display:flex}.story__row-title{color:var(--text);font-family:Playfair Display,serif;font-size:1rem;font-weight:700}.story__row-sub{color:var(--text-muted);font-size:.85rem}.story__row-date{color:var(--text-muted);white-space:nowrap;padding-left:1rem;font-family:Syne,sans-serif;font-size:.8rem}.story__stack{width:100%;margin-top:4rem}.story__stack-headline{color:var(--text);letter-spacing:-.02em;flex-wrap:wrap;gap:.5rem;margin-top:3rem;margin-bottom:2rem;font-family:Playfair Display,serif;font-size:clamp(2rem,5vw,3.5rem);font-weight:800;line-height:1.2;display:flex}.story__stack-word{display:inline-block}.story__stack-grid{grid-template-columns:repeat(3,1fr);align-items:start;gap:1.5rem;display:grid}.story__stack-category{opacity:0;flex-direction:column;gap:.5rem;display:flex}.story__stack-label{letter-spacing:.25em;text-transform:uppercase;color:#1a1a1a;width:100%;font-size:.85rem;display:block}.story__stack-tags{flex-wrap:wrap;gap:.4rem;display:flex}.story__stack-tag{color:#1a1a1a;cursor:default;white-space:nowrap;background:0 0;border:2px dotted #0000004d;border-radius:12px;padding:.4rem .85rem;font-family:Syne,sans-serif;font-size:1rem;font-weight:500;transition:border-color .2s,color .2s}.story__stack-tag:hover{color:#a78bda;border-color:#a78bda}@media (width<=768px){.story{padding:4rem 0}.story__inner{padding:0 1.5rem}.story__header{margin-bottom:1rem}.story__body{grid-template-columns:1fr;gap:2rem}.story__stack-grid{grid-template-columns:1fr}.story__stack{margin-top:6rem}.story__stack-headline{margin-bottom:.5rem;font-size:clamp(2rem,8vw,3rem)}}.footer{background:var(--bg);border-top:1px solid #0000001a;max-width:1100px;margin:0 auto;padding:3rem}.footer__inner{justify-content:space-between;align-items:center;margin-bottom:2rem;display:flex}.footer__name{color:var(--text);font-family:Playfair Display,serif;font-size:clamp(1.5rem,4vw,2.5rem);font-weight:900}.footer__surprise{letter-spacing:.08em;color:#a78bda;cursor:pointer;background:0 0;border:1.5px solid #a78bda;border-radius:999px;padding:.6rem 1.4rem;font-family:Syne,sans-serif;font-size:.85rem;font-weight:600;transition:background .2s,color .2s,transform .2s}.footer__surprise:hover{color:#fff;background:#a78bda;transform:scale(1.05)}.footer__copy{color:var(--text-muted);font-family:Syne,sans-serif;font-size:.75rem}@media (width<=768px){.footer{padding:2rem 1.5rem}.footer__inner{flex-direction:column;align-items:flex-start;gap:1.5rem}}.easter__overlay{z-index:9999;background:#1a0f0a;justify-content:center;align-items:center;animation:.4s easterFadeIn;display:flex;position:fixed;inset:0}@keyframes easterFadeIn{0%{opacity:0}to{opacity:1}}.easter__rain{pointer-events:none;position:absolute;inset:0;overflow:hidden}.easter__bear-drop{-webkit-user-select:none;user-select:none;pointer-events:none;animation:linear infinite bearFall;position:absolute;top:-40px}@keyframes bearFall{0%{opacity:1;transform:translateY(-40px)rotate(0)}to{opacity:.4;transform:translateY(110vh)rotate(360deg)}}.easter__content{z-index:2;text-align:center;flex-direction:column;align-items:center;gap:1.5rem;padding:2rem;display:flex;position:relative}.easter__koda{object-fit:contain;filter:drop-shadow(0 8px 32px #8b5e3c99);border-radius:24px;width:120px;height:120px}.easter__message{color:#fff;font-family:Playfair Display,serif;font-size:clamp(2rem,6vw,3.5rem);font-weight:900;line-height:1.1}.easter__sub{color:#8b5e3c;letter-spacing:.08em;font-family:Syne,sans-serif;font-size:1rem}.easter__close{letter-spacing:.08em;color:#fff;cursor:pointer;background:0 0;border:1.5px solid #8b5e3c;border-radius:999px;margin-top:.5rem;padding:.6rem 1.6rem;font-family:Syne,sans-serif;font-size:.85rem;font-weight:600;transition:background .2s,color .2s,transform .2s}.easter__close:hover{color:#fff;background:#8b5e3c;transform:scale(1.05)}.loading{z-index:999;background:#000;justify-content:center;align-items:center;display:flex;position:fixed;inset:0;overflow:hidden}.loading__letters{z-index:2;align-items:center;gap:.5rem;display:flex;position:relative}.loading__letter{color:#fff;font-family:Playfair Display,serif;font-size:clamp(4rem,12vw,8rem);font-weight:800;display:inline-block}.loading__square{z-index:1;transform-origin:50%;background:#fff;width:60px;height:60px;position:absolute}.app-main{transition:opacity .3s,transform .3s}.app-main--out{opacity:0;transform:translateY(8px)}.app-main--in{opacity:1;transform:translateY(0)}
