/* ============================================================================
   ГК Такт — Коломна  ·  site.css
   Концепт: «Квиз-подбор забора за 60 секунд» — яркий интерактивный лид-магнит.
   Палитра: ink (графит) · lime (электрический лайм) · coral (CTA) · sky (акцент)
   Шрифты: IBM Plex Sans (текст) + IBM Plex Mono (акценты/цифры)
   ========================================================================== */

:root {
  --ink:        #14161b;
  --ink-2:      #1d2129;
  --ink-3:      #2b313c;
  --lime:       #c7f940;
  --lime-600:   #a7e000;
  --lime-700:   #8fc400;
  --coral:      #ff5c39;
  --coral-600:  #ef4423;
  --sky:        #2ec5ff;
  --cream:      #faf9f3;
  --paper:      #ffffff;
  --paper-2:    #f3f2ea;
  --text:       #1b1e25;
  --muted:      #677084;
  --line:       rgba(20,22,27,.10);
  --line-2:     rgba(20,22,27,.06);
  --ring:       rgba(199,249,64,.55);

  --shadow-sm:  0 2px 8px rgba(20,22,27,.06);
  --shadow:     0 10px 30px rgba(20,22,27,.10);
  --shadow-lg:  0 24px 60px rgba(20,22,27,.18);
  --shadow-pop: 0 18px 44px rgba(255,92,57,.28);

  --r-sm: 10px;
  --r:    16px;
  --r-lg: 24px;
  --r-xl: 32px;

  --font-sans: 'IBM Plex Sans', system-ui, -apple-system, Segoe UI, Roboto, sans-serif;
  --font-mono: 'IBM Plex Mono', ui-monospace, SFMono-Regular, Menlo, monospace;

  --container: 1200px;
}

