/**
 * Content
 */

body {
	background-color: #ffffff;
	color: #000;
}

a:active {
	opacity: 0.7;
}

.page a.active {
    
}

i,
em {
	font-style: italic;
}

b,
strong {
	font-weight: bolder;
}

sub,
sup {
	position: relative;
	vertical-align: baseline;
}

sub {
	top: 0.3em;
}

sup {
	top: -0.4em;
}

s {
	text-decoration: line-through;
}

img {
	border: 0;
	padding: 0;
}
ul,
ol {
	margin: 0;
	padding: 0 0 0 1em;
}

blockquote {
	margin: 0;
	padding: 0 0 0 2em;
}

hr {
	background: rgba(128, 128, 128, 0.2);
	border: 0;
    height: 1px;
	display: block;
    margin-bottom: -1rem;
}

.content img {
	float: none;
	/*margin-bottom: 0.25em;*/
}

.gallery_image_caption {
    margin-top: 1.2rem;
    margin-bottom: 0.5rem;
    font-size: 1.5rem;
	font-weight: 400;
	color: rgba(0, 0, 0, 0.4);
	font-family: Karla, Icons;
	font-style: normal;
	line-height: 1.3;	
}

/**
 * Loading Animation
 */

.loading[data-loading] {
	position: fixed;
	bottom: 8px; 
    left: 8px;
}

/**
 * Editor styles
 */

[data-predefined-style="true"] bodycopy {
	font-size: 1.3rem;
	font-weight: 400;
	color: rgba(27, 27, 27, 1);
	font-family: Karla, Icons;
	font-style: normal;
	line-height: 1.3;
}

[data-predefined-style="true"] bodycopy a {
	color: inherit;
	border-bottom: 1px dotted rgba(28, 50, 255, 1);
    text-decoration: none;
}

[data-predefined-style="true"] bodycopy a:hover {
}

bodycopy a.image-link,
bodycopy a.icon-link	{
	border-bottom: 0;
	padding-bottom: 0;
    color: rgba(0, 0, 0, 0.5);
}

bodycopy a.image-link:hover,
bodycopy a.icon-link:hover	{
	border-bottom: 0;
	padding-bottom: 0;
    color: rgba(28, 50, 255, 1);
}

[data-predefined-style="true"] h1 {
	font-family: Karla, Icons;
	font-style: normal;
	font-weight: 400;
	padding: 0;
	margin: 0;
	font-size: 2.8rem;
	line-height: 1.3;
	color: rgba(27, 27, 27, 1);
	}

[data-predefined-style="true"] h1 a {
	color: rgba(0, 0, 0, 0.85);
}

[data-predefined-style="true"] h2 {
	font-family: Karla, Icons;
	font-style: normal;
	font-weight: 400;
	padding: 0;
	margin-bottom: 0.5em;
	color: rgba(27, 27, 27, 1);
	font-size: 1.7rem;
	line-height: 1.2;
	}

[data-predefined-style="true"] h2 a {
	color: rgba(0, 0, 0, 0.85);
}

h2 a.image-link,
h2 a.icon-link	{
	border-bottom: 0;
	padding-bottom: 0;
    color: rgba(0, 0, 0, 0.5);
}

[data-predefined-style="true"] small {
	display: inline-block;
	font-size: 1.3rem;
	line-height: 1.3;
	font-family: 'Space Mono', Icons;
	font-style: normal;
	font-weight: 400;
	color: rgba(0, 0, 0, 0.4);
}

[data-predefined-style="true"] small a {
	display: inline-block;
    color: rgba(0, 0, 0, 0.4);
    letter-spacing: -0.02rem;
    white-space:nowrap;
    line-height: 1.0em;
	border-bottom: 1px dotted rgba(28, 50, 255, 1);
}

/**
 * Breakpoints
 */


[data-css-preset] .page {
    background-color: initial /*!page_bgcolor*/;
}

.mobile .page,
[data-css-preset].mobile .page {
	position: relative;
	max-width: 100%;
	width: 100%;
	background-color: transparent /*!page_bgcolor*/;
}

[data-css-preset] .container {
	margin-left: auto /*!content_right*/;
	margin-right: 0 /*!content_right*/;
	text-align: left /*!text_left*/;
}

