:root{
  --split: 35%;     /* де розрізаємо голову */
  --gap: 160px;     /* на скільки роз’їжджається */
  --zoom: 1.08;     /* трохи збільшити голову */
}

html, body { height: 100%; }

body{
  margin: 0;
  background: url("images/leopard.png") center/cover no-repeat;
  overflow: hidden;
  font-family: system-ui, -apple-system, Arial, sans-serif;
}

.stage{
  height: 100vh;
  display: grid;
  place-items: center;
  position: relative;
}

/* ВАЖЛИВО: overflow visible щоб половинки могли виїжджати за рамки */
.head{
  border: 0;
  background: transparent;
  padding: 0;
  cursor: pointer;

  width: min(420px, 86vw);
  position: relative;
  overflow: visible;
  z-index: 2;
}

/* Контейнер під “голову” — НЕ малий, нормальної висоти */
.face{
  position: relative;
  width: 100%;
  height: min(640px, 78vh);
}

/* Два шари-однакові картинки */
.layer{
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;

  object-fit: contain;
  object-position: center;
  transform: scale(var(--zoom));

  transition: transform 420ms cubic-bezier(.2,.9,.2,1);
  will-change: transform;
  pointer-events: none;
}

/* КЛЮЧ: ріжемо один і той самий headfull.png на верх/низ */
.layer.top{
  clip-path: inset(0 0 calc(100% - var(--split)) 0);
}

.layer.bottom{
  clip-path: inset(var(--split) 0 0 0);
}

/* щоб меню було між половинками, а не поверх них */
.layer { z-index: 2; }
.menu  { z-index: 1; }

.menu{
  position: absolute;
  left: 50%;
  top: 35%;
  transform: translate(-50%, -50%);

  width: min(900px, 92vw);
  text-align: center;

  padding-top: 10px;     /* 👈 зазор від верхньої голови */
  padding-bottom: 10px;  /* 👈 зазор від нижньої голови */

  opacity: 0;
  pointer-events: none;
  transition: opacity 220ms ease;
}


.title{
  margin: 0 0 12px 0;
  font-size: 44px;
  color: rgba(255,255,255,.72);
  text-shadow: 0 2px 18px rgba(0,0,0,.35);
}


.links{
  display: grid;
  grid-template-columns: repeat(2, 1fr);

  row-gap: 3px;        /* 👈 було забагато — тепер щільніше */
  column-gap: 10px;

  width: 460px;
  max-width: 90vw;
  margin: 0 auto;
  padding-top: 8px;
}

/* клікабельна плитка */
.tile{
  display: block;
  width: 172px;
  border-radius: 10px;
  overflow: hidden;
  cursor: pointer;
  /*transition: transform 180ms ease, filter 180ms ease;*/
}

/* сама картинка */
.tile img{
  width: 100%;
  height: auto;
  aspect-ratio: 1 / 1;
  object-fit: cover;
  display: block;
}

/* hover — дуже стриманий */
.tile:hover{
  transform: scale(1.2);
  filter: brightness(1.06);
}

.pill{
  display: block;
  padding: 12px 14px;
  border-radius: 10px;
  text-decoration: none;
  color: #111;
  background: rgba(255,255,255,.72);
  border: 1px solid rgba(255,255,255,.25);
}

.hint{
  margin-top: 10px;
  font-size: 12px;
  color: rgba(255,255,255,.55);
  text-shadow: 0 1px 10px rgba(0,0,0,.35);
}

/* OPEN: половинки виїжджають ВІЛЬНО, не в межах маленького блока */
.head.open .layer.top{
  transform: translateY(calc(-1 * var(--gap))) scale(var(--zoom));
}
.head.open .layer.bottom{
  transform: translateY(var(--gap)) scale(var(--zoom));
}

.head.open .menu{
  opacity: 1;
  pointer-events: auto;
  transition-delay: 120ms;
}

.cta{
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(70px, -380px);
  z-index: 5;
  pointer-events: none;
}

.cta img{
  width: 300px; /* велика як на скріні */
  animation: nudge 1.2s ease-in-out infinite;
  filter: drop-shadow(0 0 14px rgba(255,255,255,.45));
}

@keyframes nudge{
  0%   { transform: translateY(0); opacity: 1; }
  50%  { transform: translateY(10px); opacity: .85; }
  100% { transform: translateY(0); opacity: 1; }
}

.stage.is-open .cta{
    opacity: 0;
}

.side-text{
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  font-family: 'Anton', sans-serif;
  font-size: clamp(48px, 8vw, 110px);
  letter-spacing: 2px;
  color: #fff;
  text-shadow: 0 6px 20px rgba(0,0,0,.35);
  pointer-events: none;
  z-index: 0; /* під головою/стрілкою */
}

