@charset "UTF-8";

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

:root  {
  --bg:#E8E5DF;
  --dark:#111110;
  --text:#111110;
  --muted:#7a7870;
  --border:rgba(17,17,16,.12);
  --card:#D8D5CF;
  --fh:'Syne','Georgia',serif;
  --fb:'DM Sans','Helvetica Neue',sans-serif
}
body.ru-active {
  --fh:'Raleway','Georgia',serif;
  --fb:'IBM Plex Sans','Helvetica Neue',sans-serif
}


html  {
  scroll-behavior:smooth
}

body  {
  background:var(--bg);
  color:var(--text);
  font-family:var(--fb);
  font-weight:300;
  font-size:15px;
  line-height:1.6
}

/* NAV */
nav  {
  position:fixed;
  top:0;
  left:0;
  right:0;
  z-index:300;
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:18px 32px;
  background:transparent;
  transition:background .35s ease,color .35s ease
}

nav.mob-open  {
  background:var(--dark) !important;
  transition:background 0s
}

nav.mob-open 

nav.mob-open .mtrig  {
  font-size:10px;
  padding:5px 14px;
  border:1px solid rgba(232,229,223,.35);
  border-radius:999px;
  color:var(--bg) !important;
  background:transparent !important;
  cursor:pointer;
  font-family:var(--fh);
  font-weight:700;
  letter-spacing:.15em;
  text-transform:uppercase;
  transition:border-color .2s,color .2s
}

.nav-logo  {
  font-family:var(--fh);
  font-size:13px;
  font-weight:700;
  letter-spacing:.2em;
  text-transform:uppercase;
  transition:color .35s ease
}

.nav-l,.nav-r  {
  display:flex;
  gap:8px;
  align-items:center
}

.pill  {
  display:inline-flex;
  align-items:center;
  gap:6px;
  padding:6px 14px;
  border:1px solid var(--border);
  border-radius:999px;
  font-size:12px;
  text-decoration:none;
  color:var(--text);
  transition:background .2s,color .2s;
  cursor:pointer;
  font-family:var(--fb)
}

.pill::before  {
  content:'';
  width:5px;
  height:5px;
  border-radius:50%;
  background:var(--dark);
  flex-shrink:0
}

.pill:hover,.pill.on  {
  background:var(--dark);
  color:var(--bg)
}

.pill:hover::before,.pill.on::before  {
  background:var(--bg)
}

/* DESKTOP LANG */
.lswrap  {
  display:inline-flex;
  align-items:center;
  border:1px solid var(--border);
  border-radius:999px;
  overflow:hidden;
  height:32px
}

.lb  {
  padding:0 11px;
  height:100%;
  display:flex;
  align-items:center;
  font-size:11px;
  font-weight:500;
  letter-spacing:.06em;
  text-transform:uppercase;
  color:var(--muted);
  cursor:pointer;
  transition:background .2s,color .2s;
  border:none;
  background:transparent;
  border-right:1px solid var(--border);
  font-family:var(--fb)
}

.lb:last-child  {
  border-right:none
}

.lb.on  {
  background:var(--dark);
  color:var(--bg)
}

.lb:not(.on):hover  {
  background:rgba(17,17,16,.06);
  color:var(--text)
}

/* MOBILE TRIGGER */
.mtrig  {
  display:none;
  align-items:center;
  gap:6px;
  padding:6px 14px;
  border:1px solid var(--border);
  border-radius:999px;
  font-size:12px;
  color:var(--text);
  cursor:pointer;
  background:transparent;
  font-family:var(--fb);
  transition:background .2s,color .2s;
  white-space:nowrap
}

.mtrig::before  {
  content:'';
  width:5px;
  height:5px;
  border-radius:50%;
  background:var(--dark);
  flex-shrink:0;
  transition:background .2s
}

.mtrig.open,.mtrig:hover  {
  background:var(--dark);
  color:var(--bg)
}

.mtrig.open::before,.mtrig:hover::before  {
  background:var(--bg)
}

/* MOBILE MENU */
.mob  {
  position:fixed;
  top:0;
  left:0;
  right:0;
  bottom:0;
  z-index:250;
  background:var(--dark);
  display:flex;
  flex-direction:column;
  padding-top:56px;
  transform:translateY(-100%);
  transition:transform .5s cubic-bezier(.23,1,.32,1);
  pointer-events:none;
  overflow:hidden
}