[data-css-preset] body {
	background-color: rgb(255, 255, 255) /*!body_bgcolor*/;
}

[data-css-preset] .container_width {
	width: 72%/*!content_right*/;
}

[data-css-preset] .content_padding {
	padding-top: 2.5rem /*!main_margin*/;
	padding-bottom: 2.5rem /*!main_margin*/;
	padding-left: 2.5rem /*!main_margin*/;
	padding-right: 2.5rem /*!main_margin*/;
}


[data-css-preset] text-limit {
	display: inline-block /*!text_width*/;
	max-width: 66rem/*!text_width*/;
}

/**
 * Thumbnails
 */

div[thumbnails] {
	justify-content: flex-start;
}

[data-css-preset] .thumbnails {
   	background-color: transparent/*!thumbnails_bgcolor*/;   
}

[data-css-preset] .thumbnails_width {
    width: 75%/*!thumbnails_width*/;
}

[data-css-preset] [thumbnails-pad] {
    /*padding: 1.5rem /*!thumbnails_padding*/;
    padding-top: 1.5rem /*!main_margin*/;
	padding-bottom: 1.0rem /*!main_margin*/;
	padding-left: 2rem /*!main_margin*/;
	padding-right: 2rem /*!main_margin*/;
}

[data-css-preset] [thumbnails-gutter] {
    margin: -4rem/*!thumbnails_padding*/;
}

[data-css-preset] [responsive-layout] [thumbnails-pad] {
    padding: 0.75rem/*!responsive_thumbnails_padding*/; 
}

[data-css-preset] [responsive-layout] [thumbnails-gutter] {
    margin: -1.5rem/*!responsive_thumbnails_padding*/; 
}

.thumbnails .thumb_image {
	outline: 0px solid rgba(0,0,0,.12);
    outline-offset: -1px;
}

.thumbnails .title {
    font-size: 1.3rem;
	font-weight: 400;
	color: rgba(27, 27, 27, 1);
	font-family: Karla, Icons;
	font-style: normal;
	line-height: 1.3;
    margin-top: 1.0rem;
    margin-bottom: 0.2rem;
}

.thumbnails .tags {
    font-size: 1.2rem;
	font-weight: 400;
	color: rgba(170, 170, 170, 1);
	font-family: Karla, Icons;
	font-style: normal;
	line-height: 1.0;
    margin-top: 1.0rem;
    margin-bottom: 0.5rem;
}

.thumbnails .tags a {
	border-bottom: 0;
    color: rgba(170, 170, 170, 1);
    text-decoration: none;
}

.thumbnails .has_title .tags {
	margin-top: 0rem;
}

/**
 * Site Menu
 */

[data-css-preset] #site_menu_button {
    color: #ffffff;
    line-height: 1;
    font-size: 27px /*!site_menu_button*/;
    padding: 5px;
    line-height: 1;
    background: rgba(33, 32, 46, 0);
    position: fixed;
	right: 2.5rem /*!site_menu_button*/;
	bottom: 1rem /*!site_menu_button*/;
}

body.mobile #site_menu_button {
	margin: -7px;
    font-size: 35px;
}

#site_menu_button.custom_icon {
	width: 40px;
    height: auto;
}

#site_menu_button.active {
	display: none;
}


/**
 * Site Menu
 */

#site_menu {
	font-family: "Karla", Icons;
	background: rgba(255, 255, 255, 0.95);
	font-size: 17px;
	font-style: normal;
	font-weight: 400;
	padding: 20px 30px 90px 30px;
	max-width: 400px;
	min-width: 300px;
	text-align: left;
	display: flex;
	justify-content: center;
}

body.mobile #site_menu {
	width: 100%;
    height: 100%;
}

#site_menu .page-link a {
	color: rgba(27, 27, 27, 0.9);
    line-height: 2.7rem;
}

#site_menu .set-link > a {
	color: rgba(27, 27, 27, 0.9);
	font-weight: bold;
	pointer-events: none;
	cursor: default;
}

#site_menu a.active {
	opacity: 1.0;
    padding-bottom: 3px;
    text-decoration: underline wavy rgba(28, 50, 255, 1) 2px;
}

#site_menu .close {
	display: none;
	color: rgba(28, 50, 255, 1);
	line-height: .85em;
	font-size: 45px;
}

