﻿:root {
  --color-primary: #0059f7;
  --color-primary-rgb: 0, 89, 247;
  --primary: var(--color-primary);
  --color-primary-hover: #034ed2;
  --btn-primary-hover-bg: var(--color-primary-hover);
  --color-secondary: #f65d2b;
  --color-secondary-rgb: 246, 93, 43;
  --secondary: var(--color-secondary);
  --color-secondary-hover: #e65627;
  --btn-secondary-hover-bg: var(--color-secondary-hover);
  --color-tertiary: #1b0444;
  --tertiary: var(--color-tertiary);
  --color-placeholder: #dd69ff;
  --color-sector-retailer: #addef8;
  --color-sector-crime-partnership: #7b708c;
  --color-sector-police: #0d6ab4;
  --color-sector-security: #a66da4;
  --color-sector-bid: #64b43a;
  --color-sector-local-authority: #faf061;
  --color-bg-subtle: #f4f6f9;
  --color-bg-subtle2: #cccfd4;
  --gap: 1rem;
  --gap-lg: 2rem;
  --gap-xl: 4rem;
  --gap-xxl: 8rem;
  --section-gap: 2.5rem;
  --btn-border-radius: 1000px;
  --box-padding: 3rem;
  --box-padding-sm: 1.5rem;
  --box-border-radius: 30px;
  --border-color: #d9e1eb;
  --border-color-light: rgba(255,255,255,.5);
  --border: 1px solid var(--border-color);
  --tile-font-size: 1.5rem;
  --main-title-border-color: var(--border-color);
  --main-title-margin-bottom: calc(var(--section-gap) / 2);
  --font-weight-bold: 600;
  --font-weight-title: 800;
  --font-size-md: 1.25rem;
  --font-size-lg: 1.75rem;
  --font-size-mega: 5rem;
  --font-size-main-title: 2.4rem;
  --break-sm: 576px;
  --break-md: 768px;
  --break-lg: 992px;
  --break-xl: 1200px;
  --break-xxl: 1400px;
  --transition-duration: .3s;
  --transition: all var(--transition-duration) ease;
  --image-shadow: rgba(50, 50, 93, 0.25) 0px 13px 27px -5px, rgba(0, 0, 0, 0.3) 0px 8px 16px -8px;
}

@media (min-width: 768px) {
  :root {
    --section-gap: 5rem;
  }
}
@keyframes svgArcSweep {
  0% {
    stroke-dashoffset: 1640;
    filter: grayscale(0);
  }
  50% {
    filter: grayscale(1);
  }
  100% {
    stroke-dashoffset: 3280;
    filter: grayscale(0);
  }
}
.text-mega {
  font-size: var(--font-size-mega);
  color: var(--primary);
  font-weight: var(--font-weight-bold);
}

ul.list,
.list > ul {
  padding-left: 1.2em;
}
ul.list li + li,
.list > ul li + li {
  margin-top: 0.5rem;
}

.title {
  font-weight: var(--font-weight-bold);
  font-size: var(--tile-font-size);
}

.bg-pattern {
  background: url(/img/bg-pattern-dark.webp) no-repeat center center/cover !important;
}

.bg-circles {
  background: url(/img/bg-circles-retailer.svg) repeat-y center top !important;
  background-size: 110% auto !important;
}
@media (min-width: 992px) {
  .bg-circles {
    background-size: 1320px auto !important;
  }
}
.bg-circles.bg-retailers {
  background-image: url(/img/bg-circles-retailer.svg) !important;
}
.bg-circles.bg-crime-partnerships {
  background-image: url(/img/bg-circles-crime-partnership.svg) !important;
}
.bg-circles.bg-police {
  background-image: url(/img/bg-circles-police.svg) !important;
}
.bg-circles.bg-security {
  background-image: url(/img/bg-circles-security.svg) !important;
}
.bg-circles.bg-bids {
  background-image: url(/img/bg-circles-bids.svg) !important;
}
.bg-circles.bg-local-authority {
  background-image: url(/img/bg-circles-local-authority.svg) !important;
}

.bg-dark {
  background: var(--color-tertiary) !important;
}

body {
  /*> form {
      display: flex;
      flex-direction: column;
      min-height: 100vh;
  }*/
  display: flex;
  flex-direction: column;
  min-height: 100vh;
}

.container {
  --bs-gutter-x: 3rem;
}
@media (min-width: 576px) {
  .container {
    --bs-gutter-x: 1.5rem;
  }
}

section {
  margin: var(--section-gap) 0;
}

/*header + section {
    margin-top: 0;
}*/
.pt-10 {
  padding-top: var(--section-gap);
}

.pb-10 {
  padding-bottom: var(--section-gap);
}

.py-10 {
  padding-top: var(--section-gap);
  padding-bottom: var(--section-gap);
}

.mt-10 {
  margin-top: var(--section-gap);
}

.mb-10 {
  margin-bottom: var(--section-gap);
}

.my-10 {
  margin-top: var(--section-gap);
  margin-bottom: var(--section-gap);
}

img.shadow {
  filter: drop-shadow(0 4px 6px rgba(0, 0, 0, 0.3));
  box-shadow: none !important;
}

/*@keyframes move-out {
    0% {
        transform: scale(100%);
    }

    50% {
        transform: scale(80%);
        opacity: 0;
    }

    100% {
        transform: scale(80%);
        opacity: 0;
    }
}

@keyframes move-in {
    0% {
        transform: scale(120%);
        opacity: 0;
    }

    50% {
        transform: scale(120%);
        opacity: 0;
    }

    100% {
        transform: scale(100%);
        opacity: 1;
    }
}

@view-transition {
    navigation: auto;
}*/
/* Apply the custom animation to the old and new page states */
/*::view-transition-old(root) {
    animation: 0.4s ease-in both move-out;
}

::view-transition-new(root) {
    animation: 0.4s 0.4s ease-in both move-in;
}*/
@view-transition {
  navigation: auto;
  types: slide, forwards;
}
.btn {
  border-radius: var(--btn-border-radius);
  text-transform: uppercase;
  --bs-btn-padding-x: 1rem;
  --bs-btn-padding-y: .35rem;
  --bs-btn-font-size: .8rem;
}
@media (min-width: 768px) {
  .btn {
    --bs-btn-padding-x: 1.4rem;
    --bs-btn-padding-y: .5rem;
    --bs-btn-font-size: 1rem;
  }
}

.btn-sm {
  --bs-btn-padding-y: 0.25rem;
  --bs-btn-padding-x: 1rem;
}

.btn-lg {
  --bs-btn-padding-x: 1.8rem;
}