.mob.open  {
  transform:translateY(0);
  pointer-events:all
}

.mob-nav  {
  display:flex;
  flex-direction:column;
  align-items:stretch;
  justify-content:flex-start;
  padding:40px 28px 24px;
  gap:4px
}

.mob-link  {
  font-family:var(--fh);
  font-size:clamp(22px,6vw,32px);
  font-weight:700;
  letter-spacing:-.01em;
  line-height:1.2;
  color:rgba(232,229,223,.55);
  text-decoration:none;
  padding:6px 0;
  display:block;
  transition:color .2s
}

.mob-link:hover  {
  color:var(--bg)
}

.mob-foot  {
  padding:24px 28px 36px;
  margin-top:auto;
  display:flex;
  flex-direction:column;
  gap:16px;
  align-items:stretch
}

.mob-lang-dd  {
  position:relative
}

.mob-lang-cur  {
  display:inline-flex;
  align-items:center;
  gap:6px;
  padding:6px 14px;
  border:1px solid rgba(232,229,223,.2);
  border-radius:999px;
  font-size:11px;
  font-weight:600;
  letter-spacing:.1em;
  text-transform:uppercase;
  color:rgba(232,229,223,.6);
  background:transparent;
  cursor:pointer;
  font-family:var(--fb);
  transition:border-color .2s,color .2s
}

.mob-lang-cur:hover  {
  border-color:rgba(232,229,223,.45);
  color:var(--bg)
}

.mob-lang-arr  {
  font-size:9px;
  opacity:.6
}

.mob-lang-list  {
  display:none;
  position:absolute;
  bottom:calc(100% + 6px);
  left:0;
  background:#1c1c1b;
  border:1px solid rgba(232,229,223,.12);
  border-radius:10px;
  overflow:hidden;
  min-width:72px
}

.mob-lang-list.open  {
  display:block
}

.mob-lang-list button  {
  display:block;
  width:100%;
  padding:8px 14px;
  font-size:11px;
  font-weight:600;
  letter-spacing:.1em;
  text-transform:uppercase;
  color:rgba(232,229,223,.45);
  background:transparent;
  border:none;
  cursor:pointer;
  font-family:var(--fb);
  text-align:left;
  transition:background .15s,color .15s
}

.mob-lang-list button:hover  {
  background:rgba(232,229,223,.07);
  color:var(--bg)
}

.mob-lang-list button.on  {
  color:var(--bg)
}

.mob-socs  {
  display:flex;
  flex-wrap:wrap;
  gap:7px
}

.mob-soc  {
  display:inline-flex;
  align-items:center;
  gap:4px;
  padding:5px 13px;
  border:1px solid rgba(232,229,223,.14);
  border-radius:999px;
  font-size:11px;
  color:rgba(232,229,223,.4);
  text-decoration:none;
  font-family:var(--fb);
  transition:border-color .2s,color .2s
}

.mob-soc:hover  {
  border-color:rgba(232,229,223,.45);
  color:var(--bg)
}

/* HERO */
#hero  {
  padding:140px 32px 64px;
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap:40px
}

.hero-copy p  {
  font-size:14px;
  line-height:1.75;
  color:var(--muted);
  max-width:320px
}

.hero-links  {
  display:flex;
  gap:8px;
  flex-shrink:0;
  padding-top:4px
}

/* WORK - desktop */
#work  {
  padding:0 32px 80px
}

.wgrid{display:flex;overflow-x:auto;scroll-snap-type:x mandatory;scrollbar-width:none;-webkit-overflow-scrolling:touch;gap:10px;padding:0 32px 16px}
.wgrid::-webkit-scrollbar{display:none}

.wcard{flex-shrink:0;width:calc(20vw - 10px);max-width:260px;min-width:180px;background:var(--card);border-radius:18px;overflow:hidden;position:relative;cursor:pointer;scroll-snap-align:start;transition:transform .4s cubic-bezier(.23,1,.32,1)}

.wcard:hover  {
  transform:scale(1.02)
}

.wcard:first-child  {
  border-top-left-radius:48px
}

.wcard-thumb  {
  width:100%;
  aspect-ratio:3/4
}

.wcard-cap  {
  padding:10px 14px 14px;
  display:flex;
  flex-direction:column;
  gap:2px
}

