/* ═══════════ СТАТИЧНЫЕ СТРАНИЦЫ old-loft ═══════════ */

/* ─── общая контент-страница (page.php): prose ─── */
.page-hero { max-width: 1180px; margin: 0 auto; padding: 2.6rem 2.4rem 0; }
.page-hero .over { font-family: 'JetBrains Mono', monospace; font-size: .62rem; letter-spacing: .3em; text-transform: uppercase; color: var(--acc2); }
.prose { max-width: 860px; margin: 2rem auto 0; padding: 0 2.4rem 2rem; color: var(--sub); font-size: 1rem; }
.prose > * + * { margin-top: 1.1rem; }
.prose h2 { font-family: 'Oswald', sans-serif; font-weight: 700; text-transform: uppercase; color: var(--text); font-size: clamp(1.4rem, 1.1rem + 1.4vw, 2.1rem); line-height: 1.1; margin-top: 2.4rem; letter-spacing: .01em; }
.prose h3 { font-family: 'Oswald', sans-serif; font-weight: 600; text-transform: uppercase; color: var(--text); font-size: 1.2rem; margin-top: 1.8rem; }
.prose h4 { font-weight: 700; color: var(--text); margin-top: 1.4rem; }
.prose p { line-height: 1.7; }
.prose b, .prose strong { color: var(--text); }
.prose a { color: var(--acc2); text-decoration: none; border-bottom: 1px solid var(--line); }
.prose a:hover { border-color: var(--acc2); }
.prose ul, .prose ol { padding-left: 1.4rem; }
.prose li { margin-top: .5rem; line-height: 1.6; }
.prose li::marker { color: var(--acc); }
.prose img { border: 1px solid var(--line); margin: 1.4rem 0; }
.prose blockquote { border-left: 2px solid var(--acc); padding-left: 1.2rem; color: var(--text); font-style: italic; }
.prose hr { border: none; border-top: 1px solid var(--line); margin: 2rem 0; }
.prose table { width: 100%; border-collapse: collapse; margin: 1.4rem 0; font-size: .9rem; }
.prose th, .prose td { border: 1px solid var(--line); padding: .7rem .9rem; text-align: left; }
.prose th { background: var(--bg2); color: var(--text); font-family: 'Oswald', sans-serif; text-transform: uppercase; font-size: .8rem; letter-spacing: .04em; }

/* ─── формы Contact Form 7 под графит ─── */
.wpcf7 input[type="text"], .wpcf7 input[type="email"], .wpcf7 input[type="tel"], .wpcf7 input[type="date"], .wpcf7 textarea, .wpcf7 select,
.book-form input, .book-form select {
  width: 100%; background: var(--bg2); border: 1px solid var(--line); color: var(--text);
  padding: .85rem 1rem; font-family: 'Manrope', sans-serif; font-size: .95rem; margin-top: .3rem;
}
.wpcf7 input:focus, .wpcf7 textarea:focus, .wpcf7 select:focus, .book-form input:focus, .book-form select:focus { outline: none; border-color: var(--acc); }
.wpcf7 label { font-size: .7rem; font-weight: 700; letter-spacing: .12em; text-transform: uppercase; color: var(--dim); display: block; margin-top: 1rem; }
.wpcf7 .wpcf7-submit, .book-form .btn-main { margin-top: 1.2rem; width: 100%; }
.wpcf7-response-output { border: 1px solid var(--line) !important; color: var(--sub); margin: 1rem 0 0 !important; padding: .8rem 1rem !important; font-size: .85rem; }

