/* ==========================================================
   ТКАЧ — Weaving studio. Undyed wool tones + madder rust + indigo.
   Young Serif + Figtree + IBM Plex Mono
   ========================================================== */
*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
html,body{margin:0;padding:0;overflow-x:clip}
:root{
  --bg:#EDE6D6;--bg-2:#E2D8C2;--paper:#F6F1E4;
  --ink:#2A2419;--ink-2:#4A4234;--ink-3:#776C58;--ink-4:#A89C82;
  --rust:#A24B2C;--rust-d:#7E3619;--indigo:#2D3F4A;--indigo-d:#1C2A33;--ochre:#C99A3E;
  --line:rgba(42,36,25,.16);--line-s:rgba(42,36,25,.3);
  --f-d:"Young Serif",Georgia,serif;--f-b:"Figtree",system-ui,sans-serif;--f-m:"IBM Plex Mono",ui-monospace,monospace;
  --pad-x:clamp(20px,4vw,72px);--sec-y:clamp(80px,9vw,140px);--ease:cubic-bezier(.22,.9,.3,1);
}
body{background:var(--bg);color:var(--ink);font-family:var(--f-b);font-size:16px;line-height:1.6;-webkit-font-smoothing:antialiased}
img,svg,video,iframe{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font:inherit;background:none;border:0;padding:0;color:inherit;cursor:pointer}
ul,ol{margin:0;padding:0;list-style:none}
h1,h2,h3,h4,p,dl,dt,dd,figure,blockquote{margin:0;padding:0;border:0}
address{font-style:normal}
::selection{background:var(--rust);color:var(--paper)}
:focus-visible{outline:2px solid var(--rust);outline-offset:3px}

.hdr{position:sticky;top:0;z-index:30;padding:14px var(--pad-x);background:rgba(237,230,214,.95);backdrop-filter:blur(8px);border-bottom:1px solid var(--line);display:flex;align-items:center;gap:22px;justify-content:space-between}
.lg{display:inline-flex;align-items:baseline;gap:10px;color:var(--ink)}
.lg-w{font-family:var(--f-d);font-size:28px;letter-spacing:.02em;line-height:1}
.lg-s{font-family:var(--f-m);font-size:11px;color:var(--ink-3);letter-spacing:.03em}
.nv{display:flex;gap:26px;font-family:var(--f-b);font-size:14px;font-weight:500;color:var(--ink-2)}
.nv a{position:relative;padding:4px 0;transition:color .25s var(--ease)}
.nv a:hover{color:var(--rust)}
.cta{font-family:var(--f-b);font-size:13px;font-weight:600;padding:12px 22px;background:var(--indigo);color:var(--paper);transition:background .25s var(--ease)}
.cta:hover{background:var(--rust)}
.mb{display:none;width:42px;height:42px;align-items:center;justify-content:center;color:var(--ink);border:1px solid var(--line-s)}
.drawer{position:fixed;inset:0;z-index:80;background:var(--indigo-d);color:var(--paper);padding:24px var(--pad-x);display:flex;flex-direction:column;gap:32px;opacity:0;pointer-events:none;transition:opacity .35s var(--ease)}
body.dr-open .drawer{opacity:1;pointer-events:auto}
.dr-x{align-self:flex-end;width:42px;height:42px;color:var(--paper);border:1px solid rgba(246,241,228,.3);display:inline-flex;align-items:center;justify-content:center}
.drawer nav{flex:1;display:flex;flex-direction:column;justify-content:center;gap:4px}
.drawer nav a{padding:16px 0;border-bottom:1px solid rgba(246,241,228,.16);font-family:var(--f-d);font-size:clamp(30px,8vw,52px);color:var(--paper)}

