/* ============================================================
   SADE HOME DESIGN — "the website as an architectural drawing"
   Design system · monochrome paper/ink + one clay accent
   ============================================================ */

/* ---------- TOKENS ---------- */
:root{
  --ink:#0A0A0A;
  --ink-2:#17150F;
  --paper:#F6F4EF;
  --paper-2:#EFEBE2;
  --white:#FFFFFF;
  --stone:#C9BEB0;        /* grid hairlines / borders */
  --stone-2:#E3DED4;
  --taupe:#8A8073;        /* muted text / labels */
  --clay:#B08355;         /* THE accent — interaction only */
  --clay-deep:#8a6338;

  --grid-line: color-mix(in srgb, var(--stone) 55%, transparent);
  --hair: 1px;

  --marginX: clamp(18px, 4.4vw, 56px);
  --maxw: 1560px;

  --f-display:"Bodoni Moda", "Times New Roman", serif;
  --f-serif:"Fraunces", Georgia, serif;
  --f-sans:"Archivo", "Helvetica Neue", Arial, sans-serif;

  --t-label: .70rem;
  --ls-label: .34em;

  --ease:cubic-bezier(.22,.61,.36,1);
  --ease-out:cubic-bezier(.16,1,.3,1);

  --dur:.9s;
}

*{box-sizing:border-box;margin:0;padding:0}
html{-webkit-text-size-adjust:100%;scroll-behavior:auto}
body{
  font-family:var(--f-sans);
  background:var(--paper);
  color:var(--ink);
  line-height:1.5;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font:inherit;color:inherit;background:none;border:none;cursor:pointer}
::selection{background:var(--clay);color:var(--paper)}