.side-text.left{
  left: 6vw;
}

.side-text.right{
  right: 6vw;
}

/* мобільна підстройка */
@media (max-width: 420px){
  :root{ --gap: 115px; --zoom: 1.04; }
  .title{ font-size: 38px; }
  .face{ height: min(560px, 74vh); }
}
@media (max-width: 520px){
  .menu{ width: min(900px, 98vw); }
  .pill{ width: 240px; padding: 18px 16px; }
}

/* =========================
   MOBILE (FULL)  <= 768px
   NO svh / NO dvh (тільки vh)
   ========================= */
/* =========================
   MOBILE OVERRIDE  <= 768px
   (NO svh/dvh — only vh)
   ========================= */
/* =========================
   MOBILE (ONLY OVERRIDES)
   <= 768px
   NO svh / NO dvh (тільки vh)
   ========================= */
@media (max-width: 768px){

  /* 1) Фон на весь екран */
  html, body { height: 100%; }
  body{
    min-height: 100vh;
    background: url("images/leopard.png") center/cover no-repeat;
    overflow: hidden;
  }

  .stage{
    height: 100vh;
    position: relative;
    display: grid;
    place-items: center;
    overflow: hidden;
  }

  /* 2) Голова: залишаємо твою логіку (relative + overflow visible) */
  .head{
    width: min(420px, 94vw);
    z-index: 2;
  }

  /* 3) КРИТИЧНО: НЕ робимо height:auto, інакше clip-path ламається */
  .face{
    width: 100%;
    height: min(520px, 66vh);
    position: relative;
  }

  /* 4) КРИТИЧНО: layer має лишатись absolute/inset 0 і 100%/100% */
  .layer{
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: contain;
    object-position: center;
    transform: scale(var(--zoom));
    pointer-events: none;
  }

  /* 5) Більший геп (щоб папки влазили) + трохи менший зум */
  :root{
    --gap: 210px;
    --zoom: 1.04;
  }

  /* 6) Меню має бути МІЖ половинками, тому НЕ fixed, а як у тебе: absolute */
  .menu{
    position: absolute;
    left: 50%;
    top: 35%;
    transform: translate(-50%, -50%);
    width: min(520px, 94vw);

    opacity: 0;
    pointer-events: none;
    z-index: 1;  /* між половинками */
  }

  .head.open .menu{
    opacity: 1;
    pointer-events: auto;
  }

  /* 7) Папки — рівно по центру гепа, однаковий розмір */
  .links{
    width: min(420px, 92vw);
    max-width: 92vw;
    margin: 0 auto;

    display: grid;
    grid-template-columns: 1fr 1fr;
    column-gap: 14px;
    row-gap: 14px;
    padding-top: 6px;
  }

  .tile{
    width: 100%;
    border-radius: 10px;
    overflow: hidden;
  }

  .tile img{
    width: 100%;
    height: auto;
    aspect-ratio: 1 / 1;
    object-fit: cover;
    display: block;
  }

  /* 8) CONTENT / CREATOR — НИЖЧЕ і БІЛЬШИЙ (як ти просив) */
  .side-text{
    font-family: "Anton", sans-serif;
    font-size: clamp(44px, 12vw, 70px);
    letter-spacing: 2px;
    color: #fff;
    text-shadow: 0 6px 20px rgba(0,0,0,.35);
    pointer-events: none;
    z-index: 6;
    white-space: nowrap;
  }

  .side-text.left{
    position: absolute;
    left: 6vw;
    top: 85%;          /* нижче, ніж було */
    transform: translateY(-50%);
  }

  .side-text.right{
    position: absolute;
    right: 6vw;
    top: 85%;          /* на одному рівні з Content */
    transform: translateY(-50%);
  }

  /* 9) Стрілка: менша + ЛІВІШЕ + ближче до голови */
  .cta{
    position: absolute;
    top: 30%;
    left: 45%;
    transform: translate(5px, -270px); /* було 70px/-380px, тепер ближче до голови */
    z-index: 7;
    pointer-events: none;
  }

  .cta img{
    width: 230px;       /* менша */
    height: auto;
    display: block;
    filter: drop-shadow(0 0 14px rgba(255,255,255,.45));
  }

  /* 10) На дуже вузьких (iPhone mini) — ще трошки піджимаємо */
  @media (max-width: 420px){
    :root{ --gap: 220px; --zoom: 1.03; }
    .face{ height: min(500px, 64vh); }
    .side-text.left, .side-text.right{ top: 74%; }
    .cta{ transform: translate(-5px, -255px); }
    .cta img{ width: 175px; }
  }
}