/*
Theme Name: Texture Loops
Author: Visiwig LLC
Description: Theme designed custom for TextureLoops.com
Version: 1.0
License: Private License
Text Domain: textureloops.com
*/
:root {
  --border-size: 1px; }

svg * {
  transform-box: fill-box; }

/*!
 * Bootstrap Reboot v4.0.0-beta.2 (https://getbootstrap.com)
 * Copyright 2011-2017 The Bootstrap Authors
 * Copyright 2011-2017 Twitter, Inc.
 * Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)
 * Forked from Normalize.css, licensed MIT (https://github.com/necolas/normalize.css/blob/master/LICENSE.md)
 */
*,
*::before,
*::after {
  box-sizing: border-box; }

html {
  font-family: sans-serif;
  font-size: 16px;
  /* https://css-tricks.com/rem-global-em-local/ */
  line-height: 1.15;
  -webkit-text-size-adjust: 100%;
  -ms-text-size-adjust: 100%;
  -ms-overflow-style: scrollbar;
  -webkit-tap-highlight-color: transparent;
  scroll-behavior: smooth; }

@-ms-viewport {
  width: device-width; }
article, aside, dialog, figcaption, figure, footer, header, hgroup, main, nav, section {
  display: block; }

body {
  margin: 0;
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol";
  font-size: 1rem;
  font-weight: 400;
  line-height: 1.5;
  color: #212529;
  text-align: left;
  background-color: #fff; }

[tabindex="-1"]:focus {
  outline: 0 !important; }

hr {
  box-sizing: content-box;
  overflow: visible;
  border: none;
  border-top: 1px dotted #AAA;
  height: 1px;
  padding: 0; }

h1, h2, h3, h4, h5, h6 {
  margin-top: 0;
  margin-bottom: 0.5rem; }

p {
  margin-top: 0;
  margin-bottom: 1rem; }

abbr[title],
abbr[data-original-title] {
  text-decoration: underline;
  -webkit-text-decoration: underline dotted;
  text-decoration: underline dotted;
  cursor: help;
  border-bottom: 0; }

ol,
ul,
dl {
  margin-top: 0;
  margin-bottom: 1rem; }

ol ol,
ul ul,
ol ul,
ul ol {
  margin-bottom: 0; }

dt {
  font-weight: 700; }

dd {
  margin-bottom: .5rem;
  margin-left: 0; }

blockquote {
  margin: 0 0 1rem; }

dfn {
  font-style: italic; }

b,
strong {
  font-weight: bolder; }

small {
  font-size: 80%; }

a {
  text-decoration: none;
  background-color: transparent;
  -webkit-text-decoration-skip: objects; }

a:hover {
  color: #404;
  text-decoration: underline; }

a:not([href]):not([tabindex]) {
  color: inherit;
  text-decoration: none; }

a:not([href]):not([tabindex]):focus, a:not([href]):not([tabindex]):hover {
  color: inherit;
  text-decoration: none; }

a:not([href]):not([tabindex]):focus {
  outline: 0; }

pre,
code,
kbd,
samp {
  font-family: monospace, monospace;
  font-size: 1em; }

pre {
  margin-top: 0;
  margin-bottom: 1rem;
  overflow: auto;
  -ms-overflow-style: scrollbar;
  white-space: pre-wrap;
  word-break: break-all; }
  @media (min-width: 900px) {
    pre {
      white-space: pre;
      word-break: normal; } }

figure {
  margin: 0 0 1rem; }

img {
  vertical-align: middle;
  border-style: none;
  width: auto;
  max-width: 100%;
  height: auto; }

svg:not(:root) {
  overflow: hidden; }

a,
area,
button,
[role="button"],
input:not([type="range"]),
label,
select,
summary,
textarea {
  -ms-touch-action: manipulation;
  touch-action: manipulation; }

button {
  border-radius: 0; }

button:focus {
  outline: 1px dotted;
  outline: 5px auto -webkit-focus-ring-color; }

input,
button,
select,
optgroup,
textarea {
  margin: 0;
  font-family: inherit;
  font-size: inherit;
  line-height: inherit; }

button,
input {
  overflow: visible; }

button,
select {
  text-transform: none; }

button,
html [type="button"],
[type="reset"],
[type="submit"] {
  -webkit-appearance: button; }

button::-moz-focus-inner,
[type="button"]::-moz-focus-inner,
[type="reset"]::-moz-focus-inner,
[type="submit"]::-moz-focus-inner {
  padding: 0;
  border-style: none; }

input[type="radio"],
input[type="checkbox"] {
  box-sizing: border-box;
  padding: 0; }

input[type="date"],
input[type="time"],
input[type="datetime-local"],
input[type="month"] {
  -webkit-appearance: listbox; }

textarea {
  overflow: auto;
  resize: vertical;
  max-height: 60vh;
  width: 100%;
  border: 1px solid #EEE;
  background: #F7F7F7; }

progress {
  vertical-align: baseline; }

[type="number"]::-webkit-inner-spin-button,
[type="number"]::-webkit-outer-spin-button {
  height: auto; }

[type="search"] {
  outline-offset: -2px;
  -webkit-appearance: none; }

[type="search"]::-webkit-search-cancel-button,
[type="search"]::-webkit-search-decoration {
  -webkit-appearance: none; }

::-webkit-file-upload-button {
  font: inherit;
  -webkit-appearance: button; }

output {
  display: inline-block; }

[hidden] {
  display: none !important; }

input[type=range] {
  display: inline-block;
  height: 8px;
  margin: 0;
  background-color: transparent;
  -webkit-appearance: none;
  transition: transform .2s ease; }

input[type=range]:focus {
  outline: none; }
  input[type=range]:focus::-webkit-slider-thumb {
    background: #606 !important;
    transform: scale(1.1); }

input[type=range]:hover::-webkit-slider-thumb {
  background: #A0A;
  transform: scale(1.1); }

input[type=range]::-webkit-slider-runnable-track {
  background: #CCC;
  border: 0;
  border-radius: 99px;
  width: 100%;
  height: 6px;
  cursor: pointer; }

input[type=range]::-webkit-slider-thumb {
  margin-top: -6px;
  width: 18px;
  height: 18px;
  background: #808;
  border: none;
  border-radius: 99px;
  cursor: pointer;
  -webkit-appearance: none;
  transition: transform .2s ease, background .2s ease; }

input[type=range]::-moz-range-track {
  background: #CCC;
  border: 0;
  border-radius: 99px;
  width: 100%;
  height: 6px;
  cursor: pointer; }

input[type="range"]::-moz-range-progress {
  background-color: #808; }

input[type=range]::-moz-range-thumb {
  width: 18px;
  height: 18px;
  background: #808;
  border: 0;
  border-radius: 99px;
  cursor: pointer;
  transition: transform .2s ease, background .2s ease; }

input[type=range]::-ms-track {
  background: transparent;
  border-color: transparent;
  border-width: 10px 0;
  color: transparent;
  width: 100%;
  height: 8px;
  cursor: pointer; }

input[type=range]::-ms-fill-lower {
  background: #808;
  border: 0;
  border-radius: 198px; }

input[type=range]::-ms-fill-upper {
  background: #CCC;
  border: 0;
  border-radius: 198px; }

input[type=range]::-ms-thumb {
  width: 18px;
  height: 18px;
  background: #808;
  border: 0;
  border-radius: 99px;
  cursor: pointer;
  margin-top: 0px;
  transition: transform .2s ease, background .2s ease; }

input[type=range]:focus::-ms-fill-lower {
  background: #808; }

input[type=range]:focus::-ms-fill-upper {
  background: #CCC; }

@supports (-ms-ime-align: auto) {
  /* Pre-Chromium Edge only styles, selector taken from hhttps://stackoverflow.com/a/32202953/7077589 */
  input[type=range] {
    margin: 0; } }
input[type="range"] {
  --webkitProgressPercent: 0%; }

input[type="range"]::-webkit-slider-runnable-track {
  background-image: linear-gradient(90deg, #808 var(--webkitProgressPercent), #CCC var(--webkitProgressPercent)); }

#DOM_CANVAS {
  position: fixed;
  top: 9999;
  left: 9999;
  z-index: -2; }
  #DOM_CANVAS svg, #DOM_CANVAS svg * {
    transform-box: view-box; }

#full-page-wrapper {
  min-height: 70vh;
  margin: 0;
  padding: 0; }

.wrap {
  padding: 15px 10px; }
  @media (min-width: 900px) {
    .wrap {
      padding: 30px 10px; } }
  @media (min-width: 1200px) {
    .wrap {
      padding: 50px 10px; } }

img[data-lazy-src] {
  opacity: 0; }

img.lazyloaded {
  -webkit-transition: opacity 1.2s ease;
  -moz-transition: opacity 1.2s ease;
  transition: opacity 1.2s ease;
  opacity: 1; }

.text_center {
  text-align: center; }

.text_right {
  text-align: right; }

.text_left {
  text-align: left; }

/* <font-size> */
/* codementor.io/@ricardozea/100-responsive-typography-system-using-a-modular-scale-s5rhft58g */
body {
  font-size: 1.125rem;
  line-height: 1.5; }
  @media (min-width: 900px) {
    body {
      font-size: 1.25rem; } }
  @media (min-width: 1200px) {
    body {
      font-size: 1.3125rem; } }

/* </font-size>*/
/* <buttons>*/
a, button {
  cursor: pointer; }

a.btn {
  display: inline-block;
  padding: 5px 15px;
  border-radius: 99px;
  border: none;
  box-shadow: 0 0 0 2px #000;
  color: #000;
  font-weight: bold;
  white-space: nowrap;
  text-decoration: none !important;
  transition: background .2s, box-shadow .2s;
  background: #F09F33; }
  a.btn:hover {
    box-shadow: 0 0 0 2px #F09F33; }
  a.btn:hover {
    background: #F5BF77; }

a.btn-alt {
  display: inline-block;
  padding: 5px 15px;
  border-radius: 99px;
  border: none;
  box-shadow: 0 0 0 2px #000;
  color: #000;
  font-weight: bold;
  white-space: nowrap;
  text-decoration: none !important;
  transition: background .2s, box-shadow .2s;
  background: #FFF; }
  a.btn-alt:hover {
    box-shadow: 0 0 0 2px #F09F33; }
  a.btn-alt:hover {
    background: #F5BF77; }

/* </button>*/
/* <navigation>*/
body {
  min-width: 320px;
  width: 100%; }

#body-wrap {
  display: block;
  border: var(--border-size) solid #F09F33;
  box-shadow: 0 0 0 var(--border-size) #F09F33; }
  @media (min-width: 900px) {
    #body-wrap {
      display: grid; } }
  @media (min-width: 900px) {
    #body-wrap {
      grid-template-columns: 240px 1fr; } }
  @media (min-width: 1200px) {
    #body-wrap {
      grid-template-columns: 300px 1fr; } }

#nav-column {
  background: #FDF4E8; }
  @media (min-width: 900px) {
    #nav-column {
      min-height: calc(100dvh - (var(--border-size) * 2)); } }
  #nav-column .nav-wrap {
    border: var(--border-size) solid #F09F33;
    box-shadow: 0 0 0 var(--border-size) #F09F33;
    position: sticky;
    top: 1px;
    display: flex;
    flex-flow: column; }
    @media (min-width: 900px) {
      #nav-column .nav-wrap {
        height: calc(100dvh - (var(--border-size) * 2)); } }

#LOGO {
  display: block;
  padding: 10px;
  transition: background .2s; }
  @media (min-width: 600px) {
    #LOGO {
      padding: 15px; } }
  @media (min-width: 900px) {
    #LOGO {
      padding: 30px; } }
  #LOGO svg {
    display: block;
    width: 100%;
    max-width: 160px; }
    @media (min-width: 600px) {
      #LOGO svg {
        max-width: 200px; } }
    @media (min-width: 900px) {
      #LOGO svg {
        max-width: none; } }
  #LOGO:hover {
    background: #F09F33; }