/* film grain / paper tactility */
body::after{
  content:"";position:fixed;inset:0;z-index:9000;pointer-events:none;
  opacity:.035;mix-blend-mode:multiply;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='140' height='140'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

/* ---------- PLAN GRID OVERLAY (the drafting language) ---------- */
.plan{position:fixed;inset:0;z-index:1;pointer-events:none}
.plan__rule{
  position:absolute;top:0;bottom:0;width:var(--hair);
  background:var(--grid-line);
  transform:scaleY(0);transform-origin:top;
}
.plan__rule.l{left:var(--marginX)}
.plan__rule.r{right:var(--marginX)}
.is-drawn .plan__rule{transform:scaleY(1);transition:transform 1.1s var(--ease) .15s}
/* faint interior columns (desktop only) */
.plan__col{position:absolute;top:0;bottom:0;width:var(--hair);background:color-mix(in srgb,var(--stone) 26%,transparent);opacity:0}
.is-drawn .plan__col{opacity:1;transition:opacity 1.4s ease .6s}

/* margin tick labels */
.tick{
  position:fixed;left:0;width:var(--marginX);z-index:2;pointer-events:none;
  font-family:var(--f-sans);font-size:9px;letter-spacing:.12em;color:var(--taupe);
  writing-mode:vertical-rl;text-orientation:mixed;
}
.tick--tl{top:104px}
.tick--bl{bottom:20px}
.tick--br{bottom:20px;left:auto;right:0;text-align:right;transform:scaleY(1) rotate(180deg)}
@media (max-width:820px){.tick,.plan__col{display:none}}

/* ---------- LAYOUT ---------- */
.wrap{max-width:var(--maxw);margin:0 auto;padding-inline:var(--marginX);position:relative;z-index:3}
.section{position:relative;padding-block:clamp(72px,11vh,150px)}
.sec-index{
  font-size:var(--t-label);letter-spacing:var(--ls-label);text-transform:uppercase;
  color:var(--taupe);display:flex;align-items:center;gap:14px;margin-bottom:34px;
}
.sec-index::before{content:"";width:40px;height:var(--hair);background:var(--ink)}
.sec-index b{color:var(--ink);font-weight:600}

.label{font-size:var(--t-label);letter-spacing:var(--ls-label);text-transform:uppercase;color:var(--taupe)}
.hair{height:var(--hair);background:var(--stone);border:0;transform-origin:left;width:100%}

/* ---------- TYPE ---------- */
.display{font-family:var(--f-display);font-weight:500;line-height:.94;letter-spacing:-.01em}
.serif{font-family:var(--f-serif)}
h1,h2,h3{font-weight:500}
.h-xl{font-family:var(--f-display);font-weight:500;line-height:.92;font-size:clamp(2.6rem,7vw,6.4rem);letter-spacing:-.02em}
.h-lg{font-family:var(--f-display);font-weight:500;line-height:.98;font-size:clamp(2rem,4.6vw,4rem);letter-spacing:-.01em}
.h-md{font-family:var(--f-display);font-weight:500;font-size:clamp(1.5rem,2.6vw,2.3rem);line-height:1.05}

/* ---------- HEADER ---------- */
.hd{
  position:fixed;top:0;left:0;right:0;z-index:400;
  padding:18px var(--marginX);
  display:flex;align-items:center;justify-content:space-between;
  mix-blend-mode:normal;transition:background .4s,box-shadow .4s,padding .4s;
}
.hd.scrolled{background:color-mix(in srgb,var(--paper) 86%,transparent);backdrop-filter:blur(9px);box-shadow:0 1px 0 var(--grid-line);padding-block:12px}
.hd__brand{font-family:var(--f-display);font-size:1.35rem;letter-spacing:.16em;font-weight:500;display:flex;align-items:baseline;gap:.5em}
.hd__brand small{font-family:var(--f-sans);font-size:8px;letter-spacing:.3em;color:var(--taupe);text-transform:uppercase}
.hd__nav{display:flex;gap:30px;align-items:center}
.hd__nav a{position:relative;font-size:.74rem;letter-spacing:.16em;text-transform:uppercase;padding:6px 0}
.hd__nav a::after{content:"";position:absolute;left:0;bottom:0;width:100%;height:var(--hair);background:var(--clay);transform:scaleX(0);transform-origin:left;transition:transform .45s var(--ease-out)}
.hd__nav a:hover::after,.hd__nav a.active::after{transform:scaleX(1)}
.hd__right{display:flex;align-items:center;gap:20px}
.hd__cart{position:relative;font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;display:flex;align-items:center;gap:8px}
.hd__cart .dot{min-width:18px;height:18px;border-radius:50%;background:var(--ink);color:var(--paper);font-size:10px;display:grid;place-items:center;letter-spacing:0}
.hd__menu{display:none;flex-direction:column;gap:5px;width:26px}
.hd__menu span{height:1.5px;background:var(--ink);transition:.35s}
@media (max-width:940px){
  .hd__nav{display:none}
  .hd__menu{display:flex}
}

/* ---------- HERO — type as aperture ---------- */
.hero{min-height:100svh;display:flex;flex-direction:column;justify-content:center;padding-top:96px;position:relative}
.hero__kicker{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:min(3vh,26px);gap:20px}
.hero__kicker .label{max-width:22ch}
.hero__title{
  font-family:var(--f-display);font-weight:500;
  font-size:clamp(5rem,25.5vw,26rem);
  line-height:.8;text-align:center;position:relative;
  color:var(--ink);                    /* ink fallback — always legible */
  letter-spacing:.06em;opacity:0;
}
.hero__title span{display:inline}
.is-loaded .hero__title{opacity:1;letter-spacing:-.02em;
  transition:opacity 1.1s var(--ease-out),letter-spacing 1.4s var(--ease-out)}
/* enhancement: image revealed THROUGH the letters (only when supported + loaded) */
body.clip-ok .hero__title{
  background-image:url("../img/hero-aperture.jpg");
  background-size:cover;background-position:center 40%;
  -webkit-background-clip:text;background-clip:text;
  color:transparent;-webkit-text-fill-color:transparent;
  animation:panbg 30s ease-in-out infinite alternate;
}
@keyframes panbg{from{background-position:36% 32%}to{background-position:64% 56%}}
.hero__tagline{text-align:center;margin-top:clamp(14px,2.4vh,30px);font-size:clamp(.66rem,1.15vw,.9rem);letter-spacing:.44em;text-transform:uppercase;color:var(--ink)}
.hero__block{
  display:flex;justify-content:space-between;align-items:flex-end;margin-top:auto;
  padding-top:min(6vh,54px);gap:24px;flex-wrap:wrap;
}
.hero__spec{font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--taupe);line-height:2}
.hero__spec b{color:var(--ink);font-weight:600}
.scrollcue{display:flex;flex-direction:column;align-items:center;gap:10px;font-size:9px;letter-spacing:.3em;text-transform:uppercase;color:var(--taupe)}
.scrollcue i{width:var(--hair);height:46px;background:var(--stone);position:relative;overflow:hidden}
.scrollcue i::after{content:"";position:absolute;inset:0;background:var(--ink);transform:translateY(-100%);animation:cue 2.4s var(--ease) infinite}
@keyframes cue{0%{transform:translateY(-100%)}55%,100%{transform:translateY(100%)}}

/* ---------- MANIFESTO ---------- */
.manifesto{padding-block:clamp(80px,14vh,190px)}
.manifesto p{
  font-family:var(--f-serif);font-weight:340;
  font-size:clamp(1.5rem,3.4vw,3rem);line-height:1.28;letter-spacing:-.01em;
  max-width:20ch;
}
.manifesto .mf-lead{max-width:none;width:min(66%,760px)}
.manifesto em{font-style:italic;color:var(--clay-deep)}
.manifesto .mf-foot{display:flex;gap:40px;margin-top:60px;flex-wrap:wrap}
.mf-stat b{font-family:var(--f-display);font-size:clamp(2rem,4vw,3.4rem);display:block;line-height:1}
.mf-stat span{font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--taupe)}