/* ─── КОНТАКТЫ (page-kontakty) ─── */
.wrapk { max-width: 1180px; margin: 0 auto; padding: 2.8rem 2.4rem 0; }
.wrapk .over { font-family: 'JetBrains Mono', monospace; font-size: .62rem; letter-spacing: .3em; text-transform: uppercase; color: var(--acc2); }
.k-grid { margin-top: 2.4rem; display: grid; grid-template-columns: 1fr 1fr; gap: 3rem; align-items: start; }
.big-phone { font-family: 'Oswald', sans-serif; font-weight: 700; font-size: clamp(1.8rem, 1.3rem + 2.6vw, 3.4rem); color: var(--text); text-decoration: none; line-height: 1; display: inline-block; }
.big-phone:hover { color: var(--acc2); }
.sub-line { color: var(--dim); font-size: .8rem; margin-top: .6rem; }
.mess { display: flex; gap: .8rem; margin-top: 1.4rem; flex-wrap: wrap; }
.mess a { font-family: 'Oswald', sans-serif; font-weight: 500; font-size: .8rem; letter-spacing: .1em; text-transform: uppercase; border: 1px solid var(--line); color: var(--text); padding: .8rem 1.4rem; text-decoration: none; transition: .25s; }
.mess a:hover { border-color: var(--acc); color: var(--acc2); }
.k-rows { margin-top: 2rem; }
.k-row { display: flex; gap: 1.2rem; align-items: baseline; padding: .9rem 0; border-bottom: 1px solid var(--line); font-size: .88rem; }
.k-row .k { font-family: 'JetBrains Mono', monospace; font-size: .62rem; letter-spacing: .14em; text-transform: uppercase; color: var(--dim); width: 8.5rem; flex: none; }
.k-row b { color: var(--text); }
.k-row span:last-child { color: var(--sub); }
.map { border: 1px solid var(--line); background: var(--bg2); aspect-ratio: 16/10; display: grid; place-items: center; position: relative; overflow: hidden; }
.map::before { content: ''; position: absolute; inset: 0; opacity: .25; background: repeating-linear-gradient(0deg, var(--line) 0 1px, transparent 1px 36px), repeating-linear-gradient(90deg, var(--line) 0 1px, transparent 1px 36px); }
.map .pin { position: relative; z-index: 2; text-align: center; }
.map .pin .ic { font-size: 2rem; color: var(--acc); }
.map .pin .t { font-family: 'JetBrains Mono', monospace; font-size: .64rem; letter-spacing: .18em; color: var(--sub); margin-top: .5rem; text-transform: uppercase; line-height: 1.9; }
.map .pin .t b { color: var(--text); }
.req { margin-top: 1.4rem; border: 1px solid var(--line); background: var(--bg2); padding: 1.2rem 1.4rem; font-family: 'JetBrains Mono', monospace; font-size: .68rem; color: var(--dim); letter-spacing: .06em; line-height: 2; }
.req b { color: var(--sub); }
.page-fin { text-align: center; padding: 4.5rem 2.4rem 0; }
.page-fin h2 { font-family: 'Oswald', sans-serif; font-weight: 700; text-transform: uppercase; font-size: clamp(1.6rem, 1.2rem + 2vw, 3rem); }
.page-fin h2 em { font-style: normal; color: var(--acc); }
.page-fin .row2 { display: flex; justify-content: center; gap: 1rem; flex-wrap: wrap; margin-top: 1.6rem; }

