/*! normalize.css v8.0.1 | MIT License | github.com/necolas/normalize.css */

/* Document
   ========================================================================== */

/**
 * 1. Correct the line height in all browsers.
 * 2. Prevent adjustments of font size after orientation changes in iOS.
 */

 html {
  line-height: 1.15; /* 1 */
  -webkit-text-size-adjust: 100%; /* 2 */
}

/* Sections
   ========================================================================== */

/**
 * Remove the margin in all browsers.
 */

body {
  margin: 0;
}

/**
 * Render the `main` element consistently in IE.
 */

main {
  display: block;
}

/**
 * Correct the font size and margin on `h1` elements within `section` and
 * `article` contexts in Chrome, Firefox, and Safari.
 */

h1 {
  font-size: 2em;
  margin: 0.67em 0;
}

/* Grouping content
   ========================================================================== */

/**
 * 1. Add the correct box sizing in Firefox.
 * 2. Show the overflow in Edge and IE.
 */

hr {
  box-sizing: content-box; /* 1 */
  height: 0; /* 1 */
  overflow: visible; /* 2 */
}

/**
 * 1. Correct the inheritance and scaling of font size in all browsers.
 * 2. Correct the odd `em` font sizing in all browsers.
 */

pre {
  font-family: monospace, monospace; /* 1 */
  font-size: 1em; /* 2 */
}

/* Text-level semantics
   ========================================================================== */

/**
 * Remove the gray background on active links in IE 10.
 */

a {
  background-color: transparent;
}

/**
 * 1. Remove the bottom border in Chrome 57-
 * 2. Add the correct text decoration in Chrome, Edge, IE, Opera, and Safari.
 */

abbr[title] {
  border-bottom: none; /* 1 */
  text-decoration: underline; /* 2 */
  text-decoration: underline dotted; /* 2 */
}

/**
 * Add the correct font weight in Chrome, Edge, and Safari.
 */

b,
strong {
  font-weight: bolder;
}

/**
 * 1. Correct the inheritance and scaling of font size in all browsers.
 * 2. Correct the odd `em` font sizing in all browsers.
 */

code,
kbd,
samp {
  font-family: monospace, monospace; /* 1 */
  font-size: 1em; /* 2 */
}

/**
 * Add the correct font size in all browsers.
 */

small {
  font-size: 80%;
}

/**
 * Prevent `sub` and `sup` elements from affecting the line height in
 * all browsers.
 */

sub,
sup {
  font-size: 75%;
  line-height: 0;
  position: relative;
  vertical-align: baseline;
}

sub {
  bottom: -0.25em;
}

sup {
  top: -0.5em;
}

/* Embedded content
   ========================================================================== */

/**
 * Remove the border on images inside links in IE 10.
 */

img {
  border-style: none;
}

/* Forms
   ========================================================================== */

/**
 * 1. Change the font styles in all browsers.
 * 2. Remove the margin in Firefox and Safari.
 */

button,
input,
optgroup,
select,
textarea {
  font-family: inherit; /* 1 */
  font-size: 100%; /* 1 */
  line-height: 1.15; /* 1 */
  margin: 0; /* 2 */
}

/**
 * Show the overflow in IE.
 * 1. Show the overflow in Edge.
 */

button,
input { /* 1 */
  overflow: visible;
}

/**
 * Remove the inheritance of text transform in Edge, Firefox, and IE.
 * 1. Remove the inheritance of text transform in Firefox.
 */

button,
select { /* 1 */
  text-transform: none;
}

/**
 * Correct the inability to style clickable types in iOS and Safari.
 */

button,
[type="button"],
[type="reset"],
[type="submit"] {
  -webkit-appearance: button;
}

/**
 * Remove the inner border and padding in Firefox.
 */

button::-moz-focus-inner,
[type="button"]::-moz-focus-inner,
[type="reset"]::-moz-focus-inner,
[type="submit"]::-moz-focus-inner {
  border-style: none;
  padding: 0;
}

/**
 * Restore the focus styles unset by the previous rule.
 */

button:-moz-focusring,
[type="button"]:-moz-focusring,
[type="reset"]:-moz-focusring,
[type="submit"]:-moz-focusring {
  outline: 1px dotted ButtonText;
}

/**
 * Correct the padding in Firefox.
 */

fieldset {
  padding: 0.35em 0.75em 0.625em;
}

/**
 * 1. Correct the text wrapping in Edge and IE.
 * 2. Correct the color inheritance from `fieldset` elements in IE.
 * 3. Remove the padding so developers are not caught out when they zero out
 *    `fieldset` elements in all browsers.
 */

legend {
  box-sizing: border-box; /* 1 */
  color: inherit; /* 2 */
  display: table; /* 1 */
  max-width: 100%; /* 1 */
  padding: 0; /* 3 */
  white-space: normal; /* 1 */
}

/**
 * Add the correct vertical alignment in Chrome, Firefox, and Opera.
 */

progress {
  vertical-align: baseline;
}

/**
 * Remove the default vertical scrollbar in IE 10+.
 */

textarea {
  overflow: auto;
}

/**
 * 1. Add the correct box sizing in IE 10.
 * 2. Remove the padding in IE 10.
 */

[type="checkbox"],
[type="radio"] {
  box-sizing: border-box; /* 1 */
  padding: 0; /* 2 */
}

/**
 * Correct the cursor style of increment and decrement buttons in Chrome.
 */

[type="number"]::-webkit-inner-spin-button,
[type="number"]::-webkit-outer-spin-button {
  height: auto;
}

/**
 * 1. Correct the odd appearance in Chrome and Safari.
 * 2. Correct the outline style in Safari.
 */

[type="search"] {
  -webkit-appearance: textfield; /* 1 */
  outline-offset: -2px; /* 2 */
}

/**
 * Remove the inner padding in Chrome and Safari on macOS.
 */

[type="search"]::-webkit-search-decoration {
  -webkit-appearance: none;
}

/**
 * 1. Correct the inability to style clickable types in iOS and Safari.
 * 2. Change font properties to `inherit` in Safari.
 */

::-webkit-file-upload-button {
  -webkit-appearance: button; /* 1 */
  font: inherit; /* 2 */
}

/* Interactive
   ========================================================================== */

/*
 * Add the correct display in Edge, IE 10+, and Firefox.
 */

details {
  display: block;
}

/*
 * Add the correct display in all browsers.
 */

summary {
  display: list-item;
}

/* Misc
   ========================================================================== */

/**
 * Add the correct display in IE 10+.
 */

template {
  display: none;
}

/**
 * Add the correct display in IE 10.
 */

[hidden] {
  display: none;
}
:root {
	--red75: rgba(255, 0, 0, 0.75);

	--color-base: #e5e1e1;
	--color-base-offset: #acabab;
	--color-contrast: #000000;
	--color-interactive: #0000ff;

	--backsplash: #cbd4e3;

	--backgroundColor: var(--color-base);
	--ring-offset-color: var(--backgroundColor);
	--ring-offset-inset: ;
	--ring-offset-width: 2px;

	--ring-blur: 0px;
	--ring-color: rgba(50, 145, 255, 0.85);
	--ring-color: rgba(25, 215, 235, 0.85);

	--ring-inset: ;
	--ring-width: 4px;

	--baseLineHeight: 1.5em;
}
:root{--f-spinner-width: 36px;--f-spinner-height: 36px;--f-spinner-color-1: rgba(0, 0, 0, 0.1);--f-spinner-color-2: rgba(17, 24, 28, 0.8);--f-spinner-stroke: 2.75}.f-spinner{margin:auto;padding:0;width:var(--f-spinner-width);height:var(--f-spinner-height)}.f-spinner svg{width:100%;height:100%;vertical-align:top;animation:f-spinner-rotate 2s linear infinite}.f-spinner svg *{stroke-width:var(--f-spinner-stroke);fill:none}.f-spinner svg *:first-child{stroke:var(--f-spinner-color-1)}.f-spinner svg *:last-child{stroke:var(--f-spinner-color-2);animation:f-spinner-dash 2s ease-in-out infinite}@keyframes f-spinner-rotate{100%{transform:rotate(360deg)}}@keyframes f-spinner-dash{0%{stroke-dasharray:1,150;stroke-dashoffset:0}50%{stroke-dasharray:90,150;stroke-dashoffset:-35}100%{stroke-dasharray:90,150;stroke-dashoffset:-124}}.f-throwOutUp{animation:var(--f-throw-out-duration, 0.175s) ease-out both f-throwOutUp}.f-throwOutDown{animation:var(--f-throw-out-duration, 0.175s) ease-out both f-throwOutDown}@keyframes f-throwOutUp{to{transform:translate3d(0, calc(var(--f-throw-out-distance, 150px) * -1), 0);opacity:0}}@keyframes f-throwOutDown{to{transform:translate3d(0, var(--f-throw-out-distance, 150px), 0);opacity:0}}.f-zoomInUp{animation:var(--f-transition-duration, 0.2s) ease .1s both f-zoomInUp}.f-zoomOutDown{animation:var(--f-transition-duration, 0.2s) ease both f-zoomOutDown}@keyframes f-zoomInUp{from{transform:scale(0.975) translate3d(0, 16px, 0);opacity:0}to{transform:scale(1) translate3d(0, 0, 0);opacity:1}}@keyframes f-zoomOutDown{to{transform:scale(0.975) translate3d(0, 16px, 0);opacity:0}}.f-fadeIn{animation:var(--f-transition-duration, 0.2s) var(--f-transition-easing, ease) var(--f-transition-delay, 0s) both f-fadeIn;z-index:2}.f-fadeOut{animation:var(--f-transition-duration, 0.2s) var(--f-transition-easing, ease) var(--f-transition-delay, 0s) both f-fadeOut;z-index:1}@keyframes f-fadeIn{0%{opacity:0}100%{opacity:1}}@keyframes f-fadeOut{100%{opacity:0}}.f-fadeFastIn{animation:var(--f-transition-duration, 0.2s) ease-out both f-fadeFastIn;z-index:2}.f-fadeFastOut{animation:var(--f-transition-duration, 0.1s) ease-out both f-fadeFastOut;z-index:2}@keyframes f-fadeFastIn{0%{opacity:.75}100%{opacity:1}}@keyframes f-fadeFastOut{100%{opacity:0}}.f-fadeSlowIn{animation:var(--f-transition-duration, 0.5s) ease both f-fadeSlowIn;z-index:2}.f-fadeSlowOut{animation:var(--f-transition-duration, 0.5s) ease both f-fadeSlowOut;z-index:1}@keyframes f-fadeSlowIn{0%{opacity:0}100%{opacity:1}}@keyframes f-fadeSlowOut{100%{opacity:0}}.f-crossfadeIn{animation:var(--f-transition-duration, 0.2s) ease-out both f-crossfadeIn;z-index:2}.f-crossfadeOut{animation:calc(var(--f-transition-duration, 0.2s)*.5) linear .1s both f-crossfadeOut;z-index:1}@keyframes f-crossfadeIn{0%{opacity:0}100%{opacity:1}}@keyframes f-crossfadeOut{100%{opacity:0}}.f-slideIn.from-next{animation:var(--f-transition-duration, 0.85s) cubic-bezier(0.16, 1, 0.3, 1) f-slideInNext}.f-slideIn.from-prev{animation:var(--f-transition-duration, 0.85s) cubic-bezier(0.16, 1, 0.3, 1) f-slideInPrev}.f-slideOut.to-next{animation:var(--f-transition-duration, 0.85s) cubic-bezier(0.16, 1, 0.3, 1) f-slideOutNext}.f-slideOut.to-prev{animation:var(--f-transition-duration, 0.85s) cubic-bezier(0.16, 1, 0.3, 1) f-slideOutPrev}@keyframes f-slideInPrev{0%{transform:translateX(100%)}100%{transform:translate3d(0, 0, 0)}}@keyframes f-slideInNext{0%{transform:translateX(-100%)}100%{transform:translate3d(0, 0, 0)}}@keyframes f-slideOutNext{100%{transform:translateX(-100%)}}@keyframes f-slideOutPrev{100%{transform:translateX(100%)}}.f-classicIn.from-next{animation:var(--f-transition-duration, 0.85s) cubic-bezier(0.16, 1, 0.3, 1) f-classicInNext;z-index:2}.f-classicIn.from-prev{animation:var(--f-transition-duration, 0.85s) cubic-bezier(0.16, 1, 0.3, 1) f-classicInPrev;z-index:2}.f-classicOut.to-next{animation:var(--f-transition-duration, 0.85s) cubic-bezier(0.16, 1, 0.3, 1) f-classicOutNext;z-index:1}.f-classicOut.to-prev{animation:var(--f-transition-duration, 0.85s) cubic-bezier(0.16, 1, 0.3, 1) f-classicOutPrev;z-index:1}@keyframes f-classicInNext{0%{transform:translateX(-75px);opacity:0}100%{transform:translate3d(0, 0, 0);opacity:1}}@keyframes f-classicInPrev{0%{transform:translateX(75px);opacity:0}100%{transform:translate3d(0, 0, 0);opacity:1}}@keyframes f-classicOutNext{100%{transform:translateX(-75px);opacity:0}}@keyframes f-classicOutPrev{100%{transform:translateX(75px);opacity:0}}:root{--f-button-width: 40px;--f-button-height: 40px;--f-button-border: 0;--f-button-border-radius: 0;--f-button-color: #374151;--f-button-bg: #f8f8f8;--f-button-hover-bg: #e0e0e0;--f-button-active-bg: #d0d0d0;--f-button-shadow: none;--f-button-transition: all 0.15s ease;--f-button-transform: none;--f-button-svg-width: 20px;--f-button-svg-height: 20px;--f-button-svg-stroke-width: 1.5;--f-button-svg-fill: none;--f-button-svg-filter: none;--f-button-svg-disabled-opacity: 0.65}.f-button{display:flex;justify-content:center;align-items:center;box-sizing:content-box;position:relative;margin:0;padding:0;width:var(--f-button-width);height:var(--f-button-height);border:var(--f-button-border);border-radius:var(--f-button-border-radius);color:var(--f-button-color);background:var(--f-button-bg);box-shadow:var(--f-button-shadow);pointer-events:all;cursor:pointer;transition:var(--f-button-transition)}@media(hover: hover){.f-button:hover:not([disabled]){color:var(--f-button-hover-color);background-color:var(--f-button-hover-bg)}}.f-button:active:not([disabled]){background-color:var(--f-button-active-bg)}.f-button:focus:not(:focus-visible){outline:none}.f-button:focus-visible{outline:none;box-shadow:inset 0 0 0 var(--f-button-outline, 2px) var(--f-button-outline-color, var(--f-button-color))}.f-button svg{width:var(--f-button-svg-width);height:var(--f-button-svg-height);fill:var(--f-button-svg-fill);stroke:currentColor;stroke-width:var(--f-button-svg-stroke-width);stroke-linecap:round;stroke-linejoin:round;transition:opacity .15s ease;transform:var(--f-button-transform);filter:var(--f-button-svg-filter);pointer-events:none}.f-button[disabled]{cursor:default}.f-button[disabled] svg{opacity:var(--f-button-svg-disabled-opacity)}.f-carousel__nav .f-button.is-prev,.f-carousel__nav .f-button.is-next,.fancybox__nav .f-button.is-prev,.fancybox__nav .f-button.is-next{position:absolute;z-index:1}.is-horizontal .f-carousel__nav .f-button.is-prev,.is-horizontal .f-carousel__nav .f-button.is-next,.is-horizontal .fancybox__nav .f-button.is-prev,.is-horizontal .fancybox__nav .f-button.is-next{top:50%;transform:translateY(-50%)}.is-horizontal .f-carousel__nav .f-button.is-prev,.is-horizontal .fancybox__nav .f-button.is-prev{left:var(--f-button-prev-pos)}.is-horizontal .f-carousel__nav .f-button.is-next,.is-horizontal .fancybox__nav .f-button.is-next{right:var(--f-button-next-pos)}.is-horizontal.is-rtl .f-carousel__nav .f-button.is-prev,.is-horizontal.is-rtl .fancybox__nav .f-button.is-prev{left:auto;right:var(--f-button-next-pos)}.is-horizontal.is-rtl .f-carousel__nav .f-button.is-next,.is-horizontal.is-rtl .fancybox__nav .f-button.is-next{right:auto;left:var(--f-button-prev-pos)}.is-vertical .f-carousel__nav .f-button.is-prev,.is-vertical .f-carousel__nav .f-button.is-next,.is-vertical .fancybox__nav .f-button.is-prev,.is-vertical .fancybox__nav .f-button.is-next{top:auto;left:50%;transform:translateX(-50%)}.is-vertical .f-carousel__nav .f-button.is-prev,.is-vertical .fancybox__nav .f-button.is-prev{top:var(--f-button-next-pos)}.is-vertical .f-carousel__nav .f-button.is-next,.is-vertical .fancybox__nav .f-button.is-next{bottom:var(--f-button-next-pos)}.is-vertical .f-carousel__nav .f-button.is-prev svg,.is-vertical .f-carousel__nav .f-button.is-next svg,.is-vertical .fancybox__nav .f-button.is-prev svg,.is-vertical .fancybox__nav .f-button.is-next svg{transform:rotate(90deg)}.f-carousel__nav .f-button:disabled,.fancybox__nav .f-button:disabled{pointer-events:none}html.with-fancybox{width:auto;overflow:visible;scroll-behavior:auto}html.with-fancybox body{touch-action:none}html.with-fancybox body.hide-scrollbar{width:auto;margin-right:calc(var(--fancybox-body-margin, 0px) + var(--fancybox-scrollbar-compensate, 0px));overflow:hidden !important;overscroll-behavior-y:none}.fancybox__container{--fancybox-color: #dbdbdb;--fancybox-hover-color: #fff;--fancybox-bg: rgba(24, 24, 27, 0.98);--fancybox-slide-gap: 10px;--f-spinner-width: 50px;--f-spinner-height: 50px;--f-spinner-color-1: rgba(255, 255, 255, 0.1);--f-spinner-color-2: #bbb;--f-spinner-stroke: 3.65;position:fixed;top:0;left:0;bottom:0;right:0;direction:ltr;display:flex;flex-direction:column;box-sizing:border-box;margin:0;padding:0;color:#f8f8f8;-webkit-tap-highlight-color:rgba(0,0,0,0);overflow:visible;z-index:var(--fancybox-zIndex, 1050);outline:none;transform-origin:top left;-webkit-text-size-adjust:100%;-moz-text-size-adjust:none;-ms-text-size-adjust:100%;text-size-adjust:100%;overscroll-behavior-y:contain}.fancybox__container *,.fancybox__container *::before,.fancybox__container *::after{box-sizing:inherit}.fancybox__container::backdrop{background-color:rgba(0,0,0,0)}.fancybox__backdrop{position:fixed;top:0;left:0;bottom:0;right:0;z-index:-1;background:var(--fancybox-bg);opacity:var(--fancybox-opacity, 1);will-change:opacity}.fancybox__carousel{position:relative;box-sizing:border-box;flex:1;min-height:0;z-index:10;overflow-y:visible;overflow-x:clip}.fancybox__viewport{width:100%;height:100%}.fancybox__viewport.is-draggable{cursor:move;cursor:grab}.fancybox__viewport.is-dragging{cursor:move;cursor:grabbing}.fancybox__track{display:flex;margin:0 auto;height:100%}.fancybox__slide{flex:0 0 auto;position:relative;display:flex;flex-direction:column;align-items:center;width:100%;height:100%;margin:0 var(--fancybox-slide-gap) 0 0;padding:4px;overflow:auto;overscroll-behavior:contain;transform:translate3d(0, 0, 0);backface-visibility:hidden}.fancybox__container:not(.is-compact) .fancybox__slide.has-close-btn{padding-top:40px}.fancybox__slide.has-iframe,.fancybox__slide.has-video,.fancybox__slide.has-html5video{overflow:hidden}.fancybox__slide.has-image{overflow:hidden}.fancybox__slide.has-image.is-animating,.fancybox__slide.has-image.is-selected{overflow:visible}.fancybox__slide::before,.fancybox__slide::after{content:"";flex:0 0 0;margin:auto}.fancybox__backdrop:empty,.fancybox__viewport:empty,.fancybox__track:empty,.fancybox__slide:empty{display:block}.fancybox__content{align-self:center;display:flex;flex-direction:column;position:relative;margin:0;padding:2rem;max-width:100%;color:var(--fancybox-content-color, #374151);background:var(--fancybox-content-bg, #fff);cursor:default;border-radius:0;z-index:20}.is-loading .fancybox__content{opacity:0}.is-draggable .fancybox__content{cursor:move;cursor:grab}.can-zoom_in .fancybox__content{cursor:zoom-in}.can-zoom_out .fancybox__content{cursor:zoom-out}.is-dragging .fancybox__content{cursor:move;cursor:grabbing}.fancybox__content [data-selectable],.fancybox__content [contenteditable]{cursor:auto}.fancybox__slide.has-image>.fancybox__content{padding:0;background:rgba(0,0,0,0);min-height:1px;background-repeat:no-repeat;background-size:contain;background-position:center center;transition:none;transform:translate3d(0, 0, 0);backface-visibility:hidden}.fancybox__slide.has-image>.fancybox__content>picture>img{width:100%;height:auto;max-height:100%}.is-animating .fancybox__content,.is-dragging .fancybox__content{will-change:transform,width,height}.fancybox-image{margin:auto;display:block;width:100%;height:100%;min-height:0;object-fit:contain;user-select:none;filter:blur(0px)}.fancybox__caption{align-self:center;max-width:100%;flex-shrink:0;margin:0;padding:14px 0 4px 0;overflow-wrap:anywhere;line-height:1.375;color:var(--fancybox-color, currentColor);opacity:var(--fancybox-opacity, 1);cursor:auto;visibility:visible}.is-loading .fancybox__caption,.is-closing .fancybox__caption{opacity:0;visibility:hidden}.is-compact .fancybox__caption{padding-bottom:0}.f-button.is-close-btn{--f-button-svg-stroke-width: 2;position:absolute;top:0;right:8px;z-index:40}.fancybox__content>.f-button.is-close-btn{--f-button-width: 34px;--f-button-height: 34px;--f-button-border-radius: 4px;--f-button-color: var(--fancybox-color, #fff);--f-button-hover-color: var(--fancybox-color, #fff);--f-button-bg: transparent;--f-button-hover-bg: transparent;--f-button-active-bg: transparent;--f-button-svg-width: 22px;--f-button-svg-height: 22px;position:absolute;top:-38px;right:0;opacity:.75}.is-loading .fancybox__content>.f-button.is-close-btn{visibility:hidden}.is-zooming-out .fancybox__content>.f-button.is-close-btn{visibility:hidden}.fancybox__content>.f-button.is-close-btn:hover{opacity:1}.fancybox__footer{padding:0;margin:0;position:relative}.fancybox__footer .fancybox__caption{width:100%;padding:24px;opacity:var(--fancybox-opacity, 1);transition:all .25s ease}.is-compact .fancybox__footer{position:absolute;bottom:0;left:0;right:0;z-index:20;background:rgba(24,24,27,.5)}.is-compact .fancybox__footer .fancybox__caption{padding:12px}.is-compact .fancybox__content>.f-button.is-close-btn{--f-button-border-radius: 50%;--f-button-color: #fff;--f-button-hover-color: #fff;--f-button-outline-color: #000;--f-button-bg: rgba(0, 0, 0, 0.6);--f-button-active-bg: rgba(0, 0, 0, 0.6);--f-button-hover-bg: rgba(0, 0, 0, 0.6);--f-button-svg-width: 18px;--f-button-svg-height: 18px;--f-button-svg-filter: none;top:5px;right:5px}.fancybox__nav{--f-button-width: 50px;--f-button-height: 50px;--f-button-border: 0;--f-button-border-radius: 50%;--f-button-color: var(--fancybox-color);--f-button-hover-color: var(--fancybox-hover-color);--f-button-bg: transparent;--f-button-hover-bg: rgba(24, 24, 27, 0.3);--f-button-active-bg: rgba(24, 24, 27, 0.5);--f-button-shadow: none;--f-button-transition: all 0.15s ease;--f-button-transform: none;--f-button-svg-width: 26px;--f-button-svg-height: 26px;--f-button-svg-stroke-width: 2.5;--f-button-svg-fill: none;--f-button-svg-filter: drop-shadow(1px 1px 1px rgba(24, 24, 27, 0.5));--f-button-svg-disabled-opacity: 0.65;--f-button-next-pos: 1rem;--f-button-prev-pos: 1rem;opacity:var(--fancybox-opacity, 1)}.fancybox__nav .f-button:before{position:absolute;content:"";top:-30px;right:-20px;left:-20px;bottom:-30px;z-index:1}.is-idle .fancybox__nav{animation:.15s ease-out both f-fadeOut}.is-idle.is-compact .fancybox__footer{pointer-events:none;animation:.15s ease-out both f-fadeOut}.fancybox__slide>.f-spinner{position:absolute;top:50%;left:50%;margin:var(--f-spinner-top, calc(var(--f-spinner-width) * -0.5)) 0 0 var(--f-spinner-left, calc(var(--f-spinner-height) * -0.5));z-index:30;cursor:pointer}.fancybox-protected{position:absolute;top:0;left:0;right:0;bottom:0;z-index:40;user-select:none}.fancybox-ghost{position:absolute;top:0;left:0;width:100%;height:100%;min-height:0;object-fit:contain;z-index:40;user-select:none;pointer-events:none}.fancybox-focus-guard{outline:none;opacity:0;position:fixed;pointer-events:none}.fancybox__container:not([aria-hidden]){opacity:0}.fancybox__container.is-animated[aria-hidden=false]>*:not(.fancybox__backdrop,.fancybox__carousel),.fancybox__container.is-animated[aria-hidden=false] .fancybox__carousel>*:not(.fancybox__viewport),.fancybox__container.is-animated[aria-hidden=false] .fancybox__slide>*:not(.fancybox__content){animation:var(--f-interface-enter-duration, 0.25s) ease .1s backwards f-fadeIn}.fancybox__container.is-animated[aria-hidden=false] .fancybox__backdrop{animation:var(--f-backdrop-enter-duration, 0.35s) ease backwards f-fadeIn}.fancybox__container.is-animated[aria-hidden=true]>*:not(.fancybox__backdrop,.fancybox__carousel),.fancybox__container.is-animated[aria-hidden=true] .fancybox__carousel>*:not(.fancybox__viewport),.fancybox__container.is-animated[aria-hidden=true] .fancybox__slide>*:not(.fancybox__content){animation:var(--f-interface-exit-duration, 0.15s) ease forwards f-fadeOut}.fancybox__container.is-animated[aria-hidden=true] .fancybox__backdrop{animation:var(--f-backdrop-exit-duration, 0.35s) ease forwards f-fadeOut}.has-iframe .fancybox__content,.has-map .fancybox__content,.has-pdf .fancybox__content,.has-youtube .fancybox__content,.has-vimeo .fancybox__content,.has-html5video .fancybox__content{max-width:100%;flex-shrink:1;min-height:1px;overflow:visible}.has-iframe .fancybox__content,.has-map .fancybox__content,.has-pdf .fancybox__content{width:calc(100% - 120px);height:90%}.fancybox__container.is-compact .has-iframe .fancybox__content,.fancybox__container.is-compact .has-map .fancybox__content,.fancybox__container.is-compact .has-pdf .fancybox__content{width:100%;height:100%}.has-youtube .fancybox__content,.has-vimeo .fancybox__content,.has-html5video .fancybox__content{width:960px;height:540px;max-width:100%;max-height:100%}.has-map .fancybox__content,.has-pdf .fancybox__content,.has-youtube .fancybox__content,.has-vimeo .fancybox__content,.has-html5video .fancybox__content{padding:0;background:rgba(24,24,27,.9);color:#fff}.has-map .fancybox__content{background:#e5e3df}.fancybox__html5video,.fancybox__iframe{border:0;display:block;height:100%;width:100%;background:rgba(0,0,0,0)}.fancybox-placeholder{border:0 !important;clip:rect(1px, 1px, 1px, 1px) !important;-webkit-clip-path:inset(50%) !important;clip-path:inset(50%) !important;height:1px !important;margin:-1px !important;overflow:hidden !important;padding:0 !important;position:absolute !important;width:1px !important;white-space:nowrap !important}.f-carousel__thumbs{--f-thumb-width: 96px;--f-thumb-height: 72px;--f-thumb-outline: 0;--f-thumb-outline-color: #5eb0ef;--f-thumb-opacity: 1;--f-thumb-hover-opacity: 1;--f-thumb-selected-opacity: 1;--f-thumb-border-radius: 2px;--f-thumb-offset: 0px;--f-button-next-pos: 0;--f-button-prev-pos: 0}.f-carousel__thumbs.is-classic{--f-thumb-gap: 8px;--f-thumb-opacity: 0.5;--f-thumb-hover-opacity: 1;--f-thumb-selected-opacity: 1}.f-carousel__thumbs.is-modern{--f-thumb-gap: 4px;--f-thumb-extra-gap: 16px;--f-thumb-clip-width: 46px}.f-thumbs{position:relative;flex:0 0 auto;margin:0;overflow:hidden;-webkit-tap-highlight-color:rgba(0,0,0,0);user-select:none;perspective:1000px;transform:translateZ(0)}.f-thumbs .f-spinner{position:absolute;top:0;left:0;width:100%;height:100%;border-radius:2px;background-image:linear-gradient(#ebeff2, #e2e8f0);z-index:-1}.f-thumbs .f-spinner svg{display:none}.f-thumbs.is-vertical{height:100%}.f-thumbs__viewport{width:100%;height:auto;overflow:hidden;transform:translate3d(0, 0, 0)}.f-thumbs__track{display:flex}.f-thumbs__slide{position:relative;flex:0 0 auto;box-sizing:content-box;display:flex;align-items:center;justify-content:center;padding:0;margin:0;width:var(--f-thumb-width);height:var(--f-thumb-height);overflow:visible;cursor:pointer}.f-thumbs__slide.is-loading img{opacity:0}.is-classic .f-thumbs__viewport{height:100%}.is-modern .f-thumbs__track{width:max-content}.is-modern .f-thumbs__track::before{content:"";position:absolute;top:0;bottom:0;left:calc((var(--f-thumb-clip-width, 0))*-0.5);width:calc(var(--width, 0)*1px + var(--f-thumb-clip-width, 0));cursor:pointer}.is-modern .f-thumbs__slide{width:var(--f-thumb-clip-width);transform:translate3d(calc(var(--shift, 0) * -1px), 0, 0);transition:none;pointer-events:none}.is-modern.is-resting .f-thumbs__slide{transition:transform .33s ease}.is-modern.is-resting .f-thumbs__slide__button{transition:clip-path .33s ease}.is-using-tab .is-modern .f-thumbs__slide:focus-within{filter:drop-shadow(-1px 0px 0px var(--f-thumb-outline-color)) drop-shadow(2px 0px 0px var(--f-thumb-outline-color)) drop-shadow(0px -1px 0px var(--f-thumb-outline-color)) drop-shadow(0px 2px 0px var(--f-thumb-outline-color))}.f-thumbs__slide__button{appearance:none;width:var(--f-thumb-width);height:100%;margin:0 -100% 0 -100%;padding:0;border:0;position:relative;border-radius:var(--f-thumb-border-radius);overflow:hidden;background:rgba(0,0,0,0);outline:none;cursor:pointer;pointer-events:auto;touch-action:manipulation;opacity:var(--f-thumb-opacity);transition:opacity .2s ease}.f-thumbs__slide__button:hover{opacity:var(--f-thumb-hover-opacity)}.f-thumbs__slide__button:focus:not(:focus-visible){outline:none}.f-thumbs__slide__button:focus-visible{outline:none;opacity:var(--f-thumb-selected-opacity)}.is-modern .f-thumbs__slide__button{--clip-path: inset( 0 calc( ((var(--f-thumb-width, 0) - var(--f-thumb-clip-width, 0))) * (1 - var(--progress, 0)) * 0.5 ) round var(--f-thumb-border-radius, 0) );clip-path:var(--clip-path)}.is-classic .is-nav-selected .f-thumbs__slide__button{opacity:var(--f-thumb-selected-opacity)}.is-classic .is-nav-selected .f-thumbs__slide__button::after{content:"";position:absolute;top:0;left:0;right:0;height:auto;bottom:0;border:var(--f-thumb-outline, 0) solid var(--f-thumb-outline-color, transparent);border-radius:var(--f-thumb-border-radius);animation:f-fadeIn .2s ease-out;z-index:10}.f-thumbs__slide__img{overflow:hidden;position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;margin:0;padding:var(--f-thumb-offset);box-sizing:border-box;pointer-events:none;object-fit:cover;border-radius:var(--f-thumb-border-radius)}.f-thumbs.is-horizontal .f-thumbs__track{padding:8px 0 12px 0}.f-thumbs.is-horizontal .f-thumbs__slide{margin:0 var(--f-thumb-gap) 0 0}.f-thumbs.is-vertical .f-thumbs__track{flex-wrap:wrap;padding:0 8px}.f-thumbs.is-vertical .f-thumbs__slide{margin:0 0 var(--f-thumb-gap) 0}.fancybox__thumbs{--f-thumb-width: 96px;--f-thumb-height: 72px;--f-thumb-border-radius: 2px;--f-thumb-outline: 2px;--f-thumb-outline-color: #ededed;position:relative;opacity:var(--fancybox-opacity, 1);transition:max-height .35s cubic-bezier(0.23, 1, 0.32, 1)}.fancybox__thumbs.is-classic{--f-thumb-gap: 8px;--f-thumb-opacity: 0.5;--f-thumb-hover-opacity: 1}.fancybox__thumbs.is-classic .f-spinner{background-image:linear-gradient(rgba(255, 255, 255, 0.1), rgba(255, 255, 255, 0.05))}.fancybox__thumbs.is-modern{--f-thumb-gap: 4px;--f-thumb-extra-gap: 16px;--f-thumb-clip-width: 46px;--f-thumb-opacity: 1;--f-thumb-hover-opacity: 1}.fancybox__thumbs.is-modern .f-spinner{background-image:linear-gradient(rgba(255, 255, 255, 0.1), rgba(255, 255, 255, 0.05))}.fancybox__thumbs.is-horizontal{padding:0 var(--f-thumb-gap)}.fancybox__thumbs.is-vertical{padding:var(--f-thumb-gap) 0}.is-compact .fancybox__thumbs{--f-thumb-width: 64px;--f-thumb-clip-width: 32px;--f-thumb-height: 48px;--f-thumb-extra-gap: 10px}.fancybox__thumbs.is-masked{max-height:0px !important}.is-closing .fancybox__thumbs{transition:none !important}.fancybox__toolbar{--f-progress-color: var(--fancybox-color, rgba(255, 255, 255, 0.94));--f-button-width: 46px;--f-button-height: 46px;--f-button-color: var(--fancybox-color);--f-button-hover-color: var(--fancybox-hover-color);--f-button-bg: rgba(24, 24, 27, 0.65);--f-button-hover-bg: rgba(70, 70, 73, 0.65);--f-button-active-bg: rgba(90, 90, 93, 0.65);--f-button-border-radius: 0;--f-button-svg-width: 24px;--f-button-svg-height: 24px;--f-button-svg-stroke-width: 1.5;--f-button-svg-filter: drop-shadow(1px 1px 1px rgba(24, 24, 27, 0.15));--f-button-svg-fill: none;--f-button-svg-disabled-opacity: 0.65;display:flex;flex-direction:row;justify-content:space-between;margin:0;padding:0;font-family:-apple-system,BlinkMacSystemFont,"Segoe UI Adjusted","Segoe UI","Liberation Sans",sans-serif;color:var(--fancybox-color, currentColor);opacity:var(--fancybox-opacity, 1);text-shadow:var(--fancybox-toolbar-text-shadow, 1px 1px 1px rgba(0, 0, 0, 0.5));pointer-events:none;z-index:20}.fancybox__toolbar :focus-visible{z-index:1}.fancybox__toolbar.is-absolute,.is-compact .fancybox__toolbar{position:absolute;top:0;left:0;right:0}.is-idle .fancybox__toolbar{pointer-events:none;animation:.15s ease-out both f-fadeOut}.fancybox__toolbar__column{display:flex;flex-direction:row;flex-wrap:wrap;align-content:flex-start}.fancybox__toolbar__column.is-left,.fancybox__toolbar__column.is-right{flex-grow:1;flex-basis:0}.fancybox__toolbar__column.is-right{display:flex;justify-content:flex-end;flex-wrap:nowrap}.fancybox__infobar{padding:0 5px;line-height:var(--f-button-height);text-align:center;font-size:17px;font-variant-numeric:tabular-nums;-webkit-font-smoothing:subpixel-antialiased;cursor:default;user-select:none}.fancybox__infobar span{padding:0 5px}.fancybox__infobar:not(:first-child):not(:last-child){background:var(--f-button-bg)}[data-fancybox-toggle-slideshow]{position:relative}[data-fancybox-toggle-slideshow] .f-progress{height:100%;opacity:.3}[data-fancybox-toggle-slideshow] svg g:first-child{display:flex}[data-fancybox-toggle-slideshow] svg g:last-child{display:none}.has-slideshow [data-fancybox-toggle-slideshow] svg g:first-child{display:none}.has-slideshow [data-fancybox-toggle-slideshow] svg g:last-child{display:flex}[data-fancybox-toggle-fullscreen] svg g:first-child{display:flex}[data-fancybox-toggle-fullscreen] svg g:last-child{display:none}:fullscreen [data-fancybox-toggle-fullscreen] svg g:first-child{display:none}:fullscreen [data-fancybox-toggle-fullscreen] svg g:last-child{display:flex}.f-progress{position:absolute;top:0;left:0;right:0;height:3px;transform:scaleX(0);transform-origin:0;transition-property:transform;transition-timing-function:linear;background:var(--f-progress-color, var(--f-carousel-theme-color, #0091ff));z-index:30;user-select:none;pointer-events:none}
/**
 * fancybox - modals
**************************/
.f-button.is-close-btn {
  --ring-offset-width: 0px;
  --ring-inset: inset;
  --ring-width: 2px;
}

/**
 * fancybox - custom animations
**************************/
.fancybox-slideInRight {
	animation: .25s cubic-bezier(0.25, 0.75, 0.15, 1) both fancybox-slideInRight;
}

.fancybox-slideOutRight {
	animation: .15s cubic-bezier(0.25, 0.75, 0.15, 1) both fancybox-slideOutRight;
}

@keyframes fancybox-slideInRight {
	from {
		transform: translate3d(100%, 0, 0);
		opacity: 0;
	}

	to {
		transform: translate3d(0, 0, 0);
		opacity: 1;
	}
}

@keyframes fancybox-slideOutRight {
	to {
		transform: translate3d(100%, 0, 0);
		opacity: 0;
	}
}

.fancybox-slideInLeft {
	animation: .25s cubic-bezier(0.25, 0.75, 0.15, 1) both fancybox-slideInLeft;
}

.fancybox-slideOutLeft {
	animation: .15s cubic-bezier(0.25, 0.75, 0.15, 1) both fancybox-slideOutLeft;
}

@keyframes fancybox-slideInLeft {
	from {
		transform: translate3d(-100%, 0, 0);
		opacity: 0;
	}

	to {
		transform: translate3d(0, 0, 0);
		opacity: 1;
	}
}

@keyframes fancybox-slideOutLeft {
	to {
		transform: translate3d(-100%, 0, 0);
		opacity: 0;
	}
}

/**
 * fancybox - variables
**************************/
.fancybox__container {
	--fancybox-bg: rgba(0, 0, 0, 0.65);

	--fancybox-content-bg: rgb(0, 0, 0);
	--fancybox-content-color: ;
}

.fancybox__content a {
	color: #d6d602;
}

/**
 * fancybox - slideshow
**************************/
.fb__kookaburra {
	--fancybox-bg: rgb(0, 0, 0);
	--f-progress-color: var(--fancybox-color, rgba(255, 255, 255, 0.94));
	--f-transition-duration: 1000ms;

	--f-button-height: 48px;
	--f-button-width: 48px;
	--f-button-svg-height: 24px;
	--f-button-svg-width: 24px;
}

.fb__kookaburra .f-button:focus-visible {
  --ring-offset-width: 0px;
  --ring-inset: inset;
  --ring-width: 2px;
}

.fancybox__cols {
	--right-col-width: clamp(150px, 20vw, 300px);

	display: grid;
	grid-template-columns: minmax(0, 1fr) 0;
	height: 100vh;
	transition: all 0.35s cubic-bezier(0.23, 1, 0.32, 1);
}

.has-sidebar .fancybox__cols {
	grid-template-columns: minmax(0, 1fr) 0;
}

.open-sidebar .fancybox__cols {
	grid-template-columns: minmax(0, 1fr) var(--right-col-width);
}

.fancybox__col {
	display: flex;
	flex-direction: column;
	min-height: 0;

	overflow: hidden;
	position: relative;
}

.fancybox__data {
	height: 100%;
	overflow: auto;
	padding: 1rem;
	width: var(--right-col-width);
}

.fb__kookaburra .fancybox__toolbar {
	--f-button-height: 48px;
	--f-button-width: 48px;
	--f-button-svg-height: 20px;
	--f-button-svg-width: 20px;

	--f-button-bg: transparent;
	--f-button-color: rgb(255, 255, 255);
	--f-button-hover-bg: rgb(122, 122, 122);
	--f-button-hover-color: var(--f-button-color);

	--f-progress-color: var(--f-button-color);

	--f-button-active-bg: rgba(228, 228, 228, 0.49);
	--f-button-svg-filter: none;
	--f-button-svg-disabled-opacity: 0.35;
	--f-button-svg-stroke-width: 2;

	background-color: rgba(255, 255, 255, 0);
	color: rgb(255, 255, 255);
	padding: 0;
}

.fancybox__cols {
	height: calc(100vh - var(--f-button-height)); // minus toolbar height
}

.fb__kookaburra .fancybox__toolbar {
	position: relative;
}

.fb__kookaburra.is-idle .fancybox__toolbar {
	animation: none;
	pointer-events: auto;
}

.fancybox__infobar {
	font-size: 0.75rem;
	padding: 0 6px;
}

.fb__kookaburra .fancybox__slide {
	padding: 9px;
}

.fb__kookaburra .is-modern .f-thumbs__slide:focus-within:not(.is-selected),
.fb__kookaburra.is-using-tab .is-modern .f-thumbs__slide:focus-within {
}

.fb__kookaburra .f-thumbs.is-horizontal .f-thumbs__track {
  padding: 4px 0 4px;
}

.fb__kookaburra .fancybox__thumbs {
	--f-thumb-outline-color: var(--ring-color);
  --f-thumb-outline-color: #fff;
}

.fb_toggle-caption-button {
	align-items: center;
	display: flex;
	height: 18px;
	justify-content: center;
	opacity: 0.25;
	position: absolute;
	right: -18px;
	transition: opacity 0.2s ease-in-out;
	vertical-align: middle;
	width: 18px;
}

.collapsed .fb_toggle-caption-button {
	height: var(--f-button-height);
	top: 0;
}

.fancybox__caption:hover .fb_toggle-caption-button {
	opacity: 1;
}

.fb_toggle-caption-button svg {
	height: 16px;
	width: 16px;
}

.fb_toggle-caption-button g:nth-child(1) {
	display: block;
}      

.fb_toggle-caption-button g:nth-child(2) {
	display: none;
}

.collapsed .fb_toggle-caption-button g:nth-child(1) {
	display: none;
}      

.collapsed .fb_toggle-caption-button g:nth-child(2) {
	display: block;
}


.fb__kookaburra .fancybox__caption > div > div:nth-child(1) {
	font-size: 1rem;
	font-weight: 400;
	line-height: 1.5em;
	margin-top: calc((1.5em - 1rem) / 2);
	margin-bottom: calc((1.5em - 1rem) / 2);
}

.fb__kookaburra .fancybox__caption > div > div:nth-child(2) {
	font-size: 1rem;
	font-weight: 400;
	line-height: 1.5em;
	margin-top: calc((1.5em - 1rem) / 2);
	margin-bottom: calc((1.5em - 1rem) / 2);
}

.fb__kookaburra .fancybox__caption {
	--caption-width: 2000px;

	align-items: center;
	color: #d9d8d8;
	cursor: pointer;
	display: flex;
	flex-direction: column;
	justify-content: center;
	margin: 0 auto;
	max-width: 100%;
	min-height: var(--f-button-height);
	overflow: hidden;
	padding: 6px 18px;
	position: relative;
	transition: height 0.15s ease-in-out;
	width: var(--caption-width);
}

.fb__kookaburra .fancybox__caption > div {
	max-width: 100%;
	position: relative;
	text-align: center;
	width: 100%;
}

.fb__kookaburra .fancybox__caption > div:empty {
	display: none;
}

.fb__kookaburra .fancybox__caption.collapsed {
	height: var(--f-button-height);
	justify-content: flex-start;
	padding-top: 0;
	padding-bottom: 0;
}

.fb__kookaburra .fancybox__caption.collapsed > div > div {
	line-height: var(--f-button-height);
	margin-top: 0;
	margin-bottom: 0;
	max-width: 100%;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}

.fb__kookaburra .fancybox__caption.collapsed > div > div:nth-child(2) {
	height: 0;
	opacity: 0;
	transition: height 0.15s ease-in-out, opacity 0.15s ease-in-out;
}

.fb__kookaburra .fancybox__caption {
			margin-top: 0;
			margin-bottom: 0;
		}


			.fb__kookaburra .fancybox__footer {
				background-color: transparent;
			}
			.fb__kookaburra .fancybox__footer .fancybox__caption {
				margin-top: 0;
				margin-bottom: 0;
			}
		
/**
** reset
**************************/
*,
*::before,
*::after {
	box-sizing: border-box;
}

/* Fix mobile Safari increase font-size on landscape mode */
html {
	-moz-text-size-adjust: none;
	-webkit-text-size-adjust: none;
	text-size-adjust: none;
}

/* Remove list styles (bullets/numbers) */
ol, ul, menu, summary {
	list-style: none;
	margin: 0;
	padding: 0;
}

/* For images to not be able to exceed their container */
img {
	max-inline-size: 100%;
	max-block-size: 100%;
}

/* Safari - solving issue when using user-select:none on the <body> text input doesn't working */
input, textarea {
	-webkit-user-select: auto;
}

/**
** document
**************************/
html {
	background-color: var(--backsplash);
	color: #000000;
	font-family: Helvetica, Roboto, Arial, 'Segoe UI', 'Droid Sans', sans-serif;
	font-size: 1em;
	height: 100%;
}

body {
	height: 100%;
	overscroll-behavior-y: contain;
	position: relative;
}

.page-wrapper {
	display: flex;
	flex-direction: column;
	min-height: 100%;
	padding: 15px;
}

.page {
	--pageBackgroundColor: var(--backgroundColor);

	background-color: var(--color-base);
	border-radius: 4px 4px 3px 3px;
	contain: paint;
	display: flex;
	flex: 1 0 auto;
	flex-direction: column;
	position: relative;
}

.page-layout {
	box-sizing: border-box;
	display: flex;
	flex-direction: column;
	flex: 1 0 auto;
	margin: 0 auto;
	position: relative;
	width: 100%;
}

/**
** layout
**************************/
.page {
	margin: 0 auto;
	max-width: 1000px;
	position: relative;
	width: 100%;
	z-index: 0;
}

.page-layout {
	margin-top: 0;
	margin-right: auto;
	margin-bottom: 0;
	margin-left: auto;
	max-width: 1000px;
	position: relative;
	width: 100%;
}

/**
** images
**************************/
figure {
	margin: 0;
}

img {
	display: inline-block;
	height: auto;
	max-width: 100%;
	vertical-align: middle;
}

svg {
	display: inline-block;
	font-size: 0;
	vertical-align: middle;
}

use {
	fill: none;
	stroke: currentColor;
	stroke-linecap: round;
	stroke-linejoin: round;
	stroke-width: 2;
}

/* fix for SVG fill in Firefox */
symbol#polaroid {
	fill: currentColor;
}