.btn-primary {
  --bs-btn-color: #fff;
  --bs-btn-bg: var(--primary);
  --bs-btn-border-color: var(--primary);
  --bs-btn-hover-color: #fff;
  --bs-btn-hover-bg: var(--btn-primary-hover-bg);
  --bs-btn-hover-border-color: var(--btn-primary-hover-bg);
  --bs-btn-focus-shadow-rgb: var(--color-primary-rgb);
  --bs-btn-active-color: #fff;
  --bs-btn-active-bg: var(--btn-primary-hover-bg);
  --bs-btn-active-border-color: var(--btn-primary-hover-bg);
  --bs-btn-active-shadow: inset 0 3px 5px rgba(0, 0, 0, 0.125);
  --bs-btn-disabled-color: #fff;
  --bs-btn-disabled-bg: var(--primary);
  --bs-btn-disabled-border-color: var(--primary);
}
.btn-secondary {
  --bs-btn-color: #fff;
  --bs-btn-bg: var(--secondary);
  --bs-btn-border-color: var(--secondary);
  --bs-btn-hover-color: #fff;
  --bs-btn-hover-bg: var(--btn-secondary-hover-bg);
  --bs-btn-hover-border-color: var(--btn-secondary-hover-bg);
  --bs-btn-focus-shadow-rgb: var(--color-secondary-rgb);
  --bs-btn-active-color: #fff;
  --bs-btn-active-bg: var(--btn-secondary-hover-bg);
  --bs-btn-active-border-color: var(--btn-secondary-hover-bg);
  --bs-btn-active-shadow: inset 0 3px 5px rgba(0, 0, 0, 0.125);
  --bs-btn-disabled-color: #fff;
  --bs-btn-disabled-bg: var(--secondary);
  --bs-btn-disabled-border-color: var(--secondary);
}

.btn-outline-secondary {
  --bs-btn-color: var(--secondary);
  --bs-btn-border-color: var(--secondary);
  --bs-btn-hover-color: #fff;
  --bs-btn-hover-bg: var(--secondary);
  --bs-btn-hover-border-color: var(--secondary);
  --bs-btn-focus-shadow-rgb: var(--color-primary-rgb);
  --bs-btn-active-color: #fff;
  --bs-btn-active-bg: var(--btn-primary-hover-bg);
  --bs-btn-active-border-color: var(--btn-primary-hover-bg);
  --bs-btn-active-shadow: inset 0 3px 5px rgba(0, 0, 0, .125);
  --bs-btn-disabled-color: #6c757d;
  --bs-btn-disabled-bg: transparent;
  --bs-btn-disabled-border-color: var(--primary);
  --bs-gradient: none;
}

.dropdown-toggle::after {
  content: "";
  width: 10px;
  height: 10px;
  vertical-align: 0.1em;
  border: none;
  border-right: var(--border);
  border-bottom: var(--border);
  border-width: 2px;
  transform-origin: bottom right;
  transform: rotate(45deg);
  transition: var(--transition);
}

.body-content img {
  width: 100%;
  max-width: 100%;
  /*border-radius: 6px;
  border: 1px solid #c6c6c6;
  box-shadow: var(--image-shadow);*/
  margin: 1rem 0 2rem;
}

.box {
  padding: var(--box-padding);
  border-radius: var(--box-border-radius);
  border: var(--border);
  background: #fff;
  position: relative;
  overflow: hidden;
}
@media (max-width: 768px) {
  .box {
    padding: 1.5rem;
  }
}
.box.subtle {
  border: none;
  background: var(--color-bg-subtle);
}
.box.subtle2 {
  border: none;
  background: var(--color-bg-subtle2);
}
.box .box-icon {
  width: 40px;
  margin-bottom: 0.5rem;
  color: var(--primary);
}
@media (min-width: 768px) {
  .box .box-icon {
    width: 60px;
  }
}
.box .box-icon img {
  width: 100%;
}
.box .box-img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.box .box-fill-image {
  width: 100%;
}
.box .box-inner {
  padding: var(--box-padding);
}
.box .box-inner.subtle {
  border: none;
  background: var(--color-bg-subtle);
}
.box .box-inner.subtle2 {
  border: none;
  background: var(--color-bg-subtle2);
}
.box.interactive {
  transition: var(--transition);
}
.box.interactive .box-icon {
  transition: var(--transition);
}
.box.interactive:hover {
  box-shadow: rgba(0, 0, 0, 0.05) 0 6px 24px 0, rgba(0, 0, 0, 0.08) 0 0 0 1px;
  border-color: var(--primary) !important;
}
.box.interactive:hover .box-icon {
  transform: scale(1.1);
}
.box.v-center {
  display: flex;
  flex-direction: column;
  justify-content: center;
}
.box.text-center .box-icon {
  margin-left: auto;
  margin-right: auto;
}

.card {
  border-radius: var(--box-border-radius);
}

/*.client-quote {
    --quote-margin: 1.5rem;
    display: flex;
    flex-direction: row;
    grid-gap: var(--gap);
    padding: var(--box-padding);

    @media (min-width: 768px) {
        //flex-direction: row;
        grid-gap: var(--gap-lg);
    }

    .leading {
        img {
            width: 100%;
            //height: 150px;
            aspect-ratio: 1;
            background: #fff;
            object-fit: contain;
            border-radius: 6px;
            padding: 1rem;

            @media (min-width: 768px) {
                width: 200px;
            }
        }
    }

    blockquote {
        font-size: 1rem;

        @media (min-width: 768px) {
            font-size: var(--font-size-lg);
        }

        &::before, &::after {
            content: '"';
        }
    }

    figure {
        margin: 0;
    }

    figcaption {
        border-top: 1px solid var(--border-color-light);
        margin-top: var(--quote-margin);
        padding-top: var(--quote-margin);
    }

    .organisation {
        font-weight: var(--font-weight-bold);
    }
}
*/
.client-quote {
  /*display: flex;
  flex-direction: row;
  grid-gap: var(--gap);*/
  /*.leading {
      position: relative;
      z-index: 1;

      img {
          width: 100%;
          aspect-ratio: 1;
          background: #fff;
          object-fit: contain;
          border-radius: 6px;
          padding: 1rem;
          border: var(--border);

          @media (min-width: 768px) {
              width: 200px;
          }
      }
  }*/
}
@media (min-width: 768px) {
  .client-quote {
    grid-gap: var(--gap-lg);
  }
}
.client-quote blockquote {
  font-size: 1rem;
  position: relative;
  padding-top: 3rem;
  padding-bottom: 1.5rem;
}
@media (min-width: 768px) {
  .client-quote blockquote {
    font-size: var(--font-size-lg);
  }
}
.client-quote blockquote::before, .client-quote blockquote::after {
  content: "";
  display: inline-block;
  width: 0.5em;
  height: 0.5em;
  font-size: 3em;
  color: var(--primary);
  mask: url(/img/quote-open.svg) no-repeat 50% 50%;
  background: var(--primary);
  opacity: 0.15;
  position: absolute;
}
.client-quote blockquote::before {
  top: 10px;
  left: -50px;
  width: 1em;
  height: 1em;
}
@media (min-width: 768px) {
  .client-quote blockquote::before {
    top: -30px;
    left: -80px;
  }
}
.client-quote blockquote::after {
  bottom: -31px;
  right: -50px;
  width: 2em;
  height: 2em;
  transform: rotate(180deg);
}
@media (min-width: 768px) {
  .client-quote blockquote::after {
    bottom: -71px;
    right: -60px;
  }
}
.client-quote figcaption {
  /*display: inline-block;
  background: var(--color-bg-subtle);
  padding: 1rem;
  border-radius: 6px;*/
  display: flex;
  align-items: center;
  grid-gap: 1rem;
}
.client-quote figcaption img {
  width: 100px;
  aspect-ratio: 1;
  background: #fff;
  object-fit: contain;
  border-radius: 6px;
  padding: 0.5rem;
  border: var(--border);
  /*@media (min-width: 768px) {
      width: 100px;
  }*/
}
.client-quote .organisation {
  font-weight: var(--font-weight-bold);
}