#nav-logo {
  display: grid;
  grid-template-columns: 1fr 80px; }
  @media (min-width: 900px) {
    #nav-logo {
      display: block; } }
  #nav-logo #mobileMenu {
    display: block;
    margin: 0;
    padding: 16px;
    background: #FDF4E8;
    border: none;
    transition: color .2s ease; }
    @media (min-width: 900px) {
      #nav-logo #mobileMenu {
        display: none !important; } }
    #nav-logo #mobileMenu svg {
      width: 100%;
      max-width: 36px;
      max-height: 36px;
      fill: none;
      stroke: #F09F33;
      stroke-width: 4px;
      stroke-linecap: round;
      margin: 0 auto;
      transition: fill .2s ease; }
    #nav-logo #mobileMenu:hover, #nav-logo #mobileMenu:focus {
      outline: none;
      background: #FFF; }
      #nav-logo #mobileMenu:hover svg, #nav-logo #mobileMenu:focus svg {
        stroke: #000; }

button#mobileMenu .line-mid, button#mobileMenu .line-ctr {
  transform: rotate(0deg);
  transform-origin: 50% 50%; }
button#mobileMenu .line-top, button#mobileMenu .line-btm {
  transform: translateY(0deg);
  transform-origin: 50% 50%;
  opacity: 1; }