.wcard-ct  {
  font-family:var(--fh);
  font-size:11px;
  font-weight:700;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:var(--text)
}

.wcard-cs  {
  font-size:10px;
  color:var(--muted);
  letter-spacing:.04em
}

.wcard-hl  {
  position:absolute;
  top:10px;
  right:10px;
  font-size:10px;
  font-weight:500;
  letter-spacing:.1em;
  text-transform:uppercase;
  color:rgba(255,255,255,.85);
  background:rgba(17,17,16,.35);
  padding:4px 10px;
  border-radius:999px;
  opacity:0;
  transition:opacity .3s
}

.wcard:hover .wcard-hl  {
  opacity:1
}

/* WORK - mobile horizontal scroll */
.wmob  {
  display:none
}

/* MARQUEE */
.mq  {
  overflow:hidden;
  padding:20px 0;
  margin-bottom:80px;
  border-top:1px solid var(--border);
  border-bottom:1px solid var(--border)
}

.mq-t  {
  display:flex;
  gap:60px;
  white-space:nowrap;
  animation:mqa 18s linear infinite
}

.mq-i  {
  font-family:var(--fh);
  font-size:13px;
  font-weight:600;
  letter-spacing:.15em;
  text-transform:uppercase;
  color:var(--muted);
  flex-shrink:0;
  display:flex;
  align-items:center;
  gap:60px
}

.mq-i::after  {
  content:"\2736";
  font-size:8px
}

@keyframes mqa  {
  from  {
  transform:translateX(0)
  }

to  {
  transform:translateX(-50%)
  }
}

/* SERVICES */
#services  {
  background:var(--dark);
  color:var(--bg);
  border-radius:32px;
  margin:0 16px 80px;
  padding:60px 48px;
  display:grid;
  grid-template-columns:260px 1fr 340px;
  gap:48px;
  align-items:start
}

.s-tag  {
  font-size:13px;
  line-height:1.8;
  color:rgba(232,229,223,.55);
  padding-top:8px
}

.s-head  {
  font-family:var(--fh);
  font-size:clamp(36px,5vw,56px);
  font-weight:800;
  line-height:1;
  color:var(--bg);
  margin-bottom:36px;
  letter-spacing:-.02em
}

.s-list  {
  list-style:none
}

.s-item  {
  border-bottom:1px solid rgba(232,229,223,.12)
}

.s-row  {
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:16px 0;
  cursor:pointer;
  transition:color .2s;
  color:rgba(232,229,223,.8)
}

.s-row:hover  {
  color:var(--bg)
}

.s-row-l  {
  display:flex;
  align-items:center;
  flex:1
}

.s-plus  {
  width:12px;
  height:12px;
  border-radius:50%;
  background:var(--bg);
  flex-shrink:0;
  margin-right:16px;
  display:flex;
  align-items:center;
  justify-content:center;
  transition:background .2s,transform .3s
}

.s-item.open .s-plus  {
  transform:rotate(45deg)
}

.s-ps  {
  font-size:8px;
  font-weight:500;
  line-height:1;
  color:var(--dark);
  pointer-events:none;
  user-select:none
}

.s-name  {
  font-size:16px;
  font-weight:300
}

.s-arr  {
  font-size:12px;
  opacity:0;
  transform:translateX(-4px);
  transition:opacity .2s,transform .2s
}

.s-row:hover .s-arr,.s-item.open .s-arr  {
  opacity:1;
  transform:rotate(90deg)
}

.s-body  {
  display:grid;
  grid-template-rows:0fr;
  transition:grid-template-rows .4s cubic-bezier(.23,1,.32,1)
}

.s-item.open .s-body  {
  grid-template-rows:1fr
}

.s-bi  {
  overflow:hidden
}

.s-bc  {
  padding:0 0 24px 28px;
  border-left:1px solid rgba(232,229,223,.12);
  margin-left:6px
}

.s-desc  {
  font-size:13px;
  line-height:1.85;
  color:rgba(232,229,223,.5);
  margin-bottom:16px;
  max-width:420px
}

.s-chips  {
  display:flex;
  flex-wrap:wrap;
  gap:7px
}

.s-chip  {
  padding:4px 12px;
  border:1px solid rgba(232,229,223,.16);
  border-radius:999px;
  font-size:11px;
  color:rgba(232,229,223,.55);
  letter-spacing:.04em
}

