:root{
  /* брендинг */
  --brand-1:#f71c1c;
  --brand-2:#adff2f;
  --preloader-blur:20px;

  /* тёмные поверхности сайта */
  --surface-1: rgba(29,18,20,0.78); /* фон секций (как в контактах) */
  --surface-1-hover: rgba(29,18,20,0.84);
  --text-on-dark:#ffffffbf;
  --muted-on-dark: #ffffffbf;
  --hairline: rgba(255,255,255,0.08);
}

/* Единый расчёт ширины для всего — избавляет от «ползущих» 100% */
*, *::before, *::after { box-sizing: border-box; }

/* Блокируем скролл, пока прелоадер активен */
body.preload-lock{ overflow:hidden; }

/* Контент станет видимым после снятия прелоадера */
.app{ opacity:0; transition:opacity 500ms ease; }
.app.is-ready{ opacity:1; }

/* ===== Прелоадер (чистый тёмный, без радуги) ===== */
.preloader{
  position:fixed; inset:0; z-index:9999;
  display:grid; place-items:center;
  color:var(--text-on-dark);
  background:
    radial-gradient(120% 120% at 50% 0%, rgba(255,255,255,0.06), transparent 60%),
    radial-gradient(120% 120% at 50% 100%, rgba(255,255,255,0.04), transparent 60%),
    #1d1214;                 /* тёмная база */
  transform:translateZ(0);
  will-change:opacity, transform, filter;
}
.preloader__inner{
  display:grid; gap:18px; place-items:center;
  padding:22px 26px;
  backdrop-filter:blur(var(--preloader-blur));
  -webkit-backdrop-filter:blur(var(--preloader-blur));
  border-radius:16px;
  background: rgba(255,255,255,0.03);
  border:1px solid var(--hairline);
}
.preloader__logo{ display:grid; gap:10px; place-items:center; text-align:center; }
.preloader__logo-ring{
  width:64px; height:64px; border-radius:50%;
  border:2px solid rgba(255,255,255,.18);
  border-top-color:var(--brand-1);
  border-right-color:rgba(255,255,255,.28);
  animation:spin 1200ms linear infinite;
}
.preloader__logo-text{
  font-family:'Poiret One', cursive;
  letter-spacing:.12em; text-transform:uppercase; font-weight:700;
  color:var(--text-on-dark); text-shadow:none;
}
.preloader__progress{ width:200px; height:2px; border-radius:999px; background:rgba(255,255,255,.18); overflow:hidden; }
.preloader__bar{
  width:100%; height:100%; transform:translateX(-100%);
  animation:loading 1600ms ease-in-out infinite;
  background:
    linear-gradient(90deg, rgba(255,255,255,0) 0%, rgba(255,255,255,.85) 50%, rgba(255,255,255,0) 100%),
    linear-gradient(90deg, var(--brand-1), var(--brand-1));
}
.preloader__skip{
  appearance:none; border:1px solid rgba(255,255,255,.55);
  background:transparent; color:var(--text-on-dark); border-radius:999px;
  padding:8px 14px; font-size:14px; cursor:pointer;
  transition:transform .2s ease, background .2s ease, color .2s ease, border-color .2s ease;
}
.preloader__skip:focus{ outline:2px solid rgba(255,255,255,.9); outline-offset:2px; }
.preloader__skip:hover{ transform:translateY(-1px); background:rgba(255,255,255,.06); }
.preloader.is-hiding{
  opacity:0; transform:none; filter:none;
  transition:opacity 500ms ease;
  pointer-events:none;
}

/* Убираем кнопку "Пропустить" у прелоадера */


/* ===== Поэлементное проявление секций при прокрутке ===== */
[data-reveal]{ opacity:0; transform:translateY(14px); transition:opacity 600ms ease, transform 600ms ease; will-change:opacity, transform; }
.reveal-in{ opacity:1; transform:translateY(0); }

@keyframes spin{ to{ transform:rotate(360deg);} }
@keyframes loading{
  0%{ transform:translateX(-100%); }
  100%{ transform:translateX(100%); }
}

