*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}

:root{
  --white:#FEFDFB;
  --black:#0D0D0D;
  --ink:#1A1A1A;
  --mid:#6B6B6B;
  --pale:#D8D5CF;
  --bg-section:#F7F5F2;
  --ease:cubic-bezier(0.25,0.46,0.45,0.94);
  --ease-out:cubic-bezier(0.16,1,0.3,1);
}

html{scroll-behavior:smooth}

@media (prefers-reduced-motion: reduce){
  html{scroll-behavior:auto}
  .hero-bg-img{animation:none!important;transform:none}
  .hero-scroll-line{animation:none!important}
}

.skip-link{
  position:absolute;left:-9999px;top:0;z-index:10001;
  padding:.75rem 1.25rem;background:var(--ink);color:var(--white);
  font-size:.75rem;letter-spacing:.12em;text-transform:uppercase;text-decoration:none;
}
.skip-link:focus{left:1rem;top:1rem;outline:2px solid var(--white);outline-offset:2px}

body{
  background:var(--white);
  color:var(--ink);
  font-family:'Cormorant',Georgia,serif;
  font-size:17px;
  font-weight:300;
  line-height:1.8;
  overflow-x:hidden;
  cursor:auto;
}

@media (pointer: fine) and (prefers-reduced-motion: no-preference){
  body{cursor:none}
}

#cur{
  position:fixed;width:6px;height:6px;
  background:var(--ink);border-radius:50%;
  pointer-events:none;z-index:9999;
  transform:translate(-50%,-50%);
  transition:width .3s,height .3s,background .3s;
}
#cur-r{
  position:fixed;width:32px;height:32px;
  border:1px solid rgba(13,13,13,.25);border-radius:50%;
  pointer-events:none;z-index:9998;
  transform:translate(-50%,-50%);
  transition:transform .15s var(--ease),width .35s var(--ease-out),height .35s var(--ease-out),opacity .3s;
}
body.h #cur{width:10px;height:10px;background:var(--ink)}
body.h #cur-r{width:48px;height:48px;opacity:.15}

body.cursor-on-dark #cur{background:var(--white)}
body.cursor-on-dark #cur-r{border-color:rgba(254,253,251,.35)}
body.cursor-on-dark.h #cur{background:var(--white)}
body.cursor-on-dark.h #cur-r{width:48px;height:48px;opacity:.22;border-color:rgba(254,253,251,.4)}

@media (pointer: coarse), (prefers-reduced-motion: reduce){
  #cur,#cur-r{display:none!important}
}

