/* ==========================================================
   ЛИС. — Gothic Forest / Private Tattoo Studio
   Midnight + bone + blood. UnifrakturCook + Cormorant Garamond + Inter
   ========================================================== */

*,*::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:#0F0E11;
  --bg-2:#181519;
  --bg-3:#1F1B22;
  --bone:#EAE2D0;
  --bone-2:#C5BDA9;
  --bone-3:#8D8676;
  --bone-4:#5A5648;
  --blood:#8B1A2C;
  --blood-d:#5F0F1B;
  --moss:#6E7F4E;
  --line:rgba(234,226,208,.12);
  --line-s:rgba(234,226,208,.28);

  --f-g:"UnifrakturCook",Georgia,serif;
  --f-d:"Cormorant Garamond","Cormorant",Georgia,serif;
  --f-b:"Inter",system-ui,sans-serif;

  --pad-x:clamp(20px,4vw,72px);
  --sec-y:clamp(80px,9vw,140px);

  --ease:cubic-bezier(.22,.9,.3,1);
  --ease-out:cubic-bezier(.19,1,.22,1);
}

body{
  background:
    radial-gradient(60% 50% at 50% 0%, rgba(139,26,44,.04) 0%, transparent 60%),
    var(--bg);
  color:var(--bone);
  font-family:var(--f-b);font-size:16px;line-height:1.55;
  -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(--blood);color:var(--bone)}
:focus-visible{outline:2px solid var(--blood);outline-offset:3px}

/* ============ HEADER ============ */
.hdr{
  position:sticky;top:0;z-index:30;
  padding:14px var(--pad-x);
  background:rgba(15,14,17,.88);
  backdrop-filter:blur(10px);
  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(--bone)}
.lg-mark{color:var(--blood);align-self:center}
.lg-w{
  font-family:var(--f-g);font-size:32px;line-height:1;letter-spacing:.005em;color:var(--bone);
}
.lg-w b{font-weight:700}
.lg-w i{color:var(--blood);font-style:italic;font-weight:400;font-family:var(--f-d);font-size:30px}
.lg-i{font-family:var(--f-d);font-style:italic;font-size:13px;color:var(--bone-3);align-self:flex-end;padding-bottom:4px}

.nv{
  display:flex;gap:30px;
  font-family:var(--f-d);font-size:21px;color:var(--bone-2);font-style:italic;
}
.nv a{position:relative;padding:4px 0;transition:color .25s var(--ease)}
.nv a:hover{color:var(--blood)}
.nv a::before{content:"†";color:var(--blood);position:absolute;left:-14px;top:0;opacity:0;transition:opacity .25s var(--ease)}
.nv a:hover::before{opacity:1}

.cta{
  font-family:var(--f-d);font-style:italic;font-size:17px;color:var(--blood);
  padding:8px 0;border-bottom:1px solid var(--blood);
  transition:color .25s var(--ease),border-color .25s var(--ease);
}
.cta:hover{color:var(--bone);border-color:var(--bone)}

.mb{display:none;width:42px;height:42px;align-items:center;justify-content:center;color:var(--bone);border:1px solid var(--line-s)}

.drawer{
  position:fixed;inset:0;z-index:80;
  background:var(--bg-2);padding:24px var(--pad-x);
  display:flex;flex-direction:column;gap:32px;
  opacity:0;pointer-events:none;transform:translateY(-12px);
  transition:opacity .35s var(--ease),transform .45s var(--ease);
}
body.dr-open .drawer{opacity:1;pointer-events:auto;transform:none}
.dr-x{align-self:flex-end;width:42px;height:42px;color:var(--bone);border:1px solid var(--line-s);display:inline-flex;align-items:center;justify-content:center}
.drawer nav{flex:1;display:flex;flex-direction:column;justify-content:center;gap:6px}
.drawer nav a{display:flex;align-items:baseline;gap:20px;padding:14px 0;border-bottom:1px solid var(--line);opacity:0;transform:translateY(20px);transition:opacity .55s var(--ease) calc(var(--i,0)*.07s + .15s),transform .55s var(--ease) calc(var(--i,0)*.07s + .15s)}
body.dr-open .drawer nav a{opacity:1;transform:none}
.drawer nav b{font-family:var(--f-d);font-style:italic;font-size:20px;color:var(--blood);font-weight:400;min-width:28px}
.drawer nav em{font-family:var(--f-d);font-style:italic;font-size:clamp(32px,8vw,56px);color:var(--bone);letter-spacing:-.01em}