.s-cta  {
  margin-top:36px
}

.btn-ol  {
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:12px 24px;
  border:1px solid rgba(232,229,223,.28);
  border-radius:999px;
  color:var(--bg);
  font-size:13px;
  text-decoration:none;
  transition:background .2s,border-color .2s;
  cursor:pointer;
  font-family:var(--fb)
}

.btn-ol:hover  {
  background:rgba(232,229,223,.1);
  border-color:rgba(232,229,223,.55)
}

.s-vis  {
  background:var(--bg);
  border-radius:20px;
  aspect-ratio:4/5;
  position:relative;
  overflow:hidden;
  cursor:pointer
}

.s-vis:hover .svh  {
  opacity:1
}

.s-vis-in  {
  position:absolute;
  inset:0;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:12px;
  padding:24px
}

.svl  {
  width:100%;
  height:1px;
  background:var(--border)
}

.svdr  {
  display:flex;
  gap:8px;
  justify-content:center
}

.svd  {
  width:6px;
  height:6px;
  border-radius:50%;
  background:rgba(17,17,16,.15)
}

.svlbl  {
  font-size:10px;
  letter-spacing:.15em;
  text-transform:uppercase;
  color:var(--muted);
  font-weight:500
}

.svh  {
  position:absolute;
  inset:0;
  display:flex;
  align-items:center;
  justify-content:center;
  opacity:0;
  transition:opacity .2s;
  background:rgba(17,17,16,.18);
  border-radius:20px
}

.svh span  {
  font-family:var(--fh);
  font-size:11px;
  font-weight:600;
  letter-spacing:.15em;
  text-transform:uppercase;
  color:var(--bg)
}

/* ABOUT */
#about  {
  padding:0 32px 100px;
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:80px;
  align-items:center
}

.a-num  {
  font-family:var(--fh);
  font-size:clamp(80px,12vw,130px);
  font-weight:800;
  line-height:1;
  letter-spacing:-.04em;
  color:var(--dark);
  opacity:.06
}

.a-txt h2  {
  font-family:var(--fh);
  font-size:26px;
  font-weight:700;
  margin-bottom:16px;
  line-height:1.2
}

.a-txt p  {
  font-size:14px;
  color:var(--muted);
  line-height:1.9;
  max-width:380px
}

/* CONTACT */
#contact  {
  padding:40px 32px 100px
}

.c-head  {
  margin-bottom:60px
}

.c-head h2  {
  font-family:var(--fh);
  font-size:clamp(42px,6vw,72px);
  font-weight:800;
  line-height:1;
  letter-spacing:-.03em
}

.c-sub  {
  font-size:14px;
  color:var(--muted);
  margin-top:12px;
  max-width:340px;
  line-height:1.8
}

.c-grid  {
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:48px
}

.c-form  {
  display:flex;
  flex-direction:column;
  gap:20px
}

.f-field  {
  display:flex;
  flex-direction:column;
  gap:8px
}

.f-label  {
  font-size:11px;
  font-weight:500;
  letter-spacing:.1em;
  text-transform:uppercase;
  color:var(--muted)
}

.f-input  {
  background:transparent;
  border:none;
  border-bottom:1px solid var(--border);
  padding:10px 0;
  font-family:var(--fb);
  font-size:14px;
  color:var(--text);
  outline:none;
  transition:border-color .2s
}

.f-input:focus  {
  border-color:var(--dark)
}

.f-input::placeholder  {
  color:rgba(17,17,16,.3)
}

.opt-list  {
  display:flex;
  flex-wrap:wrap;
  gap:7px;
  margin-top:4px
}

.opt-item  {
  display:inline-flex;
  align-items:center;
  gap:6px;
  padding:6px 14px 6px 10px;
  border:1px solid var(--border);
  border-radius:999px;
  cursor:pointer;
  user-select:none;
  transition:border-color .2s,background .15s;
  flex:0 0 calc(25% - 6px)
}

.opt-item.on  {
  border-color:rgba(17,17,16,.35);
  background:rgba(17,17,16,.05)
}

.opt-d  {
  width:8px;
  height:8px;
  border-radius:50%;
  border:1px solid rgba(17,17,16,.2);
  flex-shrink:0;
  transition:border-color .2s,background .2s
}

