/* ==========================================================================
   СТО Донецк — основные стили
   Тема: индустриальная, тёмная. Гамма: чёрный + красный.
   Шрифты: Oswald (заголовки) + Golos Text (текст)
   ========================================================================== */

:root{
    --bg:        #15171A;
    --bg-2:      #1B1E22;
    --bg-3:      #24262B;
    --card:      #1E2125;
    --card-hi:   #25282D;
    --accent:    #E23B3B;
    --accent-2:  #C42E2E;
    --accent-sh: rgba(226, 59, 59, .35);
    --light:     #F3F3F4;
    --light-2:   #E7E7E9;
    --text:      #ECECEE;
    --text-mut:  #9A9CA1;
    --text-dim:  #6E7177;
    --on-light:  #101114;
    --on-light-mut: #55585F;
    --border:    rgba(255,255,255,.08);
    --border-2:  rgba(255,255,255,.16);
    --radius:    6px;
    --maxw:      1180px;
    --head:      'Oswald', 'Arial Narrow', sans-serif;
    --body:      'Golos Text', 'Segoe UI', sans-serif;
}

*{ box-sizing:border-box; margin:0; padding:0; }

html{ scroll-behavior:smooth; }

body{
    font-family:var(--body);
    background:var(--bg);
    color:var(--text);
    font-size:16px;
    line-height:1.7;
    -webkit-font-smoothing:antialiased;
    overflow-x:hidden;
}

a{ color:inherit; text-decoration:none; }
img{ max-width:100%; display:block; }
ul{ list-style:none; }

h1,h2,h3,h4{
    font-family:var(--head);
    font-weight:600;
    line-height:1.15;
    text-transform:uppercase;
    letter-spacing:.02em;
}

section{ scroll-margin-top:78px; }

/* ---------- Утилиты ---------------------------------------------------- */
.container-x{ max-width:var(--maxw); margin:0 auto; padding:0 22px; }
.section{ padding:84px 0; position:relative; }
.section--alt{ background:var(--bg-2); }
.section--light{ background:var(--light); color:var(--on-light); }

.eyebrow{
    display:inline-flex; align-items:center; gap:9px;
    font-family:var(--head); font-weight:500; font-size:.82rem;
    text-transform:uppercase; letter-spacing:.18em;
    color:var(--accent); margin-bottom:14px;
}
.eyebrow::before{
    content:""; width:30px; height:2px; background:var(--accent); display:block;
}
.section-title{
    font-size:clamp(1.9rem, 4vw, 2.9rem);
    margin-bottom:14px;
}
.section-title span{ color:var(--accent); }
.section-lead{
    color:var(--text-mut); max-width:620px; font-size:1.03rem;
}
.section--light .section-lead{ color:var(--on-light-mut); }
.section-head{ margin-bottom:50px; }

