/* ===== Ритуальная служба «Дальний Свет» · Люберцы =====
   Уважительный, спокойный дизайн. Тёмно-графитовый + приглушённая бронза. */

:root{
  --ink:#1d2330;          /* основной тёмный */
  --ink-2:#2b3344;
  --slate:#4a5365;
  --muted:#6b7382;
  --line:#e3e6ec;
  --bg:#ffffff;
  --bg-soft:#f5f6f9;
  --bg-soft-2:#eef1f6;
  --brand:#1f3a5f;        /* глубокий синий */
  --brand-2:#2c5282;
  --gold:#a98442;         /* приглушённая бронза */
  --gold-2:#c69b53;
  --gold-soft:#f6efe1;
  --ok:#2e7d57;
  --danger:#b23b3b;
  --radius:14px;
  --radius-sm:10px;
  --shadow:0 6px 24px rgba(29,35,48,.08);
  --shadow-lg:0 18px 50px rgba(29,35,48,.16);
  --maxw:1180px;
  --serif:"PT Serif",Georgia,"Times New Roman",serif;
  --sans:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Arial,sans-serif;
}

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;font-family:var(--sans);color:var(--ink);background:var(--bg);
  font-size:17px;line-height:1.62;-webkit-font-smoothing:antialiased;
}
img,svg{max-width:100%;display:block}
a{color:var(--brand-2);text-decoration:none}
a:hover{text-decoration:underline}
h1,h2,h3,h4{font-family:var(--serif);color:var(--ink);line-height:1.22;font-weight:700;margin:0 0 .5em}
h1{font-size:clamp(1.9rem,3.6vw,2.9rem)}
h2{font-size:clamp(1.5rem,2.6vw,2.1rem)}
h3{font-size:1.22rem}
p{margin:0 0 1em}
.container{max-width:var(--maxw);margin:0 auto;padding:0 20px}
.section{padding:64px 0}
.section--soft{background:var(--bg-soft)}
.section__head{max-width:760px;margin:0 auto 38px;text-align:center}
.section__head.left{margin-left:0;text-align:left}
.section__kicker{display:inline-block;font-family:var(--sans);font-weight:600;letter-spacing:.14em;
  text-transform:uppercase;font-size:.74rem;color:var(--gold);margin-bottom:10px}
.lead{font-size:1.12rem;color:var(--slate)}
.muted{color:var(--muted)}
.center{text-align:center}

/* ---------- Buttons ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:9px;
  font-family:var(--sans);font-weight:600;font-size:1rem;line-height:1;cursor:pointer;
  padding:15px 26px;border-radius:var(--radius-sm);border:1.5px solid transparent;
  transition:.18s ease;text-decoration:none;white-space:nowrap}
.btn:hover{text-decoration:none;transform:translateY(-1px)}
.btn--gold{background:linear-gradient(180deg,var(--gold-2),var(--gold));color:#fff;box-shadow:0 6px 18px rgba(169,132,66,.32)}
.btn--gold:hover{box-shadow:0 10px 26px rgba(169,132,66,.42);color:#fff}
.btn--primary{background:var(--brand);color:#fff}
.btn--primary:hover{background:var(--brand-2);color:#fff}
.btn--ghost{background:transparent;border-color:rgba(255,255,255,.55);color:#fff}
.btn--ghost:hover{background:rgba(255,255,255,.12);color:#fff}
.btn--outline{background:#fff;border-color:var(--line);color:var(--ink)}
.btn--outline:hover{border-color:var(--brand-2);color:var(--brand-2)}
.btn--lg{padding:17px 32px;font-size:1.06rem}
.btn--block{width:100%}

/* ---------- Top bar ---------- */
.topbar{background:var(--ink);color:#cfd5e0;font-size:.86rem}
.topbar .container{display:flex;align-items:center;justify-content:space-between;height:38px;gap:16px}
.topbar a{color:#cfd5e0}
.topbar__left{display:flex;gap:18px;align-items:center}
.topbar__badge{display:inline-flex;align-items:center;gap:7px}
.dot{width:8px;height:8px;border-radius:50%;background:var(--ok);box-shadow:0 0 0 0 rgba(46,125,87,.6);animation:pulse 2.2s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(46,125,87,.55)}70%{box-shadow:0 0 0 8px rgba(46,125,87,0)}100%{box-shadow:0 0 0 0 rgba(46,125,87,0)}}
.topbar__right{display:flex;gap:18px;align-items:center}
@media(max-width:760px){.topbar__left .hide-sm{display:none}.topbar__right .hide-sm{display:none}}

/* ---------- Header ---------- */
.header{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.96);backdrop-filter:blur(8px);
  border-bottom:1px solid var(--line)}
