/* ============================================================
   Часовня Югской иконы Божией Матери — светлый минимализм
   ============================================================ */
:root {
  --cream: #faf7f1; --paper: #ffffff; --ink: #2b2622; --muted: #6f665c;
  --line: #e7ded0; --gold: #b08a3d; --gold-soft: #d9c08a;
  --accent: #7a2e2e; --accent-soft: #f3e9e9;
  --shadow: 0 6px 24px rgba(43,38,34,.06); --radius: 14px; --maxw: 1080px;
}
* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { margin:0; font-family:"Georgia","PT Serif","Times New Roman",serif; color:var(--ink); background:var(--cream); line-height:1.7; font-size:18px; -webkit-font-smoothing:antialiased; }
h1,h2,h3 { font-family:"Georgia","PT Serif",serif; font-weight:600; line-height:1.25; color:var(--ink); letter-spacing:.01em; }
a { color:var(--accent); text-decoration:none; }
a:hover { text-decoration:underline; }
.container { max-width:var(--maxw); margin:0 auto; padding:0 24px; }

/* Шапка */
.site-header { background:var(--paper); border-bottom:1px solid var(--line); position:sticky; top:0; z-index:50; }
.site-header .container { display:flex; align-items:center; justify-content:space-between; gap:16px; min-height:76px; }
.brand { display:flex; align-items:center; gap:14px; color:var(--ink); }
.brand:hover { text-decoration:none; }
.brand .mark { width:40px; height:40px; flex:0 0 40px; }
.brand .brand-text { display:flex; flex-direction:column; line-height:1.15; }
.brand .brand-text b { font-size:17px; font-weight:600; }
.brand .brand-text span { font-size:12.5px; color:var(--muted); letter-spacing:.04em; text-transform:uppercase; }
.nav { display:flex; gap:6px; flex-wrap:wrap; }
.nav a { color:var(--ink); padding:8px 14px; border-radius:999px; font-size:16px; transition:background .2s,color .2s; }
.nav a:hover { background:var(--accent-soft); text-decoration:none; }
.nav a.active { background:var(--accent); color:#fff; }
.nav-toggle { display:none; background:none; border:1px solid var(--line); border-radius:10px; padding:8px 12px; cursor:pointer; font-size:20px; color:var(--ink); }

/* Hero */
.hero { position:relative; background:radial-gradient(1200px 400px at 50% -120px, rgba(176,138,61,.16), transparent 70%), linear-gradient(180deg,#fffdf8 0%,var(--cream) 100%); text-align:center; padding:88px 24px 72px; border-bottom:1px solid var(--line); }
.hero .icon-frame { margin:0 auto 26px; }
.hero h1 { font-size:clamp(30px,5vw,48px); margin:0 0 14px; }
.hero .lead { max-width:680px; margin:0 auto 28px; color:var(--muted); font-size:20px; }
.hero .feast { display:inline-block; background:var(--paper); border:1px solid var(--gold-soft); color:var(--accent); border-radius:999px; padding:8px 20px; font-size:15px; letter-spacing:.03em; }

/* Кнопки */
.btn { display:inline-block; background:var(--accent); color:#fff; padding:13px 28px; border-radius:999px; font-size:16px; border:1px solid var(--accent); cursor:pointer; transition:transform .12s ease,box-shadow .2s; }
.btn:hover { text-decoration:none; box-shadow:var(--shadow); transform:translateY(-1px); }
.btn.ghost { background:transparent; color:var(--accent); }
.btn.ghost:hover { background:var(--accent-soft); }
.btn-row { display:flex; gap:14px; justify-content:center; flex-wrap:wrap; margin-top:28px; }

/* Секции */
section.block { padding:64px 0; }
section.block.alt { background:var(--paper); border-top:1px solid var(--line); border-bottom:1px solid var(--line); }
.section-head { text-align:center; max-width:720px; margin:0 auto 44px; }
.section-head h2 { font-size:clamp(26px,3.5vw,36px); margin:0 0 12px; }
.section-head p { color:var(--muted); margin:0; }
.eyebrow { display:inline-block; color:var(--gold); font-size:13px; letter-spacing:.18em; text-transform:uppercase; margin-bottom:10px; }

/* Карточки */
.cards { display:grid; grid-template-columns:repeat(3,1fr); gap:22px; }
.card { background:var(--paper); border:1px solid var(--line); border-radius:var(--radius); padding:28px; box-shadow:var(--shadow); }
.card .card-ico { width:38px; height:38px; margin-bottom:14px; color:var(--accent); }
.card h3 { margin:0 0 8px; font-size:20px; }
.card p { margin:0; color:var(--muted); font-size:16px; }

/* Текст */
.prose { max-width:760px; margin:0 auto; }
.prose p { margin:0 0 18px; }
.prose h2 { font-size:28px; margin:40px 0 14px; }
.prose h3 { font-size:21px; margin:30px 0 10px; color:var(--accent); }
.prose blockquote { margin:26px 0; padding:18px 24px; border-left:3px solid var(--gold); background:var(--paper); border-radius:8px; color:var(--muted); font-style:italic; }
.prose .figure { margin:30px 0; text-align:center; }
.prose .figure figcaption { font-size:14px; color:var(--muted); margin-top:10px; }

/* Расписание */
.schedule { max-width:820px; margin:0 auto; }
.sched-day { background:var(--paper); border:1px solid var(--line); border-radius:var(--radius); padding:8px 24px; margin-bottom:14px; box-shadow:var(--shadow); }
.sched-day summary { list-style:none; cursor:pointer; display:flex; justify-content:space-between; align-items:center; padding:14px 0; font-size:19px; font-weight:600; }
.sched-day summary::-webkit-details-marker { display:none; }
.sched-day summary .chev { color:var(--gold); transition:transform .2s; }
.sched-day[open] summary .chev { transform:rotate(90deg); }
.sched-row { display:flex; gap:18px; padding:12px 0; border-top:1px solid var(--line); }
.sched-row .time { flex:0 0 96px; color:var(--accent); font-weight:600; }
.sched-row .what { color:var(--ink); }
.sched-row .what small { display:block; color:var(--muted); font-size:14px; }
.note { max-width:820px; margin:28px auto 0; background:var(--accent-soft); border:1px solid #ecd9d9; border-radius:var(--radius); padding:18px 24px; color:#5a3a3a; font-size:16px; }

/* Базовые поля формы */
.field { margin-bottom:20px; }
.field label { display:block; margin-bottom:8px; font-size:15px; color:var(--ink); font-weight:600; }
.field .hint { font-weight:400; color:var(--muted); font-size:13.5px; }
.field input[type=text], .field input[type=email], .field select, .field textarea { width:100%; padding:12px 14px; border:1px solid var(--line); border-radius:10px; font-family:inherit; font-size:16px; background:var(--cream); color:var(--ink); }
.field textarea { min-height:130px; resize:vertical; line-height:1.6; }
.field input:focus, .field select:focus, .field textarea:focus { outline:none; border-color:var(--gold); background:#fff; }
.form-success { display:none; background:#eef6ee; border:1px solid #cfe6cf; color:#2f5a2f; border-radius:var(--radius); padding:22px 24px; margin-bottom:20px; }
.form-success.show { display:block; }

/* Подача треб (Оптина-стиль) */
.order-wrap { max-width:880px; margin:0 auto; }
.step-label { display:flex; align-items:center; gap:12px; font-size:15px; letter-spacing:.04em; text-transform:uppercase; color:var(--gold); margin:0 0 16px; }
.step-label .num { flex:0 0 28px; width:28px; height:28px; border-radius:50%; background:var(--accent); color:#fff; display:flex; align-items:center; justify-content:center; font-size:14px; font-family:Georgia,serif; }
.step { margin-bottom:36px; }
.kind-switch { display:flex; gap:12px; flex-wrap:wrap; }
.kind-switch label { flex:1; min-width:200px; cursor:pointer; margin:0; border:1px solid var(--line); border-radius:var(--radius); background:var(--paper); padding:18px 20px; display:flex; align-items:center; gap:14px; transition:border-color .2s,box-shadow .2s; }
.kind-switch label:hover { border-color:var(--gold-soft); }
.kind-switch input { display:none; }
.kind-switch label:has(input:checked) { border-color:var(--accent); box-shadow:0 0 0 1px var(--accent); }
.kind-switch label:has(input:checked) .ks-body { color:var(--accent); }
.kind-switch .ks-body b { display:block; font-size:18px; }
.kind-switch .ks-body span { font-size:14px; color:var(--muted); }
.kind-switch .ksico { flex:0 0 26px; color:var(--accent); }
.treba-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:16px; }
.treba-card { border:1px solid var(--line); border-radius:var(--radius); background:var(--paper); padding:20px; cursor:pointer; transition:border-color .2s,box-shadow .2s,transform .12s; }
.treba-card:hover { border-color:var(--gold-soft); transform:translateY(-1px); }
.treba-card.sel { border-color:var(--accent); box-shadow:0 0 0 1px var(--accent); }
.treba-card h3 { margin:0 0 6px; font-size:19px; }
.treba-card p { margin:0 0 14px; font-size:14.5px; color:var(--muted); }
.treba-card .periods { display:none; flex-direction:column; gap:8px; border-top:1px solid var(--line); padding-top:14px; }
.treba-card.sel .periods { display:flex; }
.treba-card .periods label { display:flex; align-items:center; justify-content:space-between; gap:10px; font-size:15px; cursor:pointer; padding:4px 0; }
.treba-card .periods .price { color:var(--accent); font-weight:600; white-space:nowrap; }
.treba-card .periods input { accent-color:var(--accent); margin-right:8px; }
.order-cart { background:var(--paper); border:1px solid var(--line); border-radius:var(--radius); box-shadow:var(--shadow); padding:24px; position:sticky; top:92px; }
.order-cart h3 { margin:0 0 16px; font-size:20px; }
.cart-empty { color:var(--muted); font-size:15px; }
.cart-item { border-top:1px solid var(--line); padding:14px 0; font-size:15px; }
.cart-item:first-of-type { border-top:none; }
.cart-item .ci-head { display:flex; justify-content:space-between; gap:10px; font-weight:600; }
.cart-item .ci-sub { color:var(--muted); font-size:13.5px; margin-top:2px; }
.cart-item .ci-names { color:var(--ink); font-size:14px; margin-top:6px; font-style:italic; }
.cart-item .ci-del { background:none; border:none; color:var(--accent); cursor:pointer; font-size:13px; padding:4px 0; }
.cart-total { border-top:2px solid var(--line); margin-top:12px; padding-top:14px; display:flex; justify-content:space-between; font-size:18px; font-weight:600; }
.cart-total .sum { color:var(--accent); }
.order-cols { display:grid; grid-template-columns:1fr 320px; gap:28px; align-items:start; }

/* Контакты */
.contact-grid { display:grid; grid-template-columns:1fr 1fr; gap:28px; }
.contact-list { list-style:none; padding:0; margin:0; }
.contact-list li { display:flex; gap:14px; padding:14px 0; border-bottom:1px solid var(--line); }
.contact-list li .ico { flex:0 0 24px; color:var(--accent); }
.contact-list li b { display:block; }
.contact-list li span { color:var(--muted); font-size:16px; }
.map-card { background:var(--paper); border:1px solid var(--line); border-radius:var(--radius); overflow:hidden; box-shadow:var(--shadow); min-height:280px; display:flex; align-items:center; justify-content:center; text-align:center; color:var(--muted); padding:24px; }

/* Подвал */
.site-footer { background:#2b2622; color:#d8cdbd; padding:48px 0 32px; }
.site-footer .container { display:grid; grid-template-columns:2fr 1fr 1fr; gap:32px; }
.site-footer h4 { color:#fff; font-size:16px; margin:0 0 14px; }
.site-footer a { color:#e8dcca; }
.site-footer .fnav { list-style:none; padding:0; margin:0; }
.site-footer .fnav li { margin-bottom:8px; }
.site-footer .copyright { border-top:1px solid #463f37; margin-top:32px; padding-top:20px; text-align:center; color:#9a9082; font-size:14px; }
.site-footer .fbrand p { color:#b8ad9d; font-size:15px; margin:8px 0 0; max-width:360px; }

/* Иконная рамка */
.icon-frame { width:200px; height:250px; border-radius:8px; position:relative; background:linear-gradient(160deg,#fdfaf3,#f2e8d3); border:6px solid var(--gold-soft); box-shadow:var(--shadow), inset 0 0 0 2px #fff; display:flex; align-items:center; justify-content:center; overflow:hidden; }

/* Адаптив */
@media (max-width:860px) {
  .cards { grid-template-columns:1fr; }
  .contact-grid { grid-template-columns:1fr; }
  .treba-grid { grid-template-columns:1fr; }
  .order-cols { grid-template-columns:1fr; }
  .order-cart { position:static; }
  .site-footer .container { grid-template-columns:1fr; }
  .nav { display:none; position:absolute; top:76px; left:0; right:0; background:var(--paper); flex-direction:column; padding:12px 24px 20px; border-bottom:1px solid var(--line); box-shadow:var(--shadow); }
  .nav.open { display:flex; }
  .nav a { padding:12px 14px; }
  .nav-toggle { display:inline-block; }
}

/* Фотографии и галерея */
.photo { width:100%; border-radius:var(--radius); border:1px solid var(--line); box-shadow:var(--shadow); display:block; }
.figure .photo { max-width:560px; margin:0 auto; }
.gallery { display:grid; grid-template-columns:repeat(4,1fr); gap:14px; }
.gallery a { display:block; border-radius:12px; overflow:hidden; border:1px solid var(--line); box-shadow:var(--shadow); aspect-ratio:4/3; background:#efe8da; }
.gallery img { width:100%; height:100%; object-fit:cover; display:block; transition:transform .35s ease; }
.gallery a:hover img { transform:scale(1.06); }
.photo-credit { text-align:center; color:var(--muted); font-size:13.5px; margin-top:16px; }
.photo-credit a { color:var(--gold); }
@media (max-width:860px) { .gallery { grid-template-columns:repeat(2,1fr); } }

/* Икона на первом экране — показывать целиком (не обрезать) */
.hero .icon-frame { width: 220px; height: auto; padding: 0; background: #fff; overflow: visible; }
.hero .icon-frame img { display: block; width: 100%; height: auto; border-radius: 4px; }
@media (max-width:860px) { .hero .icon-frame { width: 180px; } }

/* Логотип-миниикона в шапке */
.brand img.mark { border-radius:50%; object-fit:cover; border:1px solid var(--gold-soft); box-shadow:0 1px 3px rgba(0,0,0,.10); background:#fff; }

/* Шапка: длинное название бренда — аккуратный перенос и отступ */
.brand-text { gap:2px; }
.brand-text b { font-size:15.5px; line-height:1.2; }
.brand-text span { margin-top:2px; }
@media (max-width:520px){ .brand-text b { font-size:14px; } }

/* Шапка: надёжная раскладка названия (без flex-наложения при переносе) */
.brand .brand-text { display:block; line-height:1.2; }
.brand .brand-text b { display:block; font-size:15.5px; }
.brand .brand-text span { display:block; margin-top:3px; }

/* Заголовок в шапке — заглавными буквами */
.brand .brand-text b { text-transform:uppercase; letter-spacing:.02em; }
.brand .brand-text b { white-space:nowrap; }

/* Летопись (таймлайн) */
.timeline { max-width:780px; margin:0 auto; position:relative; padding-left:28px; }
.timeline::before { content:""; position:absolute; left:7px; top:6px; bottom:6px; width:3px; background:var(--gold-soft); border-radius:2px; }
.tl-item { position:relative; padding:0 0 26px 8px; }
.tl-item::before { content:""; position:absolute; left:-28px; top:4px; width:15px; height:15px; border-radius:50%; background:var(--accent); border:3px solid var(--cream); }
.tl-item.gold::before { background:var(--gold); }
.tl-year { font-weight:600; color:var(--accent); font-size:17px; }
.tl-title { font-weight:600; margin:2px 0 3px; }
.tl-desc { color:var(--muted); font-size:15px; }
.tl-period { margin:28px 0 14px; font-size:13px; letter-spacing:.16em; text-transform:uppercase; color:var(--gold); }
/* Реквизиты */
.req { background:var(--paper); border:1px solid var(--line); border-radius:var(--radius); padding:22px 24px; box-shadow:var(--shadow); max-width:640px; margin:0 auto; }
.req dl { margin:0; } .req dt { color:var(--muted); font-size:13px; margin-top:10px; } .req dd { margin:2px 0 0; font-weight:600; }
.qr-box { width:200px; height:200px; border:2px dashed var(--gold-soft); border-radius:12px; display:flex; align-items:center; justify-content:center; text-align:center; color:var(--muted); font-size:14px; margin:0 auto; padding:16px; }