nav{
  position:fixed;top:0;left:0;right:0;
  z-index:100;
  display:flex;align-items:center;justify-content:space-between;
  padding:2.25rem 5rem;
  transition:padding .5s var(--ease-out),background .5s,border-color .5s,box-shadow .5s;
  border-bottom:1px solid transparent;
}
nav.s{
  padding:1.25rem 5rem;
  background:rgba(254,253,251,.95);
  backdrop-filter:blur(20px);
  border-color:var(--pale);
  box-shadow:0 1px 24px rgba(0,0,0,.06);
}
.nav-sig{
  font-family:'Cormorant',Georgia,serif;font-style:italic;font-weight:600;
  font-size:1.35rem;
  color:#fff;
  text-decoration:none;
  opacity:0;
  animation:fd .8s var(--ease-out) .1s forwards;
  transition:color .5s;
}
nav.s .nav-sig{color:var(--ink)}
.nav-links{
  display:flex;gap:2rem;list-style:none;align-items:center;flex-wrap:wrap;
}
.nav-links a,.nav-lang a{
  font-size:.82rem;font-weight:400;letter-spacing:.18em;text-transform:uppercase;
  color:rgba(255,255,255,.7);text-decoration:none;
  transition:color .5s;
  opacity:0;animation:fd .8s var(--ease-out) forwards;
}
.nav-links li:nth-child(1) a{animation-delay:.25s}
.nav-links li:nth-child(2) a{animation-delay:.35s}
.nav-links li:nth-child(3) a{animation-delay:.45s}
.nav-links a:hover{color:#fff}
nav.s .nav-links a,nav.s .nav-lang a{color:var(--mid)}
nav.s .nav-links a:hover,nav.s .nav-lang a:hover{color:var(--ink)}
.nav-lang{font-size:.82rem;letter-spacing:.18em;text-transform:uppercase}
.nav-lang a{opacity:1;animation:none;border-left:1px solid rgba(255,255,255,.25);padding-left:2rem;margin-left:.5rem}
nav.s .nav-lang a{border-left-color:var(--pale)}

.hero{
  min-height:100vh;
  display:flex;flex-direction:column;
  align-items:center;justify-content:center;
  text-align:center;
  padding:10rem 2rem 6rem;
  position:relative;
  overflow:hidden;
}
.hero-bg-wrap{
  position:absolute;inset:0;overflow:hidden;z-index:0;
}
.hero-bg-img{
  position:absolute;
  width:140%;height:140%;
  top:-20%;left:-20%;
  object-fit:cover;
  object-position:35% 28%;
  animation:kenBurns 30s ease-in-out infinite;
  will-change:transform;
}
@keyframes kenBurns{
  0%  {transform:scale(1)    translate(  0%,   0%)}
  25% {transform:scale(1.08) translate( -4%,   1%)}
  50% {transform:scale(1.12) translate(  2%,  -3%)}
  75% {transform:scale(1.06) translate(  4%,   2%)}
  100%{transform:scale(1)    translate(  0%,   0%)}
}
.hero-overlay{
  position:absolute;inset:0;z-index:1;
  background:linear-gradient(
    to bottom,
    rgba(6,6,6,.25)  0%,
    rgba(6,6,6,.45) 55%,
    rgba(6,6,6,.72) 100%
  );
}
.hero>*:not(.hero-bg-wrap):not(.hero-overlay){position:relative;z-index:2}
.hero-label{
  font-size:.8rem;font-weight:400;letter-spacing:.28em;text-transform:uppercase;
  color:rgba(255,255,255,.55);margin-bottom:2.5rem;
  opacity:0;animation:fu .9s var(--ease-out) .5s forwards;
}
.hero-name{
  font-family:'Cormorant',Georgia,serif;font-style:italic;font-weight:600;
  font-size:clamp(4rem,12vw,9.5rem);
  color:#fff;line-height:1;letter-spacing:-.01em;
  opacity:0;animation:fu 1.2s var(--ease-out) .7s forwards;
  text-shadow:0 4px 60px rgba(0,0,0,.45);
}
.hero-rule{
  width:1px;height:60px;background:rgba(255,255,255,.28);
  margin:3rem auto;
  opacity:0;animation:grow .9s var(--ease-out) 1.1s forwards;
  transform-origin:top;
}
.hero-tagline{
  font-size:1rem;font-weight:300;
  color:rgba(255,255,255,.62);
  max-width:38ch;margin:0 auto;line-height:1.8;
  opacity:0;animation:fu .9s var(--ease-out) 1.3s forwards;
}
.hero-scroll{
  position:absolute;bottom:3rem;left:50%;
  transform:translateX(-50%);
  display:flex;flex-direction:column;align-items:center;gap:.8rem;
  font-size:.8rem;font-weight:400;letter-spacing:.22em;text-transform:uppercase;
  color:rgba(255,255,255,.35);text-decoration:none;
  opacity:0;animation:fu .8s var(--ease-out) 1.8s forwards;
  transition:color .3s;
}
.hero-scroll:hover{color:rgba(255,255,255,.7)}
.hero-scroll-line{
  width:1px;height:40px;background:currentColor;
  animation:pulse 2.5s ease-in-out 2s infinite;
}
@keyframes pulse{0%,100%{opacity:.3}50%{opacity:1}}

section{padding:8rem 5rem}
.sec-tag{
  font-size:.78rem;font-weight:400;letter-spacing:.26em;text-transform:uppercase;
  color:var(--mid);margin-bottom:1.2rem;
}
.sec-title{
  font-size:clamp(1.8rem,3.5vw,2.8rem);
  font-weight:300;line-height:1.2;color:var(--ink);
}
.sec-title em{font-style:italic;color:var(--mid)}

.r{opacity:0;transform:translateY(32px);transition:opacity .9s var(--ease-out),transform .9s var(--ease-out)}
.r.v{opacity:1;transform:none}
.d1{transition-delay:.12s}.d2{transition-delay:.24s}.d3{transition-delay:.36s}.d4{transition-delay:.48s}

.about{background:var(--bg-section)}
.about-wrap{
  display:grid;grid-template-columns:1fr 1.2fr;
  gap:8rem;align-items:start;
  max-width:1100px;margin:0 auto;
}
.about-portrait{
  position:relative;aspect-ratio:3/4;
}
.portrait-img{
  width:100%;height:100%;
  overflow:hidden;
}
.portrait-img img{
  width:100%;height:100%;object-fit:cover;display:block;
}
.portrait-line{
  position:absolute;
  inset:-1.2rem 1.2rem 1.2rem -1.2rem;
  border:1px solid var(--pale);
  pointer-events:none;
}
.about-body{
  font-size:.95rem;font-weight:300;color:var(--mid);
  line-height:1.9;margin-top:1.8rem;max-width:46ch;
}
.about-body strong{color:var(--ink);font-weight:400}
.about-line{
  width:100%;height:1px;background:var(--pale);
  margin:2.5rem 0;
}
.bio-open{
  margin-top:2rem;
  background:none;border:none;border-bottom:1px solid var(--pale);
  padding:.6rem 0;
  font-family:'Cormorant',Georgia,serif;
  font-size:.72rem;font-weight:400;letter-spacing:.22em;text-transform:uppercase;
  color:var(--ink);cursor:pointer;
  transition:border-color .3s,color .3s;
}
.bio-open:hover{border-color:var(--ink);color:var(--mid)}

.bio-overlay{
  position:fixed;inset:0;z-index:2000;
  background:var(--white);
  opacity:0;visibility:hidden;
  pointer-events:none;
  transition:opacity .45s var(--ease-out),visibility 0s linear .45s;
}
.bio-overlay.open{
  opacity:1;visibility:visible;
  pointer-events:all;
  transition:opacity .45s var(--ease-out),visibility 0s;
}
.bio-overlay-scroll{
  height:100%;
  overflow-y:auto;
  overflow-x:hidden;
  overscroll-behavior:contain;
  -webkit-overflow-scrolling:touch;
}
.bio-overlay-x{
  position:fixed;top:1.5rem;right:1.5rem;z-index:2002;
  width:48px;height:48px;
  border:1px solid var(--pale);border-radius:50%;
  background:rgba(254,253,251,.92);
  backdrop-filter:blur(12px);
  color:var(--ink);
  font-size:1.1rem;
  cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  transition:border-color .3s,background .3s;
}
.bio-overlay-x:hover{border-color:var(--ink)}
.bio-overlay-inner{
  max-width:min(56rem,92vw);
  margin:0 auto;
  padding:5.5rem clamp(1.25rem,4vw,2.75rem) 6rem;
}
.bio-overlay-title{
  font-family:'Cormorant',Georgia,serif;font-style:italic;font-weight:600;
  font-size:clamp(1.6rem,4vw,2.4rem);
  color:var(--ink);
  line-height:1.2;
  margin-bottom:2.5rem;
  padding-bottom:1.5rem;
  border-bottom:1px solid var(--pale);
}
.bio-long{
  font-size:1rem;
  font-weight:300;
  color:var(--mid);
  line-height:1.85;
}
.bio-long h3{
  font-size:1.08rem;font-weight:400;color:var(--ink);margin:2.75rem auto .9rem;
  letter-spacing:.04em;line-height:1.35;
  max-width:68ch;
}
.bio-long h3:first-of-type{margin-top:0}
.bio-long p{
  font-size:1rem;color:var(--mid);line-height:1.9;margin:0 auto 1.15rem;
  max-width:68ch;
}
.bio-long figure.bio-photo{
  margin:2.75rem 0 3.25rem;
  width:100%;
  padding:0;
}
.bio-long figure.bio-photo img{
  width:100%;
  height:auto;
  max-height:min(75vh,880px);
  object-fit:contain;
  object-position:center;
  display:block;
  margin:0 auto;
  background:var(--bg-section);
  border-radius:2px;
  box-shadow:0 8px 40px rgba(13,13,13,.1);
}
.bio-long figure.bio-photo figcaption{
  margin:1.1rem 0 0;
  font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;
  color:var(--mid);line-height:1.55;text-align:center;
}

.gallery-section{background:var(--ink);padding:8rem 5rem}
.gallery-head{
  display:flex;align-items:flex-end;
  justify-content:space-between;
  max-width:1100px;margin:0 auto 4.5rem;
}
.gallery-head .sec-title{color:var(--white)}
.gallery-head .sec-tag{color:var(--pale)}
.filters{display:flex;gap:2rem;list-style:none;flex-wrap:wrap}
.filters button{
  background:none;border:none;
  font-family:'Cormorant',Georgia,serif;
  font-size:.65rem;font-weight:400;
  letter-spacing:.18em;text-transform:uppercase;
  color:rgba(254,253,251,.3);
  cursor:pointer;padding:.3rem 0;
  border-bottom:1px solid transparent;
  transition:color .3s,border-color .3s;
}
.filters button.a,.filters button:hover{
  color:var(--white);border-color:rgba(254,253,251,.4);
}

.g-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:2px;
  max-width:1100px;margin:0 auto;
}
.g-item{
  position:relative;overflow:hidden;
  cursor:pointer;
  aspect-ratio:3/4;
}

