/* =====================================================================
   DEKO MEBLI — Bespoke furniture & interiors
   Warm editorial · Fraunces serif · cream + clay + ink · parallax
   ===================================================================== */

:root{
  --paper:#f3ede3;
  --paper-2:#eee6d9;
  --card:#f8f3ea;
  --ink:#211c17;
  --ink-soft:#5b5147;
  --ink-mute:#726555;
  --line:#d8cdbb;
  --clay:#b1633b;
  --clay-deep:#8f4a28;
  --olive:#7d8471;
  --radius:6px;
  --maxw:1320px;
  --ease:cubic-bezier(.22,1,.36,1);
  --serif:'Fraunces',Georgia,serif;
  --sans:'Jost',system-ui,sans-serif;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{-webkit-text-size-adjust:100%;overflow-x:clip;background:var(--paper)}
html.lenis,html.lenis body{height:auto}
.lenis.lenis-smooth{scroll-behavior:auto!important}
.lenis.lenis-stopped{overflow:hidden}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}
body{
  font-family:var(--sans);background:transparent;color:var(--ink);
  line-height:1.6;font-weight:400;overflow-x:clip;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
}
/* ---------- three.js background ---------- */
.three-bg{position:fixed;inset:0;z-index:-1;pointer-events:none;display:block}
body.lock{overflow:hidden}
img{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:0;background:none;color:inherit}
ul,ol{list-style:none}
::selection{background:var(--clay);color:var(--paper)}

/* ---------- typography helpers ---------- */
.h2{font-family:var(--serif);font-weight:340;font-size:clamp(2rem,5vw,4rem);line-height:1.04;letter-spacing:-.015em}
.kick{display:inline-flex;align-items:center;gap:12px;font:500 12px/1 var(--sans);letter-spacing:.22em;text-transform:uppercase;color:var(--ink-mute);margin-bottom:28px}
.kick i{width:26px;height:1px;background:var(--clay)}
.link-arrow{display:inline-flex;align-items:center;gap:10px;font:500 14px/1 var(--sans);letter-spacing:.04em;color:var(--ink);transition:gap .4s var(--ease),color .3s}
.link-arrow i{font-style:normal;transition:transform .4s var(--ease)}
.link-arrow:hover{color:var(--clay)}
.link-arrow:hover i{transform:translateX(6px)}

