/* ============================================================
   1UZ — shared styles for Услуги / Лояльность / О нас
   (extends styles.css)
   ============================================================ */

/* generic page hero */
.ph{ position:relative; overflow:hidden; padding-top:calc(var(--nav-h) + 64px); padding-bottom:56px; }
.ph .wrap{ position:relative; z-index:2; }
.ph .crumbs{ display:flex; gap:8px; align-items:center; font-size:14px; color:var(--muted); font-weight:600; margin-bottom:14px; }
.ph .crumbs a:hover{ color:var(--c-blue); }
.ph h1{ font-size:clamp(40px,5.4vw,68px); max-width:880px; margin-top:14px; }
.ph h1 .gradient-text{ display:inline; }
.ph .lead{ font-size:clamp(17px,1.6vw,20px); color:var(--ink-soft); max-width:600px; margin-top:22px; }
.ph .cta-row{ display:flex; flex-wrap:wrap; gap:13px; margin-top:32px; }
.ph.dark{ background:var(--grad-hero); }
.ph.dark h1, .ph.dark .crumbs{ color:#fff; }
.ph.dark .crumbs a{ color:rgba(255,255,255,.7); }
.ph.dark .lead{ color:rgba(255,255,255,.85); }
.ph.dark .eyebrow{ color:#fff; }

/* big stat row */
.stat-row{ display:grid; grid-template-columns:repeat(4,1fr); gap:24px; }
.stat-row.three{ grid-template-columns:repeat(3,1fr); }
.stat-box{ background:var(--surface); border:1px solid var(--line); border-radius:var(--r-lg); padding:34px 30px; }
.stat-box b{ font-family:var(--font-display); font-weight:800; font-size:clamp(38px,5vw,56px); letter-spacing:-.03em; line-height:1; display:block; }
.stat-box span{ color:var(--muted); font-size:15.5px; margin-top:12px; display:block; line-height:1.4; }

/* service / generic card grid */
.scards{ display:grid; grid-template-columns:repeat(3,1fr); gap:22px; }
.scard{ position:relative; background:var(--surface); border:1px solid var(--line); border-radius:var(--r-lg); padding:34px; transition:transform .25s, box-shadow .25s, border-color .25s; overflow:hidden; display:flex; flex-direction:column; }
.scard:hover{ transform:translateY(-6px); box-shadow:var(--sh); border-color:transparent; }
.scard .ic{ width:58px; height:58px; border-radius:16px; display:grid; place-items:center; color:#fff; margin-bottom:22px; flex:none; }
.scard h3{ font-size:21px; }
.scard p{ color:var(--muted); font-size:15px; margin-top:10px; line-height:1.5; flex:1; }
.scard .slist{ margin-top:18px; display:grid; gap:9px; }
.scard .slist li{ display:flex; gap:10px; font-size:14px; color:var(--ink-soft); align-items:flex-start; line-height:1.4; }
.scard .slist .dot{ width:6px; height:6px; border-radius:50%; background:var(--grad-brand); margin-top:7px; flex:none; }
.scard .slink{ margin-top:22px; font-family:var(--font-display); font-weight:700; font-size:14.5px; color:var(--c-blue); display:inline-flex; align-items:center; gap:6px; cursor:pointer; }
.scard .slink svg{ transition:transform .2s; } .scard:hover .slink svg{ transform:translateX(4px); }
.scard .num{ position:absolute; top:26px; right:30px; font-family:var(--font-display); font-weight:800; font-size:46px; color:var(--bg-2); line-height:1; z-index:0; }

/* steps / process */
.steps{ display:grid; grid-template-columns:repeat(4,1fr); gap:22px; counter-reset:step; }
.step{ position:relative; padding-top:18px; }
.step::before{ counter-increment:step; content:counter(step); font-family:var(--font-display); font-weight:800; font-size:18px; width:46px; height:46px; border-radius:14px; background:var(--grad-brand); color:#fff; display:grid; place-items:center; box-shadow:var(--sh-blue); }
.step h3{ font-size:19px; margin-top:20px; }
.step p{ color:var(--muted); font-size:15px; margin-top:9px; line-height:1.5; }
.step-line{ position:relative; }

/* split feature (image + copy) */
.split{ display:grid; grid-template-columns:1fr 1fr; gap:56px; align-items:center; }
.split.flip .split-media{ order:-1; }
.split h2{ font-size:clamp(26px,3.2vw,40px); }
.split .lead2{ color:var(--muted); font-size:17px; margin-top:18px; }
.split .flist{ margin-top:24px; display:grid; gap:14px; }
.split .flist li{ display:flex; gap:13px; font-size:16px; color:var(--ink-soft); align-items:flex-start; }
.split .flist .tick{ width:24px; height:24px; border-radius:8px; background:var(--grad-brand); color:#fff; flex:none; display:grid; place-items:center; margin-top:1px; }
.split-card{ background:var(--surface); border:1px solid var(--line); border-radius:var(--r-xl); box-shadow:var(--sh); padding:40px; }

/* value tiles (about) */
.values{ display:grid; grid-template-columns:repeat(3,1fr); gap:22px; }
.value{ padding:30px; border-radius:var(--r-lg); background:var(--surface); border:1px solid var(--line); }
.value .ic{ width:50px; height:50px; border-radius:14px; display:grid; place-items:center; color:#fff; margin-bottom:18px; }
.value h3{ font-size:19px; } .value p{ color:var(--muted); font-size:15px; margin-top:9px; line-height:1.5; }

/* loyalty tiers */
.tiers{ display:grid; grid-template-columns:repeat(3,1fr); gap:22px; align-items:stretch; }
.tier{ position:relative; background:var(--surface); border:1px solid var(--line); border-radius:var(--r-xl); padding:36px 32px; transition:transform .25s, box-shadow .25s; display:flex; flex-direction:column; }
.tier:hover{ transform:translateY(-6px); box-shadow:var(--sh); }
.tier.mid{ background:var(--grad-hero); color:#fff; border:none; box-shadow:var(--sh-lg); }
.tier .tname{ font-family:var(--font-display); font-weight:700; font-size:20px; }
.tier .tpct{ font-family:var(--font-display); font-weight:800; font-size:clamp(44px,5vw,60px); letter-spacing:-.03em; margin:10px 0 4px; }
.tier .tpct .gradient-text{ display:inline; }
.tier .tdesc{ color:var(--muted); font-size:15px; } .tier.mid .tdesc{ color:rgba(255,255,255,.8); }
.tier ul{ margin:24px 0 0; display:grid; gap:12px; border-top:1px solid var(--line); padding-top:24px; }
.tier.mid ul{ border-color:rgba(255,255,255,.2); }
.tier li{ display:flex; gap:11px; font-size:15px; color:var(--ink-soft); align-items:flex-start; } .tier.mid li{ color:rgba(255,255,255,.92); }
.tier .star{ color:var(--c-violet); flex:none; } .tier.mid .star{ color:#fff; }

/* contact band */
.contact-band{ display:grid; grid-template-columns:repeat(3,1fr); gap:22px; }
.cbox{ background:var(--surface); border:1px solid var(--line); border-radius:var(--r-lg); padding:30px; display:flex; gap:18px; align-items:flex-start; }
.cbox .ic{ width:50px; height:50px; border-radius:14px; display:grid; place-items:center; color:#fff; flex:none; }
.cbox .lbl{ font-size:13px; color:var(--muted); font-weight:600; }
.cbox b{ font-family:var(--font-display); font-size:18px; display:block; margin-top:4px; }
.cbox a:hover{ color:var(--c-blue); }

@media (max-width:1080px){
  .stat-row, .stat-row.three{ grid-template-columns:repeat(2,1fr); }
  .scards{ grid-template-columns:repeat(2,1fr); }
  .steps{ grid-template-columns:repeat(2,1fr); }
  .split{ grid-template-columns:1fr; gap:32px; }
  .split.flip .split-media{ order:0; }
  .values, .tiers, .contact-band{ grid-template-columns:1fr 1fr; }
}
@media (max-width:680px){
  .stat-row, .stat-row.three, .scards, .steps, .values, .tiers, .contact-band{ grid-template-columns:1fr; }
  .tier.mid{ transform:none; }
}
