/* ============================================================================
   ГК Такт — Подольск.  Design system: «Инженерный чертёж / сталь».
   Fonts: IBM Plex Sans (body/headings) + IBM Plex Mono (technical labels).
   ========================================================================== */

:root{
  /* — палитра — */
  --ink:        #14171c;   /* графит, основной тёмный */
  --ink-2:      #1b1f26;
  --ink-3:      #262b34;
  --steel:      #5b6470;
  --steel-2:    #8b95a3;
  --paper:      #f5f2ea;   /* тёплый светлый */
  --paper-2:    #ebe6d9;
  --paper-3:    #ddd6c6;
  --white:      #ffffff;

  --amber:      #ff6a1a;   /* акцент: «стройка/безопасность» */
  --amber-deep: #e2520a;
  --amber-soft: #ffe2cf;
  --green:      #3f7d4e;   /* доверие / гарантия */

  --line:       rgba(20,23,28,.12);
  --line-strong:rgba(20,23,28,.22);
  --line-blue:  rgba(120,150,180,.18); /* чертёжная сетка на тёмном */

  /* — типографика — */
  --f-sans: 'IBM Plex Sans', system-ui, sans-serif;
  --f-mono: 'IBM Plex Mono', ui-monospace, monospace;

  /* — прочее — */
  --radius:   4px;
  --radius-l: 10px;
  --shadow:   0 10px 30px -12px rgba(20,23,28,.30);
  --shadow-l: 0 30px 60px -20px rgba(20,23,28,.40);
  --maxw: 1240px;
  --header-h: 76px;
}

/* ─── reset / base ────────────────────────────────────────────────────────── */
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:var(--f-sans);
  font-weight:400;
  color:var(--ink);
  background:var(--paper);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4{font-weight:700;line-height:1.1;letter-spacing:-.02em;margin:0 0 .5em}
h1{font-size:clamp(2.4rem,5.5vw,4.4rem)}
h2{font-size:clamp(1.8rem,3.6vw,2.9rem)}
h3{font-size:clamp(1.25rem,2vw,1.6rem)}
p{margin:0 0 1rem}
.container{max-width:var(--maxw);margin:0 auto;padding:0 24px}
section{position:relative}

/* ─── технические «теги» в моно — фирменная деталь ───────────────────────── */
.mono{font-family:var(--f-mono);letter-spacing:.02em}
.eyebrow{
  font-family:var(--f-mono);
  font-size:.78rem;font-weight:500;
  text-transform:uppercase;letter-spacing:.18em;
  color:var(--amber-deep);
  display:inline-flex;align-items:center;gap:.6rem;
  margin-bottom:1rem;
}
.eyebrow::before{content:"";width:28px;height:2px;background:var(--amber);display:inline-block}
.eyebrow.light{color:var(--amber)}
.section-num{
  font-family:var(--f-mono);font-size:.8rem;color:var(--steel-2);
  letter-spacing:.1em;
}