/* ---------- SERVICES — drafted spec table ---------- */
.svc__head{display:flex;justify-content:space-between;align-items:flex-end;gap:24px;flex-wrap:wrap;margin-bottom:8px}
.svc__list{border-top:var(--hair) solid var(--ink)}
.svc-row{
  display:grid;grid-template-columns:64px 1.4fr 2fr auto;gap:24px;align-items:center;
  padding:26px 4px;border-bottom:var(--hair) solid var(--stone);
  position:relative;transition:background .5s var(--ease),padding .5s var(--ease);
}
.svc-row:hover{background:var(--ink);color:var(--paper);padding-left:20px;padding-right:20px}
.svc-row:hover .svc-row__no,.svc-row:hover .svc-row__desc{color:var(--stone-2)}
.svc-row:hover .svc-row__arrow{color:var(--clay);transform:translateX(6px) rotate(-45deg)}
.svc-row__no{font-family:var(--f-sans);font-size:.72rem;letter-spacing:.1em;color:var(--taupe)}
.svc-row__name{font-family:var(--f-display);font-size:clamp(1.35rem,2.4vw,2rem);line-height:1.05}
.svc-row__desc{font-size:.86rem;color:var(--taupe);max-width:40ch}
.svc-row__arrow{font-size:1.3rem;transition:transform .5s var(--ease),color .5s;display:inline-block}
@media(max-width:760px){
  .svc-row{grid-template-columns:44px 1fr auto;gap:14px}
  .svc-row__desc{display:none}
}

/* ---------- FILMSTRIP — pinned horizontal cinematic pan ---------- */
.strip{position:relative;background:var(--ink);color:var(--paper);overflow:clip}
.strip__pin{height:100vh;position:sticky;top:0;display:flex;align-items:center;overflow:hidden}
.strip__track{display:flex;gap:clamp(24px,4vw,72px);padding-inline:var(--marginX);will-change:transform}
.strip__intro{min-width:min(80vw,520px);display:flex;flex-direction:column;justify-content:center;padding-right:20px}
.strip__intro .sec-index{color:var(--stone)}
.strip__intro .sec-index::before{background:var(--paper)}
.strip__intro .sec-index b{color:var(--paper)}
.frame{position:relative;flex:0 0 auto;width:clamp(280px,42vw,620px);align-self:center}
.frame__img{aspect-ratio:4/5;overflow:hidden;background:#222;position:relative}
.frame--wide .frame__img{aspect-ratio:16/11}
.frame__img img{width:100%;height:100%;object-fit:cover;filter:grayscale(1) contrast(1.04) brightness(.96);transition:filter .8s var(--ease),transform 1.1s var(--ease)}
.frame:hover .frame__img img{filter:grayscale(0) contrast(1);transform:scale(1.04)}
.frame__meta{display:flex;justify-content:space-between;margin-top:16px;font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--stone)}
.frame__no{color:var(--clay)}
.frame__title{font-family:var(--f-display);font-size:clamp(1.3rem,2vw,1.9rem);margin-top:6px}
.frame__loc{font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--stone);margin-top:2px}
.strip__hint{position:absolute;bottom:26px;right:var(--marginX);font-size:9px;letter-spacing:.3em;text-transform:uppercase;color:var(--stone);display:flex;align-items:center;gap:10px}
.strip__hint::before{content:"";width:40px;height:var(--hair);background:var(--stone)}
@media(max-width:820px){
  .strip__pin{height:auto;position:static;padding-block:70px}
  .strip__track{flex-direction:column;transform:none!important}
  .frame{width:100%}
  .strip__hint{display:none}
}

/* ---------- PROCESS ---------- */
.proc{display:grid;grid-template-columns:repeat(4,1fr);border-top:var(--hair) solid var(--ink)}
.proc__cell{padding:34px 22px 40px 0;border-right:var(--hair) solid var(--stone);position:relative}
.proc__cell:last-child{border-right:0}
.proc__no{font-family:var(--f-display);font-size:2.6rem;line-height:1;color:var(--stone);transition:color .5s}
.proc__cell:hover .proc__no{color:var(--clay)}
.proc__name{font-family:var(--f-display);font-size:1.35rem;margin:16px 0 10px}
.proc__txt{font-size:.85rem;color:var(--taupe);max-width:26ch}
@media(max-width:760px){.proc{grid-template-columns:1fr 1fr}.proc__cell{border-right:0;border-bottom:var(--hair) solid var(--stone)}}

/* ---------- SHOP — museum exhibition ---------- */
.shop__head{display:flex;justify-content:space-between;align-items:flex-end;gap:24px;flex-wrap:wrap;margin-bottom:52px}
.shop__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(24px,3vw,58px) clamp(20px,2.4vw,44px)}
.prod{position:relative}
.prod__fig{position:relative;overflow:hidden;background:var(--white);aspect-ratio:4/5}
.prod:nth-child(4n+2) .prod__fig{aspect-ratio:4/5}
.prod__fig img{width:100%;height:100%;object-fit:cover;filter:grayscale(1) contrast(1.03);transition:filter .7s var(--ease),transform 1.2s var(--ease)}
.prod:hover .prod__fig img{filter:grayscale(0);transform:scale(1.045)}
.prod__tag{position:absolute;top:14px;left:14px;font-size:9px;letter-spacing:.2em;text-transform:uppercase;color:var(--taupe);background:color-mix(in srgb,var(--paper) 82%,transparent);padding:4px 9px}
.prod__add{
  position:absolute;left:14px;right:14px;bottom:14px;
  background:var(--ink);color:var(--paper);font-size:.68rem;letter-spacing:.2em;text-transform:uppercase;
  padding:13px;text-align:center;
  opacity:0;transform:translateY(10px);transition:.5s var(--ease);
}
.prod:hover .prod__add{opacity:1;transform:none}
.prod__add:hover{background:var(--clay)}
.prod__label{display:flex;justify-content:space-between;align-items:baseline;gap:14px;margin-top:16px;border-top:var(--hair) solid var(--ink);padding-top:12px}
.prod__name{font-family:var(--f-display);font-size:1.12rem;line-height:1.1}
.prod__meta{font-size:10px;letter-spacing:.13em;text-transform:uppercase;color:var(--taupe);margin-top:4px}
.prod__price{font-family:var(--f-sans);font-size:.92rem;letter-spacing:.02em;white-space:nowrap}
@media(max-width:900px){.shop__grid{grid-template-columns:1fr 1fr;gap:34px 22px}}
@media(max-width:520px){.shop__grid{grid-template-columns:1fr}}