.hero{padding:clamp(48px,6vw,84px) var(--pad-x) clamp(40px,5vw,64px);max-width:1400px;margin:0 auto;display:flex;flex-direction:column;gap:clamp(36px,4vw,56px)}
.hero-grid{display:grid;grid-template-columns:1fr 1.05fr;gap:clamp(28px,4vw,72px);align-items:center}
.hero-l{display:flex;flex-direction:column;gap:22px}
.rb{font-family:var(--f-m);font-size:11px;color:var(--rust);letter-spacing:.04em;text-transform:uppercase}
.rb-l{color:var(--ochre)}
.hh{font-family:var(--f-d);font-size:clamp(42px,5.6vw,96px);line-height:1.05;letter-spacing:-.005em;color:var(--ink)}
.hh em{color:var(--rust)}
.hp{font-family:var(--f-b);font-size:16.5px;line-height:1.7;color:var(--ink-2);max-width:56ch}
.cta-r{display:flex;gap:14px;flex-wrap:wrap}
.btn{display:inline-flex;align-items:center;gap:10px;padding:14px 24px;font-family:var(--f-b);font-size:13px;font-weight:600;cursor:pointer;border:1px solid transparent;transition:background .25s var(--ease),color .25s var(--ease),border-color .25s var(--ease),transform .2s var(--ease)}
.btn-d{background:var(--indigo);color:var(--paper)}
.btn-d:hover{background:var(--rust);transform:translateY(-1px)}
.btn-l{background:transparent;color:var(--ink);border-color:var(--ink)}
.btn-l:hover{background:var(--ink);color:var(--paper)}
.hero-fig{margin:0}
.hero-fig img{width:100%;aspect-ratio:5/4;object-fit:cover;filter:saturate(.95) contrast(1.03)}
.hero-fig figcaption{font-family:var(--f-m);font-size:11px;color:var(--ink-3);letter-spacing:.02em;margin-top:10px}
.hero-strip{display:grid;grid-template-columns:repeat(4,1fr);border-top:1px solid var(--indigo);border-bottom:1px solid var(--indigo)}
.hero-strip li{padding:20px 22px;border-right:1px solid var(--line);display:flex;flex-direction:column;gap:5px}
.hero-strip li:last-child{border-right:0}
.hero-strip b{font-family:var(--f-d);font-size:clamp(28px,3.4vw,46px);color:var(--rust);line-height:1}
.hero-strip span{font-family:var(--f-m);font-size:10.5px;color:var(--ink-3);letter-spacing:.02em;text-transform:uppercase}

.sh{display:flex;flex-direction:column;gap:14px;padding:0 var(--pad-x) clamp(36px,4vw,56px);max-width:1400px;margin:0 auto}
.sh-h{font-family:var(--f-d);font-size:clamp(38px,5.2vw,84px);line-height:1.05;letter-spacing:-.005em;color:var(--ink);max-width:18ch}
.sh-h em{color:var(--rust)}
.sh-h-l{color:var(--paper)}
.sh-p{font-family:var(--f-b);font-size:16px;line-height:1.7;color:var(--ink-2);max-width:62ch}
.sh-p-l{color:rgba(246,241,228,.8)}

.cat{padding:var(--sec-y) 0;max-width:1400px;margin:0 auto}
.ct-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin:0 var(--pad-x)}
.cw{background:var(--paper);border:1px solid var(--line);display:flex;flex-direction:column;position:relative;transition:transform .3s var(--ease)}
.cw:hover{transform:translateY(-4px)}
.cw figure{margin:0;aspect-ratio:5/4;overflow:hidden}
.cw figure img{width:100%;height:100%;object-fit:cover;transition:transform 1s var(--ease)}
.cw:hover figure img{transform:scale(1.05)}
.cw-b{padding:18px 20px;display:flex;flex-direction:column;gap:7px}
.cw-n{font-family:var(--f-m);font-size:11px;color:var(--rust);letter-spacing:.04em}
.cw-b h3{font-family:var(--f-d);font-size:23px;color:var(--ink)}
.cw-b p{font-family:var(--f-b);font-size:13.5px;line-height:1.55;color:var(--ink-3)}
.cw-px{font-family:var(--f-m);font-size:12.5px;color:var(--rust);padding-top:8px;border-top:1px dashed var(--line);margin-top:auto}
.cw-flag{position:absolute;top:10px;left:10px;font-family:var(--f-m);font-size:10px;letter-spacing:.04em;text-transform:uppercase;padding:5px 10px;background:var(--rust);color:var(--paper)}
.cw--st{outline:1.5px solid var(--rust);outline-offset:-1.5px}