/* ─── кнопки ──────────────────────────────────────────────────────────────── */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.6rem;
  font-family:var(--f-sans);font-weight:600;font-size:1rem;
  padding:.85rem 1.6rem;border-radius:var(--radius);
  border:2px solid transparent;cursor:pointer;
  transition:transform .18s ease, box-shadow .18s ease, background .18s ease, color .18s ease;
  text-align:center;line-height:1.2;
}
.btn:active{transform:translateY(1px)}
.btn-primary{background:var(--amber);color:#241200;border-color:var(--amber)}
.btn-primary:hover{background:var(--amber-deep);border-color:var(--amber-deep);box-shadow:0 10px 24px -8px rgba(226,82,10,.55);transform:translateY(-2px)}
.btn-ghost{background:transparent;color:var(--ink);border-color:var(--line-strong)}
.btn-ghost:hover{border-color:var(--ink);background:var(--ink);color:var(--paper)}
.btn-ghost.light{color:var(--paper);border-color:rgba(245,242,234,.35)}
.btn-ghost.light:hover{background:var(--paper);color:var(--ink);border-color:var(--paper)}
.btn-lg{padding:1.05rem 2.1rem;font-size:1.08rem}
.btn-block{width:100%}

/* ─── header ──────────────────────────────────────────────────────────────── */
.site-header{
  position:sticky;top:0;z-index:1000;
  background:rgba(20,23,28,.92);
  backdrop-filter:blur(10px);
  border-bottom:1px solid rgba(245,242,234,.08);
  color:var(--paper);
}
.header-inner{display:flex;align-items:center;gap:1.5rem;height:var(--header-h)}
.brand{display:flex;align-items:center;gap:.7rem;flex-shrink:0}
.brand .logo-mark{
  width:42px;height:42px;border-radius:var(--radius);
  background:var(--amber);color:#241200;
  display:grid;place-items:center;font-family:var(--f-mono);font-weight:700;font-size:1.3rem;
  position:relative;overflow:hidden;
}
.brand .logo-mark::after{content:"";position:absolute;inset:auto 0 0 0;height:7px;
  background-image:repeating-linear-gradient(45deg,#241200 0 6px,transparent 6px 12px);opacity:.55}
.brand .brand-text{line-height:1.05}
.brand .brand-name{font-weight:700;font-size:1.2rem;letter-spacing:-.01em}
.brand .brand-sub{font-family:var(--f-mono);font-size:.62rem;text-transform:uppercase;letter-spacing:.22em;color:var(--steel-2)}

.main-nav{display:flex;align-items:center;gap:.3rem;margin-left:auto}
.main-nav a{
  font-size:.96rem;font-weight:500;padding:.55rem .85rem;border-radius:var(--radius);
  color:rgba(245,242,234,.82);transition:color .15s, background .15s;position:relative;
}
.main-nav a:hover{color:var(--white)}
.main-nav a.active{color:var(--amber)}
.main-nav a.active::after{content:"";position:absolute;left:.85rem;right:.85rem;bottom:.25rem;height:2px;background:var(--amber)}

.header-cta{display:flex;align-items:center;gap:1rem;flex-shrink:0}
.header-phone{display:flex;flex-direction:column;line-height:1.1;text-align:right}
.header-phone .num{font-weight:700;font-size:1.05rem;white-space:nowrap}
.header-phone .lbl{font-family:var(--f-mono);font-size:.6rem;text-transform:uppercase;letter-spacing:.16em;color:var(--steel-2)}

.nav-toggle{display:none;background:none;border:0;color:var(--paper);font-size:1.6rem;cursor:pointer;padding:.3rem}

/* мобильное меню */
.mobile-nav{
  position:fixed;inset:var(--header-h) 0 0 0;z-index:999;
  background:var(--ink);transform:translateX(100%);transition:transform .3s ease;
  padding:2rem 24px;display:flex;flex-direction:column;gap:.3rem;overflow-y:auto;
}
.mobile-nav.open{transform:translateX(0)}
.mobile-nav a{color:var(--paper);font-size:1.3rem;font-weight:600;padding:.9rem 0;border-bottom:1px solid rgba(245,242,234,.08)}
.mobile-nav .btn{margin-top:1.5rem}

/* ─── HERO + конструктор забора ───────────────────────────────────────────── */
.hero{
  background:var(--ink);color:var(--paper);
  padding:clamp(2.5rem,6vw,4.5rem) 0 0;
  position:relative;overflow:hidden;
}
.hero::before{ /* чертёжная сетка */
  content:"";position:absolute;inset:0;opacity:.5;pointer-events:none;
  background-image:linear-gradient(var(--line-blue) 1px,transparent 1px),
                   linear-gradient(90deg,var(--line-blue) 1px,transparent 1px);
  background-size:46px 46px;
  mask-image:radial-gradient(circle at 70% 30%,#000,transparent 75%);
}
.hero-grid{display:grid;grid-template-columns:1.05fr 1.25fr;gap:3rem;align-items:center;position:relative}
.hero-copy h1 .accent{color:var(--amber);display:block}
.hero-lead{font-size:1.15rem;color:rgba(245,242,234,.75);max-width:46ch;margin:1.2rem 0 2rem}
.hero-actions{display:flex;gap:1rem;flex-wrap:wrap;margin-bottom:2rem}
.hero-stats{display:flex;gap:2.2rem;flex-wrap:wrap;border-top:1px solid rgba(245,242,234,.12);padding-top:1.6rem}
.hero-stat .n{font-family:var(--f-mono);font-size:1.9rem;font-weight:500;color:var(--amber)}
.hero-stat .l{font-size:.82rem;color:var(--steel-2);max-width:16ch}

/* стеклянный «конструктор» */
.constructor{
  background:linear-gradient(180deg,#10131a,#181d25);
  border:1px solid rgba(245,242,234,.1);
  border-radius:var(--radius-l);overflow:hidden;
  box-shadow:var(--shadow-l);
}
.constructor-bar{
  display:flex;align-items:center;gap:.5rem;padding:.7rem 1rem;
  border-bottom:1px solid rgba(245,242,234,.1);
  font-family:var(--f-mono);font-size:.72rem;color:var(--steel-2);letter-spacing:.1em;text-transform:uppercase;
}
.constructor-bar .dot{width:9px;height:9px;border-radius:50%;background:var(--steel)}
.constructor-bar .dot.live{background:var(--amber);box-shadow:0 0 0 0 rgba(255,106,26,.6);animation:pulse 2s infinite}
.constructor-stage{position:relative;width:100%;aspect-ratio:16/10;background:#0d1016}
.constructor-stage svg{width:100%;height:100%;display:block}
.constructor-controls{padding:1rem;display:flex;gap:.6rem;flex-wrap:wrap;border-top:1px solid rgba(245,242,234,.1);background:#10131a}
.fence-btn{
  flex:1 1 auto;min-width:96px;
  display:flex;flex-direction:column;align-items:center;gap:.45rem;
  padding:.7rem .4rem;border-radius:var(--radius);cursor:pointer;
  background:#1b212b;border:1.5px solid rgba(245,242,234,.08);
  color:rgba(245,242,234,.8);transition:.18s;
}
.fence-btn i{font-size:1.25rem;color:var(--steel-2);transition:.18s}
.fence-btn span{font-size:.72rem;font-weight:500;text-align:center;line-height:1.15}
.fence-btn:hover{border-color:rgba(255,106,26,.5);transform:translateY(-2px)}
.fence-btn.active{background:rgba(255,106,26,.12);border-color:var(--amber);color:var(--white)}
.fence-btn.active i{color:var(--amber)}
.constructor-readout{
  padding:.85rem 1rem;display:flex;align-items:center;justify-content:space-between;gap:1rem;
  background:var(--ink-2);border-top:1px solid rgba(245,242,234,.1);flex-wrap:wrap;
}
.constructor-readout .ro-name{font-weight:600}
.constructor-readout .ro-meta{font-family:var(--f-mono);font-size:.78rem;color:var(--steel-2)}
.constructor-readout .ro-meta b{color:var(--amber);font-weight:500}

@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(255,106,26,.55)}70%{box-shadow:0 0 0 9px rgba(255,106,26,0)}100%{box-shadow:0 0 0 0 rgba(255,106,26,0)}}

/* hazard полоса-разделитель */
.hazard{height:8px;background-image:repeating-linear-gradient(45deg,var(--amber) 0 14px,var(--ink) 14px 28px)}

/* ─── общие секции ────────────────────────────────────────────────────────── */
.section{padding:clamp(3.5rem,7vw,6rem) 0}
.section.light{background:var(--paper)}
.section.paper-2{background:var(--paper-2)}
.section.dark{background:var(--ink);color:var(--paper)}
.section-head{max-width:60ch;margin-bottom:2.6rem}
.section-head.center{margin-left:auto;margin-right:auto;text-align:center}
.section-head p{color:var(--steel);font-size:1.08rem}
.dark .section-head p{color:rgba(245,242,234,.7)}

/* ─── карточки заборов (3D-tilt) ──────────────────────────────────────────── */
.type-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1.4rem}
.type-card{
  background:var(--white);border:1px solid var(--line);border-radius:var(--radius-l);
  overflow:hidden;transform-style:preserve-3d;will-change:transform;
  box-shadow:var(--shadow);display:flex;flex-direction:column;
}
.type-card .tc-media{aspect-ratio:4/3;position:relative;overflow:hidden}
.type-card .tc-body{padding:1.3rem;display:flex;flex-direction:column;flex:1;transform:translateZ(30px)}
.type-card h3{margin-bottom:.4rem}
.type-card .tc-desc{color:var(--steel);font-size:.92rem;flex:1;margin-bottom:1rem}
.type-card .tc-foot{display:flex;align-items:center;justify-content:space-between;gap:.5rem;margin-top:auto}
.type-card .tc-price{font-family:var(--f-mono);font-weight:500;color:var(--ink)}
.type-card .tc-term{font-family:var(--f-mono);font-size:.74rem;color:var(--amber-deep);
  display:inline-flex;align-items:center;gap:.4rem}
.tc-link{margin-top:1rem;font-weight:600;color:var(--amber-deep);display:inline-flex;align-items:center;gap:.5rem;transition:gap .18s}
.type-card:hover .tc-link{gap:.85rem}

/* плейсхолдер-изображение (фото-заглушка) */
.ph{
  width:100%;height:100%;
  background:
    repeating-linear-gradient(45deg,rgba(20,23,28,.04) 0 12px,transparent 12px 24px),
    linear-gradient(135deg,var(--paper-2),var(--paper-3));
  display:grid;place-items:center;color:var(--steel);position:relative;
}
.ph i{font-size:2rem;opacity:.4}
.ph .ph-tag{position:absolute;left:10px;bottom:10px;font-family:var(--f-mono);font-size:.62rem;
  text-transform:uppercase;letter-spacing:.12em;color:var(--steel);opacity:.7}
.ph.dark{background:repeating-linear-gradient(45deg,rgba(255,255,255,.03) 0 12px,transparent 12px 24px),linear-gradient(135deg,#1b212b,#11151c);color:var(--steel-2)}

/* ─── этапы работы (timeline) ─────────────────────────────────────────────── */
.steps{display:grid;grid-template-columns:repeat(5,1fr);gap:0;counter-reset:step;position:relative}
.steps::before{content:"";position:absolute;top:34px;left:8%;right:8%;height:2px;
  background-image:repeating-linear-gradient(90deg,var(--line-strong) 0 8px,transparent 8px 16px)}
.step{padding:0 .8rem;text-align:center;position:relative}
.step .s-dot{
  width:70px;height:70px;margin:0 auto 1rem;border-radius:50%;
  background:var(--paper);border:2px solid var(--ink);
  display:grid;place-items:center;position:relative;z-index:2;
  font-size:1.5rem;color:var(--ink);
}
.step:last-child .s-dot{background:var(--amber);border-color:var(--amber);color:#241200}
.step .s-num{font-family:var(--f-mono);font-size:.72rem;color:var(--amber-deep);letter-spacing:.1em;margin-bottom:.3rem}
.step h3{font-size:1.05rem;margin-bottom:.3rem}
.step p{font-size:.86rem;color:var(--steel);margin:0}

/* ─── таймлапс монтажа (фишка) ────────────────────────────────────────────── */
.timelapse{background:var(--ink-2);border-radius:var(--radius-l);overflow:hidden;border:1px solid rgba(245,242,234,.1)}
.timelapse-stage{position:relative;aspect-ratio:21/9;background:linear-gradient(180deg,#161b22,#0e1117)}
.timelapse-stage svg{width:100%;height:100%}
.timelapse-foot{display:flex;align-items:center;gap:1rem;padding:1rem 1.3rem;flex-wrap:wrap}
.tl-progress{flex:1;height:6px;background:rgba(245,242,234,.12);border-radius:99px;overflow:hidden;min-width:140px}
.tl-progress i{display:block;height:100%;width:0;background:var(--amber);border-radius:99px}
.tl-label{font-family:var(--f-mono);font-size:.78rem;color:var(--steel-2)}
.tl-label b{color:var(--amber);font-weight:500}
.tl-replay{background:none;border:1.5px solid rgba(245,242,234,.25);color:var(--paper);
  border-radius:var(--radius);padding:.45rem .9rem;cursor:pointer;font-family:var(--f-mono);font-size:.78rem;transition:.15s}
.tl-replay:hover{border-color:var(--amber);color:var(--amber)}

/* ─── преимущества ────────────────────────────────────────────────────────── */
.adv-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1.2rem}
.adv{padding:1.8rem;background:var(--white);border:1px solid var(--line);border-radius:var(--radius-l);
  position:relative;overflow:hidden}
.adv::before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--amber)}
.adv .adv-ico{font-size:1.7rem;color:var(--amber-deep);margin-bottom:1rem}
.adv h3{font-size:1.15rem;margin-bottom:.4rem}
.adv p{color:var(--steel);font-size:.92rem;margin:0}
.dark .adv{background:var(--ink-2);border-color:rgba(245,242,234,.1)}
.dark .adv p{color:rgba(245,242,234,.65)}

/* ─── зона выезда ─────────────────────────────────────────────────────────── */
.zone{display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:center}
.zone-map{aspect-ratio:1/1;max-width:460px;width:100%;margin:0 auto;position:relative}
.zone-tags{display:flex;flex-wrap:wrap;gap:.6rem;margin-top:1.5rem}
.zone-tag{font-family:var(--f-mono);font-size:.85rem;padding:.45rem .9rem;border:1px solid var(--line-strong);
  border-radius:99px;background:var(--white);display:inline-flex;align-items:center;gap:.5rem;transition:.15s}
.zone-tag::before{content:"●";color:var(--amber);font-size:.6rem}
.zone-tag:hover{border-color:var(--amber);transform:translateY(-2px)}
.dark .zone-tag{background:var(--ink-2);border-color:rgba(245,242,234,.14);color:var(--paper)}

/* ─── отзывы (swiper) ─────────────────────────────────────────────────────── */
.reviews-wrap{position:relative}
.review-card{
  background:var(--white);border:1px solid var(--line);border-radius:var(--radius-l);
  padding:2rem;height:auto;display:flex;flex-direction:column;gap:1rem;
}
.review-card .quote{font-size:2.5rem;color:var(--amber);line-height:.5;font-family:Georgia,serif;height:1rem}
.review-card .r-text{color:var(--ink);font-size:.98rem;flex:1}
.review-card .r-foot{display:flex;align-items:center;gap:.9rem;border-top:1px solid var(--line);padding-top:1rem}
.review-card .r-ava{width:46px;height:46px;border-radius:50%;background:var(--ink);color:var(--amber);
  display:grid;place-items:center;font-weight:700;font-family:var(--f-mono);flex-shrink:0}
.review-card .r-name{font-weight:600}
.review-card .r-date{font-family:var(--f-mono);font-size:.74rem;color:var(--steel-2)}
.swiper{padding-bottom:3.5rem!important}
.swiper-pagination-bullet{background:var(--steel)!important}
.swiper-pagination-bullet-active{background:var(--amber)!important}
.swiper-button-next,.swiper-button-prev{color:var(--ink)!important}
.swiper-button-next::after,.swiper-button-prev::after{font-size:1.3rem!important;font-weight:700}
.dark .review-card{background:var(--ink-2);border-color:rgba(245,242,234,.1)}
.dark .review-card .r-text{color:rgba(245,242,234,.85)}
.dark .swiper-button-next,.dark .swiper-button-prev{color:var(--paper)!important}

/* ─── форма заявки ────────────────────────────────────────────────────────── */
.lead-section{background:var(--ink);color:var(--paper);position:relative;overflow:hidden}
.lead-section::before{content:"";position:absolute;inset:0;opacity:.4;
  background-image:linear-gradient(var(--line-blue) 1px,transparent 1px),linear-gradient(90deg,var(--line-blue) 1px,transparent 1px);
  background-size:46px 46px;mask-image:radial-gradient(circle at 20% 80%,#000,transparent 70%)}
.lead-grid{display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:center;position:relative}
.lead-form{background:var(--paper);color:var(--ink);padding:2.2rem;border-radius:var(--radius-l);box-shadow:var(--shadow-l)}
.lead-form h3{margin-bottom:.4rem}
.lead-form .lf-sub{color:var(--steel);font-size:.92rem;margin-bottom:1.4rem}
.field{margin-bottom:1rem}
.field label{display:block;font-family:var(--f-mono);font-size:.72rem;text-transform:uppercase;
  letter-spacing:.12em;color:var(--steel);margin-bottom:.4rem}
.f-input,.form-control{
  width:100%;padding:.85rem 1rem;font-family:var(--f-sans);font-size:1rem;
  border:1.5px solid var(--line-strong);border-radius:var(--radius);background:var(--white);color:var(--ink);
  transition:border-color .15s, box-shadow .15s;
}
.f-input:focus,.form-control:focus{outline:none;border-color:var(--amber);box-shadow:0 0 0 3px rgba(255,106,26,.15)}
textarea.f-input{resize:vertical;min-height:96px}
.form-note{font-size:.78rem;color:var(--steel);margin-top:.8rem}
.form-note a{color:var(--amber-deep);text-decoration:underline}
.form-err{color:#c0392b;font-size:.82rem;margin-top:.3rem}
.hp-field{position:absolute!important;left:-9999px!important;width:1px;height:1px;overflow:hidden}

/* django messages */
.flash{padding:.9rem 1.2rem;border-radius:var(--radius);margin-bottom:1rem;font-size:.92rem;border-left:4px solid}
.flash.success{background:#e7f4ea;border-color:var(--green);color:#1e5a2b}
.flash.error{background:#fbeae8;border-color:#c0392b;color:#922}

/* ─── floating call ───────────────────────────────────────────────────────── */
.floating-call{
  position:fixed;right:22px;bottom:22px;z-index:900;
  width:62px;height:62px;border-radius:50%;background:var(--amber);color:#241200;
  display:grid;place-items:center;font-size:1.5rem;box-shadow:0 12px 30px -8px rgba(226,82,10,.6);
  animation:floatpulse 2.4s infinite;transition:transform .2s;
}
.floating-call:hover{transform:scale(1.08)}
@keyframes floatpulse{0%{box-shadow:0 12px 30px -8px rgba(226,82,10,.6),0 0 0 0 rgba(255,106,26,.5)}
  70%{box-shadow:0 12px 30px -8px rgba(226,82,10,.6),0 0 0 16px rgba(255,106,26,0)}
  100%{box-shadow:0 12px 30px -8px rgba(226,82,10,.6),0 0 0 0 rgba(255,106,26,0)}}

/* ─── page-hero (внутренние страницы) ─────────────────────────────────────── */
.page-hero{background:var(--ink);color:var(--paper);padding:clamp(2.5rem,5vw,3.6rem) 0;position:relative;overflow:hidden}
.page-hero::before{content:"";position:absolute;inset:0;opacity:.4;pointer-events:none;
  background-image:linear-gradient(var(--line-blue) 1px,transparent 1px),linear-gradient(90deg,var(--line-blue) 1px,transparent 1px);
  background-size:42px 42px;mask-image:radial-gradient(circle at 80% 20%,#000,transparent 75%)}
.page-hero .container{position:relative}
.page-hero h1{margin-bottom:.6rem}
.page-hero .ph-desc{color:rgba(245,242,234,.75);font-size:1.1rem;max-width:60ch}
.breadcrumbs{font-family:var(--f-mono);font-size:.78rem;color:var(--steel-2);margin-bottom:1.2rem;display:flex;gap:.5rem;flex-wrap:wrap}
.breadcrumbs a{color:var(--steel-2)}
.breadcrumbs a:hover{color:var(--amber)}
.breadcrumbs span{color:rgba(245,242,234,.4)}

/* ─── список услуг (категория) ────────────────────────────────────────────── */
.svc-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.5rem}
.svc-card{background:var(--white);border:1px solid var(--line);border-radius:var(--radius-l);overflow:hidden;
  display:flex;flex-direction:column;transition:transform .2s, box-shadow .2s}
.svc-card:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.svc-card .svc-media{aspect-ratio:16/10;overflow:hidden}
.svc-card .svc-body{padding:1.4rem;display:flex;flex-direction:column;flex:1}
.svc-card h3{font-size:1.2rem;margin-bottom:.5rem}
.svc-card .svc-desc{color:var(--steel);font-size:.92rem;flex:1;margin-bottom:1rem}
.svc-card .svc-foot{display:flex;align-items:center;justify-content:space-between;gap:.5rem;margin-top:auto}
.svc-card .svc-price{font-family:var(--f-mono);font-weight:500}
.badge-feat{font-family:var(--f-mono);font-size:.64rem;text-transform:uppercase;letter-spacing:.1em;
  background:var(--amber);color:#241200;padding:.2rem .5rem;border-radius:3px}

/* SEO-блок */
.seo-block{max-width:78ch;color:var(--steel);font-size:1.02rem}
.seo-block h2{color:var(--ink);margin-bottom:1rem}
.seo-block p{margin-bottom:1rem}

/* ─── деталь услуги ───────────────────────────────────────────────────────── */
.detail-grid{display:grid;grid-template-columns:1.2fr 1fr;gap:3rem;align-items:start}
.detail-media{border-radius:var(--radius-l);overflow:hidden;aspect-ratio:4/3;border:1px solid var(--line)}
.spec-table{width:100%;border-collapse:collapse;margin:1.5rem 0;font-size:.95rem}
.spec-table th,.spec-table td{text-align:left;padding:.8rem 0;border-bottom:1px solid var(--line)}
.spec-table th{font-family:var(--f-mono);font-weight:500;font-size:.78rem;text-transform:uppercase;
  letter-spacing:.08em;color:var(--steel);width:45%;vertical-align:top}
.spec-table td{font-weight:500}
.detail-price{font-family:var(--f-mono);font-size:1.8rem;font-weight:500;color:var(--ink);margin:.5rem 0 1rem}
.prose{color:var(--ink)}
.prose h2{font-size:1.4rem;margin:1.6rem 0 .6rem}
.prose p{color:var(--steel);line-height:1.7}
.aside-card{background:var(--paper-2);border:1px solid var(--line);border-radius:var(--radius-l);padding:1.6rem;position:sticky;top:calc(var(--header-h) + 16px)}

/* ─── портфолио ───────────────────────────────────────────────────────────── */
.filter-bar{display:flex;gap:.6rem;flex-wrap:wrap;margin-bottom:2rem}
.filter-chip{font-family:var(--f-mono);font-size:.85rem;padding:.5rem 1.1rem;border:1.5px solid var(--line-strong);
  border-radius:99px;background:var(--white);transition:.15s;cursor:pointer}
.filter-chip:hover{border-color:var(--ink)}
.filter-chip.active{background:var(--ink);color:var(--paper);border-color:var(--ink)}
.portfolio-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.3rem}
.pf-card{border-radius:var(--radius-l);overflow:hidden;background:var(--white);border:1px solid var(--line);
  display:flex;flex-direction:column;transition:transform .2s, box-shadow .2s}
.pf-card:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.pf-media{aspect-ratio:4/3;position:relative;overflow:hidden}
.pf-cat{position:absolute;top:10px;left:10px;font-family:var(--f-mono);font-size:.66rem;text-transform:uppercase;
  letter-spacing:.08em;background:rgba(20,23,28,.85);color:var(--paper);padding:.3rem .6rem;border-radius:3px}
.pf-body{padding:1.1rem 1.3rem}
.pf-body h3{font-size:1.05rem;margin-bottom:.3rem}
.pf-body .pf-desc{font-size:.86rem;color:var(--steel);margin:0}
.pf-body .pf-date{font-family:var(--f-mono);font-size:.72rem;color:var(--steel-2);margin-top:.7rem}
.gate-badge{display:inline-block;font-family:var(--f-mono);font-size:.66rem;text-transform:uppercase;letter-spacing:.08em;
  color:var(--amber-deep);border:1px solid var(--amber);border-radius:3px;padding:.15rem .45rem;margin-top:.7rem}

/* галерея деталь */
.gallery{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:1rem}
.gallery .g-item{aspect-ratio:4/3;border-radius:var(--radius);overflow:hidden;border:1px solid var(--line)}

/* ─── блог ────────────────────────────────────────────────────────────────── */
.blog-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1.5rem}
.post-card{background:var(--white);border:1px solid var(--line);border-radius:var(--radius-l);overflow:hidden;
  display:flex;flex-direction:column;transition:transform .2s, box-shadow .2s}
.post-card:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.post-media{aspect-ratio:16/9;overflow:hidden}
.post-body{padding:1.4rem;display:flex;flex-direction:column;flex:1}
.post-body .p-date{font-family:var(--f-mono);font-size:.72rem;color:var(--amber-deep);letter-spacing:.06em;margin-bottom:.6rem}
.post-body h3{font-size:1.2rem;margin-bottom:.5rem}
.post-body .p-ex{color:var(--steel);font-size:.92rem;flex:1;margin-bottom:1rem}
.post-body .p-link{font-weight:600;color:var(--amber-deep);display:inline-flex;gap:.5rem;align-items:center;transition:gap .18s}
.post-card:hover .p-link{gap:.85rem}

.article{max-width:760px;margin:0 auto}
.article-cover{border-radius:var(--radius-l);overflow:hidden;aspect-ratio:16/8;margin-bottom:2rem;border:1px solid var(--line)}
.article .prose h2{font-size:1.5rem;margin:2rem 0 .8rem;color:var(--ink)}
.article .prose p{font-size:1.06rem;line-height:1.8;color:#33383f}

.pagination{display:flex;gap:.4rem;justify-content:center;margin-top:3rem;font-family:var(--f-mono)}
.pagination a,.pagination span{padding:.5rem .9rem;border:1px solid var(--line-strong);border-radius:var(--radius);font-size:.9rem}
.pagination .current{background:var(--ink);color:var(--paper);border-color:var(--ink)}
.pagination a:hover{border-color:var(--amber)}

/* ─── контакты ────────────────────────────────────────────────────────────── */
.contacts-grid{display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:start}
.contact-list{list-style:none;padding:0;margin:0 0 2rem;display:flex;flex-direction:column;gap:1.3rem}
.contact-list li{display:flex;gap:1rem;align-items:flex-start}
.contact-list .ci-ico{width:46px;height:46px;border-radius:var(--radius);background:var(--ink);color:var(--amber);
  display:grid;place-items:center;font-size:1.15rem;flex-shrink:0}
.contact-list .ci-lbl{font-family:var(--f-mono);font-size:.7rem;text-transform:uppercase;letter-spacing:.12em;color:var(--steel)}
.contact-list .ci-val{font-size:1.1rem;font-weight:600}
.map-embed{border-radius:var(--radius-l);overflow:hidden;border:1px solid var(--line);min-height:300px;background:var(--paper-2)}
.map-embed iframe{width:100%;height:100%;min-height:300px;border:0;display:block}

/* ─── footer ──────────────────────────────────────────────────────────────── */
.site-footer{background:var(--ink);color:rgba(245,242,234,.7);padding:3.5rem 0 1.5rem;position:relative}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.2fr;gap:2.5rem;margin-bottom:2.5rem}
.footer-grid h4{color:var(--paper);font-size:1rem;margin-bottom:1.1rem;font-family:var(--f-mono);
  font-weight:500;text-transform:uppercase;letter-spacing:.1em}
.footer-grid a{display:block;padding:.3rem 0;color:rgba(245,242,234,.7);transition:color .15s}
.footer-grid a:hover{color:var(--amber)}
.footer-about p{font-size:.92rem;color:rgba(245,242,234,.6);margin-top:1rem}
.footer-phone{font-size:1.3rem;font-weight:700;color:var(--paper);display:block;margin-bottom:.4rem}
.footer-bottom{border-top:1px solid rgba(245,242,234,.1);padding-top:1.5rem;
  display:flex;justify-content:space-between;gap:1rem;flex-wrap:wrap;font-size:.82rem;color:rgba(245,242,234,.5)}
.footer-bottom a{color:rgba(245,242,234,.6)}
.footer-bottom a:hover{color:var(--amber)}

/* ─── cookie consent ──────────────────────────────────────────────────────── */
.cookie-bar{
  position:fixed;left:16px;right:16px;bottom:16px;z-index:1100;max-width:760px;margin:0 auto;
  background:var(--ink);color:var(--paper);border:1px solid rgba(245,242,234,.14);
  border-radius:var(--radius-l);box-shadow:var(--shadow-l);
  padding:1.2rem 1.4rem;display:flex;align-items:center;gap:1.2rem;flex-wrap:wrap;
  transform:translateY(140%);transition:transform .4s cubic-bezier(.2,.8,.2,1);
}
.cookie-bar.show{transform:translateY(0)}
.cookie-bar .ck-text{flex:1;min-width:240px;font-size:.9rem;color:rgba(245,242,234,.8)}
.cookie-bar .ck-text a{color:var(--amber);text-decoration:underline}
.cookie-bar .ck-actions{display:flex;gap:.6rem;flex-shrink:0}

/* ─── утилиты ─────────────────────────────────────────────────────────────── */
.text-center{text-align:center}
.mt-section{margin-top:clamp(2.5rem,5vw,4rem)}
.cta-row{display:flex;gap:1rem;flex-wrap:wrap;justify-content:center;margin-top:2.2rem}

/* ─── адаптив ─────────────────────────────────────────────────────────────── */
@media(max-width:992px){
  .hero-grid,.zone,.lead-grid,.detail-grid,.contacts-grid{grid-template-columns:1fr}
  .detail-grid .aside-card{position:static}
  .steps{grid-template-columns:repeat(2,1fr);gap:2rem 0}
  .steps::before{display:none}
  .footer-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:768px){
  .main-nav,.header-phone{display:none}
  .nav-toggle{display:block}
  .header-inner{gap:1rem}
  .hero{padding-top:2rem}
  .footer-grid{grid-template-columns:1fr}
  .lead-form{padding:1.6rem}
  .floating-call{width:54px;height:54px;font-size:1.3rem}
}
@media(max-width:480px){
  .steps{grid-template-columns:1fr}
  .constructor-controls{gap:.4rem}
  .fence-btn{min-width:0;flex:1 1 30%}
}

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

/* ─── статус формы / доп-утилиты (main.js) ───────────────────────────────── */
.form-status{font-size:.9rem;margin-top:.8rem;min-height:1.2em}
.form-status.ok{color:var(--green);font-weight:600}
.form-status.err{color:#c0392b;font-weight:600}
.dark .form-status.ok{color:#7fd193}

/* перечень-«галочки» в тёмной форме-секции */
.lead-points{list-style:none;padding:0;margin:1.5rem 0 0;display:flex;flex-direction:column;gap:.9rem}
.lead-points li{display:flex;gap:.8rem;align-items:flex-start;color:rgba(245,242,234,.85)}
.lead-points i{color:var(--amber);margin-top:.2rem;flex-shrink:0}
.lead-points b{color:var(--paper)}

/* «бейджи доверия» в hero */
.hero-badges{display:flex;flex-wrap:wrap;gap:.6rem;margin-bottom:1.6rem}
.hero-badge{font-family:var(--f-mono);font-size:.74rem;letter-spacing:.04em;padding:.35rem .7rem;
  border:1px solid rgba(245,242,234,.2);border-radius:99px;color:rgba(245,242,234,.85);display:inline-flex;gap:.45rem;align-items:center}
.hero-badge i{color:var(--amber)}

/* внутренний CTA-блок */
.cta-band{background:var(--amber);color:#241200;border-radius:var(--radius-l);padding:clamp(2rem,4vw,3rem);
  display:flex;align-items:center;justify-content:space-between;gap:2rem;flex-wrap:wrap}
.cta-band h2{margin:0;max-width:24ch}
.cta-band .btn-ghost{border-color:rgba(36,18,0,.4);color:#241200}
.cta-band .btn-ghost:hover{background:#241200;color:var(--amber);border-color:#241200}

/* «список фактов» на детальной */
.fact-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.7rem}
.fact-list li{display:flex;gap:.7rem;align-items:flex-start;font-size:.95rem}
.fact-list i{color:var(--green);margin-top:.25rem}

/* prose-списки */
.prose ul{padding-left:1.2rem;color:var(--steel);line-height:1.7;margin:0 0 1rem}
.prose li{margin-bottom:.4rem}
.prose a{color:var(--amber-deep);text-decoration:underline}

/* aside-card элементы */
.aside-card h3{font-size:1.2rem;margin-bottom:.4rem}
.aside-card .ac-price{font-family:var(--f-mono);font-size:1.5rem;font-weight:500;margin:.4rem 0 1rem;color:var(--ink)}
.aside-card .ac-note{font-size:.82rem;color:var(--steel);margin-top:.8rem}

/* related grid компактный */
.mini-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:1rem}

/* light-bg инпуты (контактная форма) */
.f-input.light-bg{background:var(--white)}
/* swiper высота отзывов */
.reviews-swiper{padding-bottom:3.2rem!important}
.reviews-swiper .swiper-slide{height:auto;display:flex}
.reviews-swiper .swiper-slide>*{width:100%}

/* ─── прайс-блок (services/price.html) ───────────────────────────────────── */
.price-wrap{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem}
.price-card{background:var(--white);border:1px solid var(--line);border-radius:var(--radius-l);overflow:hidden}
.price-card .pc-head{display:flex;align-items:center;gap:.7rem;padding:1.1rem 1.4rem;background:var(--ink);color:var(--paper)}
.price-card .pc-head i{color:var(--amber);font-size:1.2rem}
.price-card .pc-head h3{margin:0;font-size:1.12rem;color:var(--paper)}
.price-row{display:flex;justify-content:space-between;gap:1rem;align-items:baseline;
  padding:.85rem 1.4rem;border-bottom:1px solid var(--line)}
.price-row:last-child{border-bottom:0}
.price-row .pr-name{font-weight:500}
.price-row .pr-name a:hover{color:var(--amber-deep)}
.price-row .pr-val{font-family:var(--f-mono);font-weight:500;color:var(--amber-deep);white-space:nowrap}
.price-note{font-size:.85rem;color:var(--steel);margin-top:1.4rem;text-align:center}