/* ============ HERO ============ */
.hero{
  position:relative;min-height:100svh;
  display:flex;flex-direction:column;justify-content:flex-end;
  overflow:hidden;
}
.hero-bg{position:absolute;inset:0;z-index:0}
.hero-bg img{
  width:100%;height:100%;object-fit:cover;
  filter:grayscale(.85) contrast(1.15) brightness(.45);
  transform:scale(1.04);
  animation:heroBreath 18s var(--ease) infinite alternate;
}
@keyframes heroBreath{from{transform:scale(1.04)}to{transform:scale(1.1) translateY(-1%)}}
.hero-vignette{
  position:absolute;inset:0;z-index:1;
  background:radial-gradient(70% 60% at 50% 100%, rgba(15,14,17,0) 0%, rgba(15,14,17,.7) 60%, rgba(15,14,17,.96) 100%),
    linear-gradient(to bottom, rgba(15,14,17,.6) 0%, rgba(15,14,17,0) 30%);
}

.hero-content{
  position:relative;z-index:2;
  padding:clamp(140px,18vh,200px) var(--pad-x) clamp(40px,5vw,80px);
  max-width:1500px;margin:0 auto;width:100%;
  display:flex;flex-direction:column;gap:20px;
}

.rb{
  font-family:var(--f-d);font-style:italic;font-size:13px;color:var(--blood);letter-spacing:.04em;
}
.rb i{font-style:italic;color:var(--bone-3);margin-left:6px}

.hh{
  font-family:var(--f-g);
  font-size:clamp(48px,8vw,140px);
  line-height:1;letter-spacing:-.005em;color:var(--bone);
}
.hh span{display:block}
.hh-1{}
.hh-2 em{font-family:var(--f-d);font-style:italic;color:var(--blood);font-weight:400;letter-spacing:-.01em;font-size:.95em}
.hh-3{font-family:var(--f-d);font-style:italic;font-weight:400;color:var(--bone-2);font-size:.6em;letter-spacing:-.01em;margin-top:.2em;padding-left:1em}
.hh-3 em{color:var(--bone)}

.hp{
  font-family:var(--f-b);font-size:16px;line-height:1.6;color:var(--bone-2);
  max-width:60ch;
}

.cta-r{display:flex;gap:14px;flex-wrap:wrap;margin-top:8px}
.btn{
  display:inline-flex;align-items:center;gap:10px;
  padding:13px 24px;
  font-family:var(--f-b);font-size:13px;font-weight:500;letter-spacing:.04em;text-transform:uppercase;
  cursor:pointer;border:1px solid transparent;
  transition:background .25s var(--ease),color .25s var(--ease),transform .2s var(--ease),border-color .25s var(--ease);
}
.btn-bone{background:var(--bone);color:var(--bg)}
.btn-bone:hover{background:var(--blood);color:var(--bone);transform:translateY(-1px)}
.btn-line{background:transparent;color:var(--bone);border-color:var(--bone)}
.btn-line:hover{background:var(--bone);color:var(--bg)}

/* ============ SECTION HEAD ============ */
.sh{display:flex;flex-direction:column;gap:18px;padding:0 var(--pad-x) clamp(36px,4vw,64px);max-width:1500px;margin:0 auto}
.sh-h{
  font-family:var(--f-g);font-size:clamp(40px,5.8vw,96px);
  line-height:1;letter-spacing:-.005em;color:var(--bone);max-width:18ch;
}
.sh-h em{font-family:var(--f-d);font-style:italic;color:var(--blood);font-weight:400;letter-spacing:-.01em}
.sh-p{font-family:var(--f-b);font-size:16px;line-height:1.6;color:var(--bone-2);max-width:60ch}

/* ============ FLASH WALL ============ */
.flash{padding:var(--sec-y) 0;max-width:1500px;margin:0 auto}
.fl-wall{
  display:grid;grid-template-columns:repeat(4,1fr);gap:1px;
  background:var(--line);border:1px solid var(--line);margin:0 var(--pad-x);
}
.fl{margin:0;position:relative;overflow:hidden;background:var(--bg);aspect-ratio:1}
.fl img{
  width:100%;height:100%;object-fit:cover;
  filter:grayscale(.6) contrast(1.1) brightness(.85);
  transition:transform 1.2s var(--ease),filter .4s var(--ease);
}
.fl:hover img{transform:scale(1.06);filter:grayscale(0) contrast(1.05)}
.fl figcaption{
  position:absolute;left:10px;bottom:10px;
  background:rgba(15,14,17,.86);
  padding:6px 10px;
  font-family:var(--f-d);font-style:italic;font-size:13px;color:var(--bone-2);
  display:flex;flex-direction:column;gap:1px;
  border-left:2px solid var(--blood);
  opacity:.7;
  transition:opacity .25s var(--ease);
}
.fl:hover figcaption{opacity:1}
.fl figcaption b{font-family:var(--f-d);font-style:normal;font-weight:500;color:var(--blood);font-size:11px;letter-spacing:.04em}