body.mobile #site_menu .close {
    color: rgba(28, 50, 255, 1);
    display: block;
    font-size: 60px;
	line-height: 1em;
    position: absolute;
  	top: 95%;
	right: 3%;
  	transform: translate(0, -50%);
}

#site_menu .break {
	height: 70px;
}

#site_menu .indent {
	margin-left: 26px;
}

/*
 * Shop Button
 */

[data-css-preset] #shop_button {
	color: rgba(0, 0, 0, 0.85);
    background: transparent;
	font-size: 36px;
    font-style: normal;
	font-weight: 400;
    line-height: 1;
    position: fixed;
	padding: 6px;
	top: 5rem /*!shop_button*/;
	right: 3rem /*!shop_button*/;
}

#shop_button.text {
    font-size: 1.4rem;
	font-weight: 400;
	color: rgba(0, 0, 0, 0.75);
	font-family: Karla, Icons;
    padding: 0;
    line-height: 1.3;
}

#shop_button.custom_icon {
	width: 40px;
    height: auto;
}

body.mobile #shop_button:not(.text) {
	margin: -6px;
    font-size: 40px;
}

/*
 * Shop Product Widget
 */

.shop_product {
    width: 100%;
	max-width: 22rem;
    position: relative;
    display: block;
}

.shop_product .price {
	font-family: Karla, Icons;
	font-size: 1.4rem;
	line-height: 1;
	color: rgba(0, 0, 0, 0.75);
    display: block;
    margin-bottom: 1rem;
	font-style: normal;
	font-weight: 400;
}

