/* Юридическая фирма СОВЕТНИК — sovetnik61.ru | navy + gold | mobile-first | no JS */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&display=swap');

/* 1. DESIGN TOKENS ------------------------------------------------------- */
:root{
  --navy-900:#07182b; --navy-800:#0e2a47; --navy-700:#16345a;
  --navy-600:#1e4575; --navy-500:#2c5a8f;
  --gold-700:#8a6d2f; --gold-600:#a07f3c; --gold-500:#c5a059;
  --gold-400:#d4b574; --gold-300:#e3c998; --gold-100:#f7eed8;
  --burgundy:#6b1f2e;
  --bg:#fafbfc; --bg-alt:#f2f5f9; --surface:#fff;
  --ink:#1a2332; --ink-soft:#3d4a5c; --muted:#6b7689;
  --line:#e2e8f0; --line-2:#cbd4e0;
  --color-primary:var(--navy-800); --color-primary-dark:var(--navy-900);
  --color-accent:var(--gold-500); --color-accent-dark:var(--gold-600);
  --color-text:var(--ink); --color-text-muted:var(--muted);
  --color-link:var(--navy-700); --color-on-dark:#f4f7fb;
  --font-sans:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,Arial,sans-serif;
  --font-display:var(--font-sans);
  --fs-xs:.8125rem; --fs-sm:.9375rem; --fs-base:1rem; --fs-lg:1.125rem;
  --fs-xl:1.375rem; --fs-2xl:1.75rem; --fs-3xl:2.25rem; --fs-4xl:3rem; --fs-5xl:3.75rem;
  --lh-tight:1.15; --lh-snug:1.3; --lh-normal:1.6; --lh-relaxed:1.75;
  --fw-regular:400; --fw-medium:500; --fw-semibold:600; --fw-bold:700; --fw-extrabold:800;
  --s-1:.25rem; --s-2:.5rem; --s-3:.75rem; --s-4:1rem; --s-5:1.5rem;
  --s-6:2rem; --s-7:3rem; --s-8:4rem; --s-9:6rem; --s-10:8rem;
  --container-w:1200px; --container-px:1.25rem; --header-h:72px;
  --r-sm:4px; --r:8px; --r-lg:16px; --r-xl:24px; --r-pill:999px;
  --sh-xs:0 1px 2px rgba(14,42,71,.06); --sh-sm:0 2px 8px rgba(14,42,71,.08);
  --sh-md:0 10px 30px rgba(14,42,71,.12); --sh-lg:0 24px 60px rgba(14,42,71,.18);
  --sh-gold:0 8px 24px rgba(197,160,89,.28);
  --t-fast:.18s cubic-bezier(.4,0,.2,1); --t:.25s cubic-bezier(.4,0,.2,1);
  --t-slow:.4s cubic-bezier(.4,0,.2,1);
  --z-header:100; --z-overlay:200; --z-modal:300;
}

/* 2. RESET & BASE ------------------------------------------------------- */
*,*::before,*::after{box-sizing:border-box}
*{margin:0;padding:0}
html{font-size:100%;-webkit-text-size-adjust:100%;scroll-behavior:smooth;scroll-padding-top:90px}
body{font-family:var(--font-sans);font-size:var(--fs-base);line-height:var(--lh-normal);
  color:var(--color-text);background:var(--bg);-webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility;overflow-x:hidden}
img,svg,video{display:block;max-width:100%;height:auto}
a{color:var(--color-link);text-decoration:none;transition:color var(--t)}
a:hover{color:var(--color-accent)}
ul,ol{list-style:none}
button{font:inherit;cursor:pointer;border:0;background:none;color:inherit}
input,textarea,select{font:inherit;color:inherit}
table{border-collapse:collapse;width:100%}
:focus-visible{outline:3px solid var(--color-accent);outline-offset:2px;border-radius:var(--r-sm)}
::selection{background:var(--gold-300);color:var(--navy-900)}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;
  clip:rect(0,0,0,0);white-space:nowrap;border:0}
.skip-link{position:absolute;left:-9999px;top:0;background:var(--color-primary);color:#fff;
  padding:var(--s-3) var(--s-5);z-index:var(--z-modal);border-radius:0 0 var(--r) 0;font-weight:var(--fw-semibold)}
