@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+TC:wght@100;400;700&display=swap');

:root {
  --bs-primary: #C2C2FF; /* hsv(181, 46%, 52%) */
  --bs-primary-rgb: 71, 131, 132;
  --bs-body-color: #E2E6FA;
  --bs-link-color: #EFD4AF; /* hsv(181, 46%, 37%) */
  --bs-link-color-rgb: 239, 212, 175;
  --bs-link-hover-color: #9B9BCC; /* hsv(181, 46%, 22%) */
  --bs-link-hover-color-rgb: 155, 155, 204;
  --bs-primary-bg: #171A6C;
  --bs-primary-line: rgba(194,194,255,.59);
  --bs-primary-bg-gradient: linear-gradient(89.88deg, #E68D91 0.2%, #C2C2FF 98.21%);
  --bs-primary-btn-bg: var(--bs-primary);
  --bs-secondary: #363A90;
  --bs-secondary-color: #181818;
  --bs-secondary-headind: #F3D3D4;
  --bs-secondary-line: #C5E3E9;
  --bs-content-desktop-width: 680px;
  --bs-border-radius: 14px;
  --bs-image-radius: 28px;
}

:root, [data-bs-theme=light]{
  --bs-heading-color: #C2C2FF;
}

.btn {
  --bs-btn-border-radius: 0.25rem;
  transition: all  .4s ease-out;
  padding: 0.5rem 1rem;
  border-radius: 1.25rem;
}

.btn:hover{
  transition: all .4s ease-out;
}

.btn-primary {
  color: var(--bs-primary-bg);
  background: linear-gradient(120deg, #F6B6A8 0%, #C2C2FF 100%);
  /* Rectangle 9 */  
  border: none;   
}

.btn-primary:hover{
  color: var(--bs-primary-bg);
  background: #F6B6A8;
}

.btn-secondary {
  color: var(--bs-white);
  --bs-btn-bg: var(--bs-link-hover-color);
  --bs-btn-border-color: var(--bs-link-hover-color);
  --bs-btn-hover-bg: #7762CC;
  --bs-btn-hover-border-color: #7762CC;
  --bs-btn-active-bg: var(--bs-link-hover-color);
  --bs-btn-active-border-color: var(--bs-link-hover-color);
}

.btn-outline-primary {
  color: var(--bs-primary-bg);
  --bs-btn-bg: var(--bs-secondary-headind);
  --bs-btn-border-color: var(--bs-secondary-headind);
  --bs-btn-hover-bg: var( --bs-primary-btn-bg);
  --bs-btn-hover-border-color: var(--bs-primary-btn-bg);
  --bs-btn-active-bg: var( --bs-primary-btn-bg);
  --bs-btn-active-border-color: var( --bs-primary-btn-bg);
}

.btn-outline-primary:hover{
  color: var(--bs-primary-bg);
}

.btn-outline-secondary {
  --bs-btn-color: var(--bs-primary);
  --bs-btn-bg: transparent;
  --bs-btn-border-color: var(--bs-primary);
  --bs-btn-hover-bg: var(--bs-primary-btn-bg);
  --bs-btn-hover-border-color: var(--bs-primary-btn-bg);
  --bs-btn-active-bg: var(--bs-primary-btn-bg);
  --bs-btn-active-border-color: var(--bs-primary-btn-bg);
}

.btn-outline-secondary:hover{
  color: var(--bs-primary-bg);
}

.btn-link{
  color: var(--bs-link-hover-color);
  --bs-btn-hover-color:  var(--bs-primary);
}

.sp-block-image-double{
  margin-top: 1.8rem;
  margin-bottom: 1rem;
}


body {
  font-family: 'Noto Sans TC', var(--bs-font-sans-serif);
  font-weight: 400;
  letter-spacing: 0.125em;
  line-height: 1.3;
}

.h1, .h2, .h3, .h4, .h5, .h6, h1, h2, h3, h4, h5, h6{
  line-height: 1.3;
}

a{
  color: var(--bs-primary);
}

.sp-container {
  --sp-navbar-height: 4rem;
  background: url(assets/kv-bg.jpg) 0 0 no-repeat,var(--bs-primary-bg);
  background-size: contain;
}
@media (max-width: 767px) {
  .sp-container {
    background: url(assets/kv-bg-m.jpg) 0 0 no-repeat,var(--bs-primary-bg);
    background-size: contain;
  }

  .sp-nav {
    padding: 0.5rem;
    font-size: 0.875rem;
  }
}
@media (min-width: 768px) {
  .sp-container {
    --sp-navbar-height: 4rem;
  }
  .sp-site-header{
    width: calc(100% - 120px);
    margin: 0 auto;
    padding-top: 2.5rem;
  }
  .sp-container__inner {
    position: relative;
    display: flex;
    flex-direction: column;
    align-items: center;
    padding-bottom: 4em;
  }
  .sp-container__inner::before {
    position: absolute;
    top: 0;
    bottom: 0;
    right: 0;
    display: block;
    content: "";
  }
  .sp-nav {
    display: flex;
    padding-bottom: 0.75rem;
  }
  .sp-footer {
    grid-column: 1 / 5;
    grid-row: 3 / 3;
  }
}

@media (min-width: 768px) {
  .sp-nav {
    padding-top: 1rem;
    padding-bottom: 1rem;
  }
  .sp-nav .nav {
    top: 3rem;
    flex-wrap: nowrap;
    margin: 0 auto;
  }
  .sp-header {
    margin-top: 2rem;
    margin-bottom: 4rem;
    padding-top: var(--sp-navbar-height);
  }
  .sp-header h1 {
    width: var(--bs-content-desktop-width);
  }
  .sp-header__meta {
    width: var(--bs-content-desktop-width);
  }
  .sp-main{
    width: var(--bs-content-desktop-width);
  }
}
.sp-nav .nav-link {
  color: var(--bs-body-color);
}
.sp-nav .nav-link:hover,
.sp-nav .nav-link:focus {
  border-radius: 0.5rem;
  background-color: rgba(255, 255, 255);
  color: var(--bs-secondary);
}
.sp-nav .nav-link.active {
  color: var(--bs-body-color);
}
.sp-nav .nav-link.active:hover,.dropdown-item,.dropdown-item:hover{
  color: var(--bs-secondary);
}

.sp-header {
  margin-bottom: 3rem;
  padding-top: var(--sp-navbar-height);
  width: 100%;
  padding: 1em;
}

.sp-header h1 {
  font-size: 2.375rem;
  font-weight: bold;
  letter-spacing: 2px;
  display: block;
  margin: 0 auto;
  padding-bottom: 20px;
  line-height: 1.6;
  color: var(--bs-white);
  text-shadow: 0px 4px 4px rgba(0,0,0,0.25);
}
.sp-header__meta {
  color: var(--bs-heading-color);
  display: none;
  margin: 15px auto;
  font-size: 0.875rem;
}

.sp-block-header {
  margin-top: 3rem;
  margin-bottom: 0.8rem;
}

.sp-block-header h1 { position: relative; margin-bottom: 0; font-size: 1.75rem; font-weight: bold; }
.sp-block-header h2 { position: relative; margin-bottom: 0; font-size: 1.5rem; font-weight: 400; }
.sp-block-header h3 { position: relative; margin-bottom: 0; font-size: 1.25rem; font-weight: bold; color: var(--bs-secondary-headind); }
.sp-block-header h4 { position: relative; margin-bottom: 0; font-size: 1rem; font-weight: bold; }
.sp-block-header h5 { position: relative; margin-bottom: 0; font-size: 1rem; font-weight: bold; }
.sp-block-header h6 { position: relative; margin-bottom: 0; font-size: 1rem; font-weight: bold; }

.sp-block-text {
  margin-bottom: 1.5rem;
  font-size: 1rem;
  line-height: 1.6;
  letter-spacing: 1px;
}

.sp-block-text--leading {
  font-size: 1.125rem;
}

.sp-block-text--pull-quote {
  margin-top: 2rem;
  margin-bottom: 2rem;
  padding: 1.5rem 2rem;
  color: var(--bs-body-color);
  font-size: 1rem;
  font-weight: lighter;
  background-color: var(--bs-secondary);
  border-radius: var(--bs-border-radius);
}

.sp-block-text--pull-quote p{
  margin-bottom: 0;
}


.sp-main{
  width: 100%;
  padding-left: 1.5rem;
  padding-right: 1.5rem;
  margin-left: auto;
  margin-right: auto;
}
@media (min-width: 576px) { .sp-header, .sp-main { max-width: 540px; } }
@media (min-width: 768px) { .sp-header, .sp-main { max-width: 720px; } }
@media (min-width: 992px) { .sp-header, .sp-main { max-width: 960px; } }

@media (min-width: 768px) {

  .sp-header h1 {
    font-size: 3.125rem;
  }
  .sp-header__meta{
    font-size: 1rem;
  }
}
@media (min-width: 576px) {
  .sp-block-text--pull-quote {
    padding-left: 4rem;
    padding-right: 4rem;
    font-size: 1.125rem;
  }
  .sp-block-header h2{
    font-size: 2.125rem;
  }
  .sp-block-text{
    font-size: 1.125rem;
  }
}

.sp-block-image{
  margin-top: 3rem;
  margin-bottom: 1rem;
  text-align: center;
  position: relative;
}

.sp-block-image-double__item,.sp-block-slider{
  text-align: center;
  position: relative;
}

.sp-block-image-double__image{
  object-fit: cover;
}

.sp-block-image__image,.sp-block-image-double__image,swiper-container{
  border-radius: var(--bs-image-radius);
  border-width: 2px 0 0 0;
  border-style: solid;
  border-color: transparent;
  background: var(--bs-primary-bg-gradient) border-box;
  overflow: hidden;
}

.sp-block-image__caption,.sp-block-image-double__caption {
  margin-top: 1rem;
  margin-bottom: 1rem;
  color: var(--bs-link-hover-color);
}

.sp-block-image__caption a{
  color: var(--bs-heading-color);
}


.sp-block-separator hr {
  margin-top: 3rem;
  margin-bottom: 3rem;
  width: 100%;
  height: 0;
  border-top: 3px solid;
  border-color: var(--bs-primary-line);
}

.sp-block-socials {
  background-color: rgba(255, 255, 255, 0.3);
  border-radius: 0.5rem;
  padding: 0.75rem 1rem;
}
.sp-block-socials a {
  font-size: 1.5rem;
}

.sp-block-link-card {
  margin-left: auto;
  margin-right: auto;
  margin-bottom: 1rem;
  box-shadow: var(--bs-box-shadow-sm);
}
.sp-block-link-card .card {
  display: grid;
  grid-template-columns: 8rem 1fr;
  position: relative; /* for stretched link */
  overflow: hidden;
}

.sp-block-link-card__img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.sp-block-link-card__title {
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  font-size: 1rem;
  font-weight: bold;
  color: var(--bs-primary-bg);
  overflow: hidden;
}
.sp-block-link-card__description {
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  overflow: hidden;
  margin-bottom: 0.5rem;
  font-size: 0.875rem;
  color: var(--bs-gray-700);
}
.sp-block-link-card__domain {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  font-size: 0.75rem;
  color: var(--bs-gray);
}
.sp-block-link-card .card-body {
  word-break: break-word;
}

@media (max-width: 575px) {
  .sp-block-link-card .card-body {
    padding: 0.5rem 0.75rem;
  }
}

.sp-block-index .card {
  --bs-card-border-width: 0;
  --bs-card-border-radius: 0;
  --bs-card-bg: rgba(0, 0, 0, 0.05);
  --bs-card-spacer-x: 0.75rem;
  --bs-card-spacer-y: 0.75rem;
  border-radius: var(--bs-border-radius);
  background: var(--bs-secondary);
}

.sp-block-index .card ul{
  padding-left: 0;
  margin: 8px 0;
}

.sp-block-index .card ul li{
  list-style-type: none;
  margin-left: 0;
  margin-bottom: 8px;
  padding-left: 1em;
  line-height: 1.5;
}

.sp-block-index__toggle {
  --bs-btn-padding-x: 0rem;
  --bs-btn-padding-y: 0.25rem;
  /* From .btn-secondary */
  --bs-btn-color: var(--bs-secondary-line);
  --bs-btn-bg: transparent;
  --bs-btn-hover-color: var(--bs-secondary-line);
  --bs-btn-hover-bg: transparent;
  --bs-btn-hover-border-color: var(--bs-secondary-line);
  --bs-btn-active-color: var(--bs-secondary-line);
  --bs-btn-active-bg: transparent;
  --bs-btn-active-border-color: var(--bs-secondary-line);
  border-top: transparent;
  border-left: transparent;
  border-right: transparent;
  border-bottom: 1px solid var(--bs-secondary-line);
  border-radius: 0;
  display: block;
  text-align: left;
  line-height: 2;
}

.sp-block-index__toggle[aria-expanded=false]::after {
	display: inline-block;
	margin-left: .75em;
	vertical-align: .255em;
	content: "";
	border-top: .3em solid;
	border-right: .3em solid transparent;
	border-bottom: 0;
	border-left: .3em solid transparent;
  position: absolute;
  right: 1.25rem;
  top: 1.65rem;
}

.sp-block-index__toggle[aria-expanded=true]::after {
	display: inline-block;
	margin-left: .75em;
	vertical-align: .255em;
	content: "";
	border-top: 0;
	border-right: .3em solid transparent;
	border-bottom: .3em solid;
	border-left: .3em solid transparent;    
  position: absolute;
  right: 1.25rem;
  top: 1.65rem;
}

.sp-block-index__list {
  padding-top: var(--bs-card-spacer-y);
  /* Balance out <ul> left-padding */
  padding-right: 1rem;
}

.sp-block-index__list ul {
  margin-bottom: 0;
  line-height: 1.75;
  list-style-type: square;
}

.sp-block-index__list ul a {
  text-decoration: none;
  line-height: 2;
  color: var(--bs-body-color);
}

.sp-block-index__list ul a:hover{
  color: var(--bs-white);
}

.sp-block-socials {
  --icon-discord: url('./cold-tech/assets/socials/icon-discord.svg');
  --icon-discord-ver: url('./cold-tech/assets/socials/icon-discord-ver.svg');
  --icon-email: url('./cold-tech/assets/socials/icon-email.svg');
  --icon-email-ver: url('./cold-tech/assets/socials/icon-email-ver.svg');
  --icon-facebook: url('./cold-tech/assets/socials/icon-facebook.svg');
  --icon-facebook-ver: url('./cold-tech/assets/socials/icon-facebook-ver.svg');
  --icon-github: url('./cold-tech/assets/socials/icon-github.svg');
  --icon-github-ver: url('./cold-tech/assets/socials/icon-github-ver.svg');
  --icon-instagram: url('./cold-tech/assets/socials/icon-instagram.svg');
  --icon-instagram-ver: url('./cold-tech/assets/socials/icon-instagram-ver.svg');
  --icon-line: url('./cold-tech/assets/socials/icon-line.svg');
  --icon-line-ver: url('./cold-tech/assets/socials/icon-line-ver.svg');
  --icon-linkedin: url('./cold-tech/assets/socials/icon-linkedin.svg');
  --icon-linkedin-ver: url('./cold-tech/assets/socials/icon-linkedin-ver.svg');
  --icon-pixiv: url('./cold-tech/assets/socials/icon-pixiv.svg');
  --icon-pixiv-ver: url('./cold-tech/assets/socials/icon-pixiv-ver.svg');
  --icon-podcast: url('./cold-tech/assets/socials/icon-podcast.svg');
  --icon-podcast-ver: url('./cold-tech/assets/socials/icon-podcast-ver.svg');
  --icon-threads: url('./cold-tech/assets/socials/icon-threads.svg');
  --icon-threads-ver: url('./cold-tech/assets/socials/icon-threads-ver.svg');
  --icon-tiktok: url('./cold-tech/assets/socials/icon-tiktok.svg');
  --icon-tiktok-ver: url('./cold-tech/assets/socials/icon-tiktok-ver.svg');
  --icon-twitch: url('./cold-tech/assets/socials/icon-twitch.svg');
  --icon-twitch-ver: url('./cold-tech/assets/socials/icon-twitch-ver.svg');
  --icon-website: url('./cold-tech/assets/socials/icon-website.svg');
  --icon-website-ver: url('./cold-tech/assets/socials/icon-website-ver.svg');
  --icon-wechat: url('./cold-tech/assets/socials/icon-wechat.svg');
  --icon-wechat-ver: url('./cold-tech/assets/socials/icon-wechat-ver.svg');
  --icon-x: url('./cold-tech/assets/socials/icon-x.svg');
  --icon-x-ver: url('./cold-tech/assets/socials/icon-x-ver.svg');
  --icon-youtube: url('./cold-tech/assets/socials/icon-youtube.svg');
  --icon-youtube-ver: url('./cold-tech/assets/socials/icon-youtube-ver.svg');
}

.sp-footer {
  padding-top: 1.5rem;
  padding-bottom: 1.5rem;
  background-color: rgba(128, 128, 128, 0.075);
  color: var(---bs-link-hover-color);
  text-align: center;
  font-size: 0.875rem;
}


/* 2024 add section */
.sp-header,.sp-block-kv .sp-block-kv-image{
  display: none;
}
.sp-block-kv .sp-block-header{
  margin: 2rem 0;
}
.sp-block-kv .sp-block-header h2{
  font-size: 3.125rem;
  font-weight: bold;
  letter-spacing: 2px;
  display: block;
  margin: 0 auto;
  padding-bottom: 20px;
  line-height: 1.6;
  color: var(--bs-white);
  text-shadow: 0px 4px 4px rgba(0,0,0,0.25);
}
.sp-block-kv .sp-block-header p{
  color: var(--bs-gray);
  display: none;
}
.sp-block-wrap-text-left .sp-block-wrap, .sp-block-wrap-text-right .sp-block-wrap{
  margin: 20px auto;
  word-break: break-word;
}
.sp-block-wrap{
  display: flex;
  flex-direction: column;
  align-items: center;
  margin: 1rem;
}
.sp-wrap-image ,.sp-wrap-text-header {
  flex-basis: 50%;
}
.sp-wrap-image{
  aspect-ratio: 1.32 / 1;
  overflow: hidden;
  max-width: 100%;
  border-radius: var(--bs-image-radius);
  border-width: 2px 0 0 0;
  border-style: solid;
  border-color: transparent;
  background: var(--bs-primary-bg-gradient) border-box;
  overflow: hidden;
}
.sp-wrap-image__image{
  width: 100%; 
  height: 100%; 
  object-fit: cover;
}
.sp-block-wrap-text-left .sp-wrap-image .sp-block-image-double__image ,.sp-block-wrap-text-right .sp-wrap-image .sp-block-image-double__image{
  height: 100%;
  width: auto;
  aspect-ratio: auto;
  overflow: hidden;
}
.sp-block-wrap .sp-wrap-text-header{
  padding: 1rem;
  display: flex;
  flex-direction: column;
  justify-content: center;
  line-height: 1.5;
}
.sp-wrap-text-header h3{
  color: var(--bs-secondary-line);
  padding: 0 0 0.5rem 0;
}
.sp-block-wrap-text-right .sp-wrap-text-header h3{
  color: var(--bs-primary);
}
.sp-block-wrap-text-right .sp-wrap-image{
  order: 0;
}
.sp-block-wrap-text-right .sp-wrap-text-header{
  order: 1;
  color: var(--bs-white);
}
.sp-block-wrap-text-left .sp-wrap-text-header{
  color: var(--bs-white);
}
.sp-block-text-card{
  background-color: var(--bs-heading-color);
  border-radius: var(--bs-image-radius);
  color: var(--bs-link-color);
  padding: 2rem;
}
.sp-block-text-card .sp-wrap-text-header{
  padding-bottom: 1rem;
}
.sp-block-text-card .sp-wrap-text-header h3{
  padding: 0;
  font-size: 1.275rem;
  color: var(--bs-secondary);
}
.sp-block-text-card .sp-wrap-text{
  color: var(--bs-gray);
}

@media (min-width: 768px) { 
  .sp-block-wrap{
    flex-direction: row;
  }
  .sp-block-wrap .sp-wrap-text-header{
    padding: 1rem 2rem;
  }
  .sp-wrap-text-header h3{
    color: var(--bs-secondary-line);
  }
  .sp-block-wrap-text-left .sp-block-wrap, .sp-block-wrap-text-right .sp-block-wrap{
    margin: 3rem auto;
  }
  .sp-block-wrap-text-right .sp-wrap-image{
    order: 1;
  }
  .sp-block-wrap-text-right .sp-wrap-text-header{
    order: 0;
  }
 }