.opt-item.on .opt-d  {
  border-color:var(--dark);
  background:var(--dark)
}

.opt-lbl  {
  font-size:12px;
  font-weight:300;
  color:var(--muted);
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
  transition:color .2s
}

.opt-item.on .opt-lbl  {
  color:var(--text);
  font-weight:400
}

.f-ta  {
  background:transparent;
  border:1px solid var(--border);
  border-radius:12px;
  padding:14px;
  font-family:var(--fb);
  font-size:14px;
  color:var(--text);
  outline:none;
  resize:none;
  height:100px;
  transition:border-color .2s
}

.f-ta:focus  {
  border-color:var(--dark)
}

.btn-send  {
  align-self:flex-start;
  padding:12px 32px;
  background:var(--dark);
  color:var(--bg);
  border:none;
  border-radius:999px;
  font-family:var(--fb);
  font-size:14px;
  cursor:pointer;
  transition:opacity .2s;
  letter-spacing:.02em
}

.btn-send:hover  {
  opacity:.75
}

.c-info  {
  display:flex;
  flex-direction:column;
  gap:40px
}

.c-info-b h4  {
  font-family:var(--fh);
  font-size:13px;
  font-weight:700;
  letter-spacing:.1em;
  text-transform:uppercase;
  margin-bottom:16px;
  color:var(--muted)
}

.c-email-lnk  {
  font-size:18px;
  font-weight:500;
  color:var(--text);
  text-decoration:none;
  border-bottom:1px solid var(--border);
  padding-bottom:8px;
  display:block;
  transition:border-color .2s
}

.c-email-lnk:hover  {
  border-color:var(--dark)
}

.soc-links  {
  display:flex;
  flex-direction:column;
  gap:8px
}

.soc-link  {
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:10px 14px;
  border:1px solid var(--border);
  border-radius:10px;
  text-decoration:none;
  color:var(--text);
  font-size:13px;
  transition:background .2s,color .2s,border-color .2s;
  cursor:pointer
}

.soc-link:hover  {
  background:var(--dark);
  color:var(--bg);
  border-color:var(--dark)
}

.soc-link span  {
  opacity:.4;
  font-size:11px
}

/* FOOTER */
footer  {
  border-top:1px solid var(--border);
  padding:24px 32px;
  display:flex;
  align-items:center;
  justify-content:space-between
}

.f-logo  {
  font-family:var(--fh);
  font-size:12px;
  font-weight:700;
  letter-spacing:.2em;
  text-transform:uppercase;
  color:var(--muted)
}

.f-copy  {
  font-size:12px;
  color:var(--muted)
}

/* FADE IN */
.fu  {
  opacity:0;
  transform:translateY(20px);
  transition:opacity .6s ease,transform .6s ease
}

.fu.vis  {
  opacity:1;
  transform:translateY(0)
}

/* OVERLAY */
.ovw  {
  position:fixed;
  inset:0;
  z-index:500;
  padding:20px;
  background:rgba(17,17,16,.55);
  backdrop-filter:blur(8px);
  opacity:0;
  pointer-events:none;
  transition:opacity .35s ease
}

.ovw.open  {
  opacity:1;
  pointer-events:all
}

.ovp {
  background:var(--dark);
  border-radius:28px;
  width:100%;
  height:100%;
  overflow-y:auto;
  overflow-x:hidden;
  display:flex;
  flex-direction:column;
  transform:translateY(28px);
  transition:transform .4s cubic-bezier(.23,1,.32,1);
  scrollbar-width:thin;
  scrollbar-color:rgba(232,229,223,.25) transparent
}

.ovw.open .ovp  {
  transform:translateY(0)
}



.ovtitle {
  font-family:var(--fh);
  font-size:clamp(18px,3.2vw,48px);
  font-weight:800;
  color:var(--bg);
  letter-spacing:-.02em;
  line-height:1.1;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis
}

.ovmeta  {
  display:flex;
  gap:40px;
  padding-top:6px
}

.ovmi  {
  display:flex;
  flex-direction:column;
  gap:4px
}

.ovml  {
  font-size:10px;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:rgba(232,229,223,.4);
  font-weight:500
}

.ovmv  {
  font-size:13px;
  font-weight:600;
  color:var(--bg);
  letter-spacing:.04em;
  text-transform:uppercase;
  font-family:var(--fh)
}