.content-slider {
  position: relative;
  transition: height 1s ease;
  /*&::after {
      content: "Paused";
      position: absolute;
      bottom: -36px;
      left: 50%;
      transform: translateX(-50%);
      color: #000;
      padding-left: 32px;
      background: url(/img/icon-pause-circle.svg) no-repeat;
      background-position: 5px center;
      background-size: 24px;
      opacity: 0;
      transition: var(--transition);
  }

  &.paused {
      &::after {
          opacity: .5;
      }
  }*/
}
.content-slider .slides > * {
  visibility: hidden;
  opacity: 0;
  position: absolute;
  top: 0;
  left: 0;
  transition: all 1s ease;
}
.content-slider .active {
  visibility: visible;
  opacity: 1;
  transition: all 1s 0.5s ease;
}
.content-slider .controls {
  display: flex;
  align-items: center;
  grid-gap: 0.5rem;
  position: absolute;
  bottom: -36px;
  left: 50%;
  transform: translateX(-50%);
}
.content-slider .controls .prev, .content-slider .controls .next {
  /*width: 30px;
  height: 30px;
  background: #f2f2f2;*/
  /* width: 10px;
  height: 10px;
  vertical-align: .1em;
  border: 0;
  border-right: var(--border);
  border-bottom: var(--border);
  border-width: 2px;
  transform-origin: bottom right;
  //transform: rotate(45deg);
  transition: var(--transition);*/
  cursor: pointer;
  padding: 10px;
  border-radius: 1000px;
  transition: var(--transition);
  display: flex;
  align-items: center;
  grid-gap: 0.5rem;
}
.content-slider .controls .prev::before, .content-slider .controls .next::before {
  content: "";
  display: block;
  width: 10px;
  height: 10px;
  vertical-align: 0.1em;
  border: 0;
  border-right: var(--border);
  border-bottom: var(--border);
  border-width: 2px;
  transition: var(--transition);
}
.content-slider .controls .prev::after, .content-slider .controls .next::after {
  font-size: 0.8rem;
  opacity: 0;
  transition: var(--transition);
}
.content-slider .controls .prev:hover::before, .content-slider .controls .next:hover::before {
  border-color: var(--primary);
}
.content-slider .controls .prev:hover::after, .content-slider .controls .next:hover::after {
  opacity: 1;
}
.content-slider .controls .prev::before {
  transform: translateX(2px) rotate(135deg);
}
.content-slider .controls .prev::after {
  content: "Back";
}
.content-slider .controls .next {
  flex-direction: row-reverse;
}
.content-slider .controls .next::before {
  transform: translateX(-2px) rotate(-45deg);
}
.content-slider .controls .next::after {
  content: "Next";
}
.content-slider .controls .timer {
  width: 160px;
  background: var(--color-bg-subtle);
  display: flex;
  align-items: center;
  border: var(--border);
  border-radius: 1000px;
}
.content-slider .controls .timer::before {
  content: "";
  display: block;
  width: 0;
  height: 5px;
  background: var(--border-color);
  border-radius: 1000px;
  opacity: 0;
  transition: all 0.1s linear;
}
.content-slider.static .controls {
  display: none;
}
.content-slider.running .timer::before {
  width: 100%;
  opacity: 1;
  transition: opacity 2s ease, width 6s linear;
}

.main-header {
  --header-margin-bottom: 1rem;
  padding: 0.5rem 0;
  margin-bottom: var(--header-margin-bottom);
  position: sticky;
  top: 0;
  z-index: 999;
  border-bottom: var(--border);
  /*@media (max-width: 768px) {
      .logo {
          img {
              height: 40px;
          }
      }
  }*/
}
.main-header::before {
  content: "";
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  z-index: -1;
  background: rgba(255, 255, 255, 0.85);
  backdrop-filter: blur(20px);
}
@media (min-width: 768px) {
  .main-header {
    --header-margin-bottom: 2rem;
    padding: 1rem 0;
  }
}
.main-header .logo {
  display: block;
}
.main-header .logo img {
  height: 36px;
}
@media (min-width: 768px) {
  .main-header .logo img {
    height: 40px;
  }
}
.main-header .trailing {
  display: flex;
  align-items: center;
  grid-gap: var(--gap);
}
.main-header .btn-menu-toggle {
  border-radius: 6px;
  padding: 5px;
}
.main-header .btn-menu-toggle svg {
  width: 38px;
  height: 38px;
}

.hero-section {
  margin: 0;
  padding: var(--section-gap) 0;
  overflow: hidden;
}

.hero {
  background: var(--tertiary) url(/img/sector-arc-primary.svg) no-repeat right bottom;
  overflow: visible;
}
.hero .image-container {
  position: relative;
}
.hero .image-container img {
  max-width: 100%;
  height: auto;
}
@media (min-width: 992px) {
  .hero .image-container img {
    /*height: 100%;
    max-width: unset;
    position: absolute;
    top: 0;
    bottom: 0;*/
    max-width: unset;
    width: 130%;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-39%, -52%) rotate(6deg);
  }
}
@media (min-width: 992px) {
  .hero.animate-in-view .main-title {
    opacity: 0;
    transition: all 1s 0.5s ease;
  }
  .hero.animate-in-view p {
    opacity: 0;
    transition: all 1s 1s ease;
  }
  .hero.animate-in-view .image-container img {
    opacity: 0;
    transition: all 1s 0.5s ease;
  }
}
@media (min-width: 992px) and (min-width: 992px) {
  .hero.animate-in-view .image-container img {
    transform: translate(-29%, -42%) rotate(6deg);
  }
}
@media (min-width: 992px) {
  .hero.animate-in-view.anim .main-title {
    opacity: 1;
  }
  .hero.animate-in-view.anim p {
    opacity: 1;
  }
  .hero.animate-in-view.anim .image-container img {
    opacity: 1;
  }
}
@media (min-width: 992px) and (min-width: 992px) {
  .hero.animate-in-view.anim .image-container img {
    transform: translate(-39%, -50%) rotate(0deg);
  }
}

.main-footer {
  --footer-font-size: 1.2rem;
  --footer-padding-y: 2.5rem;
  background: var(--color-tertiary);
  background: var(--color-tertiary) url(/img/bg-title-section.svg) no-repeat 15% 225%;
  background-size: auto 80%;
  color: #FFF;
  padding-top: var(--footer-padding-y);
}
@media (min-width: 768px) {
  .main-footer {
    --footer-padding-y: 5rem;
  }
}
.main-footer .title {
  font-size: 1.2rem;
  font-weight: var(--font-weight-title);
  margin-bottom: 1rem;
  padding-bottom: 0.5rem;
}
.main-footer .nav li {
  margin-bottom: 0.5rem;
}
.main-footer .logo {
  display: block;
}
.main-footer .logo img {
  height: 40px;
}
@media (min-width: 768px) {
  .main-footer .logo img {
    height: 60px;
  }
}
.main-footer a {
  text-decoration: none;
  color: inherit;
}
.main-footer .nav a {
  opacity: 0.6;
  transition: var(--transition);
}
.main-footer .nav a:hover {
  opacity: 1;
}
.main-footer .accreditation-logo img {
  width: 100%;
  height: 100px;
}
@media (min-width: 768px) {
  .main-footer .accreditation-logo img {
    --footer-padding-y: 5rem;
  }
}

