.topbar{position:fixed;z-index:70;top:calc(20px + var(--safe-top));left:clamp(16px,4vw,58px);right:clamp(16px,4vw,58px);display:flex;align-items:center;justify-content:space-between;gap:22px;pointer-events:none}.topbar>*{pointer-events:auto}.brand{display:flex;align-items:baseline;gap:10px;white-space:nowrap}.brand span{font-weight:850;letter-spacing:-.04em}.brand small{font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted)}.navdots{display:flex;align-items:center;gap:8px}.navdots button{position:relative;height:36px;min-width:36px;border:1px solid var(--hairline);background:rgba(255,255,255,.36);overflow:hidden;transition:min-width .36s var(--ease),background .36s var(--ease),border-color .36s var(--ease)}.navdots button span{display:grid;place-items:center;width:34px;height:34px;font-size:11px;font-weight:800}.navdots button b{position:absolute;left:36px;top:50%;transform:translateY(-50%);font-size:11px;text-transform:uppercase;letter-spacing:.12em;opacity:0;color:var(--muted);transition:opacity .25s var(--ease)}.navdots button.is-current{min-width:88px;background:rgba(255,255,255,.72);border-color:rgba(75,184,239,.42)}.navdots button.is-current b{opacity:1}.counter{font-size:12px;font-weight:800;letter-spacing:.1em;color:var(--muted);display:flex;align-items:center;gap:9px}.counter i{display:block;width:34px;height:1px;background:var(--hairline)}
.stage{position:relative;z-index:10;width:100vw;height:calc(var(--vh)*100);overflow:hidden;perspective:1400px}.page{position:absolute;inset:0;min-height:calc(var(--vh)*100);padding:calc(90px + var(--safe-top)) clamp(18px,5vw,82px) calc(44px + var(--safe-bottom));opacity:0;visibility:hidden;pointer-events:none;transform-style:preserve-3d}.page.is-active{opacity:1;visibility:visible;pointer-events:auto}.page__inner{position:relative;width:100%;height:100%;max-width:1500px;margin:0 auto}.page-scroll{overflow-y:auto;overscroll-behavior:contain;-webkit-overflow-scrolling:touch;scrollbar-width:thin}.page-scroll::-webkit-scrollbar{width:4px}.page-scroll::-webkit-scrollbar-thumb{background:rgba(16,35,49,.22)}
.intro-grid{display:grid;grid-template-columns:minmax(0,1.16fr) minmax(320px,.84fr);grid-template-rows:1fr auto;gap:clamp(24px,5vw,80px);align-items:center}.intro-main{max-width:880px}.intro-text{max-width:670px;margin-top:28px}.intro-actions{display:flex;flex-wrap:wrap;gap:18px;margin-top:30px}.intro-card{align-self:center;justify-self:end;width:min(440px,100%);padding:28px;border:1px solid var(--hairline);background:rgba(255,255,255,.54);box-shadow:var(--shadow);position:relative}.card-topline{position:absolute;left:28px;right:28px;top:22px;height:1px;background:linear-gradient(90deg,var(--ink),transparent)}.intro-card p{margin:26px 0 10px;color:var(--muted);font-size:13px}.intro-card h2{margin:0 0 34px;font-size:clamp(26px,3vw,44px);letter-spacing:-.05em;line-height:1}.intro-card dl{margin:0;display:grid;gap:18px}.intro-card div{display:grid;grid-template-columns:86px 1fr;gap:14px;border-top:1px solid var(--hairline-soft);padding-top:14px}.intro-card dt{font-size:11px;text-transform:uppercase;letter-spacing:.15em;color:var(--muted)}.intro-card dd{margin:0;font-size:14px;line-height:1.6}.intro-strip{grid-column:1/-1;border-top:1px solid var(--hairline);border-bottom:1px solid var(--hairline);display:flex;gap:34px;overflow:hidden;padding:13px 0;color:rgba(16,35,49,.55);font-size:12px;text-transform:uppercase;letter-spacing:.18em}.intro-strip span{white-space:nowrap;animation:strip 24s linear infinite}@keyframes strip{to{transform:translateX(-220px)}}
.profile-grid{display:grid;grid-template-columns:minmax(240px,.72fr) minmax(0,1.18fr);gap:clamp(30px,6vw,96px);align-items:center}.profile-photo{position:relative;align-self:center;border:1px solid var(--hairline);background:#fff;padding:12px;box-shadow:var(--shadow);transform:rotate(-2deg)}.profile-photo img{aspect-ratio:4/5;width:100%;object-fit:cover;filter:saturate(.96) contrast(.98)}.profile-photo span{display:block;margin-top:10px;color:var(--muted);font-size:11px;text-transform:uppercase;letter-spacing:.12em}.profile-copy{max-width:880px}.profile-copy .body{margin-top:26px;max-width:740px}.note-list{display:grid;gap:14px;margin-top:34px}.note-list article{display:grid;grid-template-columns:54px 1fr;gap:18px;border-top:1px solid var(--hairline);padding-top:16px}.note-list b{font-size:12px;color:var(--sky-2)}.note-list span{line-height:1.75;color:#475f70}.profile-index{position:absolute;right:0;bottom:0;font-weight:900;font-size:clamp(110px,18vw,260px);letter-spacing:-.1em;line-height:.72;color:rgba(16,35,49,.045);z-index:-1}
.stack-grid{display:grid;grid-template-columns:minmax(0,.86fr) minmax(380px,1.14fr);gap:clamp(30px,5vw,80px);align-items:center}.stack-title{align-self:center}.stack-title .headline{max-width:660px}.stack-board{border-top:1px solid var(--hairline);border-bottom:1px solid var(--hairline)}.stack-row{display:grid;grid-template-columns:150px minmax(0,1fr);gap:22px;min-height:92px;padding:22px 0;border-bottom:1px solid var(--hairline-soft);align-items:center;animation-delay:calc(var(--n)*70ms + 100ms)!important}.stack-row:last-child{border-bottom:0}.stack-row span{font-size:12px;text-transform:uppercase;letter-spacing:.14em;color:var(--muted)}.stack-row b{font-size:clamp(20px,2.5vw,34px);letter-spacing:-.045em;font-weight:820}.stack-row em{grid-column:2;font-style:normal;color:#536a78;line-height:1.6}.stack-aside{position:absolute;left:0;bottom:0;width:min(360px,42vw);border-left:3px solid var(--mint-2);padding-left:18px}.stack-aside p{margin:0 0 10px;color:var(--muted);font-size:12px;text-transform:uppercase;letter-spacing:.14em}.stack-aside strong{font-size:18px;line-height:1.5;font-weight:720}
.works-grid{display:grid;grid-template-rows:auto 1fr auto;gap:26px}.works-head{max-width:850px}.works-head .body{margin-top:20px;max-width:720px}.work-strip{display:grid;grid-auto-flow:column;grid-auto-columns:minmax(320px,30vw);gap:18px;align-items:stretch;overflow-x:auto;overflow-y:hidden;overscroll-behavior-x:contain;scroll-snap-type:x mandatory;scrollbar-width:none;padding:6px 18vw 24px 0}.work-strip::-webkit-scrollbar{display:none}.work-card{scroll-snap-align:start;min-height:min(52vh,430px);display:flex;flex-direction:column;justify-content:space-between;border:1px solid var(--hairline);background:rgba(255,255,255,.56);padding:24px;position:relative;overflow:hidden;transition:transform .36s var(--ease),background .36s var(--ease)}.work-card:before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:linear-gradient(var(--sky),var(--mint));transform:scaleY(.2);transform-origin:top;transition:transform .42s var(--ease)}.work-card:hover{transform:translateY(-8px);background:#fff}.work-card:hover:before{transform:scaleY(1)}.work-card span{font-size:12px;color:var(--muted);letter-spacing:.12em}.work-card h3{font-size:clamp(30px,4vw,58px);line-height:.94;letter-spacing:-.06em;margin:30px 0 18px}.work-card p{line-height:1.75;color:#516878;margin:0}.work-card i{font-style:normal;text-transform:uppercase;letter-spacing:.13em;font-size:11px;color:var(--sky-2);margin-top:34px}.drag-note{justify-self:end;font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);border-top:1px solid var(--hairline);padding-top:10px}
.map-grid{display:grid;grid-template-columns:minmax(360px,1.05fr) minmax(0,.95fr);gap:clamp(26px,5vw,80px);align-items:center}.map-paper{position:relative;min-height:min(58vh,560px);border:1px solid var(--hairline);background:linear-gradient(90deg,rgba(16,35,49,.045) 1px,transparent 1px) 0 0/34px 34px,linear-gradient(0deg,rgba(16,35,49,.04) 1px,transparent 1px) 0 0/34px 34px,rgba(255,255,255,.55);box-shadow:var(--shadow);overflow:hidden}.map-paper svg{position:absolute;inset:0;width:100%;height:100%}.map-paper path{fill:none;stroke:rgba(16,35,49,.42);stroke-width:.45;stroke-dasharray:2.4 2.1;animation:dash 7s linear infinite}.city{position:absolute;z-index:2;transform:translate(-50%,-50%);padding:7px 9px;background:#fff;border:1px solid var(--hairline);font-size:11px;text-transform:uppercase;letter-spacing:.08em;box-shadow:0 10px 24px rgba(40,90,120,.08)}.city:before{content:"";position:absolute;left:50%;top:50%;width:7px;height:7px;border-radius:50%;background:var(--sky-2);transform:translate(-50%,-50%);opacity:.26;animation:pulse 2.2s ease-in-out infinite}.city--hk{left:18%;top:56%}.city--la{left:82%;top:62%}.city--sjc{left:74%;top:47%}.city--fra{left:50%;top:53%}.city--tky{left:68%;top:46%}.city--sg{left:42%;top:64%}@keyframes dash{to{stroke-dashoffset:-32}}@keyframes pulse{50%{width:44px;height:44px;opacity:.06}}.map-copy .body{margin-top:24px;max-width:680px}.plain-list{list-style:none;padding:0;margin:32px 0 0;display:grid;gap:13px}.plain-list li{display:flex;gap:16px;border-top:1px solid var(--hairline-soft);padding-top:14px;color:#4d6474}.plain-list span{font-size:12px;color:var(--sky-2);font-weight:800}
.contact-grid{display:grid;grid-template-columns:minmax(0,1fr) minmax(340px,.72fr);gap:clamp(28px,5vw,80px);align-items:center}.contact-panel{border-top:1px solid var(--hairline);border-bottom:1px solid var(--hairline)}.contact-row{display:grid;grid-template-columns:92px 1fr;gap:18px;padding:22px 0;border-bottom:1px solid var(--hairline-soft);align-items:center}.contact-row:last-child{border-bottom:0}.contact-row span{font-size:12px;text-transform:uppercase;letter-spacing:.14em;color:var(--muted)}.contact-row b{font-size:clamp(18px,2.2vw,30px);letter-spacing:-.04em;overflow-wrap:anywhere}.site-foot{position:absolute;left:0;bottom:0;color:var(--muted);font-size:11px;text-transform:uppercase;letter-spacing:.18em;border-top:1px solid var(--hairline);padding-top:10px}
@media (max-width:1100px){.navdots button:not(.is-current){min-width:32px}.navdots button:not(.is-current) b{display:none}.intro-grid,.profile-grid,.stack-grid,.map-grid,.contact-grid{grid-template-columns:1fr}.intro-card{justify-self:start}.profile-photo{width:min(360px,70vw)}.stack-aside{position:relative;width:auto;margin-top:26px}.work-strip{grid-auto-columns:minmax(300px,44vw)}}

@media (max-width:760px){
  .topbar{
    top:calc(12px + var(--safe-top));
    left:14px;
    right:14px;
    gap:10px;
  }
  .brand{font-size:14px}
  .brand small,.counter{display:none}
  .navdots{gap:5px;max-width:62vw;overflow-x:auto;scrollbar-width:none}
  .navdots::-webkit-scrollbar{display:none}
  .navdots button{height:28px;min-width:28px;background:rgba(255,255,255,.62)}
  .navdots button span{width:26px;height:26px;font-size:10px}
  .navdots button.is-current{min-width:54px}
  .navdots button b{display:none}

  .page{
    padding:calc(76px + var(--safe-top)) 16px calc(54px + var(--safe-bottom));
    overflow-y:auto;
    overscroll-behavior:contain;
    -webkit-overflow-scrolling:touch;
    touch-action:pan-y;
  }
  .page--works{overflow-y:auto;touch-action:pan-y}
  .page__inner{
    height:auto;
    min-height:calc((var(--vh)*100) - 130px - var(--safe-top) - var(--safe-bottom));
    overflow:visible;
    padding-bottom:18px;
  }
  .page-scroll{overflow:visible;padding-right:0}

  .headline{
    font-size:clamp(38px,11.5vw,72px);
    line-height:.94;
    letter-spacing:-.055em;
  }
  .headline--xl{
    font-size:clamp(72px,22vw,124px);
    line-height:.8;
  }
  .body,.intro-text{
    font-size:15px;
    line-height:1.78;
  }
  .kicker{margin-bottom:14px}

  .intro-grid{
    display:grid;
    grid-template-columns:1fr;
    grid-template-rows:auto auto auto;
    gap:28px;
    align-content:start;
  }
  .intro-text{margin-top:20px;max-width:none}
  .intro-actions{gap:14px;margin-top:22px}
  .intro-card{
    justify-self:stretch;
    width:100%;
    margin-top:0;
    padding:22px 20px;
  }
  .intro-card h2{font-size:clamp(28px,8vw,38px);margin-bottom:24px}
  .intro-card dl{gap:13px}
  .intro-card div{grid-template-columns:86px 1fr;gap:12px;padding-top:12px}
  .intro-strip{
    position:relative;
    left:auto;
    right:auto;
    bottom:auto;
    font-size:10px;
    gap:24px;
    margin-top:0;
  }

  .profile-grid,
  .stack-grid,
  .map-grid,
  .contact-grid{
    display:block;
    min-height:0;
  }
  .profile-photo{
    width:min(56vw,220px);
    margin:0 0 28px;
    transform:rotate(-1.5deg);
  }
  .profile-copy .body{margin-top:18px}
  .note-list{gap:12px;margin-top:26px}
  .note-list article{
    grid-template-columns:38px 1fr;
    gap:12px;
    padding-top:14px;
  }
  .note-list span{font-size:14px;line-height:1.68}
  .profile-index{display:none}

  .stack-board{margin-top:28px}
  .stack-row{
    grid-template-columns:1fr;
    gap:8px;
    min-height:auto;
    padding:18px 0;
  }
  .stack-row b{font-size:clamp(22px,6.5vw,34px);line-height:1.05}
  .stack-row em{grid-column:1;font-size:14px;line-height:1.62}
  .stack-aside{
    position:relative;
    width:auto;
    margin-top:26px;
    padding-left:14px;
  }
  .stack-aside strong{font-size:15.5px;line-height:1.55}

  .works-grid{
    display:block;
    min-height:0;
  }
  .works-head .body{
    display:block;
    font-size:14px;
    line-height:1.68;
    margin-top:16px;
  }
  .work-strip{
    display:grid;
    grid-auto-flow:column;
    grid-auto-columns:minmax(78vw,300px);
    gap:12px;
    overflow-x:auto;
    overflow-y:hidden;
    overscroll-behavior-x:contain;
    scroll-snap-type:x mandatory;
    padding:22px 16vw 24px 0;
    margin-top:14px;
    touch-action:pan-x;
  }
  .work-card{
    min-height:360px;
    padding:20px;
  }
  .work-card h3{
    font-size:clamp(32px,10vw,46px);
    line-height:.98;
    margin:28px 0 16px;
  }
  .work-card p{font-size:14px;line-height:1.65}
  .drag-note{justify-self:start;margin-top:2px}

  .map-paper{
    min-height:320px;
    margin:24px 0 26px;
  }
  .city{font-size:9px;padding:5px 6px}
  .map-copy .body{margin-top:16px}
  .plain-list{margin-top:22px;gap:10px}
  .plain-list li{padding-top:11px;font-size:14px;line-height:1.5}

  .contact-panel{margin-top:30px}
  .contact-row{
    grid-template-columns:1fr;
    gap:6px;
    padding:18px 0;
  }
  .contact-row b{font-size:clamp(19px,6.3vw,30px)}
  .site-foot{
    position:relative;
    margin-top:30px;
    font-size:10px;
    line-height:1.6;
  }
}

@media (max-width:390px){
  .page{padding-left:14px;padding-right:14px}
  .headline{font-size:clamp(34px,11vw,56px)}
  .headline--xl{font-size:clamp(64px,21vw,104px)}
  .intro-card{padding:18px}
  .intro-card div{grid-template-columns:1fr;gap:4px}
  .profile-photo{width:min(58vw,190px)}
  .work-strip{grid-auto-columns:82vw}
  .work-card{min-height:340px}
  .map-paper{min-height:280px}
}

/* Page color pass: muted editorial accents, no glass glow */
.page{--page-accent:var(--sky);--page-accent-2:var(--mint);--page-wash:rgba(141,215,255,.10);--page-paper:rgba(255,255,255,.58)}
.page::before{content:"";position:absolute;inset:calc(72px + var(--safe-top)) clamp(10px,3vw,46px) calc(26px + var(--safe-bottom));pointer-events:none;z-index:-1;background:linear-gradient(90deg,var(--page-wash),transparent 28%),linear-gradient(180deg,transparent 0 68%,rgba(255,255,255,.38));border-left:1px solid color-mix(in srgb,var(--page-accent) 42%,transparent);opacity:.92}
.page__inner{z-index:1}.page--intro{--page-accent:#48bdf2;--page-accent-2:#b9f0cf;--page-wash:rgba(72,189,242,.13)}.page--profile{--page-accent:#9bdc7c;--page-accent-2:#d9f3a5;--page-wash:rgba(155,220,124,.13)}.page--stack{--page-accent:#6bb7ff;--page-accent-2:#ffe08b;--page-wash:rgba(255,224,139,.13)}.page--works{--page-accent:#ffb28f;--page-accent-2:#9edbff;--page-wash:rgba(255,178,143,.13)}.page--map{--page-accent:#74d4c1;--page-accent-2:#a9d8ff;--page-wash:rgba(116,212,193,.13)}.page--contact{--page-accent:#b6a6ff;--page-accent-2:#a7f0c0;--page-wash:rgba(182,166,255,.13)}
.kicker{display:flex;align-items:center;gap:10px;color:#516b7a}.kicker::before{content:"";width:22px;height:8px;background:linear-gradient(90deg,var(--page-accent),var(--page-accent-2));border:1px solid rgba(16,35,49,.10);flex:0 0 auto}.headline{position:relative}.headline::after{content:"";display:block;width:clamp(44px,7vw,92px);height:10px;margin-top:18px;background:linear-gradient(90deg,var(--page-accent),var(--page-accent-2));opacity:.72}.headline--xl::after{height:12px;margin-top:22px}.text-link{padding:0 4px;background:linear-gradient(transparent 62%,color-mix(in srgb,var(--page-accent) 22%,transparent) 0)}
.brand span{position:relative}.brand span::after{content:"";position:absolute;left:0;right:-4px;bottom:-5px;height:4px;background:linear-gradient(90deg,#8dd7ff,#c8f6d8);opacity:.65}.navdots button.is-current::after{content:"";position:absolute;left:0;right:0;bottom:0;height:3px;background:linear-gradient(90deg,#8dd7ff,#c8f6d8,#ffe08b)}
.intro-card{background:linear-gradient(135deg,rgba(255,255,255,.72),rgba(232,248,255,.66) 55%,rgba(242,255,246,.68));border-color:rgba(72,189,242,.34);box-shadow:0 18px 48px rgba(40,90,120,.08)}.card-topline{height:3px;background:linear-gradient(90deg,#48bdf2,#b9f0cf,#ffe08b,transparent)}.intro-card div:nth-child(1){border-color:rgba(72,189,242,.26)}.intro-card div:nth-child(2){border-color:rgba(155,220,124,.28)}.intro-card div:nth-child(3){border-color:rgba(255,224,139,.30)}.intro-strip{background:rgba(255,255,255,.24);border-top-color:rgba(72,189,242,.26);border-bottom-color:rgba(155,220,124,.25)}.intro-strip span:nth-child(3n+1){color:#318eb8}.intro-strip span:nth-child(3n+2){color:#5f9e65}.intro-strip span:nth-child(3n){color:#9a7a22}
.profile-photo{background:linear-gradient(#fff,#fff) padding-box,linear-gradient(135deg,#8dd7ff,#c8f6d8,#ffe08b) border-box;border:1px solid transparent}.profile-photo::before,.profile-photo::after{content:"";position:absolute;height:16px;width:84px;background:rgba(255,224,139,.74);border:1px solid rgba(16,35,49,.08);transform:rotate(-9deg);z-index:2}.profile-photo::before{left:18px;top:-9px}.profile-photo::after{right:22px;bottom:28px;background:rgba(141,215,255,.55);transform:rotate(8deg)}.note-list article{border-top-color:rgba(16,35,49,.10);background:linear-gradient(90deg,color-mix(in srgb,var(--page-accent) 9%,transparent),transparent 44%);padding-left:12px}.note-list article:nth-child(2){background:linear-gradient(90deg,rgba(255,224,139,.16),transparent 44%)}.note-list article:nth-child(3){background:linear-gradient(90deg,rgba(116,212,193,.15),transparent 44%)}.note-list b{display:inline-grid;place-items:center;width:34px;height:22px;background:#fff;border:1px solid color-mix(in srgb,var(--page-accent) 48%,rgba(16,35,49,.08));color:#2d7da3}.profile-index{color:rgba(92,175,146,.065)}
.stack-board{background:rgba(255,255,255,.24)}.stack-row{position:relative;padding-left:14px}.stack-row::before{content:"";position:absolute;left:0;top:22px;bottom:22px;width:4px;background:var(--row-color,#8dd7ff)}.stack-row:nth-child(1){--row-color:#8dd7ff}.stack-row:nth-child(2){--row-color:#c8f6d8}.stack-row:nth-child(3){--row-color:#ffe08b}.stack-row:nth-child(4){--row-color:#ffb28f}.stack-row:nth-child(5){--row-color:#b6a6ff}.stack-row span{color:#4f6979}.stack-aside{border-left-color:#ffe08b;background:linear-gradient(90deg,rgba(255,224,139,.18),transparent);padding-top:8px;padding-bottom:8px}
.work-card{background:linear-gradient(180deg,rgba(255,255,255,.68),rgba(255,255,255,.46));box-shadow:none}.work-card::after{content:"";position:absolute;right:18px;top:18px;width:86px;height:86px;background:var(--card-wash,rgba(141,215,255,.16));clip-path:polygon(0 0,100% 0,100% 64%,34% 100%,0 100%);z-index:-1}.work-card:nth-child(1){--card-wash:rgba(141,215,255,.22)}.work-card:nth-child(2){--card-wash:rgba(200,246,216,.25)}.work-card:nth-child(3){--card-wash:rgba(255,224,139,.24)}.work-card:nth-child(4){--card-wash:rgba(255,178,143,.23)}.work-card:before{background:linear-gradient(var(--page-accent),var(--page-accent-2))}.work-card:hover{background:rgba(255,255,255,.74)}.work-card span{display:inline-grid;place-items:center;width:34px;height:24px;border:1px solid rgba(16,35,49,.10);background:#fff;color:#315f73}.drag-note{border-top-color:rgba(255,178,143,.48);color:#6b777b}
.map-paper{background:linear-gradient(90deg,rgba(16,35,49,.04) 1px,transparent 1px) 0 0/34px 34px,linear-gradient(0deg,rgba(16,35,49,.035) 1px,transparent 1px) 0 0/34px 34px,linear-gradient(135deg,rgba(141,215,255,.18),transparent 35%),linear-gradient(315deg,rgba(200,246,216,.22),transparent 40%),rgba(255,255,255,.58);border-color:rgba(116,212,193,.38);box-shadow:0 18px 48px rgba(40,90,120,.07)}.map-paper path:nth-child(1){stroke:#3c91b8}.map-paper path:nth-child(2){stroke:#559f70}.map-paper path:nth-child(3){stroke:#b99130}.map-paper path:nth-child(4){stroke:#5f96d0}.city{background:rgba(255,255,255,.82)}.city:before{background:var(--page-accent)}.plain-list li{background:linear-gradient(90deg,rgba(116,212,193,.12),transparent 56%);padding-left:10px}.plain-list li:nth-child(2){background:linear-gradient(90deg,rgba(141,215,255,.13),transparent 56%)}.plain-list li:nth-child(3){background:linear-gradient(90deg,rgba(255,224,139,.15),transparent 56%)}
.contact-panel{background:rgba(255,255,255,.28)}.contact-row{position:relative;padding-left:12px}.contact-row::before{content:"";position:absolute;left:0;top:18px;bottom:18px;width:4px;background:var(--contact-color,#b6a6ff)}.contact-row:nth-child(1){--contact-color:#8dd7ff}.contact-row:nth-child(2){--contact-color:#c8f6d8}.contact-row:nth-child(3){--contact-color:#b6a6ff}.contact-row span{display:inline-block;width:max-content;padding:4px 8px;background:rgba(255,255,255,.66);border:1px solid rgba(16,35,49,.08);color:#536875}.site-foot{border-top-color:rgba(182,166,255,.38);background:linear-gradient(90deg,rgba(182,166,255,.12),transparent);padding-left:8px}

@media (max-width:760px){
  .page::before{inset:calc(58px + var(--safe-top)) 10px calc(22px + var(--safe-bottom));border-left-width:0;border-top:1px solid color-mix(in srgb,var(--page-accent) 34%,transparent);background:linear-gradient(180deg,var(--page-wash),transparent 30%)}
  .headline::after{width:58px;height:8px;margin-top:14px}.headline--xl::after{height:9px;margin-top:16px}.kicker::before{width:18px;height:7px}.note-list article{padding-left:10px}.stack-row{padding-left:12px}.stack-row::before{top:18px;bottom:18px}.work-card::after{width:68px;height:68px;right:14px;top:14px}.contact-row{padding-left:12px}
}

/* 3D globe page: local country borders, muted color, no neon gloss */
.globe-grid{
  display:grid;
  grid-template-columns:minmax(320px,.86fr) minmax(440px,1.14fr);
  gap:clamp(28px,5vw,76px);
  align-items:center;
}
.globe-copy .body{margin-top:24px;max-width:680px}
.globe-node-list{
  list-style:none;
  padding:0;
  margin:30px 0 0;
  display:flex;
  flex-wrap:wrap;
  gap:9px;
  max-width:720px;
}
.globe-node-list li{
  border:1px solid rgba(16,35,49,.10);
  background:rgba(255,255,255,.58);
  padding:7px 10px;
  font-size:11px;
  letter-spacing:.09em;
  text-transform:uppercase;
  color:#486271;
}
.globe-node-list li:nth-child(3n+1){background:rgba(141,215,255,.16)}
.globe-node-list li:nth-child(3n+2){background:rgba(200,246,216,.18)}
.globe-node-list li:nth-child(3n){background:rgba(255,224,139,.18)}
.globe-card{
  position:relative;
  min-height:min(64vh,620px);
  border:1px solid rgba(116,212,193,.30);
  background:
    linear-gradient(90deg,rgba(255,255,255,.075) 1px,transparent 1px) 0 0/44px 44px,
    linear-gradient(0deg,rgba(255,255,255,.06) 1px,transparent 1px) 0 0/44px 44px,
    linear-gradient(135deg,rgba(141,215,255,.15),transparent 34%),
    linear-gradient(315deg,rgba(200,246,216,.12),transparent 38%),
    #061722;
  box-shadow:0 18px 50px rgba(14,54,76,.16);
  overflow:hidden;
  isolation:isolate;
}
.globe-card::before{
  content:"";
  position:absolute;
  inset:18px;
  border:1px solid rgba(211,246,255,.11);
  pointer-events:none;
  z-index:2;
}
.globe-card::after{
  content:"";
  position:absolute;
  left:0;
  right:0;
  bottom:0;
  height:35%;
  background:linear-gradient(180deg,transparent,rgba(5,20,29,.58));
  pointer-events:none;
  z-index:1;
}
.globe-viewport{
  position:absolute;
  inset:0;
  cursor:grab;
  touch-action:pan-y pinch-zoom;
  z-index:1;
}
.globe-viewport:active{cursor:grabbing}
.globe-viewport canvas{display:block;width:100%;height:100%}
.globe-toolbar,
.globe-caption{
  position:absolute;
  left:22px;
  right:22px;
  z-index:4;
  display:flex;
  justify-content:space-between;
  gap:18px;
  pointer-events:none;
  color:rgba(226,248,255,.72);
  font-size:10px;
  letter-spacing:.16em;
  text-transform:uppercase;
}
.globe-toolbar{top:20px}
.globe-caption{bottom:18px;color:rgba(226,248,255,.55)}
.globe-fallback{
  position:absolute;
  inset:0;
  z-index:3;
  display:grid;
  place-items:center;
  pointer-events:none;
  color:rgba(226,248,255,.64);
  font-size:12px;
  letter-spacing:.16em;
  text-transform:uppercase;
}
.globe-labels{
  position:absolute;
  inset:0;
  z-index:5;
  pointer-events:none;
}
.globe-label{
  position:absolute;
  left:0;
  top:0;
  min-width:max-content;
  padding:5px 7px 6px;
  border:1px solid rgba(220,250,255,.24);
  background:rgba(6,23,34,.64);
  color:#f6fdff;
  transform:translate3d(-999px,-999px,0);
  opacity:0;
  transition:opacity .22s var(--ease);
  box-shadow:0 10px 28px rgba(0,0,0,.18);
}
.globe-label::after{
  content:"";
  position:absolute;
  left:50%;
  top:100%;
  width:1px;
  height:13px;
  background:rgba(220,250,255,.40);
}
.globe-label b,
.globe-label small{display:block;line-height:1.1;white-space:nowrap}
.globe-label b{font-size:11px;font-weight:760;letter-spacing:.04em}
.globe-label small{margin-top:3px;font-size:8.5px;letter-spacing:.11em;text-transform:uppercase;color:rgba(226,248,255,.64)}

@media (max-width:1100px){
  .globe-grid{grid-template-columns:1fr;align-items:start}
  .globe-card{min-height:56vh}
}
@media (max-width:760px){
  .globe-grid{display:block;min-height:0}
  .globe-copy .body{margin-top:16px}
  .globe-node-list{margin-top:20px;gap:7px}
  .globe-node-list li{font-size:9.5px;padding:6px 8px}
  .globe-card{
    min-height:min(62vh,520px);
    margin:24px -16px 18px;
    border-left:0;
    border-right:0;
  }
  .globe-card::before{inset:14px;border-left:0;border-right:0}
  .globe-toolbar,.globe-caption{left:14px;right:14px;font-size:8.5px;gap:10px}
  .globe-caption{display:none}
  .globe-label{padding:4px 6px}
  .globe-label b{font-size:10px}
  .globe-label small{display:none}
}
@media (max-width:390px){
  .globe-card{min-height:56vh}
}


/* seamless globe polish: remove the hard text/map split, keep muted editorial colors */
.page--map{
  --page-accent:#67c7de;
  --page-accent-2:#a9ecc5;
  --page-wash:rgba(103,199,222,.105);
}
.page--map .page__inner.globe-grid{
  isolation:isolate;
}
.page--map .page__inner.globe-grid::before{
  content:"";
  position:absolute;
  inset:clamp(-10px,-1vw,-2px) clamp(-14px,-1vw,-4px);
  z-index:-1;
  background:
    linear-gradient(90deg,rgba(103,199,222,.10),transparent 38%),
    linear-gradient(180deg,rgba(169,236,197,.12),transparent 52%);
  border-top:1px solid rgba(103,199,222,.16);
  border-bottom:1px solid rgba(169,236,197,.14);
  pointer-events:none;
}
.globe-copy .headline{
  max-width:760px;
}
.globe-copy .body{
  color:#526a78;
}
.globe-node-list li{
  border-color:rgba(16,35,49,.09);
  background:rgba(255,255,255,.50);
}
.globe-card{
  background:
    linear-gradient(90deg,rgba(16,35,49,.035) 1px,transparent 1px) 0 0/42px 42px,
    linear-gradient(0deg,rgba(16,35,49,.028) 1px,transparent 1px) 0 0/42px 42px,
    radial-gradient(circle at 50% 50%,rgba(255,255,255,.70),rgba(255,255,255,.26) 36%,transparent 62%),
    linear-gradient(135deg,rgba(141,215,255,.26),transparent 42%),
    linear-gradient(315deg,rgba(200,246,216,.25),transparent 48%),
    #eaf8fc;
  border-color:rgba(103,199,222,.26);
  box-shadow:0 16px 46px rgba(40,90,120,.075);
}
.globe-card::before{
  border-color:rgba(16,35,49,.075);
}
.globe-card::after{
  height:34%;
  background:linear-gradient(180deg,transparent,rgba(236,250,254,.70));
}
.globe-toolbar,
.globe-caption{
  color:rgba(16,35,49,.52);
}
.globe-fallback{
  color:rgba(16,35,49,.54);
}
.globe-label{
  border-color:rgba(16,35,49,.14);
  background:rgba(255,255,255,.86);
  color:#132b3a;
  box-shadow:0 8px 22px rgba(40,90,120,.12);
}
.globe-label::after{
  background:rgba(16,35,49,.25);
}
.globe-label small{
  color:rgba(16,35,49,.48);
}

@media (max-width:1100px){
  .page--map .page__inner.globe-grid::before{
    inset:-6px 0;
  }
  .globe-grid{
    gap:22px;
  }
}

@media (max-width:760px){
  .page--map{
    padding-top:calc(96px + var(--safe-top));
  }
  .page--map .page__inner.globe-grid{
    display:flex;
    flex-direction:column;
    gap:18px;
    min-height:0;
    overflow-y:auto;
    overscroll-behavior:contain;
    padding:2px 0 calc(34px + var(--safe-bottom));
  }
  .page--map .page__inner.globe-grid::before{
    inset:0;
    background:
      linear-gradient(180deg,rgba(141,215,255,.16),rgba(200,246,216,.08) 42%,transparent 78%);
    border-top:1px solid rgba(103,199,222,.14);
    border-bottom:0;
  }
  .globe-copy{
    flex:0 0 auto;
  }
  .globe-copy .kicker{
    margin-bottom:14px;
  }
  .globe-copy .headline{
    font-size:clamp(36px,10.4vw,54px);
    line-height:.98;
    letter-spacing:-.052em;
    max-width:11em;
  }
  .globe-copy .body{
    margin-top:15px;
    font-size:14px;
    line-height:1.82;
    max-width:100%;
  }
  .globe-node-list{
    margin-top:16px;
    gap:7px;
  }
  .globe-node-list li{
    font-size:9px;
    padding:5px 7px;
    letter-spacing:.075em;
  }
  .globe-card{
    flex:0 0 auto;
    min-height:min(48vh,420px);
    margin:2px 0 14px;
    border-left:1px solid rgba(103,199,222,.22);
    border-right:1px solid rgba(103,199,222,.22);
    background:
      linear-gradient(90deg,rgba(16,35,49,.03) 1px,transparent 1px) 0 0/36px 36px,
      linear-gradient(0deg,rgba(16,35,49,.024) 1px,transparent 1px) 0 0/36px 36px,
      radial-gradient(circle at 50% 54%,rgba(255,255,255,.76),rgba(255,255,255,.30) 38%,transparent 68%),
      linear-gradient(180deg,rgba(141,215,255,.18),rgba(200,246,216,.14)),
      #edfaff;
    box-shadow:0 10px 30px rgba(40,90,120,.07);
  }
  .globe-card::before{
    inset:12px;
    border:1px solid rgba(16,35,49,.065);
  }
  .globe-card::after{
    height:28%;
    background:linear-gradient(180deg,transparent,rgba(237,250,255,.68));
  }
  .globe-toolbar{
    top:14px;
  }
  .globe-toolbar,.globe-caption{
    left:14px;
    right:14px;
    color:rgba(16,35,49,.50);
  }
  .globe-label{
    padding:4px 6px 5px;
    background:rgba(255,255,255,.90);
  }
}

@media (max-width:390px){
  .globe-copy .headline{
    font-size:clamp(33px,10vw,48px);
  }
  .globe-copy .body{
    font-size:13.5px;
  }
  .globe-card{
    min-height:44vh;
  }
}

/* Mobile globe visibility fix: show the globe near the top instead of hiding it below the text. */
@media (max-width:760px){
  .page--map .page__inner.globe-grid{
    display:flex;
    flex-direction:column;
    gap:14px;
    overflow-y:auto;
    overscroll-behavior:contain;
    padding-bottom:calc(34px + var(--safe-bottom));
  }
  .page--map .globe-copy{
    display:contents;
  }
  .page--map .globe-copy .kicker{
    order:1;
    width:100%;
    margin:0 0 6px;
  }
  .page--map .globe-copy .headline{
    order:2;
    width:100%;
    font-size:clamp(34px,9.8vw,50px);
    line-height:.96;
    margin:0;
  }
  .page--map .globe-card{
    order:3;
    width:100%;
    min-height:clamp(300px,43vh,390px);
    margin:6px 0 2px;
  }
  .page--map .globe-copy .body{
    order:4;
    width:100%;
    margin-top:8px;
    font-size:13.8px;
    line-height:1.72;
  }
  .page--map .globe-node-list{
    order:5;
    width:100%;
    margin-top:8px;
    gap:6px;
  }
  .globe-viewport{
    touch-action:pan-y pinch-zoom;
  }
  .globe-viewport canvas.globe-canvas{
    display:block;
    width:100%;
    height:100%;
  }
}

@media (max-width:390px){
  .page--map .globe-card{
    min-height:clamp(270px,40vh,350px);
  }
  .page--map .globe-copy .body{
    font-size:13.2px;
  }
}

/* Atlas map revision: replace the heavy sphere feeling with a lighter flat route board. */
.page--map{
  --page-accent:#63c2df;
  --page-accent-2:#9fe7bd;
  --page-wash:rgba(99,194,223,.10);
}
.page--map .globe-card{
  min-height:min(62vh,590px);
  background:
    linear-gradient(90deg,rgba(16,35,49,.030) 1px,transparent 1px) 0 0/40px 40px,
    linear-gradient(0deg,rgba(16,35,49,.026) 1px,transparent 1px) 0 0/40px 40px,
    linear-gradient(135deg,rgba(130,210,245,.18),transparent 44%),
    linear-gradient(315deg,rgba(176,240,198,.16),transparent 48%),
    #edfaff;
  border-color:rgba(77,172,205,.24);
  box-shadow:0 14px 38px rgba(40,90,120,.070);
}
.page--map .globe-card::before{
  inset:16px;
  border-color:rgba(16,35,49,.075);
  background:
    linear-gradient(90deg,rgba(99,194,223,.08),transparent 19%,transparent 81%,rgba(159,231,189,.08));
}
.page--map .globe-card::after{
  display:none;
}
.page--map .globe-viewport{
  touch-action:pan-y pinch-zoom;
}
.page--map .globe-label{
  border-color:rgba(16,35,49,.135);
  background:rgba(255,255,255,.82);
  color:#132b3a;
  box-shadow:0 7px 20px rgba(35,88,118,.10);
  backdrop-filter:none;
}
.page--map .globe-label::after{
  display:none;
}
.page--map .globe-label b{font-weight:720;letter-spacing:.03em}
.page--map .globe-label small{color:rgba(16,35,49,.45)}
.page--map .globe-toolbar span:first-child::before{
  content:"";
  display:inline-block;
  width:18px;
  height:1px;
  margin-right:9px;
  vertical-align:middle;
  background:#63c2df;
}
.page--map .globe-toolbar span:last-child::after{
  content:"";
  display:inline-block;
  width:18px;
  height:1px;
  margin-left:9px;
  vertical-align:middle;
  background:#9fe7bd;
}

@media (max-width:760px){
  .page--map .globe-card{
    min-height:clamp(315px,43vh,405px);
    background:
      linear-gradient(90deg,rgba(16,35,49,.028) 1px,transparent 1px) 0 0/34px 34px,
      linear-gradient(0deg,rgba(16,35,49,.024) 1px,transparent 1px) 0 0/34px 34px,
      linear-gradient(135deg,rgba(130,210,245,.18),transparent 48%),
      linear-gradient(315deg,rgba(176,240,198,.16),transparent 52%),
      #f0fbff;
  }
  .page--map .globe-card::before{
    inset:10px;
  }
  .page--map .globe-toolbar{
    top:14px;
  }
  .page--map .globe-label{
    padding:3px 5px 4px;
    max-width:82px;
    overflow:hidden;
    text-overflow:ellipsis;
  }
  .page--map .globe-label b{
    font-size:9.2px;
  }
}

/* Mobile scrollbar fix: keep native scrolling but remove the intrusive inner scrollbar track. */
@media (pointer:coarse), (max-width:760px){
  html,
  body,
  .stage,
  .page,
  .page__inner,
  .page-scroll,
  .page--map .page__inner.globe-grid,
  .work-strip,
  .native-x{
    scrollbar-width:none;
    -ms-overflow-style:none;
  }
  .page::-webkit-scrollbar,
  .page__inner::-webkit-scrollbar,
  .page-scroll::-webkit-scrollbar,
  .page--map .page__inner.globe-grid::-webkit-scrollbar,
  .work-strip::-webkit-scrollbar,
  .native-x::-webkit-scrollbar{
    width:0!important;
    height:0!important;
    display:none!important;
    background:transparent!important;
  }
  .page{
    overscroll-behavior-y:contain;
  }
  .page--map .page__inner.globe-grid{
    overscroll-behavior-y:contain;
    -webkit-overflow-scrolling:touch;
  }
}

/* Avoid accidental horizontal overflow from animated labels/large headings on narrow screens. */
@media (max-width:760px){
  .page{
    overflow-x:hidden;
  }
  .page__inner{
    max-width:100%;
  }
  .headline,
  .body,
  .intro-text{
    overflow-wrap:anywhere;
  }
  .globe-labels{
    overflow:hidden;
  }
}

/* Desktop scrollbar cleanup: keep the same scroll behavior, but hide browser bars and block accidental horizontal overflow. */
html,
body,
.stage,
.page,
.page__inner,
.page-scroll,
.work-strip,
.navdots,
.native-x,
.globe-viewport{
  scrollbar-width:none!important;
  -ms-overflow-style:none!important;
}
html::-webkit-scrollbar,
body::-webkit-scrollbar,
.stage::-webkit-scrollbar,
.page::-webkit-scrollbar,
.page__inner::-webkit-scrollbar,
.page-scroll::-webkit-scrollbar,
.work-strip::-webkit-scrollbar,
.navdots::-webkit-scrollbar,
.native-x::-webkit-scrollbar,
.globe-viewport::-webkit-scrollbar{
  width:0!important;
  height:0!important;
  display:none!important;
  background:transparent!important;
}
.page,
.page__inner,
.page-scroll{
  overflow-x:hidden!important;
}
.page-scroll{
  padding-right:0;
}
.page--map .page__inner.globe-grid{
  overflow-x:hidden!important;
}


/* polish update: smoother work-card hover + transparent 3D globe */
.work-card{
  will-change:transform;
  transition:
    transform .52s cubic-bezier(.18,.78,.16,1),
    background .32s var(--ease),
    border-color .32s var(--ease),
    box-shadow .4s var(--ease);
}
.work-card::before{
  transition:transform .52s cubic-bezier(.18,.78,.16,1),opacity .3s var(--ease);
}
.work-card::after{
  transition:transform .52s cubic-bezier(.18,.78,.16,1),opacity .32s var(--ease);
}
.work-card:hover{
  transform:translateY(-5px);
  background:rgba(255,255,255,.82);
  border-color:rgba(16,35,49,.16);
  box-shadow:0 16px 38px rgba(40,90,120,.08);
}
.work-card:hover::after{
  transform:translate3d(-6px,6px,0) scale(1.02);
  opacity:.92;
}
.work-card:hover::before{
  transform:scaleY(.86);
  opacity:.9;
}

.page--map .globe-copy .body{max-width:760px}
.page--map .globe-card{
  min-height:min(70vh,700px);
  background:transparent;
  border:0;
  box-shadow:none;
  overflow:visible;
  isolation:isolate;
}
.page--map .globe-card::before,
.page--map .globe-card::after{
  display:none;
}
.page--map .globe-toolbar,
.page--map .globe-caption{
  left:8px;
  right:8px;
  color:rgba(73,97,111,.78);
}
.page--map .globe-toolbar{top:6px}
.page--map .globe-caption{bottom:8px;color:rgba(73,97,111,.6)}
.page--map .globe-viewport{
  position:relative;
  inset:auto;
  width:100%;
  height:min(66vh,680px);
  background:transparent;
}
.page--map .globe-viewport canvas.globe-canvas,
.page--map .globe-viewport canvas{
  background:transparent!important;
}
.page--map .globe-fallback{
  color:rgba(73,97,111,.65);
}
.page--map .globe-label{
  border:1px solid rgba(16,35,49,.10);
  background:rgba(255,255,255,.88);
  color:#132331;
  box-shadow:0 10px 26px rgba(40,90,120,.08);
}
.page--map .globe-label::after{background:rgba(16,35,49,.18)}
.page--map .globe-label small{color:rgba(84,101,112,.72)}
.page--map .globe-card .globe-labels{overflow:visible}

@media (max-width:1100px){
  .page--map .globe-card{min-height:min(62vh,620px)}
}
@media (max-width:760px){
  .work-card{
    transition:background .3s var(--ease), border-color .3s var(--ease);
  }
  .work-card:hover{transform:none;box-shadow:none}
  .page--map .globe-grid{display:block}
  .page--map .globe-card{
    min-height:min(60vh,560px);
    margin:18px -6px 12px;
  }
  .page--map .globe-viewport{height:min(56vh,500px)}
  .page--map .globe-toolbar,
  .page--map .globe-caption{left:4px;right:4px;font-size:8.5px}
}


/* globe zoom controls */
.globe-zoom{position:absolute;right:14px;bottom:20px;z-index:8;display:flex;flex-direction:column;gap:8px}.globe-zoom-btn{width:38px;height:38px;border:1px solid rgba(16,35,49,.12);background:rgba(255,255,255,.82);color:#143141;font-size:24px;line-height:1;display:grid;place-items:center;box-shadow:0 10px 24px rgba(40,90,120,.08);transition:transform .2s var(--ease), background .2s var(--ease), border-color .2s var(--ease)}.globe-zoom-btn:hover{transform:translateY(-2px);background:rgba(255,255,255,.95);border-color:rgba(103,199,222,.34)}.globe-zoom-btn:active{transform:translateY(0)}@media (max-width:760px){.globe-zoom{right:6px;bottom:14px;gap:7px}.globe-zoom-btn{width:34px;height:34px;font-size:22px;box-shadow:0 8px 20px rgba(40,90,120,.06)}}


/* globe page swipe isolation */
.globe-viewport canvas{touch-action:none}
.globe-zoom,.globe-zoom *{touch-action:manipulation}


/* English / softer sans refresh */
.brand span{font-weight:700;letter-spacing:-.03em}
.navdots button span,.navdots button b,.counter{font-weight:600}
.intro-card h2{font-weight:680}
.note-list b,.stack-row b,.contact-row b{font-weight:650}
.work-card h3{font-weight:680;letter-spacing:-.05em}
.work-card p,.note-list span,.stack-row em,.contact-row span,.globe-node-list li{font-weight:450}
.intro-card,.work-card,.profile-photo img,.stack-board,.stack-aside,.contact-panel,.globe-label,.globe-zoom-btn,.globe-node-list li,.navdots button,.contact-row{border-radius:18px}
.intro-card div,.contact-row{border-radius:14px}
.work-card,.intro-card,.contact-panel,.globe-zoom-btn{overflow:hidden}
.globe-label{padding:7px 10px 8px}
.globe-node-list li{border-radius:999px}


/* Editorial / Awwwards-like cool refinement */
.topbar{top:calc(18px + var(--safe-top))}
.brand{gap:12px}
.brand span{font-weight:640;letter-spacing:-.03em}
.brand span::after{height:2px;bottom:-7px;right:0;background:linear-gradient(90deg,rgba(93,159,190,.88),rgba(149,200,178,.5));opacity:.58}
.brand small{font-size:10px;letter-spacing:.18em;color:rgba(18,34,45,.46)}
.navdots{gap:10px}
.navdots button{
  height:34px;min-width:34px;border-radius:999px;border-color:rgba(18,34,45,.12);
  background:rgba(255,255,255,.48);backdrop-filter:blur(6px);
  transition:min-width .34s var(--ease),background .28s var(--ease),border-color .28s var(--ease),transform .28s var(--ease);
}
.navdots button span{width:32px;height:32px;font-size:10px;font-weight:580;letter-spacing:.14em}
.navdots button b{left:34px;font-size:10px;letter-spacing:.16em;color:rgba(18,34,45,.48);font-weight:560}
.navdots button.is-current{min-width:92px;background:rgba(255,255,255,.84);border-color:rgba(93,159,190,.24)}
.navdots button.is-current::after{height:2px;background:linear-gradient(90deg,rgba(93,159,190,.85),rgba(149,200,178,.5))}
.counter{font-size:11px;font-weight:560;letter-spacing:.14em;color:rgba(18,34,45,.46)}
.counter i{width:42px;background:rgba(18,34,45,.12)}
.page::before{
  inset:calc(76px + var(--safe-top)) clamp(12px,3vw,42px) calc(24px + var(--safe-bottom));
  background:linear-gradient(90deg,rgba(147,200,228,.07),transparent 22%),linear-gradient(180deg,transparent 0 72%,rgba(255,255,255,.28));
  border-left:1px solid rgba(93,159,190,.16);
  opacity:1;
}
.kicker::before{width:16px;height:6px;background:linear-gradient(90deg,rgba(93,159,190,.92),rgba(149,200,178,.42));border:0}
.headline::after{width:64px;height:6px;margin-top:16px;background:linear-gradient(90deg,rgba(93,159,190,.88),rgba(149,200,178,.35));opacity:.72}
.headline--xl::after{height:7px;margin-top:18px}
.text-link{background:linear-gradient(transparent 66%,rgba(147,200,228,.16) 0)}
.intro-card,.work-card,.contact-panel,.stack-board,.profile-photo,.globe-card{
  border-radius:22px;
}
.intro-card{
  padding:30px;background:rgba(255,255,255,.66);border-color:rgba(18,34,45,.10);box-shadow:0 24px 60px rgba(26,52,67,.045);
}
.card-topline{top:18px;left:30px;right:30px;height:1px;background:linear-gradient(90deg,rgba(18,34,45,.5),transparent)}
.intro-card p{font-size:12px;letter-spacing:.04em}
.intro-card h2{margin-bottom:28px;font-weight:630}
.intro-card div{grid-template-columns:92px 1fr;padding-top:12px;border-top-color:rgba(18,34,45,.07)}
.intro-strip{padding:11px 0;background:rgba(255,255,255,.22);border-top-color:rgba(18,34,45,.08);border-bottom-color:rgba(18,34,45,.08);font-size:11px;letter-spacing:.2em;color:rgba(18,34,45,.48)}
.intro-strip span{animation-duration:28s}
.profile-photo{transform:rotate(-1deg);padding:10px;background:rgba(255,255,255,.82);box-shadow:0 22px 52px rgba(26,52,67,.045)}
.profile-photo::before,.profile-photo::after{display:none}
.note-list{gap:18px}
.note-list article{padding:16px 0 0 0;background:none;border-top-color:rgba(18,34,45,.09)}
.note-list b{width:28px;height:20px;border-radius:999px;background:rgba(93,159,190,.09);border:1px solid rgba(93,159,190,.16);color:#4d88a3;font-weight:580}
.profile-index{color:rgba(18,34,45,.035)}
.stack-board{background:rgba(255,255,255,.28);border-top-color:rgba(18,34,45,.10);border-bottom-color:rgba(18,34,45,.10)}
.stack-row{padding-left:18px;border-bottom-color:rgba(18,34,45,.06)}
.stack-row::before{width:2px;top:20px;bottom:20px;border-radius:999px;opacity:.76}
.stack-row span{font-size:11px;letter-spacing:.18em;color:rgba(18,34,45,.48)}
.stack-row b{font-weight:620;letter-spacing:-.04em}
.stack-row em{color:#62747f}
.stack-aside{border-left-width:2px;border-left-color:rgba(149,200,178,.72);background:linear-gradient(90deg,rgba(149,200,178,.08),transparent);padding-left:16px}
.stack-aside strong{font-weight:600;color:#243640}
.works-grid{gap:22px}
.works-head{max-width:780px}
.work-strip{gap:16px;padding:4px 16vw 22px 0}
.work-card{
  min-height:min(50vh,410px);padding:24px 24px 22px;background:rgba(255,255,255,.6);border-color:rgba(18,34,45,.09);
  box-shadow:0 18px 40px rgba(26,52,67,.03);
  transition:transform .46s cubic-bezier(.18,.78,.16,1),background .28s var(--ease),border-color .28s var(--ease),box-shadow .28s var(--ease);
}
.work-card::before{width:2px;background:linear-gradient(rgba(93,159,190,.85),rgba(149,200,178,.38));opacity:.92}
.work-card::after{right:18px;top:18px;width:74px;height:74px;background:linear-gradient(135deg,rgba(93,159,190,.08),rgba(149,200,178,.03));clip-path:none;border-radius:18px;z-index:0}
.work-card:hover{transform:translateY(-4px);background:rgba(255,255,255,.76);border-color:rgba(93,159,190,.16);box-shadow:0 18px 48px rgba(26,52,67,.05)}
.work-card span{width:30px;height:20px;background:rgba(255,255,255,.78);border-color:rgba(18,34,45,.08);color:#627883;font-size:10px}
.work-card h3{font-weight:640;font-size:clamp(28px,3.6vw,50px);line-height:.96;margin:28px 0 14px}
.work-card p{color:#5a6d79;line-height:1.72}
.work-card i{margin-top:28px;color:#6d8796;letter-spacing:.16em}
.drag-note{padding-top:8px;font-size:10px;letter-spacing:.22em;color:rgba(18,34,45,.42);border-top-color:rgba(18,34,45,.08)}
.globe-copy .body{max-width:700px}
.globe-card{
  background:linear-gradient(180deg,rgba(255,255,255,.48),rgba(255,255,255,.22));
  border-color:rgba(18,34,45,.08);box-shadow:0 20px 44px rgba(26,52,67,.035);
}
.globe-toolbar,.globe-caption{color:rgba(18,34,45,.46);letter-spacing:.16em}
.globe-label{border-color:rgba(18,34,45,.08);background:rgba(255,255,255,.82);box-shadow:0 12px 28px rgba(26,52,67,.04)}
.globe-label b{font-weight:600;letter-spacing:.02em}
.globe-label small{color:rgba(18,34,45,.42)}
.globe-zoom-btn{border-radius:999px;background:rgba(255,255,255,.82);border-color:rgba(18,34,45,.10);box-shadow:0 12px 24px rgba(26,52,67,.045);font-size:21px;font-weight:520}
.globe-zoom-btn:hover{background:rgba(255,255,255,.94);border-color:rgba(93,159,190,.18)}
.contact-panel{background:rgba(255,255,255,.3);border-top-color:rgba(18,34,45,.09);border-bottom-color:rgba(18,34,45,.09)}
.contact-row{padding:20px 0 20px 12px;border-bottom-color:rgba(18,34,45,.06)}
.contact-row::before{width:2px;top:20px;bottom:20px;opacity:.72}
.contact-row span{padding:0;background:none;border:0;color:rgba(18,34,45,.46);font-size:11px;letter-spacing:.18em}
.contact-row b{font-weight:610;letter-spacing:-.03em}
.site-foot{font-size:10px;letter-spacing:.22em;color:rgba(18,34,45,.42);border-top-color:rgba(18,34,45,.08);background:none;padding-left:0}
@media (max-width:760px){
  .page::before{inset:calc(56px + var(--safe-top)) 10px calc(22px + var(--safe-bottom));background:linear-gradient(180deg,rgba(147,200,228,.06),transparent 26%);border-left:0;border-top:1px solid rgba(93,159,190,.16)}
  .navdots{gap:6px}
  .navdots button{height:32px;min-width:32px}
  .navdots button span{width:30px;height:30px}
  .work-card,.intro-card,.contact-panel,.stack-board,.profile-photo,.globe-card{border-radius:18px}
  .work-card{min-height:348px}
  .work-card::after{width:58px;height:58px}
  .headline::after{width:52px;height:5px}
}