.skip-link:focus{left:0;color:#fff}

/* 3. TYPOGRAPHY --------------------------------------------------------- */
h1,h2,h3,h4,h5,h6{font-family:var(--font-display);font-weight:var(--fw-bold);
  line-height:var(--lh-tight);color:var(--navy-900);letter-spacing:-.02em}
h1{font-size:var(--fs-4xl);font-weight:var(--fw-extrabold)}
h2{font-size:var(--fs-3xl)} h3{font-size:var(--fs-2xl)} h4{font-size:var(--fs-xl)}
h5{font-size:var(--fs-lg)}
h6{font-size:var(--fs-base);text-transform:uppercase;letter-spacing:.08em;color:var(--muted)}
p{margin-bottom:var(--s-4)} p:last-child{margin-bottom:0}
strong,b{font-weight:var(--fw-semibold);color:var(--navy-900)}
small{font-size:var(--fs-sm)} abbr[title]{text-decoration:underline dotted;cursor:help}
.lead{font-size:var(--fs-lg);line-height:var(--lh-relaxed);color:var(--ink-soft)}
.eyebrow{display:inline-block;font-size:var(--fs-xs);font-weight:var(--fw-bold);
  letter-spacing:.14em;text-transform:uppercase;color:var(--color-accent-dark);margin-bottom:var(--s-3)}
.eyebrow-light{color:var(--gold-400)}

/* 4. LAYOUT: container / section --------------------------------------- */
.container{width:100%;max-width:var(--container-w);margin-inline:auto;padding-inline:var(--container-px)}
.container-narrow{max-width:820px}
.section{padding-block:var(--s-9)} .section-tight{padding-block:var(--s-8)}
.section-alt{background:var(--bg-alt)}
.section-dark{background:linear-gradient(135deg,var(--navy-900),var(--navy-700));color:var(--color-on-dark)}
.section-dark h2,.section-dark h3,.section-dark h4{color:#fff}
.section-head{text-align:center;max-width:720px;margin-inline:auto;margin-bottom:var(--s-8)}
.section-head h2{margin-bottom:var(--s-3)}
.section-head p{color:var(--color-text-muted);font-size:var(--fs-lg)}
.section-head .eyebrow{margin-bottom:var(--s-2)}
.title-line::after{content:'';display:block;width:56px;height:3px;background:var(--color-accent);
  border-radius:var(--r-pill);margin-top:var(--s-4)}
.section-head .title-line::after{margin-inline:auto}
.title-line-left::after{margin-inline:0}

/* 5. BUTTONS ------------------------------------------------------------ */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--s-2);
  padding:.75rem 1.5rem;font-family:var(--font-sans);font-size:var(--fs-base);
  font-weight:var(--fw-semibold);line-height:1.2;text-align:center;text-decoration:none;
  border:2px solid transparent;border-radius:var(--r);cursor:pointer;white-space:nowrap;
  -webkit-appearance:none;appearance:none;
  transition:transform var(--t-fast),background var(--t),color var(--t),border-color var(--t),box-shadow var(--t)}
.btn:hover{text-decoration:none;transform:translateY(-2px)}
.btn:active{transform:translateY(0)}
.btn:focus-visible{outline-offset:3px}
.btn-primary{background:var(--color-accent);color:var(--navy-900);
  border-color:var(--color-accent);box-shadow:var(--sh-sm)}