/* Декоративная «индустриальная» полоса */
.hazard{
    height:8px; width:100%;
    background:repeating-linear-gradient(45deg,
        var(--accent) 0 22px, #15171A 22px 44px);
    opacity:.9;
}

/* ---------- Кнопки ----------------------------------------------------- */
.btn-x{
    display:inline-flex; align-items:center; justify-content:center; gap:10px;
    font-family:var(--head); font-weight:500; font-size:.95rem;
    text-transform:uppercase; letter-spacing:.06em;
    padding:15px 30px; border-radius:var(--radius);
    border:2px solid transparent; cursor:pointer;
    transition:transform .15s ease, background .2s ease, box-shadow .2s ease, color .2s ease;
    white-space:nowrap;
}
.btn-accent{
    background:var(--accent); color:#fff;
    box-shadow:0 8px 24px -8px var(--accent-sh);
}
.btn-accent:hover{ background:var(--accent-2); transform:translateY(-2px);
    box-shadow:0 12px 30px -8px var(--accent-sh); color:#fff; }
.btn-ghost{
    background:transparent; color:var(--text); border-color:var(--border-2);
}
.btn-ghost:hover{ border-color:var(--accent); color:#fff; transform:translateY(-2px); }
.btn-x:active{ transform:translateY(0) scale(.98); }
.btn-sm{ padding:11px 22px; font-size:.85rem; }

/* ---------- Шапка ------------------------------------------------------ */
.navbar-x{
    position:fixed; top:0; left:0; right:0; z-index:1030;
    background:rgba(21,23,26,.96);
    border-bottom:1px solid var(--border);
    transition:padding .25s ease, background .25s ease;
    backdrop-filter:blur(8px);
}
.navbar-x.scrolled{ padding-block:0; background:rgba(18,20,22,.99); }
.navbar-inner{
    display:flex; align-items:center; justify-content:space-between;
    height:74px; transition:height .25s ease;
}
.navbar-x.scrolled .navbar-inner{ height:62px; }

.logo{ display:flex; align-items:center; gap:11px; font-family:var(--head); }
.logo-mark{
    width:42px; height:42px; border-radius:8px;
    background:var(--accent); color:#fff;
    display:grid; place-items:center; font-size:1.2rem;
    box-shadow:0 6px 18px -6px var(--accent-sh);
    flex-shrink:0;
}
.logo-text{ line-height:1; }
.logo-text b{
    display:block; font-size:1.32rem; font-weight:700;
    text-transform:uppercase; letter-spacing:.04em;
}
.logo-text b i{ color:var(--accent); font-style:normal; }
.logo-text span{
    display:block; font-family:var(--body); font-size:.68rem;
    color:var(--text-mut); text-transform:uppercase; letter-spacing:.22em;
    margin-top:3px;
}

.nav-links{ display:flex; align-items:center; gap:30px; }
.nav-links a{
    font-family:var(--head); font-weight:500; font-size:.93rem;
    text-transform:uppercase; letter-spacing:.04em; color:var(--text-mut);
    position:relative; padding:6px 0; transition:color .2s ease;
}
.nav-links a::after{
    content:""; position:absolute; left:0; bottom:0; height:2px; width:0;
    background:var(--accent); transition:width .25s ease;
}
.nav-links a:hover, .nav-links a.active{ color:#fff; }
.nav-links a:hover::after, .nav-links a.active::after{ width:100%; }

.nav-side{ display:flex; align-items:center; gap:20px; }
.nav-phone{
    font-family:var(--head); font-weight:600; font-size:1.12rem;
    display:flex; align-items:center; gap:9px; white-space:nowrap;
}
.nav-phone i{ color:var(--accent); }
.nav-phone:hover{ color:var(--accent); }

.burger{
    display:none; background:none; border:1px solid var(--border-2);
    border-radius:var(--radius); width:46px; height:46px; color:#fff;
    font-size:1.25rem; cursor:pointer;
}

/* ---------- Hero ------------------------------------------------------- */
.hero{
    position:relative; padding:160px 0 96px;
    background:
        radial-gradient(900px 460px at 78% 8%, rgba(226,59,59,.16), transparent 70%),
        linear-gradient(180deg, #16181C 0%, #121316 100%);
    overflow:hidden;
}
.hero::before{
    content:""; position:absolute; inset:0;
    background-image:
        linear-gradient(rgba(255,255,255,.025) 1px, transparent 1px),
        linear-gradient(90deg, rgba(255,255,255,.025) 1px, transparent 1px);
    background-size:54px 54px;
    -webkit-mask-image:radial-gradient(circle at 60% 35%, #000 0%, transparent 78%);
            mask-image:radial-gradient(circle at 60% 35%, #000 0%, transparent 78%);
}
.hero::after{
    content:""; position:absolute; right:-130px; top:-130px;
    width:380px; height:380px; border-radius:50%;
    border:2px dashed rgba(226,59,59,.25);
    animation:spin 60s linear infinite;
}
@keyframes spin{ to{ transform:rotate(360deg); } }

.hero-inner{ position:relative; max-width:760px; }
.hero h1{
    font-size:clamp(2.4rem, 6vw, 4.1rem);
    margin:18px 0 22px;
}
.hero h1 span{ color:var(--accent); }
.hero-lead{
    font-size:1.13rem; color:var(--text-mut); max-width:600px; margin-bottom:32px;
}
.hero-cta{ display:flex; flex-wrap:wrap; gap:15px; margin-bottom:38px; }
.hero-chips{ display:flex; flex-wrap:wrap; gap:12px; }
.chip{
    display:inline-flex; align-items:center; gap:9px;
    background:var(--card); border:1px solid var(--border);
    border-radius:50px; padding:9px 18px; font-size:.9rem;
}
.chip i{ color:var(--accent); }

/* ---------- Сетка карточек -------------------------------------------- */
.grid{
    display:grid; gap:22px;
    grid-template-columns:repeat(auto-fit, minmax(260px, 1fr));
}
.services-grid{
    display:grid; gap:22px;
    grid-template-columns:repeat(3, 1fr);
}

.card-x{
    background:var(--card); border:1px solid var(--border);
    border-radius:var(--radius); padding:32px 26px;
    transition:transform .2s ease, border-color .2s ease, background .2s ease;
    position:relative; overflow:hidden;
    display:flex; flex-direction:column;
}
.card-x::before{
    content:""; position:absolute; left:0; top:0; width:3px; height:0;
    background:var(--accent); transition:height .25s ease;
}
.card-x:hover{
    transform:translateY(-6px); border-color:var(--border-2);
    background:var(--card-hi);
}
.card-x:hover::before{ height:100%; }

.card-ico{
    width:58px; height:58px; border-radius:10px;
    background:rgba(226,59,59,.12); color:var(--accent);
    display:grid; place-items:center; font-size:1.5rem; margin-bottom:20px;
    transition:background .2s ease, color .2s ease;
}
.card-x:hover .card-ico{ background:var(--accent); color:#fff; }
.card-x h3{ font-size:1.2rem; margin-bottom:10px; }
.card-x p{ color:var(--text-mut); font-size:.96rem; flex-grow:1; margin-bottom:18px; }

.card-more{
    background:transparent; border:none; padding:0; cursor:pointer;
    color:var(--accent); font-family:var(--head); font-weight:500;
    font-size:.84rem; text-transform:uppercase; letter-spacing:.05em;
    display:inline-flex; align-items:center; gap:9px;
    align-self:flex-start;
    transition:gap .2s ease, color .2s ease;
}
.card-more:hover{ gap:14px; color:#fff; }
.card-more i{ font-size:.82em; }

/* ---------- Преимущества ---------------------------------------------- */
.adv{ display:flex; gap:18px; align-items:flex-start; }
.adv-ico{
    flex-shrink:0; width:52px; height:52px; border-radius:8px;
    background:var(--bg-3); color:var(--accent);
    display:grid; place-items:center; font-size:1.3rem;
    border:1px solid var(--border);
}
.adv h3{ font-size:1.1rem; margin-bottom:6px; }
.adv p{ color:var(--text-mut); font-size:.94rem; }

/* ---------- Как мы работаем ------------------------------------------- */
.steps{
    display:grid; gap:24px;
    grid-template-columns:repeat(auto-fit, minmax(220px, 1fr));
}
.step{
    background:var(--card); border:1px solid var(--border);
    border-radius:var(--radius); padding:32px 26px 28px; position:relative;
}
.step-num{
    font-family:var(--head); font-weight:700; font-size:3.2rem;
    color:var(--accent); line-height:.9;
    -webkit-text-stroke:1px var(--accent); color:transparent;
    opacity:.7; margin-bottom:14px;
}
.step-ico{ color:var(--accent); font-size:1.35rem; margin-bottom:12px; }
.step h3{ font-size:1.12rem; margin-bottom:8px; }
.step p{ color:var(--text-mut); font-size:.94rem; }

/* ---------- Цены (светлая секция) ------------------------------------- */
.price-wrap{
    background:#fff; border-radius:var(--radius); overflow:hidden;
    border:1px solid var(--light-2);
}
.price-table{ width:100%; border-collapse:collapse; }
.price-table th{
    background:var(--bg); color:#fff; font-family:var(--head);
    text-transform:uppercase; letter-spacing:.05em; font-weight:500;
    font-size:.92rem; text-align:left; padding:16px 24px;
}
.price-table th:last-child{ text-align:right; }
.price-table td{
    padding:15px 24px; border-bottom:1px solid var(--light-2);
    font-size:.98rem;
}
.price-table tr:last-child td{ border-bottom:none; }
.price-table tbody tr{ transition:background .15s ease; }
.price-table tbody tr:hover{ background:#FAFAFA; }
.price-table td:last-child{
    text-align:right; font-family:var(--head); font-weight:600;
    font-size:1.05rem; color:var(--accent); white-space:nowrap;
}
.price-note{
    margin-top:18px; font-size:.9rem; color:var(--on-light-mut);
    display:flex; align-items:center; gap:9px;
}
.price-note i{ color:var(--accent); }

/* ---------- Отзывы ----------------------------------------------------- */
.review{
    background:var(--card); border:1px solid var(--border);
    border-radius:var(--radius); padding:30px 26px;
    display:flex; flex-direction:column; gap:16px; height:100%;
}
.stars{ color:var(--accent); font-size:.95rem; letter-spacing:2px; }
.review p{ color:var(--text); font-size:.98rem; flex-grow:1; }
.review-author{ display:flex; align-items:center; gap:13px; }
.review-ava{
    width:46px; height:46px; border-radius:50%;
    background:var(--accent); color:#fff; display:grid; place-items:center;
    font-family:var(--head); font-weight:600; font-size:1.1rem;
}
.review-author b{ font-family:var(--head); font-weight:500; font-size:1.02rem;
    text-transform:uppercase; letter-spacing:.03em; }
.review-author span{ display:block; color:var(--text-dim); font-size:.84rem; }

/* ---------- FAQ (аккордеон Bootstrap, переопределение) ---------------- */
.accordion{
    --bs-accordion-bg:transparent;
    --bs-accordion-color:var(--text);
    --bs-accordion-border-color:var(--border);
    --bs-accordion-border-radius:var(--radius);
    --bs-accordion-btn-color:var(--text);
    --bs-accordion-btn-bg:var(--card);
    --bs-accordion-active-color:#fff;
    --bs-accordion-active-bg:var(--card-hi);
    --bs-accordion-btn-focus-box-shadow:0 0 0 3px var(--accent-sh);
    --bs-accordion-btn-padding-y:1.15rem;
    --bs-accordion-btn-padding-x:1.5rem;
    --bs-accordion-body-padding-y:1.2rem;
    --bs-accordion-body-padding-x:1.5rem;
    max-width:820px;
}
.accordion-item{ margin-bottom:12px; overflow:hidden; }
.accordion-button{
    font-family:var(--head); font-weight:500; font-size:1.06rem;
    text-transform:uppercase; letter-spacing:.02em;
}
.accordion-button:not(.collapsed){ box-shadow:none; }
.accordion-button::after{
    background-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='%23E23B3B'%3e%3cpath d='M3.2 5.3a1 1 0 0 1 1.4 0L8 8.7l3.4-3.4a1 1 0 1 1 1.4 1.4l-4.1 4.1a1 1 0 0 1-1.4 0L3.2 6.7a1 1 0 0 1 0-1.4z'/%3e%3c/svg%3e");
}
.accordion-body{ color:var(--text-mut); }

/* ---------- Контакты + форма ------------------------------------------ */
.contacts-grid{
    display:grid; gap:30px;
    grid-template-columns:1.05fr 1fr;
    align-items:start;
}
.info-list{ display:flex; flex-direction:column; gap:20px; margin-bottom:30px; }
.info-row{ display:flex; gap:16px; align-items:flex-start; }
.info-ico{
    width:48px; height:48px; flex-shrink:0; border-radius:8px;
    background:var(--bg-3); border:1px solid var(--border);
    color:var(--accent); display:grid; place-items:center; font-size:1.15rem;
}
.info-row .lbl{ font-size:.8rem; text-transform:uppercase;
    letter-spacing:.14em; color:var(--text-dim); }
.info-row .val{ font-family:var(--head); font-weight:500; font-size:1.15rem; }
.info-row .val a:hover{ color:var(--accent); }

.form-card{
    background:var(--card); border:1px solid var(--border);
    border-radius:var(--radius); padding:34px 30px;
}
.form-card h3{ font-size:1.4rem; margin-bottom:6px; }
.form-card .sub{ color:var(--text-mut); font-size:.94rem; margin-bottom:24px; }
.field{ margin-bottom:16px; }
.field label{
    display:block; font-size:.86rem; margin-bottom:7px; color:var(--text-mut);
}
.field label .req{ color:var(--accent); }
.field input, .field textarea{
    width:100%; background:var(--bg); color:var(--text);
    border:1px solid var(--border-2); border-radius:var(--radius);
    padding:13px 15px; font-family:var(--body); font-size:.98rem;
    transition:border-color .2s ease, box-shadow .2s ease;
}
.field textarea{ resize:vertical; min-height:96px; }
.field input:focus, .field textarea:focus{
    outline:none; border-color:var(--accent);
    box-shadow:0 0 0 3px var(--accent-sh);
}
.field input.invalid, .field textarea.invalid{ border-color:var(--accent); }
.hp{ position:absolute; left:-9999px; width:1px; height:1px; opacity:0; }

.consent{
    display:flex; gap:11px; align-items:flex-start;
    font-size:.84rem; color:var(--text-mut); margin:6px 0 20px;
}
.consent input{
    width:18px; height:18px; flex-shrink:0; margin-top:2px;
    accent-color:var(--accent); cursor:pointer;
}
.consent a{ color:var(--accent); text-decoration:underline; }
.form-card .btn-x{ width:100%; }

.form-msg{
    display:none; margin-top:16px; padding:13px 16px;
    border-radius:var(--radius); font-size:.93rem;
}
.form-msg.ok{ display:block; background:rgba(46,160,86,.14);
    border:1px solid rgba(46,160,86,.4); color:#7ad99a; }
.form-msg.err{ display:block; background:rgba(226,59,59,.12);
    border:1px solid var(--accent-sh); color:#f0908f; }

.map-wrap{
    border-radius:var(--radius); overflow:hidden;
    border:1px solid var(--border); margin-top:30px; min-height:340px;
}
.map-wrap iframe{ width:100%; height:380px; border:0; display:block;
    filter:grayscale(.25) contrast(1.05); }

/* ---------- Подвал ----------------------------------------------------- */
.footer{ background:#101113; border-top:1px solid var(--border);
    padding:60px 0 28px; }
.footer-grid{
    display:grid; gap:36px;
    grid-template-columns:1.4fr 1fr 1.2fr;
    margin-bottom:42px;
}
.footer p{ color:var(--text-mut); font-size:.94rem; margin-top:16px;
    max-width:330px; }
.footer h4{ font-size:1.05rem; margin-bottom:18px; color:#fff; }
.footer-links{ display:flex; flex-direction:column; gap:10px; }
.footer-links a{ color:var(--text-mut); font-size:.95rem; transition:color .2s; }
.footer-links a:hover{ color:var(--accent); }
.footer-contact{ display:flex; flex-direction:column; gap:12px; }
.footer-contact a, .footer-contact span{ color:var(--text-mut); font-size:.95rem;
    display:flex; gap:10px; align-items:flex-start; }
.footer-contact i{ color:var(--accent); width:18px; }
.footer-contact a:hover{ color:var(--accent); }
.requisites{
    border-top:1px solid var(--border); border-bottom:1px solid var(--border);
    padding:20px 0; margin-bottom:24px;
    font-size:.85rem; color:var(--text-dim); line-height:1.8;
}
.footer-bottom{
    display:flex; justify-content:space-between; gap:14px; flex-wrap:wrap;
    font-size:.85rem; color:var(--text-dim);
}
.footer-bottom a{ color:var(--text-mut); }
.footer-bottom a:hover{ color:var(--accent); }

/* ---------- Cookie-баннер --------------------------------------------- */
.cookie{
    position:fixed; left:18px; right:18px; bottom:18px; z-index:1080;
    background:var(--card-hi); border:1px solid var(--border-2);
    border-radius:var(--radius); padding:20px 24px;
    display:none; align-items:center; gap:22px;
    box-shadow:0 18px 50px -12px rgba(0,0,0,.7);
    max-width:760px; margin:0 auto;
}
.cookie.show{ display:flex; animation:cookieUp .4s ease; }
@keyframes cookieUp{ from{ transform:translateY(30px); opacity:0; } }
.cookie p{ font-size:.9rem; color:var(--text-mut); flex-grow:1; }
.cookie p a{ color:var(--accent); text-decoration:underline; }
.cookie .btn-x{ flex-shrink:0; }

/* ---------- Кнопка «наверх» + плавающий звонок ------------------------ */
.to-top{
    position:fixed; right:22px; bottom:22px; z-index:1040;
    width:50px; height:50px; border-radius:50%;
    background:var(--accent); color:#fff; border:none; cursor:pointer;
    font-size:1.1rem; display:grid; place-items:center;
    opacity:0; visibility:hidden; transform:translateY(16px);
    transition:all .25s ease; box-shadow:0 10px 26px -8px var(--accent-sh);
}
.to-top.show{ opacity:1; visibility:visible; transform:translateY(0); }
.to-top:hover{ background:var(--accent-2); }

.call-fab{
    display:none;
    position:fixed; left:22px; bottom:22px; z-index:1040;
    width:56px; height:56px; border-radius:50%;
    background:var(--accent); color:#fff; place-items:center;
    font-size:1.3rem; box-shadow:0 10px 26px -6px var(--accent-sh);
    animation:pulse 2.4s ease-in-out infinite;
}
@keyframes pulse{
    0%,100%{ box-shadow:0 0 0 0 var(--accent-sh); }
    50%{ box-shadow:0 0 0 14px rgba(226,59,59,0); }
}

/* ---------- Документы ------------------------------------------------- */
.docs-grid{
    display:grid; gap:18px;
    grid-template-columns:repeat(4, 1fr);
}
.doc-card{
    background:var(--card); border:1px solid var(--border);
    border-radius:var(--radius); padding:26px 22px;
    display:flex; flex-direction:column; gap:12px; min-height:210px;
    transition:transform .2s ease, border-color .2s ease, background .2s ease;
    color:inherit; text-decoration:none; cursor:pointer;
    position:relative; overflow:hidden;
}
.doc-card::after{
    content:""; position:absolute; right:0; top:0; width:0; height:3px;
    background:var(--accent); transition:width .25s ease;
}
.doc-card:hover{
    transform:translateY(-4px); border-color:var(--border-2);
    background:var(--card-hi);
}
.doc-card:hover::after{ width:100%; }
.doc-ico{
    width:46px; height:46px; border-radius:8px;
    background:rgba(226,59,59,.12); color:var(--accent);
    display:grid; place-items:center; font-size:1.2rem;
    transition:background .2s ease, color .2s ease;
}
.doc-card:hover .doc-ico{ background:var(--accent); color:#fff; }
.doc-card h3{ font-size:1.02rem; line-height:1.3; }
.doc-card p{ color:var(--text-mut); font-size:.88rem; flex-grow:1; }
.doc-card .doc-link{
    color:var(--accent); font-family:var(--head); font-weight:500;
    text-transform:uppercase; letter-spacing:.05em; font-size:.82rem;
    display:inline-flex; align-items:center; gap:8px;
    align-self:flex-start; transition:gap .2s ease;
}
.doc-card:hover .doc-link{ gap:13px; }

/* ---------- Внутренняя страница (политика) ---------------------------- */
.page-hero{
    padding:140px 0 50px; background:var(--bg-2);
    border-bottom:1px solid var(--border);
}
.doc{ max-width:840px; margin:0 auto; padding:60px 22px 90px; }
.doc h2{ font-size:1.35rem; margin:34px 0 14px; }
.doc h1{ font-size:clamp(1.8rem,4vw,2.6rem); }
.doc p{ color:var(--text-mut); margin-bottom:14px; }
.doc ul{ list-style:disc; padding-left:22px; margin-bottom:16px; color:var(--text-mut); }
.doc li{ margin-bottom:8px; }
.doc a{ color:var(--accent); text-decoration:underline; }
.back-link{ display:inline-flex; align-items:center; gap:8px; color:var(--accent);
    font-family:var(--head); text-transform:uppercase; letter-spacing:.05em;
    font-size:.9rem; margin-top:20px; }

/* ---------- Адаптив ---------------------------------------------------- */
@media (max-width:991px){
    .nav-links{
        position:fixed; inset:74px 0 auto 0;
        background:var(--bg-2); border-bottom:1px solid var(--border);
        flex-direction:column; align-items:flex-start; gap:0;
        padding:14px 22px; display:none;
    }
    .nav-links.open{ display:flex; }
    .nav-links a{ width:100%; padding:13px 0; border-bottom:1px solid var(--border); }
    .nav-links a:last-child{ border-bottom:none; }
    .burger{ display:grid; place-items:center; }
    .nav-phone span{ display:none; }
    .contacts-grid{ grid-template-columns:1fr; }
    .footer-grid{ grid-template-columns:1fr 1fr; }
    .call-fab{ display:grid; }
    .docs-grid{ grid-template-columns:repeat(2,1fr); }
}
@media (max-width:780px){
    .services-grid{ grid-template-columns:repeat(2,1fr); }
}
@media (max-width:600px){
    .section{ padding:60px 0; }
    .hero{ padding:130px 0 70px; }
    .nav-side .nav-phone{ font-size:1rem; }
    .footer-grid{ grid-template-columns:1fr; gap:28px; }
    .cookie{ flex-direction:column; align-items:flex-start; gap:14px; }
    .cookie .btn-x{ width:100%; }
    .btn-x{ width:100%; }
    .hero-cta .btn-x{ width:100%; }

    /* === Прайс-таблица → карточный список на мобилке === */
    .price-wrap{ background:transparent; border:none; border-radius:0; overflow:visible; }
    .price-table{ display:block; }
    .price-table thead{ display:none; }
    .price-table tbody{ display:flex; flex-direction:column; gap:10px; }
    .price-table tr{
        display:flex; align-items:flex-start; justify-content:space-between;
        gap:12px; padding:14px 16px;
        background:#fff; border:1px solid var(--light-2);
        border-radius:var(--radius);
        transition:none;
    }
    .price-table tr:hover{ background:#fff; }
    .price-table td{
        display:block; padding:0; border:none;
    }
    .price-table td:first-child{
        flex:1 1 auto; min-width:0;
        font-size:.95rem; line-height:1.4;
        color:var(--on-light);
    }
    .price-table td:last-child{
        flex-shrink:0; padding-top:1px;
        font-family:var(--head); font-weight:600;
        font-size:1rem; color:var(--accent);
        white-space:nowrap; text-align:right;
    }
    .price-note{ padding:0 4px; }
}
@media (max-width:520px){
    .services-grid{ grid-template-columns:1fr; }
    .docs-grid{ grid-template-columns:1fr; }
}

@media (prefers-reduced-motion:reduce){
    *{ animation-duration:.01ms !important; transition-duration:.01ms !important; }
    html{ scroll-behavior:auto; }
}