.ovcls  {
  display:inline-flex;
  align-items:center;
  gap:7px;
  padding:8px 18px;
  border:1px solid rgba(232,229,223,.2);
  border-radius:999px;
  background:transparent;
  color:var(--bg);
  font-family:var(--fb);
  font-size:12px;
  cursor:pointer;
  transition:border-color .2s;
  white-space:nowrap;
  flex-shrink:0
}

.ovcls::before  {
  content:'';
  width:6px;
  height:6px;
  border-radius:50%;
  background:var(--bg);
  flex-shrink:0
}

.ovcls:hover  {
  border-color:rgba(232,229,223,.55)
}

.ovdesc {
  padding:28px 48px 24px;
  flex-shrink:0;
  font-size:13px;
  line-height:2;
  color:rgba(232,229,223,.6);
  letter-spacing:.03em;
  columns:2;
  column-gap:48px
}

.ovphotos{height:590px;flex-shrink:0;display:flex;gap:16px;padding:24px 48px 36px;overflow-x:auto;overflow-y:hidden;scrollbar-width:none}

.ovphotos::-webkit-scrollbar  {
  display:none
}

.ovphoto{flex-shrink:0;border-radius:18px;width:465px;height:550px;background-size:cover;background-position:center}

.ovphoto.wide  {
  aspect-ratio:4/3
}

/* MOBILE */

/* Overlay header rows */

/* Overlay header rows — desktop */
.ovt {
  display:flex;
  flex-direction:column;
  padding:40px 48px 0;
  flex-shrink:0;
  gap:8px;
  position:sticky;
  top:0;
  z-index:2;
  background:var(--dark)
}
.ovt-row1 {
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:24px
}
.ovt-row2 {
  display:flex;
  align-items:center
}

.wpag{display:flex;justify-content:center;gap:6px;padding:12px 0 4px}
.wpag-dot{width:5px;height:5px;border-radius:50%;background:var(--border);cursor:pointer;transition:background .25s,transform .25s}
.wpag-dot.active{background:var(--dark);transform:scale(1.3)}
@media(max-width:900px) {
  nav {
  padding:14px 20px;
  background:var(--bg)
  }

.nav-r>* {
  display:none!important
  }

.mtrig {
  display:flex!important;
  align-items:center
  }

#hero {
  flex-direction:column;
  padding:100px 20px 40px
  }

#work {
  padding:0 0 60px
  }

.wgrid {
  display:none
  }

.wmob {
  display:block;
  overflow-x:auto;
  scrollbar-width:none;
  -webkit-overflow-scrolling:touch;
  padding:0 20px 8px
  }

.wmob::-webkit-scrollbar {
  display:none
  }

.wmob-inner{display:flex;gap:12px;width:max-content}

.wmc{width:58vw;max-width:240px;flex-shrink:0;background:var(--card);border-radius:16px;overflow:hidden;cursor:pointer;transition:transform .3s}
.wmc:first-child {
  border-top-left-radius:40px
  }

.wmc-thumb{width:100%;aspect-ratio:3/4;background-size:cover!important;background-position:center!important;background-repeat:no-repeat!important}



.wmc-cap {
  padding:10px 12px 14px;
  display:flex;
  flex-direction:column;
  gap:2px
  }

.wmc-ct{font-family:var(--fh);font-size:10px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

.wmc-cs {
  font-size:9px;
  color:var(--muted)
  }

#services {
  grid-template-columns:1fr;
  margin:0 0 60px;
  border-radius:24px;
  padding:40px 24px
  }

#about {
  grid-template-columns:1fr
  }

#about,#contact {
  padding-left:20px;
  padding-right:20px
  }

.c-grid {
  grid-template-columns:1fr
  }

.opt-item {
  flex:0 0 calc(50% - 4px)
  }