.btn-primary:hover{background:var(--color-accent-dark);border-color:var(--color-accent-dark);
  color:#fff;box-shadow:var(--sh-gold)}
.btn-outline{background:transparent;color:var(--navy-800);border-color:var(--navy-800)}
.btn-outline:hover{background:var(--navy-800);color:#fff}
.btn-light{background:#fff;color:var(--navy-900);border-color:#fff}
.btn-light:hover{background:var(--gold-100);color:var(--navy-900)}
.btn-ghost-light{background:rgba(255,255,255,.08);color:#fff;border-color:rgba(255,255,255,.5)}
.btn-ghost-light:hover{background:rgba(255,255,255,.18);color:#fff}
.btn-large{padding:1rem 2rem;font-size:var(--fs-lg)}
.btn-block{display:flex;width:100%}
.link-arrow{display:inline-flex;align-items:center;gap:.35em;font-weight:var(--fw-semibold);color:var(--navy-800)}
.link-arrow::after{content:'→';transition:transform var(--t)}
.link-arrow:hover{color:var(--color-accent-dark)}
.link-arrow:hover::after{transform:translateX(3px)}

/* 6. HEADER & NAV (pure-CSS burger) ------------------------------------ */
/* Burger markup inside .header-inner BEFORE .main-nav:
   <input type="checkbox" id="nav-toggle" class="nav-toggle" hidden>
   <label for="nav-toggle" class="nav-toggle-label" aria-label="Меню"><span></span></label> */
.site-header{position:sticky;top:0;z-index:var(--z-header);
  background:rgba(255,255,255,.92);
  backdrop-filter:saturate(180%) blur(14px);-webkit-backdrop-filter:saturate(180%) blur(14px);
  border-bottom:1px solid var(--line);box-shadow:var(--sh-xs)}
.header-inner{display:flex;align-items:center;justify-content:space-between;gap:var(--s-4);
  min-height:var(--header-h);padding-block:var(--s-2);flex-wrap:wrap}
.logo{display:inline-flex;align-items:center;gap:var(--s-2);font-weight:var(--fw-extrabold);
  font-size:var(--fs-lg);color:var(--navy-900);letter-spacing:-.02em}
.logo img{height:46px;width:auto}
.logo:hover{color:var(--navy-800)}
.logo-text{display:flex;flex-direction:column;line-height:1.1}
.logo-text small{font-size:.625rem;font-weight:var(--fw-medium);color:var(--muted);
  letter-spacing:.12em;text-transform:uppercase}
.nav-toggle{position:absolute;opacity:0;pointer-events:none}
.nav-toggle-label{display:inline-flex;align-items:center;justify-content:center;
  width:44px;height:44px;border-radius:var(--r-sm);cursor:pointer;order:3;margin-left:auto}
.nav-toggle-label span,.nav-toggle-label span::before,.nav-toggle-label span::after{
  content:'';display:block;position:relative;width:24px;height:2px;background:var(--navy-800);
  border-radius:2px;transition:transform var(--t),opacity var(--t)}
.nav-toggle-label span::before{position:absolute;top:-7px;left:0}
.nav-toggle-label span::after{position:absolute;top:7px;left:0}
.main-nav{order:4;flex-basis:100%;max-height:0;overflow:hidden;transition:max-height var(--t-slow)}
.main-nav ul{display:flex;flex-direction:column;gap:var(--s-1);padding:var(--s-2) 0 var(--s-4)}
.main-nav a{display:block;padding:var(--s-3) var(--s-4);color:var(--ink);
  font-weight:var(--fw-medium);border-radius:var(--r);border-left:3px solid transparent}
.main-nav a:hover,.main-nav a.active{background:var(--bg-alt);color:var(--navy-800);
  border-left-color:var(--color-accent)}
.nav-toggle:checked ~ .main-nav{max-height:80vh}
.nav-toggle:checked ~ .nav-toggle-label span{background:transparent}
.nav-toggle:checked ~ .nav-toggle-label span::before{transform:translateY(7px) rotate(45deg)}
.nav-toggle:checked ~ .nav-toggle-label span::after{transform:translateY(-7px) rotate(-45deg)}
.header-cta{display:flex;align-items:center;gap:var(--s-4);order:2}
.header-cta .phone{font-weight:var(--fw-bold);font-size:var(--fs-lg);color:var(--navy-800);white-space:nowrap}
.header-cta .phone::before{content:'☎\00a0';color:var(--color-accent);font-size:.9em}
.header-cta .phone:hover{color:var(--color-accent-dark)}
.header-cta .btn{padding:.6rem 1.1rem}
/* 7. HERO + PAGE-HERO --------------------------------------------------- */
.hero{position:relative;color:var(--color-on-dark);padding-block:var(--s-10);overflow:hidden;
  background:linear-gradient(135deg,rgba(7,24,43,.92),rgba(22,52,90,.88)),
    radial-gradient(circle at 80% 20%,rgba(197,160,89,.25),transparent 55%)}
.hero::after{content:'';position:absolute;right:-120px;top:-120px;width:360px;height:360px;
  border:2px solid rgba(197,160,89,.18);border-radius:50%;pointer-events:none}
.hero .container{position:relative;z-index:1;max-width:920px}
.hero h1{color:#fff;font-size:var(--fs-5xl);margin-bottom:var(--s-5)}
.hero h1 .accent{color:var(--gold-400)}
.hero p{font-size:var(--fs-xl);color:rgba(244,247,251,.85);line-height:var(--lh-relaxed);
  max-width:640px;margin-bottom:var(--s-7)}
.hero-cta{display:flex;flex-wrap:wrap;gap:var(--s-4)}
.hero-meta{margin-top:var(--s-8);display:flex;flex-wrap:wrap;gap:var(--s-5) var(--s-7);
  font-size:var(--fs-sm);color:rgba(244,247,251,.75)}
.hero-meta strong{color:var(--gold-300);display:block;font-size:var(--fs-lg)}
.page-hero{background:linear-gradient(135deg,var(--navy-900),var(--navy-700));
  color:var(--color-on-dark);padding-block:var(--s-8);position:relative}
.page-hero::before{content:'';position:absolute;inset:0;
  background:radial-gradient(circle at 90% 10%,rgba(197,160,89,.2),transparent 50%);pointer-events:none}
.page-hero .container{position:relative}
.page-hero h1{color:#fff;font-size:var(--fs-4xl);margin-bottom:var(--s-3)}
.page-hero p{color:rgba(244,247,251,.85);font-size:var(--fs-lg);max-width:640px}

/* 8. BREADCRUMBS -------------------------------------------------------- */
.breadcrumbs{padding-block:var(--s-4) var(--s-5);font-size:var(--fs-sm);color:var(--muted)}
.breadcrumbs ol{display:flex;flex-wrap:wrap;gap:.4em;align-items:center}
.breadcrumbs li{display:flex;align-items:center;gap:.4em}
.breadcrumbs li:not(:last-child)::after{content:'/';color:var(--line-2)}
.breadcrumbs a{color:var(--muted)} .breadcrumbs a:hover{color:var(--navy-800)}
.breadcrumbs [aria-current="page"]{color:var(--navy-800);font-weight:var(--fw-medium)}

/* 9. SERVICES GRID ------------------------------------------------------ */
.services-grid{display:grid;grid-template-columns:1fr;gap:var(--s-5)}
.service-card{position:relative;background:var(--surface);border:1px solid var(--line);
  border-radius:var(--r-lg);padding:var(--s-6);overflow:hidden;
  transition:transform var(--t),box-shadow var(--t),border-color var(--t)}
.service-card::before{content:'';position:absolute;left:0;top:0;width:100%;height:3px;
  background:var(--color-accent);transform:scaleX(0);transform-origin:left;transition:transform var(--t)}
.service-card:hover{transform:translateY(-6px);box-shadow:var(--sh-md);border-color:transparent}
.service-card:hover::before{transform:scaleX(1)}
.service-icon{display:inline-flex;align-items:center;justify-content:center;
  width:64px;height:64px;margin-bottom:var(--s-4);font-size:1.75rem;
  background:var(--gold-100);border-radius:var(--r);color:var(--gold-700);
  transition:background var(--t),transform var(--t)}
.service-card:hover .service-icon{background:var(--color-accent);transform:rotate(-4deg) scale(1.05)}
.service-card h3{font-size:var(--fs-xl);margin-bottom:var(--s-3)}
.service-card p{color:var(--ink-soft);margin-bottom:var(--s-4)}
.service-link{display:inline-flex;align-items:center;gap:.35em;font-weight:var(--fw-semibold);color:var(--navy-800)}
.service-link::after{content:'→';transition:transform var(--t)}
.service-card:hover .service-link{color:var(--color-accent-dark)}
.service-card:hover .service-link::after{transform:translateX(4px)}

/* 10. STATS ------------------------------------------------------------- */
.stats{background:linear-gradient(135deg,var(--navy-900),var(--navy-700));
  color:var(--color-on-dark);padding-block:var(--s-8)}
.stats-grid{display:grid;grid-template-columns:1fr;gap:var(--s-6);text-align:center}
.stat{padding:var(--s-3)}
.stat-num{font-size:var(--fs-5xl);font-weight:var(--fw-extrabold);color:var(--gold-400);
  line-height:1;letter-spacing:-.03em}
.stat-num .suffix{font-size:.5em;color:var(--gold-300);margin-left:.05em}
.stat-label{margin-top:var(--s-2);font-size:var(--fs-base);text-transform:uppercase;
  letter-spacing:.12em;color:rgba(244,247,251,.78)}
.stats-grid .stat + .stat{position:relative}
.stats-grid .stat + .stat::before{content:'';position:absolute;left:50%;top:0;
  width:1px;height:100%;background:rgba(255,255,255,.12);transform:translateX(-50%)}

/* 11. ADVANTAGES -------------------------------------------------------- */
.advantages-grid{display:grid;grid-template-columns:1fr;gap:var(--s-5)}
.advantage{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);
  padding:var(--s-6);transition:transform var(--t),box-shadow var(--t)}
.advantage:hover{transform:translateY(-4px);box-shadow:var(--sh-sm)}
.advantage-icon{display:inline-flex;align-items:center;justify-content:center;
  width:52px;height:52px;margin-bottom:var(--s-4);font-size:1.5rem;
  background:var(--navy-800);color:var(--gold-400);border-radius:var(--r)}
.advantage h3{font-size:var(--fs-lg);margin-bottom:var(--s-2)}
.advantage p{color:var(--ink-soft);font-size:var(--fs-sm)}

/* 12. TESTIMONIALS ------------------------------------------------------ */
.testimonials-grid{display:grid;grid-template-columns:1fr;gap:var(--s-5)}
.testimonial{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);
  padding:var(--s-6);position:relative;transition:box-shadow var(--t)}
.testimonial:hover{box-shadow:var(--sh-sm)}
.testimonial::before{content:'\201C';position:absolute;top:var(--s-2);right:var(--s-4);
  font-family:Georgia,serif;font-size:4rem;line-height:1;color:var(--gold-300);opacity:.6}
.testimonial-text{font-size:var(--fs-lg);line-height:var(--lh-relaxed);color:var(--ink);
  margin-bottom:var(--s-5);position:relative;z-index:1}
.testimonial-author{display:flex;align-items:center;gap:var(--s-3)}
.testimonial-avatar{width:48px;height:48px;border-radius:50%;background:var(--navy-800);
  color:var(--gold-400);display:inline-flex;align-items:center;justify-content:center;
  font-weight:var(--fw-bold);font-size:var(--fs-lg);flex-shrink:0}
.testimonial-name{font-weight:var(--fw-semibold);color:var(--navy-900)}
.testimonial-role{font-size:var(--fs-sm);color:var(--muted)}
.testimonial-rating{color:var(--gold-500);letter-spacing:.15em;margin-bottom:var(--s-3)}

/* 13. CASES ------------------------------------------------------------- */
.cases-grid{display:grid;grid-template-columns:1fr;gap:var(--s-5)}
.case-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);
  padding:var(--s-6);border-top:4px solid var(--color-accent);
  transition:transform var(--t),box-shadow var(--t)}
.case-card:hover{transform:translateY(-4px);box-shadow:var(--sh-md)}
.case-card .case-tag{display:inline-block;font-size:var(--fs-xs);font-weight:var(--fw-bold);
  letter-spacing:.1em;text-transform:uppercase;color:var(--color-accent-dark);margin-bottom:var(--s-3)}
.case-card h3{font-size:var(--fs-xl);margin-bottom:var(--s-3)}
.case-card .case-meta{display:flex;flex-wrap:wrap;gap:var(--s-2) var(--s-4);
  font-size:var(--fs-sm);color:var(--muted);margin-bottom:var(--s-3)}
.case-card .case-meta span::before{content:'·\00a0';opacity:.5}
.case-card .case-meta span:first-child::before{content:none}
.case-card .case-result{display:flex;align-items:center;gap:var(--s-2);margin-top:var(--s-4);
  padding-top:var(--s-4);border-top:1px dashed var(--line-2);
  font-weight:var(--fw-semibold);color:var(--navy-800)}
.case-card .case-result::before{content:'✓';color:var(--color-accent-dark);font-size:1.2em}

/* 14. CTA BAND ---------------------------------------------------------- */
.cta{background:linear-gradient(135deg,var(--navy-900),var(--navy-700));
  color:var(--color-on-dark);padding-block:var(--s-9);text-align:center;
  position:relative;overflow:hidden}
.cta::before{content:'';position:absolute;left:-80px;bottom:-80px;width:240px;height:240px;
  border:2px solid rgba(197,160,89,.15);border-radius:50%}
.cta .container{position:relative;z-index:1}
.cta h2{color:#fff;font-size:var(--fs-3xl);margin-bottom:var(--s-4)}
.cta h2 .accent{color:var(--gold-400)}
.cta p{color:rgba(244,247,251,.85);font-size:var(--fs-lg);margin-bottom:var(--s-6)}
.cta .btn{margin-inline:.25rem}

/* 15. FOOTER ------------------------------------------------------------ */
.site-footer{background:var(--navy-900);color:rgba(244,247,251,.78);
  padding-top:var(--s-9);font-size:var(--fs-sm)}
.footer-grid{display:grid;grid-template-columns:1fr;gap:var(--s-7);padding-bottom:var(--s-8)}
.site-footer h4{color:#fff;font-size:var(--fs-base);text-transform:uppercase;letter-spacing:.08em;
  margin-bottom:var(--s-4);padding-bottom:var(--s-3);border-bottom:2px solid var(--gold-600);display:inline-block}
.site-footer p{margin-bottom:var(--s-2);color:rgba(244,247,251,.72)}
.site-footer a{color:rgba(244,247,251,.85)} .site-footer a:hover{color:var(--gold-400)}
.footer-contacts .phone-big{display:block;font-size:var(--fs-xl);font-weight:var(--fw-bold);
  color:#fff !important;margin-bottom:var(--s-3)}
.footer-contacts .phone-big::before{content:'☎\00a0';color:var(--gold-400)}
.footer-social{display:flex;gap:var(--s-3);margin-top:var(--s-4)}
.footer-social a{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;
  border:1px solid rgba(255,255,255,.18);border-radius:var(--r);font-size:1.1rem;
  transition:background var(--t),border-color var(--t)}
.footer-social a:hover{background:var(--gold-600);border-color:var(--gold-600);color:#fff}
.footer-nav li{margin-bottom:var(--s-2)}
.footer-nav a::before{content:'›\00a0';color:var(--gold-500)}
.footer-bottom{border-top:1px solid rgba(255,255,255,.1);padding-block:var(--s-5);
  font-size:var(--fs-xs);color:rgba(244,247,251,.55)}
.footer-bottom .container{display:flex;flex-wrap:wrap;gap:var(--s-3) var(--s-5);
  justify-content:space-between;align-items:center}
.footer-bottom a{color:rgba(244,247,251,.7)}

/* 16. CONTENT PAGE (article typography) --------------------------------- */
.content-page{max-width:820px;margin-inline:auto;padding-block:var(--s-7)}
.content-page h2{font-size:var(--fs-2xl);margin-top:var(--s-7);margin-bottom:var(--s-4)}
.content-page h3{font-size:var(--fs-xl);margin-top:var(--s-6);margin-bottom:var(--s-3)}
.content-page h4{font-size:var(--fs-lg);margin-top:var(--s-5);margin-bottom:var(--s-3)}
.content-page p{margin-bottom:var(--s-4)}
.content-page ul,.content-page ol{margin:0 0 var(--s-4) var(--s-5)}
.content-page ul li{list-style:disc;margin-bottom:var(--s-2)}
.content-page ol li{list-style:decimal;margin-bottom:var(--s-2)}
.content-page li::marker{color:var(--color-accent-dark)}
.content-page a{color:var(--navy-700);text-decoration:underline;
  text-decoration-color:var(--gold-400);text-underline-offset:3px}
.content-page a:hover{color:var(--color-accent-dark)}
.content-page img{border-radius:var(--r-lg);margin:var(--s-5) 0}
.content-page blockquote{margin:var(--s-6) 0;padding:var(--s-5) var(--s-6);background:var(--bg-alt);
  border-left:4px solid var(--color-accent);border-radius:0 var(--r) var(--r) 0;
  font-size:var(--fs-lg);font-style:italic;color:var(--ink-soft)}
.content-page blockquote p:last-child{margin-bottom:0}
.content-page table{margin:var(--s-5) 0;font-size:var(--fs-sm)}
.content-page th,.content-page td{padding:var(--s-3);text-align:left;border:1px solid var(--line)}
.content-page th{background:var(--bg-alt);font-weight:var(--fw-semibold);color:var(--navy-900)}
.content-page hr{border:0;border-top:1px solid var(--line);margin:var(--s-6) 0}
.content-page code{font-family:'SFMono-Regular',Consolas,monospace;background:var(--bg-alt);
  padding:.15em .4em;border-radius:var(--r-sm);font-size:.9em}
.article-meta{display:flex;flex-wrap:wrap;gap:var(--s-3) var(--s-5);padding-bottom:var(--s-4);
  margin-bottom:var(--s-6);border-bottom:1px solid var(--line);font-size:var(--fs-sm);color:var(--muted)}
.article-meta time::before{content:'🗓\00a0'}
.article-meta .author::before{content:'✍\00a0'}
.article-meta .reading-time::before{content:'⏱\00a0'}

/* 17. SERVICE DETAIL ---------------------------------------------------- */
.service-detail{padding-block:var(--s-7)}
.service-detail .service-overview{display:grid;gap:var(--s-6);background:var(--bg-alt);
  border-radius:var(--r-lg);padding:var(--s-6);margin-bottom:var(--s-7)}
.service-detail .service-overview h2{font-size:var(--fs-2xl)}
.service-detail .service-overview .service-price{font-size:var(--fs-xl);font-weight:var(--fw-bold);
  color:var(--color-accent-dark)}
.service-detail .service-overview .service-price small{color:var(--muted);
  font-weight:var(--fw-regular);font-size:var(--fs-sm)}
.service-detail-section{margin-bottom:var(--s-7)}
.service-detail-section h2{margin-bottom:var(--s-4)}
.service-steps{display:grid;gap:var(--s-4);counter-reset:step}
.service-step{display:flex;gap:var(--s-4);padding:var(--s-4);background:var(--surface);
  border:1px solid var(--line);border-radius:var(--r)}
.service-step::before{counter-increment:step;content:counter(step);flex-shrink:0;
  display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;
  background:var(--navy-800);color:var(--gold-400);font-weight:var(--fw-bold);font-size:var(--fs-lg);
  border-radius:50%}
.service-step h4{margin-bottom:var(--s-2)}
.service-step p{color:var(--ink-soft);font-size:var(--fs-sm);margin:0}
.service-sidebar-card{background:var(--surface);border:1px solid var(--line);
  border-radius:var(--r-lg);padding:var(--s-6);box-shadow:var(--sh-xs)}
.service-sidebar-card h3{font-size:var(--fs-lg);margin-bottom:var(--s-4)}
.service-detail-layout{display:grid;gap:var(--s-7);align-items:start}

/* 18. CONTACT: info + form --------------------------------------------- */
.contact-grid{display:grid;grid-template-columns:1fr;gap:var(--s-7);padding-block:var(--s-7)}
.contact-info{display:grid;gap:var(--s-4)}
.contact-item{display:flex;gap:var(--s-4);align-items:flex-start;padding:var(--s-4);
  border:1px solid var(--line);border-radius:var(--r);background:var(--surface);
  transition:box-shadow var(--t)}
.contact-item:hover{box-shadow:var(--sh-sm)}
.contact-item .contact-icon{flex-shrink:0;display:inline-flex;align-items:center;justify-content:center;
  width:48px;height:48px;background:var(--gold-100);color:var(--gold-700);border-radius:var(--r);font-size:1.25rem}
.contact-item h4{font-size:var(--fs-base);margin-bottom:var(--s-1)}
.contact-item p,.contact-item a{color:var(--ink-soft);font-size:var(--fs-sm)}
.contact-item a:hover{color:var(--color-accent-dark)}
.contact-item .contact-value{font-size:var(--fs-lg);font-weight:var(--fw-semibold);
  color:var(--navy-900);display:block}
.contact-form{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);
  padding:var(--s-6);box-shadow:var(--sh-sm)}
.contact-form h3{margin-bottom:var(--s-2)}
.contact-form .form-note{font-size:var(--fs-sm);color:var(--muted);margin-bottom:var(--s-5)}
.form-row{margin-bottom:var(--s-4)}
.form-row-2{display:grid;grid-template-columns:1fr;gap:var(--s-4)}
.form-label{display:block;font-weight:var(--fw-medium);margin-bottom:var(--s-2);font-size:var(--fs-sm)}
.form-label .req{color:var(--burgundy)}
.form-control{width:100%;padding:.75rem var(--s-4);background:var(--bg);
  border:1px solid var(--line-2);border-radius:var(--r);font-size:var(--fs-base);
  transition:border-color var(--t),box-shadow var(--t),background var(--t)}
.form-control::placeholder{color:var(--muted)}
.form-control:focus{outline:none;border-color:var(--color-accent);background:#fff;
  box-shadow:0 0 0 3px rgba(197,160,89,.18)}
textarea.form-control{min-height:140px;resize:vertical}
select.form-control{appearance:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='%236b7689' d='M6 8L0 0h12z'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 1rem center;padding-right:2.5rem}
.form-help{font-size:var(--fs-xs);color:var(--muted);margin-top:var(--s-1)}
.form-consent{display:flex;gap:var(--s-3);align-items:flex-start;font-size:var(--fs-sm);
  color:var(--muted);margin-bottom:var(--s-4)}
.form-consent input{margin-top:.25rem;width:18px;height:18px;accent-color:var(--color-accent-dark);flex-shrink:0}
.map-embed{border:0;width:100%;height:360px;border-radius:var(--r-lg);filter:grayscale(.2) contrast(1.05)}

/* 19. PRICE TABLE ------------------------------------------------------- */
.price-table-wrap{overflow-x:auto;border-radius:var(--r-lg);border:1px solid var(--line)}
.price-table{width:100%;border-collapse:collapse;font-size:var(--fs-sm);min-width:520px}
.price-table th,.price-table td{padding:var(--s-4) var(--s-5);text-align:left;
  border-bottom:1px solid var(--line);vertical-align:top}
.price-table thead th{background:var(--navy-800);color:#fff;font-weight:var(--fw-semibold);
  font-size:var(--fs-xs);text-transform:uppercase;letter-spacing:.06em;border-bottom:0}
.price-table tbody tr:nth-child(even){background:var(--bg-alt)}
.price-table tbody tr:hover{background:var(--gold-100)}
.price-table .price-name{font-weight:var(--fw-semibold);color:var(--navy-900)}
.price-table .price-value{font-weight:var(--fw-bold);color:var(--color-accent-dark);
  white-space:nowrap;text-align:right}
.price-table .price-note{color:var(--muted);font-size:var(--fs-xs);display:block;margin-top:.25em}
.price-table tfoot td{background:var(--bg-alt);font-style:italic;color:var(--muted);border-bottom:0}

/* 20. FAQ ACCORDION (<details>) ---------------------------------------- */
.faq{max-width:820px;margin-inline:auto;display:grid;gap:var(--s-3)}
.faq-item{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);
  overflow:hidden;transition:box-shadow var(--t),border-color var(--t)}
.faq-item[open]{border-color:var(--color-accent);box-shadow:var(--sh-sm)}
.faq-item summary{display:flex;align-items:center;justify-content:space-between;gap:var(--s-4);
  padding:var(--s-4) var(--s-5);font-weight:var(--fw-semibold);color:var(--navy-900);
  cursor:pointer;list-style:none;transition:background var(--t)}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::after{content:'+';flex-shrink:0;display:inline-flex;align-items:center;
  justify-content:center;width:28px;height:28px;font-size:1.5rem;font-weight:var(--fw-regular);
  color:var(--color-accent-dark);background:var(--gold-100);border-radius:50%;
  transition:transform var(--t),background var(--t),color var(--t)}
.faq-item[open] summary::after{content:'−';background:var(--color-accent);color:#fff;transform:rotate(180deg)}
.faq-item summary:hover{background:var(--bg-alt)}
.faq-answer{padding:0 var(--s-5) var(--s-5);color:var(--ink-soft);line-height:var(--lh-relaxed)}
.faq-answer p:last-child{margin-bottom:0}

/* 21. BLOG: tags + post cards ------------------------------------------ */
.tag-list{display:flex;flex-wrap:wrap;gap:var(--s-2)}
.tag{display:inline-flex;align-items:center;padding:.35rem .85rem;font-size:var(--fs-xs);
  font-weight:var(--fw-semibold);color:var(--navy-700);background:var(--gold-100);
  border:1px solid var(--gold-300);border-radius:var(--r-pill);text-decoration:none;
  transition:background var(--t),color var(--t),border-color var(--t)}
.tag:hover{background:var(--color-accent);color:var(--navy-900);border-color:var(--color-accent)}
.posts-grid{display:grid;grid-template-columns:1fr;gap:var(--s-5)}
.post-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);
  overflow:hidden;transition:transform var(--t),box-shadow var(--t);display:flex;flex-direction:column}
.post-card:hover{transform:translateY(-4px);box-shadow:var(--sh-md)}
.post-card-thumb{aspect-ratio:16/9;overflow:hidden;background:var(--bg-alt)}
.post-card-thumb img{width:100%;height:100%;object-fit:cover;transition:transform var(--t-slow)}
.post-card:hover .post-card-thumb img{transform:scale(1.05)}
.post-card-body{padding:var(--s-5);display:flex;flex-direction:column;flex:1}
.post-card-meta{font-size:var(--fs-xs);color:var(--muted);margin-bottom:var(--s-2);
  text-transform:uppercase;letter-spacing:.08em}
.post-card h3{font-size:var(--fs-lg);margin-bottom:var(--s-3)}
.post-card h3 a{color:var(--navy-900)} .post-card h3 a:hover{color:var(--color-accent-dark)}
.post-card p{color:var(--ink-soft);font-size:var(--fs-sm);flex:1}
.post-card .post-card-more{margin-top:var(--s-4)}

/* 22. UTILITIES --------------------------------------------------------- */
.text-center{text-align:center} .text-left{text-align:left} .text-right{text-align:right}
.mt-0{margin-top:0} .mt-2{margin-top:var(--s-2)} .mt-4{margin-top:var(--s-4)}
.mt-6{margin-top:var(--s-6)} .mt-8{margin-top:var(--s-8)}
.mb-0{margin-bottom:0} .mb-2{margin-bottom:var(--s-2)} .mb-4{margin-bottom:var(--s-4)}
.mb-6{margin-bottom:var(--s-6)} .mb-8{margin-bottom:var(--s-8)}
.hide{display:none !important}
.bg-gold{background:var(--gold-100)} .bg-navy{background:var(--navy-800);color:#fff}
.rounded{border-radius:var(--r-lg)} .shadow{box-shadow:var(--sh-md)}
.divider{height:1px;background:var(--line);border:0;margin:var(--s-6) 0}

/* 23. ANIMATIONS (reduced-motion aware) -------------------------------- */
@keyframes fade-up{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}
.animate-on-load{animation:fade-up .6s ease-out both}
@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{animation-duration:.001ms !important;animation-iteration-count:1 !important;
    transition-duration:.001ms !important;scroll-behavior:auto !important}
}

/* 24. RESPONSIVE — tablet (>=768px) ------------------------------------ */
@media (min-width:768px){
  :root{--header-h:80px;--container-px:2rem}
  h1{font-size:var(--fs-5xl)}
  .section{padding-block:var(--s-10)}
  .nav-toggle,.nav-toggle-label{display:none}
  .header-inner{flex-wrap:nowrap}
  .main-nav{order:0;flex-basis:auto;max-height:none;overflow:visible}
  .main-nav ul{flex-direction:row;gap:var(--s-1);padding:0}
  .main-nav a{padding:var(--s-2) var(--s-3);border-left:0;
    border-bottom:3px solid transparent;border-radius:var(--r-sm)}
  .main-nav a:hover,.main-nav a.active{background:transparent;border-bottom-color:var(--color-accent)}
  .header-cta{order:0}
  .header-cta .btn{display:inline-flex}
  .services-grid{grid-template-columns:repeat(2,1fr)}
  .stats-grid{grid-template-columns:repeat(3,1fr)}
  .stats-grid .stat + .stat::before{left:0;top:50%;width:1px;height:60%;transform:translateY(-50%)}
  .advantages-grid{grid-template-columns:repeat(2,1fr)}
  .testimonials-grid{grid-template-columns:repeat(2,1fr)}
  .cases-grid{grid-template-columns:repeat(2,1fr)}
  .posts-grid{grid-template-columns:repeat(2,1fr)}
  .footer-grid{grid-template-columns:repeat(2,1fr)}
  .form-row-2{grid-template-columns:1fr 1fr}
  .contact-grid{grid-template-columns:1fr 1.1fr;align-items:start}
  .service-detail .service-overview{grid-template-columns:2fr 1fr;align-items:center}
}

/* 25. RESPONSIVE — desktop (>=1024px) ---------------------------------- */
@media (min-width:1024px){
  .services-grid{grid-template-columns:repeat(3,1fr)}
  .advantages-grid{grid-template-columns:repeat(3,1fr)}
  .testimonials-grid{grid-template-columns:repeat(3,1fr)}
  .cases-grid{grid-template-columns:repeat(3,1fr)}
  .posts-grid{grid-template-columns:repeat(3,1fr)}
  .footer-grid{grid-template-columns:2fr 1fr 1fr 1fr;gap:var(--s-8)}
  .service-detail-layout{grid-template-columns:2fr 1fr}
  .hero{padding-block:var(--s-10)}
  .hero h1{font-size:4.25rem}
}
@media (min-width:1280px){:root{--container-px:2.5rem}}

/* 26. PRINT (для страниц услуг) ---------------------------------------- */
@media print{
  :root{--bg:#fff;--bg-alt:#fff;--surface:#fff}
  *,*::before,*::after{background:transparent !important;color:#000 !important;
    box-shadow:none !important;text-shadow:none !important;border-color:#ccc !important}
  .site-header,.cta,.site-footer,.breadcrumbs,.hero-cta,.header-cta,.nav-toggle-label,
  .contact-form,.footer-bottom,.post-card-more,.service-link,.btn{display:none !important}
  body{font-size:11pt;line-height:1.5}
  .hero,.page-hero,.stats,.section-dark{background:#fff !important;color:#000 !important;padding-block:1cm !important}
  .hero h1,.page-hero h1,.section-dark h2,.stats .stat-num{color:#000 !important}
  .section{padding-block:.5cm !important}
  .container{max-width:100% !important;padding:0 !important}
  .content-page{max-width:100%}
  a{text-decoration:underline;color:#000 !important}
  a::after{content:' (' attr(href) ')';font-size:9pt;color:#555 !important}
  .content-page a::after,.service-link::after,.btn::after{content:none}
  h1,h2,h3{page-break-after:avoid}
  .service-card,.case-card,.testimonial,.faq-item,table,tr,img{page-break-inside:avoid}
  .price-table th{background:#eee !important;color:#000 !important}
  .faq-answer{display:block !important}
  .faq-item[open]{border:1px solid #ccc !important}
  .faq-item summary::after{content:''}
}