.wool{display:grid;grid-template-columns:1.05fr 1fr;background:var(--indigo-d);color:var(--paper);min-height:78svh;align-items:center}
.wl-img{position:relative;overflow:hidden;height:100%;min-height:50svh}
.wl-img img{width:100%;height:100%;object-fit:cover;filter:saturate(.95) brightness(.82)}
.wl-body{padding:clamp(56px,7vw,120px) clamp(32px,4vw,80px);display:flex;flex-direction:column;gap:18px}
.wl-palette{display:flex;gap:14px;flex-wrap:wrap;margin-top:10px;padding-top:18px;border-top:1px solid rgba(246,241,228,.2)}
.wl-palette span{display:flex;flex-direction:column;align-items:center;gap:6px}
.wl-palette span::before{content:"";width:44px;height:44px;border-radius:50%;background:var(--c);border:1px solid rgba(246,241,228,.3)}
.wl-palette em{font-family:var(--f-m);font-size:10px;color:rgba(246,241,228,.7);letter-spacing:.02em}

.proc{padding:var(--sec-y) 0;max-width:1400px;margin:0 auto}
.pr-list{display:grid;grid-template-columns:repeat(4,1fr);gap:0;margin:0 var(--pad-x);border:1px solid var(--line)}
.pr-list li{padding:24px 22px;border-right:1px solid var(--line);display:flex;flex-direction:column;gap:8px;background:var(--paper)}
.pr-list li:last-child{border-right:0}
.pr-list span{font-family:var(--f-m);font-size:14px;color:var(--rust)}
.pr-list h3{font-family:var(--f-d);font-size:21px;color:var(--ink)}
.pr-list p{font-family:var(--f-b);font-size:13.5px;line-height:1.6;color:var(--ink-3)}

.story{padding:var(--sec-y) 0;background:var(--bg-2);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.st-grid{display:grid;grid-template-columns:1fr 1.15fr;gap:clamp(28px,4vw,72px);padding:0 var(--pad-x);max-width:1400px;margin:0 auto;align-items:center}
.st-fig{margin:0;overflow:hidden;border:1px solid var(--line)}
.st-fig img{width:100%;aspect-ratio:4/5;object-fit:cover;filter:saturate(.95)}
.st-body{display:flex;flex-direction:column;gap:16px}
.st-q{font-family:var(--f-d);font-size:clamp(20px,2.4vw,30px);line-height:1.45;color:var(--ink);padding:18px 0 12px;border-top:1px solid var(--rust);margin-top:10px;max-width:40ch}
.st-sign{font-family:var(--f-m);font-size:12px;color:var(--rust);letter-spacing:.02em}

.vis{padding:var(--sec-y) 0;max-width:1400px;margin:0 auto}
.vs-grid{display:grid;grid-template-columns:1fr 1.3fr;gap:clamp(24px,3vw,72px);padding:0 var(--pad-x);align-items:start}
.vs-info{display:flex;flex-direction:column;gap:18px}
.vs-l{display:flex;flex-direction:column;border-top:1px solid var(--indigo)}
.vs-l div{display:grid;grid-template-columns:120px 1fr;gap:14px;align-items:baseline;padding:13px 0;border-bottom:1px solid var(--line)}
.vs-l dt{display:inline-flex;align-items:center;gap:6px;font-family:var(--f-m);font-size:11px;color:var(--ink-3);letter-spacing:.02em;text-transform:uppercase}
.vs-l dt svg{color:var(--rust)}
.vs-l dd{font-family:var(--f-d);font-size:18px;color:var(--ink)}
.vs-l dd a{color:var(--rust);border-bottom:1px solid var(--rust)}
.vs-map{position:relative;min-height:clamp(400px,55vh,540px);overflow:hidden;border:1px solid var(--line-s)}
.vs-map iframe{position:absolute;inset:0;width:100%;height:100%;border:0;filter:saturate(.7) sepia(.14)}

.ft{padding:clamp(56px,6vw,96px) var(--pad-x) clamp(22px,2vw,30px);background:var(--indigo-d);color:var(--paper);display:flex;flex-direction:column;gap:clamp(36px,4.5vw,64px)}
.ft-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(24px,3vw,48px);max-width:1400px;margin:0 auto;width:100%}
.ft-grid > div{display:flex;flex-direction:column;gap:8px}
.ft-l{font-family:var(--f-m);font-size:11px;color:var(--ochre);letter-spacing:.04em;text-transform:uppercase;margin-bottom:6px}
.ft-grid a,.ft-grid address{font-family:var(--f-d);font-size:18px;color:var(--paper);transition:color .25s var(--ease)}
.ft-grid a:hover{color:var(--ochre)}
.ft-mark{text-align:center;font-family:var(--f-d);font-size:clamp(90px,24vw,320px);letter-spacing:.04em;color:var(--paper)}
.ft-base{display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;padding-top:20px;border-top:1px solid rgba(246,241,228,.16);font-family:var(--f-m);font-size:11px;color:rgba(246,241,228,.55);max-width:1400px;margin:0 auto;width:100%}