button#mobileMenu.contract .line-top {
  transform: translateY(0px);
  animation: lineTopBack .3s ease-in-out; }
button#mobileMenu.contract .line-mid {
  transform: rotate(0deg);
  animation: lineMidBack .3s ease-in-out; }
button#mobileMenu.contract .line-ctr {
  transform: rotate(0deg);
  animation: lineCtrBack .3s ease-in-out; }
button#mobileMenu.contract .line-btm {
  transform: translateY(0px);
  animation: lineBtmBack .3s ease-in-out; }
button#mobileMenu.expand .line-top {
  transform: translateY(14px);
  animation: lineTop .3s ease-in-out;
  opacity: 0; }
button#mobileMenu.expand .line-mid {
  transform: translateY(0px) rotate(135deg);
  animation: lineMid .3s ease-in-out; }
button#mobileMenu.expand .line-ctr {
  transform: translateY(0px) rotate(225deg);
  animation: lineCtr .3s ease-in-out; }
button#mobileMenu.expand .line-btm {
  transform: translateY(-14px);
  animation: lineBtm .3s ease-in-out;
  opacity: 0; }

@keyframes lineTop {
  0% {
    transform: translateY(0px);
    opacity: 1; }
  100% {
    transform: translateY(14px);
    opacity: 0; } }