.header .container{display:flex;align-items:center;gap:22px;height:78px}
.logo{display:flex;align-items:center;gap:12px;text-decoration:none}
.logo:hover{text-decoration:none}
.logo__mark{width:44px;height:44px;flex:0 0 auto}
.logo__txt{display:flex;flex-direction:column;line-height:1.1}
.logo__name{font-family:var(--serif);font-weight:700;font-size:1.18rem;color:var(--ink)}
.logo__sub{font-size:.72rem;letter-spacing:.06em;color:var(--muted);text-transform:uppercase}
.nav{display:flex;gap:22px;margin-left:auto}
.nav a{color:var(--ink-2);font-weight:500;font-size:.96rem;padding:6px 0;position:relative}
.nav a:hover{color:var(--brand-2);text-decoration:none}
.nav a::after{content:"";position:absolute;left:0;bottom:-2px;width:0;height:2px;background:var(--gold);transition:.2s}
.nav a:hover::after{width:100%}
.header__phone{display:flex;flex-direction:column;align-items:flex-end;line-height:1.15}
.header__phone a{font-family:var(--serif);font-weight:700;font-size:1.16rem;color:var(--ink)}
.header__phone span{font-size:.72rem;color:var(--muted)}
.header__cta{margin-left:6px}
.burger{display:none;margin-left:auto;width:46px;height:46px;border:1px solid var(--line);background:#fff;border-radius:10px;cursor:pointer;flex-direction:column;gap:5px;align-items:center;justify-content:center}
.burger span{width:22px;height:2px;background:var(--ink);border-radius:2px}
@media(max-width:1024px){
  .nav{position:fixed;inset:0 0 0 auto;width:min(320px,86vw);background:#fff;flex-direction:column;
    padding:90px 24px 24px;gap:6px;transform:translateX(100%);transition:.28s;box-shadow:var(--shadow-lg);margin:0}
  .nav.open{transform:translateX(0)}
  .nav a{padding:12px 0;border-bottom:1px solid var(--line);font-size:1.05rem;width:100%}
  .burger{display:flex}
  .header__phone,.header__cta{display:none}
}

/* ---------- Hero ---------- */
.hero{position:relative;background:linear-gradient(160deg,#1b2740 0%,#22304f 55%,#2c4267 100%);color:#eef1f7;overflow:hidden}
.hero::after{content:"";position:absolute;inset:0;background:url('../img/hero-bg.svg') right bottom/cover no-repeat;opacity:.5;pointer-events:none}
.hero .container{position:relative;z-index:2;display:grid;grid-template-columns:1.15fr .85fr;gap:48px;align-items:center;padding-top:64px;padding-bottom:64px}
.hero h1{color:#fff;margin-bottom:.4em}
.hero__sub{font-size:1.16rem;color:#c9d2e2;max-width:560px}
.hero__points{list-style:none;padding:0;margin:22px 0 28px;display:grid;gap:11px;max-width:540px}
.hero__points li{display:flex;gap:11px;align-items:flex-start;color:#dde3ee}
.hero__points svg{flex:0 0 auto;margin-top:3px}
.hero__cta{display:flex;gap:14px;flex-wrap:wrap;align-items:center}
.hero__trust{display:flex;gap:26px;margin-top:30px;flex-wrap:wrap}
.hero__trust div{line-height:1.1}
.hero__trust b{font-family:var(--serif);font-size:1.7rem;color:var(--gold-2);display:block}
.hero__trust span{font-size:.82rem;color:#aeb8cc}
@media(max-width:880px){.hero .container{grid-template-columns:1fr;gap:30px}.hero__card{order:-1}}

/* Hero callback card */
.hero__card{background:#fff;color:var(--ink);border-radius:var(--radius);box-shadow:var(--shadow-lg);padding:28px}
.hero__card h3{font-size:1.3rem;margin-bottom:4px}
.hero__card p{font-size:.92rem;color:var(--muted);margin-bottom:18px}

/* ---------- Forms ---------- */
.field{margin-bottom:14px}
.field label{display:block;font-size:.82rem;font-weight:600;color:var(--slate);margin-bottom:6px}
.field input,.field select,.field textarea{width:100%;padding:13px 15px;border:1.5px solid var(--line);border-radius:var(--radius-sm);
  font-family:var(--sans);font-size:1rem;color:var(--ink);background:#fff;transition:.15s}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--brand-2);box-shadow:0 0 0 3px rgba(44,82,130,.12)}
.form__note{font-size:.76rem;color:var(--muted);margin-top:10px}
.form__note a{color:var(--muted);text-decoration:underline}
.form__ok{display:none;background:var(--gold-soft);border:1px solid var(--gold);border-radius:var(--radius-sm);padding:16px;color:var(--ink);font-size:.95rem}
.form__ok.show{display:block}

/* ---------- Cards / grids ---------- */
.grid{display:grid;gap:24px}
.grid-2{grid-template-columns:repeat(2,1fr)}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-4{grid-template-columns:repeat(4,1fr)}
@media(max-width:980px){.grid-3,.grid-4{grid-template-columns:repeat(2,1fr)}}
@media(max-width:640px){.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}}

.card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:26px;box-shadow:var(--shadow);transition:.2s}
.card:hover{box-shadow:var(--shadow-lg);transform:translateY(-3px);border-color:#d6dbe6}
.card__icon{width:52px;height:52px;border-radius:12px;background:var(--gold-soft);display:flex;align-items:center;justify-content:center;margin-bottom:16px}
.card h3{margin-bottom:8px}
.card p{font-size:.95rem;color:var(--slate);margin-bottom:14px}
.card__link{font-weight:600;font-size:.92rem;display:inline-flex;align-items:center;gap:6px}
.card .price-from{font-family:var(--serif);color:var(--brand);font-weight:700;font-size:1.05rem}

/* service link card */
.svc{display:flex;flex-direction:column;height:100%}
.svc__top{display:flex;align-items:center;gap:14px;margin-bottom:12px}
.svc__top .card__icon{margin:0}
.svc h3{margin:0;font-size:1.12rem}
.svc p{flex:1}

/* ---------- Pricing ---------- */
.price-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
@media(max-width:980px){.price-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.price-grid{grid-template-columns:1fr}}
.plan{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:26px 24px;display:flex;flex-direction:column;position:relative;box-shadow:var(--shadow)}
.plan--featured{border:2px solid var(--gold);box-shadow:var(--shadow-lg)}
.plan__tag{position:absolute;top:-12px;left:50%;transform:translateX(-50%);background:var(--gold);color:#fff;font-size:.72rem;font-weight:600;padding:5px 14px;border-radius:20px;letter-spacing:.04em}
.plan h3{font-size:1.18rem;margin-bottom:4px}
.plan__price{font-family:var(--serif);font-size:2rem;color:var(--brand);font-weight:700;margin:8px 0 2px}
.plan__price small{font-size:.86rem;color:var(--muted);font-weight:400;font-family:var(--sans)}
.plan__desc{font-size:.88rem;color:var(--muted);margin-bottom:16px}
.plan ul{list-style:none;padding:0;margin:0 0 22px;display:grid;gap:9px;flex:1}
.plan li{display:flex;gap:9px;align-items:flex-start;font-size:.92rem;color:var(--slate)}
.plan li svg{flex:0 0 auto;margin-top:3px}

/* ---------- Steps ---------- */
.steps{counter-reset:s;display:grid;gap:18px}
.step{display:flex;gap:18px;align-items:flex-start;background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:22px 24px;box-shadow:var(--shadow)}
.step__num{counter-increment:s;flex:0 0 auto;width:44px;height:44px;border-radius:50%;background:var(--brand);color:#fff;
  font-family:var(--serif);font-weight:700;font-size:1.2rem;display:flex;align-items:center;justify-content:center}
.step__num::before{content:counter(s)}
.step h3{margin-bottom:5px;font-size:1.1rem}
.step p{margin:0;font-size:.95rem;color:var(--slate)}

/* ---------- "What to do" table ---------- */
.howto{background:#fff;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow)}
.howto__row{display:grid;grid-template-columns:54px 1fr;gap:16px;padding:18px 22px;border-bottom:1px solid var(--line);align-items:flex-start}
.howto__row:last-child{border-bottom:none}
.howto__n{width:38px;height:38px;border-radius:10px;background:var(--gold-soft);color:var(--gold);font-weight:700;font-family:var(--serif);display:flex;align-items:center;justify-content:center}
.howto__row b{display:block;margin-bottom:3px}
.howto__row p{margin:0;font-size:.93rem;color:var(--slate)}

/* ---------- Calculator ---------- */
.calc{display:grid;grid-template-columns:1.4fr .9fr;gap:30px;background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:30px;box-shadow:var(--shadow)}
@media(max-width:840px){.calc{grid-template-columns:1fr}}
.calc__opt{margin-bottom:20px}
.calc__opt>b{display:block;margin-bottom:10px;font-size:.95rem}
.chips{display:flex;flex-wrap:wrap;gap:10px}
.chip{border:1.5px solid var(--line);background:#fff;border-radius:30px;padding:9px 16px;font-size:.9rem;cursor:pointer;transition:.15s;user-select:none}
.chip:hover{border-color:var(--brand-2)}
.chip.active{background:var(--brand);border-color:var(--brand);color:#fff}
.calc__add{display:flex;flex-wrap:wrap;gap:12px;margin-top:6px}
.calc__add label{display:flex;align-items:center;gap:8px;font-size:.9rem;cursor:pointer;background:var(--bg-soft);padding:9px 14px;border-radius:10px;border:1px solid var(--line)}
.calc__result{background:var(--ink);color:#fff;border-radius:var(--radius);padding:26px;display:flex;flex-direction:column;justify-content:center}
.calc__result .small{font-size:.82rem;color:#aab3c6;letter-spacing:.04em;text-transform:uppercase}
.calc__sum{font-family:var(--serif);font-size:2.6rem;color:var(--gold-2);font-weight:700;margin:6px 0 2px}
.calc__hint{font-size:.84rem;color:#aab3c6;margin-bottom:18px}

/* ---------- Reviews ---------- */
.review{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:24px;box-shadow:var(--shadow)}
.review__stars{color:var(--gold-2);letter-spacing:2px;margin-bottom:10px;font-size:1rem}
.review p{font-size:.95rem;color:var(--slate);font-style:italic}
.review__who{display:flex;align-items:center;gap:12px;margin-top:14px}
.review__ava{width:42px;height:42px;border-radius:50%;background:var(--brand);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-family:var(--serif)}
.review__who b{display:block;font-size:.92rem}
.review__who span{font-size:.8rem;color:var(--muted)}

/* ---------- Trust / advantages ---------- */
.adv{display:flex;gap:16px;align-items:flex-start}
.adv__ic{flex:0 0 auto;width:48px;height:48px;border-radius:12px;background:var(--bg-soft-2);display:flex;align-items:center;justify-content:center}
.adv h3{font-size:1.06rem;margin-bottom:4px}
.adv p{font-size:.92rem;color:var(--slate);margin:0}

/* ---------- Warning block (чёрные агенты) ---------- */
.warn{background:#fbf3f0;border:1px solid #e9cfc6;border-left:5px solid var(--danger);border-radius:var(--radius);padding:26px 28px}
.warn h3{color:var(--danger);display:flex;align-items:center;gap:10px}
.warn ul{margin:10px 0 0;padding-left:20px;color:var(--slate)}
.warn li{margin-bottom:6px}

/* ---------- FAQ ---------- */
.faq{max-width:840px;margin:0 auto}
.faq__item{background:#fff;border:1px solid var(--line);border-radius:var(--radius-sm);margin-bottom:12px;overflow:hidden}
.faq__q{width:100%;text-align:left;background:none;border:none;padding:18px 22px;font-family:var(--serif);font-weight:700;font-size:1.05rem;color:var(--ink);cursor:pointer;display:flex;justify-content:space-between;gap:16px;align-items:center}
.faq__q::after{content:"+";font-family:var(--sans);font-size:1.5rem;color:var(--gold);transition:.2s;flex:0 0 auto}
.faq__item.open .faq__q::after{transform:rotate(45deg)}
.faq__a{max-height:0;overflow:hidden;transition:max-height .3s ease;padding:0 22px}
.faq__item.open .faq__a{max-height:600px;padding-bottom:18px}
.faq__a p{margin:0;color:var(--slate);font-size:.96rem}

/* ---------- Info / requisites lists ---------- */
.deflist{display:grid;grid-template-columns:repeat(2,1fr);gap:14px 30px}
@media(max-width:640px){.deflist{grid-template-columns:1fr}}
.deflist div{border-bottom:1px dashed var(--line);padding-bottom:10px}
.deflist dt{font-size:.8rem;color:var(--muted);text-transform:uppercase;letter-spacing:.04em}
.deflist dd{margin:2px 0 0;font-weight:600;color:var(--ink)}

/* places (морги/кладбища) */
.place{display:flex;gap:14px;background:#fff;border:1px solid var(--line);border-radius:var(--radius-sm);padding:18px;box-shadow:var(--shadow)}
.place__ic{flex:0 0 auto;color:var(--gold)}
.place b{display:block}
.place span{font-size:.9rem;color:var(--slate)}

/* ---------- CTA band ---------- */
.cta-band{background:linear-gradient(160deg,#1f3a5f,#2c5282);color:#fff;border-radius:var(--radius);padding:42px;text-align:center;box-shadow:var(--shadow-lg)}
.cta-band h2{color:#fff}
.cta-band p{color:#cdd7e8;max-width:560px;margin:0 auto 24px}
.cta-band .btn--ghost{border-color:rgba(255,255,255,.6)}

/* ---------- Breadcrumbs ---------- */
.crumbs{font-size:.85rem;color:var(--muted);padding:16px 0}
.crumbs a{color:var(--muted)}
.crumbs span{color:var(--ink-2)}

/* page hero (inner) */
.pagehero{background:linear-gradient(160deg,#1b2740,#28395a);color:#fff;padding:46px 0 54px}
.pagehero h1{color:#fff;max-width:820px}
.pagehero p{color:#c9d2e2;max-width:680px;font-size:1.1rem;margin-bottom:0}
.pagehero .btn{margin-top:22px}

/* prose */
.prose h2{margin-top:1.4em}
.prose h3{margin-top:1.2em}
.prose ul{padding-left:20px}
.prose li{margin-bottom:8px}
.prose table{width:100%;border-collapse:collapse;margin:18px 0;font-size:.95rem}
.prose th,.prose td{border:1px solid var(--line);padding:11px 14px;text-align:left}
.prose th{background:var(--bg-soft);font-family:var(--sans)}

/* ---------- Footer ---------- */
.footer{background:var(--ink);color:#aab3c6;padding:54px 0 24px;font-size:.92rem}
.footer a{color:#c4ccda}
.footer__grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.1fr;gap:34px;margin-bottom:34px}
@media(max-width:880px){.footer__grid{grid-template-columns:1fr 1fr}}
@media(max-width:520px){.footer__grid{grid-template-columns:1fr}}
.footer h4{color:#fff;font-family:var(--sans);font-size:.82rem;letter-spacing:.1em;text-transform:uppercase;margin-bottom:16px}
.footer ul{list-style:none;padding:0;margin:0;display:grid;gap:9px}
.footer__phone{font-family:var(--serif);font-size:1.4rem;color:#fff;font-weight:700}
.footer__req{font-size:.82rem;line-height:1.7;color:#8d97aa}
.footer__bottom{border-top:1px solid #313a4d;padding-top:20px;display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;font-size:.82rem;color:#7f889b}

/* ---------- Sticky mobile bar ---------- */
.mobar{position:fixed;left:0;right:0;bottom:0;z-index:60;display:none;background:#fff;border-top:1px solid var(--line);
  box-shadow:0 -6px 24px rgba(29,35,48,.12);padding:9px 12px;gap:10px}
.mobar a{flex:1;display:flex;align-items:center;justify-content:center;gap:8px;padding:13px;border-radius:10px;font-weight:600;font-size:.95rem}
.mobar__call{background:var(--brand);color:#fff}
.mobar__call:hover{color:#fff;text-decoration:none}
.mobar__cb{background:var(--gold-soft);color:var(--gold);border:1px solid var(--gold)}
.mobar__cb:hover{text-decoration:none}
@media(max-width:760px){.mobar{display:flex}body{padding-bottom:70px}}

/* ---------- Modal ---------- */
.modal{position:fixed;inset:0;z-index:100;display:none;align-items:center;justify-content:center;padding:20px;background:rgba(20,25,36,.6)}
.modal.open{display:flex}
.modal__box{background:#fff;border-radius:var(--radius);padding:30px;max-width:440px;width:100%;box-shadow:var(--shadow-lg);position:relative}
.modal__close{position:absolute;top:14px;right:16px;background:none;border:none;font-size:1.6rem;color:var(--muted);cursor:pointer;line-height:1}
.modal h3{margin-bottom:4px}
.modal p{color:var(--muted);font-size:.92rem;margin-bottom:18px}

/* utilities */
.mt0{margin-top:0}.mb0{margin-bottom:0}.tac{text-align:center}
.badges{display:flex;gap:14px;flex-wrap:wrap;align-items:center}
.badge{display:inline-flex;align-items:center;gap:8px;background:#fff;border:1px solid var(--line);border-radius:30px;padding:8px 15px;font-size:.84rem;font-weight:600;color:var(--slate);box-shadow:var(--shadow)}
.badge svg{color:var(--gold)}
.hl{color:var(--gold)}
.divider{height:1px;background:var(--line);margin:0}