/* ─── ТРИ ПУТИ (page-ways) — «развилка-двери» ─── */
.doors { display: flex; min-height: 86svh; border-bottom: 1px solid var(--line); }
.door { position: relative; flex: 1; overflow: hidden; cursor: pointer; text-decoration: none; color: inherit; display: flex; flex-direction: column; justify-content: flex-end; padding: 2.2rem 2rem; border-right: 1px solid var(--line); transition: flex .6s cubic-bezier(.65,.01,.05,.99); }
.door:last-child { border-right: none; }
.door:hover { flex: 1.7; }
.door img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; filter: brightness(.45) saturate(.9); transition: filter .5s, transform 1.2s cubic-bezier(.23,1,.32,1); }
.door:hover img { filter: brightness(.62) saturate(1); transform: scale(1.04); }
.door::after { content: ''; position: absolute; inset: 0; background: linear-gradient(180deg, var(--ov1), transparent 40%, var(--ov2) 95%); }
.door > div { position: relative; z-index: 2; }
.d-no { font-family: 'JetBrains Mono', monospace; font-size: .62rem; letter-spacing: .26em; color: var(--acc2); }
.d-name { font-family: 'Oswald', sans-serif; font-weight: 700; text-transform: uppercase; font-size: clamp(1.4rem, 1rem + 1.8vw, 2.6rem); line-height: 1.02; margin-top: .6rem; }
.d-sub { color: var(--sub); font-size: .82rem; margin-top: .6rem; max-width: 34ch; opacity: 0; transform: translateY(8px); transition: opacity .4s .1s, transform .5s .1s; }
.door:hover .d-sub { opacity: 1; transform: none; }
.d-go { margin-top: 1rem; font-family: 'JetBrains Mono', monospace; font-size: .6rem; letter-spacing: .24em; text-transform: uppercase; color: var(--acc2); }
.sect { max-width: 1180px; margin: 0 auto; padding: 5rem 2.4rem 0; }
.sect .way-no { font-family: 'JetBrains Mono', monospace; font-size: .66rem; color: var(--acc); letter-spacing: .26em; }
.sect h2 { font-family: 'Oswald', sans-serif; font-weight: 700; text-transform: uppercase; font-size: clamp(1.7rem, 1.3rem + 2vw, 3rem); line-height: 1; margin-top: .6rem; }
.sect h2 em { font-style: normal; color: var(--acc); }
.sect .lead { color: var(--sub); margin-top: 1rem; max-width: 60ch; }
.sect .lead b { color: var(--text); }
.tiles { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1px; background: var(--line); border: 1px solid var(--line); margin-top: 1.8rem; }
.tile { background: var(--bg2); padding: 1.3rem 1.2rem; }
.tile .n { font-family: 'JetBrains Mono', monospace; font-size: .6rem; color: var(--acc2); letter-spacing: .14em; }
.tile b { display: block; font-family: 'Oswald', sans-serif; font-weight: 600; font-size: .95rem; text-transform: uppercase; letter-spacing: .05em; margin-top: .5rem; }
.tile p { color: var(--dim); font-size: .76rem; margin-top: .4rem; }
.sect .meta-row { display: flex; gap: 1rem; align-items: center; margin-top: 1.4rem; flex-wrap: wrap; }
.sect .meta-row .tagm { font-family: 'JetBrains Mono', monospace; font-size: .6rem; letter-spacing: .14em; text-transform: uppercase; border: 1px solid var(--line); color: var(--sub); padding: .4rem .8rem; }
.sect .meta-row .tagm b { color: var(--acc2); }
.sect .cta { margin-top: 1.6rem; }