@keyframes lineTopBack {
  0% {
    transform: translateY(14px);
    opacity: 0; }
  100% {
    transform: translateY(0px);
    opacity: 1; } }
@keyframes lineMid {
  0% {
    transform: rotate(0deg); }
  100% {
    transform: rotate(135deg); } }
@keyframes lineMidBack {
  0% {
    transform: rotate(135deg); }
  100% {
    transform: rotate(360deg); } }
@keyframes lineCtr {
  0% {
    transform: rotate(0deg); }
  100% {
    transform: rotate(225deg); } }
@keyframes lineCtrBack {
  0% {
    transform: rotate(225deg); }
  100% {
    transform: rotate(360deg); } }
@keyframes lineBtm {
  0% {
    transform: translateY(0px);
    opacity: 1; }
  100% {
    transform: translateY(-14px);
    opacity: 0; } }
@keyframes lineBtmBack {
  0% {
    transform: translateY(-14px);
    opacity: 0; }
  100% {
    transform: translateY(0px);
    opacity: 1; } }
#nav-links {
  flex: 1;
  background: #FCEAD2;
  overflow: hidden;
  max-height: 0;
  transition: max-height .2s ease;
  padding: 0; }
  @media (min-width: 900px) {
    #nav-links {
      background: #FDF4E8; } }
  @media (min-width: 900px) {
    #nav-links {
      max-height: none; } }
  @media (min-width: 900px) {
    #nav-links {
      padding: 30px; } }
  #nav-links a {
    display: block;
    font-size: 1.5rem;
    color: #000;
    padding: 4px 8px; }
    #nav-links a svg {
      width: 27px;
      height: 24px;
      vertical-align: -3px;
      margin-right: 15px; }
    #nav-links a:hover {
      text-decoration: none;
      background: #FADFBB; }
  #nav-links .children {
    display: none; }
    @media (min-width: 900px) {
      #nav-links .children {
        display: block; } }
    #nav-links .children a {
      font-size: 1.2rem;
      padding: 0 8px; }
      #nav-links .children a svg {
        width: 57px;
        margin-right: 3px; }