.shop_product .dropdown {
    font-family: Karla, Icons;
    font-size: 1.4rem;
    display: inline-block;
	width: 100%;
    border: 1px solid rgba(0,0,0,.2);
    background:  white url(https://static.cargo.site/assets/images/select-line-arrows.svg) no-repeat right;
    margin-bottom: 1rem;
    line-height: 1.2;
    padding: .7rem 2.5rem .7rem 1rem;
	font-style: normal;
	font-weight: 400;
}

.shop_product .button {
    font-family: Karla, Icons;
	font-size: 1.4rem;
    background: rgba(0, 0, 0, 0.75);
    color: rgba(255,255,255,1);
    flex: 0 0 50%;
    text-align: left;
    display: inline-block;
	line-height: 1;
    padding: .8rem 1rem;
	font-style: normal;
	font-weight: 400;
}

/*
 * Image Zoom
 */

.content img.image-zoom:active {
  opacity: .7;
}

/**
 * Quick View
 */

[data-css-preset] .quick-view {
    padding-top: 2.5rem /*!quick_view_padding*/;
    padding-bottom: 2.5rem /*!quick_view_padding*/;
    padding-left: 2.5rem /*!quick_view_padding*/;
    padding-right: 2.5rem /*!quick_view_padding*/;
    height: 100% /*!quick_view_height*/;
    width: 100% /*!quick_view_width*/;
}

body.mobile .quick-view {
    width: 100%;
    height: 100%;
    margin: 0;
}


[data-css-preset] .quick-view-background {
	background: rgba(0, 0, 0, 0.9) /*!quick_view_bgcolor*/;
}

.quick-view-caption {
    font-family: Karla, Icons;
    transition: 100ms opacity ease-in-out;
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    margin: 3.5rem 0;
    text-align: center;
    font-size: 1.5rem;
	font-style: normal;
	font-weight: 400;
}

.quick-view-caption span {
    padding: 0.5rem 1rem;
    display: inline-block;
    background: rgba(0,0,0,0.5);
    color: white;
}


/**
 * Quick View Navigation 
 */

.quick-view-navigation .left-arrow {
    left: 10px;
}

.quick-view-navigation .right-arrow {
    right: 10px;
}

.quick-view-navigation .left-arrow,
.quick-view-navigation .right-arrow {
    /* Change height/width together to scale */
    height: 36px;
    width: 36px;
}

.quick-view-navigation .left-arrow .inner-color,
.quick-view-navigation .right-arrow .inner-color {
    stroke: #fff;
    stroke-width: 1.5px;
}

.quick-view-navigation .left-arrow .outer-color,
.quick-view-navigation .right-arrow .outer-color {
    stroke: #000;
    stroke-width: 2.5px;
    opacity: 0.6;
}

.quick-view-navigation .close-button {  
    top: 10px;
    right: 10px;
    /* Change height/width together to scale */
    width: 36px;
    height: 36px;
}

.quick-view-navigation .close-button .inner-color {
    stroke: #fff;
    stroke-width: 1.5px;
}

.quick-view-navigation .close-button .outer-color {
    stroke: #000;
    stroke-width: 2.5px;
    opacity: 0.6;
}

/** 
 * Image Gallery Navigation Arrows 
 */
 
.image-gallery-navigation .left-arrow,
.image-gallery-navigation .right-arrow {
    /* Change height/width together to scale */
    height: 36px;
    width: 36px;
}

.image-gallery-navigation .left-arrow .inner-color,
.image-gallery-navigation .right-arrow .inner-color {
    stroke: #fff;
    stroke-width: 1.5px;
}

.image-gallery-navigation .left-arrow .outer-color,
.image-gallery-navigation .right-arrow .outer-color {
    stroke: #000;
    stroke-width: 2.5px;
    opacity: 0.6;
}

/**
 * Wallpaper Backdrop Navigation Arrows 
 */

.wallpaper-navigation .left-arrow,
.wallpaper-navigation .right-arrow {
   /* Change height/width together to scale */
   width: 36px;
   height: 36px;
}

.wallpaper-navigation .left-arrow .inner-color,
.wallpaper-navigation .right-arrow .inner-color {
   stroke: #fff;
    stroke-width: 1.5px;
}

.wallpaper-navigation .left-arrow .outer-color,
.wallpaper-navigation .right-arrow .outer-color {
    stroke: #000;
    stroke-width: 2.5px;
    opacity: 0.6;
}


/**
 * Feed
 */

.feed .content_container .page {
    border-top: 0px dashed rgba(0, 0, 0, 0.2);
}

.feed .content_container .page_container:first-child .page {
	border-top: 0;
}



/*
 * Audio Player
 */

.audio-player {
    max-width: 36rem;
    height: 3.3rem;
    outline: 1px solid rgba(0,0,0,0.15);
    color: rgba(0, 0, 0, 0.6);
    background: #fff;
    font-size: 1.2rem;
    line-height: 1.3;
    font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen, Ubuntu, Cantarell, "Open Sans", "Helvetica Neue", sans-serif, "Sans Serif", Icons;
    font-style: normal;
    font-weight: 400;
    text-align: left;
    margin: 1px 1px 1em 1px;
}

body.mobile .audio-player {
    max-width: 100%;
}

.audio-player .separator {
    width: 1px;
    background-color: rgba(0,0,0,0.15);
}

.audio-player .button {
    background: transparent;
    cursor: pointer;
    fill: rgba(0, 0, 0, 0.85);
}

.audio-player .icon {
    fill: rgba(0, 0, 0, 0.85);
    padding: 30%;
    width: 100%;
    margin: auto;
}

.audio-player .buffer {
    background: rgba(0,0,0,0.03);
}

.audio-player .progress {
    background: rgba(0,0,0,0.1);
}

.audio-player .progress-indicator {
    border: 1px solid rgba(0, 0, 0, 0.7);
    width: 1px;
    height: 100%;
    right: 0;
    position: absolute;
    cursor: ew-resize;
}

.audio-player .note-icon {
    height: 100%;
    width: 3.8rem;
    padding: 1rem;
    fill: rgba(0, 0, 0, 0.5);
}

.audio-player .current-time {
    padding-left: 1rem;
}

.audio-player .total-time {
    padding-right: 1rem;
}

.hover-title {
    display: inline;
    pointer-events: auto;
    cursor: help;
}

.hover-image {
    visibility: hidden;
}

body:not(.mobile) .hover-title:hover + .hover-image {
    visibility: visible;
    pointer-events: none;
}

.hover-image {
    display: inline;
    position: fixed;
    top: 50%;
    left: 50%;
    transform: translate(-68%, -140%);
    z-index: 1;
    pointer-events: none;
    flex-direction: column;
    align-items: flex-start;
    justify-content: center;

/* Change width and height to scale images */
    width: 30vw;
    height: 30vh;
}

.hover-image img {
    max-width: 100% !important;
    max-height: 100% !important;
    width: auto !important;
    height: auto !important;
    margin-bottom: 0;
}

.videocontainer {
  position: relative;
  overflow: hidden;
  width: 100%;
  padding-top: 56.25%; /* 16:9 Aspect Ratio (divide 9 by 16 = 0.5625) */
}

/* Then style the iframe to fit in the container div with full height and width */
.responsive-iframe {
  position: absolute;
  top: 0;
  left: 0;
  bottom: 0;
  right: 0;
  width: 100%;
  height: 100%;
}

/*Comparison Slider - by Mario Duarte*/
.comparison-slider-wrapper {
  position: relative;
  width: 100%;
  margin: 0px 0;
  background-color: white;
}
.comparison-slider-wrapper .comparison-slider {
  position: relative;
  width: 100%;
  margin: 0;
  border: 0px white solid;
  box-sizing: border-box;
}
.comparison-slider-wrapper .comparison-slider > img {
  width: 100%;
  height: auto;
  display: block;
}
.comparison-slider-wrapper .comparison-slider .overlay {
  display: none;
  position: absolute;
  width: 110px;
  bottom: 20px;
  right: 15px;
  background-color: rgba(0, 0, 0, 0.7);
  padding: 10px;
  box-sizing: border-box;
  color: #DDD;
  text-align: right;
}
@media screen and (min-width: 767px) {
  .comparison-slider-wrapper .comparison-slider .overlay {
    display: block;
  }
}
.comparison-slider-wrapper .comparison-slider .resize {
  position: absolute;
  top: 0;
  left: 0;
  height: 100%;
  width: 50%;
  overflow: hidden;
}
.comparison-slider-wrapper .comparison-slider .resize > img {
  display: block;
}
.comparison-slider-wrapper .comparison-slider .resize .overlay {
  right: auto;
  left: 15px;
  text-align: left;
}
.comparison-slider-wrapper .comparison-slider .divider {
  position: absolute;
  width: 2px;
  height: 100%;
  background-color: rgba(255, 255, 255, 0.2);
  left: 50%;
  top: 0;
  bottom: 0;
  margin-left: -1px;
  cursor: ew-resize;
}
.comparison-slider-wrapper .comparison-slider .divider:before {
  content: "";
  position: absolute;
  width: 20px;
  height: 20px;
  left: -9px;
  top: 50%;
  margin-top: -10px;
  background-color: rgba(28, 50, 255, 1);
  transform: rotate(45deg);
  transition: all 0.1s ease-in-out;
}
.comparison-slider-wrapper .comparison-slider .divider:after {
  content: "";
  position: absolute;
  width: 12px;
  height: 12px;
  left: -5px;
  top: 50%;
  margin-top: -6px;
  background-color: white;
  transform: rotate(45deg);
  transition: all 0.1s ease-in-out;
}
.comparison-slider-wrapper .comparison-slider .divider.draggable:before {
  width: 30px;
  height: 30px;
  left: -14px;
  margin-top: -15px;
}
.comparison-slider-wrapper .comparison-slider .divider.draggable:after {
  width: 20px;
  height: 20px;
  left: -9px;
  margin-top: -10px;
  background-color: white;
}
.comparison-slider-wrapper .caption {
  position: relative;
  width: 100%;
  padding: 3px;
  box-sizing: border-box;
  font-size: 10px;
  text-align: center;
}

/*To disable highlight/text select on slider containers*/
.prevent-select {
  -webkit-user-select: none; /* Safari */
  -ms-user-select: none; /* IE 10 and IE 11 */
  user-select: none; /* Standard syntax */
}

/*For Smooth-scrolling to specified Anchor*/
html {
  scroll-behavior: smooth;
}

.subject	{
	color: rgba(28, 50, 255, 1);
    font-weight: bold;
    letter-spacing: 0.7px;
}

/* Disable Backdrop Design on Mobile View */
body.mobile .backdrop	{
    display: none;
}

/* Custom Text Hover Image (max size 128x128px!)*/
body.mobile .imgcursor	{
    border-bottom: 0px;
}

.degree	{
    cursor: url("https://files.cargocollective.com/c1152940/Convocation2021_icon.png"), auto;
}

.mail	{
    cursor: url("https://files.cargocollective.com/c1152940/mail_cursor.png"), auto;
}

body.mobile .who-menu	{
    display: none;
}

.intro	{
	display: none;
}

body.mobile .intro	{
    position: initial;
    display: block;
    margin-top: -1.0rem;
}

.palette-grid {
  display: flex;
  gap: 12px;
  margin: 12px 0px;
}

/* Rotation CSS by Cargo */
.rotate {
    display: inline-block;
    -webkit-animation: rotate 4s linear infinite;
    animation: rotate 4s linear infinite;
}

@keyframes rotate {
    from {
        transform: rotate(0deg);
    }
    to {
        transform: rotate(360deg);
    }
}

/* Swatches CSS for Color Palette */
.swatch {
	width: 100%;
    border-radius: 8px;
}

.swatch-lg {
  aspect-ratio: 16 / 9;
}

.swatch-sm {
  aspect-ratio: 1 / 1;
}

body.mobile .palette-grid {
	gap: 8px;
    margin: 8px 0px;
}

body.mobile .swatch {
	border-radius: 4px;
}

/* Hero Collages */
.hero-collage {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  grid-template-rows: 12vw 12vw 12vw;
  gap: 12px;
  width: 100%;
}

.hero-collage .item, .sb-div1 > * {
  border-radius: 8px;
  overflow: hidden;
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
}

.hero-collage img, .sb-div1 img {
  max-width: 100%;
  max-height: 100%;
  object-fit: cover;
  display: block;
}

/* Grid area placement (using grid lines) */
.collage-img1 { grid-column: 1 / 3; grid-row: 1 / 2; }
.collage-img2 { grid-column: 3 / 4; grid-row: 1 / 2; }
.collage-img3 { grid-column: 1 / 2; grid-row: 2 / 4; }
.collage-logo { grid-column: 2 / 3; grid-row: 2 / 3; background: #E84D30;}
.collage-img4 { grid-column: 3 / 4; grid-row: 2 / 4; }
.collage-img5 { grid-column: 2 / 3; grid-row: 3 / 4; }

/* Responsive: scale down whole collage but keep structure */
@media (max-width: 900px) {
  .hero-collage {
    width: 100%;
    gap: 8px;
    grid-template-rows: 20vw 20vw 20vw;
  }
    
  .hero-collage .item  {
	border-radius: 4px;
  }
}

/* Description Text Spacer */
.desctext {
    margin: 10rem 0px;
    padding: 0px 12rem;
}

body.mobile .desctext {
    margin: 7rem 0px;
    padding: 0px 0rem;
}

/* Seabank's Detail Div */
.sb-div1 {
    display: grid;
    width: 100%;
    grid-template-columns: repeat(2, 1fr);
    grid-template-rows: repeat(2, 16vw) repeat(6, auto) repeat(2, 20vw) repeat(2, auto);
    gap: 12px;
    
}

.sb-div1 > * {
  border-radius: 0px;
}
   
.sb-div1 .obj1 {
    grid-row: span 2 / span 2;
}

.sb-div1 .obj2 {
    grid-row: span 2 / span 2;
}

.sb-div1 .obj3 {
    grid-column: span 2 / span 2;
    grid-row-start: 3;
    padding: 4rem;
}

.sb-div1 .obj4 {
    grid-column: span 2 / span 2;
    grid-row: span 3 / span 3;
    grid-row-start: 4;
    padding: 6rem 4rem;
    gap: 6rem;
    grid-gap: 6rem;
}

.sb-div1 .obj5 {
    grid-column: span 2 / span 2;
    grid-row: span 2 / span 2;
    grid-row-start: 7;
}

.sb-div1 .obj6 {
    grid-row: span 2 / span 2;
    grid-row-start: 9;
}

.sb-div1 .obj7 {
    grid-row: span 2 / span 2;
    grid-row-start: 9;
}

.sb-div1 .obj8 {
    grid-column: span 2 / span 2;
    grid-row: span 2 / span 2;
    grid-row-start: 11;
}

/* Add bg to PNGs in image-gallery class*/
.gallery-bg .gallery_card_image {
	background-color: #F5F5F5;
}