circle, ellipse, line, path, polygon, polyline, rect, symbol, svg, use {
	pointer-events: none;
	user-select: none;
}

.pulse {
	-webkit-animation: spin 1s infinite steps(8);
					animation: spin 1s infinite steps(8);
}

.spin {
	-webkit-animation: spin 2s infinite linear;
					animation: spin 2s infinite linear;
}

@-webkit-keyframes spin {
	0% {
		-webkit-transform: rotate(0deg);
						transform: rotate(0deg);
	}
	100% {
		-webkit-transform: rotate(360deg);
						transform: rotate(360deg);
	}
}

@keyframes spin {
	0% {
		-webkit-transform: rotate(0deg);
						transform: rotate(0deg);
	}
	100% {
		-webkit-transform: rotate(360deg);
						transform: rotate(360deg);
	}
}

/**
** global
**************************/
a {
	color: var(--color-interactive);
	cursor: pointer;
	text-decoration: none;
}

a:hover {
	color: ;
	text-decoration: underline;
}

button {
	background: transparent;
	border: none;
	cursor: pointer;
}

b, strong {
	font-weight: bold;
}

cite, em, i {
	font-style: italic;
}

/**
** forms
**************************/

form button,
form .button,
form input[type="button"],
form input[type="submit"],
form input[type="reset"],
.form button,
.form .button,
.form input[type="button"],
.form input[type="submit"],
.form input[type="reset"]

{
	background-color: var(--color-contrast);
	border: none;
	border-radius: 4px;
	color: var(--color-base);
	cursor: pointer;
	font-size: 0.875rem;
	line-height: 32px;
	padding: 0 12px;
	vertical-align: top;
}

form button:hover,
form .button:hover,
form input[type="button"]:hover,
form input[type="submit"]:hover,
form input[type="reset"]:hover,
.form button:hover,
.form .button:hover,
.form input[type="button"]:hover,
.form input[type="submit"]:hover,
.form input[type="reset"]:hover

{
	background-color: var(--color-contrast);
}

form,
.form {
	display: block;
	margin : 1.5rem 0;
}

fieldset {
	border: none;
	display: contents;
	margin: 0;
}

legend {
	display: block;
	font-size: 0.75rem;
}

form p,
.form p {
	margin: 1rem 0;
}

.denotes-required-fields,
.google-recaptcha-privacy-and-terms-text {
	font-size: 0.75rem;
	line-height: 1.5em;
	margin: 1.5em 0;
}

form label,
.form label {
	font-size: 0.875rem;
	font-weight: 600;
	line-height: 1.5rem;
}

form label[for],
.form label[for] {
	cursor: pointer;
}

form input[type="color"],
form input[type="date"],
form input[type="datetime"],
form input[type="datetime-local"],
form input[type="email"],
form input[type="month"],
form input[type="number"],
form input[type="password"],
form input[type="search"],
form input[type="tel"],
form input[type="text"],
form input[type="time"],
form input[type="url"],
form input[type="week"],
form input:not([type]),
form select,
form textarea,

.form input[type="color"],
.form input[type="date"],
.form input[type="datetime"],
.form input[type="datetime-local"],
.form input[type="email"],
.form input[type="month"],
.form input[type="number"],
.form input[type="password"],
.form input[type="search"],
.form input[type="tel"],
.form input[type="text"],
.form input[type="time"],
.form input[type="url"],
.form input[type="week"],
.form input:not([type]),
.form select,
.form textarea

{
	background-color: var(--color-base);
	border: 1px solid var(--color-contrast);
	border-radius: 4px;
	color: var(--color-contrast);
	display: inline-block;
	font-size: 0.875rem;
	opacity: 0.9;
	padding: 0.5rem 0.75rem;
	vertical-align: middle;
	width: 100%; max-width: 394px;
}

form textarea, .form textarea {
	max-width: 768px;
}

form input[type="color"]:focus-visible,
form input[type="date"]:focus-visible,
form input[type="datetime"]:focus-visible,
form input[type="datetime-local"]:focus-visible,
form input[type="email"]:focus-visible,
form input[type="month"]:focus-visible,
form input[type="number"]:focus-visible,
form input[type="password"]:focus-visible,
form input[type="search"]:focus-visible,
form input[type="tel"]:focus-visible,
form input[type="text"]:focus-visible,
form input[type="time"]:focus-visible,
form input[type="url"]:focus-visible,
form input[type="week"]:focus-visible,
form input:not([type]):focus-visible,
form select:focus-visible,
form textarea:focus-visible,

.form input[type="color"]:focus-visible,
.form input[type="date"]:focus-visible,
.form input[type="datetime"]:focus-visible,
.form input[type="datetime-local"]:focus-visible,
.form input[type="email"]:focus-visible,
.form input[type="month"]:focus-visible,
.form input[type="number"]:focus-visible,
.form input[type="password"]:focus-visible,
.form input[type="search"]:focus-visible,
.form input[type="tel"]:focus-visible,
.form input[type="text"]:focus-visible,
.form input[type="time"]:focus-visible,
.form input[type="url"]:focus-visible,
.form input[type="week"]:focus-visible,
.form input:not([type]):focus-visible,
.form select:focus-visible,
.form textarea:focus-visible

{
	border-color: transparent;
	box-shadow: 0px 0px 0px 2px var(--color-contrast);
	opacity: 1;
}

form input[type="color"][disabled],
form input[type="date"][disabled],
form input[type="datetime"][disabled],
form input[type="datetime-local"][disabled],
form input[type="email"][disabled],
form input[type="month"][disabled],
form input[type="number"][disabled],
form input[type="password"][disabled],
form input[type="search"][disabled],
form input[type="tel"][disabled],
form input[type="text"][disabled],
form input[type="time"][disabled],
form input[type="url"][disabled],
form input[type="week"][disabled],
form input:not([type])[disabled],
form select[disabled],
form textarea[disabled],

.form input[type="color"][disabled],
.form input[type="date"][disabled],
.form input[type="datetime"][disabled],
.form input[type="datetime-local"][disabled],
.form input[type="email"][disabled],
.form input[type="month"][disabled],
.form input[type="number"][disabled],
.form input[type="password"][disabled],
.form input[type="search"][disabled],
.form input[type="tel"][disabled],
.form input[type="text"][disabled],
.form input[type="time"][disabled],
.form input[type="url"][disabled],
.form input[type="week"][disabled],
.form input:not([type])[disabled],
.form select[disabled],
.form textarea[disabled]

{
	background-color: #eaeded;
	color: #cad2d3;
	cursor: not-allowed;
}

form input[readonly],
form select[readonly],
form textarea[readonly],

.form input[readonly],
.form select[readonly],
.form textarea[readonly]

{
	background-color: #eee;
	border-color: #ccc;
	color: #777;
}

form label + input[type="color"],
form label + input[type="date"],
form label + input[type="datetime"],
form label + input[type="datetime-local"],
form label + input[type="email"],
form label + input[type="month"],
form label + input[type="number"],
form label + input[type="password"],
form label + input[type="search"],
form label + input[type="tel"],
form label + input[type="text"],
form label + input[type="time"],
form label + input[type="url"],
form label + input[type="week"],
form label + input:not([type]),
form label + select,
form label + textarea,

.form label + input[type="color"],
.form label + input[type="date"],
.form label + input[type="datetime"],
.form label + input[type="datetime-local"],
.form label + input[type="email"],
.form label + input[type="month"],
.form label + input[type="number"],
.form label + input[type="password"],
.form label + input[type="search"],
.form label + input[type="tel"],
.form label + input[type="text"],
.form label + input[type="time"],
.form label + input[type="url"],
.form label + input[type="week"],
.form label + input:not([type]),
.form label + select,
.form label + textarea

{
	display: block;
}

input[type="hidden"] {
	display: none;
}

form select, .form select {
	/* Normalizes the height; padding is not sufficient. */
	background-color: var(--color-base);
	border: 1px solid var(--color-contrast);
	color: var(--color-contrast);
	display: block;
	height: 2rem;
	line-height: 2rem;
	padding: initial;
	padding: 0 12px;
	/*
	-webkit-appearance: none;
	*/
	-webkit-border-radius: 4px;
}

form select[multiple],
.form select[multiple] {
	height: auto;
}

form input[type="checkbox"], .form input[type="checkbox"],
form input[type="radio"], .form input[type="radio"]
{
	clip: rect(1px, 1px, 1px, 1px);
	height: 1px;
	overflow: hidden;
	position: absolute;
	width: 1px;
}

form input[type="checkbox"] + label, .form input[type="checkbox"] + label,
form input[type="radio"] + label, .form input[type="radio"] + label
{
	align-items: center;
	cursor: pointer;
	display: flex;
	user-select: none;
}

form input[type="checkbox"]:focus-visible + label, .form input[type="checkbox"]:focus-visible + label,
form input[type="radio"]:focus-visible + label, .form input[type="radio"]:focus-visible + label
{
	box-shadow:
	var(--ring-offset-inset) 0px 0px 0px var(--ring-offset-width) var(--ring-offset-color),
		var(--ring-inset) 0px 0px var(--ring-blur) var(--ring-width) var(--ring-color)
	;
	outline: none;
}

form input[type="checkbox"] + label::before, .form input[type="checkbox"] + label::before,
form input[type="radio"] + label::before, .form input[type="radio"] + label::before
{
	background-color: var(--color-contrast);
	content: "";
	display: inline-block;
	flex: 0 0 auto;
	height: 18px;
	line-height: 0;
	margin-right: 9px;
	width: 18px;
}

form input[type="checkbox"] + label::before, .form input[type="checkbox"] + label::before
{
	-webkit-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='18' height='18' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect x='3' y='3' width='18' height='18' rx='2' ry='2'%3E%3C/rect%3E%3C/svg%3E");
	mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='18' height='18' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect x='3' y='3' width='18' height='18' rx='2' ry='2'%3E%3C/rect%3E%3C/svg%3E");
}

form input[type="checkbox"]:checked + label::before, .form input[type="checkbox"]:checked + label::before
{
	-webkit-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='18' height='18' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='9 11 12 14 22 4'%3E%3C/polyline%3E%3Cpath d='M21 12v7a2 2 0 0 1-2 2H5a2 2 0 0 1-2-2V5a2 2 0 0 1 2-2h11'%3E%3C/path%3E%3C/svg%3E");
	mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='18' height='18' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='9 11 12 14 22 4'%3E%3C/polyline%3E%3Cpath d='M21 12v7a2 2 0 0 1-2 2H5a2 2 0 0 1-2-2V5a2 2 0 0 1 2-2h11'%3E%3C/path%3E%3C/svg%3E");
}

form input[type="radio"] + label::before, .form input[type="radio"] + label::before
{
	-webkit-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='18' height='18' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='12' cy='12' r='10'%3E%3C/circle%3E%3C/svg%3E");
	mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='18' height='18' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='12' cy='12' r='10'%3E%3C/circle%3E%3C/svg%3E");
}

form input[type="radio"]:checked + label::before, .form input[type="radio"]:checked + label::before
{
	-webkit-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='18' height='18' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M22 11.08V12a10 10 0 1 1-5.93-9.14'%3E%3C/path%3E%3Cpolyline points='22 4 12 14.01 9 11.01'%3E%3C/polyline%3E%3C/svg%3E");
	mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='18' height='18' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M22 11.08V12a10 10 0 1 1-5.93-9.14'%3E%3C/path%3E%3Cpolyline points='22 4 12 14.01 9 11.01'%3E%3C/polyline%3E%3C/svg%3E");
}

/**
** running-head
**************************/

.running-head {
	--backgroundColor: #ff0000;
	--ring-offset-color: var(--backgroundColor);

	background-color: var(--backgroundColor);
	border-color: #008000;
	border-style: solid;
	border-width: 0;
	height: 0;
	max-width: 1000px;
	position: sticky;
	top: 0;
	width: 100%;
	z-index: 2;
}

.running-head > div:first-child {
	align-items: center;
	display: flex;
	gap: 14px;
	height: 48px;
	justify-content: space-between;
	margin-top: 0;
	margin-right: auto;
	margin-bottom: 0;
	margin-left: auto;
	max-width: 100%;
	min-width: 0;
	padding: 0 14px;
	position: relative;
	width: 100%;
}

	.running-head {
		border-width: 1px 0 1px;
		height: auto;
	}

.running-head-title {
	--ring-offset-width: 3px;
	--ring-width: 5px;
	
	align-items: center;
	color: var(--color-contrast);
	display: flex;
	flex: 1 1 auto;
	font-family: inherit;
	font-size: 1.25rem; 
	font-weight: 700;
	line-height: 1em;
	min-width: 0;
	text-transform: none;
}

a.running-head-title:focus,
a.running-head-title:hover {
	color: var(--color-contrast);
	text-decoration: none;
}

.running-head-title img {
	max-height: 48px;
	width: auto;
}

.running-head-title span {
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}

@media screen and ( max-width: 375px ) {
	.running-head-title {
		display: flex;
	}
}

.running-head-navigation {
	align-items: center;
	display: flex;
	flex: 0 0 auto;
	justify-content: flex-end;
}

.running-head-button {
	--ring-inset: inset;
	--ring-width: 2px;

	background-color: transparent;
	color: var(--color-contrast);
	height: 44px;
	text-align: center;
	width: 44px;
}

.running-head-button:focus-visible,
.running-head-button:hover {
	background-color: transparent;
	color: var(--color-contrast);
}


