/* ============================================================
   Добролёт — основной CSS
   Компоненты синхронизированы с мокапом m-home.html.
   Токены — в tokens.css. Пути текстур — CSS-vars из base.html.
   ============================================================ */

/* RESET */
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{background:var(--bg);color:var(--text);font-family:var(--font-body);line-height:1.65;-webkit-font-smoothing:antialiased;overflow-x:hidden;transition:background .3s,color .3s;padding-top:83px}
a{color:inherit;text-decoration:none}img{display:block;max-width:100%}

/* LAYOUT */
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 32px}
h1,h2,h3,h4{font-family:var(--font-display);font-weight:500;line-height:1.05}

/* ============================================================
   HEADER / NAV
   ============================================================ */
header.site-header{position:fixed;inset:0 0 auto 0;z-index:100;background:color-mix(in srgb,var(--bg-elevated) 88%,transparent);backdrop-filter:blur(14px);border-bottom:1px solid var(--border)}
.main--header{max-width:var(--maxw);margin:0 auto;padding:14px 32px;display:flex;align-items:center;justify-content:space-between;gap:24px;position:relative;z-index:1}

/* Logo */
.site-header svg.logo path,
.site-header svg.logo polygon{fill:#211E1A}
[data-theme="dark"] .site-header svg.logo path,
[data-theme="dark"] .site-header svg.logo polygon{fill:#EEE7D8}
.site-header svg.logo path.st0{fill:#F4EFE6;transform-box:view-box;transform-origin:31.37px 31.43px;animation:propellerSpin 3.2s cubic-bezier(0.08,0.82,0.07,1) forwards}
[data-theme="dark"] .site-header svg.logo path.st0{fill:#15120D}
@keyframes propellerSpin{
  0%{transform:rotate(0deg);filter:blur(0px)}
  6%{filter:blur(1.2px)}
  14%{filter:blur(2.5px)}
  32%{filter:blur(1.8px)}
  58%{filter:blur(0.6px)}
  78%{filter:blur(0.1px)}
  100%{transform:rotate(1440deg);filter:blur(0px)}
}
.site-header svg.logo{width:190px;height:auto;display:block}
@media(min-width:1280px){.site-header svg.logo{margin-left:-65px}}
@media(max-width:1279px){.site-header svg.logo{width:150px}}
/* Логотип уменьшается <1280 → header ниже; синхронизируем отступ body. */
@media(max-width:1279px){body{padding-top:72px}}

/* Nav container */
.site-header__nav-container{margin-left:auto}
ul.site-header__nav{display:flex;align-items:center;list-style:none}
.site-header__nav li{position:relative}
.site-header__nav a{font-family:Helvetica,Arial,sans-serif;font-size:14px;font-weight:700;letter-spacing:var(--tracking-wide);text-transform:uppercase;color:#211E1A;transition:color .2s;display:block;padding:6px 0;text-decoration:none}
[data-theme="dark"] .site-header__nav a{color:#EEE7D8}
.site-header__nav a:hover{color:var(--accent);text-decoration:none}
/* Подчёркивание пунктов меню (анимированная линия из style_plus.css):
   делаем зелёным как и hover-цвет текста (по умолчанию #1d3051 выглядит чёрным). */
.site-header__nav a:before{background:var(--accent)}
[data-theme="dark"] .site-header__nav a:before{background:var(--accent-hover)}

/* Dropdown trigger (with icon ::before) */
.site-header__nav .menu-item-has-children>a{display:flex;align-items:center;gap:0;white-space:nowrap}
.site-header__nav .menu-item-has-children>a::before{
  content:"";position:static;bottom:auto;left:auto;
  width:8px;height:8px;margin-right:4px;flex-shrink:0;
  background-color:currentColor;
  -webkit-mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 8 8'%3E%3Cpolygon points='2.9,0 8,4 2.9,8'/%3E%3Cpath d='M0,8V0h1.6v8H0z'/%3E%3C/svg%3E") center/contain no-repeat;
  mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 8 8'%3E%3Cpolygon points='2.9,0 8,4 2.9,8'/%3E%3Cpath d='M0,8V0h1.6v8H0z'/%3E%3C/svg%3E") center/contain no-repeat;
  transition:background-color .2s
}
.site-header__nav .menu-item-has-children--open>a::before{
  -webkit-mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 8 8'%3E%3Cpath d='M1.8,8V0h1.6v8H1.8z'/%3E%3Cpath d='M4.6,8V0h1.6v8H4.6z'/%3E%3C/svg%3E") center/contain no-repeat;
  mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 8 8'%3E%3Cpath d='M1.8,8V0h1.6v8H1.8z'/%3E%3Cpath d='M4.6,8V0h1.6v8H4.6z'/%3E%3C/svg%3E") center/contain no-repeat
}

/* Sub-menu */
.site-header__nav .sub-menu{position:absolute;top:100%;left:0;min-width:160px;list-style:none;background:var(--bg-elevated);border:1px solid var(--border-soft);border-radius:var(--r-sm);padding:8px 0;box-shadow:var(--shadow-lg);opacity:0;visibility:hidden;transform:translateY(6px);transition:.2s;z-index:50;overflow:hidden}
.site-header__nav .sub-menu::after{content:"";position:absolute;inset:0;background:var(--texture-paper) repeat;opacity:.22;mix-blend-mode:multiply;pointer-events:none;z-index:0}
[data-theme="dark"] .site-header__nav .sub-menu::after{background:var(--texture-black) repeat;opacity:.55;mix-blend-mode:normal}
.site-header__nav .menu-item-has-children:hover>.sub-menu{opacity:1;visibility:visible;transform:none}
.site-header__nav .sub-menu li{margin:0;position:relative;z-index:1}
.site-header__nav .sub-menu a{display:block;padding:8px 18px;font-size:13px;text-transform:uppercase;letter-spacing:var(--tracking-wide);font-family:Helvetica,Arial,sans-serif;font-weight:700;transition:color .2s;text-decoration:none}
.site-header__nav .sub-menu a:hover{color:var(--accent);text-decoration:none}
/* Kill full-width underline from legacy uikit.css */
.site-header__nav .sub-menu a::before{display:none}
/* Text-width growing underline */
.site-header__nav .sub-menu a .dd-text{position:relative;display:inline-block}
.site-header__nav .sub-menu a .dd-text::after{content:"";position:absolute;left:0;bottom:-2px;height:1px;width:0;background:currentColor;transition:width .2s ease-in}
.site-header__nav .sub-menu a:hover .dd-text::after{width:100%}

/* Nav spacing */
.site-header__nav>li{margin-left:35px}
.site-header__nav>li:first-child{margin-left:0}

/* Theme toggle */
.theme-toggle{font-family:var(--font-mono);font-size:11px;letter-spacing:var(--tracking-wide);color:var(--text-faint);border:1px solid var(--border);padding:6px 11px;border-radius:var(--r-sm);cursor:pointer;background:none;text-transform:uppercase;margin-left:35px}
.theme-toggle:hover{border-color:var(--accent);color:var(--accent)}

/* Booking CTA in header */
.btn-book{font-family:var(--font-display);font-size:13px;letter-spacing:var(--tracking-wide);text-transform:uppercase;font-weight:500;color:#1a1206;background:var(--gold);border:none;padding:15px 18px;border-radius:var(--r-sm);cursor:pointer;margin-left:35px}
.btn-book:hover{background:var(--gold-hover)}
.btn-book--mobile{margin-left:0;width:100%}

/* Mobile controls (theme + burger, shown on mobile) */
.mobile-controls{display:none;align-items:center;gap:15px;margin-left:16px;flex-direction:row-reverse}
.menu-toggle{background:none;border:none;cursor:pointer;padding:4px;color:var(--text-muted);display:flex;align-items:center}
.menu-toggle:hover{color:var(--accent)}
.menu-toggle__lines{display:flex;flex-direction:column;gap:4px}
.menu-toggle__lines span{display:block;width:20px;height:2px;background:currentColor;transition:transform .25s,opacity .25s}
/* X animation when open */
.menu-toggle--open .menu-toggle__lines span:nth-child(1){transform:translateY(6px) rotate(45deg)}
.menu-toggle--open .menu-toggle__lines span:nth-child(2){opacity:0}
.menu-toggle--open .menu-toggle__lines span:nth-child(3){transform:translateY(-6px) rotate(-45deg)}
.theme-toggle--mobile{display:block}

/* Scroll lock when mobile menu open */
body.noscroll{overflow:hidden}

/* Mobile nav overlay */
.mobile-nav{position:fixed;inset:83px 0 0 0;background:var(--bg-elevated);z-index:99;padding:32px;display:none;flex-direction:column;overflow-y:auto}
.mobile-nav--open{display:flex}
.mobile-nav ul{list-style:none;display:flex;flex-direction:column;gap:4px}
.mobile-nav a{font-family:Helvetica,Arial,sans-serif;font-size:18px;font-weight:700;text-transform:uppercase;letter-spacing:var(--tracking-wide);color:var(--text);display:block;padding:14px 0;border-bottom:1px solid var(--border-soft)}
.mobile-nav a:hover{color:var(--accent)}
.mobile-nav__group{display:flex;gap:8px;align-items:baseline;padding:14px 0;border-bottom:1px solid var(--border-soft)}
.mobile-nav__group a{border-bottom:none;padding:0}

/* Texture overlays — пути задаются CSS-vars из base.html */
header.site-header::after{content:"";position:absolute;inset:0;background:var(--texture-paper) repeat;opacity:.22;mix-blend-mode:multiply;pointer-events:none;z-index:0}
[data-theme="dark"] header.site-header::after{background:var(--texture-black) repeat;opacity:.55;mix-blend-mode:normal}

/* ============================================================
   HERO
   ============================================================ */
.hero{position:relative;height:370px;display:flex;align-items:flex-end}
.hero-inner{max-width:var(--maxw);margin:0 auto;width:100%;padding:0 32px 38px;animation:rise 1s cubic-bezier(.2,.7,.2,1) both}
.kicker{font-family:var(--font-mono);font-size:11px;letter-spacing:var(--tracking-wider);text-transform:uppercase;color:var(--on-accent);background:var(--accent);display:inline-block;padding:9px 21px;border-radius:var(--r-sm);margin-bottom:14px}
.hero h1{font-size:clamp(34px,5vw,45px);font-weight:600;letter-spacing:-.01em;color:#EEE7D8;max-width:18ch;text-transform:uppercase}
.hero p{margin-top:12px;max-width:54ch;font-size:15px;color:rgba(255,255,255,.88);line-height:1.6}
@keyframes rise{from{opacity:0;transform:translateY(36px)}to{opacity:1;transform:none}}

/* ============================================================
   SECTIONS
   ============================================================ */
section{padding:var(--space-section) 0}
.sec-head{display:flex;align-items:flex-end;justify-content:space-between;gap:24px;margin-bottom:52px;border-bottom:1px solid var(--border);padding-bottom:20px}
.sec-head h2{font-size:clamp(32px,5vw,58px);font-weight:500;letter-spacing:-.01em;text-transform:uppercase}
.idx{font-family:var(--font-mono);font-size:12px;color:var(--accent);letter-spacing:var(--tracking-wider);text-transform:uppercase;display:block;margin-bottom:10px}
.more{font-family:var(--font-mono);font-size:12px;color:var(--text-muted);letter-spacing:var(--tracking-wide);text-transform:uppercase;border-bottom:1px solid var(--accent);padding-bottom:3px;white-space:nowrap}
.more:hover{color:var(--accent)}

/* HISTORY (accent band) */
.history{position:relative;background:var(--accent);color:var(--on-accent)}
.history::after{content:"";position:absolute;inset:0;background:var(--texture-paper) repeat;opacity:.35;mix-blend-mode:multiply;pointer-events:none;z-index:0}
[data-theme="dark"] .history::after{background:var(--texture-black) repeat;opacity:.3;mix-blend-mode:normal}
.history>*{position:relative;z-index:1}
.hg{max-width:var(--maxw);margin:0 auto;padding:var(--space-section) 32px;display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
.hg figure{position:relative;border-radius:var(--r-md);overflow:hidden;box-shadow:var(--shadow-lg)}
.hg img{width:100%;height:440px;object-fit:cover}
.hg figcaption{font-family:var(--font-mono);font-size:11px;letter-spacing:var(--tracking-wide);color:rgba(247,243,234,.7);margin-top:12px}
.hg .kicker{background:var(--on-accent);color:var(--accent)}
.hg h3{font-size:38px;font-weight:500;margin-bottom:20px;text-transform:uppercase}
.hg p{font-size:17px;line-height:1.8;color:rgba(247,243,234,.9);margin-bottom:14px}
/* историческая справка (markdown) — кегль как текст про студии (14px) */
.hg-note{font-size:14px;line-height:1.7;color:rgba(247,243,234,.9)}
.hg-note p{font-size:14px;line-height:1.7;margin:0 0 12px}
.hg-note p:last-child{margin-bottom:0}
.hg-note ul,.hg-note ol{margin:0 0 12px;padding-left:20px}
.hg-note li{margin-bottom:4px}
.hg-note a{color:var(--on-accent);text-decoration:underline}
.hg-note strong{font-weight:600}
.hg-note h2,.hg-note h3,.hg-note h4{font-family:var(--font-display);text-transform:uppercase;margin:1em 0 .4em}
/* тёмная тема: текст справки и подпись фото — чёрные (как заголовок) */
[data-theme="dark"] .hg-note,
[data-theme="dark"] .hg-note p,
[data-theme="dark"] .hg figcaption{color:var(--on-accent)}

/* NEWS / RELEASES cards */
.cards3{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.card .ph{aspect-ratio:4/3;overflow:hidden;border-radius:var(--r-md);margin-bottom:16px;background:var(--surface-alt)}
.card img{width:100%;height:100%;object-fit:cover;transition:transform .5s,filter .5s;filter:brightness(.75)}
.card:hover img{transform:scale(1.05);filter:brightness(1)}
.card .date{font-family:var(--font-mono);font-size:12px;color:var(--text-faint);letter-spacing:var(--tracking-wide)}
.card h4{font-size:21px;font-weight:500;margin-top:5px}
.card .by{color:var(--text-muted);font-size:14px}
.card .stream{margin-top:9px;font-family:var(--font-mono);font-size:11px;color:var(--accent);letter-spacing:var(--tracking-wide);text-transform:uppercase}

/* STUDIOS */
.studios{display:grid;grid-template-columns:1fr 1fr;gap:26px}
.scard{position:relative;min-height:470px;display:flex;align-items:flex-end;overflow:hidden;border-radius:var(--r-md)}
.scard img,.scard-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform .7s,opacity .5s;z-index:0}
.scard:hover img,.scard:hover .scard-img{transform:scale(1.05)}
.scard-img--hover{opacity:0}
.scard:hover .scard-img--hover{opacity:1}
.scard::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 35%,rgba(12,10,7,.9));z-index:1}
.scard .b{position:relative;z-index:2;padding:36px;color:#fff}
.scard .tag{font-family:var(--font-mono);font-size:11px;letter-spacing:var(--tracking-wider);text-transform:uppercase;color:var(--gold)}
.scard h3{font-size:46px;font-weight:600;margin:8px 0 12px;text-transform:uppercase}
.scard p{font-size:14px;opacity:.9;max-width:38ch}
.scard .sp{margin-top:18px;display:flex;gap:24px;font-family:var(--font-mono);font-size:12px;opacity:.85}
.scard .sp b{display:block;font-family:var(--font-body);font-size:15px;font-weight:600;margin-top:3px}

/* ARTISTS */
.alt-bg{background:var(--surface-alt);position:relative}
.alt-bg::after{content:"";position:absolute;inset:0;background:var(--texture-paper) repeat;opacity:.2;mix-blend-mode:multiply;pointer-events:none;z-index:0}
[data-theme="dark"] .alt-bg::after{background:var(--texture-black) repeat;opacity:.4;mix-blend-mode:normal}
.alt-bg>*{position:relative;z-index:1}
.arow{display:grid;grid-template-columns:repeat(6,1fr);gap:14px}
.art{position:relative;aspect-ratio:3/4;overflow:hidden;border-radius:var(--r-md);display:block}
.art img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;filter:grayscale(.7) contrast(1.05);transition:filter .5s,transform .7s;z-index:0}
.art:hover img{filter:grayscale(0);transform:scale(1.05)}
.art::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 45%,rgba(12,10,7,.88));z-index:1;transition:opacity .4s}
.art .cap{position:absolute;left:0;right:0;bottom:0;z-index:2;padding:18px 16px;text-align:left}
.art h4{font-family:var(--font-display);font-size:21px;font-weight:500;color:#fff;text-transform:uppercase;line-height:1.05}
.art span{font-family:var(--font-mono);font-size:10px;color:var(--gold);letter-spacing:var(--tracking-wide);text-transform:uppercase;display:block;margin-top:4px;opacity:0;transform:translateY(6px);transition:.4s}
.art:hover span{opacity:1;transform:none}

/* EQUIPMENT */
.eq{display:grid;grid-template-columns:repeat(3,1fr);gap:46px;font-family:var(--font-mono);font-size:13px}
.eq h5{font-family:var(--font-display);font-size:13px;letter-spacing:var(--tracking-wider);text-transform:uppercase;color:var(--accent);border-bottom:1px solid var(--border);padding-bottom:10px;margin-bottom:14px;font-weight:600}
.eq ul{list-style:none}
.eq li{display:flex;justify-content:space-between;gap:12px;padding:6px 0;color:var(--text-muted);border-bottom:1px dotted var(--border-soft)}
.eq li .q{color:var(--gold);font-weight:500;white-space:nowrap}

/* ============================================================
   FOOTER
   ============================================================ */
footer{background:var(--bg-elevated);border-top:1px solid var(--border);padding-top:var(--space-section);position:relative}
.fg{max-width:var(--maxw);margin:0 auto;padding:0 32px;display:grid;grid-template-columns:1.2fr 1fr 1.4fr;gap:54px}
.fg h3{font-size:30px;margin-bottom:18px;text-transform:uppercase}
.cl{display:flex;flex-direction:column;gap:12px;font-size:15px;color:var(--text-muted)}
.cl a:hover{color:var(--accent)}
.cl .lbl{font-family:var(--font-mono);font-size:11px;letter-spacing:var(--tracking-wide);text-transform:uppercase;color:var(--text-faint);display:block;margin-bottom:3px}
.soc{margin-top:20px;display:flex;gap:12px}
.soc a{font-family:var(--font-mono);font-size:12px;border:1px solid var(--border);padding:7px 14px;border-radius:var(--r-sm);color:var(--text-muted);letter-spacing:var(--tracking-wide)}
.soc a:hover{border-color:var(--accent);color:var(--accent)}
.ff{display:flex;flex-direction:column;gap:13px}
.ff input,.ff textarea,.ff select{background:var(--surface);border:1px solid var(--border);color:var(--text);padding:13px 16px;font-family:var(--font-body);font-size:15px;border-radius:var(--r-sm)}
.ff input:focus,.ff textarea:focus,.ff select:focus{outline:none;border-color:var(--accent)}
.ff button{background:var(--gold);color:#1a1206;border:none;padding:14px;border-radius:var(--r-sm);font-family:var(--font-display);font-size:14px;letter-spacing:var(--tracking-wide);text-transform:uppercase;font-weight:500;cursor:pointer}
.ff button:hover{background:var(--gold-hover)}
.fb{max-width:var(--maxw);margin:64px auto 0;padding:24px 32px;border-top:1px solid var(--border-soft);display:flex;justify-content:space-between;font-family:var(--font-mono);font-size:11px;letter-spacing:var(--tracking-wide);color:var(--text-faint)}

/* ============================================================
   MOBILE
   ============================================================ */
@media(max-width:1100px){.arow{grid-template-columns:repeat(3,1fr)}}
@media(max-width:900px){
  .site-header__nav-container{display:none}
  .theme-toggle:not(.theme-toggle--mobile){display:none}
  .btn-book:not(.btn-book--mobile){display:none}
  .mobile-controls{display:flex}
  .hg,.studios,.cards3,.eq,.fg{grid-template-columns:1fr}
  .arow{grid-template-columns:repeat(2,1fr)}
  .footer-studio-label{display:none}
  .footer-side{display:block}
}

/* AUTH LINKS in header */
.auth-links{display:flex;align-items:center;gap:10px;margin-left:16px;font-family:var(--font-mono);font-size:12px;letter-spacing:.03em}
.auth-links a{color:var(--text-muted);text-decoration:none}
.auth-links a:hover{color:var(--text)}
.auth-name{color:var(--text-faint);max-width:160px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;display:flex;align-items:center;gap:6px}
.auth-av{width:22px;height:22px;border-radius:50%;object-fit:cover;flex-shrink:0}
@media(max-width:900px){.auth-links{display:none}}

/* Booking modal */
.modal-backdrop{position:fixed;inset:0;background:rgba(12,10,7,.6);z-index:199;opacity:0;visibility:hidden;transition:opacity .25s}
.modal-backdrop.show{opacity:1;visibility:visible}
.booking-modal{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%) scale(.96);width:min(440px,calc(100% - 32px));max-height:calc(100vh - 64px);overflow-y:auto;background:var(--bg-elevated);border:1px solid var(--border-soft);border-radius:var(--r-sm);box-shadow:var(--shadow-lg);padding:32px;z-index:200;opacity:0;visibility:hidden;transition:opacity .25s,transform .25s}
.booking-modal.show{opacity:1;visibility:visible;transform:translate(-50%,-50%) scale(1)}
.booking-modal h3{font-size:22px;text-transform:uppercase;margin-bottom:18px;padding-right:24px}
.booking-modal__close{position:absolute;top:16px;right:16px;background:none;border:none;font-size:24px;line-height:1;color:var(--text-faint);cursor:pointer;padding:4px}
.booking-modal__close:hover{color:var(--accent)}