/* ============ MASTERS ============ */
.mst{padding:var(--sec-y) 0;max-width:1500px;margin:0 auto}
.m-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:clamp(24px,3vw,56px);margin:0 var(--pad-x)}
.ma{display:grid;grid-template-columns:1fr 1.2fr;gap:18px;align-items:start}
.ma-img{margin:0;aspect-ratio:4/5;overflow:hidden;border:1px solid var(--line-s)}
.ma-img img{width:100%;height:100%;object-fit:cover;filter:grayscale(.5) contrast(1.05) brightness(.92);transition:transform 1.2s var(--ease),filter .4s var(--ease)}
.ma:hover .ma-img img{transform:scale(1.04);filter:grayscale(0) contrast(1.05)}
.ma-body{display:flex;flex-direction:column;gap:8px}
.ma-r{font-family:var(--f-d);font-style:italic;font-size:13px;color:var(--blood)}
.ma-body h3{font-family:var(--f-g);font-size:30px;color:var(--bone);letter-spacing:-.01em;line-height:1.05}
.ma-body p{font-family:var(--f-b);font-size:14.5px;line-height:1.55;color:var(--bone-2)}
.ma-style{display:flex;gap:6px;flex-wrap:wrap;margin-top:6px}
.ma-style li{
  font-family:var(--f-b);font-size:11px;letter-spacing:.04em;text-transform:uppercase;
  color:var(--bone-3);padding:5px 10px;border:1px solid var(--line-s);
}

/* ============ PROCESS ============ */
.proc{
  padding:var(--sec-y) 0;background:var(--bg-2);
  border-top:1px solid var(--line);border-bottom:1px solid var(--line);
}
.pr-list{display:flex;flex-direction:column;gap:0;margin:0 var(--pad-x);max-width:1100px;border-top:1px solid var(--line)}
.pr-list li{
  display:grid;grid-template-columns:80px 1fr;gap:24px;
  padding:22px 0;border-bottom:1px solid var(--line);
}
.pr-no{
  font-family:var(--f-d);font-style:italic;font-size:36px;color:var(--blood);font-weight:400;
  letter-spacing:-.01em;text-align:right;
}
.pr-list h3{
  font-family:var(--f-g);font-size:26px;color:var(--bone);letter-spacing:-.005em;line-height:1.05;margin-bottom:6px;
}
.pr-list h3 em{font-family:var(--f-d);font-style:italic;color:var(--blood);font-weight:400}
.pr-list p{font-family:var(--f-b);font-size:14.5px;line-height:1.6;color:var(--bone-2);max-width:60ch}

/* ============ PRICE ============ */
.price{padding:var(--sec-y) 0;max-width:1500px;margin:0 auto}
.pr-tbl{margin:0 var(--pad-x);border-top:2px solid var(--bone);border-bottom:2px solid var(--bone);font-family:var(--f-b)}
.pr-row{display:grid;grid-template-columns:80px 1.4fr 90px 110px;gap:18px;padding:14px 0;border-bottom:1px solid var(--line);align-items:baseline}
.pr-row:last-child{border-bottom:0}
.pr-hd{font-family:var(--f-d);font-style:italic;font-size:13px;color:var(--bone-3);padding:12px 0;border-bottom:1px solid var(--bone);letter-spacing:.02em}
.pr-s{font-family:var(--f-g);font-size:24px;color:var(--blood);letter-spacing:.01em}
.pr-row > span:nth-child(2){font-family:var(--f-d);font-style:italic;font-size:18px;color:var(--bone);letter-spacing:-.005em}
.pr-row > span:nth-child(3){font-family:var(--f-d);font-style:italic;font-size:15px;color:var(--bone-2)}
.pr-row > span:nth-child(4){font-family:var(--f-g);font-size:22px;color:var(--bone);text-align:right;letter-spacing:.005em}
.pr-foot{margin:22px var(--pad-x) 0;font-family:var(--f-d);font-style:italic;font-size:16px;line-height:1.6;color:var(--bone-2);max-width:62ch}

/* ============ VISIT ============ */
.vis{padding:var(--sec-y) 0;max-width:1500px;margin:0 auto}
.vs-grid{display:grid;grid-template-columns:1fr 1.2fr;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;gap:0}
.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-d);font-style:italic;font-size:13px;color:var(--bone-3)}
.vs-l dt svg{color:var(--blood)}
.vs-l dd{font-family:var(--f-g);font-size:21px;color:var(--bone);letter-spacing:-.005em}
.vs-l dd a{color:var(--blood);border-bottom:1px solid var(--blood)}
.vs-map{position:relative;min-height:clamp(400px,55vh,560px);overflow:hidden;border:1px solid var(--line-s)}
.vs-map iframe{position:absolute;inset:0;width:100%;height:100%;border:0;filter:invert(.94) hue-rotate(180deg) saturate(.4)}