/* Mobile overlay header */
  .ovt{flex-direction:column;gap:0;padding:18px 20px 0}
  .ovt-row1 {
  align-items:center;
  gap:12px
  }
  .ovtitle {
  font-size:clamp(16px,5.5vw,28px);
  white-space:normal;
  word-break:break-word;
  line-height:1.15;
  flex:1;
  min-width:0
  }
  .ovt-row2{padding-top:10px;padding-bottom:2px}
  .ovmeta {
  gap:16px;
  flex-wrap:nowrap
  }
  .ovml { font-size:9px }
  .ovmv {
  font-size:10px;
  white-space:nowrap
  }
  .ovcls {
  flex-shrink:0;
  padding:5px 12px;
  font-size:10px;
  white-space:nowrap
  }

  /* Mobile: expanded description enables full panel scroll */
  .ovp {
  overflow-y:auto;
  overflow-x:hidden;
  -webkit-overflow-scrolling:touch;
  scrollbar-width:thin;
  scrollbar-color:rgba(232,229,223,.25) transparent
  }
  .ovdesc{columns:1;padding:16px 20px 0;text-align:left}
  .ovphotos{flex-shrink:0;display:flex;height:320px;padding:16px 20px 20px;gap:10px;overflow-x:auto;overflow-y:hidden;scrollbar-width:none;-webkit-overflow-scrolling:touch}
  .ovphoto{flex-shrink:0;width:240px;height:280px;border-radius:14px}

.wpag{display:none}
}

@media(min-width:901px)  {
  .mtrig,.mob,.wmob  {
  display:none!important
  }

nav  {
  background:var(--bg)
  }
}

/* Desktop lang dropdown */
.dls  {
  position:relative;
  display:inline-block
}

.dls-cur  {
  padding:0 14px;
  height:32px;
  display:flex;
  align-items:center;
  gap:5px;
  border:1px solid var(--border);
  border-radius:999px;
  font-size:11px;
  font-weight:500;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:var(--muted);
  background:transparent;
  cursor:pointer;
  font-family:var(--fb);
  transition:border-color .2s,color .2s,background .2s
}

.dls-cur::after  {
  content:"▾";
  font-size:9px;
  opacity:.6
}

.dls-cur:hover  {
  background:var(--dark);
  color:var(--bg);
  border-color:var(--dark)
}

.dls-drop  {
  display:none;
  position:absolute;
  top:calc(100% + 6px);
  right:0;
  background:var(--bg);
  border:1px solid var(--border);
  border-radius:12px;
  overflow:hidden;
  min-width:72px;
  z-index:400;
  box-shadow:0 4px 16px rgba(17,17,16,.1)
}

.dls-drop.open  {
  display:block
}

.dls-drop button  {
  display:block;
  width:100%;
  padding:8px 14px;
  font-size:11px;
  font-weight:500;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:var(--muted);
  background:transparent;
  border:none;
  cursor:pointer;
  font-family:var(--fb);
  text-align:left;
  transition:background .15s,color .15s
}

.dls-drop button:hover  {
  background:rgba(17,17,16,.05);
  color:var(--text)
}

.dls-drop button.on  {
  color:var(--text);
  font-weight:600
}



.site-logo-svg{display:block;height:56px;width:auto;color:var(--dark);transition:color .3s}
nav.mob-open .nav-logo .site-logo-svg{color:var(--bg) !important}
.f-logo .site-logo-svg{height:40px}

nav.scrolled { background:var(--bg); box-shadow:0 1px 0 var(--border) }
nav.scrolled.mob-open { background:var(--dark) !important; box-shadow:none !important }

/* Description expand/collapse */
.ovdesc-short{display:block}
.ovdesc-full{display:none}
.ovdesc.expanded .ovdesc-short{display:none}
.ovdesc.expanded .ovdesc-full{display:block}
.ovdesc-toggle{display:inline-flex;align-items:center;gap:5px;margin-top:10px;font-size:10px;font-family:var(--fh);font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:rgba(232,229,223,.4);cursor:pointer;border:none;background:none;padding:0;transition:color .2s}
.ovdesc-toggle:hover{color:rgba(232,229,223,.85)}
.ovdesc-toggle .tog-plus{font-size:14px;font-weight:300;line-height:1;transition:transform .25s}
.ovdesc.expanded .tog-plus{transform:rotate(45deg)}

/* Custom scrollbar for mobile overlay panel */
.ovp::-webkit-scrollbar {
  width:3px
}
.ovp::-webkit-scrollbar-track {
  background:transparent;
  margin:60px 0
}
.ovp::-webkit-scrollbar-thumb {
  background:rgba(232,229,223,.25);
  border-radius:999px
}
.ovp::-webkit-scrollbar-thumb:hover {
  background:rgba(232,229,223,.45)
}