/* ── base ─────────────────────────────────────────────────────────────────── */
* { box-sizing: border-box; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
body {
  font-family: var(--font-sans);
  color: var(--text);
  background: var(--cream);
  line-height: 1.6;
  margin: 0;
  overflow-x: hidden;
  font-size: 17px;
}
img { max-width: 100%; height: auto; display: block; }
a { color: inherit; text-decoration: none; transition: color .2s ease; }
a:hover { color: var(--coral-600); }
h1,h2,h3,h4,h5 { font-weight: 700; line-height: 1.12; letter-spacing: -.02em; color: var(--ink); margin: 0 0 .5em; }
p { margin: 0 0 1rem; }
::selection { background: var(--lime); color: var(--ink); }

.container-tk { width: 100%; max-width: var(--container); margin-inline: auto; padding-inline: 20px; }

.font-mono { font-family: var(--font-mono); }
.text-coral { color: var(--coral); }
.text-lime  { color: var(--lime-700); }
.text-muted-tk { color: var(--muted); }

/* utility section spacing */
.section { padding: clamp(56px, 7vw, 110px) 0; position: relative; }
.section--tight { padding: clamp(40px, 5vw, 72px) 0; }

/* eyebrow / kicker */
.kicker {
  display: inline-flex; align-items: center; gap: .5em;
  font-family: var(--font-mono); font-size: .78rem; font-weight: 600;
  letter-spacing: .12em; text-transform: uppercase; color: var(--coral-600);
  background: rgba(255,92,57,.10); border: 1px solid rgba(255,92,57,.22);
  padding: .4em .9em; border-radius: 999px;
}
.kicker--lime { color: var(--ink); background: var(--lime); border-color: var(--lime-600); }
.kicker--ghost { color: var(--lime); background: rgba(199,249,64,.08); border-color: rgba(199,249,64,.25); }

.section-head { max-width: 720px; margin-bottom: clamp(28px,4vw,52px); }
.section-head h2 { font-size: clamp(1.9rem, 3.6vw, 3rem); margin-top: .55rem; }
.section-head p { color: var(--muted); font-size: 1.08rem; }
.section-head--center { margin-inline: auto; text-align: center; }

/* ── buttons ──────────────────────────────────────────────────────────────── */
.btn-tk {
  --b: var(--coral); --bt: #fff;
  display: inline-flex; align-items: center; justify-content: center; gap: .6em;
  font-family: var(--font-sans); font-weight: 600; font-size: 1rem;
  padding: .92em 1.6em; border-radius: 999px; border: 0; cursor: pointer;
  background: var(--b); color: var(--bt); line-height: 1;
  transition: transform .18s cubic-bezier(.2,.8,.2,1), box-shadow .2s, background .2s;
  box-shadow: var(--shadow-pop); text-align: center;
}
.btn-tk:hover { transform: translateY(-2px); color: #fff; background: var(--coral-600); }
.btn-tk:active { transform: translateY(0); }
.btn-tk i { font-size: 1.05em; }

.btn-lime { --b: var(--lime); --bt: var(--ink); box-shadow: 0 16px 38px rgba(167,224,0,.35); }
.btn-lime:hover { background: var(--lime-600); color: var(--ink); }

.btn-ink { --b: var(--ink); --bt: #fff; box-shadow: var(--shadow); }
.btn-ink:hover { background: #000; color:#fff; }

.btn-ghost {
  background: transparent; color: var(--ink); box-shadow: none;
  border: 1.5px solid var(--line); 
}
.btn-ghost:hover { background: var(--ink); color: #fff; border-color: var(--ink); transform: translateY(-2px); }
.btn-ghost--light { color:#fff; border-color: rgba(255,255,255,.3); }
.btn-ghost--light:hover { background:#fff; color: var(--ink); border-color:#fff; }

.btn-sm { padding: .68em 1.15em; font-size: .92rem; }
.btn-lg { padding: 1.05em 2em; font-size: 1.1rem; }
.btn-block { width: 100%; }

/* ── header ───────────────────────────────────────────────────────────────── */
.topbar {
  background: var(--ink); color: rgba(255,255,255,.78);
  font-size: .86rem; padding: 7px 0;
}
.topbar a { color: rgba(255,255,255,.78); }
.topbar a:hover { color: var(--lime); }
.topbar__row { display: flex; align-items: center; justify-content: space-between; gap: 16px; flex-wrap: wrap; }
.topbar__left { display:flex; gap: 20px; flex-wrap: wrap; }
.topbar__item { display:inline-flex; align-items:center; gap:.45em; }
.topbar__item i { color: var(--lime); }
.topbar__socials { display:flex; gap: 12px; }
.topbar__socials a { font-size: 1rem; }

.site-header {
  position: sticky; top: 0; z-index: 1030;
  background: rgba(250,249,243,.86);
  backdrop-filter: saturate(150%) blur(12px);
  border-bottom: 1px solid var(--line);
  transition: box-shadow .25s, background .25s;
}
.site-header.is-stuck { box-shadow: var(--shadow-sm); background: rgba(250,249,243,.96); }
.navbar-tk { display: flex; align-items: center; gap: 15px; min-height: 74px; }

.brand { display:flex; align-items:center; gap: 12px; flex-shrink: 0; }
.brand__mark {
  width: 44px; height: 44px; border-radius: 12px; flex-shrink: 0;
  display:grid; place-items:center; font-family: var(--font-mono); font-weight: 700;
  background: var(--ink); color: var(--lime); font-size: 1.25rem;
  box-shadow: var(--shadow-sm); position: relative; overflow: hidden;
}
.brand__mark::after { content:""; position:absolute; inset: 0; background:
  repeating-linear-gradient(135deg, transparent 0 6px, rgba(199,249,64,.14) 6px 7px); }
.brand__name { font-weight: 700; font-size: 1.18rem; letter-spacing: -.02em; color: var(--ink); line-height: 1; display: block;}
.brand__sub { font-size: .72rem; color: var(--muted); font-family: var(--font-mono); letter-spacing: .02em; display: block; }

.main-nav { display: flex; align-items: center; gap: 4px; margin: 0 auto 0 8px; }
.main-nav a {
  padding: .55em .75em; border-radius: 25px; font-weight: 500; font-size: .98rem;
  color: var(--ink); position: relative;
}
.main-nav a:hover { background: rgba(20,22,27,.05); color: var(--ink); }
.main-nav a.active { background: var(--ink); color: #fff; }

.header-cta { display:flex; align-items:center; gap: 14px; flex-shrink: 0; }
.header-phone { font-family: var(--font-mono); font-weight: 600; font-size: 1.02rem; white-space: nowrap; letter-spacing: -1px; }
.header-phone span { display:block; font-size:.66rem; font-family: var(--font-sans); color: var(--muted); font-weight:500; letter-spacing: normal; }

.nav-toggle {
  display:none; width:46px; height:46px; border-radius:12px; border:1px solid var(--line);
  background: var(--paper); align-items:center; justify-content:center; font-size:1.3rem; color: var(--ink); cursor:pointer;
}

@media (max-width: 1100px) {
  .main-nav, .header-phone span { display: none; }
  .nav-toggle { display: inline-flex; }
}
@media (max-width: 560px) {
  .header-cta .btn-tk span.lbl { display:none; }
  .header-cta .btn-tk { padding: .8em; }
}

/* offcanvas mobile menu */
.tk-offcanvas { background: var(--ink); color:#fff; }
.tk-offcanvas .offcanvas-header { border-bottom:1px solid rgba(255,255,255,.1); }
.tk-offcanvas .btn-close { filter: invert(1) grayscale(1) brightness(1.6); }
.tk-offcanvas a { color:#fff; display:block; padding: .85rem .25rem; font-size: 1.15rem; border-bottom:1px solid rgba(255,255,255,.07); font-weight:500; }
.tk-offcanvas a:hover, .tk-offcanvas a.active { color: var(--lime); }

/* ── HERO + QUIZ ──────────────────────────────────────────────────────────── */
.hero {
  background: radial-gradient(120% 120% at 85% -10%, #20252f 0%, var(--ink) 55%, #0d0f13 100%);
  color: #fff; position: relative; overflow: hidden;
  padding: clamp(40px,6vw,80px) 0 clamp(56px,7vw,96px);
}
.hero::before { /* dotted grid texture */
  content:""; position:absolute; inset:0;
  background-image: radial-gradient(rgba(255,255,255,.06) 1px, transparent 1px);
  background-size: 22px 22px; opacity:.7; pointer-events:none;
}
.hero__glow { position:absolute; border-radius:50%; filter: blur(70px); opacity:.5; pointer-events:none; }
.hero__glow--lime { width: 360px; height:360px; background: var(--lime); top:-120px; left:-80px; opacity:.18; }
.hero__glow--coral { width: 420px; height:420px; background: var(--coral); bottom:-160px; right:-120px; opacity:.22; }

.hero__grid { display:grid; grid-template-columns: 1fr 1.05fr; gap: clamp(28px,4vw,56px); align-items:center; position:relative; z-index:2; }
@media (max-width: 980px){ .hero__grid { grid-template-columns: 1fr; } }

.hero h1 { color:#fff; font-size: clamp(2.1rem, 5vw, 3.6rem); margin-bottom:.5em; }
.hero h1 em { font-style: normal; color: var(--lime); }
.hero__lead { color: rgba(255,255,255,.82); font-size: 1.12rem; max-width: 520px; }
.hero__badges { display:flex; flex-wrap:wrap; gap: 10px; margin: 22px 0 26px; }
.hero__badge {
  display:inline-flex; align-items:center; gap:.5em; font-size:.86rem; font-weight:600;
  background: rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.12);
  padding:.5em .9em; border-radius: 999px; color:#fff;
}
.hero__badge i { color: var(--lime); }
.hero__stats { display:flex; gap: 28px; margin-top: 30px; flex-wrap:wrap; }
.hero__stat b { font-family: var(--font-mono); font-size: 1.9rem; color: var(--lime); display:block; line-height:1; }
.hero__stat span { font-size:.84rem; color: rgba(255,255,255,.7); }

/* QUIZ card */
.quiz {
  background: var(--paper); color: var(--text); border-radius: var(--r-xl);
  box-shadow: var(--shadow-lg); padding: clamp(22px,3vw,34px);
  position: relative; overflow: hidden;
}
.quiz::before { content:""; position:absolute; top:0; left:0; right:0; height:6px;
  background: linear-gradient(90deg, var(--coral), var(--lime), var(--sky)); }
.quiz__top { display:flex; align-items:center; justify-content:space-between; gap:12px; margin-bottom: 16px; }
.quiz__label { font-family: var(--font-mono); font-size:.8rem; font-weight:600; letter-spacing:.08em; text-transform:uppercase; color: var(--muted); }
.quiz__count { font-family: var(--font-mono); font-weight:700; color: var(--ink); }
.quiz__count b { color: var(--coral); }

.quiz__bar { height: 8px; border-radius:999px; background: var(--paper-2); overflow:hidden; margin-bottom: 22px; }
.quiz__bar > span { display:block; height:100%; background: linear-gradient(90deg, var(--lime-600), var(--lime)); border-radius:999px; transition: width .4s cubic-bezier(.2,.8,.2,1); }

.quiz__q { font-size: clamp(1.25rem,2.4vw,1.55rem); font-weight:700; margin-bottom: 18px; min-height: 2.2em; }

.quiz__options { display:grid; grid-template-columns: 1fr 1fr; gap: 12px; }
@media (max-width: 480px){ .quiz__options { grid-template-columns: 1fr; } }
.quiz__opt {
  display:flex; align-items:center; gap: 14px; text-align:left; cursor:pointer;
  background: var(--cream); border: 2px solid transparent; border-radius: var(--r);
  padding: 16px 16px; font-weight:600; font-size:1rem; color: var(--ink);
  transition: transform .15s, border-color .15s, background .15s, box-shadow .15s;
}
.quiz__opt:hover { transform: translateY(-2px); border-color: var(--lime-600); box-shadow: var(--shadow-sm); }
.quiz__opt.is-selected { border-color: var(--coral); background: #fff; box-shadow: var(--shadow-pop); }
.quiz__opt .ic {
  width: 46px; height: 46px; border-radius: 12px; flex-shrink:0; display:grid; place-items:center;
  background: var(--ink); color: var(--lime); font-size: 1.25rem;
}
.quiz__opt.is-selected .ic { background: var(--coral); color:#fff; }
.quiz__opt small { display:block; font-weight:500; font-size:.78rem; color: var(--muted); margin-top:2px; }

.quiz__nav { display:flex; justify-content:space-between; align-items:center; margin-top: 22px; gap: 12px; }
.quiz__back { background:none; border:0; color: var(--muted); font-weight:600; cursor:pointer; padding:.5em; display:inline-flex; align-items:center; gap:.4em; }
.quiz__back:hover { color: var(--ink); }
.quiz__back[disabled] { opacity:.35; cursor:not-allowed; }

/* quiz result */
.quiz__result { text-align:center; }
.quiz__result .ic-done { width:64px;height:64px;border-radius:50%; display:grid;place-items:center; margin:0 auto 14px; background: var(--lime); color: var(--ink); font-size:1.8rem; }
.quiz__result h3 { font-size: 1.5rem; }
.recos { display:grid; gap: 10px; margin: 18px 0; text-align:left; }
.reco {
  display:flex; align-items:center; gap: 14px; background: var(--cream);
  border:1px solid var(--line); border-radius: var(--r); padding: 12px 14px;
}
.reco .ic { width:42px;height:42px;border-radius:11px; flex-shrink:0; display:grid;place-items:center; background: var(--ink); color: var(--lime); }
.reco b { display:block; font-size:1rem; }
.reco span { font-family: var(--font-mono); font-size:.85rem; color: var(--coral-600); font-weight:600; }
.reco a.go { margin-left:auto; color: var(--ink); font-weight:600; white-space:nowrap; }
.reco a.go:hover { color: var(--coral-600); }

/* discount + timer */
.promo {
  display:flex; align-items:center; gap:14px; justify-content:center; flex-wrap:wrap;
  background: linear-gradient(100deg, rgba(255,92,57,.10), rgba(199,249,64,.14));
  border:1px dashed var(--coral); border-radius: var(--r); padding: 14px 16px; margin: 14px 0 18px;
}
.promo__gift { font-size:1.6rem; }
.promo__txt b { color: var(--coral-600); }
.timer { font-family: var(--font-mono); font-weight:700; font-size:1.25rem; background: var(--ink); color: var(--lime); padding:.25em .6em; border-radius:10px; letter-spacing:.04em; }
.timer.is-up { background: var(--coral); color:#fff; }

/* ── lead form fields ─────────────────────────────────────────────────────── */
.lead-form .field { margin-bottom: 12px; }
.lead-form label { font-weight:600; font-size:.9rem; margin-bottom:6px; display:block; }
.f-input, .lead-form input, .lead-form textarea {
  width:100%; font-family: var(--font-sans); font-size:1rem; color: var(--ink);
  background: var(--cream); border:1.5px solid var(--line); border-radius: var(--r-sm);
  padding: .85em 1em; transition: border-color .15s, box-shadow .15s, background .15s;
}
.f-input.light-bg { background:#fff; }
.lead-form input:focus, .lead-form textarea:focus, .f-input:focus {
  outline:none; border-color: var(--lime-600); box-shadow: 0 0 0 4px var(--ring); background:#fff;
}
.lead-form textarea { resize: vertical; min-height: 96px; }
.hp-field { position:absolute !important; left:-9999px !important; width:1px;height:1px; overflow:hidden; opacity:0; }
.form-consent { font-size:.8rem; color: var(--muted); margin-top:10px; }
.form-consent a { color: var(--coral-600); text-decoration: underline; }
.form-msg { margin-top:10px; font-size:.92rem; font-weight:600; min-height: 1.2em; }
.form-msg.ok { color: var(--lime-700); }
.form-msg.err { color: var(--coral-600); }

/* ── cards: services ──────────────────────────────────────────────────────── */
.cards-grid { display:grid; grid-template-columns: repeat(auto-fill, minmax(280px,1fr)); gap: 22px; }
.scard {
  background: var(--paper); border-radius: var(--r-lg); overflow:hidden;
  box-shadow: var(--shadow-sm); border:1px solid var(--line-2);
  display:flex; flex-direction:column; transition: transform .22s, box-shadow .22s;
  position: relative;
}
.scard:hover { transform: translateY(-6px); box-shadow: var(--shadow); }
.scard__media { aspect-ratio: 16/11; position:relative; overflow:hidden; background: var(--paper-2); }
.scard__media img { width:100%; height:100%; object-fit: cover; transition: transform .4s ease; }
.scard:hover .scard__media img { transform: scale(1.05); }
.scard__badge { position:absolute; top:12px; left:12px; z-index:2;
  font-size:.74rem; font-weight:700; font-family: var(--font-mono);
  background: var(--lime); color: var(--ink); padding:.35em .7em; border-radius:999px; }
.scard__body { padding: 20px 20px 22px; display:flex; flex-direction:column; flex:1; }
.scard__body h3 { font-size:1.18rem; margin-bottom:.4rem; }
.scard__body p { color: var(--muted); font-size:.95rem; margin-bottom: 1rem; flex:1; }
.scard__foot { display:flex; align-items:center; justify-content:space-between; gap:10px; margin-top:auto; }
.scard__price { font-family: var(--font-mono); font-weight:700; color: var(--ink); font-size:1.02rem; }
.scard__price small { display:block; font-size:.66rem; color: var(--muted); font-weight:500; font-family: var(--font-sans); }
.scard__link { color: var(--coral-600); font-weight:600; font-size:.92rem; display:inline-flex; align-items:center; gap:.35em; }
.scard__link:hover { gap:.6em; color: var(--coral-600); }

/* placeholder media (no image) */
.media-ph {
  width:100%; height:100%; display:grid; place-items:center; position:relative;
  background:
    linear-gradient(135deg, var(--ink) 0%, var(--ink-2) 100%);
  color: rgba(199,249,64,.9);
}
.media-ph::before { content:""; position:absolute; inset:0;
  background-image: repeating-linear-gradient(45deg, transparent 0 14px, rgba(255,255,255,.04) 14px 15px); }
.media-ph i { font-size: 2.4rem; opacity:.85; position:relative; }
.media-ph .ph-cap { position:absolute; bottom:10px; left:0; right:0; text-align:center; font-family: var(--font-mono); font-size:.7rem; letter-spacing:.1em; color: rgba(255,255,255,.45); text-transform:uppercase; }

/* ── advantages ───────────────────────────────────────────────────────────── */
.adv-grid { display:grid; grid-template-columns: repeat(auto-fit,minmax(220px,1fr)); gap: 18px; }
.adv {
  background: var(--paper); border-radius: var(--r-lg); padding: 26px 22px;
  border:1px solid var(--line-2); box-shadow: var(--shadow-sm); transition: transform .2s;
}
.adv:hover { transform: translateY(-4px); }
.adv .ic { width:56px;height:56px;border-radius:16px; display:grid;place-items:center; font-size:1.5rem; margin-bottom:14px; }
.adv:nth-child(4n+1) .ic { background: var(--lime); color: var(--ink); }
.adv:nth-child(4n+2) .ic { background: var(--coral); color:#fff; }
.adv:nth-child(4n+3) .ic { background: var(--ink); color: var(--lime); }
.adv:nth-child(4n+4) .ic { background: var(--sky); color: var(--ink); }
.adv h3 { font-size:1.12rem; margin-bottom:.4rem; }
.adv p { color: var(--muted); font-size:.93rem; margin:0; }

/* number stats band */
.stats-band { background: var(--ink); color:#fff; border-radius: var(--r-xl); padding: clamp(28px,4vw,44px); position:relative; overflow:hidden; }
.stats-band::after { content:""; position:absolute; inset:0; background-image: radial-gradient(rgba(255,255,255,.05) 1px, transparent 1px); background-size:20px 20px; }
.stats-row { display:grid; grid-template-columns: repeat(auto-fit,minmax(160px,1fr)); gap: 24px; position:relative; text-align:center; }
.stat b { font-family: var(--font-mono); font-size: clamp(2rem,4vw,2.9rem); color: var(--lime); display:block; line-height:1; }
.stat span { color: rgba(255,255,255,.75); font-size:.92rem; }

/* ── steps / timeline ─────────────────────────────────────────────────────── */
.steps { display:grid; grid-template-columns: repeat(auto-fit,minmax(220px,1fr)); gap: 20px; counter-reset: step; }
.step { position:relative; background: var(--paper); border-radius: var(--r-lg); padding: 28px 22px 24px; border:1px solid var(--line-2); box-shadow: var(--shadow-sm); }
.step__num { counter-increment: step; font-family: var(--font-mono); font-weight:700; font-size:1.05rem;
  width:42px;height:42px;border-radius:12px; background: var(--lime); color: var(--ink); display:grid; place-items:center; margin-bottom:14px; }
.step__num::before { content:"0" counter(step); }
.step h3 { font-size:1.1rem; margin-bottom:.4rem; }
.step p { color: var(--muted); font-size:.92rem; margin:0; }

/* ── masonry portfolio ────────────────────────────────────────────────────── */
.masonry { columns: 3 280px; column-gap: 18px; }
.masonry .pcard { break-inside: avoid; margin-bottom: 18px; }
.pcard {
  display:block; border-radius: var(--r-lg); overflow:hidden; position:relative;
  box-shadow: var(--shadow-sm); border:1px solid var(--line-2); background: var(--paper);
}
.pcard__media { position:relative; overflow:hidden; }
.pcard__media img { width:100%; display:block; transition: transform .45s ease; }
.pcard:hover .pcard__media img { transform: scale(1.06); }
.pcard__media .media-ph { aspect-ratio: 4/3; }
.pcard__overlay {
  position:absolute; inset:0; display:flex; flex-direction:column; justify-content:flex-end;
  padding: 16px; color:#fff; opacity:0; transition: opacity .25s;
  background: linear-gradient(to top, rgba(11,12,15,.85) 0%, rgba(11,12,15,0) 60%);
}
.pcard:hover .pcard__overlay { opacity:1; }
.pcard__overlay b { font-size:1rem; }
.pcard__overlay .tag { font-family: var(--font-mono); font-size:.74rem; color: var(--lime); text-transform:uppercase; letter-spacing:.08em; }
.pcard__zoom { position:absolute; top:12px; right:12px; width:40px;height:40px; border-radius:50%;
  background: rgba(255,255,255,.9); color: var(--ink); display:grid;place-items:center; opacity:0; transform: scale(.7); transition:.25s; }
.pcard:hover .pcard__zoom { opacity:1; transform: scale(1); }

@media (max-width: 700px){ .masonry { columns: 2 150px; } }
@media (max-width: 460px){ .masonry { columns: 1; } }

/* ── reviews (swiper) ─────────────────────────────────────────────────────── */
.review-card {
  background: var(--paper); border-radius: var(--r-lg); padding: 28px 26px;
  border:1px solid var(--line-2); box-shadow: var(--shadow-sm); height:100%;
  display:flex; flex-direction:column;
}
.review-card .stars { color: var(--coral); margin-bottom: 10px; font-size:.95rem; letter-spacing:1px; }
.review-card__text { font-size:1rem; color: var(--text); flex:1; margin-bottom: 18px; }
.review-card__foot { display:flex; align-items:center; gap: 12px; }
.review-card__ava { width:48px;height:48px;border-radius:50%; flex-shrink:0; display:grid;place-items:center;
  background: var(--lime); color: var(--ink); font-weight:700; font-family: var(--font-mono); font-size:1.1rem; object-fit:cover; }
.review-card__name { font-weight:700; }
.review-card__date { font-size:.82rem; color: var(--muted); font-family: var(--font-mono); }

.swiper { padding-bottom: 50px !important; }
.swiper-pagination-bullet { background: var(--ink); opacity:.25; }
.swiper-pagination-bullet-active { background: var(--coral); opacity:1; width: 22px; border-radius:6px; }
.swiper-button-next, .swiper-button-prev { color: var(--ink); }
.swiper-button-next:after, .swiper-button-prev:after { font-size: 1.2rem; font-weight:700; }

/* ── page hero (inner pages) ──────────────────────────────────────────────── */
.page-hero {
  background: radial-gradient(120% 140% at 90% -20%, #20252f 0%, var(--ink) 60%, #0c0e12 100%);
  color:#fff; padding: clamp(46px,6vw,84px) 0 clamp(40px,5vw,64px); position:relative; overflow:hidden;
}
.page-hero::before { content:""; position:absolute; inset:0; background-image: radial-gradient(rgba(255,255,255,.06) 1px, transparent 1px); background-size: 22px 22px; }
.page-hero__glow { position:absolute; width:340px;height:340px; border-radius:50%; filter: blur(80px); background: var(--coral); opacity:.18; bottom:-150px; left:-80px; }
.page-hero h1 { color:#fff; font-size: clamp(2rem,4.4vw,3.1rem); position:relative; }
.page-hero p { color: rgba(255,255,255,.8); max-width: 640px; font-size:1.08rem; position:relative; }
.crumbs { position:relative; display:flex; gap:.5em; flex-wrap:wrap; font-size:.84rem; color: rgba(255,255,255,.6); font-family: var(--font-mono); margin-bottom: 16px; }
.crumbs a { color: rgba(255,255,255,.6); }
.crumbs a:hover { color: var(--lime); }
.crumbs span.sep { opacity:.5; }

/* category chips */
.chips { display:flex; flex-wrap:wrap; gap:10px; }
.chip {
  padding:.55em 1.05em; border-radius:999px; font-weight:600; font-size:.92rem;
  background: var(--paper); border:1.5px solid var(--line); color: var(--ink); transition:.18s;
}
.chip:hover { border-color: var(--ink); color: var(--ink); transform: translateY(-2px); }
.chip.active { background: var(--ink); color:#fff; border-color: var(--ink); }

/* ── feature table (service detail) ───────────────────────────────────────── */
.feat-table { width:100%; border-collapse:collapse; background: var(--paper); border-radius: var(--r); overflow:hidden; box-shadow: var(--shadow-sm); border:1px solid var(--line-2); }
.feat-table tr { border-bottom:1px solid var(--line-2); }
.feat-table tr:last-child { border-bottom:0; }
.feat-table td { padding: 14px 18px; }
.feat-table td.k { color: var(--muted); font-weight:500; width:45%; }
.feat-table td.v { font-weight:600; color: var(--ink); }
.feat-table tr:nth-child(even) { background: rgba(20,22,27,.02); }

/* prose (full descriptions / blog / privacy) */
.prose { font-size: 1.06rem; color: var(--text); }
.prose h2 { font-size: clamp(1.4rem,2.6vw,1.9rem); margin: 1.6em 0 .5em; }
.prose h3 { font-size: 1.25rem; margin: 1.3em 0 .4em; }
.prose p { margin: 0 0 1.1em; }
.prose ul, .prose ol { margin: 0 0 1.2em; padding-left: 1.3em; }
.prose li { margin-bottom: .5em; }
.prose a { color: var(--coral-600); text-decoration: underline; }
.prose img { border-radius: var(--r); margin: 1.2em 0; box-shadow: var(--shadow-sm); }

/* sticky price box (detail) */
.pricebox { background: var(--paper); border-radius: var(--r-lg); padding: 26px; border:1px solid var(--line-2); box-shadow: var(--shadow); position: sticky; top: 96px; }
.pricebox__price { font-family: var(--font-mono); font-weight:700; font-size:1.8rem; color: var(--ink); }
.pricebox__price small { font-size:.8rem; color: var(--muted); font-weight:500; display:block; font-family: var(--font-sans); }

/* ── CTA band ─────────────────────────────────────────────────────────────── */
.cta-band {
  background: linear-gradient(110deg, var(--ink) 0%, var(--ink-2) 60%, #23303a 100%);
  border-radius: var(--r-xl); color:#fff; padding: clamp(32px,5vw,56px); position:relative; overflow:hidden;
}
.cta-band::after { content:""; position:absolute; width:300px;height:300px; border-radius:50%; background: var(--lime); filter: blur(80px); opacity:.18; right:-60px; top:-60px; }
.cta-band h2 { color:#fff; font-size: clamp(1.6rem,3vw,2.4rem); }
.cta-band p { color: rgba(255,255,255,.8); }
.cta-band__grid { display:grid; grid-template-columns: 1.4fr 1fr; gap: 30px; align-items:center; position:relative; z-index:2; }
@media (max-width: 820px){ .cta-band__grid { grid-template-columns: 1fr; } }

/* ── footer ───────────────────────────────────────────────────────────────── */
.site-footer { background: var(--ink); color: rgba(255,255,255,.72); padding: clamp(48px,6vw,72px) 0 28px; margin-top: 0; }
.footer-grid { display:grid; grid-template-columns: 1.4fr 1fr 1fr 1.2fr; gap: 36px; }
@media (max-width: 860px){ .footer-grid { grid-template-columns: 1fr 1fr; gap: 28px; } }
@media (max-width: 520px){ .footer-grid { grid-template-columns: 1fr; } }
.site-footer h4 { color:#fff; font-size: .95rem; text-transform:uppercase; letter-spacing:.08em; font-family: var(--font-mono); margin-bottom: 16px; }
.site-footer a { color: rgba(255,255,255,.72); display:block; padding: 4px 0; }
.site-footer a:hover { color: var(--lime); }
.footer-brand .brand__name { color:#fff; }
.footer-brand p { color: rgba(255,255,255,.6); font-size:.93rem; margin-top:14px; }
.footer-contact .ci { display:flex; gap:.6em; margin-bottom:10px; align-items:flex-start; }
.footer-contact .ci i { color: var(--lime); margin-top:3px; }
.footer-socials { display:flex; gap:12px; margin-top:16px; }
.footer-socials a { width:42px;height:42px;border-radius:12px; background: rgba(255,255,255,.07); display:grid !important; place-items:center; padding:0 !important; font-size:1.1rem; }
.footer-socials a:hover { background: var(--lime); color: var(--ink); }
.footer-bottom { border-top:1px solid rgba(255,255,255,.1); margin-top: 40px; padding-top: 22px; display:flex; justify-content:space-between; gap:16px; flex-wrap:wrap; font-size:.84rem; color: rgba(255,255,255,.5); }
.footer-bottom a { display:inline; }

/* ── cookie banner ────────────────────────────────────────────────────────── */
.cookie-bar {
  position: fixed; left: 16px; right: 16px; bottom: 16px; z-index: 1080;
  max-width: 720px; margin-inline:auto;
  background: var(--ink); color:#fff; border-radius: var(--r-lg);
  box-shadow: var(--shadow-lg); padding: 18px 20px;
  display:flex; align-items:center; gap: 18px; flex-wrap:wrap;
  border:1px solid rgba(255,255,255,.12);
  transform: translateY(140%); transition: transform .45s cubic-bezier(.2,.8,.2,1);
}
.cookie-bar.is-shown { transform: translateY(0); }
.cookie-bar__txt { flex:1; min-width: 220px; font-size:.92rem; color: rgba(255,255,255,.82); }
.cookie-bar__txt i { color: var(--lime); margin-right:.4em; }
.cookie-bar__txt a { color: var(--lime); text-decoration: underline; }
.cookie-bar__btns { display:flex; gap:10px; flex-wrap:wrap; }

/* ── teaser popup (90s) ───────────────────────────────────────────────────── */
.teaser {
  position: fixed; left: 16px; bottom: 16px; z-index: 1075; max-width: 320px;
  background: var(--paper); border-radius: var(--r-lg); box-shadow: var(--shadow-lg);
  padding: 18px 18px 18px 18px; border:1px solid var(--line);
  transform: translateY(180%); transition: transform .5s cubic-bezier(.2,.8,.2,1);
}
.teaser.is-shown { transform: translateY(0); }
.teaser__close { position:absolute; top:8px; right:10px; border:0; background:none; font-size:1.1rem; color: var(--muted); cursor:pointer; }
.teaser__close:hover { color: var(--ink); }
.teaser b { display:block; margin-bottom:4px; }
.teaser p { font-size:.9rem; color: var(--muted); margin:0 0 12px; }

/* django messages */
.flash-wrap { position: fixed; top: 90px; right: 20px; z-index: 1090; display:flex; flex-direction:column; gap:10px; max-width: 360px; }
.flash { padding: 14px 18px; border-radius: var(--r); box-shadow: var(--shadow); font-weight:600; font-size:.95rem; background: var(--paper); border-left:4px solid var(--sky); animation: flashIn .3s ease; }
.flash.success { border-left-color: var(--lime-600); }
.flash.error { border-left-color: var(--coral); }
@keyframes flashIn { from { opacity:0; transform: translateX(20px);} to {opacity:1; transform:none;} }

/* generic helpers */
.lead-xl { font-size: 1.15rem; color: var(--muted); }
.grid-2 { display:grid; grid-template-columns: 1fr 1fr; gap: clamp(20px,3vw,40px); }
.grid-detail { display:grid; grid-template-columns: 1.7fr 1fr; gap: clamp(24px,3vw,40px); align-items:start; }
@media (max-width: 900px){ .grid-2, .grid-detail { grid-template-columns: 1fr; } }
.divider { height:1px; background: var(--line); border:0; margin: 0; }

/* AOS fallback: ensure visible if JS off */
[data-aos]:not(.aos-animate) { opacity: 1; }
.no-js [data-aos] { opacity:1 !important; transform:none !important; }

/* small print */
.fineprint { font-size:.82rem; color: var(--muted); }

/* tag pill */
.pill { display:inline-flex; align-items:center; gap:.4em; font-family: var(--font-mono); font-size:.72rem; font-weight:600;
  text-transform:uppercase; letter-spacing:.06em; background: var(--paper-2); color: var(--ink); padding:.35em .7em; border-radius:999px; }
.pill--coral { background: rgba(255,92,57,.12); color: var(--coral-600); }
.pill--lime { background: var(--lime); color: var(--ink); }
.pill--sky { background: rgba(46,197,255,.15); color: #0a82ad; }