/* ============ FOOTER ============ */
.ft{
  background:var(--bg-2);color:var(--bone);
  padding:clamp(56px,6vw,96px) var(--pad-x) clamp(22px,2vw,32px);
  display:flex;flex-direction:column;gap:clamp(40px,5vw,72px);
  border-top:1px solid var(--line);
}
.ft-mark{
  text-align:center;font-family:var(--f-g);
  font-size:clamp(110px,26vw,360px);line-height:.86;color:var(--bone);
}
.ft-mark b{font-weight:700}
.ft-mark i{font-family:var(--f-d);color:var(--blood);font-style:italic}
.ft-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(24px,3vw,48px);max-width:1500px;margin:0 auto;width:100%}
.ft-c{display:flex;flex-direction:column;gap:8px}
.ft-l{font-family:var(--f-d);font-style:italic;font-size:14px;color:var(--blood);margin-bottom:6px}
.ft-c a,.ft-c address{font-family:var(--f-d);font-size:18px;color:var(--bone);letter-spacing:-.005em;transition:color .25s var(--ease)}
.ft-c a:hover{color:var(--blood)}
.ft-base{display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;padding-top:22px;border-top:1px solid var(--line);font-family:var(--f-d);font-style:italic;font-size:13px;color:var(--bone-3);max-width:1500px;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(--blood);color:var(--bone);box-shadow:0 12px 32px rgba(139,26,44,.5);opacity:0;transform:translateY(16px);pointer-events:none;transition:opacity .35s var(--ease),transform .35s var(--ease),background .25s var(--ease)}
.fab.is-on{opacity:1;transform:none;pointer-events:auto}
.fab:hover{background:var(--blood-d)}
body.dr-open .fab{opacity:0;pointer-events:none}

/* RESPONSIVE */
@media (max-width:1023px){
  :root{--pad-x:22px;--sec-y:clamp(64px,8vw,100px)}
  .nv{display:none}
  .cta{display:none}
  .mb{display:inline-flex}
  .fl-wall{grid-template-columns:repeat(2,1fr)}
  .m-grid{grid-template-columns:1fr;gap:32px}
  .ma{grid-template-columns:1fr 1.2fr}
  .vs-grid{grid-template-columns:1fr;gap:28px}
}

@media (max-width:767px){
  :root{--pad-x:16px;--sec-y:56px}
  .hdr{padding:12px 16px}
  .lg-w{font-size:24px}
  .lg-i{display:none}
  .hero-content{padding:120px 16px 32px}
  .hh{font-size:48px}
  .hh-3{font-size:.5em}
  .hp{font-size:14.5px}
  .cta-r{flex-direction:column;align-items:stretch}
  .cta-r .btn{justify-content:center;min-height:48px}

  .sh-h{font-size:38px}

  .fl-wall{margin:0 16px}

  .m-grid{margin:0 16px}
  .ma{grid-template-columns:1fr;gap:14px}
  .ma-img{aspect-ratio:4/5;max-width:60%}
  .ma-body h3{font-size:24px}
  .ma-body p{font-size:13.5px}

  .pr-list{margin:0 16px}
  .pr-list li{grid-template-columns:50px 1fr;gap:14px;padding:16px 0}
  .pr-no{font-size:26px}
  .pr-list h3{font-size:21px}
  .pr-list p{font-size:13.5px}

  .pr-tbl{margin:0 16px}
  .pr-hd{display:none}
  .pr-row{grid-template-columns:60px 1fr 90px;row-gap:4px;padding:13px 0}
  .pr-row > span:nth-child(2){grid-column:1 / -1;font-size:15px}
  .pr-row > span:nth-child(3){font-size:13px;color:var(--bone-3)}
  .pr-row > span:nth-child(4){font-size:18px}
  .pr-foot{margin:18px 16px 0;font-size:14.5px}

  .vs-l div{grid-template-columns:100px 1fr;padding:11px 0;gap:10px}
  .vs-l dd{font-size:17px}
  .vs-map{min-height:320px}

  .ft-grid{grid-template-columns:1fr 1fr;gap:18px}
  .ft-c a,.ft-c address{font-size:15.5px}
  .ft-mark{font-size:clamp(80px,24vw,140px)}
  .ft-base{flex-direction:column;gap:6px;font-size:11.5px}
  .fab{right:14px;bottom:14px;width:48px;height:48px}
}

@media (max-width:479px){.ft-grid{grid-template-columns:1fr}.fl-wall{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}.hero-bg img{animation:none}}