.postfooter {
  background: rgba(0, 0, 0, 0.5);
  padding: 10px 0;
  border-top: 1px solid black;
  margin-top: 20px;
}
.postfooter p {
  display: inline-flex;
  grid-gap: 1rem;
  margin: 0;
}
.postfooter p > * {
  opacity: 0.6;
}
.postfooter p a {
  transition: var(--transition);
}
.postfooter p a:hover {
  opacity: 1;
}

.form .title {
  border-bottom: var(--border);
}
@media (min-width: 768px) {
  .form .title {
    font-size: var(--tile-font-size);
  }
}
.form .required-indicator {
  color: var(--color-primary);
}
.form textarea {
  min-height: calc(5em + 0.75rem + var(--bs-border-width) * 2);
  field-sizing: content;
  resize: none;
}

.grid {
  --grid-gap: 1.5rem;
  display: grid;
  grid-gap: var(--grid-gap);
}
.grid + .grid {
  margin-top: var(--grid-gap);
}
.grid .grid-item.animate-in-view {
  transition: all 1s ease;
  transition-delay: calc(var(--n) * 0.25s);
  translate: 0 100px;
  opacity: 0;
}
.grid .grid-item.animate-in-view.anim {
  translate: 0 0;
  opacity: 1;
}

.grid-1-1 {
  grid-template-columns: 1fr;
}
@media (min-width: 992px) {
  .grid-1-1 {
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  }
}

.grid-1-1-1 {
  grid-template-columns: 1fr;
}
@media (min-width: 992px) {
  .grid-1-1-1 {
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr) minmax(0, 1fr);
  }
}

.grid-2-1 {
  grid-template-columns: 1fr;
}
@media (min-width: 992px) {
  .grid-2-1 {
    grid-template-columns: minmax(0, 2fr) minmax(0, 1fr);
  }
}

.grid-1-2 {
  grid-template-columns: 1fr;
}
@media (min-width: 992px) {
  .grid-1-2 {
    grid-template-columns: minmax(0, 1fr) minmax(0, 2fr);
  }
}

.grid-2-1-1 {
  grid-template-columns: 1fr;
}
@media (min-width: 992px) {
  .grid-2-1-1 {
    grid-template-columns: minmax(0, 2fr) minmax(0, 1fr) minmax(0, 1fr);
  }
}

.grid-alternating {
  display: grid;
  grid-template-columns: 1fr;
  grid-auto-flow: dense;
  column-gap: var(--gap-lg);
  row-gap: var(--gap-xl);
}
@media (min-width: 992px) {
  .grid-alternating {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    row-gap: var(--gap-xxl);
  }
}
.grid-alternating .grid-item-content {
  padding-left: var(--gap-lg);
  padding-right: 0;
  transform: translateY(100px);
  opacity: 0;
  transition: all 1s ease;
}
.grid-alternating .grid-item-image {
  opacity: 0;
  transition: all 2s 0.5s ease;
}
.grid-alternating .grid-item {
  align-self: center;
}
.grid-alternating .grid-item .title {
  font-weight: var(--font-weight-title);
}
@media (min-width: 992px) {
  .grid-alternating .grid-item.grid-item-image:nth-child(4n+1) {
    grid-column: 2;
  }
  .grid-alternating .grid-item.grid-item-content:nth-child(4n+2) {
    grid-column: 1;
    padding-left: 0;
    padding-right: var(--gap-lg);
  }
}
.grid-alternating .grid-item.anim.grid-item-content {
  transform: translateY(0);
  opacity: 1;
}
.grid-alternating .grid-item.anim.grid-item-image {
  opacity: 1;
}