#nav-footer {
  display: none;
  text-align: center;
  padding: 0; }
  @media (min-width: 900px) {
    #nav-footer {
      display: block; } }
  #nav-footer .login {
    padding: 15px; }

#content-column {
  display: flex;
  flex-flow: column; }
  @media (min-width: 900px) {
    #content-column {
      min-height: calc(100dvh - (var(--border-size) * 2)); } }

main {
  flex: 1;
  box-shadow: inset 0 0 0 var(--border-size) #F09F33; }

footer {
  border: var(--border-size) solid #F09F33;
  box-shadow: 0 0 0 var(--border-size) #F09F33;
  padding: 5px;
  background: #F8D4A4;
  text-align: center;
  margin: 0;
  z-index: 999; }
  footer .copyright {
    line-height: 1;
    font-size: 0.8rem; }
    footer .copyright p {
      margin: 0; }

/* </navigation>*/
/* <homepage>*/
.section-duo {
  display: grid;
  grid-template-columns: 1fr;
  grid-gap: 30px;
  border: var(--border-size) solid #F09F33;
  box-shadow: 0 0 0 var(--border-size) #F09F33;
  padding: 60px calc((20% - 6px) / 4);
  background: #FCEAD2; }
  @media (min-width: 900px) {
    .section-duo {
      grid-template-columns: 1fr 1fr; } }

.sample-grid .sample-wrap {
  max-width: 500px;
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  grid-gap: 10px; }
  .sample-grid .sample-wrap img {
    animation: shadow-strength linear 10s;
    opacity: .5; }
  .sample-grid .sample-wrap div:last-child img {
    animation: highlight-strength linear 10s;
    opacity: 1; }
  .sample-grid .sample-wrap div {
    background-color: #F09F33;
    animation: glow linear 10s;
    position: relative; }
    .sample-grid .sample-wrap div img:nth-child(2) {
      position: absolute;
      left: 0;
      top: 0;
      width: 100%;
      height: auto;
      z-index: 1;
      animation: highlight-strength linear 10s;
      opacity: 1; }
    .sample-grid .sample-wrap div span {
      position: absolute;
      left: 0;
      bottom: 0;
      z-index: 3;
      width: 100%;
      padding: 5px;
      text-align: center;
      background: #FFF;
      font-size: 1rem;
      font-weight: bold;
      white-space: nowrap;
      overflow: hidden; }
    .sample-grid .sample-wrap div::before {
      content: "";
      position: absolute;
      left: 0;
      bottom: 0;
      width: 100%;
      height: 100%;
      box-shadow: inset 0 0 0 5px #FFF;
      z-index: 2; }

.section-sampler {
  border: var(--border-size) solid #F09F33;
  box-shadow: 0 0 0 var(--border-size) #F09F33;
  padding: 60px;
  background-color: #FCEAD2;
  background-size: cover, auto;
  background-position: top left, center;
  background-repeat: no-repeat, repeat-x; }
  @media (min-width: 900px) {
    .section-sampler {
      background-image: url('data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 2000 500"><path fill="%23fbe7cc" d="M2000 0H0v500h1000c211.6-201.22 284.42-373.04 1000-500Z"/></svg>'), url("images/texture-sample-background.jpg"); } }
  .section-sampler p {
    max-width: 100%; }
    @media (min-width: 900px) {
      .section-sampler p {
        max-width: 60%; } }

.heading-box {
  border: var(--border-size) solid #F09F33;
  box-shadow: 0 0 0 var(--border-size) #F09F33;
  padding: 60px 60px 20px 60px;
  padding: 60px calc((20% - 6px) / 4) 20px calc((20% - 6px) / 4); }

.release-grid {
  display: grid; }
  @media (min-width: 1200px) {
    .release-grid {
      grid-template-columns: 1fr 1fr; } }
  .release-grid .box-set {
    border: var(--border-size) solid #F09F33;
    box-shadow: 0 0 0 var(--border-size) #F09F33;
    padding: 30px; }
    @media (min-width: 600px) {
      .release-grid .box-set {
        padding: 45px; } }
    @media (min-width: 900px) {
      .release-grid .box-set {
        padding: 60px; } }
    .release-grid .box-set a.thumb-strip {
      display: grid;
      grid-template-columns: 1fr 1fr 1fr;
      grid-gap: 5px;
      position: relative; }
      @media (min-width: 600px) {
        .release-grid .box-set a.thumb-strip {
          grid-gap: 15px; } }
      .release-grid .box-set a.thumb-strip img {
        display: block; }
      .release-grid .box-set a.thumb-strip::after {
        position: absolute;
        content: "";
        background-color: #F09F33;
        animation: glow linear 10s infinite;
        mix-blend-mode: overlay;
        top: 0;
        right: 0;
        bottom: 0;
        left: 0;
        width: 100%;
        height: 100%;
        opacity: 0;
        transition: opacity .2s; }
      .release-grid .box-set a.thumb-strip:hover::after {
        opacity: 1; }
    .release-grid .box-set svg {
      vertical-align: -3px;
      width: 27px;
      height: 24px; }
    .release-grid .box-set p {
      transform: translateY(8px); }
      @media (min-width: 600px) {
        .release-grid .box-set p {
          position: absolute; } }

/* </homepage>*/
/* <util>*/
.breadcrumbs {
  font-size: 1.2rem; }

/* </util>*/
/* <child template>*/
.set-layout {
  display: grid; }
  @media (min-width: 1200px) {
    .set-layout {
      grid-template-columns: 1fr 1fr; } }
  .set-layout .set-content {
    background: #FADFBB; }
    .set-layout .set-content .wrap {
      position: sticky;
      top: 1px;
      padding: 0; }
    .set-layout .set-content .set-description {
      background: #FFF;
      padding: 30px;
      border: var(--border-size) solid #F09F33;
      box-shadow: 0 0 0 var(--border-size) #F09F33; }
      @media (min-width: 900px) {
        .set-layout .set-content .set-description {
          padding: 45px; } }
      @media (min-width: 1200px) {
        .set-layout .set-content .set-description {
          padding: 60px; } }
    .set-layout .set-content .tags a {
      display: inline-block;
      padding: 2px 10px;
      font-size: 1.2rem;
      line-height: 1.2;
      background: #FCEAD2;
      color: rgba(0, 0, 0, 0.75);
      border-radius: 99px;
      margin: 2px;
      transition: background .2s, color .2s; }
      .set-layout .set-content .tags a:hover {
        color: #000;
        background: #FDF4E8;
        text-decoration: none; }
    .set-layout .set-content .pricing-options {
      padding: 60px;
      border: var(--border-size) solid #F09F33;
      box-shadow: 0 0 0 var(--border-size) #F09F33;
      background: #FCEAD2; }
      .set-layout .set-content .pricing-options h2 {
        padding-bottom: 30px; }
      .set-layout .set-content .pricing-options p {
        margin-left: 50px; }
        .set-layout .set-content .pricing-options p a {
          margin-left: -25px; }
  .set-layout .desc_columns {
    margin-bottom: 1rem; }
    .set-layout .desc_columns > div {
      display: grid;
      grid-template-columns: 1fr;
      line-height: 1.75;
      margin: 0; }
      @media (min-width: 600px) {
        .set-layout .desc_columns > div {
          grid-template-columns: 80px 1fr; } }
      @media (min-width: 900px) {
        .set-layout .desc_columns > div {
          grid-template-columns: 100px 1fr; } }
  .set-layout .child-thumbs {
    grid-template-columns: 1fr; }
    @media (min-width: 600px) {
      .set-layout .child-thumbs {
        grid-template-columns: repeat(auto-fill, minmax(min(300px, 100%), 1fr));
        grid-template-rows: repeat(auto-fill, minmax(min(300px, 100%), auto) 1fr); } }
    .set-layout .child-thumbs .box {
      padding: 15%; }
      .set-layout .child-thumbs .box span {
        font-size: 1rem;
        white-space: nowrap; }

.img-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(min(360px, 100%), 1fr));
  grid-template-rows: repeat(auto-fill, minmax(min(360px, 100%), auto) 1fr); }
  .img-grid .box {
    border: var(--border-size) solid #F09F33;
    box-shadow: 0 0 0 var(--border-size) #F09F33;
    padding: 20%;
    position: relative;
    overflow: hidden; }
    .img-grid .box a {
      display: block;
      position: relative; }
      .img-grid .box a::after {
        position: absolute;
        content: "";
        background-color: #F09F33;
        animation: glow linear 10s 3;
        mix-blend-mode: overlay;
        top: 0;
        right: 0;
        bottom: 0;
        left: 0;
        width: 100%;
        height: 100%;
        opacity: 0;
        transition: opacity .2s; }
      .img-grid .box a:hover::after {
        opacity: 1; }
    .img-grid .box img {
      position: relative;
      display: block;
      max-width: 100%;
      height: auto; }
    .img-grid .box h3, .img-grid .box span {
      position: absolute;
      transform: translateY(8px); }
    .img-grid .box.box-cap {
      grid-column: 1 / -1;
      padding: 0;
      border: none;
      height: 0; }

@keyframes glow {
  0% {
    background-color: #F09F33; }
  20% {
    background-color: #cc3f47; }
  40% {
    background-color: #880088; }
  60% {
    background-color: #22347f; }
  80% {
    background-color: #46893d; }
  100% {
    background-color: #F09F33; } }
@keyframes shadow-strength {
  0% {
    opacity: .5; }
  20% {
    opacity: .7; }
  40% {
    opacity: .9; }
  60% {
    opacity: 1; }
  80% {
    opacity: .75; }
  100% {
    opacity: .5; } }
@keyframes highlight-strength {
  0% {
    opacity: 1; }
  20% {
    opacity: .8; }
  40% {
    opacity: .6; }
  60% {
    opacity: .5; }
  80% {
    opacity: .7; }
  100% {
    opacity: 1; } }
p.hasAccess {
  display: inline-block;
  padding: 10px;
  background: #F8D4A4;
  border: 1px solid #F5BF77; }

/* </child template>*/
/* <tag template>*/
h1 em {
  background: #F8D4A4;
  color: #c07f29;
  background: #FFF;
  padding: 0 5px; }

/* </tag template>*/