/* ─── ШОУ-РУМ (page-showroom) ─── */
.sr-hero { position: relative; min-height: 78svh; display: flex; align-items: flex-end; overflow: hidden; }
.sr-hero .bg { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; filter: grayscale(.4) contrast(1.05) brightness(.5); }
.sr-hero::after { content: ''; position: absolute; inset: 0; background: linear-gradient(180deg, var(--ov1), transparent 40%, var(--ov2) 92%); }
.hero-in { position: relative; z-index: 2; max-width: 1180px; margin: 0 auto; width: 100%; padding: 0 2.4rem 2.4rem; }
.hero-in .over { font-family: 'JetBrains Mono', monospace; font-size: .62rem; letter-spacing: .3em; text-transform: uppercase; color: var(--acc2); }
.hero-in h1 { font-family: 'Oswald', sans-serif; font-weight: 700; text-transform: uppercase; font-size: clamp(2rem, 1.4rem + 3.4vw, 4.6rem); line-height: 1; margin-top: .8rem; }
.hero-in h1 em { font-style: normal; color: var(--acc); }
.hero-in p { color: var(--sub); margin-top: 1.1rem; max-width: 56ch; }
.hero-in p b { color: var(--text); }
.hero-cta { display: flex; gap: 1rem; margin-top: 1.8rem; flex-wrap: wrap; }
.why { max-width: 1180px; margin: 4.5rem auto 0; padding: 0 2.4rem; display: grid; grid-template-columns: repeat(3, 1fr); gap: 2rem; }
.why .num { font-family: 'Oswald', sans-serif; font-weight: 700; font-size: 2.6rem; color: var(--acc); line-height: 1; }
.why .l { font-weight: 700; text-transform: uppercase; letter-spacing: .08em; font-size: .82rem; margin-top: .6rem; }
.why p { color: var(--dim); font-size: .82rem; margin-top: .5rem; }
.visit { max-width: 1180px; margin: 5rem auto 0; padding: 0 2.4rem; display: grid; grid-template-columns: 1fr 1fr; gap: 3rem; align-items: center; }
.visit-img img { width: 100%; filter: grayscale(.3) contrast(1.05) brightness(.85); }
.visit .over { font-family: 'JetBrains Mono', monospace; font-size: .62rem; letter-spacing: .3em; text-transform: uppercase; color: var(--acc2); }
.visit h2 { font-family: 'Oswald', sans-serif; font-weight: 700; text-transform: uppercase; font-size: clamp(1.5rem, 1.2rem + 1.6vw, 2.6rem); margin-top: .5rem; }
.visit h2 em { font-style: normal; color: var(--acc); }
.steps { margin-top: 1.4rem; }
.step { padding: .9rem 0; border-bottom: 1px solid var(--line); }
.step b { font-family: 'Oswald', sans-serif; font-weight: 600; text-transform: uppercase; letter-spacing: .04em; }
.step p { color: var(--dim); font-size: .82rem; margin-top: .3rem; }
.book { max-width: 1180px; margin: 5rem auto 0; padding: 0 2.4rem; display: grid; grid-template-columns: 1fr 1fr; gap: 3rem; align-items: start; }
.book h3 { font-family: 'Oswald', sans-serif; font-weight: 700; text-transform: uppercase; font-size: 1.3rem; margin-bottom: 1rem; }
.book-form { border: 1px solid var(--line); background: var(--bg2); padding: 1.8rem; }
.book-form .fine { color: var(--dim); font-size: .74rem; margin-top: .9rem; }
.faq { max-width: 1100px; margin: 5.5rem auto 0; padding: 0 2.4rem; }
.faq details { border-bottom: 1px solid var(--line); }
.faq summary { cursor: pointer; list-style: none; display: flex; justify-content: space-between; align-items: center; font-family: 'Oswald', sans-serif; font-weight: 600; font-size: 1rem; letter-spacing: .06em; text-transform: uppercase; padding: 1.1rem .2rem; }
.faq summary::-webkit-details-marker { display: none; }
.faq summary::after { content: '+'; color: var(--acc); font-size: 1.2rem; transition: transform .3s; }
.faq details[open] summary::after { transform: rotate(45deg); }
.faq .bd { padding: 0 .2rem 1.2rem; color: var(--sub); font-size: .86rem; max-width: 70ch; }
.faq .bd b { color: var(--text); }

@media (max-width: 1000px) {
  .wrapk, .prose, .page-hero { padding-left: 1.3rem; padding-right: 1.3rem; }
  .k-grid { grid-template-columns: 1fr; gap: 2rem; }
  .doors { flex-direction: column; min-height: 0; }
  .door { min-height: 30vh; border-right: none; border-bottom: 1px solid var(--line); padding: 1.4rem 1.3rem; }
  .door .d-sub { opacity: 1; transform: none; }
  .sect { padding: 3.4rem 1.3rem 0; }
  .tiles { grid-template-columns: 1fr 1fr; }
  .hero-in, .why, .visit, .book, .faq { padding-left: 1.3rem; padding-right: 1.3rem; }
  .why { grid-template-columns: 1fr; margin-top: 3.5rem; }
  .visit, .book { grid-template-columns: 1fr; gap: 1.8rem; }
}

/* Яндекс.Карта (реальный iframe вместо заглушки) — ревью #07 P1 */
.map iframe { width: 100%; height: 100%; border: 0; display: block; position: relative; z-index: 3; }
