/* ====== Ритуальная служба Мытищи — общий стиль ====== */
:root{
  --graphite:#1f2a2e;
  --green:#2f4f4a;
  --green-dark:#243d39;
  --gold:#c2a36b;
  --gold-dark:#a8884f;
  --ivory:#f7f5f1;
  --paper:#ffffff;
  --text:#2b2b2b;
  --muted:#6b6f6e;
  --line:#e4e0d8;
  --radius:12px;
  --shadow:0 8px 30px rgba(31,42,46,.08);
  --shadow-sm:0 3px 12px rgba(31,42,46,.07);
  --maxw:1160px;
  --serif:"PT Serif",Georgia,"Times New Roman",serif;
  --sans:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,"Helvetica Neue",Arial,sans-serif;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;font-family:var(--sans);color:var(--text);
  background:var(--ivory);line-height:1.6;font-size:17px;
  -webkit-font-smoothing:antialiased;
}
h1,h2,h3,h4{font-family:var(--serif);color:var(--graphite);line-height:1.22;font-weight:700;margin:0 0 .5em}
h1{font-size:clamp(28px,4.4vw,46px)}
h2{font-size:clamp(24px,3.3vw,34px)}
h3{font-size:clamp(19px,2.2vw,23px)}
p{margin:0 0 1em}
a{color:var(--green);text-decoration:none}
a:hover{color:var(--gold-dark)}
img,svg{max-width:100%}
.container{max-width:var(--maxw);margin:0 auto;padding:0 20px}
.section{padding:64px 0}
.section--tight{padding:44px 0}
.bg-green{background:var(--green);color:#eef1ef}
.bg-graphite{background:var(--graphite);color:#dfe4e3}
.bg-paper{background:var(--paper)}
.center{text-align:center}
.lead{font-size:19px;color:var(--muted);max-width:760px}
.center .lead{margin-left:auto;margin-right:auto}
.eyebrow{display:inline-block;text-transform:uppercase;letter-spacing:.16em;font-size:12.5px;font-weight:700;color:var(--gold-dark);margin-bottom:12px}
.bg-green .eyebrow,.bg-graphite .eyebrow{color:var(--gold)}
.bg-green h2,.bg-graphite h2,.bg-green h3,.bg-graphite h3{color:#fff}

/* ---- Buttons ---- */
.btn{display:inline-flex;align-items:center;gap:9px;justify-content:center;
  padding:14px 26px;border-radius:10px;font-weight:700;font-size:16px;
  cursor:pointer;border:2px solid transparent;transition:.18s;text-align:center;line-height:1.2}
.btn--gold{background:var(--gold);color:#231c0d}
.btn--gold:hover{background:var(--gold-dark);color:#fff}
.btn--green{background:var(--green);color:#fff}
.btn--green:hover{background:var(--green-dark);color:#fff}
.btn--ghost{background:transparent;border-color:var(--gold);color:var(--gold)}
.btn--ghost:hover{background:var(--gold);color:#231c0d}
.btn--outline{background:transparent;border-color:var(--green);color:var(--green)}
.btn--outline:hover{background:var(--green);color:#fff}
.btn--lg{padding:17px 34px;font-size:17px}
.btn--block{width:100%}

/* ---- Topbar ---- */
.topbar{background:var(--graphite);color:#cdd4d2;font-size:14px}
.topbar .container{display:flex;justify-content:space-between;align-items:center;gap:14px;padding-top:7px;padding-bottom:7px;flex-wrap:wrap}
.topbar a{color:#cdd4d2}
.topbar .dot{color:var(--gold)}

/* ---- Header ---- */
.header{position:sticky;top:0;z-index:50;background:var(--paper);box-shadow:var(--shadow-sm)}
.header .container{display:flex;align-items:center;gap:12px;padding-top:12px;padding-bottom:12px}
.logo{display:flex;align-items:center;gap:12px;flex-shrink:0}
.logo__txt b{display:block;font-family:var(--serif);font-size:20px;color:var(--graphite);line-height:1.05}
.logo__txt span{font-size:12.5px;color:var(--muted);letter-spacing:.04em}
.nav{display:flex;gap:15px;margin-left:auto;flex-wrap:wrap}
.nav a{color:var(--graphite);font-weight:600;font-size:14.5px;padding:6px 0;border-bottom:2px solid transparent;white-space:nowrap}
.nav a:hover,.nav a.active{color:var(--green);border-color:var(--gold)}
.header__phone{display:flex;flex-direction:column;align-items:flex-end;margin-left:12px}
.header__phone a{font-family:var(--serif);font-size:19px;font-weight:700;color:var(--graphite);white-space:nowrap}
.header__phone span{font-size:11.5px;color:var(--gold-dark);font-weight:700}
.header__cta{margin-left:10px}
.burger{display:none;margin-left:auto;background:none;border:0;cursor:pointer;padding:6px}
.burger span{display:block;width:26px;height:3px;background:var(--graphite);margin:5px 0;border-radius:2px;transition:.2s}

/* ---- Hero ---- */
.hero{position:relative;background:linear-gradient(180deg,#243d39 0%,#1f2a2e 100%);color:#eef1ef;overflow:hidden}
.hero::after{content:"";position:absolute;inset:0;background:radial-gradient(circle at 80% 20%,rgba(194,163,107,.13),transparent 55%);pointer-events:none}
.hero .container{position:relative;display:grid;grid-template-columns:1.1fr .9fr;gap:44px;align-items:center;padding:70px 20px}
.hero h1{color:#fff}
.hero p{color:#d6ddda;font-size:19px}
.hero__badges{display:flex;gap:10px;flex-wrap:wrap;margin:22px 0 26px}
.hero__badge{display:flex;align-items:center;gap:8px;background:rgba(255,255,255,.07);border:1px solid rgba(194,163,107,.35);padding:8px 14px;border-radius:30px;font-size:14px}
.hero__cta{display:flex;gap:14px;flex-wrap:wrap}
.hero__art{display:flex;justify-content:center}

/* ---- Form card ---- */
.form-card{background:var(--paper);color:var(--text);border-radius:16px;box-shadow:var(--shadow);padding:28px;border-top:4px solid var(--gold)}
.form-card h3{margin-bottom:6px}
.form-card .small{font-size:14px;color:var(--muted);margin-bottom:16px}
.field{margin-bottom:13px}
.field input,.field textarea,.field select{width:100%;padding:13px 15px;border:1.5px solid var(--line);border-radius:9px;font-size:16px;font-family:inherit;background:#fff;color:var(--text)}
.field input:focus,.field textarea:focus,.field select:focus{outline:none;border-color:var(--green)}
.consent{display:flex;gap:9px;font-size:12.5px;color:var(--muted);margin:10px 0 14px;align-items:flex-start}
.consent input{margin-top:3px}

/* ---- Cards / grids ---- */
.grid{display:grid;gap:22px}
.grid-2{grid-template-columns:repeat(2,1fr)}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-4{grid-template-columns:repeat(4,1fr)}
.card{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);padding:26px;box-shadow:var(--shadow-sm);transition:.18s;height:100%}
.card:hover{transform:translateY(-3px);box-shadow:var(--shadow)}
.card .ico{width:52px;height:52px;margin-bottom:14px}
.card h3{margin-bottom:8px}
.card p{color:var(--muted);font-size:15.5px;margin-bottom:14px}
.card .arrow{font-weight:700;color:var(--green)}

/* ---- Stats ---- */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;text-align:center}
.stat b{display:block;font-family:var(--serif);font-size:40px;color:var(--gold)}
.stat span{font-size:15px;color:#cdd4d2}

/* ---- Steps ---- */
.steps{counter-reset:s;display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
.step{position:relative;background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);padding:28px 22px 22px}
.step::before{counter-increment:s;content:counter(s);position:absolute;top:-18px;left:22px;width:40px;height:40px;border-radius:50%;background:var(--gold);color:#231c0d;font-family:var(--serif);font-weight:700;font-size:20px;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-sm)}
.step h3{font-size:18px;margin:8px 0}
.step p{font-size:14.5px;color:var(--muted);margin:0}

/* ---- Pricing ---- */
.price-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;align-items:stretch}
.plan{background:var(--paper);border:1px solid var(--line);border-radius:16px;padding:30px 26px;display:flex;flex-direction:column;box-shadow:var(--shadow-sm);position:relative}
.plan--featured{border:2px solid var(--gold);box-shadow:var(--shadow)}
.plan__tag{position:absolute;top:-13px;left:50%;transform:translateX(-50%);background:var(--gold);color:#231c0d;font-size:12.5px;font-weight:700;padding:5px 16px;border-radius:20px}
.plan h3{margin-bottom:4px}
.plan .from{font-size:14px;color:var(--muted)}
.plan .price{font-family:var(--serif);font-size:36px;color:var(--graphite);margin:6px 0 16px}
.plan ul{list-style:none;padding:0;margin:0 0 22px;flex-grow:1}
.plan li{padding:9px 0 9px 28px;position:relative;font-size:15px;border-bottom:1px dashed var(--line)}
.plan li::before{content:"✓";position:absolute;left:0;color:var(--green);font-weight:700}

/* ---- Price table ---- */
.ptable{width:100%;border-collapse:collapse;background:var(--paper);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm)}
.ptable th,.ptable td{padding:14px 18px;text-align:left;border-bottom:1px solid var(--line)}
.ptable th{background:var(--green);color:#fff;font-family:var(--serif)}
.ptable td:last-child,.ptable th:last-child{text-align:right;white-space:nowrap;font-weight:700}
.ptable tr:hover td{background:#faf8f4}
.ptable caption{caption-side:top;text-align:left;font-family:var(--serif);font-size:21px;color:var(--graphite);margin-bottom:12px}

/* ---- Calculator ---- */
.calc{background:var(--paper);border-radius:16px;box-shadow:var(--shadow);padding:30px;display:grid;grid-template-columns:1fr 320px;gap:30px}
.calc__result{background:var(--green);color:#fff;border-radius:12px;padding:26px;display:flex;flex-direction:column;justify-content:center;text-align:center}
.calc__result .sum{font-family:var(--serif);font-size:42px;color:var(--gold)}
.calc__opt{margin-bottom:16px}
.calc__opt label{display:block;font-weight:600;margin-bottom:7px}

/* ---- Trust / mosaic ---- */
.trust{display:grid;grid-template-columns:repeat(2,1fr);gap:22px}
.trust__item{display:flex;gap:16px;align-items:flex-start}
.trust__item .ico{width:46px;height:46px;flex-shrink:0}
.trust__item h3{font-size:18px;margin-bottom:4px}
.trust__item p{font-size:15px;color:var(--muted);margin:0}

/* ---- FAQ ---- */
.faq{max-width:840px;margin:0 auto}
.faq details{background:var(--paper);border:1px solid var(--line);border-radius:10px;margin-bottom:12px;overflow:hidden}
.faq summary{cursor:pointer;padding:18px 22px;font-weight:600;font-family:var(--serif);font-size:18px;list-style:none;display:flex;justify-content:space-between;gap:14px;color:var(--graphite)}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";color:var(--gold-dark);font-size:24px;line-height:1}
.faq details[open] summary::after{content:"–"}
.faq details[open] summary{color:var(--green)}
.faq .faq__a{padding:0 22px 18px;color:var(--muted)}

/* ---- Reviews ---- */
.review{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);padding:24px;box-shadow:var(--shadow-sm)}
.review .stars{color:var(--gold);letter-spacing:2px;margin-bottom:8px}
.review p{font-style:italic;color:var(--text)}
.review .who{font-weight:700;color:var(--graphite);font-style:normal;font-size:15px}

/* ---- Breadcrumbs ---- */
.crumbs{font-size:13.5px;color:var(--muted);padding:14px 0}
.crumbs a{color:var(--muted)}
.crumbs a:hover{color:var(--green)}

/* ---- CTA band ---- */
.cta-band{background:linear-gradient(120deg,var(--green) 0%,var(--graphite) 100%);color:#fff;border-radius:18px;padding:44px;text-align:center;position:relative;overflow:hidden}
.cta-band h2{color:#fff}
.cta-band .hero__cta{justify-content:center;margin-top:18px}

/* ---- Local list ---- */
.chips{display:flex;flex-wrap:wrap;gap:10px}
.chip{background:#fff;border:1px solid var(--line);border-radius:24px;padding:8px 16px;font-size:14px;color:var(--graphite)}
.bg-green .chip,.bg-graphite .chip{background:rgba(255,255,255,.08);border-color:rgba(194,163,107,.3);color:#eef1ef}

/* ---- Footer ---- */
.footer{background:var(--graphite);color:#aeb6b4;font-size:14.5px;padding:54px 0 26px}
.footer a{color:#cdd4d2}
.footer a:hover{color:var(--gold)}
.footer__grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.2fr;gap:30px;margin-bottom:30px}
.footer h4{color:#fff;font-size:16px;margin-bottom:14px}
.footer ul{list-style:none;padding:0;margin:0}
.footer li{margin-bottom:9px}
.footer__legal{border-top:1px solid rgba(255,255,255,.1);padding-top:20px;font-size:12.5px;color:#7e8684;line-height:1.7}

/* ---- Floating mobile bar ---- */
.mobar{display:none;position:fixed;bottom:0;left:0;right:0;z-index:60;background:var(--graphite);padding:9px;gap:9px;box-shadow:0 -4px 18px rgba(0,0,0,.2)}
.mobar a{flex:1;text-align:center;padding:13px;border-radius:9px;font-weight:700;font-size:15px}

/* ---- Modal ---- */
.modal{position:fixed;inset:0;z-index:100;background:rgba(31,42,46,.6);display:none;align-items:center;justify-content:center;padding:18px}
.modal.open{display:flex}
.modal__box{background:#fff;border-radius:16px;max-width:440px;width:100%;padding:30px;position:relative;border-top:4px solid var(--gold)}
.modal__close{position:absolute;top:12px;right:16px;border:0;background:none;font-size:28px;cursor:pointer;color:var(--muted);line-height:1}
.toast{position:fixed;bottom:24px;left:50%;transform:translateX(-50%) translateY(120px);background:var(--green);color:#fff;padding:15px 26px;border-radius:10px;box-shadow:var(--shadow);z-index:120;transition:.35s;font-weight:600}
.toast.show{transform:translateX(-50%) translateY(0)}

/* ---- Content prose ---- */
.prose h2{margin-top:32px}
.prose h3{margin-top:24px}
.prose ul{padding-left:22px}
.prose li{margin-bottom:8px}
.feature-list{list-style:none;padding:0;margin:0}
.feature-list li{position:relative;padding:10px 0 10px 36px;border-bottom:1px solid var(--line);font-size:16px}
.feature-list li::before{content:"";position:absolute;left:0;top:12px;width:20px;height:20px;background:var(--gold);border-radius:50%}
.feature-list li::after{content:"✓";position:absolute;left:5px;top:10px;color:#231c0d;font-weight:700;font-size:13px}

/* ---- Responsive ---- */
@media(max-width:980px){
  .hero .container{grid-template-columns:1fr;gap:32px;padding:48px 20px}
  .hero__art{order:-1}
  .grid-3,.grid-4,.price-grid,.steps{grid-template-columns:repeat(2,1fr)}
  .stats{grid-template-columns:repeat(2,1fr)}
  .calc{grid-template-columns:1fr}
  .footer__grid{grid-template-columns:repeat(2,1fr)}
  .nav,.header__phone,.header__cta{display:none}
  .header.open .nav{display:flex;position:absolute;top:100%;left:0;right:0;background:#fff;flex-direction:column;padding:16px 20px;box-shadow:var(--shadow);gap:4px}
  .header.open .nav a{padding:11px 0;border-bottom:1px solid var(--line)}
  .burger{display:block}
  .mobar{display:flex}
  body{padding-bottom:64px}
}
@media(max-width:600px){
  .grid-3,.grid-4,.price-grid,.steps,.grid-2,.trust,.footer__grid,.stats{grid-template-columns:1fr}
  .section{padding:46px 0}
  .cta-band{padding:30px 20px}
  .ptable th,.ptable td{padding:11px 12px;font-size:14px}
}