.grid-articles {
  display: grid;
  grid-template-columns: 1fr;
  grid-gap: var(--gap-xl);
}
@media (min-width: 768px) {
  .grid-articles {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}
@media (min-width: 1200px) {
  .grid-articles {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}
.grid-articles .grid-item {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  grid-gap: var(--gap);
  position: relative;
}
.grid-articles .grid-item .image {
  border-radius: var(--box-border-radius);
  overflow: hidden;
  align-self: stretch;
  position: relative;
}
.grid-articles .grid-item .image img {
  width: 100%;
  aspect-ratio: 1;
  background: #f2f2f2;
  transition: all 0.3s ease;
  object-fit: cover;
}
.grid-articles .grid-item .image::after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: url(/img/sector-arc-primary.svg) no-repeat center center/cover;
  transform: scaleX(-1) translate(100%, 100%);
  mix-blend-mode: soft-light;
  transition: all 0.3s ease;
}
.grid-articles .grid-item .title {
  margin-bottom: var(--gap);
  font-weight: var(--font-weight-bold);
}
.grid-articles .grid-item .meta {
  color: var(--primary);
}
.grid-articles .grid-item:hover .image img {
  filter: grayscale(1) brightness(90%);
}
.grid-articles .grid-item:hover .image::after {
  transform: scaleX(-1) translate(60px, 0);
}

.grid-cards {
  /*--quote-margin: 1.5rem;
      --grid-gap: 2rem;
      display: grid;
      grid-template-columns: repeat(1, minmax(0, 1fr));
      grid-gap: var(--grid-gap);
      justify-content: space-around;

      @media (min-width: 768px) {
          grid-template-columns: repeat(3, minmax(0, 1fr));
      }
  */
  /*@media (min-width: 992px) {
      --grid-gap: 3rem;
  }*/
}
.grid-cards .grid-item {
  display: flex;
  flex-direction: row;
  align-items: center;
  grid-gap: 2rem;
  color: inherit;
  text-decoration: none;
  transition: all 0.3s ease;
  padding: 2rem;
}
@media (min-width: 768px) {
  .grid-cards .grid-item {
    flex-direction: column;
    text-align: center;
    padding: 2rem 1rem;
  }
}
@media (min-width: 992px) {
  .grid-cards .grid-item {
    padding: 2rem 1rem;
  }
}
@media (min-width: 1200px) {
  .grid-cards .grid-item {
    padding: var(--box-padding) 2rem;
  }
}
.grid-cards .grid-item img {
  width: 60px;
  aspect-ratio: 1;
  object-fit: contain;
  transition: var(--transition);
}
@media (min-width: 768px) {
  .grid-cards .grid-item img {
    width: 50%;
  }
}
.grid-cards .grid-item .title {
  font-size: 1.4rem;
  font-weight: bold;
  margin-bottom: 0;
}
@media (min-width: 768px) {
  .grid-cards .grid-item .title {
    font-size: 1.2rem;
  }
}
@media (min-width: 992px) {
  .grid-cards .grid-item .title {
    font-size: 1.6rem;
  }
}
.grid-cards a.grid-item:hover {
  box-shadow: rgba(149, 157, 165, 0.2) 0px 8px 24px;
  box-shadow: rgba(0, 0, 0, 0.05) 0px 6px 24px 0px, rgba(0, 0, 0, 0.08) 0px 0px 0px 1px;
  border-color: var(--primary);
}
.grid-cards a.grid-item:hover img {
  transform: scale(1.05);
}

.grid-features {
  display: grid;
  grid-template-columns: repeat(1, minmax(0, 360px));
  grid-gap: 3rem;
  justify-content: space-around;
}
@media (min-width: 768px) {
  .grid-features {
    grid-template-columns: repeat(2, minmax(0, 360px));
  }
}
.grid-features .grid-item {
  display: flex;
  flex-direction: column;
  align-items: center;
  grid-gap: 1rem;
  color: inherit;
  text-decoration: none;
  border-radius: 1rem;
  border: 1px solid transparent;
  transition: all 0.3s ease;
}
.grid-features .grid-item .icon {
  width: 70px;
}
@media (min-width: 768px) {
  .grid-features .grid-item .icon {
    width: 100px;
  }
}
.grid-features .grid-item .icon img {
  width: 100%;
}
.grid-features .grid-item .title {
  font-size: 1.2rem;
  font-weight: bold;
}
.grid-features .grid-item.animate-in-view {
  transition: all 1s ease;
  translate: 0 100px;
  opacity: 0;
}
.grid-features .grid-item.animate-in-view.anim {
  translate: 0 0;
  opacity: 1;
}
.grid-features a.grid-item:hover {
  box-shadow: rgba(149, 157, 165, 0.2) 0px 8px 24px;
  box-shadow: rgba(0, 0, 0, 0.05) 0px 6px 24px 0px, rgba(0, 0, 0, 0.08) 0px 0px 0px 1px;
}

.grid-features-boxed {
  display: grid;
  grid-template-columns: repeat(1, minmax(0, 1fr));
  grid-gap: 1.5rem;
}
@media (min-width: 768px) {
  .grid-features-boxed {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}
@media (min-width: 992px) {
  .grid-features-boxed {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}
.grid-features-boxed .grid-item.animate-in-view {
  transition: all 1s ease;
  transition-delay: calc(var(--n) * 0.25s);
  translate: 0 100px;
  opacity: 0;
}
.grid-features-boxed .grid-item.animate-in-view.anim {
  translate: 0 0;
  opacity: 1;
}
.grid-features-boxed .icon {
  width: 60px;
  margin-bottom: 0.5rem;
}
.grid-features-boxed .icon img {
  width: 100%;
}
.grid-features-boxed .title {
  margin-bottom: 0.5rem;
}

.grid-logos {
  display: grid;
  grid-template-columns: repeat(1, minmax(0, 1fr));
  grid-gap: 1.5rem;
}
@media (min-width: 576px) {
  .grid-logos {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}
@media (min-width: 768px) {
  .grid-logos {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}
@media (min-width: 1400px) {
  .grid-logos {
    grid-template-columns: repeat(6, minmax(0, 1fr));
  }
}
.grid-logos .grid-item img {
  width: 60%;
}
@media (min-width: 768px) {
  .grid-logos .grid-item img {
    width: 80%;
  }
}

.grid-quotes {
  --quote-margin: 1.5rem;
  display: grid;
  grid-template-columns: repeat(1, minmax(0, 360px));
  grid-gap: 3rem;
  justify-content: space-around;
}
@media (min-width: 768px) {
  .grid-quotes {
    grid-template-columns: repeat(3, minmax(0, 360px));
  }
}
.grid-quotes .grid-item {
  display: flex;
  flex-direction: column;
  align-items: center;
  grid-gap: 1rem;
  color: inherit;
  text-decoration: none;
  border-radius: 1rem;
  border: 1px solid transparent;
  transition: all 0.3s ease;
}
.grid-quotes .grid-item .icon {
  width: 80%;
}
.grid-quotes .grid-item .icon img {
  width: 100%;
  height: 120px;
}
.grid-quotes .grid-item .title {
  font-size: 1.2rem;
  font-weight: bold;
}
.grid-quotes a.grid-item:hover {
  box-shadow: rgba(149, 157, 165, 0.2) 0px 8px 24px;
  box-shadow: rgba(0, 0, 0, 0.05) 0px 6px 24px 0px, rgba(0, 0, 0, 0.08) 0px 0px 0px 1px;
}
.grid-quotes blockquote {
  margin-bottom: var(--quote-margin);
  font-size: var(--font-size-md);
}
.grid-quotes blockquote::before, .grid-quotes blockquote::after {
  content: '"';
}
.grid-quotes blockquote::before {
  margin-right: -0.2em;
}
.grid-quotes blockquote::after {
  margin-left: -0.2em;
}
.grid-quotes figcaption::before {
  content: "";
  display: block;
  width: 20%;
  margin: 0 auto;
  margin-bottom: var(--quote-margin);
  border-top: 1px solid var(--border-color);
}

/*@keyframes dash {
    0% {
        stroke-dashoffset: -1640;
        filter: grayscale(0);
    }
    50% {
        filter: grayscale(1);
    }
    100% {
        stroke-dashoffset: 0;
        filter: grayscale(0);
    }
}*/
.grid-sectors {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  grid-column-gap: 1.5rem;
  grid-row-gap: 6rem;
  margin-bottom: 2rem;
  /*.sector-image {
      mask-image: url(/img/sectors/sector-mask.svg);
      mask-repeat: no-repeat;
      mask-size: 100% 100%;
      position: relative;
      width: 80%;
      aspect-ratio: 205 / 269;

      img {
          width: 100%;
          position: relative;
          transform-origin: bottom right;
          transition: all 1s ease;
          transform: scale(0.975) translate(0, 0);
          filter: drop-shadow(0px 5px 15px rgba(0, 0, 0, 0));
      }

      .arc {
          position: absolute;
          bottom: 0;
          right: 0;
          width: 100%;
          aspect-ratio: 1;

          path {
              fill: none;
              stroke: currentColor;
              stroke-width: 324px;
              stroke-dasharray: 820;
              stroke-dashoffset: 0;
          }
      }
  }

  .sector-retailer {
      .arc {
          color: var(--color-sector-retailer);
      }
  }

  .sector-crime-partnership {
      .arc {
          color: var(--color-sector-crime-partnership);
      }
  }

  .sector-police {
      .arc {
          color: var(--color-sector-police);
      }
  }

  .sector-security {
      .arc {
          color: var(--color-sector-security);
      }
  }

  .sector-bid {
      .arc {
          color: var(--color-sector-bid);
      }
  }

  .sector-local-authority {
      .arc {
          color: var(--color-sector-local-authority);
      }
  }*/
}
@media (min-width: 768px) {
  .grid-sectors {
    grid-column-gap: 2rem;
    grid-row-gap: 8rem;
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}
@media (min-width: 992px) {
  .grid-sectors {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}
.grid-sectors .grid-item {
  text-align: center;
  position: relative;
  display: flex;
  flex-direction: column;
  /*&.anim {
      .arc {
          path {
              animation: svgArcSweep 2s;
              animation-fill-mode: both;
          }
      }
  }*/
}
.grid-sectors .grid-item img {
  width: 80%;
}
.grid-sectors .grid-item .title {
  margin-top: 1.5rem;
  margin-bottom: auto;
  font-weight: var(--font-weight-title);
}
.grid-sectors .grid-item .title + .btn {
  margin-top: 1.5rem;
}
@media (min-width: 768px) {
  .grid-sectors .grid-item .title {
    font-size: var(--tile-font-size);
  }
}
.grid-sectors .grid-item .btn {
  align-self: center;
}
.grid-sectors .grid-item .sector-image-container {
  padding: 0;
  overflow: visible;
}
.grid-sectors .grid-item .sector-image {
  margin: 0 auto;
  margin-top: -2rem;
  border-radius: 0 0 var(--box-border-radius) var(--box-border-radius);
}
@media (min-width: 768px) {
  .grid-sectors .grid-item .sector-image {
    margin-top: -4rem;
  }
}
.grid-sectors .grid-item:hover .sector-image img {
  transform: scale(1) translate(0, 0);
  filter: drop-shadow(10px 10px 7px rgba(0, 0, 0, 0.35));
}

.grid-stats {
  --gap: 1.5rem;
  --grid-item-offset-x: 2rem;
  --grid-item-offset-y: 4rem;
  --column-gap: 3rem;
  --row-gap: 3rem;
  display: inline-grid;
  grid-template-columns: repeat(1, minmax(0, 1fr));
  column-gap: var(--column-gap);
  row-gap: var(--row-gap);
  align-items: flex-start;
}
@media (min-width: 992px) {
  .grid-stats {
    --row-gap: 0;
    grid-template-columns: repeat(3, minmax(0, 360px));
  }
}
@media (min-width: 1200px) {
  .grid-stats {
    --grid-gap: 6rem;
  }
}
.grid-stats .grid-item {
  display: flex;
  flex-direction: column;
  grid-gap: var(--gap);
  color: inherit;
  text-decoration: none;
  text-align: left;
  border-radius: 1rem;
  border: var(--border);
  transition: all 0.3s ease;
  padding: var(--box-padding-sm);
  width: 80%;
}
.grid-stats .grid-item:nth-child(even) {
  justify-self: flex-end;
}
@media (min-width: 768px) {
  .grid-stats .grid-item:nth-child(odd) {
    transform: translateX(calc(var(--grid-item-offset-x) * -1));
  }
  .grid-stats .grid-item:nth-child(even) {
    transform: translateX(var(--grid-item-offset-x));
    justify-self: flex-end;
  }
}
@media (min-width: 992px) {
  .grid-stats .grid-item {
    --grid-item-offset-x: 0;
    width: 100%;
  }
  .grid-stats .grid-item:nth-child(3n+1), .grid-stats .grid-item:nth-child(3n+3) {
    margin-bottom: var(--grid-item-offset-y);
  }
  .grid-stats .grid-item:nth-child(3n+2) {
    margin-top: var(--grid-item-offset-y);
    justify-self: initial;
  }
}
.grid-stats .grid-item .icon {
  width: 80px;
}
.grid-stats .grid-item .icon img {
  width: 100%;
}
.grid-stats .grid-item .stat {
  font-size: calc(var(--font-size-mega) * 0.75);
  color: var(--secondary);
  font-weight: var(--font-weight-bold);
  line-height: 1;
}
.grid-stats .grid-item .title {
  font-size: 2rem;
  font-weight: var(--font-weight-bold);
  line-height: 1.2;
  /*border-bottom: var(--border);
  padding-bottom: var(--gap);*/
}
.grid-stats .grid-item p {
  border-top: var(--border);
  padding-top: var(--gap);
}
.grid-stats .grid-item p:empty {
  display: none;
}
.grid-stats .grid-item:hover {
  box-shadow: rgba(0, 0, 0, 0.05) 0px 6px 24px 0px, rgba(0, 0, 0, 0.08) 0px 0px 0px 1px !important;
}
.grid-stats .grid-item.animate-in-view {
  transition: all 1s ease;
  translate: 0 100px;
  opacity: 0;
}
.grid-stats .grid-item.animate-in-view.anim {
  translate: 0 0;
  opacity: 1;
}

.grid-team {
  display: grid;
  grid-template-columns: repeat(1, minmax(0, 1fr));
  grid-gap: 3rem;
  justify-content: space-around;
  color: var(--bs-body-color);
}
@media (min-width: 768px) {
  .grid-team {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}
.grid-team .grid-item {
  display: flex;
  flex-direction: column;
  grid-gap: 1rem;
  color: inherit;
  text-decoration: none;
  border: 1px solid transparent;
  transition: all 0.3s ease;
}
.grid-team .grid-item .image {
  width: 100%;
  border-radius: calc(var(--box-border-radius) - 1rem);
  overflow: hidden;
  margin-bottom: var(--gap);
}
.grid-team .grid-item .image img {
  width: 100%;
}
.grid-team .grid-item .title {
  font-size: 1.2rem;
  font-weight: bold;
  color: var(--primary);
}
.grid-team a.grid-item:hover {
  box-shadow: rgba(149, 157, 165, 0.2) 0px 8px 24px;
  box-shadow: rgba(0, 0, 0, 0.05) 0px 6px 24px 0px, rgba(0, 0, 0, 0.08) 0px 0px 0px 1px;
}

.icon-title {
  display: flex;
  grid-gap: var(--gap-lg);
  align-items: center;
  margin-bottom: var(--gap-lg);
}
.icon-title .icon {
  width: 80px;
  height: 80px;
  flex: 0 0;
  flex-basis: 80px;
  background: var(--primary);
  border-radius: 1000px;
}
.icon-title .icon img {
  width: 100%;
  height: 100%;
}
.icon-title .subtitle {
  margin-bottom: 0;
  font-weight: var(--font-weight-bold);
}

.image-caption {
  font-size: 0.8rem;
  opacity: 0.8;
  margin-top: -1.5rem;
  padding-left: 0.5rem;
  text-align: center;
}

.list-faqs .list-item + .list-item {
  margin-top: 2rem;
}
.list-faqs .question {
  color: var(--primary);
  font-size: 1.4rem;
  margin-bottom: 0.5rem;
}

:root {
  --logo-carousel-item-width: 180;
  --logo-carousel-item-width-px: calc(var(--logo-carousel-item-width) * 1px);
  --logo-carousel-item-height-px: 64px;
  --logo-carousel-item-gap: 64;
  --logo-carousel-item-gap-px: calc(var(--logo-carousel-item-gap) * 1px);
}

@media (min-width: 992px) {
  :root {
    --logo-carousel-item-width: 240;
    --logo-carousel-item-height-px: 96px;
    --logo-carousel-item-gap: 96;
  }
}
@media (min-width: 1200px) {
  :root {
    --logo-carousel-item-gap: 144;
  }
}
.logo-carousel-container {
  width: 100%;
  overflow: hidden;
  position: relative;
}

.logo-carousel {
  white-space: nowrap;
  height: var(--logo-carousel-item-height-px);
  opacity: 0;
}
.logo-carousel.loaded {
  opacity: 1;
  transition: opacity 1s ease;
}

.logo-carousel-item {
  display: inline-block;
  height: var(--logo-carousel-item-height-px);
  margin: 0 calc(var(--logo-carousel-item-gap-px) / 2);
  max-width: calc(var(--logo-carousel-item-width) * 1px);
  box-sizing: border-box;
  text-align: center;
}
.logo-carousel-item img {
  max-height: 100%;
  max-width: 100%;
}

.main-banner {
  --main-banner-font-size: 2rem;
  --main-banner-height: 350px;
  position: relative;
  height: var(--main-banner-height);
  border-radius: var(--box-border-radius);
  overflow: hidden;
  color: #fff;
  background: url("/img/bg-pattern-dark.webp") center center;
  background-size: cover;
  display: flex;
  align-items: center;
  padding: 2rem;
}
@media (min-width: 768px) {
  .main-banner {
    --main-banner-font-size: 3rem;
    --main-banner-height: 460px;
  }
}
.main-banner img {
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  object-fit: cover;
  width: 100%;
  height: 100%;
}
.main-banner h1 {
  /* position: absolute;
  top: 50%;*/
  position: relative;
  color: var(--white-color);
  font-size: var(--main-banner-font-size);
  font-weight: 700;
  margin-bottom: 0;
}
.main-banner h1.main-title {
  border-color: #fff;
}
.main-banner:not(.align-left) {
  justify-content: center;
}
.main-banner:not(.align-left) h1 {
  /*left: 50%;
  transform: translate(-50%, -50%);*/
  text-align: center;
}
@media (min-width: 992px) {
  .main-banner.align-left h1 {
    max-width: 60%;
  }
}
@media (min-width: 1200px) {
  .main-banner.align-left h1 {
    max-width: 50%;
  }
}

.main-menu {
  justify-content: center;
  position: relative;
}
.main-menu a {
  color: inherit;
  font-size: 1.2rem;
}
.main-menu a:hover {
  color: var(--color-primary);
}
.main-menu .has-mega-menu:hover > a {
  color: var(--color-primary);
}
.main-menu .has-mega-menu:hover > a::after {
  border-right-color: var(--color-primary);
  border-bottom-color: var(--color-primary);
}
.main-menu .has-mega-menu:hover .mega-menu {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
  transform: translate(-50%, 0);
}

.main-title {
  --font-size-main-title: 1.8rem;
  padding: 0.35em 0;
  line-height: 1.25;
  margin-bottom: var(--main-title-margin-bottom);
  font-size: var(--font-size-main-title);
  font-weight: var(--font-weight-title);
}
@media (min-width: 992px) {
  .main-title {
    --font-size-main-title: 2.8rem;
  }
}
.main-title.quote {
  display: inline-flex !important;
  align-items: center;
  grid-gap: var(--gap-lg);
}
.main-title.quote::before, .main-title.quote::after {
  content: "";
  display: inline-block;
  width: 0.5em;
  height: 0.5em;
  font-size: 3em;
  color: var(--primary);
  mask: url(/img/quote-open.svg) no-repeat 50% 50%;
  background: var(--primary);
}
.main-title.quote::after {
  transform: rotate(180deg);
}

.text-light .main-title {
  --main-title-border-color: var(--border-color-light);
}

.main-subtitle {
  margin-top: 1.5rem;
}

.media_embed {
  aspect-ratio: 16/9;
}
.media_embed iframe {
  width: 100%;
  height: 100%;
}

.mega-menu {
  position: absolute;
  top: 112%;
  left: 50%;
  transform: translate(-50%, 10px);
  padding: 1rem;
  width: 800px;
  border: var(--border);
  border-radius: 1rem;
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transition: var(--transition);
  background: #fff;
}
.mega-menu ul {
  list-style: none;
  padding: 0;
  margin: 0;
}
.mega-menu::before {
  content: "";
  display: block;
  background: transparent;
  height: 15px;
  position: absolute;
  left: 0;
  right: 0;
  top: -16px;
}

.mega-menu-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  grid-gap: 0.5rem;
}
.mega-menu-grid .list-item {
  text-align: left;
}
.mega-menu-grid .list-item a {
  display: block;
  text-decoration: none;
  padding: 1rem;
  border-radius: 0.5rem;
  height: 100%;
  transition: var(--transition);
}
.mega-menu-grid .list-item a > * {
  display: block;
}
.mega-menu-grid .list-item a:hover {
  background: var(--color-bg-subtle);
}
.mega-menu-grid .list-item .title {
  font-weight: var(--font-weight-bold);
  font-size: 1rem;
  margin-bottom: 5px;
}
.mega-menu-grid .list-item .description {
  font-size: 0.8rem;
}

.odometer.odometer-auto-theme, .odometer.odometer-theme-minimal {
  display: inline-block;
  vertical-align: middle;
  *vertical-align: auto;
  *zoom: 1;
  *display: inline;
  position: relative;
}

.odometer.odometer-auto-theme .odometer-digit, .odometer.odometer-theme-minimal .odometer-digit {
  display: inline-block;
  vertical-align: middle;
  *vertical-align: auto;
  *zoom: 1;
  *display: inline;
  position: relative;
}

.odometer.odometer-auto-theme .odometer-digit .odometer-digit-spacer, .odometer.odometer-theme-minimal .odometer-digit .odometer-digit-spacer {
  display: inline-block;
  vertical-align: middle;
  *vertical-align: auto;
  *zoom: 1;
  *display: inline;
  visibility: hidden;
}

.odometer.odometer-auto-theme .odometer-digit .odometer-digit-inner, .odometer.odometer-theme-minimal .odometer-digit .odometer-digit-inner {
  text-align: left;
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  overflow: hidden;
}

.odometer.odometer-auto-theme .odometer-digit .odometer-ribbon, .odometer.odometer-theme-minimal .odometer-digit .odometer-ribbon {
  display: block;
}

.odometer.odometer-auto-theme .odometer-digit .odometer-ribbon-inner, .odometer.odometer-theme-minimal .odometer-digit .odometer-ribbon-inner {
  display: block;
  -webkit-backface-visibility: hidden;
}

.odometer.odometer-auto-theme .odometer-digit .odometer-value, .odometer.odometer-theme-minimal .odometer-digit .odometer-value {
  display: block;
  -webkit-transform: translateZ(0);
}

.odometer.odometer-auto-theme .odometer-digit .odometer-value.odometer-last-value, .odometer.odometer-theme-minimal .odometer-digit .odometer-value.odometer-last-value {
  position: absolute;
}

.odometer.odometer-auto-theme.odometer-animating-up .odometer-ribbon-inner, .odometer.odometer-theme-minimal.odometer-animating-up .odometer-ribbon-inner {
  -webkit-transition: -webkit-transform 2s;
  -moz-transition: -moz-transform 2s;
  -ms-transition: -ms-transform 2s;
  -o-transition: -o-transform 2s;
  transition: transform 2s;
}

.odometer.odometer-auto-theme.odometer-animating-up.odometer-animating .odometer-ribbon-inner, .odometer.odometer-theme-minimal.odometer-animating-up.odometer-animating .odometer-ribbon-inner {
  -webkit-transform: translateY(-100%);
  -moz-transform: translateY(-100%);
  -ms-transform: translateY(-100%);
  -o-transform: translateY(-100%);
  transform: translateY(-100%);
}

.odometer.odometer-auto-theme.odometer-animating-down .odometer-ribbon-inner, .odometer.odometer-theme-minimal.odometer-animating-down .odometer-ribbon-inner {
  -webkit-transform: translateY(-100%);
  -moz-transform: translateY(-100%);
  -ms-transform: translateY(-100%);
  -o-transform: translateY(-100%);
  transform: translateY(-100%);
}

.odometer.odometer-auto-theme.odometer-animating-down.odometer-animating .odometer-ribbon-inner, .odometer.odometer-theme-minimal.odometer-animating-down.odometer-animating .odometer-ribbon-inner {
  -webkit-transition: -webkit-transform 2s;
  -moz-transition: -moz-transform 2s;
  -ms-transition: -ms-transform 2s;
  -o-transition: -o-transform 2s;
  transition: transform 2s;
  -webkit-transform: translateY(0);
  -moz-transform: translateY(0);
  -ms-transform: translateY(0);
  -o-transform: translateY(0);
  transform: translateY(0);
}

.offcanvas .main-menu {
  font-size: 1.4rem;
  margin-bottom: var(--gap);
}
.offcanvas .main-menu .nav-item {
  overflow: hidden;
}
.offcanvas .main-menu .nav-item .btn {
  color: #fff;
}
.offcanvas .main-menu .nav-item a {
  font-weight: var(--font-weight-bold);
  transform: translate(0, 100%);
}
.offcanvas .main-menu .nav-item a.anim {
  transition: all 1s ease;
  transform: translate(0, 0);
}

.prefooter {
  --prefooter-font-size: 1.2rem;
  --prefooter-padding-y: 1.5rem;
  background: url(/img/bg-pattern-light.png) no-repeat center center/cover;
  background: var(--primary);
  color: #FFF;
  padding-top: var(--prefooter-padding-y);
  padding-bottom: var(--prefooter-padding-y);
}
@media (min-width: 768px) {
  .prefooter {
    --prefooter-font-size: 1.8rem;
    --prefooter-padding-y: 2rem;
  }
}
.prefooter .container {
  text-align: center;
}
@media (min-width: 992px) {
  .prefooter .container {
    text-align: left;
    display: flex;
    align-items: center;
    justify-content: space-between;
    grid-gap: var(--gap-lg);
  }
}
.prefooter .btn {
  white-space: nowrap;
  margin-top: var(--gap-lg);
}
@media (min-width: 992px) {
  .prefooter .btn {
    margin-top: 0;
  }
}
.prefooter p {
  font-size: var(--prefooter-font-size);
}

.sector-circle-bg {
  /*position: absolute;
  top: 800px;
  left: 50%;
  width: 1320px;
  aspect-ratio: 1;
  z-index: -1;
  transform: translateX(-50%);*/
  width: 1166px;
  height: 2111px;
}

.sector-header {
  --font-size-sector-header: 1.8rem;
}
.sector-header h2 {
  font-size: var(--font-size-sector-header);
}
@media (min-width: 992px) {
  .sector-header h2 {
    --font-size-sector-header: 2.4rem;
  }
}
.sector-header .lead {
  --sector-header-lead-padding: 0;
  font-size: 1.4rem;
  line-height: 1.3;
  padding-left: var(--sector-header-lead-padding);
}
@media (min-width: 768px) {
  .sector-header .lead {
    --sector-header-lead-padding: 1rem;
  }
}
@media (min-width: 768px) {
  .sector-header .lead {
    font-size: 1.8rem;
  }
}

.sector-image {
  mask-image: url(/img/sectors/sector-mask.svg);
  mask-repeat: no-repeat;
  mask-size: 100% 100%;
  position: relative;
  aspect-ratio: 205/269;
}
.sector-image img {
  width: 100% !important;
  height: auto;
  position: relative;
  transform-origin: bottom right;
  transition: all 1s ease;
  transform: scale(0.975) translate(0, 0);
  filter: drop-shadow(0px 5px 15px rgba(0, 0, 0, 0));
}
.sector-image .arc {
  position: absolute;
  bottom: 0;
  right: 0;
  width: 100%;
  aspect-ratio: 1;
}
.sector-image .arc path {
  fill: none;
  stroke: currentColor;
  stroke-width: 324px;
  stroke-dasharray: 820;
  stroke-dashoffset: 0;
}

.sector-image-container.anim {
  /*.sector-image {
      img {
          transform: scale(1) translate(0, 0);
          filter: drop-shadow(10px 10px 7px rgba(0, 0, 0, 0.35));
      }
  }*/
}
.sector-image-container.anim .arc path {
  animation: svgArcSweep 2s;
  animation-fill-mode: both;
}

.sector-retailer .arc {
  color: var(--color-sector-retailer);
}

.sector-crime-partnership .arc {
  color: var(--color-sector-crime-partnership);
}

.sector-police .arc {
  color: var(--color-sector-police);
}

.sector-security .arc {
  color: var(--color-sector-security);
}

.sector-bid .arc {
  color: var(--color-sector-bid);
}

.sector-local-authority .arc {
  color: var(--color-sector-local-authority);
}

.stats-bar {
  container: stats-bar/inline-size;
}
.stats-bar .stat {
  font-size: 15cqw;
  color: var(--primary);
  font-weight: var(--font-weight-bold);
}
.stats-bar .stat > * {
  margin-bottom: 0;
}
.stats-bar .message {
  font-size: 2rem;
  font-weight: var(--font-weight-bold);
}

/*@container stats-bar (min-width: 500px) {
    .message {
        font-size: 4em;
    }
}
*/
.tab-controls {
  display: flex;
  margin-bottom: 20px;
  position: relative;
}
.tab-controls .pill-bg {
  width: 33.33%;
  height: 100%;
  background: var(--secondary);
  position: absolute;
  top: 0;
  left: 0;
  border-radius: 1000px;
  transition: all 0.3s ease;
}
.tab-controls .btn {
  border: none;
  position: relative;
  flex: 1;
  z-index: 1;
}
.tab-controls .btn.active {
  color: #fff;
}
.tab-controls .btn:nth-child(2).active ~ .pill-bg {
  transform: translateX(100%);
}
.tab-controls .btn:nth-child(3).active ~ .pill-bg {
  transform: translateX(200%);
}

.tab-content {
  border-bottom: var(--border);
  padding-bottom: var(--box-padding-sm);
  margin-bottom: var(--box-padding-sm);
}
.tab-content .title {
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-bold);
  margin-bottom: var(--box-padding-sm);
}

.title-section {
  padding: var(--section-gap) 0;
  background: url(/img/bg-title-section.svg) no-repeat right -100px center;
  background-size: contain;
}
@media (min-width: 992px) {
  .title-section {
    background-position: right -35% center;
  }
}
@media (min-width: 1200px) {
  .title-section {
    background-position: right -10% center;
  }
}
@media (min-width: 1400px) {
  .title-section {
    background-position: right 25% center;
  }
}
.title-section .main-title {
  font-size: 2.5rem;
  text-align: left;
}
@media (min-width: 768px) {
  .title-section .main-title {
    font-size: 4rem;
  }
}

.page-case-study {
  /*background: url(/img/bg-circles.svg) no-repeat;
  background-size: 140% auto;
  background-position: 50% 620px;

  @media (min-width: 992px) {
      background-size: 110% auto;
      background-position: 50% 620px;
  }

  @media (min-width: 1200px) {
      background-size: 1380px auto;
      background-position: 50% 620px;
  }*/
  /*background: url(/img/bg-circles-alt2.svg) repeat-y;
  background-size: 908px;
  background-position: 50% 620px;

  @media (min-width: 768px) {
      background-size: 1168px;
  }

  @media (min-width: 992px) {
      background-size: 1468px;
  }*/
  background: url(/img/bg-circles-retailer.svg) repeat-y center top;
  background-size: 1320px;
}

.page-sector {
  background: url(/img/bg-circles-retailer.svg) repeat-y center 1250px;
  background-size: 1320px auto;
}