.fab{position:fixed;right:24px;bottom:24px;z-index:50;width:54px;height:54px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;background:var(--rust);color:var(--paper);box-shadow:0 12px 30px rgba(162,75,44,.4);opacity:0;transform:translateY(16px);pointer-events:none;transition:opacity .3s var(--ease),transform .3s var(--ease),background .25s var(--ease)}
.fab.is-on{opacity:1;transform:none;pointer-events:auto}
.fab:hover{background:var(--indigo)}

@media (max-width:1023px){
  :root{--pad-x:22px;--sec-y:clamp(64px,8vw,100px)}
  .nv{display:none}.cta{display:none}.mb{display:inline-flex}
  .hero-grid{grid-template-columns:1fr;gap:28px}
  .ct-grid{grid-template-columns:repeat(2,1fr)}
  .wool{grid-template-columns:1fr}.wl-img{min-height:50vw;max-height:460px}
  .pr-list{grid-template-columns:1fr 1fr}
  .pr-list li:nth-child(2){border-right:0}
  .pr-list li:nth-child(1),.pr-list li:nth-child(2){border-bottom:1px solid var(--line)}
  .st-grid{grid-template-columns:1fr;gap:28px}
  .vs-grid{grid-template-columns:1fr;gap:24px}
}
@media (max-width:767px){
  :root{--pad-x:16px;--sec-y:56px}
  .hdr{padding:12px 16px}
  .lg-w{font-size:24px}.lg-s{display:none}
  .hh{font-size:36px}.hp{font-size:15px}
  .cta-r{flex-direction:column;align-items:stretch}.cta-r .btn{justify-content:center;min-height:48px}
  .hero-strip{grid-template-columns:1fr 1fr}
  .hero-strip li{border-right:1px solid var(--line)}
  .hero-strip li:nth-child(2),.hero-strip li:nth-child(4){border-right:0}
  .hero-strip li:nth-child(1),.hero-strip li:nth-child(2){border-bottom:1px solid var(--line)}
  .hero-strip b{font-size:26px}
  .sh-h{font-size:32px}
  .ct-grid{grid-template-columns:1fr;margin:0 16px}
  .wl-body{padding:48px 22px}
  .pr-list{grid-template-columns:1fr;margin:0 16px}
  .pr-list li{border-right:0;border-bottom:1px solid var(--line)}
  .pr-list li:last-child{border-bottom:0}
  .st-q{font-size:19px}
  .vs-l div{grid-template-columns:96px 1fr;padding:12px 0}
  .vs-l dd{font-size:15.5px}
  .vs-map{min-height:320px}
  .ft-grid{grid-template-columns:1fr 1fr;gap:18px}
  .ft-grid a,.ft-grid address{font-size:15px}
  .ft-mark{font-size:clamp(64px,26vw,140px)}
  .ft-base{flex-direction:column;gap:6px;font-size:10px}
  .fab{right:14px;bottom:14px;width:48px;height:48px}
}
@media (max-width:479px){.ct-grid,.ft-grid{grid-template-columns:1fr}}
@media (hover:none) and (pointer:coarse){.btn,.cta,.mb,.dr-x,.fab{min-height:44px}}
@media (prefers-reduced-motion:reduce){*,*::before,*::after{animation-duration:.01ms !important;transition-duration:.01ms !important}}