/* ---------- image wrap (reveal) ---------- */
.img-wrap{position:relative;overflow:hidden;border-radius:var(--radius);background:linear-gradient(135deg,#e3d7c4,#cdbfa8)}
.img-wrap img{width:100%;height:100%;object-fit:cover;transition:transform 1.2s var(--ease);will-change:transform}
.img-wrap::after{content:"";position:absolute;inset:0;background:var(--paper);transform-origin:top;z-index:2;transition:transform 1.1s var(--ease)}
.img-wrap.in::after{transform:scaleY(0)}
.img-wrap.in img{transform:scale(1.001)}
.img-wrap:not(.in) img{transform:scale(1.12)}

/* ---------- loader ---------- */
.loader{position:fixed;inset:0;z-index:1000;background:var(--paper);display:grid;place-items:center}
.loader__inner{display:flex;flex-direction:column;align-items:center;gap:22px}
.loader__chair{width:140px;height:70px;overflow:visible}
.lc{fill:none;stroke:var(--ink);stroke-width:2.4;stroke-linecap:round;stroke-linejoin:round;
  stroke-dasharray:120;stroke-dashoffset:120;animation:draw 1.1s var(--ease) forwards}
.lc:nth-child(2){animation-delay:.12s}.lc:nth-child(3){animation-delay:.22s}
.lc:nth-child(4){animation-delay:.3s}.lc:nth-child(5){animation-delay:.42s}.lc:nth-child(6){animation-delay:.48s}
@keyframes draw{to{stroke-dashoffset:0}}
.loader__word{font-family:var(--serif);font-size:26px;font-weight:360;letter-spacing:.02em;opacity:0;animation:fadeUp .7s var(--ease) .5s forwards}
.loader__word i{font-style:italic;color:var(--clay)}
@keyframes fadeUp{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
.loader.done{transform:translateY(-101%);transition:transform 1.1s var(--ease)}

/* ---------- header ---------- */
.head{position:fixed;top:0;left:0;width:100%;z-index:200;display:flex;align-items:center;justify-content:space-between;
  padding:26px clamp(20px,5vw,64px);transition:padding .4s var(--ease),background .4s,box-shadow .4s}
.head.scrolled{padding:16px clamp(20px,5vw,64px);background:rgba(243,237,227,.85);backdrop-filter:blur(12px);box-shadow:0 1px 0 var(--line)}
.logo{display:flex;align-items:center;gap:12px}
.logo__mark{width:38px;height:auto}
.lm{fill:none;stroke:var(--ink);stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.logo__txt{font-family:var(--serif);font-size:22px;font-weight:380;letter-spacing:.01em}
.logo__txt i{font-style:italic;color:var(--clay)}
.hnav{display:flex;gap:36px}
.hnav a{position:relative;font:500 13px/1 var(--sans);letter-spacing:.04em;color:var(--ink-soft);transition:color .3s}
.hnav a::after{content:"";position:absolute;left:0;bottom:-6px;width:0;height:1px;background:var(--clay);transition:width .4s var(--ease)}
.hnav a:hover{color:var(--ink)}.hnav a:hover::after{width:100%}
.head__right{display:flex;align-items:center;gap:22px}
.lang{display:flex;align-items:center;gap:8px;font:500 13px/1 var(--sans)}
.lang button{color:var(--ink-mute);transition:color .3s}.lang button.is-active{color:var(--ink)}
.hburger{display:none;flex-direction:column;gap:6px;width:30px;height:26px;justify-content:center;align-items:flex-end}
.hburger span{height:1.6px;background:var(--ink);transition:.4s var(--ease)}
.hburger span:nth-child(1){width:24px}.hburger span:nth-child(2){width:16px}
.hburger.open span:nth-child(1){transform:translateY(3.8px) rotate(45deg);width:22px}
.hburger.open span:nth-child(2){transform:translateY(-3.8px) rotate(-45deg);width:22px}

/* ---------- mobile nav ---------- */
.mnav{position:fixed;inset:0;z-index:190;background:var(--paper-2);display:flex;flex-direction:column;justify-content:center;gap:6px;
  padding:0 32px;clip-path:inset(0 0 100% 0);transition:clip-path .8s var(--ease);pointer-events:none}
.mnav.open{clip-path:inset(0 0 0 0);pointer-events:auto}
.mnav nav{display:flex;flex-direction:column;gap:4px}
.mnav nav a{font-family:var(--serif);font-size:13vw;font-weight:340;line-height:1.05;color:var(--ink);transition:color .3s,padding-left .4s var(--ease)}
.mnav nav a:hover{color:var(--clay);padding-left:10px}
.mnav__phone{margin-top:36px;font:500 16px/1 var(--sans);color:var(--clay);letter-spacing:.05em}

/* ---------- hero ---------- */
.hero{padding:140px clamp(20px,5vw,64px) 0;max-width:var(--maxw);margin:0 auto}
.hero__head{display:flex;flex-direction:column}
.hero__since{font:500 12px/1 var(--sans);letter-spacing:.22em;text-transform:uppercase;color:var(--ink-mute);margin-bottom:28px}
.hero__title{font-family:var(--serif);font-weight:330;font-size:clamp(2.8rem,10vw,9rem);line-height:.95;letter-spacing:-.02em}
.hero__title span{display:block}
.hero__title em{font-style:italic;color:var(--clay)}
.hero__media{display:grid;grid-template-columns:1.7fr 1fr;gap:clamp(24px,4vw,56px);align-items:end;margin-top:clamp(30px,5vw,60px)}
.hero__img{aspect-ratio:16/10}
.hero__lead{font-size:clamp(1rem,1.4vw,1.18rem);color:var(--ink-soft);max-width:360px;padding-bottom:8px}
.hero__marquee{margin-top:clamp(40px,6vw,80px);overflow:hidden;border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:18px 0}
.hm-track{display:flex;align-items:center;gap:26px;width:max-content;white-space:nowrap;animation:marq 30s linear infinite}
.hm-track span{font-family:var(--serif);font-style:italic;font-weight:340;font-size:clamp(1.3rem,2.6vw,2rem);color:var(--ink)}
.hm-track b{color:var(--clay);font-weight:300}
@keyframes marq{to{transform:translateX(-50%)}}

/* ---------- philosophy ---------- */
.philo{max-width:1100px;margin:0 auto;padding:clamp(90px,15vw,200px) clamp(20px,5vw,64px)}
.philo__text{font-family:var(--serif);font-weight:330;font-size:clamp(1.5rem,3.6vw,2.9rem);line-height:1.28;letter-spacing:-.01em}
.philo__text span{display:block}
.philo__text .muted{color:var(--ink-mute);font-style:italic}
[data-line]{opacity:0;transform:translateY(20px);transition:opacity .9s var(--ease),transform .9s var(--ease)}
[data-line].in{opacity:1;transform:none}

/* ---------- studio ---------- */
.studio{max-width:var(--maxw);margin:0 auto;padding:clamp(40px,6vw,90px) clamp(20px,5vw,64px)}
.studio__head{display:flex;flex-direction:column;margin-bottom:60px}
.studio__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden}
.scard{background:var(--paper);padding:clamp(28px,3vw,44px);display:flex;flex-direction:column;gap:14px;min-height:240px;transition:background .5s var(--ease)}
.scard:hover{background:var(--card)}
.scard__no{font:500 12px/1 var(--sans);letter-spacing:.18em;color:var(--clay-deep)}
.scard h3{font-family:var(--serif);font-weight:380;font-size:1.5rem;line-height:1.1;margin-top:auto}
.scard p{color:var(--ink-soft);font-size:.96rem}

/* ---------- feature split ---------- */
.feature{max-width:var(--maxw);margin:0 auto;padding:clamp(60px,9vw,130px) clamp(20px,5vw,64px);
  display:grid;grid-template-columns:1.1fr 1fr;gap:clamp(40px,6vw,90px);align-items:center}
.feature__img{aspect-ratio:4/5}
.feature__copy p{color:var(--ink-soft);font-size:1.06rem;margin:22px 0 30px;max-width:420px}

/* ---------- process ---------- */
.proc{max-width:var(--maxw);margin:0 auto;padding:clamp(60px,9vw,130px) clamp(20px,5vw,64px)}
.proc__head{margin-bottom:60px}
.proc__list{display:grid;gap:0;border-top:1px solid var(--line)}
.proc__list li{display:grid;grid-template-columns:120px 1fr;gap:clamp(20px,4vw,60px);padding:clamp(28px,4vw,46px) 0;border-bottom:1px solid var(--line);align-items:start}
.proc__n{font-family:var(--serif);font-style:italic;font-weight:330;font-size:clamp(2rem,4vw,3.4rem);color:var(--clay);line-height:1}
.proc__list h3{font-family:var(--serif);font-weight:380;font-size:clamp(1.4rem,2.4vw,1.9rem);margin-bottom:10px}
.proc__list p{color:var(--ink-soft);font-size:1.02rem;max-width:560px}

/* ---------- materials ---------- */
.mats{max-width:var(--maxw);margin:0 auto;padding:clamp(60px,9vw,130px) clamp(20px,5vw,64px)}
.mats__head{max-width:680px;margin-bottom:60px}
.mats__lead{color:var(--ink-soft);font-size:1.08rem;margin-top:22px}
.mats__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(20px,3vw,40px)}
.mat{display:flex;flex-direction:column;gap:14px}
.mat__swatch{width:100%;aspect-ratio:3/2;border-radius:var(--radius);background:var(--c);border:1px solid rgba(0,0,0,.06)}
.mat h4{font-family:var(--serif);font-weight:400;font-size:1.2rem}
.mat p{color:var(--ink-soft);font-size:.92rem}

/* ---------- work / gallery ---------- */
.work{max-width:var(--maxw);margin:0 auto;padding:clamp(60px,9vw,130px) clamp(20px,5vw,64px)}
.work__head{margin-bottom:56px}
.work__grid{display:grid;grid-template-columns:repeat(2,1fr);gap:clamp(20px,3vw,40px)}
.proj{aspect-ratio:4/3;position:relative}
.proj--tall{aspect-ratio:4/5;grid-row:span 1}
.proj figcaption{position:absolute;left:0;bottom:0;z-index:3;padding:22px 24px;color:var(--paper);
  display:flex;flex-direction:column;gap:2px;background:linear-gradient(to top,rgba(20,16,12,.6),transparent);width:100%}
.proj figcaption b{font-family:var(--serif);font-weight:400;font-size:1.3rem}
.proj figcaption span{font-size:.85rem;letter-spacing:.06em;opacity:.85}

/* ---------- numbers ---------- */
.nums{max-width:var(--maxw);margin:0 auto;padding:clamp(50px,7vw,100px) clamp(20px,5vw,64px);
  display:grid;grid-template-columns:repeat(4,1fr);gap:30px;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.num{display:flex;flex-direction:column;gap:8px}
.num b{font-family:var(--serif);font-weight:330;font-size:clamp(2.6rem,5vw,4.2rem);line-height:1}
.num span{font:400 13px/1.4 var(--sans);letter-spacing:.08em;text-transform:uppercase;color:var(--ink-mute)}

/* ---------- quote ---------- */
.quote{max-width:1000px;margin:0 auto;padding:clamp(80px,12vw,160px) clamp(20px,5vw,64px);text-align:center}
.quote blockquote p{font-family:var(--serif);font-weight:330;font-style:italic;font-size:clamp(1.5rem,3.4vw,2.6rem);line-height:1.32;letter-spacing:-.01em}
.quote footer{margin-top:36px;display:flex;flex-direction:column;gap:4px}
.quote footer b{font-family:var(--serif);font-weight:400;font-size:1.2rem}
.quote footer span{font-size:.86rem;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-mute)}

/* ---------- cta / contact ---------- */
.cta{background:var(--ink);color:var(--paper);margin:0 clamp(12px,2vw,24px) clamp(12px,2vw,24px);border-radius:clamp(12px,2vw,24px);
  padding:clamp(60px,9vw,130px) clamp(24px,5vw,80px)}
.cta__grid{max-width:var(--maxw);margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:clamp(40px,6vw,100px)}
.cta .kick{color:rgba(243,237,227,.6)}.cta .kick i{background:var(--clay)}
.cta__title{color:var(--paper)}
.cta__copy p{color:rgba(243,237,227,.72);font-size:1.06rem;margin:22px 0 40px;max-width:400px}
.cta__info{display:grid;gap:20px}
.cta__info li{display:flex;flex-direction:column;gap:4px;border-top:1px solid rgba(243,237,227,.16);padding-top:16px}
.cta__info span{font:500 11px/1 var(--sans);letter-spacing:.18em;text-transform:uppercase;color:rgba(243,237,227,.5)}
.cta__info a{font-size:1.04rem;color:var(--paper);transition:color .3s}.cta__info a:hover{color:var(--clay)}
.cta__form{display:grid;grid-template-columns:1fr 1fr;gap:26px 22px;align-content:start}
.fld{position:relative}.fld--full{grid-column:1/-1}
.fld input,.fld select,.fld textarea{width:100%;background:transparent;border:0;border-bottom:1px solid rgba(243,237,227,.26);
  padding:12px 0;color:var(--paper);font:400 1rem var(--sans);transition:border-color .3s}
.fld select option{background:var(--ink);color:var(--paper)}
.fld textarea{resize:vertical}
.fld input:focus,.fld select:focus,.fld textarea:focus{outline:none;border-color:var(--clay)}
.fld label{position:absolute;left:0;top:12px;color:rgba(243,237,227,.55);pointer-events:none;transition:transform .3s var(--ease),font-size .3s,color .3s}
.fld input:focus+label,.fld input:not(:placeholder-shown)+label,
.fld textarea:focus+label,.fld textarea:not(:placeholder-shown)+label,
.fld .lbl-static{transform:translateY(-22px);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--clay)}
.lbl-static{top:12px}
.btn-fill{grid-column:1/-1;justify-self:start;display:inline-flex;align-items:center;gap:12px;background:var(--clay);color:var(--paper);
  padding:1.1em 2em;border-radius:60px;font:500 14px/1 var(--sans);letter-spacing:.04em;transition:background .4s,gap .4s var(--ease),transform .4s var(--ease)}
.btn-fill i{font-style:normal;transition:transform .4s var(--ease)}
.btn-fill:hover{background:var(--paper);color:var(--ink)}.btn-fill:hover i{transform:translateX(6px)}
.form-note{grid-column:1/-1;font:400 13px var(--sans);color:#9fd3a0;min-height:18px}
.form-note.error{color:#e6a07a}

/* ---------- footer ---------- */
.foot{padding:clamp(50px,7vw,90px) clamp(20px,5vw,64px) 30px;overflow:hidden}
.foot__big{font-family:var(--serif);font-weight:300;font-size:clamp(3.5rem,16vw,15rem);line-height:.9;letter-spacing:-.02em;color:var(--ink);opacity:.92;margin-bottom:50px}
.foot__big em{font-style:italic;color:var(--clay)}
.foot__grid{max-width:var(--maxw);display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:40px;border-top:1px solid var(--line);padding-top:40px}
.foot__col p{color:var(--ink-soft);max-width:280px}
.foot__col h5{font:500 11px/1 var(--sans);letter-spacing:.2em;text-transform:uppercase;color:var(--ink-mute);margin-bottom:18px}
.foot__col a{display:block;color:var(--ink-soft);margin-bottom:10px;font-size:.96rem;transition:color .3s}
.foot__col a:hover{color:var(--clay)}
.foot__bottom{max-width:var(--maxw);margin-top:50px;padding-top:24px;border-top:1px solid var(--line);display:flex;justify-content:space-between;gap:20px;flex-wrap:wrap;font:400 13px var(--sans);color:var(--ink-mute);letter-spacing:.04em}

/* ---------- reveal ---------- */
[data-reveal]{opacity:0;transform:translateY(28px);transition:opacity 1s var(--ease),transform 1s var(--ease)}
[data-reveal].in{opacity:1;transform:none}

/* ---------- legal ---------- */
.legal{max-width:820px;margin:0 auto;padding:160px clamp(20px,5vw,40px) 100px}
.legal h1{font-family:var(--serif);font-weight:340;font-size:clamp(2rem,6vw,3.4rem);margin-bottom:12px;letter-spacing:-.01em}
.legal .upd{font:400 13px var(--sans);color:var(--ink-mute);letter-spacing:.06em;margin-bottom:48px}
.legal h2{font-family:var(--serif);font-weight:400;font-size:1.5rem;margin:40px 0 14px}
.legal p,.legal li{color:var(--ink-soft);margin-bottom:14px}
.legal ul{padding-left:22px;list-style:disc}
.legal a{color:var(--clay)}
.legal .back{display:inline-flex;align-items:center;gap:8px;margin-bottom:40px;font:500 13px var(--sans);color:var(--ink-soft)}
.legal .back:hover{color:var(--clay)}

/* ===================================================================
   RESPONSIVE
   =================================================================== */
@media (max-width:1024px){
  .hnav,.head__cta{display:none}
  .hburger{display:flex}
  .studio__grid{grid-template-columns:repeat(2,1fr)}
  .feature{grid-template-columns:1fr}
  .feature__img{aspect-ratio:16/10;order:-1}
  .cta__grid{grid-template-columns:1fr}
  .mats__grid{grid-template-columns:repeat(2,1fr)}
  .foot__grid{grid-template-columns:1fr 1fr}
}
@media (max-width:680px){
  .head{padding:18px 20px}
  .hero{padding:120px 20px 0}
  .hero__media{grid-template-columns:1fr;align-items:start}
  .hero__lead{max-width:none}
  .nums{grid-template-columns:1fr 1fr}
  .work__grid{grid-template-columns:1fr}
  .proj,.proj--tall{aspect-ratio:4/3}
  .proc__list li{grid-template-columns:1fr;gap:10px}
  .cta__form{grid-template-columns:1fr}
  .foot__grid{grid-template-columns:1fr 1fr;gap:30px}
  .foot__bottom{flex-direction:column;gap:8px}
}
@media (max-width:430px){
  .studio__grid{grid-template-columns:1fr}
  .mats__grid{grid-template-columns:1fr 1fr}
  .foot__grid{grid-template-columns:1fr}
}

/* ---------- keyboard focus ---------- */
a:focus-visible,button:focus-visible,
.fld input:focus-visible,.fld select:focus-visible,.fld textarea:focus-visible{
  outline:2px solid var(--clay);outline-offset:3px;border-radius:2px}

/* ---------- reduced motion ---------- */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{
    animation-duration:.001ms!important;animation-iteration-count:1!important;
    transition-duration:.01ms!important;scroll-behavior:auto!important}
  .img-wrap::after{transform:scaleY(0)!important}
  .img-wrap img{transform:none!important}
}