/**
** navigation
 * https://moderncss.dev/css-only-accessible-dropdown-navigation-menu/
**************************/
@media screen and ( min-width: 1141px ) {
	.gate--nav:has(.main-navigation) {
		--prevBackgroundColor: var(--backgroundColor);

		display: contents;
	}

	.main-navigation .nav--interior {
		--backgroundColor: rgb(154, 150, 150);
		--ring-offset-color: var(--backgroundColor);

		align-items: center;
		background-color: var(--backgroundColor);
		border-color: var(--color-base-offset);
		border-style: solid;
		border-width: 0px 0 0px;
		display: flex !important;
		flex: 0 0 auto;
		font-family: inherit;
		font-size: 14px;
		justify-content: flex-end;
		margin: 0px 0 0;
		padding: 0px 18px 0px;
		position: relative;
		width: 100%;
		z-index: 1;

		right: -9px	}
	
	.main-navigation.preload * {
		transition: none !important;
	}
	
	.main-navigation .nav--interior > ul {
		display: grid;
		grid-auto-flow: column;
		line-height: 1.25rem;
		margin: 0;
		position: relative;
		user-select: none;
	}
	
	.main-navigation .nav--interior > ul > li {
		margin-right: 6px;
		position: relative;
		white-space: nowrap;
		z-index: 1;
	}

	.main-navigation .nav--interior > ul > li > a,
	.main-navigation .nav--interior > ul > li > button,
	.main-navigation .nav--interior > ul > li > span {
		align-items: center;
		box-shadow: none !important;
		display: flex;
		font-weight: 400;
		line-height: 1.25rem;
		margin: 0;
		outline: none;
		padding: 0;
		text-decoration: none;
	}

	.main-navigation .nav--interior > ul > li > a,
	.main-navigation .nav--interior > ul > li > button,
	.main-navigation .nav--interior > ul > li > span span {
		padding: 0px 6px 0px;
	}

	.main-navigation .nav--interior > ul > li.drop-item,
	.main-navigation .nav--interior > ul > li:last-child {
		margin-right: 0;
	}

	.main-navigation .nav--interior > ul > li.drop-trigger {
		width: 0;
	}

	.main-navigation .nav--interior > ul > li.drop-trigger button {
		transform: translate(-100%);
	}

	.main-navigation .nav--interior > ul > li.drop-item > span {
		opacity: 0;
	}

	.main-navigation .nav--interior > ul > li.drop-item > span a,
	.main-navigation .nav--interior > ul > li.drop-item > span span {
		padding-right: 0;
	}

	.main-navigation .nav--interior > ul > li.drop-item {
		margin-right: 25px;
		z-index: 2;
	}

	.main-navigation .nav--interior > ul > li.drop-trigger > button {
		padding-right: 25px;
	}

	.main-navigation .nav--interior > ul > li.drop-trigger button::after {
		border-top: 5px solid var(--color-contrast);
		border-right: 5px solid transparent;
		border-left: 5px solid transparent;
		content: "";
		display: inline-block;
		margin: 0 6px 0 0;
		position: absolute;
		right: 0;
		width: 0;
	}

	.main-navigation .nav--interior > ul ul {
		background-color: rgb(122, 122, 122);
		border-radius: 4px;
		filter: drop-shadow(0 3px 2px rgba(0, 0, 0, 0.25));
		left: 50%;
		margin-left: -10px;
		opacity: 0.1;
		padding: 7px 0;
		position: absolute;
		text-align: center;
		top: calc(1.25rem + 0px + 0px);
		transform: rotateX(-90deg) translateX(-50%);
		transform-origin: top center;
		transition: 0.25s opacity ease-out, 0.25s transform ease-out, 0.25s visibility ease-out;
		visibility: hidden;
		width: 192px;
	}

	.main-navigation .nav--interior > ul > li.drop-item:hover + li.drop-trigger > ul,
	.main-navigation .nav--interior > ul > li.drop-trigger:focus-within > ul,
	.main-navigation .nav--interior > ul > li.drop-trigger:hover > ul {
		opacity: 1;
		text-align: left;
		transform: rotateX(0) translateX(-50%);
		visibility: visible;
	}
	
	.main-navigation .nav--interior > ul ul::after {
		border-right: 5px solid transparent;
		border-bottom: 5px solid rgb(122, 122, 122);
		border-left: 5px solid transparent;
		content: "";
		display: block;
		left: 50%;
		margin-left: -5px;
		position: absolute;
		top: -5px;
	}

	.main-navigation,
	.main-navigation a,
	.main-navigation button {
		color: var(--color-contrast);
	}
	
	.main-navigation .nav--interior > ul > li:not(.drop-item),
	.main-navigation .nav--interior > ul > li.drop-item + li.drop-trigger button {
		background-color: rgb(154, 150, 150);
		border-radius: 1px;
	}
	
	.main-navigation .nav--interior > ul > li:not(.drop-item):focus-within,
	.main-navigation .nav--interior > ul > li:not(.drop-item):hover,
	.main-navigation .nav--interior > ul > li.drop-item:focus-within + li.drop-trigger button,
	.main-navigation .nav--interior > ul > li.drop-item:hover + li.drop-trigger button,
	.main-navigation .nav--interior > ul > li.drop-item + li.drop-trigger:focus-within button,
	.main-navigation .nav--interior > ul > li.drop-item + li.drop-trigger:hover button {
		background-color: var(--color-contrast);
	}
	
	.main-navigation .nav--interior > ul > li.drop-item:focus-within + li.drop-trigger button,
	.main-navigation .nav--interior > ul > li.drop-item:hover + li.drop-trigger button,
	.main-navigation .nav--interior > ul > li:focus-within > a,
	.main-navigation .nav--interior > ul > li:hover > a,
	.main-navigation .nav--interior > ul > li:focus-within > span > a,
	.main-navigation .nav--interior > ul > li:hover > span > a,
	.main-navigation .nav--interior > ul > li:focus-within > button,
	.main-navigation .nav--interior > ul > li:hover > button {
		color: var(--color-base);
	}
	
	.main-navigation .nav--interior > ul > li.drop-item:focus-within + li.drop-trigger button::after,
	.main-navigation .nav--interior > ul > li.drop-item:hover + li.drop-trigger button::after,
	.main-navigation .nav--interior > ul > li.drop-item + li.drop-trigger:focus-within button::after,
	.main-navigation .nav--interior > ul > li.drop-item + li.drop-trigger:hover button::after {
		border-top-color: var(--color-base);
	}

	.main-navigation .nav--interior > ul ul li {
		background-color: transparent;
		border: 0 solid var(--color-base-offset);
		border-bottom-width: 0px;
	}

	.main-navigation .nav--interior > ul ul li:first-child {
		border-top-width: 0px;
	}

	.main-navigation .nav--interior > ul ul li,
	.main-navigation .nav--interior > ul ul li a,
	.main-navigation .nav--interior > ul ul li button {
		color: var(--color-contrast);
	}

	.main-navigation .nav--interior > ul ul li a,
	.main-navigation .nav--interior > ul ul li button {
		box-shadow: none !important;
		display: block;
		overflow: hidden;
		padding: 9px;
		text-decoration: none;
		text-overflow: ellipsis;
		white-space: nowrap;
	}

	.main-navigation .nav--interior > ul ul li:focus-within,
	.main-navigation .nav--interior > ul ul li:hover {
		background-color: var(--color-contrast);
	}

	.main-navigation .nav--interior > ul ul li:focus-within a,
	.main-navigation .nav--interior > ul ul li:hover a,
	.main-navigation .nav--interior > ul ul li:focus-within button,
	.main-navigation .nav--interior > ul ul li:hover button {
		color: var(--color-base);
	}

	button.side-navigation-button {
		display: none;
	}

	.main-navigation .nav--decorations {
		align-items: center;
		display: flex;
		font-weight: 400;
		gap: 6px;
		line-height: 1.25rem;
		margin: 0;
		position: relative;
		user-select: none;
	}

	.main-navigation .nav--decorations:empty {
		display: none;
	}

	.main-navigation .nav--decorations.prefix {
		display: none;
		margin-right: 6px;
	}

	.main-navigation .nav--decorations.suffix {
		margin-left: 6px;
	}

	.main-navigation [class*="button--"] {
		--ring-offset-color: var(--backgroundColor);

		align-items: center;
		background-color: rgb(154, 150, 150);
		border-radius: 1px;
		color: var(--color-contrast);
		display: flex;
		line-height: 1.25rem;
		padding: 0px 6px 0px;
	}

	.main-navigation [class*="button--"]:hover {
		background-color: var(--color-contrast);
		color: var(--color-base);
	}

	.main-navigation .button--language-select {}
	.main-navigation .button--search {}

}
@media screen and ( max-width: 1000px ) {
	/* unset outdent value when screen is narrower than the layout */
	.main-navigation {
		right: auto;
		left: auto;
	}
}


@media screen and ( max-width: 1140px ) {
	.main-navigation,
	.drop-trigger button {
		display: none;
	}

	button.side-navigation-button {
		display: block;
	}

	.fb__side-navigation .fancybox__backdrop {
		background: var(--fancybox-bg, rgba(24, 24, 27, 0.98));
	}

	.fb__side-navigation .fancybox__slide::before,
	.fb__side-navigation .fancybox__slide::after {
		display: none;
	}

	.fb__side-navigation .fancybox__slide {
		flex: 1 0 auto;
		margin: 0;
		min-height: 100vh;
		padding: 0;
	}

	.fb__side-navigation:not(.is-compact) .fancybox__slide.has-close-btn {
		padding-top: 0;
	}

	.fb__side-navigation {
		--drawerBackgroundColor: var(--color-base);
	}

	.fb__side-navigation .fancybox__content {
		--backgroundColor: var(--drawerBackgroundColor);
		--ring-offset-color: var(--backgroundColor);

		align-self: flex-end;
		background-color: var(--backgroundColor);
		box-shadow: -4px 0px 4px -4px rgba(0, 0, 0, 0.25);
		color: var(--color-contrast);
		max-width: calc(100% - 25%);
		height: 100dvh;
		padding: 0;    
		position: relative;
		width: 192px;
	}

	.fb__side-navigation .fancybox__content .f-button.is-close-btn {
		--f-button-svg-filter: drop-shadow(1px 1px 1px rgba(24, 24, 27, 0.5));
		--ring-offset-width: 0px;
		--ring-width: 2px;

		align-items: center;
		background-color: transparent;
		color: #fff;
		display: flex;
		height: var(--f-button-height);
		justify-content: center;
		opacity: 1;
		padding: 0;
		top: 8px; right: auto; bottom: auto; left: -8px;
		transform: translateX(-100%);
		width: var(--f-button-width);
	}

	.fb__side-navigation .fancybox__content .f-button.is-close-btn:focus-visible {

	}

	.side-navigation .nav--interior {
		overflow-y: auto;
		padding-bottom: 50px;
	}

	.side-navigation a,
	.side-navigation button,
	.side-navigation span > span {
		display: block;
		height: 100%;
		line-height: 18px;
		overflow: hidden;
		padding: 16px;
		text-decoration: none;
		text-overflow: ellipsis;
		user-select: none;
		white-space: normal;
	}

	.side-navigation button[aria-expanded] {
		display: none;
	}

	.side-navigation .nav--interior > ul > li {
		border-bottom: 1px solid var(--color-contrast);
		text-align: left;
	}

	.side-navigation .nav--interior > ul ul li {
		font-size: 0.875rem;
		text-align: right;
	}

	.side-navigation a,
	.side-navigation button,
	.side-navigation span > span {
		--navItemBackgroundColor: var(--backgroundColor);

		background-color: var(--navItemBackgroundColor);
		color: var(--color-contrast);
	}

	.side-navigation a:hover,
	.side-navigation button:hover {
		--navItemBackgroundColor: var(--color-contrast);

		background-color: var(--navItemBackgroundColor);
		color: var(--backgroundColor);
	}

	.side-navigation a:focus-visible {
		--ring-offset-inset: inset;
		--ring-offset-width: 4px;
		--ring-inset: inset;
		--ring-width: calc(var(--ring-offset-width) + 2px);

		box-shadow:
			var(--ring-offset-inset) 0px 0px 0px var(--ring-offset-width) var(--navItemBackgroundColor),
			var(--ring-inset) 0px 0px var(--ring-blur) var(--ring-width) var(--ring-color)
		;
	}

	.side-navigation .nav--decorations {
		align-items: center;
		border-bottom: 1px solid var(--color-contrast);
		display: flex;
		gap: 6px;
		height: 50px;
		justify-content: flex-end;
		padding: 7px;
		text-align: right;
	}

	.side-navigation .nav--decorations:empty {
		display: none;
	}

	.side-navigation .nav--decorations.prefix {
	}

	.side-navigation .nav--decorations.suffix {
		display: none;
	}

	.side-navigation [class*="button--"] {
		border: 1px solid var(--color-contrast);
		border-radius: 1px;
		font-size: 0.75rem;
		line-height: 1rem;
		min-width: 35px;
		padding: 0 7px;
	}

}
/**
** headers
**************************/

/**
** main
**************************/
.main {
	--backgroundColor: var(--pageBackgroundColor);
	--ring-offset-color: var(--backgroundColor);

	background-color: var(--backgroundColor);
	flex: 1 0 auto;
	margin-top: 0;
	margin-right: auto;
	margin-bottom: 0;
	margin-left: auto;
	max-width: none;
	padding: 0 14px;
	padding-top: 0px;
	padding-bottom: 0px;
	position: relative;
	width: 100%;
	z-index: 0;
}

.main--dock {
	display: flex;
	justify-content: flex-end;
	height: 0;
	position: sticky;
	top: 50px;
	z-index: 1;
}

/**
** essay
**************************/
.main {
	font-size: 1rem;
	line-height: var(--baseLineHeight);
	text-align: left;
}

.main h1,
.main h2,
.main h3 {
	margin-block: 2.5rem 1.5rem;
	margin-inline: 0 0;
}

.main h1 {
	color: var(--color-contrast);
	font-family: Helvetica, Roboto, Arial, 'Segoe UI', 'Droid Sans', sans-serif;
	font-size: 1.125rem;
	font-weight: 600;
	line-height: 1.25em;
	text-align: left;
	text-transform: none;
}

.main h2 {
	color: var(--color-contrast);
	font-family: inherit;
	font-size: 1.25rem;
	font-weight: 400;
	line-height: 1.25em;
	text-align: center;
	text-transform: none;
}

.main h3,
.main h4,
.main h5
.main h6 {
	color: var(--color-contrast);
	font-family: inherit;
	font-size: 1.125rem;
	font-weight: 600;
	letter-spacing: 0.125em;
	line-height: 1.25em;
	margin-block: 2.5rem 1.5rem;
	margin-inline: 0;
	padding-top: 2px;
	text-align: center;
	text-transform: none;
}

.main hr {
	border: none;
	border-top-color: var(--color-base-offset);
	border-top-style: solid;
	border-top-width: 1px;
	box-sizing: border-box;
	clear: both;
	display: block;
	margin: var(--baseLineHeight) 0;
}

.main hr + h2:has(+ hr),
.main hr + h3:has(+ hr),
.main hr + h4:has(+ hr),
.main hr + h5:has(+ hr),
.main hr + h6:has(+ hr) {
	color: var(--color-contrast);
	font-family: inherit;
	font-size: 1rem;
	font-weight: 600;
	letter-spacing: 0.125em;
	line-height: 1.25em;
	margin-block: 0;
	margin-inline: 0;
	padding-top: 2px;
	text-align: center;
	text-transform: uppercase;
}

.main p {
	margin: var(--baseLineHeight) 0;
}

.main dl {
	margin: var(--baseLineHeight) 0;
}

.main dt {}

.main dd {}

.main ol, .main ul {
	list-style-position: inside;
	margin: var(--baseLineHeight) 0;
}

.main ol ol, .main ul ul {
	margin: 0;
}

.main li {
}

.main ol {
	color: var(--color-contrast);
	font-size: 1rem;
	line-height: 1.625em;
	padding-left: 23px;
}

.main ol ol {
	padding-left: 15px;
}

.main ol li {
	list-style-type: decimal;
}

.main ol li::marker {
	/* Safari support is limited to color and font-size. */
	color: var(--color-contrast);
	font-size: 0.75rem;
}

.main ul {
	color: var(--color-contrast);
	font-size: 1rem;
	line-height: 1.625em;
	padding-left: 16px;
}

.main ul ul {
	padding-left: 23px;
}

.main ul li {
	list-style-type: square;
}

.main ul li::marker {
	/* Safari support is limited to color and font-size. */
	color: var(--color-contrast);
	font-size: 16px;
}

/**
** code
**************************/
code {
	background-color: var(--color-base-offset);
	border-radius: 4px;
	color: #e83e8c;
	font-family: Consolas, Monaco, 'Andale Mono', 'Ubuntu Mono', monospace;
	font-size: 0.875rem;
	line-height: var(--baseLineHeight);
	padding: 0.2em 0.5em;
	white-space: nowrap;
}

pre {
	background-color: var(--color-base-offset);
	border-radius: 6px;
	font-size: 0.875rem;
	margin: var(--baseLineHeight) 0;
	overflow: auto;
	padding: 1em;
}

pre code {
	background: none;
	color: var(--color-contrast);
	display: block;
	white-space: pre;
}

/**
** table
**************************/

table {
	--tableBackgroundColor: var(--color-base);
	--tableHeadBackgroundColor: var(--color-base-offset);

	background-color: var(--tableBackgroundColor);
	border-collapse: separate;
	border-spacing: 0;
	display: block;
	font-family: system-ui, sans-serif;
	font-size: 0.875rem; 
	margin: var(--baseLineHeight) 0;
	max-width: 100%;
	overflow-x: auto;
	position: relative;
	width: fit-content;
	z-index: 0;

	-webkit-overflow-scrolling: touch;
}

thead {
	background-color: var(--tableHeadBackgroundColor);
	color: var(--color-contrast);
	font-weight: 600;
}

th, td {
	padding: 0.75em 1em;
	white-space: nowrap;
}

tbody tr {
	background: transparent;
	color: var(--color-contrast);
}

tbody tr:nth-child(odd) {
	background-color: var(--color-base);
}

tbody tr:hover {
	}

hr[data-sticky]:has(+ table) {
	border: none;
	height: 0;
	margin: 0;
}

hr[data-sticky]:has(+ table) + table thead th:first-child,
hr[data-sticky]:has(+ table) + table tbody td:first-child {
	background-color: var(--tableHeadBackgroundColor);
	background-clip: padding-box;
	left: 0;
	position: sticky;
	z-index: 1;
}

table {
	--tableBorderColor: var(--color-contrast);

	border: 1px solid var(--tableBorderColor);
}

th, td {
	border: 0 solid var(--tableBorderColor);
	border-width: 0 1px 1px 0;
}

th {
	border-bottom-width: 2px;
}

th:last-child,
td:last-child {
	border-right: none;
}

tr:last-child td {
	border-bottom: none;
}

hr[data-sticky]:has(+ table) + table thead th:first-child,
hr[data-sticky]:has(+ table) + table tbody td:first-child {
	border-right: 2px solid var(--tableBorderColor);
}

/**
** footer
**************************/
.footer--dock {
	bottom: 6px;
	display: flex;
	justify-content: flex-end;
	position: sticky;
	z-index: 1;
}

.footer--dock > div {
	background-color: rgba(255,255,255,0.5);
	border-radius: 8px;
	display: flex;
	gap: 9px;
	margin: 6px 0;
	padding: 4px 9px;
	position: absolute; bottom: 0;
}

.footer--dock > div:empty {
	display: none;
}

.footer--dock button {
	all: unset;
	border-radius: 1px;
	color: #212121;
	cursor: pointer;
	display: block;
	font-size: 0;
	text-decoration: none;
	filter: drop-shadow(0px 0px rgba(0, 0, 0, 0.25));
}

.footer--dock button:focus-visible,
.footer--dock button:hover {
	--ring-inset: inset;
	--ring-offset-color: var(--ring-color);
	--ring-offset-width: 1px;
	--ring-width: 1px;

	color: #000000;
	filter: none;
}

.footer {
	--backgroundColor: var(--pageBackgroundColor);
	--ring-offset-color: var(--backgroundColor);

	background-color: var(--backgroundColor);
	border-color: var(--color-base-offset);
	border-style: solid;
	border-width: 0px 0 0px;
	color: var(--color-contrast);
	margin-top: 0px;
	width: 100%;
}

.footer > div {
	align-items: center;
	display: flex;
	font-size: 0.75rem;
	gap: 12px;
	line-height: 1.25rem;
	margin: 0 auto;
	max-width: 100%;
	overflow: hidden;
	padding: 12px 14px;
}

.footer .copyright {
	flex: 1 1 auto;
	text-align: right;
}

.footer .copyright span {
	display: inline-block;
}

.footer a {
	color: var(--color-interactive);
}

.footer a:hover {
	color: ;
}

/**
** animations
**************************/
.animate-spin {
	-webkit-animation-name: animate-spin;
					animation-name: animate-spin;
	-webkit-animation-delay: var(--fa-animation-delay, 0);
					animation-delay: var(--fa-animation-delay, 0);
	-webkit-animation-direction: var(--fa-animation-direction, normal);
					animation-direction: var(--fa-animation-direction, normal);
	-webkit-animation-duration: var(--fa-animation-duration, 2s);
					animation-duration: var(--fa-animation-duration, 2s);
	-webkit-animation-iteration-count: var(--fa-animation-iteration-count, infinite);
					animation-iteration-count: var(--fa-animation-iteration-count, infinite);
	-webkit-animation-timing-function: var(--fa-animation-timing, linear);
					animation-timing-function: var(--fa-animation-timing, linear);
}

@-webkit-keyframes animate-spin {
	0% {
		-webkit-transform: rotate(0deg);
						transform: rotate(0deg);
	}
	100% {
		-webkit-transform: rotate(360deg);
						transform: rotate(360deg);
	}
}

@keyframes animate-spin {
	0% {
		-webkit-transform: rotate(0deg);
						transform: rotate(0deg);
	}
	100% {
		-webkit-transform: rotate(360deg);
						transform: rotate(360deg);
	}
}

/**
** breadcrumbs
**************************/
ul.breadcrumbs {
	align-items: center;
	display: flex;
	font-size: 0;
	justify-content: flex-start;
	margin : 0;
	padding: 9px 0;
}

ul.breadcrumbs li {
	display: block;
	flex: 0 0 auto;
	font-size: 0.75rem; 
	font-weight: 400;
	letter-spacing: 0.015em;
	line-height: 1.5em;
	list-style: none;
	margin-right: 9px;
	padding: 0;
}

ul.breadcrumbs li:last-child {
	margin-right: 0;
}

ul.breadcrumbs li::after {
	border-style: solid;
	border-width: 1px 1px 0 0;
	content: '\a0';
	display: inline-block;
	height: 5px;
	margin: 0 0 0 5px;
	opacity: 0.5;
	position: relative;
	top: -1px;
	transform: rotate(45deg);
	vertical-align: middle;
	width: 5px;
}

ul.breadcrumbs li:last-child::after {
	top: -2px;
	transform: rotate(135deg);
}

/**
** cookies acceptance notice
**************************/

.cookies-acceptance-notice {
	--backgroundColor: #e5e1e1;
  --color: #000000;
  --pageBackgroundColor: var(--backgroundColor);

  background-color: var(--backgroundColor);
	border: 0 solid var(--color);
	border-width: 2px 0 0 0;
	bottom: 0;
	left: 0;
	position: fixed;
	width: 100%;
	z-index: 100;
}

.cookies-acceptance-notice > div {
  background-color: var(--backgroundColor);
	color: var(--color);
	font-size: 0.75rem;
	line-height: 1.25;
	margin: 0 auto;
	max-width: 1000px;
	padding: 18px;
}

.cookies-acceptance-buttons {
	align-items: center;
	display: flex;
	justify-content: flex-end;
}

label[for="gaOptOut"] {
	font-size: 0.75rem;
	margin-right: 9px;
}

.cookies-acceptance-buttons button,
.cookies-acceptance-buttons label {
	align-items: center;
	background-color: var(--color-contrast);
	border-radius: 4px;
	color: var(--color-base);
	display: flex;
	font-size: 0.75rem;
	font-weight: 600;
	height: 36px;
	justify-content: center;
	padding: 0 18px;
}

.cookies-acceptance-buttons button:hover,
.cookies-acceptance-buttons label:hover {
	background-color: var(--color-contrast);
}

.cookies-acceptance-buttons label {
	padding-left: 9px;
}

.cookies-acceptance-buttons input[type="checkbox"] + label::before {
	background-color: var(--backgroundColor);
}

@media only screen and (max-width: 640px) {
	.cookies-acceptance-buttons {
		flex-direction: column;
		justify-content: center;
	}

	.cookies-acceptance-buttons button,
	.cookies-acceptance-buttons label {
		margin-bottom: 18px;
	}
}

.cookies-acceptance-notice .button--language-select {
  align-items: center;
  border: 1px solid var(--color-contrast);
  border-radius: 4px;
  display: flex;
  font-size: 0.75rem;
  line-height: 1rem;
  margin: 0 0 0 auto;
  padding: 6px 9px;
}

.cookies-acceptance-notice .button--language-select:hover {
	background-color: var(--color-contrast);
	color: var(--color-base);
}

/**
** modals
**************************/

*[data-lang] {
	display: none !important;
}

html[lang="en"] *[data-lang="en"],
html[lang="is"] *[data-lang="is"],
html[lang="no"] *[data-lang="no"] { display: inherit !important; }


.modal--language-select a,
.modal--language-select span {
	border-radius: 6px;
	display: block;
	margin: 6px auto;
	padding: 9px 18px;
	width: 256px;
}

.modal--language-select > div > :first-child {
	margin-top: 0;
}

.modal--language-select > div > :last-child {
	margin-bottom: 0;
}

.modal--language-select a {
	border: 1px solid #d6d602;
}

.modal--language-select span {
	border: 1px solid ;
}

button.button--language-select > svg {
	margin-right: 6px;
}

.modal--search {
  --modal-height: calc(var(--modal-width) / 2);
  --modal-width: 768px;

  align-items: center;
  border-radius: 6px;
  height: var(--modal-height);
  justify-content: center;
  max-height: 100%;
  max-width: 100%;
  padding: 44px;
  width: var(--modal-width);
}

.modal--search form {
  margin: 0;
  width: 100%;
}

.modal--search form input[type="text"] {
  display: block;
  height: 44px;
  margin: 0 auto 12px;
  max-width: none;
  text-align: center;
  width: 100%;
}

.modal--search form button {
  align-items: center;
  border-radius: 100%;
  display: flex;
  height: 44px;
  justify-content: center;
  margin: 0 auto;
  width: 44px;
}

button.button--search {}

@media screen and ( max-width: 640px ) {
  .modal--search {
    height: auto;
    width: 100%;
  }

  .modal--search::before {
    content: "";
    display: block;
    padding-top: 100%;
  }

  .modal--search form {
    align-items: center;
    display: flex;
    flex-direction: column;
    justify-content: center;
    padding: 20px;
    position: absolute;
    top: 0; right: 0; bottom: 0; left: 0;
  }
}
/**
 * logomarks
**************************/

.logomark,
.logomark * {
	all: unset;
	flex: 0 0 auto;
}

.logomark a {
	align-items: center;
	color: inherit;
	cursor: pointer;
	display: flex;
	gap: 6px;
}

.logomark a:hover {
	text-decoration: none;
}

.logomark ul {
	box-sizing: border-box;
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	width: 44px; height: 44px;
}

.logomark .col_x2 {
	grid-column: span 2;
}

.logomark .row_x2 {
	grid-row: auto / span 2;
}

.logomark--theturninggate ul {
	background-color: #fff;
	border: 2px solid transparent;
	gap: 2px;
}

.logomark--theturninggate li.color_999999 { background-color: #9E9E9E; } /* grey */
.logomark--theturninggate li.color_66ccff { background-color: #90CAF9; } /* light blue */
.logomark--theturninggate li.color_0099cc { background-color: #2196F3; } /* blue */
.logomark--theturninggate li.color_99cc66 { background-color: #B2FF59; } /* light green */
.logomark--theturninggate li.color_66cc33 { background-color: #8BC34A; } /* green */
.logomark--theturninggate li.color_ff9933 { background-color: #FF9800; } /* orange */

.logomark--backlight ul {
	background-color: rgba(255, 255, 255, 0.25);
	background-color: rgba(0, 0, 0, 0.25);
	border: 2px solid transparent;
}

.logomark--backlight li {
	background-color: #ffffff;
}

.logomark a > div {
	display: flex;
	flex-direction: column;
	font-size: 0.75rem;
	gap: 4px;
	line-height: 1;
}

.logomark a > div span:nth-child(2) {
	font-size: 0.875rem;
	font-weight: 600;
}

@media only screen and (max-width: 640px) {
	.logomark ul {
		width: 40px; height: 40px;
	}
	.logomark a > div span:nth-child(2) {
		font-size: 0.75rem;
	}
}

/**
** messages
**************************/

#message {
	border: 0 solid rgba(255,255,255,0.15);
	border-width: 0 0 0 8px;
	border-radius: 3px;
	border-top-left-radius: 0;
	box-shadow: 1px 1px 3px rgba(0,0,0,0.15);
	margin: 1.5rem 0;
	max-width: 768px;
	padding: 0.75rem 12px;
}

#message.error {
	background-color: #F44336;
}

#message.success {
	background-color: #0091EA;
}

#message * {
	color: #fff;
}

#message > *:first-child {
	margin-top: 0;
}

#message > *:last-child {
	margin-bottom: 0;
}

#message h1 {
	font-size: 1rem;
	font-weight: ;
	line-height: 1.5rem;
	margin : 0;
	padding: 0;
}

#message p {
	font-size: 0.857rem;
	margin: 1.5rem 0;
}

#message a {
	text-decoration: underline;
}

/** hide the honey-pot */
.contact-address { display: none }

/**
** utility classes
**************************/
.detect-interaction > .detect-interaction-tripwire {
	display: none;
}

.detect-interaction:focus-within > .detect-interaction-tripwire,
.detect-interaction:hover > .detect-interaction-tripwire {
	display: block;
}

.display-contents {
	display: contents;
}

/* Hide scrollbar for Chrome, Safari and Opera */
.hide-scrollbar::-webkit-scrollbar {
	display: none;
}

/* Hide scrollbar for IE, Edge and Firefox */
.hide-scrollbar {
	-ms-overflow-style: none;
	scrollbar-width: none;
}

/**
** iOS Safari
**************************/
@supports (-webkit-touch-callout: none) {
	/* rules specific to iOS Safari */
}

/**
 * collapsable-section
**************************/
collapsable-section {
	display: none;
}

collapsable-section.ready {
	display: block;
}

/**
 * image presentations
**************************/
div[data-presentation],
div[data-presentation] .presentation-interior {
	clear: both;
	position: relative;
}

div[data-presentation][data-columns="12"] figure {
	width: 8.333333%;
}
div[data-presentation][data-columns="11"] figure {
	width: 9.090910%;
}
div[data-presentation][data-columns="10"] figure {
	width: 10%;
}
div[data-presentation][data-columns="9"] figure {
	width: 11.111111%;
}
div[data-presentation][data-columns="8"] figure {
	width: 12.5%;
}
div[data-presentation][data-columns="7"] figure {
	width: 14.285714%;
}
div[data-presentation][data-columns="6"] figure {
	width: 16.666667%;
}
div[data-presentation][data-columns="5"] figure {
	width: 20%;
}
div[data-presentation][data-columns="4"] figure {
	width: 25%;
}
div[data-presentation][data-columns="3"] figure {
	width: 33.333333%;
}
div[data-presentation][data-columns="2"] figure {
	width: 50%;
}
div[data-presentation][data-columns="1"] figure {
	width: 100%;
}

div[data-presentation] :focus-visible {
	--ring-offset-width: 0px;
	--ring-width: 2px;
}