.pm{width:100%;height:100%;transition:transform .9s var(--ease-out);background-size:cover;background-position:center}
.pm.has-img{background-repeat:no-repeat}
.g-item:hover .pm{transform:scale(1.05)}

.p1{background:linear-gradient(145deg,#7A3F2E,#C4886A,#E8C9A8,#A0795A)}
.p2{background:linear-gradient(195deg,#162840,#2A5275,#7AB0C8,#E0ECF4)}
.p3{background:linear-gradient(50deg,#2D3E24,#658050,#C4B87A,#F0E8C0)}
.p4{background:linear-gradient(160deg,#241830,#5E3A7A,#B88AC0,#E8D8F0)}
.p5{background:linear-gradient(105deg,#3A2810,#8B6238,#D4A868,#F4E0B0)}
.p6{background:linear-gradient(215deg,#162A2A,#3A7878,#88C4C4,#D8F0F0)}

.g-ov{
  position:absolute;inset:0;
  background:rgba(13,13,13,.8);
  display:flex;flex-direction:column;justify-content:flex-end;
  padding:1.8rem;
  opacity:0;transition:opacity .4s var(--ease);
}
.g-item:hover .g-ov{opacity:1}
.ov-title{
  font-size:1rem;font-weight:300;color:var(--white);
  margin-bottom:.3rem;
  transform:translateY(8px);
  transition:transform .4s var(--ease);
}
.g-item:hover .ov-title{transform:none}
.ov-meta{
  font-size:.6rem;font-weight:400;letter-spacing:.18em;
  text-transform:uppercase;color:var(--pale);
  transform:translateY(8px);
  transition:transform .45s var(--ease);
}
.g-item:hover .ov-meta{transform:none}
.ov-arr{
  position:absolute;top:1.5rem;right:1.5rem;
  width:36px;height:36px;
  border:1px solid rgba(254,253,251,.25);border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  color:var(--white);font-size:1rem;
  opacity:0;transform:scale(.8) rotate(-45deg);
  transition:opacity .35s,transform .35s var(--ease-out);
}
.g-item:hover .ov-arr{opacity:1;transform:scale(1) rotate(0)}

.lb{
  --lb-dur:0.5s;
  position:fixed;inset:0;
  background:rgba(13,13,13,.97);
  z-index:1000;
  display:flex;align-items:center;justify-content:center;
  opacity:0;pointer-events:none;
  transition:opacity var(--lb-dur) var(--ease-out);
}
.lb.open{opacity:1;pointer-events:all}
.lb.open.is-closing{pointer-events:none}
.lb.is-closing{pointer-events:none}
.lb-inner{
  display:grid;grid-template-columns:1fr 340px;
  width:88vw;max-width:1080px;height:82vh;
  background:var(--white);
  transform:scale(.96) translateY(20px);
  transition:transform var(--lb-dur) var(--ease-out);
}
.lb.open .lb-inner{transform:scale(1) translateY(0)}
.lb-inner{position:relative;z-index:1}
.lb-x,.lb-nav{z-index:3}
.lb-img{
  height:100%;
  overflow:hidden;
  background:var(--bg-section);
}
.lb-img .pm{
  width:100%;height:100%;
  transition:opacity .32s var(--ease-out),transform .38s var(--ease-out);
}
.lb-img .pm.is-swapping{
  opacity:0;
  transform:scale(.96);
}
.lb-img .pm.lb-preview-enter{
  opacity:0;
  transform:scale(.98);
}
.lb.open .lb-img .pm.lb-preview-enter{
  opacity:1;
  transform:scale(1);
}
.lb-img .pm.has-img{
  background-size:contain;
  background-position:center;
  background-repeat:no-repeat;
}
.lb-info{
  padding:3rem 2.5rem;
  border-left:1px solid var(--pale);
  display:flex;flex-direction:column;
  overflow-y:auto;
  transition:opacity .32s var(--ease-out),transform .36s var(--ease-out);
}
.lb-info.is-swapping{
  opacity:0;
  transform:translateY(10px);
}
@media (prefers-reduced-motion: reduce){
  .lb,.lb-inner,.lb-img .pm,.lb-info{transition:none!important}
}
.lb-yr{
  font-size:.62rem;font-weight:400;letter-spacing:.22em;
  text-transform:uppercase;color:var(--mid);margin-bottom:1rem;
}
.lb-t{
  font-family:'Cormorant',Georgia,serif;font-style:italic;font-weight:600;
  font-size:1.7rem;color:var(--ink);
  line-height:1.25;margin-bottom:1.5rem;
}
.lb-hr{width:32px;height:1px;background:var(--pale);margin-bottom:1.5rem}
.lb-d{font-size:.88rem;font-weight:300;color:var(--mid);line-height:1.85;flex:1}
.lb-meta{
  margin-top:2rem;padding-top:2rem;
  border-top:1px solid var(--pale);
  display:grid;grid-template-columns:1fr 1fr;gap:1.5rem;
}
.lb-ml{font-size:.58rem;font-weight:400;letter-spacing:.2em;text-transform:uppercase;color:var(--pale);margin-bottom:.3rem}
.lb-mv{font-size:.88rem;font-weight:300;color:var(--ink)}
.lb-x{
  position:absolute;top:2rem;right:2rem;
  width:40px;height:40px;
  border:1px solid rgba(254,253,251,.15);border-radius:50%;
  background:none;color:var(--white);font-size:1rem;
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;transition:border-color .3s,color .3s;
}
.lb-x:hover{border-color:rgba(254,253,251,.5);color:var(--white)}
.lb-nav{
  position:absolute;bottom:2rem;left:50%;
  transform:translateX(-50%);
  display:flex;gap:.8rem;
}
.lb-nav button{
  background:none;
  border:1px solid rgba(254,253,251,.15);
  color:rgba(254,253,251,.5);
  width:40px;height:40px;border-radius:50%;
  font-size:1rem;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  transition:border-color .3s,color .3s;
}
.lb-nav button:hover{border-color:rgba(254,253,251,.5);color:var(--white)}

.quote-sec{
  padding:8rem 2rem;text-align:center;
  position:relative;overflow:hidden;
}
.q-mark{
  font-family:'Cormorant',Georgia,serif;font-style:italic;font-weight:600;
  font-size:22rem;
  color:rgba(13,13,13,.04);
  position:absolute;top:-4rem;left:50%;
  transform:translateX(-50%);
  line-height:1;
  pointer-events:none;user-select:none;
}
.q-text{
  font-family:'Cormorant',Georgia,serif;font-style:italic;font-weight:600;
  font-size:clamp(1.3rem,3vw,2.1rem);
  color:var(--ink);
  max-width:30ch;margin:0 auto;
  line-height:1.5;
  position:relative;
}
.q-attr{
  font-size:.62rem;font-weight:400;letter-spacing:.22em;
  text-transform:uppercase;color:var(--mid);margin-top:2rem;
}

.contact-wrap{
  display:grid;grid-template-columns:1fr 1fr;
  gap:7rem;max-width:1100px;margin:0 auto;
  align-items:start;
}
.contact-desc{
  font-size:.9rem;font-weight:300;color:var(--mid);
  line-height:1.9;margin-top:1.5rem;max-width:38ch;
}
.c-detail{display:flex;gap:1rem;align-items:flex-start;margin-top:2.5rem}
.c-icon{
  width:32px;height:32px;
  border:1px solid var(--pale);border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-size:.8rem;color:var(--mid);flex-shrink:0;margin-top:.15rem;
}
.c-dt-l{font-size:.58rem;font-weight:400;letter-spacing:.2em;text-transform:uppercase;color:var(--pale)}
.c-dt-v{font-size:.9rem;font-weight:300;color:var(--ink);margin-top:.2rem}
.c-dt-v a{color:var(--ink)}

form{display:flex;flex-direction:column;gap:2.2rem}
.fg{display:flex;flex-direction:column;gap:.5rem}
.fr{display:grid;grid-template-columns:1fr 1fr;gap:1.2rem}
.fg label{
  font-size:.6rem;font-weight:400;letter-spacing:.2em;
  text-transform:uppercase;color:var(--pale);
}
.fg input,.fg textarea,.fg select{
  background:transparent;
  border:none;border-bottom:1px solid var(--pale);
  padding:.75rem 0;
  font-family:'Cormorant',Georgia,serif;font-size:.92rem;
  font-weight:300;color:var(--ink);
  outline:none;resize:none;
  cursor:text;
  transition:border-color .3s;
}
.fg select{cursor:pointer}
.fg input::placeholder,.fg textarea::placeholder{color:var(--pale);font-style:normal}
.fg input:focus,.fg textarea:focus{border-color:var(--ink)}
.fg textarea{min-height:110px}
.fg select option{background:var(--white);color:var(--ink)}

.btn{
  align-self:flex-start;
  background:var(--ink);color:var(--white);
  border:none;
  padding:1rem 3rem;
  font-family:'Cormorant',Georgia,serif;
  font-size:.85rem;font-weight:500;letter-spacing:.22em;
  text-transform:uppercase;
  cursor:pointer;
  position:relative;overflow:hidden;
  transition:color .4s;
}
.btn-bg{
  position:absolute;inset:0;
  background:#333;
  transform:translateX(-100%);
  transition:transform .5s var(--ease-out);
}
.btn:hover .btn-bg{transform:none}
.btn span{position:relative;z-index:1}
.success{
  display:none;padding:1.5rem;
  background:var(--bg-section);
  font-size:.9rem;color:var(--mid);font-style:italic;
}

footer{
  background:var(--ink);
  padding:3rem 5rem;
  display:flex;
  justify-content:space-between;
  align-items:center;
  flex-wrap:wrap;gap:1rem;
  border-top:1px solid rgba(254,253,251,.06);
}
.f-sig{
  font-family:'Cormorant',Georgia,serif;font-style:italic;font-weight:600;
  font-size:1.2rem;color:rgba(254,253,251,.6);
}
.f-copy{
  font-size:.6rem;font-weight:400;letter-spacing:.14em;
  color:rgba(254,253,251,.25);
}

@keyframes fu{from{opacity:0;transform:translateY(22px)}to{opacity:1;transform:none}}
@keyframes fd{from{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:none}}
@keyframes grow{from{opacity:0;transform:scaleY(0)}to{opacity:1;transform:scaleY(1)}}

@media(max-width:960px){
  nav,nav.s{padding:1.35rem 1.35rem}
  section{padding:5rem 2rem}
  .about-wrap,.contact-wrap{grid-template-columns:1fr;gap:3.5rem}
  .g-grid{grid-template-columns:1fr 1fr}
  .gallery-head{flex-direction:column;gap:1.5rem;align-items:flex-start}
  footer{flex-direction:column;text-align:center;justify-content:center}
  .lb-inner{
    grid-template-columns:1fr;
    grid-template-rows:minmax(0,1fr) auto;
    align-content:stretch;
    width:min(96vw,100%);
    min-width:0;
    height:calc(100dvh - env(safe-area-inset-top,0px) - env(safe-area-inset-bottom,0px) - 0.5rem);
    max-height:calc(100dvh - env(safe-area-inset-top,0px) - env(safe-area-inset-bottom,0px) - 0.5rem);
    box-sizing:border-box;
    padding-bottom:calc(3.75rem + env(safe-area-inset-bottom,0px));
  }
  .lb-img{
    min-height:0;
    height:100%;
    align-self:stretch;
  }
  .lb-info{
    display:flex;
    max-height:min(40vh,300px);
    overflow-y:auto;
    -webkit-overflow-scrolling:touch;
    overscroll-behavior:contain;
    border-left:none;
    border-top:1px solid var(--pale);
    padding:1.15rem 1.25rem 1.35rem;
    flex-shrink:0;
  }
  .lb-t{font-size:1.35rem;margin-bottom:1rem;line-height:1.2}
  .lb-d{font-size:.84rem;line-height:1.75}
  .lb-meta{margin-top:1.15rem;padding-top:1.15rem;gap:1rem 1.25rem}
  .lb-x{
    top:calc(0.65rem + env(safe-area-inset-top,0px));
    right:calc(0.65rem + env(safe-area-inset-right,0px));
    width:44px;height:44px;
    background:rgba(13,13,13,.5);
    backdrop-filter:blur(10px);
    border:1px solid rgba(254,253,251,.35);
    color:var(--white);
    box-shadow:0 2px 16px rgba(0,0,0,.25);
  }
  .lb-nav{
    bottom:calc(0.85rem + env(safe-area-inset-bottom,0px));
    gap:0.65rem;
  }
  .lb-nav button{
    width:44px;height:44px;
    background:rgba(13,13,13,.45);
    backdrop-filter:blur(10px);
    border:1px solid rgba(254,253,251,.3);
    color:rgba(254,253,251,.92);
    box-shadow:0 2px 14px rgba(0,0,0,.2);
  }
  body{cursor:auto!important}
  #cur,#cur-r{display:none!important}
}

@media(max-width:600px){
  nav,nav.s{
    padding:0.9rem 1rem;
    gap:0.5rem 0.75rem;
    flex-wrap:wrap;
    align-items:center;
  }
  .nav-sig{font-size:1.12rem}
  .nav-links{
    flex:1 1 auto;
    justify-content:flex-end;
    gap:0.35rem 0.65rem;
    min-width:0;
  }
  .nav-links a,.nav-lang a{
    font-size:.72rem;
    letter-spacing:.1em;
    padding:0.35rem 0.15rem;
  }
  .nav-lang a{
    padding-left:0.75rem;
    margin-left:0.2rem;
  }

  .lb-inner{
    width:100%;
    max-width:100%;
    min-width:0;
    height:calc(100dvh - env(safe-area-inset-top,0px) - env(safe-area-inset-bottom,0px));
    max-height:calc(100dvh - env(safe-area-inset-top,0px) - env(safe-area-inset-bottom,0px));
    border-radius:0;
  }
  .lb-info{
    max-height:min(38vh,280px);
    padding:1rem 1rem 1.2rem;
  }
  .lb-x{
    top:calc(0.45rem + env(safe-area-inset-top,0px));
    right:calc(0.45rem + env(safe-area-inset-right,0px));
  }
  .lb-nav{
    bottom:calc(0.55rem + env(safe-area-inset-bottom,0px));
    left:0;right:0;transform:none;
    justify-content:center;
    padding:0 0.5rem;
    gap:0.5rem;
  }
}