/* Уважение prefers-reduced-motion */
@media (prefers-reduced-motion: reduce){
  *{ animation:none !important; transition:none !important; }
  .preloader__logo-ring, .preloader__progress{ display:none; }
}

/* ===== БАЗОВЫЕ СТИЛИ САЙТА ===== */

html{ min-height:100%; }
body{
  margin:0;
  font-family:'Inter', sans-serif;
  background-image:url('images/Webpage_elements/studio.jpg');
  background-size:cover;
  background-position:center center;
  background-attachment:fixed;
  color:#e9e9e9;       /* общий цвет текста — чуть светлее */
  position:relative;
  min-height:100vh;
}
/* общий затемняющий слой на фоне */
body::before{
  content:"";
  position:fixed; top:0; left:0; width:100vw; height:100vh;
  background-color:rgba(20, 14, 15, 0.55);
  z-index:1; pointer-events:none;
}
.site-container{ width:90%; max-width:1200px; margin:0 auto; padding-top:20px; position:relative; z-index:2; }

h1, h2, h3, .content-section h2{ font-family:'Jura', sans-serif; letter-spacing:1px; margin-top:0; }

/* ссылки по умолчанию на тёмном */
a{ text-decoration:none; color:#ffd3d3; }
a:hover{ color:#d0ffa0; }

/* ===== ЕДИНЫЙ ТЁМНЫЙ СТИЛЬ ДЛЯ ВСЕХ СЕКЦИЙ ===== */
.content-section{
  padding:30px 20px; margin-bottom:20px;
  background-color:var(--surface-1);
  color:var(--text-on-dark);
  border-radius:10px;
  box-shadow:0 8px 30px rgba(0,0,0,0.35);
  border:1px solid var(--hairline);
  transition:background-color .35s ease, box-shadow .35s ease, transform .2s ease;
}
.content-section:hover{
  background-color:var(--surface-1-hover);
  box-shadow:0 10px 34px rgba(0,0,0,0.45);
}
.content-section:last-child{ margin-bottom:0; }

/* белый текст внутри секций и читаемые muted */
.content-section h1,
.content-section h2,
.content-section h3,
.content-section p,
.content-section li,
.content-section strong,
.content-section span { color:var(--text-on-dark); }
.content-section p{ color:var(--muted-on-dark); }

/* кнопки/ссылки в секциях */
.content-section a{ color:#ffb6b6; }
.content-section a:hover{ color:#c7ff8a; }

/* ===== ШАПКА ===== */
header{
  background-color:rgba(29, 18, 20, 0.80); color:#FFFFFF; padding:10px 0;
  position:sticky; top:0; z-index:1000; font-family:'Jura', sans-serif;
  box-shadow:0 2px 5px rgba(0,0,0,0.2);
}
.header-container{ width:90%; max-width:1200px; margin:0 auto; display:flex; justify-content:space-between; align-items:center; }
header:hover{ background-color:rgba(29, 18, 20, 0.93); }

.logo a{
  font-family:'Poiret One', cursive; font-size:1.2em; font-weight:bold;
  color:#f71c1c; text-decoration:none; transition:color 0.3s, text-shadow 0.3s;
  animation:heartbeat 2.8s infinite;
}

nav#main-nav{ display:flex; align-items:center; }
nav#main-nav ul{ list-style:none; padding:0; margin:0; display:flex; }
nav#main-nav ul li{ margin-left:20px; }
nav#main-nav ul li:first-child{ margin-left:0; }
nav#main-nav ul li a{ color:#f71c1c; font-size:1.0em; transition:color 0.3s ease; padding:5px 0; }
nav#main-nav ul li a:hover{ color:#adff2f; }

.language-switcher{ margin-left:25px; }
.language-switcher button{
  background:transparent; border:1px solid #f71c1c; color:#f71c1c;
  padding:5px 8px; cursor:pointer; transition:background-color 0.3s ease, color 0.3s ease, border-color 0.3s ease;
  font-size:0.9em; margin:0 3px; font-family:'Jura', sans-serif;
}
.language-switcher button:hover{ background-color:#f71c1c; color:#1d1214; }

.hamburger{ display:none; flex-direction:column; justify-content:space-around; width:30px; height:25px; background:transparent; border:none; cursor:pointer; padding:0; z-index:1001; margin-left:15px; }
.hamburger span{ width:30px; height:3px; background-color:#e90e0e; border-radius:5px; transition:all 0.3s linear; }
.hamburger.open span:nth-child(1){ transform:rotate(45deg) translate(5px, 5px); }
.hamburger.open span:nth-child(2){ opacity:0; }
.hamburger.open span:nth-child(3){ transform:rotate(-45deg) translate(7px, -7px); }

/* ===== Блок «Обо мне» ===== */
#meet-master{ font-family:'Jura', sans-serif; }
#meet-master h2{ text-align:center; color:#ffffff; margin-bottom:20px; font-size:2.2em; }
#meet-master p{ font-size:1.1em; line-height:1.65; text-align:justify; color:var(--muted-on-dark); text-shadow:none; font-family:'Inter', sans-serif; }
#meet-master .master-photo{
  display:block; max-width:420px; margin:0 auto 20px auto; border-radius:90%;
  border:4px solid #080808; box-shadow:0 0 12px rgba(14, 13, 14, 0.8);
}

/* ===== Услуги ===== */
#services{ font-family:'Jura', sans-serif;}
#services h2{ text-align:center; color:#ffffff; margin-bottom:30px; font-size:2.2em; }
.service-item{
  background-color:rgba(255,255,255,0.03); border:1px solid var(--hairline);
  padding:15px; margin-bottom:15px; border-radius:8px;
  box-shadow:0 20px 40px rgba(0,0,0,0.08);
}
.service-item h3{ color:#ffffff; font-size:1.3em; margin-bottom:8px; font-family:'Jura', sans-serif; }
.service-item p{ font-size:0.95em; line-height:1.55; color:var(--muted-on-dark); font-family:'Inter', sans-serif; }

/* ===== Портфолио ===== */
#portfolio{ font-family:'Jura', sans-serif; }
#portfolio h2{ text-align:center; color:#ffffff; margin-bottom:30px; font-size:2.2em; }
.portfolio-grid{ display:grid; grid-template-columns:repeat(auto-fit, minmax(260px, 1fr)); gap:20px; }
.portfolio-item{
  border-radius:8px; border:1px solid var(--hairline); box-shadow:0 3px 7px rgba(0,0,0,0.25);
  overflow:hidden; position:relative; background-color:#0f0f0f;
}
.portfolio-slider img{ width:100%; height:299px; object-fit:cover; display:block; }
.portfolio-item .tns-controls{
  position:absolute; top:50%; left:0; width:100%; transform:translateY(-50%);
  display:flex; justify-content:space-between; padding:0 5px; z-index:10; pointer-events:none;
}
.portfolio-item .tns-controls button{
  background:rgba(29, 18, 20, 0.6); color:white; border:1px solid rgba(255,255,255,0.4);
  border-radius:50%; width:35px; height:35px; cursor:pointer;
  transition:background-color 0.3s ease, border-color 0.3s ease;
  display:flex; align-items:center; justify-content:center; pointer-events:all; line-height:1; font-size:0;
}
.portfolio-item .tns-controls button:hover{ background-color:rgba(247, 28, 28, 0.8); border-color:rgba(255,255,255,0.8); }
.portfolio-item .tns-controls button[data-controls="prev"]::before{ content:'<'; font-size:20px; color:white; }
.portfolio-item .tns-controls button[data-controls="next"]::before{ content:'>'; font-size:20px; color:white; }

/* ===== Контакты ===== */
#contact{ font-family:'Jura', sans-serif; }
#contact h2{ text-align:center; color:#ffffff; margin-bottom:30px; font-size:2.2em; }
.contact-info p{ font-size:1.05em; line-height:1.55; text-align:center; margin-bottom:8px; color:var(--muted-on-dark); font-family:'Inter', sans-serif; }
.contact-info strong{ color:#ffffff; }
.contact-info a{ color:#ffb6b6; }
.contact-info a:hover{ text-decoration:underline; color:#c7ff8a; }
#map-container{ width:100%; height:350px; margin-top:25px; border:1px solid var(--hairline); border-radius:8px; overflow:hidden; }
#map-container iframe{ width:100%; height:100%; border:0; }

#map-container {
  position: relative; /* нужно для позиционирования оверлея */
  overflow: hidden;   /* на всякий случай */
}

#map-container::after {
  content: "";
  position: absolute;
  inset: 0; /* top:0; right:0; bottom:0; left:0 */
  background: linear-gradient(
    rgba(20, 14, 15, 0.3) 0%,
    rgba(20, 14, 15, 0.0) 50%,
    rgba(20, 14, 15, 0.3) 100%
  );
  pointer-events: none; /* карта остаётся кликабельной */
  z-index: 2;
}

#map-container iframe {
  position: relative;
  z-index: 1; /* карта под градиентом */
}

/* ===== Форма записи (контакты) ===== */
.contact-form{
  margin-top:24px; padding:18px;
  background:rgba(255,255,255,0.03);
  border:1px solid var(--hairline); border-radius:10px;
}
.contact-form h3{ margin:0 0 12px; color:#ffffff; }
.contact-form form{ display:grid; gap:12px; }
.contact-form label{ font-weight:600; color:#ffffff; }
.contact-form input,
.contact-form textarea{
  padding:10px 12px; font-size:1rem; border:1px solid rgba(255,255,255,0.18);
  border-radius:8px; width:100%; color:#ffffff; background:rgba(255,255,255,0.06);
}
.contact-form input::placeholder,
.contact-form textarea::placeholder{ color:rgba(255,255,255,0.55); }
.contact-form button{
  background:var(--brand-1); color:#fff; border:0; padding:12px 14px; cursor:pointer; border-radius:999px;
  font-weight:700;
}
.contact-form button:hover{ filter:brightness(1.05); }

/* Контейнер формы выравниваем по левому краю на всякий случай */
.contact-form { text-align: left; }

/* Грид не сжимает элементы, тянет их на всю ширину колонки */
.contact-form form { display: grid; gap: 12px; align-items: start; }

/* Лейбл — блочный, инпуты — на всю ширину контейнера лейбла */
.contact-form label { display: block; }

.contact-form input,
.contact-form textarea,
.contact-form button{
  display: block;
  width: 100%;
  max-width: 100%;
  box-sizing: border-box; /* подстраховка, если уберёшь глобальное правило */
  margin: 0;
  /* iOS не будет зумить при фокусе */
  font-size: 16px;
}

/* Запрет resizing у textarea формы */
.contact-form textarea{
  resize: none;
}

/* Один шрифт для всех контролов формы */
input, textarea, select, button {
  font-family: inherit;   /* возьми шрифт как у body = Inter */
  font-size: 1rem;
  line-height: 1.5;
}

/* Плейсхолдер тоже тем же шрифтом */
.contact-form ::placeholder {
  font-family: inherit;
}

/* ===== Подвал ===== */
footer{ background-color:rgba(0,0,0,0.9); color:#f72222; text-align:center; padding:20px 0; margin-top:30px; font-family:'Jura', sans-serif; }
.social-links a{ color:#f70808; font-size:1.4em; margin:0 8px; transition:color 0.3s ease; }
.social-links a:hover{ color:#56b617; }
footer p{ font-size:0.9em; color:#e6e6e6; }

/* ===== Мобильные ===== */
@media (max-width:880px){
  .logo a{ font-size:1.3em; }
  .hamburger{ display:flex; }
  nav#main-nav{
    position:absolute; top:100%; left:0; right:0;
    background-color:#1f1013; box-shadow:0 3px 5px rgba(0,0,0,0.2);
    flex-direction:column; max-height:0; overflow:hidden; transition:max-height 0.4s ease-out;
    border-bottom-left-radius:8px; border-bottom-right-radius:8px;
  }
  nav#main-nav.open{ max-height:500px; }
  nav#main-nav ul{ flex-direction:column; width:100%; }
  nav#main-nav ul li{ margin:0; text-align:center; border-bottom:1px solid rgba(255,255,255,0.08); }
  nav#main-nav ul li a{ display:block; padding:14px 0; font-size:1.05em; color:#ffffff; }
  nav#main-nav ul li a:hover{ color:#d0ffa0; background-color:rgba(255,255,255,0.06); }
  nav#main-nav .language-switcher{
    width:100%; margin-left:0; padding:12px 0; display:flex; justify-content:center; align-items:center; border-top:1px solid rgba(255,255,255,0.08);
  }
  nav#main-nav .language-switcher button{
    font-size:0.95em; padding:6px 10px; color:#ffffff; border:1px solid rgba(255,255,255,0.25); background:transparent; font-family:'Jura', sans-serif;
  }
  nav#main-nav .language-switcher button:hover{ background-color:rgba(255,255,255,0.08); color:#ffffff; border-color:rgba(255,255,255,0.35); }
}

@media (max-width:480px){
  .site-container{ width:95%; padding-top:15px; }
  .content-section{ padding:20px 15px; }
  .logo a{ font-size:0.9em; }
  #meet-master h2, #services h2, #portfolio h2, #contact h2{ font-size:1.7em; }
  #meet-master .master-photo{ max-width:210px; }
  .portfolio-grid{ grid-template-columns:1fr; gap:15px; }
  .portfolio-image-wrapper{ position:relative; width:100%; padding-top:25%; background-color:#0f0f0f; overflow:hidden; }
  .portfolio-image-wrapper.aspect-ratio-1-1{ padding-top:100%; }
  .portfolio-image-wrapper.aspect-ratio-4-3{ padding-top:75%; }
  .portfolio-image-wrapper.aspect-ratio-3-4{ padding-top:133.33%; }
  .portfolio-image-wrapper.aspect-ratio-16-9{ padding-top:56.25%; }
  .portfolio-image-wrapper.aspect-ratio-9-16{ padding-top:120.77%; }
  .portfolio-image-wrapper.portfolio-image-12-custom-aspect{ padding-top:110%; }
  .portfolio-slider .portfolio-image-wrapper img{ position:absolute; top:0; left:0; width:100%; height:100%; object-fit:cover; }
  #map-container{ height:250px; }
    /* Минимальная высота контейнера, если плагин ещё не посчитал высоту */
  .portfolio-slider{ min-height: 240px; }
  .hamburger{ width:28px; height:22px; margin-left:10px; }
  .hamburger span{ width:28px; height:2.5px; }
  nav#main-nav ul li a{ padding:12px 0; font-size:1em; }
  nav#main-nav .language-switcher button{ font-size:0.9em; padding:5px 8px; }
}

@keyframes heartbeat{
  0%{ color:#f71c1c; text-shadow:0 0 7px #f71c1c33; transform:scale(1);}
  20%{ color:#adff2f; text-shadow:0 0 14px #86a78655; transform:scale(1.14);}
  40%{ color:#f71c1c; text-shadow:0 0 9px #f71c1c66; transform:scale(1.02);}
  60%{ color:#adff2f; text-shadow:0 0 12px #86a78677; transform:scale(1.12);}
  100%{ color:#f71c1c; text-shadow:0 0 7px #f71c1c33; transform:scale(1);}
}

/* === Fallback, если Tiny Slider не подгрузился === */
.portfolio-slider.slider-fallback{
  display: grid;
  grid-auto-flow: column;
  grid-auto-columns: 100%;
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  -webkit-overflow-scrolling: touch;
}
.portfolio-slider.slider-fallback .portfolio-image-wrapper{
  scroll-snap-align: start;
}
.portfolio-slider.slider-fallback img{
  width: 100%;
  height: auto;
  display: block;
}

@media (max-width: 880px){
  /* Всегда показывать элементы с data-reveal на мобильных */
  [data-reveal]{ opacity: 1 !important; transform: none !important; }
}

/* Только кольцо — без полосы прогресса */
.preloader__progress,
.preloader__bar {
  display: none !important;
}

@media (prefers-reduced-motion: reduce){
  .preloader__logo-ring{
    display: inline-block !important;
    animation: none !important;
  }
}

/* Hide Netlify honeypot field */
.hidden{display:none !important;}