:root{--f-spinner-width: 36px;--f-spinner-height: 36px;--f-spinner-color-1: rgba(0, 0, 0, 0.1);--f-spinner-color-2: rgba(17, 24, 28, 0.8);--f-spinner-stroke: 2.75}.f-spinner{margin:auto;padding:0;width:var(--f-spinner-width);height:var(--f-spinner-height)}.f-spinner svg{width:100%;height:100%;vertical-align:top;animation:f-spinner-rotate 2s linear infinite}.f-spinner svg *{stroke-width:var(--f-spinner-stroke);fill:none}.f-spinner svg *:first-child{stroke:var(--f-spinner-color-1)}.f-spinner svg *:last-child{stroke:var(--f-spinner-color-2);animation:f-spinner-dash 2s ease-in-out infinite}@keyframes f-spinner-rotate{100%{transform:rotate(360deg)}}@keyframes f-spinner-dash{0%{stroke-dasharray:1,150;stroke-dashoffset:0}50%{stroke-dasharray:90,150;stroke-dashoffset:-35}100%{stroke-dasharray:90,150;stroke-dashoffset:-124}}.f-throwOutUp{animation:var(--f-throw-out-duration, 0.175s) ease-out both f-throwOutUp}.f-throwOutDown{animation:var(--f-throw-out-duration, 0.175s) ease-out both f-throwOutDown}@keyframes f-throwOutUp{to{transform:translate3d(0, calc(var(--f-throw-out-distance, 150px) * -1), 0);opacity:0}}@keyframes f-throwOutDown{to{transform:translate3d(0, var(--f-throw-out-distance, 150px), 0);opacity:0}}.f-zoomInUp{animation:var(--f-transition-duration, 0.2s) ease .1s both f-zoomInUp}.f-zoomOutDown{animation:var(--f-transition-duration, 0.2s) ease both f-zoomOutDown}@keyframes f-zoomInUp{from{transform:scale(0.975) translate3d(0, 16px, 0);opacity:0}to{transform:scale(1) translate3d(0, 0, 0);opacity:1}}@keyframes f-zoomOutDown{to{transform:scale(0.975) translate3d(0, 16px, 0);opacity:0}}.f-fadeIn{animation:var(--f-transition-duration, 0.2s) var(--f-transition-easing, ease) var(--f-transition-delay, 0s) both f-fadeIn;z-index:2}.f-fadeOut{animation:var(--f-transition-duration, 0.2s) var(--f-transition-easing, ease) var(--f-transition-delay, 0s) both f-fadeOut;z-index:1}@keyframes f-fadeIn{0%{opacity:0}100%{opacity:1}}@keyframes f-fadeOut{100%{opacity:0}}.f-fadeFastIn{animation:var(--f-transition-duration, 0.2s) ease-out both f-fadeFastIn;z-index:2}.f-fadeFastOut{animation:var(--f-transition-duration, 0.1s) ease-out both f-fadeFastOut;z-index:2}@keyframes f-fadeFastIn{0%{opacity:.75}100%{opacity:1}}@keyframes f-fadeFastOut{100%{opacity:0}}.f-fadeSlowIn{animation:var(--f-transition-duration, 0.5s) ease both f-fadeSlowIn;z-index:2}.f-fadeSlowOut{animation:var(--f-transition-duration, 0.5s) ease both f-fadeSlowOut;z-index:1}@keyframes f-fadeSlowIn{0%{opacity:0}100%{opacity:1}}@keyframes f-fadeSlowOut{100%{opacity:0}}.f-crossfadeIn{animation:var(--f-transition-duration, 0.2s) ease-out both f-crossfadeIn;z-index:2}.f-crossfadeOut{animation:calc(var(--f-transition-duration, 0.2s)*.5) linear .1s both f-crossfadeOut;z-index:1}@keyframes f-crossfadeIn{0%{opacity:0}100%{opacity:1}}@keyframes f-crossfadeOut{100%{opacity:0}}.f-slideIn.from-next{animation:var(--f-transition-duration, 0.85s) cubic-bezier(0.16, 1, 0.3, 1) f-slideInNext}.f-slideIn.from-prev{animation:var(--f-transition-duration, 0.85s) cubic-bezier(0.16, 1, 0.3, 1) f-slideInPrev}.f-slideOut.to-next{animation:var(--f-transition-duration, 0.85s) cubic-bezier(0.16, 1, 0.3, 1) f-slideOutNext}.f-slideOut.to-prev{animation:var(--f-transition-duration, 0.85s) cubic-bezier(0.16, 1, 0.3, 1) f-slideOutPrev}@keyframes f-slideInPrev{0%{transform:translateX(100%)}100%{transform:translate3d(0, 0, 0)}}@keyframes f-slideInNext{0%{transform:translateX(-100%)}100%{transform:translate3d(0, 0, 0)}}@keyframes f-slideOutNext{100%{transform:translateX(-100%)}}@keyframes f-slideOutPrev{100%{transform:translateX(100%)}}.f-classicIn.from-next{animation:var(--f-transition-duration, 0.85s) cubic-bezier(0.16, 1, 0.3, 1) f-classicInNext;z-index:2}.f-classicIn.from-prev{animation:var(--f-transition-duration, 0.85s) cubic-bezier(0.16, 1, 0.3, 1) f-classicInPrev;z-index:2}.f-classicOut.to-next{animation:var(--f-transition-duration, 0.85s) cubic-bezier(0.16, 1, 0.3, 1) f-classicOutNext;z-index:1}.f-classicOut.to-prev{animation:var(--f-transition-duration, 0.85s) cubic-bezier(0.16, 1, 0.3, 1) f-classicOutPrev;z-index:1}@keyframes f-classicInNext{0%{transform:translateX(-75px);opacity:0}100%{transform:translate3d(0, 0, 0);opacity:1}}@keyframes f-classicInPrev{0%{transform:translateX(75px);opacity:0}100%{transform:translate3d(0, 0, 0);opacity:1}}@keyframes f-classicOutNext{100%{transform:translateX(-75px);opacity:0}}@keyframes f-classicOutPrev{100%{transform:translateX(75px);opacity:0}}.f-carousel{--f-carousel-theme-color: #706f6c;--f-carousel-spacing: 0px;--f-carousel-slide-width: 100%;--f-carousel-slide-height: auto;--f-carousel-slide-padding: 0;--f-button-width: 42px;--f-button-height: 42px;--f-button-color: var(--f-carousel-theme-color, currentColor);--f-button-hover-color: var(--f-carousel-theme-color, currentColor);--f-button-bg: transparent;--f-button-hover-bg: var(--f-button-bg);--f-button-active-bg: var(--f-button-bg);--f-button-svg-width: 24px;--f-button-svg-height: 24px;--f-button-next-pos: 10px;--f-button-prev-pos: 10px;--f-spinner-color-1: rgba(0, 0, 0, 0.1);--f-spinner-color-2: rgba(17, 24, 28, 0.8);--f-spinner-stroke: 2.75;position:relative;box-sizing:border-box}.f-carousel *,.f-carousel *:before,.f-carousel *:after{box-sizing:inherit}.f-carousel.is-ltr{direction:ltr}.f-carousel.is-rtl{direction:rtl}.f-carousel__viewport{overflow:hidden;transform:translate3d(0, 0, 0);backface-visibility:hidden;width:100%;height:100%}.f-carousel__viewport.is-draggable{cursor:move;cursor:grab}.f-carousel__viewport.is-dragging{cursor:move;cursor:grabbing}.f-carousel__track{display:flex;margin:0 auto;padding:0;height:100%;-webkit-tap-highlight-color:rgba(0,0,0,0)}.f-carousel__slide{position:relative;flex:0 0 auto;width:var(--f-carousel-slide-width);max-width:100%;height:var(--f-carousel-slide-height);margin:0 var(--f-carousel-spacing) 0 0;padding:var(--f-carousel-slide-padding);outline:0;transform-origin:center center}.f-carousel__slide img.is-preloading{visibility:hidden}.f-carousel__slide>.f-spinner{position:absolute;top:50%;left:50%;transform:translate(-50%, -50%)}.f-carousel.is-vertical{--f-carousel-slide-height: 100%}.f-carousel.is-vertical .f-carousel__track{flex-wrap:wrap}.f-carousel.is-vertical .f-carousel__slide{margin:0 0 var(--f-carousel-spacing) 0}:root{--f-carousel-dots-width: 24px;--f-carousel-dots-height: 30px;--f-carousel-dot-width: 8px;--f-carousel-dot-height: 8px;--f-carousel-dot-radius: 50%;--f-carousel-dot-color: var(--f-carousel-theme-color, currentColor);--f-carousel-dot-opacity: 0.2;--f-carousel-dot-hover-opacity: 0.4}.f-carousel.has-dots{margin-bottom:var(--f-carousel-dots-height)}.f-carousel__dots{position:absolute;bottom:calc(var(--f-carousel-dots-height)*-1);left:0;right:0;display:flex;justify-content:center;align-items:center;flex-wrap:wrap;margin:0 auto !important;padding:0;list-style:none !important;user-select:none}.f-carousel__dots li{margin:0;padding:0;border:0;display:flex;align-items:center;justify-content:center;opacity:var(--f-carousel-dot-opacity);transition:opacity .15s ease-in-out}.f-carousel__dots li+li{margin:0}.f-carousel__dots li:hover{opacity:var(--f-carousel-dot-hover-opacity)}.f-carousel__dots li.is-current{opacity:1}.f-carousel__dots li button{appearance:none;display:flex;align-items:center;justify-content:center;margin:0;padding:0;width:var(--f-carousel-dots-width);height:var(--f-carousel-dots-height);border:0;background:rgba(0,0,0,0);cursor:pointer;transition:all .2s linear}.f-carousel__dot{display:block;margin:0;padding:0;border:0;width:var(--f-carousel-dot-width);height:var(--f-carousel-dot-height);border-radius:var(--f-carousel-dot-radius);background-color:var(--f-carousel-dot-color);line-height:0;font-size:0;cursor:pointer;pointer-events:none}.f-carousel__dots.is-dynamic li:not(.is-prev,.is-next,.is-current,.is-after-next,.is-before-prev) button{transform:scale(0);width:0}.f-carousel__dots.is-dynamic li.is-before-prev button,.f-carousel__dots.is-dynamic li.is-after-next button{transform:scale(0.22)}.f-carousel__dots.is-dynamic li.is-prev button,.f-carousel__dots.is-dynamic li.is-next button{transform:scale(0.66)}.f-carousel__dots.is-dynamic li.is-current button{transform:scale(1)}.f-carousel__dots.is-dynamic li.is-before-prev button,.f-carousel__dots.is-dynamic li.is-after-next button{transform:scale(0.33)}.f-carousel__dots.is-dynamic li.is-current:first-child{margin-left:calc(var(--f-carousel-dots-width)*2)}.f-carousel__dots.is-dynamic li.is-prev:first-child{margin-left:var(--f-carousel-dots-width)}.f-carousel__dots.is-dynamic li.is-next:last-child{margin-right:var(--f-carousel-dots-width)}.f-carousel__dots.is-dynamic li.is-current:last-child{margin-right:calc(var(--f-carousel-dots-width)*2)}.f-carousel.is-rtl .f-carousel__dots.is-dynamic .is-current:first-child{margin-left:0;margin-right:var(--f-carousel-dots-width)}.f-carousel.is-rtl .f-carousel__dots.is-dynamic .is-prev:first-child{margin-left:0;margin-right:var(--f-carousel-dots-width)}.f-carousel.is-rtl .f-carousel__dots.is-dynamic .is-current:last-child{margin-left:0;margin-right:var(--f-carousel-dots-width)}.f-carousel.is-rtl .f-carousel__dots.is-dynamic .is-next:last-child{margin-right:0;margin-left:var(--f-carousel-dots-width)}:root{--f-button-width: 40px;--f-button-height: 40px;--f-button-border: 0;--f-button-border-radius: 0;--f-button-color: #374151;--f-button-bg: #f8f8f8;--f-button-hover-bg: #e0e0e0;--f-button-active-bg: #d0d0d0;--f-button-shadow: none;--f-button-transition: all 0.15s ease;--f-button-transform: none;--f-button-svg-width: 20px;--f-button-svg-height: 20px;--f-button-svg-stroke-width: 1.5;--f-button-svg-fill: none;--f-button-svg-filter: none;--f-button-svg-disabled-opacity: 0.65}.f-button{display:flex;justify-content:center;align-items:center;box-sizing:content-box;position:relative;margin:0;padding:0;width:var(--f-button-width);height:var(--f-button-height);border:var(--f-button-border);border-radius:var(--f-button-border-radius);color:var(--f-button-color);background:var(--f-button-bg);box-shadow:var(--f-button-shadow);pointer-events:all;cursor:pointer;transition:var(--f-button-transition)}@media(hover: hover){.f-button:hover:not([disabled]){color:var(--f-button-hover-color);background-color:var(--f-button-hover-bg)}}.f-button:active:not([disabled]){background-color:var(--f-button-active-bg)}.f-button:focus:not(:focus-visible){outline:none}.f-button:focus-visible{outline:none;box-shadow:inset 0 0 0 var(--f-button-outline, 2px) var(--f-button-outline-color, var(--f-button-color))}.f-button svg{width:var(--f-button-svg-width);height:var(--f-button-svg-height);fill:var(--f-button-svg-fill);stroke:currentColor;stroke-width:var(--f-button-svg-stroke-width);stroke-linecap:round;stroke-linejoin:round;transition:opacity .15s ease;transform:var(--f-button-transform);filter:var(--f-button-svg-filter);pointer-events:none}.f-button[disabled]{cursor:default}.f-button[disabled] svg{opacity:var(--f-button-svg-disabled-opacity)}.f-carousel__nav .f-button.is-prev,.f-carousel__nav .f-button.is-next,.fancybox__nav .f-button.is-prev,.fancybox__nav .f-button.is-next{position:absolute;z-index:1}.is-horizontal .f-carousel__nav .f-button.is-prev,.is-horizontal .f-carousel__nav .f-button.is-next,.is-horizontal .fancybox__nav .f-button.is-prev,.is-horizontal .fancybox__nav .f-button.is-next{top:50%;transform:translateY(-50%)}.is-horizontal .f-carousel__nav .f-button.is-prev,.is-horizontal .fancybox__nav .f-button.is-prev{left:var(--f-button-prev-pos)}.is-horizontal .f-carousel__nav .f-button.is-next,.is-horizontal .fancybox__nav .f-button.is-next{right:var(--f-button-next-pos)}.is-horizontal.is-rtl .f-carousel__nav .f-button.is-prev,.is-horizontal.is-rtl .fancybox__nav .f-button.is-prev{left:auto;right:var(--f-button-next-pos)}.is-horizontal.is-rtl .f-carousel__nav .f-button.is-next,.is-horizontal.is-rtl .fancybox__nav .f-button.is-next{right:auto;left:var(--f-button-prev-pos)}.is-vertical .f-carousel__nav .f-button.is-prev,.is-vertical .f-carousel__nav .f-button.is-next,.is-vertical .fancybox__nav .f-button.is-prev,.is-vertical .fancybox__nav .f-button.is-next{top:auto;left:50%;transform:translateX(-50%)}.is-vertical .f-carousel__nav .f-button.is-prev,.is-vertical .fancybox__nav .f-button.is-prev{top:var(--f-button-next-pos)}.is-vertical .f-carousel__nav .f-button.is-next,.is-vertical .fancybox__nav .f-button.is-next{bottom:var(--f-button-next-pos)}.is-vertical .f-carousel__nav .f-button.is-prev svg,.is-vertical .f-carousel__nav .f-button.is-next svg,.is-vertical .fancybox__nav .f-button.is-prev svg,.is-vertical .fancybox__nav .f-button.is-next svg{transform:rotate(90deg)}.f-carousel__nav .f-button:disabled,.fancybox__nav .f-button:disabled{pointer-events:none}.f-progress{position:absolute;top:0;left:0;right:0;height:3px;transform:scaleX(0);transform-origin:0;transition-property:transform;transition-timing-function:linear;background:var(--f-progress-color, var(--f-carousel-theme-color, #0091ff));z-index:30;user-select:none;pointer-events:none}.f-carousel__thumbs{--f-thumb-width: 96px;--f-thumb-height: 72px;--f-thumb-outline: 0;--f-thumb-outline-color: #5eb0ef;--f-thumb-opacity: 1;--f-thumb-hover-opacity: 1;--f-thumb-selected-opacity: 1;--f-thumb-border-radius: 2px;--f-thumb-offset: 0px;--f-button-next-pos: 0;--f-button-prev-pos: 0}.f-carousel__thumbs.is-classic{--f-thumb-gap: 8px;--f-thumb-opacity: 0.5;--f-thumb-hover-opacity: 1;--f-thumb-selected-opacity: 1}.f-carousel__thumbs.is-modern{--f-thumb-gap: 4px;--f-thumb-extra-gap: 16px;--f-thumb-clip-width: 46px}.f-thumbs{position:relative;flex:0 0 auto;margin:0;overflow:hidden;-webkit-tap-highlight-color:rgba(0,0,0,0);user-select:none;perspective:1000px;transform:translateZ(0)}.f-thumbs .f-spinner{position:absolute;top:0;left:0;width:100%;height:100%;border-radius:2px;background-image:linear-gradient(#ebeff2, #e2e8f0);z-index:-1}.f-thumbs .f-spinner svg{display:none}.f-thumbs.is-vertical{height:100%}.f-thumbs__viewport{width:100%;height:auto;overflow:hidden;transform:translate3d(0, 0, 0)}.f-thumbs__track{display:flex}.f-thumbs__slide{position:relative;flex:0 0 auto;box-sizing:content-box;display:flex;align-items:center;justify-content:center;padding:0;margin:0;width:var(--f-thumb-width);height:var(--f-thumb-height);overflow:visible;cursor:pointer}.f-thumbs__slide.is-loading img{opacity:0}.is-classic .f-thumbs__viewport{height:100%}.is-modern .f-thumbs__track{width:max-content}.is-modern .f-thumbs__track::before{content:"";position:absolute;top:0;bottom:0;left:calc((var(--f-thumb-clip-width, 0))*-0.5);width:calc(var(--width, 0)*1px + var(--f-thumb-clip-width, 0));cursor:pointer}.is-modern .f-thumbs__slide{width:var(--f-thumb-clip-width);transform:translate3d(calc(var(--shift, 0) * -1px), 0, 0);transition:none;pointer-events:none}.is-modern.is-resting .f-thumbs__slide{transition:transform .33s ease}.is-modern.is-resting .f-thumbs__slide__button{transition:clip-path .33s ease}.is-using-tab .is-modern .f-thumbs__slide:focus-within{filter:drop-shadow(-1px 0px 0px var(--f-thumb-outline-color)) drop-shadow(2px 0px 0px var(--f-thumb-outline-color)) drop-shadow(0px -1px 0px var(--f-thumb-outline-color)) drop-shadow(0px 2px 0px var(--f-thumb-outline-color))}.f-thumbs__slide__button{appearance:none;width:var(--f-thumb-width);height:100%;margin:0 -100% 0 -100%;padding:0;border:0;position:relative;border-radius:var(--f-thumb-border-radius);overflow:hidden;background:rgba(0,0,0,0);outline:none;cursor:pointer;pointer-events:auto;touch-action:manipulation;opacity:var(--f-thumb-opacity);transition:opacity .2s ease}.f-thumbs__slide__button:hover{opacity:var(--f-thumb-hover-opacity)}.f-thumbs__slide__button:focus:not(:focus-visible){outline:none}.f-thumbs__slide__button:focus-visible{outline:none;opacity:var(--f-thumb-selected-opacity)}.is-modern .f-thumbs__slide__button{--clip-path: inset( 0 calc( ((var(--f-thumb-width, 0) - var(--f-thumb-clip-width, 0))) * (1 - var(--progress, 0)) * 0.5 ) round var(--f-thumb-border-radius, 0) );clip-path:var(--clip-path)}.is-classic .is-nav-selected .f-thumbs__slide__button{opacity:var(--f-thumb-selected-opacity)}.is-classic .is-nav-selected .f-thumbs__slide__button::after{content:"";position:absolute;top:0;left:0;right:0;height:auto;bottom:0;border:var(--f-thumb-outline, 0) solid var(--f-thumb-outline-color, transparent);border-radius:var(--f-thumb-border-radius);animation:f-fadeIn .2s ease-out;z-index:10}.f-thumbs__slide__img{overflow:hidden;position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;margin:0;padding:var(--f-thumb-offset);box-sizing:border-box;pointer-events:none;object-fit:cover;border-radius:var(--f-thumb-border-radius)}.f-thumbs.is-horizontal .f-thumbs__track{padding:8px 0 12px 0}.f-thumbs.is-horizontal .f-thumbs__slide{margin:0 var(--f-thumb-gap) 0 0}.f-thumbs.is-vertical .f-thumbs__track{flex-wrap:wrap;padding:0 8px}.f-thumbs.is-vertical .f-thumbs__slide{margin:0 0 var(--f-thumb-gap) 0}
/**
 * carousel
**************************/
div[data-presentation="carousel"] {
	--aspect-ratio: 42.857142857143%;
	--aspect-ratio-mobile: 75%;

	--f-carousel-dots-height: 32px;

	margin-right: auto;
	margin-bottom: 1.5em;
	margin-left: auto;
	max-width: none;
}

.pagination + div[data-presentation="carousel"] {
	margin-top: 8px;
	margin-bottom: 8px;
}

div[data-presentation="carousel"] + .pagination {
	margin-bottom: 1.5em;
}

div[data-presentation="carousel"] div.presentation-interior {
	position: relative;
}

.kookaburra-carousel-ui {
	--kookabura-carousel-ui-button-size: 32px;

	align-items: center;
	background-color: var(--backgroundColor);
	display: flex;
	height: var(--kookabura-carousel-ui-button-size);
	justify-content: space-between;
	width: 100%;
}

.kookaburra-carousel-ui div {
	display: flex;
	gap: 8px;
	padding: 0 8px;
}

.kookaburra-carousel-ui button {
	align-items: center;
  border-radius: 4px;
	color: var(--f-button-color);
	display: flex;
	justify-content: center;
	height: calc(var(--kookabura-carousel-ui-button-size) - 4px);
	transition: opacity 0.2s ease;
  width: var(--kookabura-carousel-ui-button-size);
}

.kookaburra-carousel-ui button:focus-visible {
  --ring-offset-width: 0px;
  --ring-inset: inset;
  --ring-width: 2px;
}

.kookaburra-carousel-ui svg {
	height: 18px; width: 18px;
}

.kookaburra-carousel-ui .carousel-ui--play-pause g:nth-child(2) {
	display: none;
}
.kookaburra-carousel-ui .carousel-ui--play-pause.has-autoplay g:nth-child(1) { display: none; }
.kookaburra-carousel-ui .carousel-ui--play-pause.has-autoplay g:nth-child(2) { display: inline; }

	.kookaburra-carousel-ui {
		position: absolute; top: 0; left: 0;
		z-index: 1;
	}

	.kookaburra-carousel-ui svg {
		filter: drop-shadow(0px 0px 1px rgba(0, 0, 0, 0.5));
	}

.kookaburra-carousel {
	--f-button-color: #ffffff;
	--f-carousel-dot-color: #000000;
	--f-carousel-slide-height: 100%;
	--f-carousel-slide-width: calc(100% / 1);
	--f-progress-color: var(--f-button-color);

	background-color: transparent;
	box-shadow: 0 0 0px 0px ;
	opacity: 0;
	position: relative;
	transition: opacity 0.2s ease-in-out;
}

.kookaburra-carousel.ready {
	opacity: 1;
}

.kookaburra-carousel.has-autoplay {
	--f-transition-duration: 2000ms;
}

.kookaburra-carousel::before {
	content: "";
	display: block;
	padding-top: var(--aspect-ratio);
}

.kookaburra-carousel .f-carousel__viewport {
	position: absolute;
	top: 0; right: 0; bottom: 0; left: 0;
}

.kookaburra-carousel .f-carousel__slide {
	background-color: transparent;
	border: 0 solid white;
}

.kookaburra-carousel .f-carousel__slide figure {
	height: 100%;
	width: 100%;
}

.kookaburra-carousel .f-carousel__slide img {
	height: 100%;
	object-fit: contain;
	width: 100%;
}

.kookaburra-carousel .f-carousel__nav .f-button.is-prev,
.kookaburra-carousel .f-carousel__nav .f-button.is-next {
	border-radius: 50%;
	color: var(--f-button-color);
}

.kookaburra-carousel .f-carousel__nav .f-button.is-next svg {
	filter: drop-shadow(-2px 0px 1px rgba(0, 0, 0, 0.5));
}

.kookaburra-carousel .f-carousel__nav .f-button.is-prev svg {
	filter: drop-shadow(2px 0px 1px rgba(0, 0, 0, 0.5));
}

.kookaburra-carousel .f-carousel__dots {
	background-color: ;
}

	.kookaburra-carousel .f-carousel__dot {
		filter: drop-shadow(0px 0px 1px rgba(0, 0, 0, 0.5));
	}

.kookaburra-carousel.f-carousel.has-dots {
	margin-bottom: 0;
}
.kookaburra-carousel.f-carousel.has-dots + .kookaburra-carousel-bumper {
	height: var(--f-carousel-dots-height);
}




@media screen and ( max-width: 992px ) {
.kookaburra-carousel::before {
	padding-top: var(--aspect-ratio-mobile);
}

}
/* data for opening slideshow; should be hidden */
div[data-presentation="carousel"] .f-carousel__slide div.f-carousel__slide--data {
	height: 0;
	position: absolute; right: 0; bottom: 0;
	visibility: hidden;
	width: 0;
}

/**
 * image presentation: grid
**************************/
div[data-presentation="grid"] .essay-presentation-toolbar {
	border: 0 solid var(--color-base-offset);
	border-top-width: 1px;
	border-bottom-width: 1px;
	margin: 0 5px;
	width: calc(100% - (10px))
}

div[data-presentation="grid"] {
	margin: 0 -5px 1.5em;
}

.pagination + div[data-presentation="grid"] {
	margin-top: 0;
	margin-bottom: 0;
}

div[data-presentation="grid"] + .pagination {
	margin-bottom: 1.5em;
}

div[data-presentation="grid"] .presentation-interior {
	display: flex;
	flex-wrap: wrap;
}

@media only screen and (max-width: 640px) {
	div[data-presentation="grid"] {
		margin-right: 0;
		margin-left: 0;
	}
}

div[data-presentation="grid"] figure {
	box-sizing: border-box;
	flex: 0 0 auto;
	width: 25%;
}

div[data-presentation="grid"] figure > div {
	box-shadow: 1px 1px 4px rgba(0,0,0,0.1);
	margin: 5px;
}

div[data-presentation="grid"] figure > div a {
	background-color: rgb(154, 154, 148);
	border: 0px solid var(--color-base-offset);
	border-radius: 6px;
}

div[data-presentation="grid"] figure > div a {
	display: block;
	position: relative;
}

div[data-presentation="grid"] figure > div a::before {
	content: "";
	display: block;
	padding-top: 75%;
}


div[data-presentation="grid"] figure > div a img {
	border: 5px solid transparent;
	object-fit: contain;
	position: absolute; top: 0; left: 0; bottom: 0; right: 0;
	width: 100%; height: 100%;
}


div[data-presentation="grid"][data-columns="12"] figure, div[data-presentation="grid"][data-columns="11"] figure, div[data-presentation="grid"][data-columns="10"] figure, div[data-presentation="grid"][data-columns="9"] figure, div[data-presentation="grid"][data-columns="8"] figure, div[data-presentation="grid"][data-columns="7"] figure, div[data-presentation="grid"][data-columns="6"] figure, div[data-presentation="grid"][data-columns="5"] figure {
	width: 20%;
}

@media only screen and (max-width: 1680px) {
	div[data-presentation="grid"][data-columns="12"] figure, div[data-presentation="grid"][data-columns="11"] figure, div[data-presentation="grid"][data-columns="10"] figure, div[data-presentation="grid"][data-columns="9"] figure, div[data-presentation="grid"][data-columns="8"] figure, div[data-presentation="grid"][data-columns="7"] figure, div[data-presentation="grid"][data-columns="6"] figure, div[data-presentation="grid"][data-columns="5"] figure {
		width: 20%;
	}
}

@media only screen and (max-width: 1440px) {
	div[data-presentation="grid"][data-columns="12"] figure, div[data-presentation="grid"][data-columns="11"] figure, div[data-presentation="grid"][data-columns="10"] figure, div[data-presentation="grid"][data-columns="9"] figure, div[data-presentation="grid"][data-columns="8"] figure, div[data-presentation="grid"][data-columns="7"] figure, div[data-presentation="grid"][data-columns="6"] figure, div[data-presentation="grid"][data-columns="5"] figure {
		width: 20%;
	}
}

@media only screen and (max-width: 1280px) {
	div[data-presentation="grid"][data-columns="12"] figure, div[data-presentation="grid"][data-columns="11"] figure, div[data-presentation="grid"][data-columns="10"] figure, div[data-presentation="grid"][data-columns="9"] figure, div[data-presentation="grid"][data-columns="8"] figure, div[data-presentation="grid"][data-columns="7"] figure, div[data-presentation="grid"][data-columns="6"] figure, div[data-presentation="grid"][data-columns="5"] figure {
		width: 20%;
	}
}

@media only screen and (max-width: 1140px) {
	div[data-presentation="grid"][data-columns="12"] figure, div[data-presentation="grid"][data-columns="11"] figure, div[data-presentation="grid"][data-columns="10"] figure, div[data-presentation="grid"][data-columns="9"] figure, div[data-presentation="grid"][data-columns="8"] figure, div[data-presentation="grid"][data-columns="7"] figure, div[data-presentation="grid"][data-columns="6"] figure, div[data-presentation="grid"][data-columns="5"] figure {
		width: 20%;
	}
}

@media only screen and (max-width: 1024px) {
	div[data-presentation="grid"][data-columns="12"] figure, div[data-presentation="grid"][data-columns="11"] figure, div[data-presentation="grid"][data-columns="10"] figure, div[data-presentation="grid"][data-columns="9"] figure, div[data-presentation="grid"][data-columns="8"] figure, div[data-presentation="grid"][data-columns="7"] figure, div[data-presentation="grid"][data-columns="6"] figure, div[data-presentation="grid"][data-columns="5"] figure {
		width: 20%;
	}
}

@media only screen and (max-width: 992px) {
	div[data-presentation="grid"][data-columns="12"] figure, div[data-presentation="grid"][data-columns="11"] figure, div[data-presentation="grid"][data-columns="10"] figure, div[data-presentation="grid"][data-columns="9"] figure, div[data-presentation="grid"][data-columns="8"] figure, div[data-presentation="grid"][data-columns="7"] figure, div[data-presentation="grid"][data-columns="6"] figure, div[data-presentation="grid"][data-columns="5"] figure, div[data-presentation="grid"][data-columns="4"] figure, div[data-presentation="grid"][data-columns="3"] figure, div[data-presentation="grid"][data-columns="2"] figure {
		width: 50%;
	}
}

@media only screen and (max-width: 640px) {
	div[data-presentation="grid"][data-columns="12"] figure, div[data-presentation="grid"][data-columns="11"] figure, div[data-presentation="grid"][data-columns="10"] figure, div[data-presentation="grid"][data-columns="9"] figure, div[data-presentation="grid"][data-columns="8"] figure, div[data-presentation="grid"][data-columns="7"] figure, div[data-presentation="grid"][data-columns="6"] figure, div[data-presentation="grid"][data-columns="5"] figure, div[data-presentation="grid"][data-columns="4"] figure, div[data-presentation="grid"][data-columns="3"] figure, div[data-presentation="grid"][data-columns="2"] figure, div[data-presentation="grid"][data-columns="1"] figure {
		width: 100%;
	}
}

@media only screen and (max-width: 414px) {
	div[data-presentation="grid"][data-columns="12"] figure, div[data-presentation="grid"][data-columns="11"] figure, div[data-presentation="grid"][data-columns="10"] figure, div[data-presentation="grid"][data-columns="9"] figure, div[data-presentation="grid"][data-columns="8"] figure, div[data-presentation="grid"][data-columns="7"] figure, div[data-presentation="grid"][data-columns="6"] figure, div[data-presentation="grid"][data-columns="5"] figure, div[data-presentation="grid"][data-columns="4"] figure, div[data-presentation="grid"][data-columns="3"] figure, div[data-presentation="grid"][data-columns="2"] figure, div[data-presentation="grid"][data-columns="1"] figure {
		width: 100%;
	}
}

@media only screen and (max-width: 375px) {
	div[data-presentation="grid"] figure > div {
		border: none;
		margin: 3px;
	}

	div[data-presentation="grid"] figure > div a img {
		border: none;
	}
}

div[data-presentation="grid"] figcaption div.caption {
	display: none;
}

div[data-presentation="grid"] figcaption ul.metadata li {
	list-style: none;
	margin: 0;
	max-width: 100%;
	overflow: hidden;
	padding: 0;
	text-overflow: ellipsis;
	white-space: nowrap;
}

div[data-presentation] figcaption ul.metadata li:empty {
	display: none;
}

div[data-presentation="grid"] figcaption ul.metadata {
	display: block;
	margin: 0;
	padding: 0 0 0px;
}


div[data-presentation="grid"] figcaption ul.metadata li:first-child {
	border: 0 solid var(--color-base-offset);
	border-top-width: 0px;
	padding-top: 0px;
}

div[data-presentation="grid"] figcaption ul.metadata li.metadata1 {
	display: block;
	font-size: 0.75rem; 
	font-weight: 300;
	line-height: 1.5em;
	text-align: center;
}

div[data-presentation="grid"] figcaption ul.metadata li.metadata2 {
	display: block;
	font-size: 0.75rem; 	
	font-weight: 400;
	line-height: 1.5em;
	text-align: center;
}

div[data-presentation="grid"] figcaption ul.metadata:empty {
	display: none;
}


/**
 * image presentation: img-comparison-slider
**************************/
img-comparison-slider {
	outline: none;
}

div[data-presentation="img-comparison-slider"] img-comparison-slider:focus-visible {
  --ring-offset-width: 2px;
	--ring-width: 4px;
}

div[data-presentation="img-comparison-slider"] {
	margin-bottom: 1.5em;
}

.pagination + div[data-presentation="img-comparison-slider"] {
	margin-top: 8px;
	margin-bottom: 8px;
}

div[data-presentation="img-comparison-slider"] + .pagination {
	margin-bottom: 1.5em;
}

div[data-presentation="img-comparison-slider"] .presentation-interior {
	display: grid;
	grid-template-columns: 1fr;
	grid-template-rows: 1fr;
	justify-items: center;
	row-gap: 1.5em;
}

div[data-presentation="img-comparison-slider"] figure.ic-figure {
	display: block;
	width: 100%;
}

div[data-presentation="img-comparison-slider"] img-comparison-slider {
	--common-shadow: 0px 0px 3px rgba(0, 0, 0, 0.5);
	--default-handle-color: #ffffff;
	--default-handle-opacity: 1;
	--default-handle-shadow: var(--common-shadow);
	--default-handle-width: 50px;
	--divider-color: #ffffff;
	--divider-shadow:  var(--common-shadow);
	--divider-width: 1px;

	border: 0px solid var(--color-base-offset);
	border-radius: 0px;
	box-shadow: none;
	direction: ltr;
	display: block;
	overflow: hidden;
	position: relative;
	visibility: hidden;
}

div[data-presentation="img-comparison-slider"] img-comparison-slider [slot="second"] {
	display: none;
}

div[data-presentation="img-comparison-slider"] img-comparison-slider.rendered [slot="second"] {
	display: unset;
}

div[data-presentation="img-comparison-slider"] img-comparison-slider.rendered {
	visibility: inherit;
}

div[data-presentation="img-comparison-slider"] figure.ic-figure div[slot] {
	background-color: var(--color-base);
	display: block;
	position: relative;
}

div[data-presentation="img-comparison-slider"] figure.ic-figure div[slot] div.label {
	background-color: rgba(0,0,0,0.75);
	border-radius: 8px;
	color: #ffffff;
	font-size: 0.75rem;
	font-weight: 400;
	line-height: 1.5em;
	margin: 4px;
	padding: 4px 8px;
	position: absolute;
	top: 0;
}

div[data-presentation="img-comparison-slider"] figure.ic-figure div[slot="first"] div.label {
	left: 0;
}

div[data-presentation="img-comparison-slider"] figure.ic-figure div[slot="second"] div.label {
	right: 0;
}

div[data-presentation="img-comparison-slider"] figure.ic-figure img-comparison-slider[direction="vertical"] div[slot="second"] div.label {
	top: auto;
	bottom: 0;
}

.ic-slot {
	margin: 0;
	position: relative;
}

.ic-slot::before {
	content: "";
	display: block;
	padding-top: var(--aspectRatio);
}

.ic-slot img {
	object-fit: contain;
	position: absolute; top: 0; right: 0; bottom: 0; left: 0;
	width: 100%; height: 100%;
}

div[data-presentation="img-comparison-slider"] figcaption {
	display: flex;
	flex-direction: column;
	gap: 8px;
	margin-top: 8px;
}

div[data-presentation="img-comparison-slider"] figcaption div.captions {
	align-items: first baseline;
	color: var(--color-contrast);
	font-size: 0.75rem;
	font-weight: 400;
	line-height: 1.5em;

	display: grid;
	grid-gap: 8px 12px;
	grid-template-columns: max-content 1fr;
}

div[data-presentation="img-comparison-slider"] figcaption div.captions > *:nth-child(2n + 1) {
	font-size: 0.75rem;
}

/** */



/**
 * image presentation: masonry
**************************/
div[data-presentation="masonry"] .essay-presentation-toolbar {
	border: 0 solid var(--color-base-offset);
	border-top-width: 1px;
	border-bottom-width: 1px;
	margin: 0 5px;
	width: calc(100% - (10px))
}

div[data-presentation="masonry"] {
	opacity: 0;
	margin: 0 -5px 1.5em;
	transition: opacity 0.2s ease-in-out;
}

@media only screen and (max-width: 640px) {
	div[data-presentation="masonry"] {
		margin-right: 0;
		margin-left: 0;
	}
}

div[data-presentation="masonry"] figure {
	box-sizing: border-box;
	flex: 0 0 auto;
	width: 25%;
}

div[data-presentation="masonry"] figure > div {
	margin: 5px;
}

div[data-presentation="masonry"] figure > div {
	background-color: transparent;
	border: 0px solid var(--color-base-offset);
	border-radius: 8px;
	box-shadow: 0 0 3px rgba(0,0,0,0.25);
}

div[data-presentation="masonry"] figure > div a {
	align-items: center;
	display: flex;
	justify-content: center;
	position: relative;
}

div[data-presentation="masonry"] figure > div a img {
	border: 5px solid transparent;
}

div[data-presentation="masonry"][data-columns="12"] figure, div[data-presentation="masonry"][data-columns="11"] figure, div[data-presentation="masonry"][data-columns="10"] figure, div[data-presentation="masonry"][data-columns="9"] figure, div[data-presentation="masonry"][data-columns="8"] figure, div[data-presentation="masonry"][data-columns="7"] figure, div[data-presentation="masonry"][data-columns="6"] figure, div[data-presentation="masonry"][data-columns="5"] figure, div[data-presentation="masonry"][data-columns="4"] figure {
	width: 25%;
}

@media only screen and (max-width: 1680px) {
	div[data-presentation="masonry"][data-columns="12"] figure, div[data-presentation="masonry"][data-columns="11"] figure, div[data-presentation="masonry"][data-columns="10"] figure, div[data-presentation="masonry"][data-columns="9"] figure, div[data-presentation="masonry"][data-columns="8"] figure, div[data-presentation="masonry"][data-columns="7"] figure, div[data-presentation="masonry"][data-columns="6"] figure, div[data-presentation="masonry"][data-columns="5"] figure, div[data-presentation="masonry"][data-columns="4"] figure {
		width: 25%;
	}
}

@media only screen and (max-width: 1440px) {
	div[data-presentation="masonry"][data-columns="12"] figure, div[data-presentation="masonry"][data-columns="11"] figure, div[data-presentation="masonry"][data-columns="10"] figure, div[data-presentation="masonry"][data-columns="9"] figure, div[data-presentation="masonry"][data-columns="8"] figure, div[data-presentation="masonry"][data-columns="7"] figure, div[data-presentation="masonry"][data-columns="6"] figure, div[data-presentation="masonry"][data-columns="5"] figure, div[data-presentation="masonry"][data-columns="4"] figure {
		width: 25%;
	}
}

@media only screen and (max-width: 1280px) {
	div[data-presentation="masonry"][data-columns="12"] figure, div[data-presentation="masonry"][data-columns="11"] figure, div[data-presentation="masonry"][data-columns="10"] figure, div[data-presentation="masonry"][data-columns="9"] figure, div[data-presentation="masonry"][data-columns="8"] figure, div[data-presentation="masonry"][data-columns="7"] figure, div[data-presentation="masonry"][data-columns="6"] figure, div[data-presentation="masonry"][data-columns="5"] figure, div[data-presentation="masonry"][data-columns="4"] figure, div[data-presentation="masonry"][data-columns="3"] figure {
		width: 33.333333333333%;
	}
}

@media only screen and (max-width: 1140px) {
	div[data-presentation="masonry"][data-columns="12"] figure, div[data-presentation="masonry"][data-columns="11"] figure, div[data-presentation="masonry"][data-columns="10"] figure, div[data-presentation="masonry"][data-columns="9"] figure, div[data-presentation="masonry"][data-columns="8"] figure, div[data-presentation="masonry"][data-columns="7"] figure, div[data-presentation="masonry"][data-columns="6"] figure, div[data-presentation="masonry"][data-columns="5"] figure, div[data-presentation="masonry"][data-columns="4"] figure, div[data-presentation="masonry"][data-columns="3"] figure {
		width: 33.333333333333%;
	}
}

@media only screen and (max-width: 1024px) {
	div[data-presentation="masonry"][data-columns="12"] figure, div[data-presentation="masonry"][data-columns="11"] figure, div[data-presentation="masonry"][data-columns="10"] figure, div[data-presentation="masonry"][data-columns="9"] figure, div[data-presentation="masonry"][data-columns="8"] figure, div[data-presentation="masonry"][data-columns="7"] figure, div[data-presentation="masonry"][data-columns="6"] figure, div[data-presentation="masonry"][data-columns="5"] figure, div[data-presentation="masonry"][data-columns="4"] figure, div[data-presentation="masonry"][data-columns="3"] figure {
		width: 33.333333333333%;
	}
}

@media only screen and (max-width: 992px) {
	div[data-presentation="masonry"][data-columns="12"] figure, div[data-presentation="masonry"][data-columns="11"] figure, div[data-presentation="masonry"][data-columns="10"] figure, div[data-presentation="masonry"][data-columns="9"] figure, div[data-presentation="masonry"][data-columns="8"] figure, div[data-presentation="masonry"][data-columns="7"] figure, div[data-presentation="masonry"][data-columns="6"] figure, div[data-presentation="masonry"][data-columns="5"] figure, div[data-presentation="masonry"][data-columns="4"] figure, div[data-presentation="masonry"][data-columns="3"] figure {
		width: 33.333333333333%;
	}
}

@media only screen and (max-width: 640px) {
	div[data-presentation="masonry"][data-columns="12"] figure, div[data-presentation="masonry"][data-columns="11"] figure, div[data-presentation="masonry"][data-columns="10"] figure, div[data-presentation="masonry"][data-columns="9"] figure, div[data-presentation="masonry"][data-columns="8"] figure, div[data-presentation="masonry"][data-columns="7"] figure, div[data-presentation="masonry"][data-columns="6"] figure, div[data-presentation="masonry"][data-columns="5"] figure, div[data-presentation="masonry"][data-columns="4"] figure, div[data-presentation="masonry"][data-columns="3"] figure, div[data-presentation="masonry"][data-columns="2"] figure, div[data-presentation="masonry"][data-columns="1"] figure {
		width: 100%;
	}
}

@media only screen and (max-width: 414px) {
	div[data-presentation="masonry"][data-columns="12"] figure, div[data-presentation="masonry"][data-columns="11"] figure, div[data-presentation="masonry"][data-columns="10"] figure, div[data-presentation="masonry"][data-columns="9"] figure, div[data-presentation="masonry"][data-columns="8"] figure, div[data-presentation="masonry"][data-columns="7"] figure, div[data-presentation="masonry"][data-columns="6"] figure, div[data-presentation="masonry"][data-columns="5"] figure, div[data-presentation="masonry"][data-columns="4"] figure, div[data-presentation="masonry"][data-columns="3"] figure, div[data-presentation="masonry"][data-columns="2"] figure, div[data-presentation="masonry"][data-columns="1"] figure {
		width: 100%;
	}
}

@media only screen and (max-width: 375px) {
	div[data-presentation="masonry"] figure > div {
		/*
		border: none;
		margin: 3px;
		*/
	}

	div[data-presentation="masonry"] figure > div a img {
		/* border: none; */
	}
}

.pagination + div[data-presentation="masonry"] {
	margin-bottom: 0;
}

div[data-presentation="masonry"] + .pagination {
	margin-bottom: 1.5em;
}

.pagination-masonry {
	opacity: 0;
	transition: opacity 0.2s ease-in-out;
}

div[data-presentation="masonry"] figcaption div.caption {
	display: none;
}

div[data-presentation="masonry"] figcaption ul.metadata li {
	list-style: none;
	margin: 0;
	max-width: 100%;
	overflow: hidden;
	padding: 0;
	text-overflow: ellipsis;
	white-space: nowrap;
}

div[data-presentation="masonry"] figcaption ul.metadata li:empty {
	display: none;
}

div[data-presentation="masonry"] figcaption ul.metadata {
	display: block;
	margin: 0;
	padding: 0 0 0px;
}

	div[data-presentation="masonry"] figcaption ul.metadata li {
		padding-right: 3px;
		padding-left: 3px;
	}

div[data-presentation="masonry"] figcaption ul.metadata li:first-child {
	border: 0 solid var(--color-base-offset);
	border-top-width: 0px;
	padding-top: 0px;
}

div[data-presentation="masonry"] figcaption ul.metadata li.metadata1 {
	display: block;
	font-size: 0.75rem; 
	font-weight: 400;
	line-height: 1.5em;
	text-align: center;
}

div[data-presentation="masonry"] figcaption ul.metadata li.metadata2 {
	display: block;
	font-size: 0.75rem; 	
	font-weight: 400;
	line-height: 1.5em;
	text-align: center;
}

div[data-presentation="masonry"] figcaption ul.metadata:empty {
	display: none;
}


/* bottom boundary, for clearing next content */
div[data-presentation="masonry"]::after {
	border-top: 1px solid transparent;
	content: "";
	display: block;
	height: 0;
	position: relative; top: -1px;
	z-index: -1;
}


/**
 * media
**************************/
div[data-presentation="media"] {
	margin: 1.5em auto;
	position: relative;
	width: 100%;
	z-index: 0;
}

.pagination + div[data-presentation="media"] {
	margin-block: 0;
}

div[data-presentation="media"] + .pagination {
	margin-block: 0 1.5em;
}

div[data-presentation="media"]::after {
	background-color: #2c2c2c;
	border: 1px solid #000000;
	border-radius: 6px;
	color: #ffffff;
	content: "Audio/Video Support is disabled.";
	display: block;
	font-size: 0.75rem;
	font-weight: 600;
	line-height: 3em;
	padding: 0 18px;
	text-align: center;
}

div[data-presentation="media"]:has(media-player:defined) {
	background: initial;
	border: initial;
	border-radius: initial;
	padding: initial;
}

div[data-presentation="media"]:has(media-player:defined)::after {
	content: "";
	display: none;
}

.kookaburra .vds-audio-layout,
.kookaburra [data-media-player][data-layout='video']:not([data-fullscreen]) {
	--default-bg: var(--default-bg);

	--audio-bg: var(--audio-bg);
	--audio-border: 1px solid var(--audio-border);
	--audio-filter: drop-shadow(0 2px 2px rgb(0 0 0 / 0.05)) drop-shadow(0 2px 2px rgb(0 0 0 / 0.05));

	--video-border: 1px solid var(--video-border);

	--audio-focus-ring: 
		var(--ring-offset-inset) 0px 0px 0px var(--ring-offset-width) var(--ring-offset-color),
		var(--ring-inset) 0px 0px var(--ring-blur) var(--ring-width) var(--ring-color)
	;
	--video-focus-ring:
		var(--ring-offset-inset) 0px 0px 0px var(--ring-offset-width) var(--ring-offset-color),
		var(--ring-inset) 0px 0px var(--ring-blur) var(--ring-width) var(--ring-color)
	;
}

.kookaburra [data-media-player][data-layout='video'] {
	--video-bg: var(--video-bg);
}

/**
 * image presentation: single / static
**************************/
div[data-presentation="single"] :focus-visible {
  --ring-offset-width: 2px;
	--ring-width: 4px;
}

div[data-presentation="single"],
div[data-presentation="static"] {
	margin: 0 0 1.5em;
}

.pagination + div[data-presentation="single"],
.pagination + div[data-presentation="static"] {
	margin-top: 8px;
	margin-bottom: 8px;
}

div[data-presentation="single"] + .pagination,
div[data-presentation="static"] + .pagination {
	margin-bottom: 1.5em;
}

div[data-presentation="single"] .presentation-interior,
div[data-presentation="static"] .presentation-interior {
	display: flex;
	flex-direction: column;
	gap: 1.5em;
}

div[data-presentation="single"] figure,
div[data-presentation="static"] figure {
	max-width: 100%;
	margin: 0;
	padding: 0;
}

div[data-presentation="single"] figure > div,
div[data-presentation="static"] figure > div {
	font-size: 0;
	text-align: center;
}

div[data-presentation="single"] figure a {
	display: inline-block;
	padding: 0;
}

div[data-presentation="single"] figure img,
div[data-presentation="static"] figure img {
	border: 2px solid rgb(135, 130, 130);
	border-radius: 0px;
	box-shadow: 0 0 3px rgba(0,0,0,0.25);
	margin: 0 auto;
}

div[data-presentation="single"] figcaption,
div[data-presentation="static"] figcaption {
	border: 0 solid var(--color-base-offset);
	border-width: 0 0 1px;
	margin-top: 8px;
	padding-bottom: 4px;
}

div[data-presentation="single"] figcaption div.caption,
div[data-presentation="static"] figcaption div.caption {
	display: flex;
	flex-direction: column;
	gap: 4px;

	font-size: 0.75rem; 
	font-weight: 400;
	line-height: 1.5em;
	text-align: center;
}

div[data-presentation="single"] figcaption div.caption > div:empty,
div[data-presentation="static"] figcaption div.caption > div:empty {
	display: none;
}

div[data-presentation="single"] figcaption ul.metadata {
	display: none;
}

[data-presentation="single"][data-align="center"],
[data-presentation="static"][data-align="center"] {
	margin-right: auto;
	margin-left: auto;
}

[data-presentation="single"][data-align="left"],
[data-presentation="static"][data-align="left"] {
	float: left;
	margin-right: 18px;
}

[data-presentation="single"][data-align="right"],
[data-presentation="static"][data-align="right"] {
	float: right;
	margin-left: 18px;
}

@media screen and (max-width: 800px) {
	[data-presentation="single"][data-align="left"],
	[data-presentation="single"][data-align="right"],
	[data-presentation="static"][data-align="left"],
	[data-presentation="static"][data-align="right"] {
		float: none;
		margin-right: auto;
		margin-left: auto;
	}

	[data-presentation="single"],
	[data-presentation="static"] {
		width: auto !important;
	}
}

div[data-presentation="grid"] figure > div div.thumbnail,
div[data-presentation="masonry"] figure > div div.thumbnail {
	position: relative;
}

div[data-presentation="grid"] figure > div div.thumbnail .thumbnail-actions,
div[data-presentation="masonry"] figure > div div.thumbnail .thumbnail-actions {
	--duration: 0.15s;
	--delay: 0s;
	--triggerSize: 21px;
	--triggerIconSize: calc(var(--triggerSize) - 3px);

	overflow: hidden;
	position: absolute; top: 0; right: 0; bottom: 0; left: 0;
}

div[data-presentation="grid"] figure > div div.thumbnail .thumbnail-actions:has(> div:empty),
div[data-presentation="masonry"] figure > div div.thumbnail .thumbnail-actions:has(> div:empty) {
	display: none;
}

div[data-presentation="grid"] figure > div div.thumbnail .thumbnail-actions *,
div[data-presentation="masonry"] figure > div div.thumbnail .thumbnail-actions * {
	all: unset;
}

div[data-presentation="grid"] figure > div div.thumbnail .thumbnail-actions > div,
div[data-presentation="masonry"] figure > div div.thumbnail .thumbnail-actions > div {
	background: transparent;
	display: grid;
	gap: 0;
	grid-template-columns: repeat(auto-fill, 25%);
	grid-template-columns: repeat(auto-fit, minmax(25%, 1fr));
	padding: 0;
	position: absolute; top: 0; right: 0; bottom: 0; left: 0;
	transform: translateX(calc(100% - var(--triggerSize))) translateY(calc(-100% + var(--triggerSize)));
	transition:
		background var(--duration) ease var(--delay),
		transform var(--duration) ease var(--delay)
	;
	z-index: 1;
}

div[data-presentation="grid"] figure > div div.thumbnail .thumbnail-actions > div:hover,
div[data-presentation="masonry"] figure > div div.thumbnail .thumbnail-actions > div:hover {
	background: rgba(0, 0, 0, 0.22);
	transform: translateX(0%) translateY(0%);
}

div[data-presentation="grid"] figure > div div.thumbnail .thumbnail-actions > div div,
div[data-presentation="masonry"] figure > div div.thumbnail .thumbnail-actions > div div {
	align-items: center;
	color: rgba(255, 255, 255, 0.41);
	cursor: pointer;
	display: flex;
	filter: none;
	height: var(--triggerSize); width: var(--triggerSize);
	justify-content: center;
	opacity: 1;
	position: absolute; bottom: 0; left: 0;
	transition: opacity var(--duration) ease var(--delay);
}
div[data-presentation="grid"] figure > div div.thumbnail .thumbnail-actions > div:hover div,
div[data-presentation="masonry"] figure > div div.thumbnail .thumbnail-actions > div:hover div {
	opacity: 0;
}

div[data-presentation="grid"] figure > div div.thumbnail .thumbnail-actions > div div svg,
div[data-presentation="masonry"] figure > div div.thumbnail .thumbnail-actions > div div svg {
	display: none;
	height: var(--triggerIconSize); width: var(--triggerIconSize);
}

div[data-presentation="grid"] figure > div div.thumbnail .thumbnail-actions > div div::after {
	border-top: 9px solid rgba(255, 255, 255, 0.41);
	border-left: 9px solid transparent;
	content: "";
	display: block;
	height: 0; width: 0;
	position: absolute;
	top: 0; right: 0;
}

div[data-presentation="grid"] figure > div div.thumbnail .thumbnail-actions > div a,
div[data-presentation="masonry"] figure > div div.thumbnail .thumbnail-actions > div a {
	align-items: center;
	background: transparent;
	color: rgba(255, 255, 255, 0.48);
	cursor: pointer;
	display: flex;
	justify-content: center;
	transition:
		background var(--duration) ease var(--delay),
		color var(--duration) ease var(--delay)
	;
}

div[data-presentation="grid"] figure > div div.thumbnail .thumbnail-actions > div:hover a,
div[data-presentation="masonry"] figure > div div.thumbnail .thumbnail-actions > div:hover a {
	background: rgba(0, 0, 0, 0.42);
}

div[data-presentation="grid"] figure > div div.thumbnail .thumbnail-actions > div a:hover,
div[data-presentation="masonry"] figure > div div.thumbnail .thumbnail-actions > div a:hover {
	background: rgba(255, 255, 0, 0.28);
	color: rgba(255, 255, 255, 0.48);
}

/* styles for touch devices */
@media (hover: none) and (pointer: coarse) {
	div[data-presentation="grid"] figure > div div.thumbnail .thumbnail-actions,
	div[data-presentation="masonry"] figure > div div.thumbnail .thumbnail-actions {
		display: none;
	}
}

/* **************************************************************************
   grid-framework-12col.css
   **************************************************************************/

*[class*="grid_"] {
	margin-left: 0 auto;
	width: auto;
	}

/* Always apply clearfix to container */
*[class*="grid_"]:before,
*[class*="grid_"]:after {
    content:"";
    display:table;
	}
*[class*="grid_"]:after {
    clear:both;
	}

.row {
	clear: both;
	margin: 0 auto;
	max-width: 100%;
	}

*[class*="col_"] {
	list-style: none;
	padding-left: 0;
	padding-right: 0;
	-moz-box-sizing: border-box;
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
	}

*[class*="push_"],
*[class*="pull_"] {
	position: relative;
	}
	
@media screen and ( min-width: 992px ) {

	*[class*="col_"] {
		float: left;
		}

/* Grid >> Children (Alpha ~ First, Omega ~ Last) */

.grid_12 *[class*="col_"] {
	padding-right: 24px;
	padding-left:  24px;
	}

*[class*="grid_"] .alpha {
	padding-left: 0;
	}

*[class*="grid_"] .omega {
	padding-right: 0;
	}

	/* Grid >> 12 Columns */
	
	.grid_12 .col_1 {
		width: 8.333333%;
		}
	
	.grid_12 .col_2 {
		width: 16.666667%;
		}
	
	.grid_12 .col_3 {
		width: 25%;
		}
	
	.grid_12 .col_4 {
		width: 33.333333%;
		}
	
	.grid_12 .col_5 {
		width: 41.666667%;
		}
	
	.grid_12 .col_6 {
		width: 50%;
		}
	
	.grid_12 .col_7 {
		width: 58.333333%;
		}
	
	.grid_12 .col_8 {
		width: 66.666667%;
		}
	
	.grid_12 .col_9 {
		width: 75%;
		}
	
	.grid_12 .col_10 {
		width: 83.333333%;
		}
	
	.grid_12 .col_11 {
		width: 91.666667%;
		}
	
	.grid_12 .col_12 {
		width: 100%;
		}

	/* Prefix Extra Space >> 12 Columns */

	.grid_12 .prefix_1 {
		margin-left: 8.333333%;
		}
	
	.grid_12 .prefix_2 {
		margin-left: 16.666667%;
		}
	
	.grid_12 .prefix_3 {
		margin-left:25%;
		}
	
	.grid_12 .prefix_4 {
		margin-left: 33.333333%;
		}
	
	.grid_12 .prefix_5 {
		margin-left: 41.666667%;
		}
	
	.grid_12 .prefix_6 {
		margin-left: 50%;
		}
	
	.grid_12 .prefix_7 {
		margin-left: 58.333333%;
		}
	
	.grid_12 .prefix_8 {
		margin-left: 66.666667%;
		}
	
	.grid_12 .prefix_9 {
		margin-left: 75%;
		}
	
	.grid_12 .prefix_10 {
		margin-left: 83.333333%;
		}
	
	.grid_12 .prefix_11 {
		margin-left: 91.666667%;
		}

	/* Suffix Extra Space >> 12 Columns */
	
	.grid_12 .suffix_1 {
		margin-right: 8.333333%;
		}
	
	.grid_12 .suffix_2 {
		margin-right: 16.666667%;
		}
	
	.grid_12 .suffix_3 {
		margin-right:25%;
		}
	
	.grid_12 .suffix_4 {
		margin-right: 33.333333%;
		}
	
	.grid_12 .suffix_5 {
		margin-right: 41.666667%;
		}
	
	.grid_12 .suffix_6 {
		margin-right: 50%;
		}
	
	.grid_12 .suffix_7 {
		margin-right: 58.333333%;
		}
	
	.grid_12 .suffix_8 {
		margin-right: 66.666667%;
		}
	
	.grid_12 .suffix_9 {
		margin-right: 75%;
		}
	
	.grid_12 .suffix_10 {
		margin-right: 83.333333%;
		}
	
	.grid_12 .suffix_11 {
		margin-right: 91.666667%;
		}

	/* Push Space >> 12 Columns */
	
	.grid_12 .push_1 {
		left: 8.333333%;
		}
	
	.grid_12 .push_2 {
		left: 16.666667%;
		}
	
	.grid_12 .push_3 {
		left: 25%;
		}
	
	.grid_12 .push_4 {
		left: 33.333333%;
		}
	
	.grid_12 .push_5 {
		left: 41.666667%;
		}
	
	.grid_12 .push_6 {
		left: 50%;
		}
	
	.grid_12 .push_7 {
		left: 58.333333%;
		}
	
	.grid_12 .push_8 {
		left: 66.666667%;
		}
	
	.grid_12 .push_9 {
		left: 75%;
		}
	
	.grid_12 .push_10 {
		left: 83.333333%;
		}
	
	.grid_12 .push_11 {
		left: 91.666667%;
		}

	/* Pull Space >> 12 Columns */
	
	.grid_12 .pull_1 {
		left: -8.333333%;
		}
	
	.grid_12 .pull_2 {
		left: -16.666667%;
		}
	
	.grid_12 .pull_3 {
		left: -25%;
		}
	
	.grid_12 .pull_4 {
		left: -33.333333%;
		}
	
	.grid_12 .pull_5 {
		left: -41.666667%;
		}
	
	.grid_12 .pull_6 {
		left: -50%;
		}
	
	.grid_12 .pull_7 {
		left: -58.333333;
		}
	
	.grid_12 .pull_8 {
		left: -66.666667%;
		}
	
	.grid_12 .pull_9 {
		left: -75%;
		}
	
	.grid_12 .pull_10 {
		left: -83.333333%;
		}
	
	.grid_12 .pull_11 {
		left: -91.666667%;
		}

	} /* min-width */

/**
** search results page
**************************/
.search-results-search-field input {
  margin-bottom: 12px;
}
/*
 * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 * Player
 * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 */

[data-media-player] {
  width: 100%;
  display: inline-flex;
  align-items: center;
  position: relative;
  contain: style;
  box-sizing: border-box;
  user-select: none;
}

[data-media-player] * {
  box-sizing: border-box;
}

:where([data-media-player][data-view-type='video']) {
  aspect-ratio: 16 / 9;
}

[data-media-player]:focus,
[data-media-player]:focus-visible {
  outline: none;
}

[data-media-player][data-view-type='video'][data-started]:not([data-controls]) {
  pointer-events: auto;
  cursor: none;
}

[data-media-player] slot {
  display: contents;
}

/*
 * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 * Provider
 * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 */

[data-media-provider] {
  display: flex;
  position: relative;
  box-sizing: border-box;
  align-items: center;
  border-radius: inherit;
  width: 100%;
  aspect-ratio: inherit;
  overflow: hidden;
}

[data-media-player]:not([data-view-type='audio']) [data-media-provider],
[data-media-player][data-fullscreen] [data-media-provider] {
  height: 100%;
}

[data-media-player][data-view-type='audio'] [data-media-provider] {
  display: contents;
  background-color: unset;
}

[data-media-provider] audio {
  width: 100%;
}

:where(video:not([width]):not([height]), iframe:not([width]):not([height])) {
  width: 100%;
  aspect-ratio: 16 / 9;
}

:where([data-media-provider] video),
:where([data-media-provider] iframe) {
  aspect-ratio: inherit;
  display: inline-block;
  height: auto;
  object-fit: contain;
  touch-action: manipulation;
  border-radius: inherit;
  width: 100%;
}

[data-media-provider] iframe {
  height: 100%;
}

[data-media-player][data-view-type='audio'] video,
[data-media-player][data-view-type='audio'] iframe {
  display: none;
}

[data-media-player][data-fullscreen] video {
  height: 100%;
}

[data-media-provider] iframe:not([src]) {
  display: none;
}

iframe.vds-youtube[data-no-controls] {
  height: 1000%;
}

.vds-blocker {
  position: absolute;
  inset: 0;
  width: 100%;
  height: auto;
  aspect-ratio: inherit;
  pointer-events: auto;
  border-radius: inherit;
  z-index: 1;
}

[data-ended] .vds-blocker {
  background-color: black;
}

.vds-icon:focus {
  outline: none;
}

/*
 * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 * Google Cast
 * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 */

.vds-google-cast {
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  color: #dedede;
  font-family: sans-serif;
  font-weight: 500;
}

.vds-google-cast svg {
  --size: max(18%, 40px);
  width: var(--size);
  height: var(--size);
  margin-bottom: 8px;
}

.vds-google-cast-info {
  font-size: calc(var(--media-height) / 100 * 6);
}

:where(.vds-buffering-indicator) {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  pointer-events: none;
  z-index: 1;
}

:where(.vds-buffering-indicator) :where(.vds-buffering-icon, .vds-buffering-spinner) {
  opacity: 0;
  pointer-events: none;
  transition: var(--media-buffering-transition, opacity 200ms ease);
}

:where(.vds-buffering-indicator)
  :where(.vds-buffering-icon, svg.vds-buffering-spinner, .vds-buffering-spinner svg) {
  width: var(--media-buffering-size, 96px);
  height: var(--media-buffering-size, 96px);
}

:where(.vds-buffering-indicator) :where(.vds-buffering-track, circle[data-part='track']) {
  color: var(--media-buffering-track-color, #f5f5f5);
  opacity: var(--media-buffering-track-opacity, 0.25);
  stroke-width: var(--media-buffering-track-width, 8);
}

:where(.vds-buffering-indicator) :where(.vds-buffering-track-fill, circle[data-part='track-fill']) {
  color: var(--media-buffering-track-fill-color, var(--media-brand));
  opacity: var(--media-buffering-track-fill-opacity, 0.75);
  stroke-width: var(--media-buffering-track-fill-width, 9);
  stroke-dasharray: 100;
  stroke-dashoffset: var(--media-buffering-track-fill-offset, 50);
}

:where([data-buffering]) :where(.vds-buffering-icon, .vds-buffering-spinner) {
  opacity: 1;
  animation: var(--media-buffering-animation, vds-buffering-spin 1s linear infinite);
}

@keyframes vds-buffering-spin {
  to {
    transform: rotate(360deg);
  }
}

@media (prefers-reduced-motion) {
  :where([data-buffering]) :where(.vds-buffering-icon, .vds-buffering-spinner) {
    animation-duration: 8s;
  }
}

/*
 * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 * Buttons
 * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 */

:where(.vds-button) {
  -webkit-tap-highlight-color: transparent;
  position: relative;
  display: inline-flex;
  justify-content: center;
  align-items: center;
  user-select: none;
  appearance: none;
  background: none;
  outline: none;
  border: none;
  border-radius: var(--media-button-border-radius, 8px);
  width: var(--media-button-size, 40px);
  height: var(--media-button-size, 40px);
  transition: transform 0.2s ease-out;
  contain: layout style;
  cursor: pointer;
  -webkit-user-select: none;
  -webkit-tap-highlight-color: transparent;
  touch-action: manipulation;
  flex-shrink: 0;
}

.vds-button {
  border: var(--media-button-border);
  color: var(--media-button-color, var(--media-controls-color, #f5f5f5));
  padding: var(--media-button-padding, 0px);
}

:where([data-fullscreen] .vds-button) {
  width: var(--media-fullscreen-button-size, 42px);
  height: var(--media-fullscreen-button-size, 42px);
}

@media screen and (max-width: 599px) {
  :where([data-fullscreen] .vds-button) {
    width: var(--media-sm-fullscreen-button-size, 42px);
    height: var(--media-sm-fullscreen-button-size, 42px);
  }
}

:where(.vds-button .vds-icon) {
  width: var(--media-button-icon-size, 80%);
  height: var(--media-button-icon-size, 80%);
  border-radius: var(--media-button-border-radius, 8px);
}

:where(.vds-menu-button .vds-icon) {
  display: flex !important;
}

:where(.vds-button[aria-hidden='true']) {
  display: none !important;
}

@media (hover: hover) and (pointer: fine) {
  .vds-button:hover {
    background-color: var(--media-button-hover-bg, rgb(255 255 255 / 0.2));
  }

  .vds-button:hover {
    transform: var(--media-button-hover-transform, scale(1.05));
    transition: var(--media-button-hover-transition, transform 0.2s ease-in);
  }

  .vds-button[aria-expanded='true'] {
    transform: unset;
  }
}

@media (pointer: coarse) {
  .vds-button:hover {
    border-radius: var(--media-button-touch-hover-border-radius, 100%);
    background-color: var(--media-button-touch-hover-bg, rgb(255 255 255 / 0.2));
  }
}

:where(.vds-button:focus) {
  outline: none;
}

:where(.vds-button[data-focus], .vds-button:focus-visible) {
  box-shadow: var(--media-focus-ring);
}

/*
 * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 * Live Button
 * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 */

:where(.vds-live-button) {
  min-width: auto;
  min-height: auto;
  width: var(--media-live-button-width, 40px);
  height: var(--media-live-button-height, 40px);
  padding: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  user-select: none;
  appearance: none;
  background: none;
  outline: none;
  border: none;
}

:where(.vds-live-button-text) {
  font-family: var(--media-font-family, sans-serif);
  font-size: var(--media-live-button-font-size, 12px);
  font-weight: var(--media-live-button-font-weight, 600);
  letter-spacing: var(--media-live-button-letter-spacing, 1.5px);
  transition: color 0.3s ease;
}

.vds-live-button-text {
  background-color: var(--media-live-button-bg, #8a8a8a);
  border-radius: var(--media-live-button-border-radius, 2px);
  color: var(--media-live-button-color, #161616);
  padding: var(--media-live-button-padding, 1px 4px);
}

:where(.vds-live-button[data-focus] .vds-live-button-text) {
  box-shadow: var(--media-focus-ring);
}

:where(.vds-live-button[data-edge]) {
  cursor: unset;
}

.vds-live-button[data-edge] .vds-live-button-text {
  background-color: var(--media-live-button-edge-bg, #dc2626);
  color: var(--media-live-button-edge-color, #f5f5f5);
}

@media (pointer: fine) {
  :where(.vds-live-button:hover) {
    background-color: unset;
  }
}

/*
 * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 * States
 * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 */

/* Play Button */
.vds-button:not([data-paused]) .vds-play-icon,
.vds-button[data-ended] .vds-play-icon,
.vds-button[data-paused] .vds-pause-icon,
.vds-button[data-ended] .vds-pause-icon,
.vds-button:not([data-ended]) .vds-replay-icon,
/* PIP Button */
.vds-button[data-active] .vds-pip-enter-icon,
.vds-button:not([data-active]) .vds-pip-exit-icon,
/* Fullscreen Button */
.vds-button[data-active] .vds-fs-enter-icon,
.vds-button:not([data-active]) .vds-fs-exit-icon,
/* Caption Button */
.vds-button:not([data-active]) .vds-cc-on-icon,
.vds-button[data-active] .vds-cc-off-icon,
/* Mute Button */
.vds-button:not([data-muted]) .vds-mute-icon,
.vds-button:not([data-state='low']) .vds-volume-low-icon,
.vds-button:not([data-state='high']) .vds-volume-high-icon {
  display: none;
}

/*
 * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 * Captions
 * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 */

:where(.vds-captions) {
  /* Recommended settings in the WebVTT spec (https://www.w3.org/TR/webvtt1). */
  --overlay-padding: var(--media-captions-padding, 1%);
  --cue-color: var(--media-user-text-color, var(--media-cue-color, white));
  --cue-bg-color: var(--media-user-text-bg, var(--media-cue-bg, rgba(0, 0, 0, 0.7)));
  --cue-default-font-size: var(--media-cue-font-size, calc(var(--overlay-height) / 100 * 4.5));
  --cue-font-size: calc(var(--cue-default-font-size) * var(--media-user-font-size, 1));
  --cue-line-height: var(--media-cue-line-height, calc(var(--cue-font-size) * 1.2));
  --cue-padding-x: var(--media-cue-padding-x, calc(var(--cue-font-size) * 0.6));
  --cue-padding-y: var(--media-cue-padding-x, calc(var(--cue-font-size) * 0.4));
  --cue-padding: var(--cue-padding-y) var(--cue-padding-x);
  position: absolute;
  inset: 0;
  z-index: 1;
  contain: layout style;
  margin: var(--overlay-padding);
  font-size: var(--cue-font-size);
  font-family: var(--media-user-font-family, sans-serif);
  box-sizing: border-box;
  pointer-events: none;
  user-select: none;
  word-spacing: normal;
  word-break: break-word;
}

:where([data-fullscreen][data-orientation='portrait'] .vds-captions) {
  --cue-default-font-size: var(--media-cue-font-size, calc(var(--overlay-width) / 100 * 4.5));
}

:where([data-view-type='audio'] .vds-captions) {
  position: relative;
  margin: 0;
}

:where(.vds-captions[aria-hidden='true']) {
  opacity: 0;
  visibility: hidden;
}

.vds-captions[data-example] {
  opacity: 1 !important;
  visibility: visible !important;
}

:where([data-view-type='video'] .vds-captions [data-part='cue-display'][data-example]) {
  --cue-text-align: center;
  --cue-width: 100%;
  --cue-top: 90%;
  --cue-left: 0%;
}

:where([data-view-type='audio'] .vds-captions [data-part='cue-display']) {
  --cue-width: 100%;
  position: relative !important;
}

/*
 * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 * VTT Cues
 * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 */

:where(.vds-captions [data-part='cue-display']) {
  position: absolute;
  direction: ltr;
  overflow: visible;
  contain: content;
  top: var(--cue-top);
  left: var(--cue-left);
  right: var(--cue-right);
  bottom: var(--cue-bottom);
  width: var(--cue-width, auto);
  height: var(--cue-height, auto);
  box-sizing: border-box;
  transform: var(--cue-transform);
  text-align: var(--cue-text-align);
  writing-mode: var(--cue-writing-mode, unset);
  white-space: pre-line;
  unicode-bidi: plaintext;
  min-width: min-content;
  min-height: min-content;
  background-color: var(--media-user-display-bg, var(--media-cue-display-bg));
  border-radius: var(--media-cue-display-border-radius);
}

.vds-captions [data-part='cue-display'] {
  padding: var(--media-cue-display-padding);
}

:where(.vds-captions[data-dir='rtl'] [data-part='cue-display']) {
  direction: rtl;
}

:where(.vds-captions [data-part='cue']) {
  display: inline-block;
  contain: content;
  font-variant: var(--media-user-font-variant);
  border: var(--media-cue-border, unset);
  border-radius: var(--media-cue-border-radius, 2px);
  backdrop-filter: var(--media-cue-backdrop, blur(8px));
  line-height: var(--cue-line-height);
  box-sizing: border-box;
  box-shadow: var(--media-cue-box-shadow, var(--cue-box-shadow));
  white-space: var(--cue-white-space, pre-wrap);
  outline: var(--cue-outline);
  text-shadow: var(--media-user-text-shadow, var(--cue-text-shadow));
}

.vds-captions [data-part='cue'] {
  background-color: var(--cue-bg-color);
  color: var(--cue-color);
  padding: var(--cue-padding);
}

:where(.vds-captions [data-part='cue-display'][data-vertical] [data-part='cue']) {
  --cue-padding: var(--cue-padding-x) var(--cue-padding-y);
}

/*
 * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 * VTT Regions
 * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 */

:where(.vds-captions [data-part='region']) {
  --anchor-x-percent: calc(var(--region-anchor-x) / 100);
  --anchor-x: calc(var(--region-width) * var(--anchor-x-percent));
  --anchor-y-percent: calc(var(--region-anchor-y) / 100);
  --anchor-y: calc(var(--region-height) * var(--anchor-y-percent));
  --vp-anchor-x: calc(var(--region-viewport-anchor-x) * 1%);
  --vp-anchor-y-percent: calc(var(--region-viewport-anchor-y) / 100);
  --vp-anchor-y: calc(var(--overlay-height) * var(--vp-anchor-y-percent));
  position: absolute;
  display: inline-flex;
  flex-flow: column;
  justify-content: flex-start;
  width: var(--region-width);
  height: var(--region-height);
  min-height: 0px;
  max-height: var(--region-height);
  writing-mode: horizontal-tb;
  top: var(--region-top, calc(var(--vp-anchor-y) - var(--anchor-y)));
  left: var(--region-left, calc(var(--vp-anchor-x) - var(--anchor-x)));
  right: var(--region-right);
  bottom: var(--region-bottom);
  overflow: hidden;
  overflow-wrap: break-word;
  box-sizing: border-box;
}

:where(.vds-captions [data-part='region'][data-active]) {
}

:where(.vds-captions [data-part='region'][data-scroll='up']) {
  justify-content: end;
}

:where(.vds-captions [data-part='region'][data-active][data-scroll='up']) {
  transition: top 0.433s;
}

:where(.vds-captions [data-part='region'] > [data-part='cue-display']) {
  position: relative;
  width: auto;
  left: var(--cue-offset);
  height: var(--cue-height, auto);
  text-align: var(--cue-text-align);
  unicode-bidi: plaintext;
  margin-top: 2px;
}

:where(.vds-captions [data-part='region'] [data-part='cue']) {
  position: relative;
  border-radius: 0px;
}

:where(.vds-chapter-title) {
  --color: var(--media-chapter-title-color, rgba(255 255 255 / 0.64));
  display: inline-block;
  font-family: var(--media-font-family, sans-serif);
  font-size: var(--media-chapter-title-font-size, 16px);
  font-weight: var(--media-chapter-title-font-weight, 400);
  color: var(--color);
  flex: 1 1 0%;
  padding-inline: 6px;
  overflow: hidden;
  text-align: start;
  white-space: nowrap;
  text-overflow: ellipsis;
}

.vds-chapter-title::before {
  content: var(--media-chapter-title-separator, '\2022');
  display: inline-block;
  margin-right: var(--media-chapter-title-separator-gap, 6px);
  color: var(--media-chapter-title-separator-color, var(--color));
}

.vds-chapter-title:empty::before {
  content: '';
  margin: 0;
}

/*
 * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 * Controls
 * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 */

:where(.vds-controls),
:where(.vds-controls-group) {
  position: relative;
  display: inline-block;
  width: 100%;
  box-sizing: border-box;
}

/*
 * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 * Audio Controls
 * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 */

:where([data-view-type='audio'] .vds-controls) {
  display: inline-block;
  max-width: 100%;
}

/*
 * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 * Video Controls
 * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 */

:where([data-view-type='video'] .vds-controls) {
  display: flex;
  position: absolute;
  flex-direction: column;
  inset: 0;
  width: 100%;
  height: 100%;
  z-index: 10;
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  padding: var(--media-controls-padding, 0px);
  transition: var(--media-controls-out-transition, opacity 0.2s ease-out);
}

:where([data-view-type='video'] .vds-controls[data-visible]) {
  opacity: 1;
  visibility: visible;
  transition: var(--media-controls-in-transition, opacity 0.2s ease-in);
}

:where(.vds-controls-spacer) {
  flex: 1 1 0%;
  pointer-events: none;
}

/*
 * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 * Gesture
 * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 */

:where(.vds-gestures) {
  display: contents;
}

:where(.vds-gesture) {
  position: absolute;
  display: block;
  contain: content;
  z-index: 0;
  opacity: 0;
  visibility: hidden;
  pointer-events: none !important;
}

:where(.vds-icon svg) {
  display: block;
  width: 100%;
  height: 100%;
  vertical-align: middle;
}

/*
 * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 * Keyboard Action
 * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 */

:where(.vds-kb-action.hidden) {
  opacity: 0;
}

/*
 * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 * Keyboard Text
 * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 */

:where(.vds-kb-text-wrapper) {
  text-align: center;
  position: absolute;
  left: 0;
  right: 0;
  top: var(--media-kb-text-top, 10%);
  z-index: 20;
  pointer-events: none;
}

:where(.vds-kb-text) {
  display: inline-block;
  font-size: var(--media-kb-text-size, 150%);
  font-family: var(--media-font-family, sans-serif);
  backdrop-filter: blur(2px);
  border-radius: var(--media-kb-border-radius, 2.5px);
  pointer-events: none;
}

.vds-kb-text {
  color: var(--media-kb-text-color, var(--default-color));
  background-color: var(--media-kb-text-bg, var(--default-bg));
  padding: var(--media-kb-text-padding, 10px 20px);
}

.light .vds-kb-text {
  --default-color: #1a1a1a;
  --default-bg: rgb(240 240 240 / 0.6);
}

.dark .vds-kb-text {
  --default-color: #f5f5f5;
  --default-bg: rgb(10 10 10 / 0.6);
}

:where(.vds-kb-text:empty) {
  display: none;
}

/*
 * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 * Keyboard Bezel
 * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 */

:where(.vds-kb-bezel) {
  --size: var(--media-kb-bezel-size, 52px);
  position: absolute;
  left: 50%;
  top: 45%;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  width: var(--size);
  height: var(--size);
  margin-left: calc(-1 * calc(var(--size) / 2));
  margin-right: calc(-1 * calc(var(--size) / 2));
  z-index: 20;
  backdrop-filter: blur(2px);
  background-color: var(--media-kb-bezel-bg, var(--default-bg));
  animation: var(--media-kb-bezel-animation, vds-bezel-fade 0.35s linear 1 normal forwards);
  border-radius: var(--media-kb-bezel-border-radius, calc(var(--size) / 2));
  pointer-events: none;
}

.vds-kb-bezel:not(:has(svg)) {
  display: none !important;
}

.light .vds-kb-bezel {
  --default-bg: rgb(255 255 255 / 0.6);
}

.dark .vds-kb-bezel {
  --default-bg: rgb(10 10 10 / 0.6);
}

@media (prefers-reduced-motion) {
  :where(.vds-kb-bezel) {
    animation: none;
  }
}

:where(.vds-kb-bezel:has(slot:empty)) {
  opacity: 0;
}

:where(.vds-kb-action[data-action='seek-forward'] .vds-kb-bezel) {
  top: 45%;
  left: unset;
  right: 10%;
}

:where(.vds-kb-action[data-action='seek-backward'] .vds-kb-bezel) {
  top: 45%;
  left: 10%;
}

/*
 * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 * Keyboard Icon
 * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 */

:where(.vds-kb-icon) {
  --size: var(--media-kb-icon-size, 38px);
  width: var(--size);
  height: var(--size);
}

.vds-kb-icon {
  color: var(--media-kb-icon-color, var(--default-color));
}

.light .vds-kb-icon {
  --default-color: #1a1a1a;
}

.dark .vds-kb-icon {
  --default-color: #f5f5f5;
}

@keyframes vds-bezel-fade {
  0% {
    opacity: 1;
  }
  100% {
    opacity: 0;
    transform: scale(2);
  }
}

/*
 * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 * Theme
 * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 */

:where(.vds-menu-items) {
  --color-inverse: var(--media-menu-color-inverse, var(--default-inverse));
  --color-gray-50: var(--media-menu-color-gray-50, var(--default-gray-50));
  --color-gray-100: var(--media-menu-color-gray-100, var(--default-gray-100));
  --color-gray-200: var(--media-menu-color-gray-200, var(--default-gray-200));
  --color-gray-300: var(--media-menu-color-gray-300, var(--default-gray-300));
  --color-gray-400: var(--media-menu-color-gray-400, var(--default-gray-400));

  --text-color: var(--media-menu-text-color, var(--default-text));
  --text-secondary-color: var(--media-menu-text-secondary-color, var(--default-text-secondary));

  --root-border: var(--media-menu-border, var(--default-root-border));
}

.light .vds-menu-items {
  --default-inverse: black;
  --default-gray-50: rgb(80 80 80 / 0.15);
  --default-gray-100: rgb(80 80 80 / 0.45);
  --default-gray-200: rgb(235 235 235 / 0.6);
  --default-gray-300: rgb(238 238 238);
  --default-gray-400: rgb(250 250 250);

  --default-text: #1a1a1a;
  --default-text-secondary: #6b6b6b;

  --default-root-border: 1px solid rgb(10 10 10 / 0.1);
}

.dark .vds-menu-items {
  --default-inverse: white;
  --default-gray-50: rgb(245 245 245 / 0.1);
  --default-gray-100: rgb(245 245 245 / 0.45);
  --default-gray-200: rgb(10 10 10 / 0.6);
  --default-gray-300: rgb(27 27 27);
  --default-gray-400: rgb(10 10 10);

  --default-text: #f5f5f5;
  --default-text-secondary: #8a8a8a;

  --default-root-border: 1px solid rgb(255 255 255 / 0.1);
}

:where(.vds-menu-items) {
  --font-family: var(--media-font-family, sans-serif);
  --font-size: var(--media-menu-font-size, 14px);
  --font-weight: var(--media-menu-font-weight, 500);

  --root-bg: var(--media-menu-bg, var(--color-gray-400));
  --root-padding: var(--media-menu-padding, 12px);
  --root-border-radius: var(--media-menu-border-radius, 4px);

  --divider: var(--media-menu-divider, 1px solid var(--color-gray-50));

  --section-bg: var(--media-menu-section-bg, var(--color-gray-300));
  --section-border: var(--media-menu-section-border);
  --section-divider: var(--media-menu-section-divider, var(--divider));

  --top-bar-bg: var(--media-menu-top-bar-bg, var(--color-gray-200));
  --top-bar-divider: var(--media-menu-divider, transparent);

  --text-hint-color: var(--media-menu-hint-color, var(--text-secondary-color));

  --chapter-divider: var(--media-chapters-divider, var(--divider));
  --chapter-active-bg: var(--media-chapters-item-active-bg, var(--color-gray-50));
  --chapter-active-border-left: var(--media-chapters-item-active-border-left);

  --chapter-progress-bg: var(--media-chapters-progress-bg, var(--color-inverse));

  --chapter-time-font-size: var(--media-chapters-time-font-size, 12px);
  --chapter-time-font-weight: var(--media-chapters-time-font-weight, 500);
  --chapter-time-gap: var(--media-chapters-time-gap, 6px);

  --chapter-duration-bg: var(--media-chapters-duration-bg);

  --item-border: var(--media-menu-item-border, 0);
  --item-bg: var(--media-menu-item-bg, transparent);
  --item-hover-bg: var(--media-menu-item-hover-bg, var(--color-gray-50));
  --item-icon-size: var(--media-menu-item-icon-size, 18px);
  --item-padding: var(--media-menu-item-padding, 10px);
  --item-min-height: var(--media-menu-item-height, 40px);
  --item-border-radius: var(--media-menu-item-border-radius, 2px);

  --scrollbar-track-bg: var(--media-menu-scrollbar-track-bg, transparent);
  --scrollbar-thumb-bg: var(--media-menu-scrollbar-thumb-bg, var(--color-gray-50));
  --webkit-scrollbar-bg: var(--color-gray-400);
  --webkit-scrollbar-track-bg: var(--media-menu-scrollbar-track-bg, var(--color-gray-50));

  --checkbox-bg: var(--media-menu-checkbox-bg, var(--color-gray-100));
  --checkbox-active-bg: var(--media-menu-checkbox-bg-active, #1ba13f);
  --checkbox-handle-bg: var(--media-menu-checkbox-handle-bg, #f5f5f5);
  --checkbox-handle-border: var(--media-menu-checkbox-handle-border);

  --radio-icon-color: var(--media-menu-radio-icon-color, var(--text-color));
}

/*
 * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 * Menu
 * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 */

:where(.vds-menu[data-root] media-menu[data-root]) {
  display: contents;
}

:where(.vds-menu) {
  font-family: var(--font-family);
  font-size: var(--font-size);
  font-weight: var(--font-weight);
}

:where(.vds-menu[data-disabled][data-root]) {
  display: none;
}

:where(.vds-menu[data-submenu]) {
  display: inline-block;
}

:where(.vds-menu-items:focus) {
  outline: none;
}

:where(.vds-menu-item:focus, .vds-radio:focus) {
  outline: none;
}

:where(
    .vds-menu-item:focus-visible,
    .vds-menu-item[data-focus],
    .vds-radio:focus-visible,
    .vds-radio[data-focus]
  ) {
  outline: none;
  box-shadow: var(--media-focus-ring);
}

:where(.vds-menu[data-open] .vds-tooltip-content) {
  display: none !important;
}

.vds-menu-items [data-hidden] {
  display: none !important;
}

/*
 * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 * Scroll
 * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 */

@media (prefers-reduced-motion: no-preference) {
  :where(.vds-menu-items) {
    scroll-behavior: smooth;
  }
}

:where(.vds-menu-items) {
  box-sizing: border-box;
  min-width: var(--media-menu-min-width, 280px);
  scrollbar-width: thin;
  scrollbar-color: var(--scrollbar-thumb-bg) var(--scrollbar-track-bg);
  transform: translate3d(0, 0, 0);
}

:where(.vds-menu-items)::-webkit-scrollbar {
  background-color: var(--webkit-scrollbar-bg);
  border-radius: var(--root-border-radius);
  height: 6px;
  width: 5px;
}

:where(.vds-menu-items)::-webkit-scrollbar-track {
  background-color: var(--webkit-scrollbar-track-bg);
  border-radius: 4px;
}

:where(.vds-menu-items)::-webkit-scrollbar-thumb {
  background-color: var(--scrollbar-thumb-bg);
  border-radius: 4px;
}

:where(.vds-menu-items)::-webkit-scrollbar-corner {
  background-color: var(--scrollbar-thumb-bg);
}

/*
 * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 * Menu Button
 * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 */

:where(.vds-menu-button) {
  outline: none;
  box-sizing: border-box;
}

:where(.vds-menu-button .vds-rotate-icon) {
  transition: transform 0.2s ease-out;
}

:where(.vds-menu-button[aria-expanded='true'] .vds-rotate-icon) {
  transform: rotate(var(--media-menu-icon-rotate-deg, 90deg));
  transition: transform 0.2s ease-in;
}

:where(.vds-menu-button) {
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

@media (prefers-reduced-motion) {
  :where(.vds-menu-button .vds-rotate-icon) {
    transition: unset;
  }
}

/*
 * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 * Menu Items
 * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 */

:where(.vds-menu-items) {
  display: flex;
  align-items: center;
  flex-direction: column;
  font-family: var(--font-family);
  font-size: var(--font-size);
  font-weight: var(--font-weight);
  transition: height 0.35s ease;
}

@media (prefers-reduced-motion) {
  :where(.vds-menu-items) {
    transition: unset;
  }
}

:where(.vds-menu-items[data-root]) {
  background-color: var(--root-bg);
  border-radius: var(--root-border-radius);
  box-shadow: var(--media-menu-box-shadow);
  backdrop-filter: blur(4px);
  height: var(--menu-height, auto);
  will-change: width, height;
  overflow-y: auto;
  overscroll-behavior: contain;
  opacity: 0;
  z-index: 9999999;
  box-sizing: border-box;
  max-height: var(--media-menu-max-height, 250px);
  filter: var(
    --media-menu-filter,
    drop-shadow(0 4px 3px rgb(0 0 0 / 0.07)) drop-shadow(0 2px 2px rgb(0 0 0 / 0.06))
  );
}

.vds-menu-items[data-root] {
  border: var(--root-border);
  padding: var(--root-padding);
}

:where([data-view-type='video']) :where(.vds-menu-items[data-root]) {
  max-height: var(--media-menu-video-max-height, calc(var(--player-height) * 0.7));
}

:where(.vds-menu-items[data-transition='height']) {
  --scrollbar-thumb-bg: rgba(0, 0, 0, 0);
  pointer-events: none;
  overflow: hidden;
}

.vds-menu-button[aria-disabled='true'],
.vds-menu-item[aria-disabled='true'],
.vds-menu-item[data-disabled] {
  display: none;
}

/*
 * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 * Menu Items Animation
 * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 */

:where(.vds-menu-items[data-root]) {
  --enter-transform: translateY(0px);
  --exit-transform: translateY(12px);
}

/* Mobile Popup */
:where(.vds-menu-items[data-root]:not([data-placement])) {
  --enter-transform: translateY(-24px);
}

:where(.vds-menu-items[data-root][aria-hidden='true']) {
  animation: var(--media-menu-exit-animation, vds-menu-exit 0.2s ease-out);
}

:where(.vds-menu-items[data-root][aria-hidden='false']) {
  animation: var(--media-menu-enter-animation, vds-menu-enter 0.3s ease-out);
  animation-fill-mode: forwards;
}

/* Bottom */
:where(.vds-menu-items[data-placement~='bottom']) {
  --enter-transform: translateY(0);
  --exit-transform: translateY(-12px);
}

@keyframes vds-menu-enter {
  from {
    opacity: 0;
    transform: var(--exit-transform);
  }
  to {
    opacity: 1;
    transform: var(--enter-transform);
  }
}

@keyframes vds-menu-exit {
  from {
    opacity: 1;
    transform: var(--enter-transform);
  }
  to {
    opacity: 0;
    transform: var(--exit-transform);
  }
}

@media (prefers-reduced-motion) {
  :where(.vds-menu-items) {
    animation: none;
    opacity: 1;
  }
}

/*
 * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 * Menu Portal
 * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 */

:where(media-menu-portal) {
  display: contents;
}

:where(.vds-menu-items[data-root]:not([data-placement])) {
  position: fixed;
  left: 16px;
  right: 16px;
  top: unset;
  bottom: 0;
  max-height: var(--media-sm-menu-portrait-max-height, 40vh);
  max-height: var(--media-sm-menu-portrait-max-height, 40dvh);
}

:where(.vds-menu-items[data-root]:not([data-placement])) {
  max-width: 480px;
  margin: 0 auto;
}

@media (orientation: landscape) and (pointer: coarse) {
  :where(.vds-menu-items[data-root]:not([data-placement])) {
    max-height: var(--media-sm-menu-landscape-max-height, min(70vh, 400px));
    max-height: var(--media-sm-menu-landscape-max-height, min(70dvh, 400px));
  }
}

/*
 * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 * Submenu
 * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 */

:where(.vds-menu[data-submenu] .vds-menu-button) {
  display: flex;
  align-items: center;
  justify-content: flex-start;
}

:where(.vds-menu-items[data-submenu]) {
  width: 100%;
}

:where(.vds-menu[aria-hidden='true']),
:where(.vds-menu-items[data-submenu][aria-hidden='true']) {
  display: none;
}

/*
 * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 * Menu Item
 * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 */

:where(.vds-menu-item, .vds-radio) {
  position: relative;
  -webkit-tap-highlight-color: transparent;
  user-select: none;
  display: flex;
  align-items: center;
  justify-content: left;
  width: 100%;
  appearance: none;
  border: 0;
  border-radius: var(--item-border-radius);
  box-sizing: border-box;
  min-height: var(--item-min-height);
  font-size: var(--font-size);
  outline: none;
}

.vds-menu-item,
.vds-radio {
  color: var(--text-color);
  background-color: var(--item-bg);
  padding: var(--item-padding);
}

.vds-menu-item:focus-visible,
.vds-menu-item[data-focus],
.vds-radio:focus-visible,
.vds-radio[data-focus] {
  cursor: pointer;
  background-color: var(--item-hover-bg);
}

@media (hover: hover) and (pointer: fine) {
  .vds-menu-item[role]:hover,
  .vds-radio:hover {
    cursor: pointer;
    background-color: var(--item-hover-bg);
  }
}

:where(.vds-menu-items[data-submenu]) {
  align-items: flex-start;
  justify-content: center;
  flex-direction: column;
}

:where(.vds-menu-item[aria-expanded='true']) {
  font-weight: bold;
  border-radius: 0;
  border-top-left-radius: var(--item-border-radius);
  border-top-right-radius: var(--item-border-radius);
}

.vds-menu-item[aria-expanded='true'] {
  border-bottom: var(--top-bar-divider);
}

:where(.vds-menu-item[aria-expanded='true']) {
  position: sticky;
  top: calc(-1 * var(--root-padding));
  left: 0;
  width: 100%;
  z-index: 10;
  backdrop-filter: blur(4px);
  margin-bottom: 4px;
}

.vds-menu-item[aria-expanded='true'] {
  background-color: var(--top-bar-bg);
}

/*
 * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 * Menu Item Parts
 * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 */

:where(.vds-menu-item-label) {
  flex: 1 0 0%;
  text-align: start;
}

:where(.vds-menu-item .vds-icon, .vds-radio .vds-icon) {
  --size: var(--item-icon-size);
  width: var(--size);
  height: var(--size);
  margin-right: var(--media-menu-item-icon-spacing, 6px);
}

:where(.vds-menu-open-icon, .vds-menu-close-icon) {
  --size: var(--media-menu-arrow-icon-size, 18px);
  width: var(--size);
  height: var(--size);
}

:where(.vds-menu-item-hint, .vds-menu-open-icon, .vds-radio-hint) {
  color: var(--text-hint-color);
  font-size: var(--media-menu-hint-font-size, 13px);
  font-weight: var(--media-menu-hint-font-weight, 400);
}

:where(.vds-menu-items .vds-menu-open-icon) {
  margin-right: 0;
}

:where(.vds-menu-items) :where(.vds-menu-item-hint, .vds-menu-open-icon) {
  margin-left: auto;
}

:where(.vds-menu-items) :where(.vds-menu-item-hint + .vds-menu-open-icon),
:where(.vds-menu-item-hint + media-icon .vds-menu-open-icon),
:where(.vds-menu-item-hint + slot > .vds-menu-open-icon) {
  margin-left: 2px;
}

:where(.vds-menu-item[aria-hidden='true']),
:where(.vds-menu-item[aria-expanded='true'] .vds-menu-open-icon) {
  display: none !important;
}

:where(.vds-menu-items)
  :where(.vds-menu-item[aria-disabled='true'], .vds-menu-item[data-disabled])
  :where(.vds-menu-open-icon) {
  opacity: 0;
}

:where(.vds-menu-close-icon),
:where(.vds-menu-item[aria-expanded='true'] > .vds-icon) {
  display: none !important;
}

:where(.vds-menu-item[aria-expanded='true'] .vds-menu-close-icon) {
  display: inline !important;
  margin-left: calc(-1 * var(--item-padding) / 2);
}
/*
 * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 * Checkbox
 * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 */

:where(.vds-menu-checkbox) {
  --checkbox-width: var(--media-menu-checkbox-width, 40px);
  --checkbox-height: var(--media-menu-checkbox-height, 18px);
  --checkbox-top: calc((var(--checkbox-height) - var(--checkbox-diameter)) / 2);
  --checkbox-diameter: var(
    --media-menu-checkbox-handle-diameter,
    calc(var(--checkbox-height) - 2px)
  );
  --checkbox-gap: var(--media-menu-checkbox-gap, 2.5px);
  position: relative;
  display: inline-block;
  width: var(--checkbox-width);
  height: var(--checkbox-height);
  border-radius: calc(var(--checkbox-height) / 2);
  transition: 0.3s all ease-in-out;
  box-sizing: border-box;
  cursor: pointer;
  pointer-events: auto;
}

.vds-menu-checkbox {
  background-color: var(--checkbox-bg);
}

:where(.vds-menu-checkbox:focus-visible) {
  outline: none;
  box-shadow: var(--media-focus-ring);
}

.vds-menu-checkbox[aria-checked='true'] {
  background-color: var(--checkbox-active-bg);
}

:where(.vds-menu-checkbox)::after {
  content: '';
  display: inline-block;
  width: var(--checkbox-diameter);
  height: var(--checkbox-diameter);
  border-radius: calc(var(--checkbox-diameter) / 2);
  position: absolute;
  top: var(--checkbox-top);
  transform: translateX(var(--checkbox-gap));
  transition: 0.3s all ease-in-out;
  border: var(--checkbox-handle-border);
  box-sizing: border-box;
}

.vds-menu-checkbox::after {
  background-color: var(--checkbox-handle-bg);
}

:where(.vds-menu-checkbox[aria-checked='true'])::after {
  transform: translateX(
    calc(var(--checkbox-width) - var(--checkbox-diameter) - var(--checkbox-gap))
  );
}

@media (prefers-reduced-motion: no-preference) {
  :where(.vds-menu-checkbox[data-active])::after {
    width: calc(var(--checkbox-width) - calc(var(--checkbox-gap) * 2));
  }
}

:where(.vds-menu-checkbox[aria-checked='true'][data-active])::after {
  transform: translateX(var(--checkbox-gap));
}

/*
 * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 * Slider
 * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 */

:where(.vds-menu-items .vds-slider) {
  --media-slider-track-bg: var(--media-menu-slider-track-bg, var(--color-gray-50));
  --media-slider-track-fill-bg: var(--media-menu-slider-track-fill-bg, var(--color-inverse));
  --media-slider-height: var(--media-menu-slider-height, 32px);
  --track-focus-height: var(--track-height) !important;
}

:where(.vds-menu-items .vds-slider-thumb) {
  opacity: 1 !important;
}

:where(.vds-menu-slider-item.group) {
  flex-direction: column;
}

:where(.vds-menu-slider-title) {
  margin-top: 4px;
}

:where(.vds-menu-slider-body) {
  width: 100%;
  display: flex;
  align-items: center;
  margin-top: 6px;
}

:where(.vds-menu-slider-item .vds-icon) {
  margin: 0;
  color: var(--text-hint-color);
}

:where(
    .vds-menu-slider-item[data-min] .vds-icon.down,
    .vds-menu-slider-item[data-max] .vds-icon.up
  ) {
  color: var(--text-color);
  animation: 0.6s ease-in-out vds-slider-icon;
  transition: all 1.2s ease;
}

@keyframes vds-slider-icon {
  0% {
    transform: scale(1);
  }
  50% {
    transform: scale(1.25);
  }
  100% {
    transform: scale(1);
  }
}

:where(.vds-menu-items .vds-slider-track-fill) {
  transition: opacity 0.3s ease;
}

:where(.vds-menu-items .vds-slider[data-active] .vds-slider-track-fill) {
  opacity: 0;
}

/*
 * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 * Radio
 * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 */

:where(.vds-radio-group) {
  box-sizing: border-box;
  width: 100%;
  display: flex;
  flex-direction: column;
}

.vds-radio {
  cursor: pointer;
  contain: content;
  padding-left: calc(var(--item-icon-size) + var(--item-padding));
}

.vds-radio[aria-checked='true'] {
  padding-left: 0;
}

.vds-radio .vds-icon {
  display: none;
  color: var(--radio-icon-color);
}

.vds-radio[aria-checked='true'] .vds-icon {
  display: inline-block;
  margin-left: 6px;
}

:where(.vds-radio-hint) {
  margin-left: auto;
}

/*
 * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 * Color Picker
 * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 */

.vds-color-picker {
  width: 32px;
  height: 32px;
  border: 0;
  background-color: transparent;
  outline: none;
}

.vds-color-picker::-webkit-color-swatch {
  border-radius: 2px;
}

.vds-color-picker::-moz-color-swatch {
  border-radius: 2px;
}

.vds-color-picker:focus-visible::-webkit-color-swatch {
  box-shadow: var(--media-focus-ring);
}

.vds-color-picker:focus-visible::-moz-color-swatch {
  box-shadow: var(--media-focus-ring);
}

/*
 * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 * Menu Section
 * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 */

:where(.vds-menu-section) {
  width: 100%;
}

:where(.vds-menu-item + .vds-menu-section) {
  margin-top: 8px;
}

:where(.vds-menu-section + .vds-menu-section) {
  margin-top: 24px;
}

:where(.vds-menu-section:first-child) {
  margin-top: 8px;
}

:where(.vds-menu-section:last-child) {
  margin-bottom: 8px;
}

:where(.vds-menu-section-title),
:where(.vds-menu-slider-title) {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  color: var(--text-secondary-color);
  font-size: var(--media-menu-section-header-font-size, 12px);
  font-weight: var(--media-menu-section-header-font-weight, 500);
  padding-inline: 2px;
}

:where(.vds-menu-section-body) {
  width: 100%;
}

:where(.vds-menu-section-title + .vds-menu-section-body) {
  margin-top: var(--media-menu-section-gap, 8px);
}

.vds-menu-section-body {
  background-color: var(--section-bg);
  border: var(--section-border);
  border-radius: var(--media-menu-section-border-radius, 2px);
}

:where(.vds-menu-section:not([data-open]) .vds-menu-item:not(:last-child)) {
  border-bottom: var(--section-divider);
}

:where(.vds-menu-section-body .vds-menu:last-child > .vds-menu-item) {
  border-bottom: unset;
}

.vds-menu-section[data-open],
.vds-menu-section[data-open] > .vds-menu-section-body {
  display: contents !important;
  background-color: transparent !important;
}

.vds-menu-section[data-open] > .vds-menu-section-title,
.vds-menu-section[data-open] > .vds-menu-section-body > :not([data-open]) {
  display: none;
}

/*
 * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 * Chapters Menu
 * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 */

:where(.vds-chapters-menu-items) {
  min-width: var(--media-chapters-min-width, var(--media-menu-min-width, 220px));
}

.vds-chapters-menu-items {
  padding: var(--media-chapters-padding, 0);
}

:where(.vds-menu-items:has(.vds-chapters-radio-group[data-thumbnails])) {
  min-width: var(--media-chapters-with-thumbnails-min-width, 300px);
}

:where(.vds-chapter-radio) {
  border-radius: 0;
}

.vds-chapter-radio {
  border-bottom: var(--chapter-divider);
  padding: var(--item-padding);
}

.vds-chapter-radio[aria-checked='true'] {
  padding-left: var(--item-padding);
}

:where(.vds-chapter-radio:last-child) {
  border-bottom: 0;
}

.vds-chapter-radio[aria-checked='true'] {
  background-color: var(--chapter-active-bg);
  border-left: var(--chapter-active-border-left);
}

:where(.vds-chapter-radio[aria-checked='true']):after {
  content: ' ';
  width: var(--progress);
  height: var(--media-chapters-progress-height, 4px);
  position: absolute;
  bottom: 0;
  left: 0;
}

.vds-chapter-radio[aria-checked='true']:after {
  border-radius: var(--media-chapters-progress-border-radius, 0);
  background-color: var(--chapter-progress-bg);
}

.vds-chapters-radio-group :where(.vds-thumbnail) {
  margin-right: var(--media-chapters-thumbnail-gap, 12px);
  flex-shrink: 0;
  min-width: var(--media-chapters-thumbnail-min-width, 100px);
  min-height: var(--media-chapters-thumbnail-min-height, 56px);
  max-width: var(--media-chapters-thumbnail-max-width, 120px);
  max-height: var(--media-chapters-thumbnail-max-height, 68px);
}

.vds-chapters-radio-group .vds-thumbnail {
  border: var(--media-chapters-thumbnail-border, 0);
}

:where(.vds-chapters-radio-group .vds-chapter-radio-label) {
  color: var(--text-secondary-color);
  font-size: var(--font-size);
  font-weight: var(--font-weight);
  white-space: nowrap;
}

:where(.vds-chapter-radio[aria-checked='true'] .vds-chapter-radio-label) {
  color: var(--text-color);
}

:where(.vds-chapters-radio-group .vds-chapter-radio-start-time) {
  display: inline-block;
  letter-spacing: var(--media-chapters-start-time-letter-spacing, 0.4px);
  border-radius: var(--media-chapters-start-time-border-radius, 2px);
  font-size: var(--chapter-time-font-size);
  font-weight: var(--chapter-time-font-weight);
  margin-top: var(--chapter-time-gap);
}

.vds-chapters-radio-group .vds-chapter-radio-start-time {
  color: var(--text-secondary-color);
  background-color: var(--section-bg);
  padding: var(--media-chapters-start-time-padding, 1px 4px);
}

:where(.vds-chapters-radio-group .vds-chapter-radio-duration) {
  color: var(--text-hint-color);
  font-size: var(--chapter-time-font-size);
  font-weight: var(--chapter-time-font-weight);
  margin-top: var(--chapter-time-gap);
}

.vds-chapters-radio-group .vds-chapter-radio-duration {
  background-color: var(--chapter-duration-bg);
  border-radius: var(--media-chapters-duration-border-radius, 2px);
}

.vds-chapters-radio-group:not([data-thumbnails]) :where(.vds-thumbnail, media-thumbnail) {
  display: none;
}

:where(.vds-chapter-radio-content) {
  display: flex;
  align-items: flex-start;
  flex-direction: column;
}

:where(.vds-chapters-radio-group:not([data-thumbnails]) .vds-chapter-radio-content) {
  width: 100%;
  flex-direction: row;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
}

:where(.vds-chapters-radio-group:not([data-thumbnails]) .vds-chapter-radio-start-time) {
  margin-top: 0;
  margin-left: auto;
}

:where(.vds-chapters-radio-group:not([data-thumbnails]) .vds-chapter-radio-duration) {
  margin-top: 4px;
  flex-basis: 100%;
}

.vds-menu-items[data-keyboard] .vds-chapters-radio-group:focus-within {
  padding: var(--media-chapters-focus-padding, 4px);
}

/*
 * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 * Poster
 * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 */

:where(.vds-poster) {
  display: block;
  contain: content;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  left: 0;
  opacity: 0;
  width: 100%;
  height: 100%;
  z-index: 1;
  border: 0;
  pointer-events: none;
  box-sizing: border-box;
  transition: opacity 0.2s ease-out;
  background-color: var(--media-poster-bg, black);
}

:where(.vds-poster img) {
  object-fit: inherit;
  object-position: inherit;
  pointer-events: none;
  user-select: none;
  -webkit-user-select: none;
  box-sizing: border-box;
}

.vds-poster :where(img) {
  border: 0;
  width: 100%;
  height: 100%;
  object-fit: contain;
}

:where(.vds-poster[data-hidden]) {
  display: none;
}

:where(.vds-poster[data-visible]) {
  opacity: 1;
}

.vds-poster:not(:defined),
.vds-poster img:not([src]) {
  display: none;
}

/*
 * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 * Sliders
 * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 */

:where(.vds-slider) {
  --width: var(--media-slider-width, 100%);
  --height: var(--media-slider-height, 48px);

  --thumb-size: var(--media-slider-thumb-size, 15px);
  --thumb-focus-size: var(--media-slider-focused-thumb-size, calc(var(--thumb-size) * 1.1));

  --track-width: var(--media-slider-track-width, 100%);
  --track-height: var(--media-slider-track-height, 5px);
  --track-focus-width: var(--media-slider-focused-track-width, var(--track-width));
  --track-focus-height: var(--media-slider-focused-track-height, calc(var(--track-height) * 1.25));

  display: inline-flex;
  align-items: center;
  width: var(--width);
  height: var(--height);
  /** Prevent thumb flowing out of slider. */
  margin: 0 calc(var(--thumb-size) / 2);
  position: relative;
  contain: layout style;
  outline: none;
  pointer-events: auto;
  cursor: pointer;
  user-select: none;
  touch-action: none;
  -webkit-user-select: none;
  -webkit-tap-highlight-color: transparent;
}

:where(.vds-slider[aria-hidden='true']) {
  display: none !important;
}

:where(.vds-slider[aria-disabled='true']) {
  cursor: unset;
}

:where(.vds-slider:focus) {
  outline: none;
}

:where(.vds-slider:not([data-chapters])[data-focus], .vds-slider:not([data-chapters]):focus-visible)
  :where(.vds-slider-track) {
  box-shadow: var(--media-focus-ring);
}

:where(.vds-slider .vds-slider-track) {
  z-index: 0;
  position: absolute;
  width: var(--track-width);
  height: var(--track-height);
  top: 50%;
  left: 0;
  border-radius: var(--media-slider-track-border-radius, 2px);
  transform: translateY(-50%) translateZ(0);
  background-color: var(--media-slider-track-bg, rgb(255 255 255 / 0.3));
  contain: strict;
}

:where(.vds-slider[data-focus], .vds-slider:focus-visible) :where(.vds-slider-track) {
  outline-offset: var(--thumb-size);
}

:where(.vds-slider:not([data-chapters])[data-active] .vds-slider-track) {
  width: var(--track-focus-width);
  height: var(--track-focus-height);
}

:where(.vds-slider .vds-slider-track-fill) {
  z-index: 2; /** above track and track progress. */
  background-color: var(--media-slider-track-fill-bg, var(--media-brand));
  width: var(--slider-fill, 0%);
  will-change: width;
}

:where(.vds-slider .vds-slider-thumb) {
  position: absolute;
  top: 50%;
  left: var(--slider-fill);
  opacity: 0;
  contain: layout size style;
  width: var(--thumb-size);
  height: var(--thumb-size);
  border: var(--media-slider-thumb-border, 1px solid #cacaca);
  border-radius: var(--media-slider-thumb-border-radius, 9999px);
  background-color: var(--media-slider-thumb-bg, #fff);
  transform: translate(-50%, -50%) translateZ(0);
  transition: opacity 0.15s ease-in;
  pointer-events: none;
  will-change: left;
  z-index: 2; /** above track fill. */
}

:where(.vds-slider[data-dragging], .vds-slider[data-focus], .vds-slider:focus-visible)
  :where(.vds-slider-thumb) {
  box-shadow: var(--media-slider-focused-thumb-shadow, 0 0 0 4px hsla(0, 0%, 100%, 0.4));
}

:where(.vds-slider[data-active] .vds-slider-thumb) {
  opacity: 1;
  transition: var(--media-slider-thumb-transition, opacity 0.2s ease-in, box-shadow 0.2s ease);
}

:where(.vds-slider[data-dragging] .vds-slider-thumb) {
  width: var(--thumb-focus-size);
  height: var(--thumb-focus-size);
}

/*
 * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 * Slider Value
 * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 */

:where(.vds-slider-value) {
  display: inline-block;
  contain: content;
  font-size: 14px;
  font-family: var(--media-font-family, sans-serif);
}

/*
 * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 * Slider Thumbnail
 * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 */

:where(.vds-slider-thumbnail) {
  display: block;
  contain: content;
  box-sizing: border-box;
}

/*
 * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 * Slider Video
 * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 */

:where(.vds-slider-video) {
  background-color: black;
  box-sizing: border-box;
  contain: content;
  display: inline-block;
  border: var(--media-thumbnail-border, 1px solid white);
}

:where(.vds-slider-video video) {
  display: block;
  height: auto;
  width: 156px;
}

/* Temporarily hide video while loading. */
:where(.vds-slider-video[data-loading]) {
  opacity: 0;
}

/* Hide video if it fails to load. */
:where(.vds-slider-video[data-hidden], .vds-slider-video[data-hidden] video) {
  display: none;
  width: 0px;
}

/*
 * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 * Previews
 * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 */

:where(.vds-slider .vds-slider-preview) {
  display: flex;
  flex-direction: column;
  align-items: center;
  opacity: 0;
  background-color: var(--media-slider-preview-bg);
  border-radius: var(--media-slider-preview-border-radius, 2px);
  pointer-events: none;
  transition: opacity 0.2s ease-out;
  will-change: left, opacity;
  contain: layout paint style;
}

:where(.vds-slider-preview[data-visible]) {
  opacity: 1;
  transition: opacity 0.2s ease-in;
}

.vds-slider-value {
  background-color: var(--media-slider-value-bg, black);
  border-radius: var(--media-slider-value-border-radius, 2px);
  border: var(--media-slider-value-border);
  color: var(--media-slider-value-color, white);
  padding: var(--media-slider-value-padding, 1px 10px);
}

:where(
    .vds-slider-video:not([data-hidden]) + .vds-slider-chapter-title,
    .vds-slider-thumbnail:not([data-hidden]) + .vds-slider-chapter-title
  ) {
  margin-top: var(--media-slider-chapter-title-gap, 6px);
}

:where(
    .vds-slider-video:not([data-hidden]) + .vds-slider-value,
    .vds-slider-thumbnail:not([data-hidden]) + .vds-slider-value,
    .vds-slider-chapter-title + .vds-slider-value
  ) {
  margin-top: var(--media-slider-value-gap, 2px);
}

/*
 * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 * Vertical Sliders
 * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 */

:where(.vds-slider[aria-orientation='vertical']) {
  --width: var(--media-slider-width, 48px);
  --height: var(--media-slider-height, 100%);

  --track-width: var(--media-slider-track-width, 4px);
  --track-height: var(--media-slider-track-height, 100%);
  --track-focus-width: var(--media-slider-focused-track-width, calc(var(--track-width) * 1.25));
  --track-focus-height: var(--media-slider-focused-track-height, var(--track-height));

  /** Prevent thumb flowing out of slider. */
  margin: calc(var(--thumb-size) / 2) 0;
}

:where(.vds-slider[aria-orientation='vertical'] .vds-slider-track) {
  top: unset;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%) translateZ(0);
}

:where(.vds-slider[aria-orientation='vertical'] .vds-slider-track-fill) {
  width: var(--track-width);
  height: var(--slider-fill);
  will-change: height;
  transform: translateX(-50%) translateZ(0);
}

:where(.vds-slider[aria-orientation='vertical'] .vds-slider-progress) {
  top: unset;
  bottom: 0;
  width: var(--track-width);
  height: var(--slider-progress, 0%);
  will-change: height;
}

:where(.vds-slider[aria-orientation='vertical'] .vds-slider-thumb) {
  top: unset;
  bottom: var(--slider-fill);
  left: 50%;
  will-change: bottom;
  transform: translate(-50%, 50%) translateZ(0);
}

:where(.vds-slider[aria-orientation='vertical'] .vds-slider-preview) {
  will-change: bottom, opacity;
}

/*
 * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 * Time Slider
 * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 */

:where([data-live] .vds-time-slider .vds-slider-track-fill) {
  background-color: var(--media-slider-track-fill-live-bg, #dc2626);
}

:where(.vds-time-slider .vds-slider-progress) {
  z-index: 1; /** above track. */
  left: 0;
  width: var(--slider-progress, 0%);
  will-change: width;
  background-color: var(--media-slider-track-progress-bg, rgb(255 255 255 / 0.5));
}

:where([data-media-player]:not([data-can-play]) .vds-time-slider .vds-slider-value) {
  display: none;
}

/*
 * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 * Slider Steps
 * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 */

:where(.vds-slider-steps) {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
}

:where(.vds-slider-step) {
  width: var(--media-slider-step-width, 2.5px);
  height: calc(var(--track-height) + 1px);
  background-color: var(--media-slider-step-color, rgb(124, 124, 124));
  opacity: 0;
  transition: opacity 0.3s ease;
}

:where(.vds-slider[data-active] .vds-slider-step) {
  opacity: 1;
}

/*
 * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 * Slider Chapters
 * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 */

:where(.vds-time-slider .vds-slider-chapters) {
  position: relative;
  display: flex;
  align-items: center;
  width: 100%;
  height: 100%;
  contain: layout style;
  border-radius: var(--media-slider-track-border-radius, 1px);
}

:where(.vds-slider[data-focus], .vds-slider:focus-visible) :where(.vds-slider-chapters) {
  box-shadow: var(--media-focus-ring);
  height: var(--track-height);
}

:where(.vds-time-slider .vds-slider-chapter) {
  margin-right: 2px;
}

:where(.vds-time-slider .vds-slider-chapter:last-child) {
  margin-right: 0;
}

:where(.vds-time-slider .vds-slider-chapter) {
  position: relative;
  display: flex;
  align-items: center;
  width: 100%;
  height: 100%;
  will-change: height, transform;
  contain: layout style;
  border-radius: var(--media-slider-track-border-radius, 1px);
}

:where(.vds-time-slider .vds-slider-chapter .vds-slider-track-fill) {
  width: var(--chapter-fill, 0%);
  will-change: width;
}

:where(.vds-time-slider .vds-slider-chapter .vds-slider-progress) {
  width: var(--chapter-progress, 0%);
  will-change: width;
}

@media (hover: hover) and (pointer: fine) {
  :where(.vds-time-slider:hover .vds-slider-chapters) {
    contain: strict;
  }

  :where(.vds-time-slider .vds-slider-chapter:hover:not(:only-of-type)) {
    transform: var(--media-slider-chapter-hover-transform, scaleY(2));
    transition: var(
      --media-slider-chapter-hover-transition,
      transform 0.1s cubic-bezier(0.4, 0, 1, 1)
    );
  }
}

:where(.vds-time-slider .vds-slider-chapter-title) {
  font-family: var(--media-font-family, sans-serif);
  font-size: var(--media-slider-chapter-title-font-size, 14px);
  color: var(--media-slider-chapter-title-color, #f5f5f5);
  background-color: var(--media-slider-chapter-title-bg);
}

/*
 * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 * Thumbnail
 * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 */

:where(.vds-thumbnail) {
  --min-width: var(--media-thumbnail-min-width, 140px);
  --max-width: var(--media-thumbnail-max-width, 180px);
  --aspect-ratio: var(--media-thumbnail-aspect-ratio, var(--thumbnail-aspect-ratio));
  display: block;
  width: var(--thumbnail-width);
  height: var(--thumbnail-height);
  background-color: var(--media-thumbnail-bg, black);
  contain: strict;
  overflow: hidden;
  box-sizing: border-box;
  min-width: var(--min-width);
  min-height: var(--media-thumbnail-min-height, calc(var(--min-width) / var(--aspect-ratio)));
  max-width: var(--max-width);
  max-height: var(--media-thumbnail-max-height, calc(var(--max-width) / var(--aspect-ratio)));
}

.vds-thumbnail {
  border: var(--media-thumbnail-border, 1px solid white);
}

:where(.vds-thumbnail img) {
  min-width: unset !important;
  max-width: unset !important;
  will-change: width, height, transform;
}

:where(.vds-thumbnail[data-loading] img) {
  opacity: 0;
}

:where(.vds-thumbnail[aria-hidden='true']) {
  display: none !important;
}

/*
 * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 * Time
 * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 */

:where(.vds-time-group) {
  display: flex;
  align-items: center;
}

.vds-time-divider {
  margin: 0 var(--media-time-divider-gap, 2.5px);
  color: var(--media-time-divider-color, #e0e0e0);
}

:where(.vds-time) {
  display: inline-block;
  contain: content;
  font-size: var(--media-time-font-size, 15px);
  font-weight: var(--media-time-font-weight, 400);
  font-family: var(--media-font-family, sans-serif);
  border-radius: var(--media-time-border-radius, 2px);
  letter-spacing: var(--media-time-letter-spacing, 0.025em);
}

.vds-time {
  outline: 0;
  color: var(--media-time-color, var(--default-color));
  background-color: var(--media-time-bg);
  border: var(--media-time-border);
  padding: var(--media-time-padding, 2px);
}

:where(.vds-time:focus-visible) {
  box-shadow: var(--media-focus-ring);
}

.light .vds-time {
  --default-color: rgb(10 10 10);
}

.dark .vds-time {
  --default-color: #f5f5f5;
}

/*
 * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 * Tooltips
 * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 */

:where(.vds-tooltip, media-tooltip) {
  display: contents;
}

:where(.vds-tooltip-content) {
  display: inline-block;
  box-sizing: border-box;
  font-family: var(--media-font-family, sans-serif);
  font-size: var(--media-tooltip-font-size, 13px);
  font-weight: var(--media-tooltip-font-weight, 500);
  opacity: 0;
  pointer-events: none;
  white-space: nowrap;
  z-index: 10;
  will-change: transform, opacity;
}

.vds-tooltip-content {
  border-radius: var(--media-tooltip-border-radius, 2px);
  background-color: var(--media-tooltip-bg-color, var(--default-bg));
  border: var(--media-tooltip-border, var(--default-border));
  color: var(--media-tooltip-color, var(--default-color));
  padding: var(--media-tooltip-padding, 2px 8px);
}

.light .vds-tooltip-content {
  --default-color: #1a1a1a;
  --default-bg: white;
  --default-border: 1px solid rgb(0 0 0 / 0.2);
}

.dark .vds-tooltip-content {
  --default-color: #f5f5f5;
  --default-bg: black;
  --default-border: 1px solid rgb(255 255 255 / 0.1);
}

:where(.vds-menu .vds-menu-button[role='button'][data-pressed] .vds-tooltip-content) {
  opacity: 0;
  display: none;
}

/*
 * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 * Tooltip Animation
 * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 */

:where(.vds-tooltip-content) {
  --enter-transform: translateY(0px) scale(1);
  --exit-transform: translateY(12px) scale(0.8);
}

:where(.vds-tooltip-content:not([data-visible])) {
  animation: var(--media-tooltip-exit-animation, vds-tooltip-exit 0.2s ease-out);
}

:where(.vds-tooltip-content[data-visible]) {
  animation: var(--media-tooltip-enter-animation, vds-tooltip-enter 0.2s ease-in);
  animation-fill-mode: forwards;
}

/* Bottom */
:where(.vds-tooltip-content[data-placement~='bottom']) {
  --enter-transform: translateY(0) scale(1);
  --exit-transform: translateY(-12px) scale(0.8);
}

/* Left */
:where(.vds-tooltip-content[data-placement~='left']) {
  --enter-transform: translateX(0) scale(1);
  --exit-transform: translateX(12px) scale(0.8);
}

/* Right */
:where(.vds-tooltip-content[data-placement~='right']) {
  --enter-transform: translateX(0) scale(1);
  --exit-transform: translateX(-12px) scale(0.8);
}

@keyframes vds-tooltip-enter {
  from {
    opacity: 0;
    transform: var(--exit-transform);
  }
  to {
    opacity: 1;
    transform: var(--enter-transform);
  }
}

@keyframes vds-tooltip-exit {
  from {
    opacity: 1;
    transform: var(--enter-transform);
  }
  to {
    opacity: 0;
    transform: var(--exit-transform);
  }
}

@media (prefers-reduced-motion) {
  :where(.vds-tooltip-content) {
    animation: none;
  }

  :where(.vds-tooltip-content[data-visible]) {
    opacity: 1;
  }
}

/*
 * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 * States
 * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 */

/* Play Button */
[data-media-player]:not([data-paused]) .vds-play-tooltip-text,
[data-media-player][data-paused] .vds-pause-tooltip-text,
/* PIP Button */
[data-media-player][data-pip] .vds-pip-enter-tooltip-text,
[data-media-player]:not([data-pip]) .vds-pip-exit-tooltip-text,
/* Fullscreen Button */
[data-media-player][data-fullscreen] .vds-fs-enter-tooltip-text,
[data-media-player]:not([data-fullscreen]) .vds-fs-exit-tooltip-text,
/* Caption Button */
[data-media-player]:not([data-captions]) .vds-cc-on-tooltip-text,
[data-media-player][data-captions] .vds-cc-off-tooltip-text,
/* Mute Button */
[data-media-player]:not([data-muted]) .vds-mute-tooltip-text,
[data-media-player][data-muted] .vds-unmute-tooltip-text {
  display: none;
}

/*
 * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 * Audio Layout
 * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 */

[data-media-player] .vds-audio-layout:not([data-match]) {
  display: none !important;
}

:where([data-media-player][data-layout='audio']) {
  border-radius: var(--audio-border-radius, 6px);
}

:where(.vds-audio-layout) {
  position: relative;
  display: inline-flex;
  align-items: center;
  min-width: 100%;
  height: 60px;
  color: var(--audio-controls-color, var(--default-color));
  background-color: var(--audio-bg, var(--default-bg));
  border-radius: var(--audio-border-radius, 6px);
  box-sizing: border-box;
  filter: var(
    --audio-filter,
    drop-shadow(0 4px 3px rgb(0 0 0 / 0.07)) drop-shadow(0 2px 2px rgb(0 0 0 / 0.06))
  );
}

.vds-audio-layout {
  border: var(--audio-border, 1px solid rgb(255 255 255 / 0.1));
}

:where([data-media-player][data-focus]:not([data-playing]) .vds-audio-layout) {
  box-shadow: var(--media-focus-ring);
}

:where(.vds-audio-layout) {
  --media-brand: var(--audio-brand, var(--default-brand));
  --media-font-family: var(--audio-font-family, sans-serif);
  --media-controls-color: var(--audio-controls-color, var(--default-controls-color));
  --media-menu-y-offset: 18px;
  --media-tooltip-y-offset: 18px;
  --media-slider-track-bg: var(--audio-slider-track-bg, var(--default-slider-track-bg));
  --media-slider-track-fill-bg: var(--audio-slider-track-bg, var(--media-brand));
  --media-slider-track-progress-bg: var(
    --audio-slider-progress-bg,
    var(--default-slider-progress-bg)
  );
  --media-slider-value-border: var(--audio-slider-value-border, 1px solid rgb(255 255 255 / 0.1));
  --media-slider-value-gap: var(--audio-slider-value-gap, 6px);
  --media-focus-ring-color: var(--audio-focus-ring-color, rgb(78 156 246));
  --media-focus-ring: var(--audio-focus-ring, 0 0 0 3px var(--media-focus-ring-color));
}

.vds-audio-layout.light,
.light .vds-audio-layout {
  --default-brand: rgb(10 10 10);
  --default-color: rgb(10 10 10);
  --default-bg: rgb(250 250 250);
  --default-controls-color: rgb(10 10 10);
  --default-border: 1px solid rgb(100 100 100 /0.2);
  --default-slider-track-bg: rgb(50 50 50 / 0.1);
  --default-slider-progress-bg: rgb(10 10 10 / 0.2);
}

.vds-audio-layout.dark,
.dark .vds-audio-layout {
  --default-brand: #f5f5f5;
  --default-color: #f5f5f5;
  --default-controls-color: #f5f5f5;
  --default-bg: black;
  --default-slider-track-bg: rgb(255 255 255 / 0.3);
  --default-slider-progress-bg: rgb(255 255 255 / 0.5);
}

/*
 * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 * Controls
 * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 */

.vds-audio-layout .vds-controls {
  padding-inline: 6px;
  border-radius: var(--audio-border-radius, 6px);
}

:where(.vds-audio-layout .vds-controls-group) {
  display: flex;
  align-items: center;
  pointer-events: auto;
  width: 100%;
}

:where(.vds-audio-layout .vds-button) {
  width: var(--audio-button-size, 36px);
  height: var(--audio-button-size, 36px);
  margin-right: 2.5px;
}

/*
 * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 * Buttons
 * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 */

:where(.vds-audio-layout .vds-play-tooltip) {
  --media-tooltip-y-offset: 18px;
}

:where(.vds-audio-layout .vds-button) {
  transition: max-width 140ms ease-in;
  max-width: var(--audio-button-size, 36px);
}

:where(.vds-audio-layout .vds-play-button) {
  --media-button-hover-transform: 0;
  --media-button-border: var(--audio-play-button-border, var(--color));
  --media-button-hover-bg: var(--bg-color);
  --media-button-touch-hover-bg: var(--bg-color);
  width: var(--audio-play-button-size, 32px);
  height: var(--audio-play-button-size, 32px);
  border-radius: var(--audio-play-button-border-radius, 100%);
  pointer-events: auto;
  margin-bottom: 2px;
  overflow: hidden;
}

.vds-audio-layout .vds-play-button {
  color: var(--audio-play-button-color, var(--default-color));
  background-color: var(--audio-play-button-bg, var(--default-bg));
}

.light .vds-audio-layout .vds-play-button,
.vds-audio-layout.light .vds-play-button {
  --default-color: #f5f5f5;
  --default-bg: var(--media-brand);
}

.dark .vds-audio-layout .vds-play-button,
.vds-audio-layout.dark .vds-play-button {
  --default-color: rgb(10 10 10);
  --default-bg: var(--media-brand);
}

:where(.vds-audio-layout .vds-caption-button:not([data-active])) {
  opacity: var(--audio-caption-button-off-opacity, 0.64);
}

:where(.vds-audio-layout .vds-live-button) {
  margin-right: 8px;
}

:where(.vds-audio-layout .vds-seek-button) {
  max-width: 0px;
  visibility: hidden;
}

:where([data-playing] .vds-audio-layout .vds-seek-button) {
  max-width: var(--audio-button-size, 36px);
  visibility: visible;
}

:where(.vds-audio-layout .vds-settings-menu .vds-button) {
  margin-right: 0;
}

@media (pointer: coarse) {
  :where(.vds-audio-layout .vds-caption-button) {
    display: none;
  }
}

/*
 * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 * Title
 * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 */

:where(.vds-audio-layout .vds-title) {
  display: flex;
  align-items: center;
  position: relative;
  margin-left: 6px;
  margin-right: auto;
  max-width: 100%;
  opacity: 1;
  transition:
    max-width 150ms ease-in,
    opacity 150ms ease-in;
  overflow: hidden;
  text-wrap: nowrap;
  white-space: nowrap;
  transition-delay: 75ms;
}

:where([data-playing] .vds-audio-layout .vds-title) {
  opacity: 0;
  margin: 0;
  max-width: 0px;
  transition: none;
  transition-delay: 0;
}

:where(.vds-audio-layout .vds-title-text) {
  display: inline-flex;
  align-items: center;
}

:where(.vds-audio-layout .vds-marquee .vds-title-text) {
  animation: vds-marquee 8s linear infinite;
}

:where(.vds-audio-layout .vds-title:hover *) {
  animation-play-state: paused;
}

:where(.vds-audio-layout .vds-title-text:nth-child(2)) {
  margin-left: 16px;
}

@keyframes vds-marquee {
  from {
    transform: translateX(0%);
  }
  to {
    transform: translateX(calc(-100% - 16px));
  }
}

/*
 * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 * Time
 * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 */

:where(.vds-audio-layout .vds-time) {
  margin-inline: 8px;
  transition: max-width 140ms ease-in;
  font-size: var(--audio-time-font-size, 15px);
}

/*
 * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 * Time Slider
 * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 */

:where(.vds-audio-layout .vds-time-slider) {
  --media-slider-preview-offset: 14px;
  opacity: 0;
  max-width: 0px;
  transform: scaleX(0);
  transform-origin: center left;
  transition: none;
  visibility: hidden;
}

:where([data-media-player]:not([data-paused]) .vds-audio-layout .vds-time-slider) {
  opacity: 1;
  max-width: 100%;
  transform: scaleX(1);
  transition:
    opacity 150ms ease-in,
    transform 150ms ease-in;
  transition-delay: 75ms;
  visibility: visible;
}

:where(.vds-audio-layout .vds-slider-chapter-title) {
  color: var(--audio-slider-chapter-title-color, black);
}

:where(.dark .vds-audio-layout .vds-slider-chapter-title) {
  color: var(--audio-slider-chapter-title-color, white);
}

:where([data-buffering] .vds-audio-layout .vds-slider-progress) {
  --stripe-color: var(--audio-buffering-stripe-color, rgb(0 0 0 / 0.25));
  --stripe-size: var(--audio-buffering-stripe-size, 30px);
  width: 100% !important;
  background-image: linear-gradient(
    -45deg,
    var(--stripe-color) 25%,
    transparent 25%,
    transparent 50%,
    var(--stripe-color) 50%,
    var(--stripe-color) 75%,
    transparent 75%,
    transparent
  );
  background-size: var(--stripe-size) var(--stripe-size);
  animation: vds-audio-track-progress var(--audio-buffering-stripe-speed, 2s) linear infinite;
}

@keyframes vds-audio-track-progress {
  0% {
    background-position: 0 0;
  }
  100% {
    background-position: var(--stripe-size) var(--stripe-size);
  }
}

/*
 * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 * Volume Slider
 * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 */

:where(.vds-audio-layout .vds-volume) {
  --media-slider-height: var(--audio-volume-height, 96px);
  --media-slider-preview-offset: 6px;
  --gap: var(--audio-volume-gap, 16px);
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
}

:where(.vds-audio-layout .vds-volume-popup) {
  position: absolute;
  bottom: calc(100% + var(--gap));
  left: 50%;
  opacity: 0;
  transform: translateX(-50%);
  transition:
    opacity 150ms ease-out,
    visibility 150ms ease-out;
  border-radius: var(--audio-volume-border-radius, 8px);
  filter: var(--media-volume-filter, drop-shadow(0 1px 1px rgb(0 0 0 / 0.05)));
  visibility: hidden;
}

/* safe area. */
.vds-audio-layout .vds-volume-popup::after {
  content: '';
  position: fixed;
  bottom: calc(-1 * var(--gap));
  right: 0;
  width: 100%;
  height: var(--gap);
  z-index: 1;
  pointer-events: auto;
}

.vds-audio-layout .vds-volume-popup {
  background-color: var(--audio-volume-bg, var(--media-menu-bg, var(--default-bg)));
  border: var(--audio-volume-border, var(--default-border));
}

.light .vds-audio-layout .vds-volume-popup,
.vds-audio-layout.light .vds-volume-popup {
  --default-bg: rgb(250 250 250);
  --default-border: 1px solid rgb(10 10 10 / 0.1);
}

.dark .vds-audio-layout .vds-volume-popup,
.vds-audio-layout.dark .vds-volume-popup {
  --default-bg: rgb(10 10 10);
  --default-border: 1px solid rgb(255 255 255 / 0.1);
}

:where(.vds-audio-layout .vds-volume[data-active] .vds-volume-popup),
:where(.vds-audio-layout .vds-volume:has([data-active]) .vds-volume-popup) {
  transition:
    opacity 150ms ease-in,
    visibility 150ms ease-in;
  opacity: 1;
  visibility: visible;
}

:where(.vds-audio-layout .vds-volume[data-active] .vds-tooltip-content) {
  display: none !important;
}

/*
 * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 * Menus
 * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 */

:where(.vds-audio-layout .vds-menu-items[data-root]) {
  max-height: var(--audio-menu-max-height, 320px);
}

/*
 * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 * Captions
 * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 */

:where(.vds-audio-layout .vds-captions) {
  --cue-font-size: calc(var(--audio-cue-font-size, 14px) * var(--media-user-font-size, 1));
  display: inline-block;
  position: absolute;
  width: 100%;
  top: unset;
  bottom: calc(100% + var(--audio-captions-offset, 4px));
  text-align: center;
  background-color: var(--media-user-display-bg, var(--media-cue-display-bg));
}

:where([data-preview] .vds-audio-layout .vds-captions),
:where([data-paused] .vds-audio-layout .vds-captions) {
  opacity: 0;
}

@media (pointer: coarse) {
  .vds-audio-layout[data-scrubbing] :where(.vds-button, .vds-time) {
    max-width: 0 !important;
    margin: 0 !important;
    padding: 0 !important;
    transition: max-width 150ms ease-out;
  }
}

/*
 * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 * Video Layout
 * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 */

[data-media-player] .vds-video-layout:not([data-match]) {
  display: none !important;
}

[data-media-player][data-layout='video'] {
  background-color: var(--video-bg, black);
}

[data-media-player][data-layout='video']:not([data-fullscreen]) {
  border-radius: var(--video-border-radius, 6px);
  border: var(--video-border, 1px solid rgb(255 255 255 / 0.1));
}

:where(.vds-video-layout) {
  --media-brand: var(--video-brand, #f5f5f5);
  --media-font-family: var(--video-font-family, sans-serif);
  --media-controls-color: var(--video-controls-color, #f5f5f5);
  --media-tooltip-y-offset: 6px;
  --media-menu-y-offset: 6px;
  --media-focus-ring-color: var(--video-focus-ring-color, rgb(78 156 246));
  --media-focus-ring: var(--video-focus-ring, 0 0 0 3px var(--media-focus-ring-color));
  color: var(--video-controls-color, #f5f5f5);
  display: contents;
}

:where([data-media-player][data-focus]:not([data-playing]) .vds-video-layout .vds-controls) {
  border-radius: var(--video-border-radius, 6px);
  box-shadow: var(--media-focus-ring);
}

/*
 * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 * Controls
 * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 */

:where(.vds-video-layout .vds-controls[data-visible]) {
  border-radius: var(--video-border-radius, 6px);
  background-image: linear-gradient(
    to top,
    rgb(0 0 0 / 0.6),
    10%,
    transparent,
    95%,
    rgb(0 0 0 / 0.3)
  );
}

.vds-video-layout .vds-controls-group {
  align-items: center;
  display: flex;
  pointer-events: auto;
  z-index: 0;
  padding: 4px 6px;
}

.vds-video-layout .vds-controls-group:first-child {
  z-index: 50;
}

/* second last group */
.vds-video-layout .vds-controls-group:nth-last-child(2) {
  padding: 0 12px;
  z-index: 11;
  margin-bottom: -16px;
}

.vds-video-layout:not([data-sm]) .vds-controls-group:last-child {
  --media-menu-y-offset: 26px;
  --media-tooltip-y-offset: 26px;
  --media-slider-preview-offset: 26px;
  z-index: 10;
}

:where(.vds-video-layout .vds-button) {
  margin-right: 2.5px;
}

/*
 * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 * Title
 * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 */

:where(.vds-video-layout[data-sm] .vds-chapter-title) {
  font-size: var(--video-sm-chapter-title-font-size, 15px);
}

:where([data-fullscreen] .vds-video-layout .vds-chapter-title) {
  font-size: var(--video-fullscreen-chapter-title-font-size, 16px);
}

/*
 * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 * Buttons
 * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 */

:where(.vds-video-layout:not([data-sm]) .vds-mute-button) {
  margin-left: -2.5px;
  margin-right: -5px;
}

:where(.vds-video-layout[data-sm]) {
  --media-button-size: var(--video-sm-button-size, 36px);
}

/*
 * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 * Sliders
 * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 */

:where(.vds-video-layout .vds-time-slider) {
  --media-slider-height: 45px;
  flex-grow: 0;
}

:where(.vds-video-layout .vds-slider-thumbnail) {
  --media-thumbnail-border: var(--video-slider-thumbnail-border, 1px solid #f5f5f5);
  border-radius: var(--video-slider-thumbnail-border-radius, 2px);
}

.vds-video-layout .vds-time-slider .vds-slider-value {
  background-color: var(--video-time-bg, unset);
  text-shadow:
    -1px -1px 0 #333333,
    1px -1px 0 #333333,
    -1px 1px 0 #333333,
    1px 1px 0 #333333;
}

:where(.vds-video-layout[data-sm] .vds-time) {
  text-shadow: unset;
}

/*
 * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 * Large Layout Volume Slider
 * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 */

:where(.vds-video-layout[data-lg] .vds-volume) {
  --gap: var(--video-volume-gap, 10px);
  display: contents;
}

:where(.vds-video-layout[data-lg] .vds-volume-popup) {
  display: contents;
}

:where(.vds-video-layout[data-lg] .vds-volume-slider) {
  margin: 0;
  max-width: 0;
  transition: all 0.15s ease;
}

:where(.vds-video-layout[data-lg] .vds-volume[data-active] .vds-volume-slider),
:where(.vds-video-layout[data-lg] .vds-volume:has([data-active]) .vds-volume-slider) {
  margin-left: var(--gap);
  opacity: 1;
  visibility: visible;
  max-width: var(--video-volume-slider-max-width, 72px);
}

/* safe area. */
.vds-video-layout[data-lg] .vds-volume-slider::after {
  content: '';
  position: fixed;
  top: 0;
  left: calc(-1 * var(--gap));
  width: var(--gap);
  height: 100%;
  z-index: 1;
  pointer-events: auto;
}

/*
 * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 * Small Layout Volume Slider
 * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 */

:where(.vds-video-layout[data-sm] .vds-volume) {
  --media-slider-height: var(--video-volume-height, 96px);
  --media-slider-preview-offset: calc(-200% - 6px);
  --gap: var(--video-volume-gap, 10px);
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
}

:where(.vds-video-layout[data-sm] .vds-volume-popup) {
  display: block;
  position: absolute;
  top: calc(100% + var(--gap));
  left: 50%;
  opacity: 0;
  transform: translateX(-50%);
  transition:
    opacity 150ms ease-out,
    visibility 150ms ease-out;
  border-radius: var(--video-volume-border-radius, 8px);
  filter: var(--media-volume-filter, drop-shadow(0 1px 1px rgb(0 0 0 / 0.05)));
  visibility: hidden;
}

/* safe area. */
.vds-video-layout[data-sm] .vds-mute-button::after {
  content: '';
  position: fixed;
  bottom: calc(-1 * var(--gap));
  right: 0;
  width: 100%;
  height: var(--gap);
  z-index: 1;
  pointer-events: auto;
}

.vds-video-layout .vds-volume-popup {
  background-color: var(--video-volume-bg, var(--media-menu-bg, var(--default-bg)));
  border: var(--video-volume-border, var(--default-border));
}

.light .vds-video-layout .vds-volume-popup,
.vds-video-layout.light .vds-volume-popup {
  --default-bg: rgb(250 250 250);
  --default-border: 1px solid rgb(10 10 10 / 0.1);
}

.dark .vds-video-layout .vds-volume-popup,
.vds-video-layout.dark .vds-volume-popup {
  --default-bg: rgb(10 10 10);
  --default-border: 1px solid rgb(255 255 255 / 0.1);
}

:where(.vds-video-layout[data-sm] .vds-volume[data-active] .vds-volume-popup),
:where(.vds-video-layout[data-sm] .vds-volume:has([data-active]) .vds-volume-popup) {
  transition:
    opacity 150ms ease-in,
    visibility 150ms ease-in;
  opacity: 1;
  visibility: visible;
}

:where(.vds-video-layout[data-sm] .vds-volume[data-active] .vds-tooltip-content) {
  display: none !important;
}

/*
 * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 * Time
 * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 */

:where(.vds-video-layout .vds-time[data-type='current']) {
  margin-right: 2px;
}

:where(.vds-video-layout .vds-time[data-type='current'][remainder]) {
  margin-left: 2px;
}

.vds-video-layout .vds-time {
  --default-color: #f5f5f5 !important;
}

/*
 * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 * Captions
 * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 */

:where([data-preview] .vds-video-layout .vds-captions) {
  opacity: 0;
}

:where(.vds-video-layout .vds-captions) {
  z-index: 10;
  transition: var(--video-captions-transition, bottom 0.3s ease-in-out);
}

@media (min-width: 980px) {
  :where([data-fullscreen] .vds-video-layout .vds-captions) {
    bottom: var(--video-lg-fullscreen-captions-offset, 54px);
  }
}

:where([data-media-player][data-controls] .vds-video-layout .vds-captions) {
  bottom: var(--video-captions-offset, 78px);
}

:where([data-media-player][data-controls] .vds-video-layout[data-sm] .vds-captions) {
  bottom: var(--video-sm-captions-offset, 48px);
}

/*
 * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 * Chapters
 * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 */

:where(.vds-video-layout .vds-time-slider .vds-slider-chapter-title) {
  width: 100%;
  text-align: center;
  text-shadow:
    -1px -1px 0 #212121,
    1px -1px 0 #212121,
    -1px 1px 0 #212121,
    1px 1px 0 #212121;
}

/*
 * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 * Gestures
 * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 */

:where(.vds-video-layout .vds-gesture) {
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 0;
}

:where(.vds-video-layout .vds-gesture[action='seek:-10']) {
  width: var(--video-gesture-seek-width, 20%);
  z-index: 1;
}

:where(.vds-video-layout .vds-gesture[action='seek:10']) {
  left: unset;
  right: 0;
  width: var(--video-gesture-seek-width, 20%);
  z-index: 1;
}

@media (pointer: coarse) {
  :where(.vds-video-layout .vds-gesture[action='toggle:paused']) {
    display: none;
  }
}

@media not (pointer: coarse) {
  :where([data-media-player] .vds-video-layout .vds-gesture[action='toggle:controls']) {
    display: none;
  }
}

/*
 * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 * Live Button
 * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 */

:where(.vds-video-layout .vds-live-button) {
  margin-left: 12px;
}

/*
 * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 * Time Group
 * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 */

:where(.vds-video-layout:not([data-sm]) .vds-time-group) {
  margin-left: 10px;
}

:where(.vds-video-layout[data-sm] .vds-time) {
  font-size: var(--video-sm-time-font-size, 14px);
}

:where([data-fullscreen] .vds-video-layout .vds-time) {
  font-size: var(--video-fullscreen-time-font-size, 16px);
}

/*
 * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 * Load Container
 * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 */

:where(.vds-video-layout .vds-load-container) {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  display: none;
  align-items: center;
  justify-content: center;
  pointer-events: none;
  z-index: 99;
}

:where(
    [data-media-player][data-load='play']:not([data-started])
      .vds-video-layout[data-match]
      .vds-load-container
  ) {
  display: flex;
}

:where(.vds-video-layout .vds-load-container .vds-play-button) {
  --size: var(--video-load-button-size, 56px);
  --color: var(--video-load-button-color, rgb(0 0 0 / 0.8));
  --bg-color: var(--video-load-button-bg, var(--media-brand));

  --media-button-hover-transform: 0;
  --media-button-border: var(--video-load-button-border, var(--color));
  --media-button-hover-bg: var(--video-load-button-bg, var(--media-brand));

  width: var(--size);
  height: var(--size);
  pointer-events: auto;
  margin-bottom: 2px;
  overflow: hidden;
}

.vds-video-layout .vds-load-container .vds-play-button {
  border-radius: var(--video-load-button-border-radius, 100%);
  color: var(--color);
}

.vds-video-layout .vds-load-container .vds-play-button {
  background-color: var(--bg-color);
}

:where(.vds-video-layout[data-sm] .vds-load-container .vds-play-button) {
  --size: var(--video-sm-load-button-size, 48px);
  --media-button-hover-transform: translateY(0%);
  width: var(--size);
  height: var(--size);
  transform: translateY(0%);
}

/*
 * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 * Small Layout
 * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 */

:where(.vds-video-layout[data-sm] .vds-controls-group:nth-last-child(2)) {
  pointer-events: none;
}

:where(.vds-video-layout[data-sm] .vds-controls-group:last-child) {
  z-index: 2;
  margin-top: -2.5px;
  margin-bottom: -6px;
}

:where([data-fullscreen] .vds-video-layout[data-sm] .vds-controls-group:last-child) {
  margin-bottom: 0;
}

.vds-video-layout[data-sm] .vds-controls-group {
  padding: 2px;
}

:where(.vds-video-layout[data-sm])
  :where(
    .vds-button,
    .vds-slider:not(.vds-time-slider),
    .vds-time,
    .vds-time-divider,
    .vds-chapter-title
  ) {
  transition: opacity 0.15s ease;
}

:where([data-media-player]:not([data-started]) .vds-video-layout[data-sm])
  :where(.vds-button .vds-slider, .vds-time-group) {
  opacity: 0;
  visibility: hidden;
}

:where(.vds-video-layout[data-sm] .vds-time-slider) {
  transition: transform 0.1s linear;
}

@media (pointer: coarse) {
  :where([data-preview] .vds-video-layout:not([data-no-scrub-gesture]))
    :where(
      .vds-button,
      .vds-slider:not(.vds-time-slider),
      .vds-time,
      .vds-chapter-title,
      .vds-time-divider,
      .vds-captions,
      .vds-live-button
    ) {
    opacity: 0;
  }

  :where([data-preview] .vds-video-layout:not([data-no-scrub-gesture]) .vds-time-slider) {
    --track-height: var(--video-sm-slider-focus-track-height, 12px);
    transform: translateY(-6px);
    transition: transform 0.1s linear;
  }
}

:where(.vds-video-layout[data-sm] .vds-controls .vds-play-button) {
  --size: var(--video-sm-play-button-size, 45px);
  --media-button-hover-transform: translateY(25%);
  width: var(--size);
  height: var(--size);
  transform: translateY(25%);
  border-radius: 100%;
  pointer-events: auto;
  margin-bottom: 2px;
  overflow: hidden;
}

.vds-video-layout[data-sm] .vds-controls .vds-play-button {
  background-color: var(--video-sm-play-button-bg, rgba(0 0 0 / 0.6));
}

:where(
    [data-media-player]:not([data-started])
      .vds-video-layout[data-sm]
      .vds-controls-group:not(:nth-child(3))
  ) {
  opacity: 0;
  visibility: hidden;
}

/* center big play button inside buffering indicator. */
:where(.vds-video-layout[data-sm] .vds-buffering-indicator) {
  --media-buffering-size: 64px;
  transform: translate(-2px, -4px);
}

:where(.vds-video-layout .vds-start-duration .vds-time) {
  position: absolute;
  right: 8px;
  bottom: 8px;
  margin-right: 8px;
  margin-bottom: 8px;
  z-index: 10;
}

.vds-video-layout .vds-start-duration .vds-time {
  padding: var(--video-sm-start-duration-padding, 3px 6px);
  color: var(--video-sm-start-duration-color, var(--video-controls-color));
  background-color: var(--video-sm-start-duration-bg, rgba(0 0 0 / 0.64));
}

:where([data-started] .vds-video-layout .vds-start-duration .vds-time) {
  display: none;
}

:where([data-media-player]:not([data-can-play]) .vds-video-layout .vds-start-duration .vds-time) {
  opacity: 0;
}

:where(.vds-video-layout[data-sm] .vds-time[data-type='current']) {
  margin-left: 8px;
}

/*
 * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 * Fullscreen
 * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 */

:where([data-fullscreen] .vds-video-layout .vds-controls-group:nth-last-child(2)) {
  margin-bottom: -16px;
}

@media (orientation: portrait) {
  :where([data-fullscreen] .vds-video-layout .vds-captions) {
    bottom: 30lvh;
    bottom: 10dvh;
  }
}

@media (orientation: landscape) {
  :where([data-fullscreen] .vds-video-layout .vds-controls-group:nth-last-child(2)) {
    margin-bottom: -12px;
  }
}


/**
** focus styling
**************************/
:root :focus-visible {
	box-shadow:
		var(--ring-offset-inset) 0px 0px 0px var(--ring-offset-width) var(--ring-offset-color),
		var(--ring-inset) 0px 0px var(--ring-blur) var(--ring-width) var(--ring-color)
	;
	outline: none;
}

:root :focus:not(:focus-visible) {
	outline: none;
}

:root embed:focus-visible,
:root iframe:focus-visible {
	outline: unset;
}

/* focusable elements */
a,
audio[controls],
button,
details,
embed,
iframe,
img[usemap],
input:not([type='hidden']),
keygen,
label,
menu[type='toolbar'],
object[usemap],
select,
textarea,
video[controls] {}

/**
** "Skip to content" button
**************************/
a.skip {
	border: 2px solid #fff;
	border-radius: 3px;
	box-shadow: 0 2px 4px rgba(0, 0, 0, 0.45);
	font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Oxygen-Sans, Ubuntu, Cantarell, 'Helvetica Neue', sans-serif;
	font-size: 1rem;
	font-weight: bold;
	left: 0px;
	line-height: 2rem;
	margin: 6px 14px;
	padding: 0 12px;
	position: fixed;
	top: -72px;
	transition: top 1.25s ease-out;
	z-index: 3;
}

a.skip,
a.skip:focus-visible {
/* Colors: http://web-accessibility.carnegiemuseums.org/design/color/ */
	background: #fad980;
	color: #212121;
}

a.skip:focus-visible {
	outline-color: transparent;	
	top: 0px;
	transition: top .25s ease-in;
}

@media (prefers-reduced-motion: reduce) {
	a.skip {
		transition-duration: 0.001ms !important;
	}
}

/**
** for screen readers
**************************/
.sr-only,
.screen-reader-text {
	height: 1px;
	left: -999999px;
	overflow: hidden;
	position: absolute;
	top: auto;
	width: 1px;
}

/**
** child content stylesheets
**************************/

/**
 * kookaburra-album
**************************/
.hero-image {
	background-color: transparent;
	border: 0px solid var(--color-base-offset);
	border-radius: 0px;
	margin-top: 0px;
	overflow: hidden;
	padding-top: 41.666666666667%;
	position: relative;
}

.hero-image .background-image {
	background-position: center center;
	background-repeat: no-repeat;
	background-size: contain;
	border-radius: 24px;
	position: absolute;
	top: 0; right: 0; bottom: 0; left: 0;
}

.hero-image .background-image::before {
	content: "";
	display: inline-block;
	height: 100%;
	vertical-align: middle;
	width: 0;
}

.hero-image .background-image {
	font-size: 0;
	text-align: center;
}

.hero-image .hero-image--album-title {
	color: #FFFFFF;
	display: inline-block;
	font-size: 33px;
	font-weight: 400;
	line-height: 1em;
	margin: 24px 24px;
	max-width: 2560px;
	text-shadow: 0 1px 3px rgba(0,0,0,0.5);
	text-transform: none;
	vertical-align: top;
}

.hero-image + .hero-image--album-title {
	display: none;
}


/**
 * pagination
 *************************/
.pagination,
.pagination ul,
.pagination ul li {
	margin: 0;
	padding:0;
}

.pagination {
	align-items: center;
	display: flex;
	justify-content: space-between;
}

.pagination ul {
	background-color: transparent;
	display: flex;
	font-size: 0;
	margin: 0;
	overflow: hidden;
	text-align: right;
}

.pagination ul li {
	background-color: var(--color-base-offset);
	color: var(--color-contrast);
	font-size: 0.875rem;
	line-height: 1;
	list-style: none;
	margin-right: 12px;
	text-align: center;
	width: 36px; height: 36px;
}

.pagination ul li:last-child {
	margin-right: 0;
}

.pagination ul li.current {
	font-weight: bold;
	text-decoration: none;
}

.pagination ul li.disabled span {
	opacity: 0.25;
}

.pagination ul li.ellipses span {
	opacity: 0.75;
}

.pagination ul li a,
.pagination ul li span {
	align-items: center;
	display: flex;
	height: 100%;
	justify-content: center;
}

.pagination ul li a {
	--ring-offset-width: 0px;
	--ring-inset: inset;
	--ring-width: 2px;

	color: var(--color-interactive);
	text-decoration: underline;
}

.pagination ul.page-numbers {
	border-radius: 18px;
	margin-right: 12px;
}

.pagination ul.page-navigation {
	border-radius: 18px;
}

/**
 * presentations
**************************/
.kookaburra.type-album div[data-presentation="grid"] figcaption ul.metadata li.metadata1 {
	display: block;
}

.kookaburra.type-album div[data-presentation="grid"] figcaption ul.metadata li.metadata2 {
	display: block;
}