/* ---------- MATERIALS — the one warm strip ---------- */
.mat{background:var(--ink-2);color:var(--paper)}
.mat .sec-index{color:var(--stone)}
.mat .sec-index::before{background:var(--clay)}
.mat__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:2px;margin-top:30px}
.swatch{aspect-ratio:1/1.15;position:relative;display:flex;align-items:flex-end;padding:16px;overflow:hidden}
.swatch b{position:relative;z-index:2;font-family:var(--f-display);font-size:1.2rem}
.swatch small{position:absolute;top:14px;left:16px;font-size:9px;letter-spacing:.2em;text-transform:uppercase;opacity:.7}
.sw-clay{background:var(--clay);color:#241a10}
.sw-stone{background:var(--stone);color:#2a251d}
.sw-oak{background:#7c5a3a;color:#f3e7d6}
.sw-lin{background:var(--stone-2);color:#2a251d}
.sw-ink{background:#050505;color:var(--stone)}
.sw-brass{background:linear-gradient(135deg,#b8946a,#8a6338);color:#f3e7d6}
.sw-plaster{background:#d8d2c6;color:#2a251d}
.sw-marble{background:linear-gradient(135deg,#eceae4,#cfc9bd);color:#2a251d}
@media(max-width:640px){.mat__grid{grid-template-columns:1fr 1fr}}

/* ---------- TESTIMONIAL ---------- */
.quote{text-align:center;padding-block:clamp(90px,15vh,200px)}
.quote blockquote{font-family:var(--f-display);font-weight:500;font-size:clamp(1.7rem,4.4vw,3.6rem);line-height:1.18;letter-spacing:-.01em;max-width:18ch;margin:0 auto}
.quote blockquote span{color:var(--clay)}
.quote cite{display:block;margin-top:36px;font-style:normal;font-size:11px;letter-spacing:.24em;text-transform:uppercase;color:var(--taupe)}

/* ---------- VISIT ---------- */
.visit{display:grid;grid-template-columns:1fr 1fr;gap:0;border:var(--hair) solid var(--ink)}
.visit__info{padding:clamp(30px,4vw,60px);display:flex;flex-direction:column;gap:26px}
.visit__map{position:relative;background:var(--paper-2);border-left:var(--hair) solid var(--ink);min-height:340px;overflow:hidden}
.visit__map iframe{width:100%;height:100%;border:0;filter:grayscale(1) contrast(1.05);min-height:340px}
.visit__map .pin{position:absolute;top:14px;left:14px;z-index:2;background:var(--paper);padding:6px 12px;font-size:10px;letter-spacing:.16em;text-transform:uppercase}
.visit__row{border-top:var(--hair) solid var(--stone);padding-top:16px}
.visit__row .label{display:block;margin-bottom:6px}
.visit__row p{font-family:var(--f-display);font-size:1.25rem;line-height:1.3}
.visit__row a{border-bottom:var(--hair) solid transparent;transition:border-color .4s}
.visit__row a:hover{border-color:var(--clay)}
@media(max-width:820px){.visit{grid-template-columns:1fr}.visit__map{border-left:0;border-top:var(--hair) solid var(--ink)}}

/* ---------- FOOTER ---------- */
.ft{background:var(--ink);color:var(--paper);padding:clamp(50px,8vh,110px) var(--marginX) 30px;position:relative;z-index:3}
.ft__cta{display:flex;justify-content:space-between;align-items:flex-end;gap:30px;flex-wrap:wrap;border-bottom:var(--hair) solid color-mix(in srgb,var(--stone) 40%,transparent);padding-bottom:50px}
.ft__phone{font-family:var(--f-display);font-size:clamp(2.4rem,6.5vw,6rem);line-height:.9;letter-spacing:-.02em}
.ft__phone a{transition:color .4s}
.ft__phone a:hover{color:var(--clay)}
.ft__wa{border:var(--hair) solid var(--stone);color:var(--paper);padding:16px 28px;font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;transition:.4s;white-space:nowrap}
.ft__wa:hover{background:var(--clay);border-color:var(--clay);color:var(--ink)}
.ft__cols{display:grid;grid-template-columns:2fr 1fr 1fr;gap:40px;padding-block:50px}
.ft__cols h4{font-size:10px;letter-spacing:.24em;text-transform:uppercase;color:var(--stone);margin-bottom:18px;font-weight:500}
.ft__cols a,.ft__cols p{display:block;font-size:.86rem;color:color-mix(in srgb,var(--paper) 78%,transparent);margin-bottom:10px}
.ft__cols a:hover{color:var(--clay)}
.ft__mark{font-family:var(--f-display);font-size:clamp(3rem,14vw,11rem);line-height:.8;letter-spacing:.02em;color:color-mix(in srgb,var(--stone) 22%,transparent);border-top:var(--hair) solid color-mix(in srgb,var(--stone) 30%,transparent);padding-top:30px}
.ft__base{display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;margin-top:24px;font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--taupe)}
@media(max-width:760px){.ft__cols{grid-template-columns:1fr 1fr}}

/* ---------- CART DRAWER ---------- */
.scrim{position:fixed;inset:0;background:rgba(10,10,10,.5);opacity:0;visibility:hidden;transition:.4s;z-index:600;backdrop-filter:blur(2px)}
.scrim.open{opacity:1;visibility:visible}
.cart{
  position:fixed;top:0;right:0;bottom:0;width:min(430px,92vw);background:var(--paper);z-index:700;
  transform:translateX(100%);transition:transform .5s var(--ease);display:flex;flex-direction:column;
  box-shadow:-20px 0 60px rgba(0,0,0,.14);
}
.cart.open{transform:none}
.cart__hd{display:flex;justify-content:space-between;align-items:center;padding:24px var(--marginX);border-bottom:var(--hair) solid var(--ink)}
.cart__hd h3{font-family:var(--f-display);font-size:1.5rem}
.cart__close{font-size:1.4rem;line-height:1}
.cart__body{flex:1;overflow-y:auto;padding:10px var(--marginX)}
.cart__item{display:grid;grid-template-columns:64px 1fr auto;gap:16px;padding:20px 0;border-bottom:var(--hair) solid var(--stone);align-items:center}
.cart__item img{width:64px;height:78px;object-fit:cover;filter:grayscale(1)}
.cart__item .nm{font-family:var(--f-display);font-size:1.05rem}
.cart__item .mt{font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--taupe);margin-top:4px}
.cart__item .rm{font-size:9px;letter-spacing:.16em;text-transform:uppercase;color:var(--taupe);border-bottom:1px solid var(--stone);margin-top:8px;display:inline-block}
.cart__item .pr{font-size:.9rem;white-space:nowrap}
.cart__empty{color:var(--taupe);font-size:.9rem;padding:40px 0;text-align:center}
.cart__ft{padding:22px var(--marginX);border-top:var(--hair) solid var(--ink)}
.cart__tot{display:flex;justify-content:space-between;font-family:var(--f-display);font-size:1.4rem;margin-bottom:8px}
.cart__note{font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--taupe);margin-bottom:18px}
.btn-solid{display:block;width:100%;text-align:center;background:var(--ink);color:var(--paper);padding:16px;font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;transition:.4s}
.btn-solid:hover{background:var(--clay);color:var(--ink)}

/* ---------- MOBILE NAV ---------- */
.mnav{position:fixed;inset:0;background:var(--ink);color:var(--paper);z-index:650;transform:translateY(-100%);transition:transform .6s var(--ease);display:flex;flex-direction:column;justify-content:center;padding:var(--marginX)}
.mnav.open{transform:none}
.mnav a{font-family:var(--f-display);font-size:2.4rem;padding:12px 0;border-bottom:var(--hair) solid color-mix(in srgb,var(--stone) 30%,transparent)}
.mnav a:hover{color:var(--clay)}
.mnav__close{position:absolute;top:22px;right:var(--marginX);font-size:.8rem;letter-spacing:.2em;text-transform:uppercase}

/* ---------- PRELOADER ---------- */
.pre{position:fixed;inset:0;z-index:9500;background:var(--paper);display:grid;place-items:center;transition:opacity .7s ease,visibility .7s}
.pre.done{opacity:0;visibility:hidden}
.pre__mark{font-family:var(--f-display);font-size:clamp(2.4rem,8vw,4.6rem);letter-spacing:.3em;overflow:hidden}
.pre__mark span{display:inline-block;opacity:0;transform:translateY(100%)}
.pre.run .pre__mark span{opacity:1;transform:none;transition:all .7s var(--ease-out)}
.pre.run .pre__mark span:nth-child(1){transition-delay:.35s}
.pre.run .pre__mark span:nth-child(2){transition-delay:.45s}
.pre.run .pre__mark span:nth-child(3){transition-delay:.55s}
.pre.run .pre__mark span:nth-child(4){transition-delay:.65s}
.pre__bar{position:absolute;left:var(--marginX);right:var(--marginX);bottom:40px;height:var(--hair);background:var(--stone);transform:scaleX(0);transform-origin:left}
.pre.run .pre__bar{transform:scaleX(1);transition:transform 1.1s var(--ease)}
.pre__cap{position:absolute;bottom:48px;left:var(--marginX);font-size:9px;letter-spacing:.24em;text-transform:uppercase;color:var(--taupe)}
.pre__cap.r{left:auto;right:var(--marginX)}

/* ---------- CUSTOM CURSOR ---------- */
.cursor{position:fixed;top:0;left:0;z-index:9600;pointer-events:none;mix-blend-mode:difference;transform:translate(-50%,-50%);transition:width .3s,height .3s}
.cursor__x{position:relative;width:18px;height:18px}
.cursor__x::before,.cursor__x::after{content:"";position:absolute;background:var(--paper)}
.cursor__x::before{left:50%;top:0;width:1px;height:100%;transform:translateX(-50%)}
.cursor__x::after{top:50%;left:0;height:1px;width:100%;transform:translateY(-50%)}
.cursor.hoverimg{width:82px;height:82px}
.cursor.hoverimg .cursor__x{width:82px;height:82px;border:1px solid var(--paper);border-radius:50%}
.cursor.hoverimg .cursor__x::before,.cursor.hoverimg .cursor__x::after{opacity:0}
.cursor__t{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);color:var(--paper);font-size:9px;letter-spacing:.16em;text-transform:uppercase;opacity:0}
.cursor.hoverimg .cursor__t{opacity:1}
@media(hover:none),(pointer:coarse){.cursor{display:none}}

/* ---------- REVEAL ---------- */
.rv{opacity:0;transform:translateY(26px);transition:opacity 1s var(--ease-out),transform 1s var(--ease-out)}
.rv.in{opacity:1;transform:none}
.rv-d1{transition-delay:.08s}.rv-d2{transition-delay:.16s}.rv-d3{transition-delay:.24s}.rv-d4{transition-delay:.32s}
.clip{clip-path:inset(100% 0 0 0);transition:clip-path 1.15s var(--ease)}
.clip.in{clip-path:inset(0 0 0 0)}
.clip img{transform:scale(1.08);transition:transform 1.4s var(--ease)}
.clip.in img{transform:scale(1)}

/* ---- INNER PAGES (shop / service) ---- */
.page{padding-top:clamp(96px,12vh,150px)}
.phead{padding-block:clamp(30px,5vh,70px)}
.phead__row{display:grid;grid-template-columns:1.3fr 1fr;gap:40px;align-items:end;margin-top:20px}
.phead__lead{font-family:var(--f-serif);font-weight:300;font-size:clamp(1.05rem,1.5vw,1.3rem);line-height:1.5;color:var(--ink-2);max-width:44ch}
@media(max-width:820px){.phead__row{grid-template-columns:1fr;gap:24px}}

.filter{display:flex;flex-wrap:wrap;gap:8px;border-top:var(--hair) solid var(--ink);border-bottom:var(--hair) solid var(--stone);padding:18px 0;position:sticky;top:56px;background:color-mix(in srgb,var(--paper) 92%,transparent);backdrop-filter:blur(6px);z-index:120}
.filter__b{font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;padding:9px 16px;border:var(--hair) solid var(--stone);border-radius:40px;color:var(--taupe);transition:.35s}
.filter__b sup{font-size:.6em;color:var(--clay);margin-left:2px}
.filter__b:hover{border-color:var(--ink);color:var(--ink)}
.filter__b.active{background:var(--ink);color:var(--paper);border-color:var(--ink)}
.filter__empty{text-align:center;color:var(--taupe);padding:60px 0;font-size:.95rem}
.prod.hide{display:none}

.storenote{display:grid;grid-template-columns:1fr 1fr;gap:40px;border:var(--hair) solid var(--ink);padding:clamp(28px,4vw,56px);margin-bottom:clamp(60px,9vh,120px)}
.storenote__meta{display:flex;flex-direction:column;gap:16px;font-size:.85rem;color:var(--taupe)}
.storenote__meta b{color:var(--ink);font-family:var(--f-sans);font-weight:600;letter-spacing:.02em}
.storenote__meta .ft__wa{align-self:flex-start}
@media(max-width:760px){.storenote{grid-template-columns:1fr}}

/* service page case study */
.case{display:grid;grid-template-columns:5fr 7fr;gap:0;border:var(--hair) solid var(--ink);margin-block:clamp(30px,5vh,60px)}
.case__txt{padding:clamp(28px,3.4vw,52px);display:flex;flex-direction:column;gap:22px;border-right:var(--hair) solid var(--ink)}
.case__img{position:relative;overflow:hidden;min-height:420px}
.case__img img{width:100%;height:100%;object-fit:cover;filter:grayscale(1) contrast(1.03)}
.case__spec{display:grid;grid-template-columns:1fr 1fr;gap:16px;border-top:var(--hair) solid var(--stone);padding-top:20px;margin-top:auto}
.case__spec b{font-family:var(--f-display);font-size:1.5rem;display:block}
.case__spec span{font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--taupe)}
.gal{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-block:clamp(30px,4vh,50px)}
.gal .clip{aspect-ratio:4/5;overflow:hidden}
.gal .clip:first-child{grid-column:span 2;grid-row:span 2;aspect-ratio:auto}
.gal img{width:100%;height:100%;object-fit:cover;filter:grayscale(1) contrast(1.03)}
@media(max-width:820px){.case{grid-template-columns:1fr}.case__txt{border-right:0;border-bottom:var(--hair) solid var(--ink)}.gal{grid-template-columns:1fr 1fr}.gal .clip:first-child{grid-column:span 2;grid-row:auto;aspect-ratio:16/10}}

/* screenshot mode — neutralise the pinned filmstrip into a clean vertical flow */
body.static-shot .rv{opacity:1!important;transform:none!important}
body.static-shot .clip{clip-path:none!important}
body.static-shot{scroll-behavior:auto}
body.static-shot .hero{min-height:0;padding-top:130px;padding-bottom:70px}
body.static-shot .strip__pin{height:auto;position:static;overflow:visible;padding-block:70px}
body.static-shot .strip__track{flex-direction:column;transform:none!important;gap:60px}
body.static-shot .frame{width:100%;max-width:760px}
body.static-shot .strip__hint{display:none}

@media (prefers-reduced-motion:reduce){
  *{animation:none!important}
  .rv,.clip{opacity:1;transform:none;clip-path:none;transition:opacity .3s}
  .hero__title span{opacity:1;transform:none;filter:none}
  .scrollcue i::after{display:none}
}

/* ================= PHP SÜRÜMÜ EK BİLEŞENLER ================= */
/* breadcrumb */
.crumb{display:flex;gap:10px;align-items:center;font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;color:var(--taupe);margin-bottom:28px;flex-wrap:wrap}
.crumb a:hover{color:var(--clay)} .crumb span{color:var(--stone)}
/* PDP */
.pdp{display:grid;grid-template-columns:1.05fr 1fr;gap:clamp(24px,4vw,64px);align-items:start}
.pdp__img{position:relative;overflow:hidden;background:var(--white);aspect-ratio:4/5;border:var(--hair) solid var(--stone)}
.pdp__img img{width:100%;height:100%;object-fit:cover;filter:grayscale(1) contrast(1.03);transition:filter .8s var(--ease),transform 1.4s var(--ease)}
.pdp__img:hover img{filter:grayscale(0);transform:scale(1.04)}
.pdp__info{padding-top:10px}
.pdp__info .h-lg{margin:10px 0 18px}
.pdp__price{font-family:var(--f-display);font-size:2rem;margin-bottom:24px;display:flex;gap:14px;align-items:baseline}
.pdp__price s{font-family:var(--f-sans);font-size:1rem;color:var(--taupe)}
.pdp__desc{font-size:1rem;line-height:1.7;color:var(--ink-2);max-width:52ch;margin-bottom:28px}
.pdp__spec{display:grid;grid-template-columns:1fr 1fr;border-top:var(--hair) solid var(--ink);margin-bottom:28px}
.pdp__spec div{padding:14px 0;border-bottom:var(--hair) solid var(--stone);display:flex;justify-content:space-between;gap:12px}
.pdp__spec dt{font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;color:var(--taupe)}
.pdp__spec dd{font-family:var(--f-display);font-size:1.05rem}
.pdp__buy{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:16px}
.pdp__buy .btn-solid{width:auto;flex:1;min-width:220px;padding:18px 26px}
.pdp__wa{border:var(--hair) solid var(--ink);padding:18px 26px;font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;transition:.4s;white-space:nowrap;display:inline-flex;align-items:center}
.pdp__wa:hover{background:var(--clay);border-color:var(--clay);color:var(--ink)}
.pdp__note{font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--taupe)}
@media(max-width:820px){.pdp{grid-template-columns:1fr}.pdp__buy .btn-solid{min-width:0}}
/* forms */
.form{display:grid;gap:18px;max-width:560px}
.form label{display:block;font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:var(--taupe);margin-bottom:8px}
.form input,.form textarea{width:100%;font:inherit;font-size:.95rem;padding:14px 16px;border:var(--hair) solid var(--stone);background:var(--white);color:var(--ink);transition:border-color .3s}
.form input:focus,.form textarea:focus{outline:none;border-color:var(--ink)}
.form textarea{min-height:120px;resize:vertical}
.form .row2{display:grid;grid-template-columns:1fr 1fr;gap:18px}
@media(max-width:640px){.form .row2{grid-template-columns:1fr}}
.notice{padding:16px 18px;border:var(--hair) solid var(--clay);background:color-mix(in srgb,var(--clay) 8%,var(--paper));font-size:.9rem;margin-bottom:22px}
.notice.ok{border-color:#3a6b4a;background:#eef4ef}
/* checkout */
.checkout{display:grid;grid-template-columns:1.2fr .9fr;gap:clamp(30px,5vw,70px);align-items:start}
.osum{border:var(--hair) solid var(--ink);padding:26px;position:sticky;top:90px}
.osum h3{font-family:var(--f-display);font-size:1.4rem;margin-bottom:16px}
.osum__row{display:flex;justify-content:space-between;gap:12px;padding:12px 0;border-bottom:var(--hair) solid var(--stone);font-size:.9rem;align-items:center}
.osum__row img{width:46px;height:56px;object-fit:cover;filter:grayscale(1)}
.osum__tot{display:flex;justify-content:space-between;font-family:var(--f-display);font-size:1.4rem;padding-top:16px}
.osum__empty{color:var(--taupe);padding:20px 0}
@media(max-width:820px){.checkout{grid-template-columns:1fr}.osum{position:static}}
/* 404 */
.err{min-height:70vh;display:flex;flex-direction:column;justify-content:center;align-items:center;text-align:center;gap:20px}
.err h1{font-family:var(--f-display);font-size:clamp(4rem,16vw,11rem);line-height:.9}

/* ================= v3: MOBİL HEADER + KREATİF ANİMASYONLU ALANLAR ================= */
/* --- header cart ikonu + mobil kompakt --- */
.hd__cart{gap:9px}
.hd__cart svg{width:17px;height:17px;stroke:currentColor;fill:none;stroke-width:1.4}
.hd__menu{position:relative;z-index:460}
.hd__menu span{transition:transform .4s var(--ease),opacity .3s}
.hd__menu.on span:nth-child(1){transform:translateY(6.5px) rotate(45deg)}
.hd__menu.on span:nth-child(2){opacity:0}
.hd__menu.on span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}
@media(max-width:940px){
  .hd{padding-inline:16px}
  .hd__brand{font-size:1.15rem}
  .hd__brand small{display:none}
  .hd__cart .lbl{display:none}
  .hd__right{gap:16px}
}
.mnav{z-index:650}
.mnav a{transform:translateY(20px);opacity:0}
.mnav.open a{transform:none;opacity:1;transition:all .5s var(--ease-out)}
.mnav.open a:nth-child(2){transition-delay:.08s}
.mnav.open a:nth-child(3){transition-delay:.14s}
.mnav.open a:nth-child(4){transition-delay:.20s}
.mnav.open a:nth-child(5){transition-delay:.26s}
.mnav.open a:nth-child(6){transition-delay:.32s}
.mnav__meta{position:absolute;bottom:26px;left:var(--marginX);right:var(--marginX);display:flex;justify-content:space-between;font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--taupe);border-top:1px solid rgba(255,255,255,.14);padding-top:16px}

/* --- MİMARİ KAYAN ŞERİT (marquee) --- */
.ticker{background:var(--ink);color:var(--paper);overflow:hidden;padding:20px 0;position:relative}
.ticker__row{display:flex;width:max-content;white-space:nowrap;animation:tick 34s linear infinite}
.ticker:hover .ticker__row{animation-play-state:paused}
.ticker__row>span{font-family:var(--f-display);font-size:clamp(1.3rem,3.2vw,2.5rem);display:inline-flex;align-items:center;gap:34px;padding-right:34px}
.ticker__row>span::after{content:"✳";color:var(--clay);font-size:.6em;transform:translateY(-2px)}
@keyframes tick{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* --- ANİMASYONLU SAYAÇ (stats zaten .mf-stat) --- */
.mf-stat b{font-variant-numeric:tabular-nums}

/* --- YORUM DUVARI (reviews) --- */
.reviews{padding-block:clamp(80px,12vh,170px)}
.reviews__head{display:flex;justify-content:space-between;align-items:flex-end;gap:24px;flex-wrap:wrap;margin-bottom:48px}
.rating{display:flex;align-items:center;gap:16px}
.rating__num{font-family:var(--f-display);font-size:clamp(2.6rem,6vw,4.4rem);line-height:1}
.rating__stars{color:var(--clay);font-size:1.1rem;letter-spacing:3px}
.rating__meta{font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--taupe);margin-top:4px}
.rev-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(16px,2vw,28px)}
.rev{border:var(--hair) solid var(--stone);background:var(--white);padding:clamp(22px,2.4vw,34px);display:flex;flex-direction:column;gap:18px;position:relative;transition:transform .6s var(--ease),border-color .6s}
.rev:hover{transform:translateY(-6px);border-color:var(--ink)}
.rev__q{font-family:var(--f-display);font-size:2.4rem;line-height:.6;color:var(--clay);height:.5em}
.rev__text{font-family:var(--f-serif);font-weight:300;font-size:clamp(1.02rem,1.4vw,1.18rem);line-height:1.5;flex:1}
.rev__by{border-top:var(--hair) solid var(--stone);padding-top:14px;font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--taupe)}
.rev__by b{display:block;font-family:var(--f-sans);font-weight:600;color:var(--ink);letter-spacing:.02em;text-transform:none;font-size:.95rem;margin-bottom:2px}
.rev__stars{color:var(--clay);font-size:.85rem;letter-spacing:2px}
@media(max-width:820px){.rev-grid{grid-template-columns:1fr}.reviews__head{margin-bottom:32px}}

/* --- ölçülü ekstra hareket: bölüm başlıklarına imza çizgi büyümesi --- */
.h-lg,.h-xl{will-change:transform}
/* mobil hero ölçek düzeltme */
@media(max-width:560px){
  .hero__block{gap:16px}
  .hero__spec{font-size:10px}
  .hero__kicker .label{font-size:.62rem}
  .manifesto p{font-size:clamp(1.3rem,6vw,2rem)}
  .visit__row p{font-size:1.05rem}
}

/* yatay taşma kesin engeli (mobil header + yatay kaydırma fix) */
html{overflow-x:clip}
body{overflow-x:clip}
@media(max-width:560px){ .hero__title{font-size:clamp(4.2rem,23vw,7rem)} }
