:root {
  --bg: #f4f4f0;
  --surface: #ffffff;
  --ink: #0a0c10;
  --muted: #686b73;
  --line: #dfe1dc;
  --dark: #0b0d12;
  --dark-2: #14171d;
  --accent: #d9ff55;
  --accent-2: #bff52f;
  --violet: #8f77ff;
  --radius-sm: 14px;
  --radius-md: 22px;
  --radius-lg: 32px;
  --shadow: 0 24px 80px rgba(10, 12, 16, .10);
  --container: 1240px;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  color: var(--ink);
  background: var(--bg);
  font-family: "Manrope", sans-serif;
  font-size: 16px;
  line-height: 1.55;
  overflow-x: hidden;
}
body.modal-open { overflow: hidden; }
button, input { font: inherit; }
button { cursor: pointer; }
a { color: inherit; text-decoration: none; }
img, svg { display: block; max-width: 100%; }

.page-noise {
  position: fixed;
  inset: 0;
  pointer-events: none;
  opacity: .028;
  z-index: 999;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 180 180' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.8' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.8'/%3E%3C/svg%3E");
}

.container { width: min(calc(100% - 40px), var(--container)); margin-inline: auto; }
.section { padding: 112px 0; }
.section-dark { color: #fff; background: var(--dark); }

.site-header {
  position: fixed;
  z-index: 100;
  top: 0;
  left: 0;
  right: 0;
  color: #fff;
  transition: background .3s ease, box-shadow .3s ease, transform .3s ease;
}
.site-header.scrolled { background: rgba(11,13,18,.88); backdrop-filter: blur(18px); box-shadow: 0 1px 0 rgba(255,255,255,.08); }
.header-inner { height: 86px; display: flex; align-items: center; justify-content: space-between; gap: 24px; }
.brand { display: inline-flex; align-items: center; gap: 10px; font-weight: 800; letter-spacing: -.04em; }
.brand-mark { display: grid; place-items: center; width: 38px; height: 38px; border-radius: 11px; background: var(--accent); color: #0b0d12; transform: rotate(-6deg); }
.brand-text { font-size: 20px; }
.brand-text span { color: var(--accent); }
.desktop-nav { display: flex; align-items: center; gap: 30px; font-size: 14px; font-weight: 600; color: rgba(255,255,255,.7); }
.desktop-nav a { position: relative; transition: color .2s; }
.desktop-nav a::after { content: ""; position: absolute; left: 0; right: 100%; bottom: -7px; height: 2px; background: var(--accent); transition: right .25s ease; }
.desktop-nav a:hover { color: #fff; }
.desktop-nav a:hover::after { right: 0; }
.header-actions { display: flex; align-items: center; gap: 14px; }
.header-phone { font-size: 14px; font-weight: 700; }
.menu-toggle { display: none; width: 44px; height: 44px; border: 1px solid rgba(255,255,255,.16); background: transparent; border-radius: 12px; padding: 0 12px; }
.menu-toggle span { display: block; height: 2px; background: #fff; margin: 6px 0; transition: .25s; }
.menu-toggle.active span:first-child { transform: translateY(4px) rotate(45deg); }
.menu-toggle.active span:last-child { transform: translateY(-4px) rotate(-45deg); }
.mobile-menu { display: none; }

.btn {
  border: 0;
  border-radius: 12px;
  min-height: 52px;
  padding: 0 22px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 12px;
  font-weight: 800;
  transition: transform .2s ease, box-shadow .2s ease, background .2s ease;
}
.btn:hover { transform: translateY(-2px); }
.btn-small { min-height: 44px; padding: 0 18px; font-size: 13px; border-radius: 10px; }
.btn-large { min-height: 60px; padding: 0 28px; }
.btn-dark { background: #fff; color: #0b0d12; }
.btn-dark:hover { box-shadow: 0 12px 34px rgba(255,255,255,.16); }
.btn-accent { background: var(--accent); color: #0a0c10; box-shadow: 0 16px 44px rgba(217,255,85,.18); }
.btn-accent:hover { background: #e5ff89; box-shadow: 0 20px 50px rgba(217,255,85,.25); }
.btn-outline-dark { border: 1px solid #cfd2cc; background: transparent; color: var(--ink); }
.btn-outline-dark:hover { border-color: var(--ink); }
.btn-outline-light { border: 1px solid rgba(255,255,255,.2); color: #fff; background: transparent; }
.btn-outline-light:hover { border-color: var(--accent); color: var(--accent); }

.hero {
  position: relative;
  overflow: hidden;
  min-height: 880px;
  padding: 172px 0 36px;
}
.hero::before { content: ""; position: absolute; inset: 0; background-image: linear-gradient(rgba(255,255,255,.028) 1px, transparent 1px), linear-gradient(90deg, rgba(255,255,255,.028) 1px, transparent 1px); background-size: 74px 74px; mask-image: linear-gradient(to bottom, black 0%, transparent 78%); }
.hero-glow { position: absolute; border-radius: 999px; filter: blur(110px); opacity: .23; pointer-events: none; }
.hero-glow-one { width: 420px; height: 420px; background: var(--accent); right: 5%; top: 14%; }
.hero-glow-two { width: 330px; height: 330px; background: var(--violet); left: 18%; bottom: 5%; opacity: .14; }
.hero-grid { position: relative; z-index: 1; display: grid; grid-template-columns: .92fr 1.08fr; align-items: center; gap: 68px; }
.eyebrow { display: flex; align-items: center; gap: 10px; color: rgba(255,255,255,.62); text-transform: uppercase; letter-spacing: .13em; font-size: 11px; font-weight: 800; }
.eyebrow span { width: 28px; height: 2px; background: var(--accent); }
.eyebrow.dark { color: #73766f; }
.hero h1 { max-width: 700px; margin: 24px 0 26px; font-family: "Unbounded", sans-serif; font-size: clamp(52px, 5.2vw, 78px); line-height: 1.03; letter-spacing: -.06em; font-weight: 600; }
.hero h1 em { color: var(--accent); font-style: normal; }
.hero-lead { max-width: 620px; font-size: 19px; color: rgba(255,255,255,.66); }
.hero-actions { display: flex; align-items: center; gap: 28px; margin-top: 38px; }
.text-link { display: inline-flex; align-items: center; gap: 10px; font-size: 14px; font-weight: 700; color: rgba(255,255,255,.75); }
.text-link:hover { color: #fff; }
.hero-trust { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; margin-top: 58px; padding-top: 28px; border-top: 1px solid rgba(255,255,255,.1); }
.trust-item { display: grid; gap: 2px; }
.trust-item strong { font-size: 22px; color: #fff; }
.trust-item span { font-size: 12px; color: rgba(255,255,255,.47); line-height: 1.45; }

.hero-visual { position: relative; perspective: 1500px; }
.dashboard-shell { border: 1px solid rgba(255,255,255,.14); border-radius: 28px; background: rgba(18,21,27,.87); box-shadow: 0 50px 120px rgba(0,0,0,.45); overflow: hidden; transform: rotateY(-4deg) rotateX(2deg); backdrop-filter: blur(18px); }
.dashboard-topbar { height: 58px; padding: 0 18px; display: flex; align-items: center; gap: 16px; border-bottom: 1px solid rgba(255,255,255,.08); font-size: 11px; color: rgba(255,255,255,.48); }
.window-dots { display: flex; gap: 6px; }
.window-dots i { width: 7px; height: 7px; border-radius: 50%; background: rgba(255,255,255,.22); }
.live-badge { margin-left: auto; display: flex; align-items: center; gap: 7px; border: 1px solid rgba(217,255,85,.18); color: #cfff60; background: rgba(217,255,85,.05); padding: 6px 9px; border-radius: 999px; }
.live-badge b { width: 6px; height: 6px; border-radius: 50%; background: var(--accent); box-shadow: 0 0 12px var(--accent); }
.dashboard-body { padding: 18px; }
.metric-row { display: grid; grid-template-columns: 1.3fr .7fr; gap: 12px; }
.metric-card { border-radius: 17px; padding: 18px; background: #1c2027; border: 1px solid rgba(255,255,255,.06); }
.metric-card span { display: block; color: rgba(255,255,255,.47); font-size: 11px; }
.metric-card strong { display: block; margin: 7px 0 4px; font-size: 25px; letter-spacing: -.04em; }
.metric-card small { color: #ff8585; font-size: 10px; }
.metric-card small i { margin-right: 3px; }
.metric-card .positive { color: var(--accent); }
.main-metric { background: linear-gradient(135deg, rgba(217,255,85,.12), rgba(255,255,255,.03)); }
.chart-card { margin-top: 12px; padding: 18px 18px 8px; border-radius: 17px; background: #1c2027; border: 1px solid rgba(255,255,255,.06); }
.chart-head { display: flex; align-items: flex-start; justify-content: space-between; }
.chart-head div:first-child span { display: block; color: rgba(255,255,255,.45); font-size: 11px; }
.chart-head div:first-child strong { font-size: 24px; }
.chart-legend { display: flex; align-items: center; gap: 6px; color: rgba(255,255,255,.38); font-size: 9px; }
.chart-legend i { width: 8px; height: 8px; border-radius: 2px; background: var(--accent); }
.chart-area { position: relative; height: 190px; margin-top: 6px; }
.grid-lines { position: absolute; inset: 0; background: repeating-linear-gradient(to bottom, transparent 0, transparent 46px, rgba(255,255,255,.055) 47px); }
.chart-area svg { width: 100%; height: 100%; overflow: visible; }
.chart-area .area { fill: url(#areaGradient); }
.chart-area .line { fill: none; stroke: var(--accent); stroke-width: 4; filter: drop-shadow(0 0 10px rgba(217,255,85,.35)); }
.chart-area circle { fill: var(--accent); stroke: #283117; stroke-width: 5; }
.campaign-row { display: grid; grid-template-columns: 44px 1fr auto; align-items: center; gap: 12px; margin-top: 10px; padding: 12px; border: 1px solid rgba(255,255,255,.06); border-radius: 14px; background: rgba(255,255,255,.025); }
.campaign-icon { width: 42px; height: 42px; display: grid; place-items: center; border-radius: 12px; background: rgba(217,255,85,.12); color: var(--accent); }
.campaign-icon.violet { background: rgba(143,119,255,.12); color: #a999ff; }
.campaign-row strong, .campaign-row span { display: block; }
.campaign-row strong { font-size: 12px; }
.campaign-row span { color: rgba(255,255,255,.38); font-size: 9px; }
.campaign-cost { text-align: right; }
.floating-card { position: absolute; z-index: 2; display: flex; align-items: center; gap: 12px; padding: 13px 15px; border-radius: 14px; background: rgba(255,255,255,.96); color: #101218; box-shadow: 0 20px 50px rgba(0,0,0,.3); }
.floating-card i { width: 38px; height: 38px; display: grid; place-items: center; border-radius: 11px; background: #eefdc0; color: #53690c; }
.floating-card span, .floating-card strong { display: block; }
.floating-card span { font-size: 9px; color: #8a8d93; }
.floating-card strong { font-size: 11px; }
.floating-one { top: 18%; left: -8%; animation: floatOne 5s ease-in-out infinite; }
.floating-two { right: -5%; bottom: 10%; animation: floatTwo 6s ease-in-out infinite; }
.score-ring { width: 42px; height: 42px; display: grid; place-items: center; border-radius: 50%; border: 4px solid var(--accent-2); font-weight: 800; font-size: 12px; }
@keyframes floatOne { 50% { transform: translateY(-12px); } }
@keyframes floatTwo { 50% { transform: translateY(10px); } }
.industries-strip { position: relative; z-index: 1; display: grid; grid-template-columns: auto 1fr; align-items: center; gap: 34px; margin-top: 78px; padding-top: 27px; border-top: 1px solid rgba(255,255,255,.09); font-size: 12px; color: rgba(255,255,255,.36); }
.industry-list { display: flex; align-items: center; justify-content: space-between; gap: 18px; overflow: hidden; }
.industry-list b { color: rgba(255,255,255,.72); white-space: nowrap; }
.industry-list i { flex: 0 0 4px; height: 4px; border-radius: 50%; background: rgba(255,255,255,.18); }

.section-heading { margin-bottom: 54px; }
.section-heading h2 { margin: 16px 0 0; font-family: "Unbounded", sans-serif; font-size: clamp(34px, 4vw, 54px); line-height: 1.12; letter-spacing: -.055em; }
.section-heading > p { color: var(--muted); max-width: 640px; margin: 18px 0 0; }
.split-heading { display: grid; grid-template-columns: 1.15fr .65fr; align-items: end; gap: 70px; }
.split-heading > p { margin: 0 0 6px; }
.centered { text-align: center; max-width: 850px; margin-left: auto; margin-right: auto; }
.centered .eyebrow { justify-content: center; }
.centered > p { margin-left: auto; margin-right: auto; }
.section-heading.light h2 { color: #fff; }
.section-heading.light > p { color: rgba(255,255,255,.55); }

.problems-section { background: #f7f7f3; }
.problem-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; }
.problem-card { position: relative; min-height: 350px; padding: 30px; border-radius: var(--radius-md); background: #fff; border: 1px solid #e4e5df; overflow: hidden; transition: transform .3s ease, box-shadow .3s ease; }
.problem-card:hover { transform: translateY(-6px); box-shadow: var(--shadow); }
.problem-number { position: absolute; right: 24px; top: 18px; font-size: 54px; font-family: "Unbounded", sans-serif; font-weight: 700; color: #f0f1ed; }
.problem-icon { width: 58px; height: 58px; display: grid; place-items: center; border-radius: 17px; background: #f1f2ed; font-size: 20px; }
.problem-card h3 { margin: 86px 0 13px; font-size: 23px; letter-spacing: -.035em; }
.problem-card p { margin: 0; color: var(--muted); }
.accent-problem { background: var(--accent); border-color: var(--accent); }
.accent-problem .problem-number { color: rgba(10,12,16,.08); }
.accent-problem .problem-icon { background: rgba(10,12,16,.08); }
.accent-problem p { color: rgba(10,12,16,.65); }

.services-section { background: #eceee8; }
.services-grid { display: grid; grid-template-columns: 1.15fr .85fr .85fr; gap: 18px; }
.service-card { min-height: 330px; padding: 28px; border-radius: var(--radius-md); background: #fff; border: 1px solid #dcdfd8; display: flex; flex-direction: column; transition: transform .3s ease, box-shadow .3s ease; }
.service-card:hover { transform: translateY(-6px); box-shadow: var(--shadow); }
.service-large { grid-row: span 2; min-height: 678px; background: linear-gradient(160deg, #ffffff 58%, #f1f7dd); }
.service-wide { grid-column: span 2; min-height: 330px; }
.service-top { display: flex; justify-content: space-between; align-items: flex-start; }
.service-top > span { color: #a8aba4; font-size: 12px; font-weight: 800; }
.service-icon { width: 54px; height: 54px; display: grid; place-items: center; border-radius: 16px; background: #eff1eb; font-size: 19px; }
.service-card h3 { margin: auto 0 12px; font-size: 24px; letter-spacing: -.04em; }
.service-card p { color: var(--muted); margin: 0 0 18px; }
.service-card > a, .service-link { align-self: flex-start; display: inline-flex; align-items: center; gap: 10px; border: 0; background: transparent; padding: 0; font-weight: 800; font-size: 13px; }
.service-card > a:hover, .service-link:hover { color: #5a7106; }
.service-card ul { list-style: none; margin: 28px 0 36px; padding: 0; display: grid; gap: 14px; }
.service-card li { display: flex; align-items: center; gap: 10px; font-size: 14px; }
.service-card li i { color: #6f8a15; }
.dark-service { color: #fff; background: #12151a; border-color: #12151a; }
.dark-service p { color: rgba(255,255,255,.55); }
.dark-service .service-icon { background: rgba(217,255,85,.12); color: var(--accent); }
.dark-service > a { color: var(--accent); }
.service-wide-content { display: grid; grid-template-columns: 1fr .86fr; gap: 40px; align-items: end; flex: 1; }
.service-wide-content h3 { margin-top: 70px; }
.mini-page-mockup { align-self: stretch; border-radius: 17px; background: #e9ebe4; padding: 12px; transform: rotate(-2deg); }
.mini-browser { display: flex; gap: 4px; height: 20px; align-items: center; }
.mini-browser i { width: 5px; height: 5px; border-radius: 50%; background: #c2c5bd; }
.mini-hero { height: calc(100% - 20px); padding: 22px; border-radius: 11px; background: linear-gradient(140deg, #151820 0 62%, var(--accent) 62%); }
.mini-hero span, .mini-hero b { display: block; border-radius: 4px; background: #fff; opacity: .9; }
.mini-hero span { width: 58%; height: 9px; margin-top: 15px; }
.mini-hero b { width: 44%; height: 6px; margin-top: 10px; opacity: .4; }
.mini-hero button { width: 82px; height: 24px; margin-top: 22px; border: 0; border-radius: 6px; background: var(--accent); }

.cases-section { background: #0d1015; }
.case-tabs { display: flex; gap: 10px; margin-bottom: 22px; }
.case-tab { border: 1px solid rgba(255,255,255,.1); border-radius: 999px; padding: 11px 18px; background: transparent; color: rgba(255,255,255,.5); font-size: 12px; font-weight: 800; }
.case-tab.active { background: var(--accent); border-color: var(--accent); color: #0a0c10; }
.case-panel { display: none; grid-template-columns: 1.1fr .9fr; gap: 40px; min-height: 520px; padding: 54px; border-radius: var(--radius-lg); background: #15191f; border: 1px solid rgba(255,255,255,.08); }
.case-panel.active { display: grid; }
.case-label { color: var(--accent); font-size: 11px; font-weight: 800; text-transform: uppercase; letter-spacing: .1em; }
.case-copy h3 { max-width: 650px; margin: 16px 0 17px; font-size: 35px; line-height: 1.18; letter-spacing: -.045em; }
.case-copy > p { color: rgba(255,255,255,.55); max-width: 650px; }
.case-metrics { display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px; margin: 40px 0 36px; }
.case-metrics div { padding: 16px; border-radius: 14px; background: rgba(255,255,255,.04); border: 1px solid rgba(255,255,255,.06); }
.case-metrics strong, .case-metrics span, .case-metrics small { display: block; }
.case-metrics strong { font-size: 24px; color: #fff; }
.case-metrics span { font-size: 10px; color: rgba(255,255,255,.5); margin: 4px 0; }
.case-metrics small { font-size: 9px; color: var(--accent); }
.case-chart-card { align-self: stretch; border-radius: 22px; padding: 24px; background: #f4f4ef; color: var(--ink); display: flex; flex-direction: column; }
.case-chart-head { display: flex; align-items: center; justify-content: space-between; }
.case-chart-head span { font-size: 12px; color: #6f726b; }
.case-chart-head strong { color: #57710a; }
.bar-chart { flex: 1; display: flex; align-items: flex-end; gap: 12px; min-height: 300px; padding-top: 38px; border-bottom: 1px solid #cfd2cb; background: repeating-linear-gradient(to bottom, transparent 0, transparent 63px, #e5e7e1 64px); }
.bar-chart > div { position: relative; flex: 1; height: var(--h); min-height: 38px; border-radius: 7px 7px 0 0; background: #cfd3c9; transition: height .6s ease; }
.bar-chart > div.active { background: var(--accent-2); box-shadow: 0 -8px 28px rgba(191,245,47,.32); }
.bar-chart span { position: absolute; top: -25px; left: 50%; transform: translateX(-50%); font-size: 10px; font-weight: 800; }
.bar-chart b { position: absolute; bottom: -27px; left: 50%; transform: translateX(-50%); font-size: 9px; color: #898c84; }
.case-note { margin-top: 40px; font-size: 9px; color: #9a9d95; }

.process-section { background: #f7f7f3; }
.process-timeline { display: grid; grid-template-columns: repeat(4, 1fr); gap: 0; border-top: 1px solid #d9dcd5; }
.process-step { position: relative; padding: 34px 28px 0 0; }
.process-step:not(:last-child)::after { content: ""; position: absolute; right: 0; top: -1px; width: 1px; height: 100%; background: #d9dcd5; }
.step-marker { position: absolute; top: -22px; left: 0; width: 44px; height: 44px; display: grid; place-items: center; border: 1px solid #cfd2cb; border-radius: 50%; background: #f7f7f3; font-size: 10px; font-weight: 800; }
.step-time { display: inline-block; margin: 10px 0 60px; color: #74776f; font-size: 10px; font-weight: 800; text-transform: uppercase; letter-spacing: .1em; }
.process-step h3 { font-size: 21px; letter-spacing: -.035em; margin: 0 0 12px; }
.process-step p { color: var(--muted); font-size: 14px; padding-right: 20px; }

.pricing-section { background: #eceee8; }
.pricing-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; align-items: stretch; }
.price-card { position: relative; min-height: 620px; padding: 30px; border-radius: var(--radius-md); background: #fff; border: 1px solid #daddd6; display: flex; flex-direction: column; }
.price-card.featured { background: #111419; color: #fff; border-color: #111419; transform: translateY(-12px); box-shadow: 0 35px 80px rgba(16,19,24,.22); }
.popular-badge { position: absolute; top: -14px; left: 30px; padding: 8px 12px; border-radius: 999px; background: var(--accent); color: #101218; font-size: 10px; font-weight: 800; }
.price-head { display: flex; align-items: center; justify-content: space-between; }
.price-head > span { text-transform: uppercase; letter-spacing: .12em; font-size: 10px; font-weight: 800; color: #7f827b; }
.price-icon { width: 48px; height: 48px; display: grid; place-items: center; border-radius: 14px; background: #eff1eb; }
.featured .price-icon { color: var(--accent); background: rgba(217,255,85,.1); }
.price-card h3 { margin: 56px 0 12px; font-size: 25px; letter-spacing: -.04em; }
.price-card > p { min-height: 70px; margin: 0; color: var(--muted); }
.featured > p { color: rgba(255,255,255,.52); }
.price { margin: 34px 0; font-size: 36px; font-weight: 800; letter-spacing: -.045em; }
.price small { font-size: 12px; color: #8a8d86; font-weight: 700; }
.price-card ul { list-style: none; padding: 24px 0; margin: 0 0 28px; display: grid; gap: 15px; border-top: 1px solid #e4e6e0; }
.featured ul { border-color: rgba(255,255,255,.1); }
.price-card li { display: flex; align-items: center; gap: 10px; font-size: 13px; }
.price-card li i { color: #65800e; }
.featured li i { color: var(--accent); }
.price-card .btn { margin-top: auto; }
.pricing-note { margin-top: 36px; text-align: center; color: #7a7d76; font-size: 12px; }

.about-section { background: #f7f7f3; }
.about-grid { display: grid; grid-template-columns: .9fr 1.1fr; gap: 90px; align-items: center; }
.about-visual { position: relative; min-height: 600px; }
.portrait-card { position: relative; width: 82%; height: 540px; border-radius: 34px; overflow: hidden; background: #d9ff55; transform: rotate(-2deg); }
.portrait-placeholder { position: absolute; inset: 0; display: flex; align-items: center; justify-content: center; background: radial-gradient(circle at 42% 24%, #f4ffd1 0 8%, transparent 9%), linear-gradient(150deg, #d9ff55, #91b70c); }
.portrait-placeholder::before { content: ""; position: absolute; width: 265px; height: 320px; bottom: -40px; left: 50%; transform: translateX(-50%); border-radius: 140px 140px 20px 20px; background: #111419; }
.portrait-placeholder::after { content: ""; position: absolute; width: 150px; height: 185px; top: 84px; left: 50%; transform: translateX(-50%); border-radius: 46% 46% 48% 48%; background: #e8c39f; box-shadow: inset 0 20px 0 #282017; }
.portrait-initials { position: absolute; z-index: 2; top: 153px; font-size: 26px; font-weight: 800; letter-spacing: .08em; color: rgba(21,24,29,.22); }
.portrait-caption { position: absolute; z-index: 3; bottom: 24px; left: 24px; right: 24px; padding: 17px 18px; border-radius: 16px; background: rgba(255,255,255,.9); backdrop-filter: blur(10px); transform: rotate(2deg); }
.portrait-caption strong, .portrait-caption span { display: block; }
.portrait-caption strong { font-size: 15px; }
.portrait-caption span { color: #777a72; font-size: 10px; }
.certificate-stack { position: absolute; right: 0; bottom: 0; display: grid; gap: 12px; width: 46%; }
.certificate { display: grid; grid-template-columns: 34px 1fr; align-items: center; padding: 16px; border-radius: 15px; background: #fff; box-shadow: 0 18px 50px rgba(10,12,16,.1); }
.certificate i { grid-row: span 2; font-size: 22px; }
.certificate span { font-size: 10px; color: #7c7f77; }
.certificate b { font-size: 11px; }
.cert-one { transform: rotate(4deg); }
.cert-two { transform: rotate(-2deg); }
.about-copy h2 { margin: 18px 0 22px; font-family: "Unbounded", sans-serif; font-size: clamp(34px, 4vw, 50px); line-height: 1.13; letter-spacing: -.055em; }
.about-lead { font-size: 18px; color: var(--muted); }
.about-points { display: grid; gap: 14px; margin-top: 34px; }
.about-points > div { display: grid; grid-template-columns: 52px 1fr; gap: 15px; align-items: center; padding: 16px; border: 1px solid #dedfd9; border-radius: 15px; background: rgba(255,255,255,.62); }
.about-points i { width: 52px; height: 52px; display: grid; place-items: center; border-radius: 14px; background: #eff1eb; }
.about-points span { color: #696c65; font-size: 13px; }
.about-points strong { display: block; color: var(--ink); margin-bottom: 3px; }
.about-signature { margin-top: 34px; display: flex; align-items: flex-end; gap: 18px; }
.signature-line { font-family: cursive; font-size: 29px; transform: rotate(-4deg); }
.about-signature span { color: #8d9088; font-size: 10px; padding-bottom: 7px; }

.testimonials-section { background: #eceee8; overflow: hidden; }
.slider-controls { display: flex; gap: 10px; }
.slider-controls button { width: 48px; height: 48px; border-radius: 50%; border: 1px solid #cfd2cb; background: transparent; }
.slider-controls button:hover { background: #fff; }
.reviews-viewport { overflow: hidden; }
.reviews-track { display: flex; gap: 18px; transition: transform .5s cubic-bezier(.2,.7,.2,1); }
.review-card { flex: 0 0 calc((100% - 36px)/3); min-height: 360px; padding: 28px; border-radius: var(--radius-md); background: #fff; border: 1px solid #dfe1db; display: flex; flex-direction: column; }
.review-stars { color: #a5cc1a; font-size: 12px; letter-spacing: 3px; }
.review-card > p { margin: 56px 0 42px; font-size: 18px; line-height: 1.65; letter-spacing: -.015em; }
.review-author { margin-top: auto; display: flex; align-items: center; gap: 13px; }
.author-avatar { width: 46px; height: 46px; display: grid; place-items: center; border-radius: 50%; background: #111419; color: var(--accent); font-size: 11px; font-weight: 800; }
.review-author strong, .review-author span { display: block; }
.review-author strong { font-size: 12px; }
.review-author span { color: #8b8e87; font-size: 9px; }

.faq-section { background: #f7f7f3; }
.faq-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 18px; align-items: start; }
.faq-column { display: grid; gap: 12px; }
.faq-item { border-radius: 16px; background: #fff; border: 1px solid #dfe1dc; overflow: hidden; }
.faq-item button { width: 100%; border: 0; background: transparent; padding: 22px; display: flex; align-items: center; justify-content: space-between; gap: 20px; text-align: left; font-weight: 800; }
.faq-item button i { width: 30px; height: 30px; display: grid; place-items: center; border-radius: 50%; background: #eff1eb; transition: transform .25s; }
.faq-item.active button i { transform: rotate(45deg); background: var(--accent); }
.faq-answer { max-height: 0; overflow: hidden; transition: max-height .35s ease; }
.faq-answer p { margin: 0; padding: 0 22px 22px; color: var(--muted); font-size: 14px; }
.faq-item.active .faq-answer { max-height: 240px; }

.seo-section { padding-top: 0; background: #f7f7f3; }
.seo-card { border: 1px solid #dfe1dc; border-radius: var(--radius-md); background: #fff; padding: 34px; }
.seo-heading span { color: #777a73; text-transform: uppercase; font-size: 9px; font-weight: 800; letter-spacing: .12em; }
.seo-heading h2 { margin: 8px 0 20px; font-size: 25px; }
.seo-content { position: relative; color: var(--muted); font-size: 13px; transition: max-height .35s ease; overflow: hidden; }
.seo-content.is-collapsed { max-height: 145px; }
.seo-content.is-collapsed::after { content: ""; position: absolute; left: 0; right: 0; bottom: 0; height: 80px; background: linear-gradient(transparent, #fff); }
.seo-content p { margin: 0 0 14px; }
.seo-toggle { border: 0; background: transparent; padding: 10px 0 0; font-size: 12px; font-weight: 800; }
.seo-toggle i { margin-left: 5px; transition: transform .25s; }
.seo-toggle.active i { transform: rotate(180deg); }

.contact-section { position: relative; overflow: hidden; background: #0d1015; }
.contact-glow { position: absolute; width: 480px; height: 480px; border-radius: 50%; background: var(--accent); filter: blur(150px); opacity: .12; left: -120px; top: -100px; }
.contact-grid { position: relative; display: grid; grid-template-columns: 1fr .82fr; gap: 80px; align-items: center; }
.contact-copy h2 { margin: 18px 0 22px; font-family: "Unbounded", sans-serif; font-size: clamp(38px, 4vw, 57px); line-height: 1.12; letter-spacing: -.055em; }
.contact-copy > p { color: rgba(255,255,255,.56); font-size: 17px; max-width: 630px; }
.contact-benefits { display: grid; gap: 13px; margin-top: 34px; }
.contact-benefits div { display: flex; align-items: center; gap: 10px; color: rgba(255,255,255,.7); font-size: 13px; }
.contact-benefits i { color: var(--accent); }
.lead-form { padding: 30px; border-radius: 24px; background: #f6f6f1; color: var(--ink); }
.form-heading { margin-bottom: 22px; }
.form-heading span, .form-heading small { display: block; }
.form-heading span { font-size: 23px; font-weight: 800; letter-spacing: -.035em; }
.form-heading small { color: #84877f; font-size: 10px; margin-top: 3px; }
.lead-form label:not(.consent) { display: grid; gap: 7px; margin-top: 14px; }
.lead-form label > span { font-size: 10px; font-weight: 800; color: #6f726b; }
.lead-form input, .modal-form input { width: 100%; height: 54px; border: 1px solid #daddd5; border-radius: 12px; background: #fff; padding: 0 16px; outline: none; transition: border .2s, box-shadow .2s; }
.lead-form input:focus, .modal-form input:focus { border-color: #9abc25; box-shadow: 0 0 0 4px rgba(217,255,85,.24); }
.lead-form .btn { width: 100%; margin-top: 20px; }
.consent { display: flex; align-items: flex-start; gap: 8px; margin-top: 13px; font-size: 8px; color: #898c84; }
.consent input { flex: 0 0 auto; width: 14px; height: 14px; margin-top: 1px; accent-color: #6f8a15; }

.site-footer { background: #080a0d; color: #fff; padding: 70px 0 22px; }
.footer-main { display: grid; grid-template-columns: 1.35fr .7fr .9fr .9fr; gap: 60px; padding-bottom: 56px; }
.footer-brand p { max-width: 320px; margin-top: 20px; color: rgba(255,255,255,.4); font-size: 12px; }
.footer-nav, .footer-contacts { display: grid; align-content: start; gap: 10px; }
.footer-nav strong, .footer-contacts > strong { margin-bottom: 8px; font-size: 11px; text-transform: uppercase; letter-spacing: .12em; color: rgba(255,255,255,.38); }
.footer-nav a, .footer-contacts a { font-size: 12px; color: rgba(255,255,255,.65); }
.footer-nav a:hover, .footer-contacts a:hover { color: var(--accent); }
.footer-phone { font-size: 19px !important; font-weight: 800; color: #fff !important; }
.social-links { display: flex; gap: 8px; margin-top: 10px; }
.social-links a { width: 36px; height: 36px; display: grid; place-items: center; border: 1px solid rgba(255,255,255,.12); border-radius: 10px; }
.footer-bottom { border-top: 1px solid rgba(255,255,255,.08); padding-top: 22px; display: flex; justify-content: space-between; color: rgba(255,255,255,.3); font-size: 9px; }

.modal { position: fixed; z-index: 300; inset: 0; display: grid; place-items: center; padding: 20px; opacity: 0; visibility: hidden; transition: .25s; }
.modal.active { opacity: 1; visibility: visible; }
.modal-backdrop { position: absolute; inset: 0; background: rgba(4,5,7,.78); backdrop-filter: blur(10px); }
.modal-dialog { position: relative; z-index: 1; width: min(100%, 470px); padding: 36px; border-radius: 26px; background: #f6f6f1; transform: translateY(18px) scale(.98); transition: transform .25s; }
.modal.active .modal-dialog { transform: translateY(0) scale(1); }
.modal-close { position: absolute; right: 16px; top: 16px; width: 38px; height: 38px; border: 0; border-radius: 50%; background: #e9ebe5; }
.modal-icon { width: 58px; height: 58px; display: grid; place-items: center; border-radius: 17px; background: var(--accent); font-size: 20px; }
.modal-dialog h2 { margin: 22px 0 8px; font-size: 28px; letter-spacing: -.045em; }
.modal-dialog > p { color: var(--muted); font-size: 13px; }
.modal-form { display: grid; gap: 12px; margin-top: 24px; }
.modal-form .btn { width: 100%; }
.success-toast { position: fixed; z-index: 400; right: 24px; bottom: 24px; display: flex; align-items: center; gap: 12px; width: min(calc(100% - 48px), 340px); padding: 16px; border-radius: 15px; background: #fff; color: #121419; box-shadow: var(--shadow); transform: translateY(120px); opacity: 0; transition: .35s; }
.success-toast.show { transform: translateY(0); opacity: 1; }
.success-toast > i { color: #86a918; font-size: 25px; }
.success-toast strong, .success-toast span { display: block; }
.success-toast strong { font-size: 12px; }
.success-toast span { color: #83867e; font-size: 9px; }

.cookie-banner { position: fixed; z-index: 120; left: 18px; right: 18px; bottom: 18px; display: flex; align-items: center; justify-content: space-between; gap: 24px; max-width: 980px; margin: auto; padding: 14px 16px; border: 1px solid rgba(255,255,255,.12); border-radius: 16px; color: #fff; background: rgba(14,17,22,.94); box-shadow: 0 20px 60px rgba(0,0,0,.32); backdrop-filter: blur(16px); transition: .3s; }
.cookie-banner.hidden { transform: translateY(130%); opacity: 0; pointer-events: none; }
.cookie-banner > div:first-child { display: flex; align-items: center; gap: 12px; }
.cookie-banner > div:first-child > i { width: 38px; height: 38px; display: grid; place-items: center; border-radius: 10px; background: rgba(217,255,85,.1); color: var(--accent); }
.cookie-banner p { margin: 0; color: rgba(255,255,255,.56); font-size: 10px; }
.cookie-banner p a { color: #fff; text-decoration: underline; }
.cookie-actions { display: flex; align-items: center; gap: 8px; }
.cookie-settings, .cookie-decline { border: 0; background: transparent; color: rgba(255,255,255,.55); font-size: 10px; }
.cookie-settings:hover, .cookie-decline:hover { color: #fff; }
.floating-contact { position: fixed; right: 20px; bottom: 20px; z-index: 90; display: none; align-items: center; gap: 9px; min-height: 48px; padding: 0 16px; border-radius: 999px; background: var(--accent); color: #101218; box-shadow: 0 16px 45px rgba(0,0,0,.22); font-size: 11px; font-weight: 800; }

.reveal { opacity: 0; transform: translateY(24px); transition: opacity .7s ease, transform .7s ease; }
.reveal.visible { opacity: 1; transform: translateY(0); }
.reveal-delay { transition-delay: .14s; }
.reveal-delay-sm { transition-delay: .08s; }
.reveal-delay-md { transition-delay: .16s; }

@media (max-width: 1100px) {
  .desktop-nav { display: none; }
  .menu-toggle { display: block; }
  .header-phone { display: none; }
  .mobile-menu { position: fixed; z-index: 99; top: 86px; left: 16px; right: 16px; display: grid; gap: 6px; padding: 18px; border-radius: 18px; color: #fff; background: rgba(14,17,22,.97); border: 1px solid rgba(255,255,255,.1); transform: translateY(-20px); opacity: 0; visibility: hidden; transition: .25s; }
  .mobile-menu.active { transform: translateY(0); opacity: 1; visibility: visible; }
  .mobile-menu a { padding: 11px 8px; border-bottom: 1px solid rgba(255,255,255,.07); font-weight: 700; font-size: 13px; }
  .hero { padding-top: 150px; }
  .hero-grid { grid-template-columns: 1fr; gap: 70px; }
  .hero-copy { max-width: 800px; }
  .hero h1 { font-size: 67px; }
  .hero-visual { max-width: 760px; margin: auto; }
  .dashboard-shell { transform: none; }
  .services-grid { grid-template-columns: 1fr 1fr; }
  .service-large { grid-row: span 2; }
  .service-wide { grid-column: span 1; }
  .service-wide-content { grid-template-columns: 1fr; }
  .mini-page-mockup { display: none; }
  .case-panel { grid-template-columns: 1fr; }
  .process-timeline { grid-template-columns: repeat(2, 1fr); row-gap: 60px; }
  .process-step:nth-child(2)::after { display: none; }
  .pricing-grid { gap: 14px; }
  .price-card { padding: 24px; }
  .about-grid { gap: 50px; }
  .footer-main { grid-template-columns: 1.2fr .7fr .9fr; }
  .footer-contacts { grid-column: span 3; display: flex; align-items: center; gap: 20px; }
  .footer-contacts > strong { margin: 0; }
}

@media (max-width: 800px) {
  .container { width: min(calc(100% - 28px), var(--container)); }
  .section { padding: 82px 0; }
  .header-inner { height: 74px; }
  .site-header .btn-small { display: none; }
  .mobile-menu { top: 74px; }
  .hero { min-height: auto; padding: 126px 0 28px; }
  .hero h1 { font-size: clamp(43px, 12vw, 62px); }
  .hero-lead { font-size: 17px; }
  .hero-actions { align-items: flex-start; flex-direction: column; gap: 18px; }
  .hero-trust { grid-template-columns: 1fr; gap: 14px; }
  .trust-item { grid-template-columns: 110px 1fr; align-items: center; }
  .hero-visual { width: 100%; }
  .dashboard-topbar > span { display: none; }
  .floating-one { left: -3%; top: 24%; }
  .floating-two { right: -2%; bottom: 4%; }
  .industries-strip { grid-template-columns: 1fr; gap: 14px; }
  .industry-list { justify-content: flex-start; overflow-x: auto; padding-bottom: 5px; }
  .section-heading h2 { font-size: 37px; }
  .split-heading { grid-template-columns: 1fr; gap: 22px; }
  .problem-grid { grid-template-columns: 1fr; }
  .problem-card { min-height: 280px; }
  .problem-card h3 { margin-top: 70px; }
  .services-grid { grid-template-columns: 1fr; }
  .service-large { min-height: 560px; grid-row: auto; }
  .service-wide { grid-column: auto; }
  .case-panel { padding: 28px; }
  .case-copy h3 { font-size: 29px; }
  .case-metrics { grid-template-columns: 1fr; }
  .case-tabs { overflow-x: auto; padding-bottom: 6px; }
  .case-tab { white-space: nowrap; }
  .process-timeline { grid-template-columns: 1fr; border-top: 0; }
  .process-step { padding: 0 0 30px 70px; border-left: 1px solid #d9dcd5; }
  .process-step:not(:last-child)::after { display: none; }
  .step-marker { left: -22px; top: 0; }
  .step-time { margin: 0 0 18px; }
  .pricing-grid { grid-template-columns: 1fr; }
  .price-card.featured { transform: none; }
  .about-grid { grid-template-columns: 1fr; }
  .about-visual { min-height: 520px; }
  .portrait-card { height: 470px; }
  .certificate-stack { bottom: -20px; }
  .review-card { flex-basis: calc((100% - 18px)/2); }
  .faq-grid { grid-template-columns: 1fr; }
  .contact-grid { grid-template-columns: 1fr; gap: 44px; }
  .footer-main { grid-template-columns: 1fr 1fr; }
  .footer-brand { grid-column: span 2; }
  .footer-contacts { grid-column: span 2; flex-wrap: wrap; }
  .footer-bottom { gap: 10px; flex-direction: column; }
  .cookie-banner { flex-direction: column; align-items: stretch; gap: 10px; }
  .cookie-actions { justify-content: flex-end; }
}

@media (max-width: 560px) {
  .brand-mark { width: 34px; height: 34px; }
  .brand-text { font-size: 17px; }
  .hero h1 { font-size: 40px; line-height: 1.08; }
  .btn-large { min-height: 56px; padding: 0 19px; font-size: 13px; }
  .dashboard-body { padding: 10px; }
  .metric-card { padding: 13px; }
  .metric-card strong { font-size: 20px; }
  .chart-area { height: 145px; }
  .campaign-row { grid-template-columns: 38px 1fr auto; padding: 9px; }
  .campaign-icon { width: 36px; height: 36px; }
  .floating-card { display: none; }
  .section-heading h2, .about-copy h2, .contact-copy h2 { font-size: 32px; }
  .service-card, .problem-card, .price-card { padding: 22px; }
  .case-panel { padding: 22px; }
  .case-copy h3 { font-size: 25px; }
  .case-chart-card { padding: 18px; }
  .bar-chart { gap: 6px; min-height: 250px; }
  .about-visual { min-height: 440px; }
  .portrait-card { width: 94%; height: 410px; }
  .portrait-placeholder::before { width: 220px; height: 260px; }
  .portrait-placeholder::after { width: 126px; height: 155px; top: 78px; }
  .portrait-initials { top: 132px; }
  .certificate-stack { width: 52%; right: -4px; }
  .review-card { flex-basis: 100%; }
  .lead-form { padding: 22px; }
  .footer-main { grid-template-columns: 1fr; }
  .footer-brand, .footer-contacts { grid-column: auto; }
  .footer-contacts { display: grid; }
  .cookie-banner { bottom: 10px; left: 10px; right: 10px; }
  .cookie-actions { display: grid; grid-template-columns: 1fr 1fr 1fr; }
  .cookie-actions button { padding: 0 7px; }
  .floating-contact { display: flex; bottom: 14px; right: 14px; }
  .cookie-banner:not(.hidden) + .floating-contact { display: none; }
}

/* Local stock photography */
.service-photo-wrap {
  display: block;
  height: 168px;
  margin: 24px 0 22px;
  overflow: hidden;
  border-radius: 18px;
  background: #e8eae4;
}
.service-photo-wrap img { width: 100%; height: 100%; object-fit: cover; transition: transform .55s ease; }
.service-card:hover .service-photo-wrap img { transform: scale(1.045); }
.dark-service .service-photo-wrap { opacity: .82; }
.section-more-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 9px;
  margin-top: 18px;
  font-size: 12px;
  font-weight: 800;
}
.section-more-link:hover i { transform: translateX(4px); }
.section-more-link i { transition: transform .2s ease; }
.light-link { color: var(--accent); }
.case-thumb {
  position: relative;
  display: block;
  width: 100%;
  height: 185px;
  margin-bottom: 24px;
  overflow: hidden;
  border-radius: 20px;
  background: #1b1f26;
}
.case-thumb::after { content: ""; position: absolute; inset: 0; background: linear-gradient(180deg, transparent 42%, rgba(5,7,10,.84)); }
.case-thumb img { width: 100%; height: 100%; object-fit: cover; transition: transform .55s ease; }
.case-thumb span { position: absolute; z-index: 2; left: 18px; right: 18px; bottom: 15px; display: flex; justify-content: space-between; align-items: center; color: #fff; font-size: 11px; font-weight: 800; }
.case-thumb:hover img { transform: scale(1.045); }
.portrait-image { width: 100%; height: 100%; object-fit: cover; object-position: center 22%; }
.contact-photo { width: min(100%, 590px); height: 210px; margin-top: 38px; overflow: hidden; border: 1px solid rgba(255,255,255,.11); border-radius: 22px; }
.contact-photo img { width: 100%; height: 100%; object-fit: cover; opacity: .72; }

/* Inner pages */
.inner-page { background: #f5f5f1; }
.inner-page .site-header { background: rgba(11,13,18,.94); backdrop-filter: blur(18px); box-shadow: 0 1px 0 rgba(255,255,255,.08); }
.page-hero {
  position: relative;
  overflow: hidden;
  padding: 160px 0 88px;
  color: #fff;
  background: #0b0d12;
}
.page-hero::before { content: ""; position: absolute; width: 520px; height: 520px; right: -170px; top: -170px; border-radius: 50%; background: var(--accent); filter: blur(165px); opacity: .11; }
.page-hero-grid { position: relative; display: grid; grid-template-columns: minmax(0, 1fr) minmax(360px, .84fr); gap: 70px; align-items: center; }
.breadcrumbs { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 22px; color: rgba(255,255,255,.46); font-size: 11px; }
.breadcrumbs a:hover { color: var(--accent); }
.page-hero h1 { margin: 14px 0 22px; max-width: 860px; font-family: "Unbounded", sans-serif; font-size: clamp(42px, 5.4vw, 72px); line-height: 1.04; letter-spacing: -.06em; }
.page-hero h1 em { color: var(--accent); font-style: normal; }
.page-hero-lead { max-width: 760px; margin: 0; color: rgba(255,255,255,.62); font-size: 18px; }
.page-hero-actions { display: flex; align-items: center; gap: 16px; margin-top: 34px; }
.page-hero-photo { position: relative; min-height: 470px; overflow: hidden; border-radius: 32px; transform: rotate(1.5deg); box-shadow: 0 34px 90px rgba(0,0,0,.34); }
.page-hero-photo::after { content: ""; position: absolute; inset: 0; background: linear-gradient(180deg, transparent 45%, rgba(5,6,9,.58)); }
.page-hero-photo img { width: 100%; height: 100%; min-height: 470px; object-fit: cover; }
.page-photo-caption { position: absolute; z-index: 2; left: 22px; right: 22px; bottom: 20px; display: flex; align-items: center; justify-content: space-between; gap: 18px; color: #fff; }
.page-photo-caption strong { display: block; font-size: 13px; }
.page-photo-caption span { display: block; color: rgba(255,255,255,.62); font-size: 10px; }
.page-photo-caption i { width: 46px; height: 46px; display: grid; place-items: center; flex: 0 0 auto; border-radius: 14px; color: #101218; background: var(--accent); }
.inner-section { padding: 96px 0; }
.inner-section.alt { background: #eceee8; }
.inner-heading { max-width: 820px; margin-bottom: 44px; }
.inner-heading h2 { margin: 12px 0 15px; font-family: "Unbounded", sans-serif; font-size: clamp(32px, 4vw, 50px); line-height: 1.12; letter-spacing: -.055em; }
.inner-heading p { margin: 0; color: var(--muted); font-size: 16px; }
.catalog-grid { display: grid; grid-template-columns: repeat(2, minmax(0,1fr)); gap: 22px; }
.catalog-card { overflow: hidden; border: 1px solid #dfe1dc; border-radius: 26px; background: #fff; transition: transform .25s ease, box-shadow .25s ease; }
.catalog-card:hover { transform: translateY(-5px); box-shadow: var(--shadow); }
.catalog-card-media { position: relative; height: 265px; overflow: hidden; }
.catalog-card-media img { width: 100%; height: 100%; object-fit: cover; transition: transform .55s ease; }
.catalog-card:hover .catalog-card-media img { transform: scale(1.04); }
.catalog-card-number { position: absolute; top: 18px; right: 18px; min-width: 42px; height: 42px; display: grid; place-items: center; border-radius: 12px; color: #111419; background: var(--accent); font-size: 11px; font-weight: 800; }
.catalog-card-body { padding: 28px; }
.catalog-card-body h2, .catalog-card-body h3 { margin: 0 0 12px; font-size: 25px; letter-spacing: -.04em; }
.catalog-card-body p { margin: 0 0 22px; color: var(--muted); }
.catalog-card-link { display: inline-flex; align-items: center; gap: 10px; font-size: 12px; font-weight: 800; }
.catalog-card-link i { transition: transform .2s ease; }
.catalog-card-link:hover i { transform: translateX(4px); }
.detail-layout { display: grid; grid-template-columns: minmax(0, 1.55fr) minmax(290px, .62fr); gap: 54px; align-items: start; }
.content-stack { display: grid; gap: 28px; }
.content-card { padding: 34px; border: 1px solid #dfe1dc; border-radius: 24px; background: #fff; }
.content-card h2 { margin: 0 0 16px; font-size: 29px; letter-spacing: -.045em; }
.content-card h3 { margin: 24px 0 10px; font-size: 20px; }
.content-card p { color: var(--muted); }
.check-list { list-style: none; display: grid; gap: 13px; margin: 20px 0 0; padding: 0; }
.check-list li { display: grid; grid-template-columns: 26px 1fr; gap: 10px; align-items: start; }
.check-list i { width: 24px; height: 24px; display: grid; place-items: center; border-radius: 8px; color: #4f6710; background: #eaf5c8; font-size: 10px; }
.side-panel { position: sticky; top: 112px; display: grid; gap: 18px; }
.side-card { padding: 26px; border-radius: 22px; color: #fff; background: #101319; }
.side-card.accent { color: #101218; background: var(--accent); }
.side-card h3 { margin: 0 0 12px; font-size: 22px; letter-spacing: -.04em; }
.side-card p { margin: 0 0 22px; color: rgba(255,255,255,.58); font-size: 13px; }
.side-card.accent p { color: rgba(16,18,24,.63); }
.side-card .btn { width: 100%; }
.side-nav { display: grid; padding: 12px; border: 1px solid #dfe1dc; border-radius: 20px; background: #fff; }
.side-nav a { display: flex; align-items: center; justify-content: space-between; gap: 12px; padding: 14px; border-radius: 12px; color: #676a63; font-size: 12px; font-weight: 700; }
.side-nav a:hover, .side-nav a.active { color: #111419; background: #eff1eb; }
.feature-grid { display: grid; grid-template-columns: repeat(3, minmax(0,1fr)); gap: 16px; }
.feature-box { padding: 24px; border: 1px solid #dfe1dc; border-radius: 20px; background: #fff; }
.feature-box i { width: 44px; height: 44px; display: grid; place-items: center; margin-bottom: 22px; border-radius: 13px; background: var(--accent); }
.feature-box h3 { margin: 0 0 8px; font-size: 18px; }
.feature-box p { margin: 0; color: var(--muted); font-size: 13px; }
.case-list-grid { display: grid; grid-template-columns: repeat(3, minmax(0,1fr)); gap: 20px; }
.case-list-card { position: relative; min-height: 480px; overflow: hidden; border-radius: 26px; color: #fff; background: #111419; }
.case-list-card::after { content: ""; position: absolute; inset: 0; background: linear-gradient(180deg, rgba(0,0,0,.03) 20%, rgba(7,9,12,.94) 90%); }
.case-list-card > img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; transition: transform .6s ease; }
.case-list-card:hover > img { transform: scale(1.045); }
.case-list-content { position: absolute; z-index: 2; left: 24px; right: 24px; bottom: 24px; }
.case-list-content small { display: block; margin-bottom: 8px; color: var(--accent); text-transform: uppercase; letter-spacing: .1em; font-size: 9px; font-weight: 800; }
.case-list-content h2, .case-list-content h3 { margin: 0 0 12px; font-size: 25px; line-height: 1.2; letter-spacing: -.04em; }
.case-list-content p { margin: 0 0 18px; color: rgba(255,255,255,.62); font-size: 13px; }
.case-kpis { display: grid; grid-template-columns: repeat(3, minmax(0,1fr)); gap: 12px; margin: 28px 0; }
.case-kpi { padding: 22px; border: 1px solid #dfe1dc; border-radius: 18px; background: #fff; }
.case-kpi strong { display: block; font-size: 28px; letter-spacing: -.05em; }
.case-kpi span { color: var(--muted); font-size: 11px; }
.case-story-photo { height: 390px; overflow: hidden; border-radius: 24px; }
.case-story-photo img { width: 100%; height: 100%; object-fit: cover; }
.timeline-list { display: grid; gap: 14px; counter-reset: step; }
.timeline-item { position: relative; padding: 24px 24px 24px 78px; border: 1px solid #dfe1dc; border-radius: 18px; background: #fff; }
.timeline-item::before { counter-increment: step; content: "0" counter(step); position: absolute; left: 22px; top: 22px; width: 38px; height: 38px; display: grid; place-items: center; border-radius: 11px; color: #111419; background: var(--accent); font-size: 10px; font-weight: 800; }
.timeline-item h3 { margin: 0 0 6px; font-size: 18px; }
.timeline-item p { margin: 0; color: var(--muted); font-size: 13px; }
.cta-band { padding: 42px; border-radius: 28px; color: #fff; background: #0d1015; display: grid; grid-template-columns: 1fr auto; gap: 32px; align-items: center; }
.cta-band h2 { margin: 0 0 10px; font-family: "Unbounded", sans-serif; font-size: clamp(28px, 3vw, 42px); letter-spacing: -.055em; }
.cta-band p { margin: 0; max-width: 720px; color: rgba(255,255,255,.56); }
.text-page { max-width: 920px; }
.text-page h1 { margin: 0 0 24px; font-family: "Unbounded", sans-serif; font-size: clamp(38px,5vw,64px); letter-spacing: -.06em; }
.text-page h2 { margin-top: 36px; font-size: 24px; }
.text-page p, .text-page li { color: var(--muted); }

@media (max-width: 1100px) {
  .page-hero-grid { grid-template-columns: 1fr; }
  .page-hero-photo { min-height: 390px; }
  .page-hero-photo img { min-height: 390px; }
  .case-list-grid { grid-template-columns: repeat(2, minmax(0,1fr)); }
  .feature-grid { grid-template-columns: repeat(2, minmax(0,1fr)); }
}
@media (max-width: 800px) {
  .service-photo-wrap { height: 190px; }
  .case-thumb { height: 210px; }
  .page-hero { padding: 130px 0 72px; }
  .page-hero-actions { align-items: flex-start; flex-direction: column; }
  .catalog-grid, .detail-layout { grid-template-columns: 1fr; }
  .side-panel { position: static; }
  .case-list-grid { grid-template-columns: 1fr; }
  .case-list-card { min-height: 430px; }
  .case-kpis { grid-template-columns: 1fr; }
  .cta-band { grid-template-columns: 1fr; padding: 32px; }
  .contact-photo { height: 180px; }
}
@media (max-width: 560px) {
  .page-hero h1 { font-size: 38px; }
  .page-hero-photo, .page-hero-photo img { min-height: 330px; }
  .page-hero-photo { border-radius: 23px; }
  .inner-section { padding: 74px 0; }
  .catalog-card-media { height: 220px; }
  .catalog-card-body, .content-card { padding: 22px; }
  .feature-grid { grid-template-columns: 1fr; }
  .case-list-card { min-height: 400px; }
  .case-story-photo { height: 270px; }
  .cta-band { padding: 24px; }
  .contact-photo { height: 150px; }
}

/* Premium services bento — homepage */
.services-premium {
  position: relative;
  overflow: hidden;
  background:
    radial-gradient(circle at 12% 6%, rgba(217,255,85,.22), transparent 22%),
    linear-gradient(180deg, #f3f4ef 0%, #e9ece5 100%);
}
.services-premium::before {
  content: "";
  position: absolute;
  width: 520px;
  height: 520px;
  right: -260px;
  top: 90px;
  border: 1px solid rgba(15,18,22,.06);
  border-radius: 50%;
  box-shadow: 0 0 0 70px rgba(15,18,22,.018), 0 0 0 140px rgba(15,18,22,.012);
  pointer-events: none;
}
.services-premium .container { position: relative; z-index: 1; }
.services-premium .section-heading { margin-bottom: 44px; }
.services-bento {
  display: grid;
  grid-template-columns: 1.12fr .88fr .88fr;
  grid-template-rows: repeat(2, minmax(300px, 1fr));
  gap: 18px;
}
.service-bento-card {
  position: relative;
  min-width: 0;
  overflow: hidden;
  border: 1px solid rgba(17,20,24,.09);
  border-radius: 28px;
  background: #fff;
  color: var(--text);
  box-shadow: 0 10px 35px rgba(22,28,19,.035);
  isolation: isolate;
  transition: transform .42s cubic-bezier(.2,.7,.2,1), box-shadow .42s ease, border-color .42s ease;
}
.service-bento-card:hover {
  transform: translateY(-7px);
  border-color: rgba(17,20,24,.16);
  box-shadow: 0 26px 70px rgba(22,28,19,.13);
}
.service-bento-card::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 5;
  border-radius: inherit;
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.22);
  pointer-events: none;
}
.service-bento-main { grid-row: 1 / span 2; min-height: 618px; color: #fff; }
.service-bento-media { position: relative; overflow: hidden; }
.service-bento-media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform .8s cubic-bezier(.2,.7,.2,1), filter .5s ease;
}
.service-bento-card:hover .service-bento-media img { transform: scale(1.055); }
.service-bento-main .service-bento-media { position: absolute; inset: 0; }
.service-bento-main .service-bento-media img { filter: saturate(.78) contrast(1.04); }
.service-bento-overlay {
  position: absolute;
  inset: 0;
  z-index: 1;
  background:
    linear-gradient(180deg, rgba(8,11,14,.08) 0%, rgba(8,11,14,.18) 38%, rgba(8,11,14,.92) 100%),
    linear-gradient(90deg, rgba(8,11,14,.28), transparent 70%);
}
.service-bento-body {
  position: relative;
  z-index: 2;
  min-height: 100%;
  padding: 25px;
  display: flex;
  flex-direction: column;
}
.service-bento-main .service-bento-body { padding: 32px; justify-content: space-between; }
.service-bento-meta { display: flex; align-items: center; justify-content: space-between; gap: 12px; }
.service-index {
  display: inline-grid;
  place-items: center;
  width: 39px;
  height: 39px;
  border: 1px solid rgba(15,18,22,.10);
  border-radius: 50%;
  color: #858a81;
  font-family: "Unbounded", sans-serif;
  font-size: 10px;
  font-weight: 700;
}
.service-label {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  padding: 8px 11px;
  border-radius: 999px;
  background: #f0f2ec;
  color: #555b52;
  font-size: 10px;
  font-weight: 800;
  letter-spacing: .035em;
  text-transform: uppercase;
}
.service-bento-main .service-index { border-color: rgba(255,255,255,.28); color: rgba(255,255,255,.76); }
.service-bento-main .service-label { background: rgba(255,255,255,.14); color: #fff; backdrop-filter: blur(12px); }
.service-bento-copy { margin-top: auto; }
.service-bento-copy h3 {
  margin: 0 0 12px;
  font-size: clamp(22px, 2vw, 28px);
  line-height: 1.08;
  letter-spacing: -.045em;
}
.service-bento-copy p { margin: 0; color: var(--muted); font-size: 14px; line-height: 1.65; }
.service-bento-main .service-bento-copy { max-width: 480px; padding-top: 180px; }
.service-bento-main .service-bento-copy h3 { max-width: 420px; font-size: clamp(34px, 3.5vw, 48px); }
.service-bento-main .service-bento-copy p { max-width: 430px; color: rgba(255,255,255,.72); font-size: 15px; }
.service-chips { display: flex; flex-wrap: wrap; gap: 7px; margin-top: 22px; }
.service-chips span {
  padding: 8px 11px;
  border: 1px solid rgba(255,255,255,.18);
  border-radius: 999px;
  background: rgba(0,0,0,.18);
  color: rgba(255,255,255,.78);
  font-size: 10px;
  font-weight: 700;
  backdrop-filter: blur(10px);
}
.service-round-arrow {
  position: absolute;
  right: 30px;
  bottom: 30px;
  width: 54px;
  height: 54px;
  display: grid;
  place-items: center;
  border-radius: 50%;
  background: var(--accent);
  color: #0a0d10;
  font-size: 16px;
  transition: transform .35s ease, background .35s ease;
}
.service-bento-main:hover .service-round-arrow { transform: rotate(8deg) scale(1.06); background: #e5ff89; }
.service-bento-light .service-bento-media,
.service-bento-dark .service-bento-media,
.service-bento-landing .service-bento-media { height: 132px; margin: 10px 10px 0; border-radius: 20px; }
.service-bento-light .service-bento-body,
.service-bento-dark .service-bento-body,
.service-bento-landing .service-bento-body { min-height: calc(100% - 142px); padding-top: 18px; }
.service-inline-link {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  margin-top: 18px;
  color: #30352f;
  font-size: 11px;
  font-weight: 800;
}
.service-inline-link i { transition: transform .25s ease; }
.service-bento-card:hover .service-inline-link i { transform: translateX(4px); }
.service-bento-dark { background: #11151a; color: #fff; border-color: #11151a; }
.service-bento-dark .service-bento-media img { opacity: .78; }
.service-bento-dark .service-index { border-color: rgba(255,255,255,.17); color: rgba(255,255,255,.55); }
.service-bento-dark .service-label { background: rgba(217,255,85,.10); color: var(--accent); }
.service-bento-dark .service-bento-copy p { color: rgba(255,255,255,.52); }
.service-bento-dark .service-inline-link { color: var(--accent); }
.service-bento-accent {
  background:
    linear-gradient(145deg, rgba(255,255,255,.28), transparent 55%),
    var(--accent);
  border-color: rgba(117,145,17,.28);
}
.service-bento-accent .service-bento-body { justify-content: flex-end; }
.service-bento-accent .service-bento-meta { position: absolute; top: 25px; left: 25px; right: 25px; }
.service-bento-accent .service-index { border-color: rgba(10,13,16,.14); color: rgba(10,13,16,.58); }
.service-bento-accent .service-label { background: rgba(255,255,255,.36); color: #353c20; }
.service-bento-accent .service-bento-copy p { color: rgba(10,13,16,.62); }
.service-bento-symbol {
  position: absolute;
  right: -18px;
  top: 42px;
  width: 152px;
  height: 152px;
  display: grid;
  place-items: center;
  border-radius: 50%;
  background: rgba(255,255,255,.26);
  color: rgba(20,25,16,.13);
  font-size: 66px;
  transform: rotate(-9deg);
}
.service-bento-accent .service-inline-link { color: #171b12; }
.service-bento-landing .service-bento-media img { object-position: center 58%; }

@media (max-width: 1100px) {
  .services-bento { grid-template-columns: 1fr 1fr; grid-template-rows: auto; }
  .service-bento-main { grid-column: 1 / span 2; grid-row: auto; min-height: 520px; }
  .service-bento-main .service-bento-copy { padding-top: 150px; }
}
@media (max-width: 800px) {
  .services-premium::before { display: none; }
  .services-bento { grid-template-columns: 1fr; gap: 14px; }
  .service-bento-main { grid-column: auto; min-height: 500px; }
  .service-bento-card { border-radius: 23px; }
  .service-bento-light,
  .service-bento-dark,
  .service-bento-accent,
  .service-bento-landing { min-height: 330px; }
  .service-bento-light .service-bento-media,
  .service-bento-dark .service-bento-media,
  .service-bento-landing .service-bento-media { height: 150px; }
  .service-bento-main .service-bento-copy { padding-top: 130px; padding-right: 52px; }
  .service-bento-main .service-bento-body { padding: 25px; }
  .service-round-arrow { right: 23px; bottom: 23px; width: 48px; height: 48px; }
}
@media (max-width: 560px) {
  .services-premium .section-heading { margin-bottom: 32px; }
  .service-bento-main { min-height: 460px; }
  .service-bento-main .service-bento-copy { padding-top: 108px; padding-right: 0; }
  .service-bento-main .service-bento-copy h3 { font-size: 31px; padding-right: 35px; }
  .service-bento-main .service-bento-copy p { font-size: 13px; padding-right: 34px; }
  .service-chips { padding-right: 20px; }
  .service-bento-body { padding: 21px; }
  .service-bento-light .service-bento-body,
  .service-bento-dark .service-bento-body,
  .service-bento-landing .service-bento-body { min-height: calc(100% - 160px); padding-top: 16px; }
  .service-bento-copy h3 { font-size: 23px; }
  .service-bento-accent .service-bento-meta { top: 21px; left: 21px; right: 21px; }
  .service-bento-symbol { width: 125px; height: 125px; font-size: 54px; }
  .service-round-arrow { width: 44px; height: 44px; right: 20px; bottom: 20px; }
}
/* SEO knowledge base and regional pages */
.city-directory-section {
  position: relative;
  overflow: hidden;
  background:
    radial-gradient(circle at 88% 14%, rgba(143,119,255,.12), transparent 26%),
    linear-gradient(180deg, #f4f4f0 0%, #eceee7 100%);
}
.city-directory-section::before {
  content: "";
  position: absolute;
  width: 420px;
  height: 420px;
  left: -180px;
  bottom: -250px;
  border-radius: 50%;
  background: rgba(217,255,85,.35);
  filter: blur(90px);
}
.city-link-grid {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 10px;
  margin-top: 38px;
}
.city-link-grid a {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  min-height: 54px;
  padding: 12px 15px;
  border: 1px solid rgba(10,12,16,.09);
  border-radius: 14px;
  background: rgba(255,255,255,.7);
  box-shadow: 0 10px 34px rgba(10,12,16,.035);
  font-size: 13px;
  font-weight: 750;
  transition: .25s ease;
}
.city-link-grid a::after {
  content: "↗";
  color: #92968d;
  font-size: 13px;
  transition: transform .25s ease, color .25s ease;
}
.city-link-grid a:hover {
  transform: translateY(-3px);
  border-color: rgba(10,12,16,.22);
  background: #fff;
  box-shadow: 0 16px 38px rgba(10,12,16,.07);
}
.city-link-grid a:hover::after { transform: translate(2px,-2px); color: #10130c; }
.city-directory-actions { display: flex; justify-content: center; margin-top: 30px; }

.seo-knowledge-section {
  position: relative;
  padding-top: 0;
  background: linear-gradient(180deg, #eceee7 0%, #f4f4f0 20%, #f4f4f0 100%);
}
.seo-knowledge-card {
  position: relative;
  overflow: hidden;
  padding: clamp(30px, 5vw, 68px);
  border: 1px solid rgba(10,12,16,.09);
  border-radius: 34px;
  background: #fff;
  box-shadow: 0 30px 100px rgba(10,12,16,.09);
}
.seo-knowledge-card::before {
  content: "";
  position: absolute;
  width: 360px;
  height: 360px;
  right: -190px;
  top: -210px;
  border-radius: 50%;
  background: var(--accent);
  opacity: .28;
  filter: blur(80px);
}
.seo-knowledge-head { position: relative; max-width: 900px; }
.seo-kicker {
  display: inline-flex;
  align-items: center;
  gap: 9px;
  margin-bottom: 18px;
  color: #61655b;
  font-size: 11px;
  font-weight: 850;
  letter-spacing: .12em;
  text-transform: uppercase;
}
.seo-kicker::before { content: ""; width: 25px; height: 2px; background: var(--accent-2); }
.seo-knowledge-head h2,
.city-seo-article > h2,
.cities-page-hero h1 {
  margin: 0;
  font-family: "Unbounded", sans-serif;
  font-weight: 600;
  letter-spacing: -.055em;
  line-height: 1.08;
}
.seo-knowledge-head h2 { font-size: clamp(32px, 4.2vw, 56px); }
.seo-knowledge-head > p { max-width: 800px; margin: 22px 0 0; color: var(--muted); font-size: 18px; }
.seo-answer-box {
  position: relative;
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 18px;
  margin-top: 34px;
  padding: 24px 26px;
  border: 1px solid rgba(10,12,16,.09);
  border-left: 4px solid var(--accent-2);
  border-radius: 18px;
  background: #f6f7f2;
}
.seo-answer-box::before {
  content: "AI";
  display: grid;
  place-items: center;
  width: 45px;
  height: 45px;
  border-radius: 13px;
  background: var(--dark);
  color: var(--accent);
  font-size: 12px;
  font-weight: 900;
  letter-spacing: .04em;
}
.seo-answer-box strong { display: block; margin-bottom: 5px; }
.seo-answer-box p { margin: 0; color: #555a50; }
.seo-toc {
  display: flex;
  flex-wrap: wrap;
  gap: 9px;
  margin: 28px 0 0;
  padding: 0;
  list-style: none;
}
.seo-toc a {
  display: inline-flex;
  padding: 9px 13px;
  border-radius: 999px;
  background: #f1f2ed;
  color: #555a50;
  font-size: 12px;
  font-weight: 750;
  transition: .2s ease;
}
.seo-toc a:hover { color: #0b0d12; background: var(--accent); }
.seo-article-grid {
  position: relative;
  display: grid;
  grid-template-columns: minmax(0, 1fr) 300px;
  gap: 56px;
  align-items: start;
  margin-top: 52px;
}
.seo-article-main { min-width: 0; }
.seo-article-main section { scroll-margin-top: 110px; padding: 31px 0; border-top: 1px solid #e5e7e1; }
.seo-article-main section:first-child { border-top: 0; padding-top: 0; }
.seo-article-main h2,
.seo-article-main h3,
.city-seo-main h2,
.city-seo-main h3,
.expert-seo-card h2,
.expert-seo-card h3 {
  margin: 0 0 15px;
  letter-spacing: -.035em;
  line-height: 1.2;
}
.seo-article-main h2, .city-seo-main h2, .expert-seo-card h2 { font-size: clamp(24px, 2.4vw, 34px); }
.seo-article-main h3, .city-seo-main h3, .expert-seo-card h3 { font-size: 21px; }
.seo-article-main p,
.city-seo-main p,
.expert-seo-card p { margin: 0 0 15px; color: #555a50; }
.seo-article-main ul,
.city-seo-main ul,
.expert-seo-card ul { margin: 16px 0; padding-left: 20px; color: #4f544b; }
.seo-article-main li + li,
.city-seo-main li + li,
.expert-seo-card li + li { margin-top: 9px; }
.seo-callout {
  margin: 23px 0;
  padding: 22px 24px;
  border-radius: 18px;
  background: var(--dark);
  color: #fff;
}
.seo-callout strong { color: var(--accent); }
.seo-callout p { margin: 6px 0 0; color: rgba(255,255,255,.68); }
.seo-steps { display: grid; gap: 13px; counter-reset: seo-step; margin-top: 24px; }
.seo-steps > div {
  counter-increment: seo-step;
  position: relative;
  padding: 18px 18px 18px 62px;
  border: 1px solid #e3e5df;
  border-radius: 16px;
  background: #fafbf8;
}
.seo-steps > div::before {
  content: counter(seo-step, decimal-leading-zero);
  position: absolute;
  left: 17px;
  top: 17px;
  display: grid;
  place-items: center;
  width: 31px;
  height: 31px;
  border-radius: 9px;
  background: var(--accent);
  color: #10120c;
  font-size: 11px;
  font-weight: 900;
}
.seo-steps strong { display: block; margin-bottom: 4px; }
.seo-steps p { margin: 0; font-size: 14px; }
.seo-factor-grid { display: grid; grid-template-columns: repeat(2, minmax(0,1fr)); gap: 13px; margin-top: 23px; }
.seo-factor-grid > div {
  padding: 20px;
  border: 1px solid #e2e4de;
  border-radius: 17px;
  background: #fafbf8;
}
.seo-factor-grid strong { display: block; margin-bottom: 6px; }
.seo-factor-grid p { margin: 0; font-size: 13px; }
.seo-article-aside { position: sticky; top: 112px; display: grid; gap: 14px; }
.seo-aside-card {
  padding: 22px;
  border: 1px solid rgba(10,12,16,.09);
  border-radius: 20px;
  background: #f5f6f1;
}
.seo-aside-card.dark { color: #fff; background: var(--dark); }
.seo-aside-card h3 { margin: 0 0 13px; font-size: 18px; letter-spacing: -.03em; }
.seo-aside-card p { margin: 0 0 16px; color: #65695f; font-size: 13px; }
.seo-aside-card.dark p { color: rgba(255,255,255,.6); }
.seo-aside-card a:not(.btn) { display: flex; gap: 8px; align-items: center; padding: 8px 0; border-bottom: 1px solid #e0e2dc; font-size: 13px; font-weight: 700; }
.seo-aside-card a:not(.btn):last-child { border-bottom: 0; }
.seo-article-footer {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 24px;
  margin-top: 36px;
  padding-top: 28px;
  border-top: 1px solid #e3e5df;
}
.seo-article-footer p { margin: 0; max-width: 720px; color: #686c63; font-size: 13px; }

/* City landing pages */
.city-page { background: #f4f4f0; }
.city-hero {
  position: relative;
  min-height: 790px;
  overflow: hidden;
  padding: 154px 0 76px;
  color: #fff;
  background:
    radial-gradient(circle at 80% 20%, rgba(143,119,255,.24), transparent 31%),
    radial-gradient(circle at 12% 75%, rgba(217,255,85,.13), transparent 30%),
    #0b0d12;
}
.city-hero::before {
  content: "";
  position: absolute;
  inset: 0;
  opacity: .42;
  background-image:
    linear-gradient(rgba(255,255,255,.025) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.025) 1px, transparent 1px);
  background-size: 62px 62px;
  mask-image: linear-gradient(to bottom, #000, transparent 95%);
}
.city-hero-grid { position: relative; z-index: 1; display: grid; grid-template-columns: minmax(0,1.08fr) minmax(380px,.92fr); gap: 70px; align-items: center; }
.breadcrumbs { display: flex; flex-wrap: wrap; gap: 8px; align-items: center; margin-bottom: 24px; color: rgba(255,255,255,.48); font-size: 12px; }
.breadcrumbs a:hover { color: var(--accent); }
.city-hero-copy h1 { margin: 18px 0 22px; font-family: "Unbounded", sans-serif; font-size: clamp(45px, 5vw, 72px); font-weight: 600; line-height: 1.03; letter-spacing: -.06em; }
.city-hero-copy h1 span { color: var(--accent); }
.city-hero-copy > p { max-width: 690px; color: rgba(255,255,255,.68); font-size: 18px; }
.city-hero-tags { display: flex; flex-wrap: wrap; gap: 9px; margin: 25px 0 0; }
.city-hero-tags span { padding: 9px 12px; border: 1px solid rgba(255,255,255,.12); border-radius: 999px; background: rgba(255,255,255,.05); color: rgba(255,255,255,.75); font-size: 12px; }
.city-hero-visual { position: relative; }
.city-visual-panel {
  position: relative;
  min-height: 480px;
  overflow: hidden;
  padding: 24px;
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 30px;
  background: linear-gradient(145deg, rgba(255,255,255,.1), rgba(255,255,255,.025));
  box-shadow: 0 40px 100px rgba(0,0,0,.36);
  backdrop-filter: blur(18px);
}
.city-visual-panel::before {
  content: "";
  position: absolute;
  inset: 24px;
  border-radius: 23px;
  background:
    linear-gradient(180deg, rgba(217,255,85,.18), transparent 58%),
    url("assets/images/analytics-office.webp") center/cover no-repeat;
  opacity: .6;
}
.city-visual-panel::after { content: ""; position: absolute; inset: 24px; border-radius: 23px; background: linear-gradient(to top, rgba(11,13,18,.96), transparent 64%); }
.city-visual-stat { position: absolute; z-index: 2; left: 45px; right: 45px; bottom: 45px; display: grid; grid-template-columns: repeat(2,1fr); gap: 10px; }
.city-visual-stat > div { padding: 17px; border: 1px solid rgba(255,255,255,.1); border-radius: 15px; background: rgba(11,13,18,.72); backdrop-filter: blur(12px); }
.city-visual-stat strong { display: block; color: var(--accent); font-family: "Unbounded",sans-serif; font-size: 22px; letter-spacing: -.04em; }
.city-visual-stat span { display: block; margin-top: 5px; color: rgba(255,255,255,.55); font-size: 11px; }
.city-answer-section { margin-top: -45px; position: relative; z-index: 3; padding: 0 0 90px; }
.city-answer-card { display: grid; grid-template-columns: auto 1fr; gap: 24px; padding: 28px 30px; border: 1px solid rgba(10,12,16,.08); border-radius: 24px; background: #fff; box-shadow: 0 25px 75px rgba(10,12,16,.1); }
.city-answer-icon { display: grid; place-items: center; width: 58px; height: 58px; border-radius: 17px; background: var(--accent); font-size: 20px; }
.city-answer-card h2 { margin: 0 0 8px; font-size: 23px; letter-spacing: -.035em; }
.city-answer-card p { margin: 0; color: var(--muted); }
.city-services-section { padding-top: 86px; }
.city-service-grid { display: grid; grid-template-columns: repeat(4, minmax(0,1fr)); gap: 14px; margin-top: 42px; }
.city-service-card { position: relative; min-height: 310px; padding: 25px; overflow: hidden; border: 1px solid rgba(255,255,255,.1); border-radius: 24px; background: #14171d; transition: .25s ease; }
.city-service-card::before { content: ""; position: absolute; width: 150px; height: 150px; right: -75px; top: -75px; border-radius: 50%; background: var(--accent); opacity: .08; filter: blur(20px); }
.city-service-card:hover { transform: translateY(-5px); border-color: rgba(217,255,85,.38); }
.city-service-card i { display: grid; place-items: center; width: 48px; height: 48px; border-radius: 14px; background: rgba(217,255,85,.1); color: var(--accent); }
.city-service-card h3 { margin: 54px 0 11px; font-size: 21px; letter-spacing: -.035em; }
.city-service-card p { margin: 0; color: rgba(255,255,255,.55); font-size: 13px; }
.city-service-card a { position: absolute; left: 25px; bottom: 24px; color: var(--accent); font-size: 12px; font-weight: 800; }
.city-strategy-section { background: linear-gradient(180deg, #f4f4f0, #eceee7); }
.city-strategy-grid { display: grid; grid-template-columns: minmax(0,.88fr) minmax(0,1.12fr); gap: 70px; align-items: start; }
.city-strategy-copy { position: sticky; top: 110px; }
.city-strategy-copy h2 { margin: 20px 0; font-family: "Unbounded",sans-serif; font-size: clamp(34px,4vw,52px); line-height: 1.08; letter-spacing: -.055em; font-weight: 600; }
.city-strategy-copy > p { color: var(--muted); font-size: 17px; }
.city-strategy-points { display: grid; gap: 11px; margin-top: 26px; }
.city-strategy-points div { display: flex; align-items: flex-start; gap: 11px; padding: 13px 14px; border: 1px solid rgba(10,12,16,.08); border-radius: 14px; background: rgba(255,255,255,.56); font-size: 13px; }
.city-strategy-points i { margin-top: 3px; color: #6c8b08; }
.city-niche-grid { display: grid; grid-template-columns: repeat(2,minmax(0,1fr)); gap: 14px; }
.city-niche-card { min-height: 190px; padding: 24px; border: 1px solid rgba(10,12,16,.09); border-radius: 23px; background: #fff; box-shadow: 0 16px 45px rgba(10,12,16,.045); }
.city-niche-card i { color: #7d68e7; font-size: 20px; }
.city-niche-card h3 { margin: 30px 0 8px; font-size: 19px; letter-spacing: -.03em; }
.city-niche-card p { margin: 0; color: var(--muted); font-size: 13px; }
.city-seo-section { background: #fff; }
.city-seo-article { max-width: 1080px; margin-inline: auto; }
.city-seo-article > h2 { max-width: 880px; font-size: clamp(34px,4.2vw,54px); }
.city-seo-lead { max-width: 850px; margin: 21px 0 0; color: var(--muted); font-size: 18px; }
.city-seo-columns { display: grid; grid-template-columns: minmax(0,1fr) 280px; gap: 55px; align-items: start; margin-top: 48px; }
.city-seo-main section { padding: 28px 0; border-top: 1px solid #e5e7e1; }
.city-seo-main section:first-child { padding-top: 0; border-top: 0; }
.city-seo-aside { position: sticky; top: 112px; }
.nearby-cities-section { padding-top: 0; background: #fff; }
.nearby-cities-card { display: grid; grid-template-columns: .65fr 1.35fr; gap: 40px; align-items: center; padding: 32px; border-radius: 25px; background: #f0f2eb; }
.nearby-cities-card h2 { margin: 0; font-size: 25px; letter-spacing: -.04em; }
.nearby-city-links { display: flex; flex-wrap: wrap; gap: 9px; }
.nearby-city-links a { padding: 10px 13px; border-radius: 999px; background: #fff; font-size: 12px; font-weight: 750; transition: .2s ease; }
.nearby-city-links a:hover { color: #12140e; background: var(--accent); }

/* Cities directory */
.cities-page-hero { min-height: 570px; padding: 168px 0 88px; color: #fff; background: radial-gradient(circle at 75% 20%,rgba(143,119,255,.25),transparent 30%),#0b0d12; }
.cities-page-hero h1 { max-width: 950px; font-size: clamp(45px,5.4vw,74px); }
.cities-page-hero h1 span { color: var(--accent); }
.cities-page-hero p { max-width: 780px; margin-top: 24px; color: rgba(255,255,255,.65); font-size: 18px; }
.cities-catalog-section { background: linear-gradient(180deg,#f4f4f0,#eceee7); }
.cities-intro { display: grid; grid-template-columns: .9fr 1.1fr; gap: 55px; align-items: end; margin-bottom: 42px; }
.cities-intro h2 { margin: 0; font-family: "Unbounded",sans-serif; font-size: clamp(32px,4vw,52px); line-height: 1.08; letter-spacing: -.055em; font-weight: 600; }
.cities-intro p { margin: 0; color: var(--muted); }
.cities-directory-grid { display: grid; grid-template-columns: repeat(4,minmax(0,1fr)); gap: 13px; }
.city-directory-card { position: relative; min-height: 185px; padding: 22px; overflow: hidden; border: 1px solid rgba(10,12,16,.085); border-radius: 21px; background: #fff; transition: .25s ease; }
.city-directory-card::after { content: "↗"; position: absolute; right: 20px; bottom: 18px; color: #a3a69e; transition: .25s ease; }
.city-directory-card:hover { transform: translateY(-4px); border-color: rgba(10,12,16,.2); box-shadow: 0 20px 45px rgba(10,12,16,.07); }
.city-directory-card:hover::after { transform: translate(2px,-2px); color: #10120c; }
.city-directory-card span { display: inline-flex; padding: 6px 9px; border-radius: 999px; background: #f0f2eb; color: #6b6f65; font-size: 10px; font-weight: 850; text-transform: uppercase; letter-spacing: .08em; }
.city-directory-card h3 { margin: 26px 0 7px; font-size: 19px; letter-spacing: -.035em; }
.city-directory-card p { max-width: 88%; margin: 0; color: var(--muted); font-size: 12px; }

/* Additional expert blocks on services and cases */
.expert-seo-section { padding-top: 0; background: #f4f4f0; }
.expert-seo-card { padding: clamp(28px,4.8vw,58px); border: 1px solid rgba(10,12,16,.09); border-radius: 29px; background: #fff; box-shadow: 0 25px 80px rgba(10,12,16,.07); }
.expert-seo-card > p { max-width: 920px; font-size: 16px; }
.expert-seo-points { display: grid; grid-template-columns: repeat(3,minmax(0,1fr)); gap: 12px; margin: 25px 0; }
.expert-seo-points > div { padding: 18px; border: 1px solid #e2e4de; border-radius: 16px; background: #f7f8f4; }
.expert-seo-points strong { display: block; margin-bottom: 6px; font-size: 14px; }
.expert-seo-points p { margin: 0; font-size: 12px; }

@media (max-width: 1100px) {
  .city-link-grid { grid-template-columns: repeat(4,minmax(0,1fr)); }
  .seo-article-grid, .city-seo-columns { grid-template-columns: minmax(0,1fr) 260px; gap: 36px; }
  .city-hero-grid { grid-template-columns: 1fr 380px; gap: 40px; }
  .city-service-grid, .cities-directory-grid { grid-template-columns: repeat(2,minmax(0,1fr)); }
  .expert-seo-points { grid-template-columns: repeat(2,minmax(0,1fr)); }
}
@media (max-width: 850px) {
  .city-link-grid { grid-template-columns: repeat(3,minmax(0,1fr)); }
  .seo-article-grid, .city-seo-columns { grid-template-columns: 1fr; }
  .seo-article-aside, .city-seo-aside, .city-strategy-copy { position: static; }
  .city-hero { min-height: auto; }
  .city-hero-grid { grid-template-columns: 1fr; }
  .city-hero-visual { max-width: 620px; width: 100%; }
  .city-strategy-grid, .nearby-cities-card, .cities-intro { grid-template-columns: 1fr; gap: 28px; }
}
@media (max-width: 700px) {
  .city-link-grid { grid-template-columns: repeat(2,minmax(0,1fr)); }
  .seo-knowledge-card { border-radius: 24px; }
  .seo-answer-box { grid-template-columns: 1fr; }
  .seo-factor-grid, .expert-seo-points { grid-template-columns: 1fr; }
  .seo-article-footer { align-items: flex-start; flex-direction: column; }
  .city-hero { padding-top: 128px; padding-bottom: 80px; }
  .city-hero-copy h1 { font-size: clamp(38px,11vw,55px); }
  .city-visual-panel { min-height: 390px; }
  .city-answer-section { margin-top: -35px; padding-bottom: 60px; }
  .city-answer-card { grid-template-columns: 1fr; padding: 23px; }
  .city-service-grid, .city-niche-grid, .cities-directory-grid { grid-template-columns: 1fr; }
  .city-service-card { min-height: 270px; }
  .nearby-cities-card { padding: 24px; }
  .cities-page-hero { min-height: 500px; padding-top: 145px; }
}
@media (max-width: 460px) {
  .city-link-grid { grid-template-columns: 1fr; }
  .city-link-grid a { min-height: 49px; }
  .seo-knowledge-card { padding: 24px 19px; }
  .seo-answer-box { padding: 20px; }
  .seo-article-main section { padding: 24px 0; }
  .city-hero-copy > p, .city-seo-lead { font-size: 16px; }
  .city-visual-panel { min-height: 335px; padding: 14px; }
  .city-visual-panel::before, .city-visual-panel::after { inset: 14px; }
  .city-visual-stat { left: 27px; right: 27px; bottom: 27px; grid-template-columns: 1fr; }
  .city-visual-stat > div:nth-child(n+3) { display: none; }
  .city-strategy-copy h2, .city-seo-article > h2, .cities-intro h2 { font-size: 31px; }
}

/* City hero visual alignment refinements */
.city-hero-visual {
  min-height: 520px;
  overflow: hidden;
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 31px;
  background: #151820;
  box-shadow: 0 40px 100px rgba(0,0,0,.34);
}
.city-hero-visual::after {
  content: "";
  position: absolute;
  z-index: 1;
  inset: 0;
  background: linear-gradient(180deg, transparent 35%, rgba(11,13,18,.88) 100%);
  pointer-events: none;
}
.city-hero-visual > img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.city-visual-panel {
  position: absolute;
  z-index: 3;
  left: 24px;
  right: 24px;
  bottom: 24px;
  min-height: 0;
  padding: 20px 235px 20px 20px;
  overflow: visible;
  border-radius: 19px;
  background: rgba(11,13,18,.76);
  backdrop-filter: blur(18px);
}
.city-visual-panel::before,
.city-visual-panel::after { display: none; }
.city-visual-panel > span,
.city-visual-panel > strong,
.city-visual-panel > small { display: block; }
.city-visual-panel > span { margin-bottom: 6px; color: rgba(255,255,255,.46); font-size: 10px; text-transform: uppercase; letter-spacing: .09em; }
.city-visual-panel > strong { color: #fff; font-size: 16px; line-height: 1.35; }
.city-visual-panel > small { margin-top: 7px; color: rgba(255,255,255,.5); font-size: 10px; line-height: 1.45; }
.city-visual-stat {
  position: absolute;
  z-index: 4;
  top: auto;
  right: 38px;
  bottom: 38px;
  left: auto;
  width: 205px;
  display: grid;
  grid-template-columns: 34px 1fr;
  align-items: start;
  gap: 11px;
  padding: 16px;
  border: 1px solid rgba(217,255,85,.18);
  border-radius: 15px;
  background: #101218;
  box-shadow: 0 14px 40px rgba(0,0,0,.25);
}
.city-visual-stat > i { display: grid; place-items: center; width: 34px; height: 34px; border-radius: 10px; background: rgba(217,255,85,.12); color: var(--accent); }
.city-visual-stat > div { padding: 0; border: 0; border-radius: 0; background: transparent; backdrop-filter: none; }
.city-visual-stat span { margin: 0 0 4px; color: rgba(255,255,255,.42); font-size: 9px; }
.city-visual-stat strong { color: var(--accent); font-family: "Manrope",sans-serif; font-size: 11px; line-height: 1.4; letter-spacing: 0; }
.city-answer-card { grid-template-columns: auto minmax(0,1fr) auto; align-items: center; }
.city-answer-card > a { display: inline-flex; align-items: center; gap: 9px; white-space: nowrap; padding: 11px 14px; border-radius: 999px; background: #f0f2eb; font-size: 12px; font-weight: 800; }
.city-answer-card > a:hover { background: var(--accent); }
.city-answer-card > div:nth-child(2) > span { display: block; margin-bottom: 5px; color: #74786f; font-size: 10px; font-weight: 850; letter-spacing: .1em; text-transform: uppercase; }
.city-service-card > span { display: inline-flex; color: rgba(255,255,255,.33); font-size: 10px; font-weight: 850; letter-spacing: .1em; }
.city-service-card > i { position: absolute; right: 24px; top: 22px; }
.city-service-card h3 { margin: 62px 0 11px; }
.city-service-card > b { position: absolute; left: 25px; bottom: 23px; color: var(--accent); font-size: 12px; }
.city-niche-card > strong { display: block; margin: 28px 0 8px; font-size: 18px; letter-spacing: -.03em; }
.city-niche-card > span { display: block; color: var(--muted); font-size: 13px; }

@media (max-width: 700px) {
  .city-answer-card { grid-template-columns: 1fr; }
  .city-answer-card > a { justify-self: start; }
  .city-hero-visual { min-height: 410px; }
  .city-visual-panel { left: 14px; right: 14px; bottom: 14px; padding: 18px; padding-bottom: 105px; }
  .city-visual-stat { right: 27px; left: 27px; bottom: 27px; width: auto; }
}

/* Mini CMS runtime: brand, geo menu and forms */
.brand-logo-image{display:block;max-width:190px;max-height:48px;width:auto;height:auto;object-fit:contain}.geo-selector{position:relative;display:block}.geo-trigger{height:42px;padding:0 12px;border:1px solid rgba(18,22,28,.12);background:rgba(255,255,255,.72);border-radius:12px;display:flex;align-items:center;gap:8px;font:inherit;font-size:12px;font-weight:750;color:#1b2029;cursor:pointer;white-space:nowrap}.site-header:not(.scrolled) .geo-trigger{background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.13);color:#fff}.geo-trigger .fa-location-dot{color:#9dbd27}.geo-trigger .fa-chevron-down{font-size:9px;opacity:.6;transition:transform .2s}.geo-selector.open .geo-trigger .fa-chevron-down{transform:rotate(180deg)}.geo-mega{position:absolute;right:-250px;top:calc(100% + 16px);width:min(850px,calc(100vw - 48px));padding:25px;background:rgba(255,255,255,.98);border:1px solid rgba(18,22,28,.1);border-radius:24px;box-shadow:0 30px 80px rgba(13,17,23,.2);color:#171b22;opacity:0;visibility:hidden;transform:translateY(-8px);transition:.22s;z-index:100}.geo-selector.open .geo-mega{opacity:1;visibility:visible;transform:none}.geo-mega:before{content:"";position:absolute;top:-8px;right:285px;width:16px;height:16px;background:#fff;border-left:1px solid rgba(18,22,28,.1);border-top:1px solid rgba(18,22,28,.1);transform:rotate(45deg)}.geo-mega-head{display:flex;justify-content:space-between;align-items:center;gap:24px;padding-bottom:18px;border-bottom:1px solid #e8ebef}.geo-mega-head div{display:grid;gap:4px}.geo-mega-head small{text-transform:uppercase;letter-spacing:.1em;font-size:9px;font-weight:800;color:#9299a5}.geo-mega-head strong{font-size:22px;letter-spacing:-.03em}.geo-mega-head label{width:270px;height:42px;border:1px solid #dfe3e8;border-radius:12px;display:flex;align-items:center;gap:9px;padding:0 12px;background:#f8f9fa}.geo-mega-head label i{color:#9ba2ad}.geo-mega-head input{border:0;outline:0;background:transparent;width:100%;font:inherit;font-size:13px}.geo-city-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:5px 12px;padding:18px 0;max-height:340px;overflow:auto}.geo-city-grid a{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:9px 10px;border-radius:9px;color:#262c35;text-decoration:none;font-size:12px;font-weight:650}.geo-city-grid a:hover{background:#efffbb;color:#171b22}.geo-city-grid a i{font-size:9px;opacity:.45}.geo-mega-foot{font-size:11px;color:#7c8491;background:#f5f6f8;padding:11px 13px;border-radius:10px}.geo-suggestion{position:fixed;z-index:1000;right:28px;top:92px;display:grid;grid-template-columns:42px 1fr auto auto 28px;align-items:center;gap:10px;padding:13px 14px;background:#fff;border:1px solid rgba(18,22,28,.1);border-radius:17px;box-shadow:0 20px 60px rgba(16,20,27,.2);opacity:0;transform:translateY(-12px);transition:.25s}.geo-suggestion.show{opacity:1;transform:none}.geo-suggestion-icon{width:42px;height:42px;display:grid;place-items:center;border-radius:12px;background:#efffbb;color:#6d860d}.geo-suggestion>div:nth-child(2){display:grid;gap:2px;min-width:130px}.geo-suggestion small{font-size:9px;text-transform:uppercase;letter-spacing:.07em;color:#8a929e;font-weight:800}.geo-suggestion strong{font-size:14px}.geo-suggestion button{border:0;border-radius:9px;padding:9px 11px;font:inherit;font-size:11px;font-weight:750;cursor:pointer}.geo-yes{background:#171b22;color:#fff}.geo-change{background:#f0f2f5;color:#303640}.geo-suggestion .geo-dismiss{padding:0;width:28px;height:28px;background:transparent;color:#8b929e;font-size:20px}.modal-form textarea{width:100%;resize:vertical;min-height:88px;border:1px solid rgba(17,20,26,.13);border-radius:13px;padding:13px 15px;font:inherit;color:inherit;background:#fff}.hp-field{position:absolute!important;left:-10000px!important;width:1px!important;height:1px!important;opacity:0!important;pointer-events:none!important}.success-toast.error{border-color:#efb5bf}.success-toast.error>i{color:#d13e56}.runtime-case-metric{display:flex;align-items:baseline;gap:8px;margin:14px 0}.runtime-case-metric strong{font-size:24px;color:#7f9c19}.runtime-case-metric span{font-size:11px;color:#858c97}.floating-contact{border:0;cursor:pointer;font:inherit}.btn:disabled{opacity:.65;cursor:wait}@media(max-width:1180px){.geo-trigger span{max-width:85px;overflow:hidden;text-overflow:ellipsis}.geo-mega{right:-170px}.geo-mega:before{right:205px}}@media(max-width:980px){.geo-selector,.geo-suggestion{display:none!important}.brand-logo-image{max-width:155px;max-height:40px}}@media(max-width:640px){.brand-logo-image{max-width:135px;max-height:36px}}
.managed-rich-content h2{margin:0 0 18px;font-size:clamp(26px,3vw,40px);letter-spacing:-.045em}.managed-rich-content h2:not(:first-child){margin-top:42px}.managed-rich-content h3{margin:30px 0 14px;font-size:21px}.managed-rich-content p{font-size:16px;line-height:1.8;color:#555e69}.managed-rich-content ul,.managed-rich-content ol{display:grid;gap:11px;margin:18px 0 25px;padding-left:0;list-style:none}.managed-rich-content li{position:relative;padding:13px 16px 13px 43px;background:#f5f7f8;border-radius:12px;color:#343b45;line-height:1.55}.managed-rich-content li:before{content:"✓";position:absolute;left:15px;top:13px;width:20px;height:20px;border-radius:6px;background:#d9ff55;color:#253000;display:grid;place-items:center;font-size:11px;font-weight:900}.managed-rich-content blockquote{margin:28px 0;padding:20px 23px;border-left:4px solid #badb3e;background:#f5f8ea;border-radius:0 14px 14px 0;color:#3d4730}.managed-rich-content a{color:#688700;text-underline-offset:3px}.managed-rich-content table{width:100%;border-collapse:collapse;margin:24px 0}.managed-rich-content th,.managed-rich-content td{border:1px solid #e1e5e9;padding:12px;text-align:left}.case-hero-metric{display:flex;align-items:baseline;gap:10px;margin:22px 0 0;color:#d9ff55}.case-hero-metric strong{font-family:var(--font-display);font-size:42px}.case-hero-metric span{color:rgba(255,255,255,.68);font-size:13px}


/* === DIRECTOLOG 2026 layout repair: services and city homepage clones === */
.services-premium-v2{overflow:hidden;background:linear-gradient(180deg,#f8f9f5 0%,#fff 100%)}
.services-premium-v2 .split-heading{align-items:end;margin-bottom:42px}
.home-service-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:18px;align-items:stretch}
.home-service-card{position:relative;isolation:isolate;display:flex;min-width:0;min-height:500px;overflow:hidden;border:1px solid rgba(255,255,255,.11);border-radius:28px;background:#11161d;color:#fff;text-decoration:none;box-shadow:0 20px 54px rgba(17,22,29,.10);transition:transform .35s ease,box-shadow .35s ease,border-color .35s ease}
.home-service-card:hover{transform:translateY(-8px);border-color:rgba(217,255,85,.55);box-shadow:0 30px 70px rgba(17,22,29,.18)}
.home-service-media{position:absolute;z-index:-3;inset:0}
.home-service-media img{width:100%;height:100%;object-fit:cover;filter:saturate(.72) contrast(1.05);transform:scale(1.015);transition:transform .65s ease,filter .65s ease}
.home-service-card:hover .home-service-media img{transform:scale(1.06);filter:saturate(.95) contrast(1.06)}
.home-service-shade{position:absolute;z-index:-2;inset:0;background:linear-gradient(180deg,rgba(9,12,17,.18) 0%,rgba(9,12,17,.62) 42%,rgba(9,12,17,.97) 78%,#090c11 100%)}
.home-service-card::after{content:"";position:absolute;z-index:-1;inset:0;background:radial-gradient(circle at 88% 12%,rgba(217,255,85,.13),transparent 30%);pointer-events:none}
.home-service-top{position:absolute;left:24px;right:24px;top:23px;display:flex;align-items:center;justify-content:space-between;gap:12px}
.home-service-top>span{display:grid;place-items:center;width:42px;height:42px;border:1px solid rgba(255,255,255,.3);border-radius:50%;color:#fff;font-size:11px;font-weight:800}
.home-service-top>b{display:inline-flex;align-items:center;gap:7px;max-width:72%;padding:8px 11px;border:1px solid rgba(255,255,255,.15);border-radius:999px;background:rgba(11,15,21,.46);backdrop-filter:blur(12px);color:#fff;font-size:9px;font-weight:800;letter-spacing:.07em;text-transform:uppercase;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.home-service-top>b i{color:var(--accent)}
.home-service-content{align-self:flex-end;width:100%;padding:30px 25px 26px}
.home-service-content h3{max-width:95%;margin:0 0 13px;color:#fff;font-size:clamp(23px,1.8vw,31px);line-height:1.06;letter-spacing:-.045em}
.home-service-content p{min-height:88px;margin:0;color:rgba(255,255,255,.68);font-size:13px;line-height:1.65}
.home-service-chips{display:flex;flex-wrap:wrap;gap:6px;margin-top:18px}
.home-service-chips span{padding:7px 9px;border:1px solid rgba(255,255,255,.16);border-radius:999px;color:rgba(255,255,255,.82);font-size:9px;font-weight:750}
.home-service-link{display:flex;align-items:center;justify-content:space-between;margin-top:22px;padding-top:18px;border-top:1px solid rgba(255,255,255,.12);color:var(--accent);font-size:12px;font-weight:850}
.home-service-link i{display:grid;place-items:center;width:34px;height:34px;border-radius:11px;background:rgba(217,255,85,.13);transition:.25s}
.home-service-card:hover .home-service-link i{background:var(--accent);color:#10130c;transform:translateX(3px)}
.services-section-action{display:flex;justify-content:center;margin-top:32px}
.city-directory-v2{padding-top:48px;padding-bottom:86px;background:#fff}
.city-navigation-panel{display:grid;grid-template-columns:minmax(300px,.86fr) minmax(0,1.55fr);gap:50px;align-items:center;padding:45px;border:1px solid rgba(16,20,24,.09);border-radius:34px;background:radial-gradient(circle at 88% 16%,rgba(217,255,85,.20),transparent 30%),linear-gradient(135deg,#f4f6f0 0%,#fbfcf9 52%,#f1f4ec 100%);box-shadow:0 24px 70px rgba(22,28,20,.07)}
.city-navigation-copy h2{margin:17px 0 15px;font-size:clamp(32px,3.3vw,52px);line-height:1.02;letter-spacing:-.055em}
.city-navigation-copy p{max-width:580px;margin:0 0 24px;color:var(--muted);font-size:15px;line-height:1.7}
.city-navigation-links{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}
.city-navigation-links a{display:flex;align-items:center;justify-content:space-between;gap:12px;min-width:0;padding:14px 15px;border:1px solid rgba(16,20,24,.08);border-radius:14px;background:rgba(255,255,255,.84);color:#171b21;text-decoration:none;font-size:12px;font-weight:800;transition:.25s}
.city-navigation-links a span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.city-navigation-links a i{flex:0 0 auto;color:#8fae23;font-size:10px;transition:.25s}
.city-navigation-links a:hover{transform:translateY(-2px);border-color:rgba(143,174,35,.4);background:#fff;box-shadow:0 12px 25px rgba(19,24,17,.08)}
.city-navigation-links a:hover i{transform:translateX(3px)}
.local-niche-list{display:flex;flex-wrap:wrap;gap:8px;margin-top:14px}
.local-niche-chip{display:inline-flex!important;padding:8px 10px!important;border-radius:999px;background:#eef1e8;color:#4d5546;font-size:11px!important;font-weight:750!important;line-height:1.2!important}
.city-home-page .hero{min-height:900px}
.city-home-page .seo-article-body>h3:first-child{margin-top:0}
@media(max-width:1180px){.home-service-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.home-service-card{min-height:460px}.city-navigation-panel{grid-template-columns:1fr;gap:30px}.city-navigation-links{grid-template-columns:repeat(4,minmax(0,1fr))}}
@media(max-width:820px){.city-navigation-panel{padding:30px}.city-navigation-links{grid-template-columns:repeat(2,minmax(0,1fr))}.city-home-page .hero{min-height:auto}}
@media(max-width:640px){.services-premium-v2 .split-heading{margin-bottom:28px}.home-service-grid{grid-template-columns:1fr;gap:14px}.home-service-card{min-height:430px;border-radius:24px}.home-service-content{padding:26px 21px 22px}.home-service-content p{min-height:0}.city-directory-v2{padding-top:20px;padding-bottom:66px}.city-navigation-panel{padding:24px;border-radius:26px}.city-navigation-links{grid-template-columns:1fr}.city-navigation-links a{padding:13px 14px}}


/* Premium animated Hero proof badges */
.hero-proof-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;margin-top:42px;padding-top:0;border-top:0}
.hero-proof-badge{position:relative;display:grid;grid-template-columns:42px 1fr;align-items:center;gap:12px;min-height:88px;padding:14px 14px 14px 13px;border:1px solid rgba(255,255,255,.11);border-radius:18px;background:linear-gradient(145deg,rgba(255,255,255,.075),rgba(255,255,255,.025));box-shadow:inset 0 1px 0 rgba(255,255,255,.05);overflow:hidden;transition:transform .3s ease,border-color .3s ease,background .3s ease}
.hero-proof-badge::after{content:"";position:absolute;width:90px;height:90px;border-radius:50%;right:-50px;top:-50px;background:var(--accent);filter:blur(35px);opacity:.07;pointer-events:none}
.hero-proof-badge:hover{transform:translateY(-4px);border-color:rgba(217,255,85,.28);background:linear-gradient(145deg,rgba(217,255,85,.08),rgba(255,255,255,.025))}
.proof-icon{width:42px;height:42px;display:grid;place-items:center;border-radius:13px;background:rgba(217,255,85,.1);border:1px solid rgba(217,255,85,.13);color:var(--accent);font-size:15px;box-shadow:0 10px 25px rgba(0,0,0,.16)}
.hero-proof-badge>div{min-width:0;display:grid;gap:3px}
.hero-proof-badge strong{display:flex;align-items:baseline;gap:2px;font-family:"Unbounded",sans-serif;font-size:20px;line-height:1;color:#fff;letter-spacing:-.04em;font-variant-numeric:tabular-nums}
.hero-proof-badge strong small{font-family:"Manrope",sans-serif;font-size:10px;text-transform:uppercase;letter-spacing:.08em;color:rgba(255,255,255,.52)}
.hero-proof-badge strong sup{font-family:"Manrope",sans-serif;font-size:10px;color:var(--accent);letter-spacing:0}
.hero-proof-badge>div>span{font-size:10px;line-height:1.4;color:rgba(255,255,255,.48)}
.hero-proof-badge.counter-complete .proof-icon{animation:proofPulse .55s ease}
@keyframes proofPulse{0%,100%{transform:scale(1)}50%{transform:scale(1.12);box-shadow:0 0 0 8px rgba(217,255,85,.06)}}
.js-counter{font-variant-numeric:tabular-nums}
.live-badge{position:relative;overflow:hidden;font-weight:700;letter-spacing:.015em}
.live-badge::after{content:"";position:absolute;inset:0;transform:translateX(-110%);background:linear-gradient(90deg,transparent,rgba(255,255,255,.13),transparent);animation:liveShine 3.8s ease-in-out infinite}
.live-badge b{animation:livePulse 1.8s ease-in-out infinite}
@keyframes livePulse{0%,100%{transform:scale(.85);opacity:.75;box-shadow:0 0 8px var(--accent)}50%{transform:scale(1.25);opacity:1;box-shadow:0 0 18px var(--accent)}}
@keyframes liveShine{0%,55%{transform:translateX(-110%)}80%,100%{transform:translateX(110%)}}
.chart-area .line{stroke-dasharray:900;stroke-dashoffset:900;animation:drawHeroLine 1.7s .35s cubic-bezier(.22,.8,.25,1) forwards}
.chart-area .area{opacity:0;animation:fadeHeroArea .9s 1.1s ease forwards}
@keyframes drawHeroLine{to{stroke-dashoffset:0}}
@keyframes fadeHeroArea{to{opacity:1}}
@media(max-width:800px){
  .hero-proof-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;margin-top:34px}
  .hero-proof-badge{min-height:80px;padding:11px;grid-template-columns:38px 1fr;border-radius:15px}
  .hero-proof-badge:nth-child(3){grid-column:1/-1;grid-template-columns:38px 1fr}
  .proof-icon{width:38px;height:38px;border-radius:11px}
  .hero-proof-badge strong{font-size:18px}
}
@media(max-width:560px){
  .hero-proof-grid{margin-top:28px;gap:8px}
  .hero-proof-badge{min-height:76px;padding:10px;gap:9px}
  .hero-proof-badge>div>span{font-size:9px}
  .hero-proof-badge strong{font-size:17px}
  .dashboard-topbar{height:48px;padding:0 11px}
  .live-badge{padding:5px 8px;font-size:9px}
}
@media(prefers-reduced-motion:reduce){.live-badge::after,.live-badge b,.chart-area .line,.chart-area .area{animation:none}.chart-area .line{stroke-dashoffset:0}.chart-area .area{opacity:1}}

/* Hero dashboard metric readability fix — 2026-06-24 */
.metric-row{
  grid-template-columns:minmax(0,1.34fr) minmax(190px,.66fr);
  gap:14px;
}
.metric-card{
  min-width:0;
  min-height:146px;
  padding:22px 24px;
  display:flex;
  flex-direction:column;
  justify-content:center;
  overflow:visible;
}
.metric-card > span{
  display:block;
  color:rgba(255,255,255,.58);
  font-size:13px;
  line-height:1.3;
}
.metric-card strong{
  display:inline-flex;
  align-items:baseline;
  gap:7px;
  width:max-content;
  max-width:100%;
  margin:11px 0 10px;
  color:#fff;
  font-family:"Unbounded",sans-serif;
  font-size:clamp(34px,3.05vw,46px);
  font-weight:600;
  line-height:1;
  letter-spacing:-.065em;
  white-space:nowrap;
  overflow:visible;
  font-variant-numeric:tabular-nums;
  text-shadow:0 3px 22px rgba(255,255,255,.08);
}
.metric-card strong .js-counter{
  display:inline-block !important;
  color:inherit !important;
  font:inherit !important;
  line-height:inherit !important;
  letter-spacing:inherit !important;
  white-space:nowrap !important;
}
.metric-card small{
  display:flex;
  align-items:center;
  gap:4px;
  color:#ff8585;
  font-size:11px;
  line-height:1.35;
}
.metric-card .positive{
  color:var(--accent);
  font-size:12px;
  font-weight:800;
}
.chart-head > div:first-child > span{
  display:block;
  color:rgba(255,255,255,.48);
  font-size:11px;
}
.chart-head > div:first-child > strong{
  display:block;
  margin-top:3px;
  color:#fff;
  font-family:"Unbounded",sans-serif;
  font-size:30px;
  line-height:1;
  letter-spacing:-.045em;
}
.chart-head strong .js-counter{
  display:inline !important;
  color:inherit !important;
  font:inherit !important;
  line-height:inherit !important;
}
.score-ring .js-counter{
  display:inline !important;
  color:#101218 !important;
  font-size:14px !important;
  font-weight:900 !important;
  line-height:1 !important;
}
/* Keep the decorative notification clear of the KPI values. */
.floating-one{
  top:86px;
  left:-8%;
}

@media(max-width:800px){
  .metric-row{
    grid-template-columns:minmax(0,1.2fr) minmax(128px,.8fr);
    gap:9px;
  }
  .metric-card{
    min-height:122px;
    padding:16px;
  }
  .metric-card > span{font-size:11px}
  .metric-card strong{
    gap:4px;
    margin:9px 0 8px;
    font-size:31px;
  }
  .metric-card small{font-size:9px}
  .metric-card .positive{font-size:10px}
  .floating-card{display:none}
}

@media(max-width:560px){
  .metric-row{
    grid-template-columns:minmax(0,1.16fr) minmax(112px,.84fr);
    gap:7px;
  }
  .metric-card{
    min-height:108px;
    padding:12px 11px;
    border-radius:14px;
  }
  .metric-card > span{
    font-size:9px;
    white-space:nowrap;
  }
  .metric-card strong{
    gap:3px;
    margin:7px 0 6px;
    font-size:24px;
    letter-spacing:-.055em;
  }
  .metric-card small{
    font-size:8px;
    line-height:1.25;
  }
  .metric-card .positive{font-size:9px}
  .chart-head > div:first-child > strong{font-size:24px}
}
/* Final placement: notification floats over the dashboard chrome, never over KPI content. */
.floating-one{top:22px;left:-7%}
.metric-card strong .metric-unit{
  display:inline-block;
  flex:0 0 auto;
  color:inherit;
  font:inherit;
  line-height:inherit;
  letter-spacing:-.035em;
}
