/*----------------------------------------------------
 *              Base Style
 * ----------------------------------------------------*/
main img {
  max-width: 100%;
}

main h3 {
  margin: 1rem auto 0;
}
main section:nth-last-of-type(2) .grid {
  padding-bottom: 0 !important;
}

main#main-content {
  overflow: clip;
}

@media (max-width: 768px) {
  main.DEU h2 {
    word-break: break-word;
  }
}
/*--------------------------------------------------
 *            Hide obstructive ad if mobile
 * ----------------------------------------------------*/
@media (max-width: 1000px) {
  div.fix_bottom {
    display: none !important;
  }
}
/*----------------------------------------------------
 *                 Top Hero
 * ----------------------------------------------------*/
section.hero {
  display: grid;
  min-height: 620px;
  max-height: fit-content;
  position: relative;
}
section.hero .p-name {
  color: white;
}
section.hero .backdrop {
  position: absolute;
  width: 100%;
  height: 100%;
}
section.hero .backdrop img {
  object-fit: cover;
  width: 100%;
  height: 100%;
}
section.hero .wrapper.product-info {
  max-width: 1600px;
  gap: 1rem;
}

/*----------------------------------------------------
 *              CTA buttons style
 * ----------------------------------------------------*/
:is(#boost-sales, #your-business, #stock-media, #grab-attention) a.trial-btn {
  background: black;
  color: white;
  border-radius: 7px;
  font-size: 1rem;
  line-height: 1;
  display: flex;
  flex-direction: column;
  justify-content: center;
  height: 70px;
  width: -webkit-fill-available;
  min-width: 250px;
  border: 0;
  margin-top: 1.2rem;
  text-transform: uppercase;
  transition: all 0.2s;
}
:is(#boost-sales, #your-business, #stock-media, #grab-attention) a.trial-btn:hover {
  transform: scale(1.05);
}

a.trial-btn {
  min-width: 250px;
  width: fit-content;
  max-width: 251px;
}

:is(.hero, .bottom-hero) a.trial-btn {
  border: 2px solid white;
  text-align: center;
  color: white;
}
:is(.hero, .bottom-hero) a.buy-now-btn {
  color: #000000;
  background: #21EEEF;
  transition: 0.2s all;
  min-width: 250px !important;
  padding: 10px 10px;
}
:is(.hero, .bottom-hero) a.buy-now-btn span, :is(.hero, .bottom-hero) a.buy-now-btn:hover {
  color: black !important;
}

@media (max-width: 600px) {
  :is(#boost-sales, #your-business, #stock-media) a.trial-btn {
    margin-left: auto;
    margin-right: auto;
  }
}
/*----------------------------------------------------
 *              Promotional Ribbon
 * ----------------------------------------------------*/
.promo-ribbon {
  position: absolute;
  background-color: #ff0057;
  padding: 8px 16px;
  border-bottom-right-radius: 6px;
  font-weight: 700;
  z-index: 3;
}
.promo-ribbon a {
  color: #fff;
}

.promo-ribbon:has(a:empty) {
  display: none;
}

@media (max-width: 620px) {
  .promo-ribbon {
    width: 100vw;
    border-radius: 0;
    height: fit-content;
    position: unset;
    order: 1;
  }
}
/*----------------------------------------------------
 *              New tag style
 * ----------------------------------------------------*/
span.new {
  position: absolute;
  background: red;
  padding: 0.2rem 0.5rem;
  border-radius: 10px;
  font-size: clamp(12px, 2vw, 15px);
  rotate: -15deg;
  color: #fff;
  line-height: 1;
  left: -15px;
  top: 13px;
  font-weight: bold;
}

@media (max-width: 1125px) {
  span.new {
    width: max-content;
    rotate: none;
    left: 2rem;
    top: 0;
  }
}
/*--------------------------------------------------
 *              Intel AI PC section
 * ----------------------------------------------------*/
#intel-ai-pc {
  background: #181829;
  padding: 80px 2rem;
  margin-top: 0;
}
#intel-ai-pc .content {
  margin: 0 auto;
  max-width: 1600px;
}
#intel-ai-pc .content h2, #intel-ai-pc .content h3 {
  color: #21EEEF;
  text-align: center;
}
#intel-ai-pc .content h3 {
  margin-bottom: 0.5rem;
}
#intel-ai-pc .content p, #intel-ai-pc .content i {
  color: white;
  text-align: center;
  display: block;
  font-weight: 200;
}
#intel-ai-pc .content .flex-container {
  display: flex;
  gap: clamp(20px, 4vw, 4rem);
  flex-wrap: wrap;
  justify-content: center;
}
#intel-ai-pc .content .flex-container > div {
  flex-basis: 100%;
  max-width: 485px;
}
#intel-ai-pc .content .flex-container img {
  display: block;
  margin: 0 auto;
}
#intel-ai-pc img {
  display: block;
  margin: 4rem auto 2rem;
}

/*--------------------------------------------------
 *              Boost Sales section
 * ----------------------------------------------------*/
:is(#stock-media, #ready-to-share, #your-business, #cohesive-branding, #japan-branding) {
  background: #fff;
}
:is(#stock-media, #ready-to-share, #your-business, #cohesive-branding, #japan-branding) .grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  padding: 5rem 0;
  max-width: 1200px;
  margin: 0 auto;
  row-gap: 5.5rem;
  justify-items: center;
}
:is(#stock-media, #ready-to-share, #your-business, #cohesive-branding, #japan-branding) .grid > div {
  padding: 2rem;
  height: fit-content;
  place-self: center;
  max-width: 550px;
  z-index: 2;
}
@media (max-width: 767px) {
  :is(#stock-media, #ready-to-share, #your-business, #cohesive-branding, #japan-branding) .grid > div {
    padding: 0rem;
  }
}
:is(#stock-media, #ready-to-share, #your-business, #cohesive-branding, #japan-branding) picture, :is(#stock-media, #ready-to-share, #your-business, #cohesive-branding, #japan-branding) video {
  z-index: 2;
}
:is(#stock-media, #ready-to-share, #your-business, #cohesive-branding, #japan-branding) video {
  align-self: center;
  max-width: 460px;
  box-shadow: -40px -40px 0px #DAE1EB;
}

#boost-sales .grid {
  display: grid;
  grid-template-columns: 1fr;
  padding: 5rem 0;
  max-width: 1200px;
  margin: 0 auto;
  row-gap: 5.5rem;
  justify-items: center;
}
#boost-sales .grid > div {
  display: flex;
  justify-content: space-around;
  width: 100%;
}
#boost-sales .grid > div > div {
  position: relative;
}
#boost-sales .grid > div h3 {
  margin-top: 0 !important;
}
#boost-sales .grid > div div {
  padding: 2rem;
  height: fit-content;
  place-self: center;
  max-width: 550px;
  z-index: 2;
  flex: 1 1 0;
}
#boost-sales .grid > div video {
  flex: 1 1 0;
}
#boost-sales .grid > div:nth-of-type(2n + 1):not(.intro) {
  flex-direction: row-reverse;
}
#boost-sales picture, #boost-sales video {
  z-index: 2;
}
#boost-sales video {
  align-self: center;
  max-width: 460px;
  box-shadow: -40px -40px 0px #DAE1EB;
}

:is(#boost-sales, #ready-to-share, #cohesive-branding, #japan-branding) {
  margin-top: 0;
}
:is(#boost-sales, #ready-to-share, #cohesive-branding, #japan-branding) .intro {
  grid-column: 1/-1;
  max-width: 1200px !important;
  display: flex;
  flex-direction: column;
  align-items: center;
}
:is(#boost-sales, #ready-to-share, #cohesive-branding, #japan-branding) h2 {
  grid-column: 1/-1;
  text-align: center;
  font-size: clamp(2rem, 5vw, 2.6rem);
  margin: 0;
  max-width: 33ch;
}
:is(#boost-sales, #ready-to-share, #cohesive-branding, #japan-branding) h3 {
  font-size: clamp(1.8rem, 2vw, 1.8rem);
  font-weight: 600;
  margin: 1rem auto 0.7rem auto !important;
}

#stock-media {
  margin-top: 0;
}
#stock-media .grid {
  grid-template-columns: 1fr 1.4fr;
  grid-template-rows: clamp(0px, 20vw, 20rem) 1.4fr;
  row-gap: 0;
  transition: all 0.2s;
}
#stock-media .grid .txt {
  grid-column: 1;
  grid-row: 2/3;
  padding: 4rem 0 4rem 4rem;
  z-index: 3;
}
#stock-media .grid picture {
  grid-column: 2;
  grid-row: 1/3;
  align-self: end;
  padding-bottom: 10%;
}
#stock-media .grid .black-border {
  grid-column: 1/-1;
  grid-row: 2/3;
  border: 2px solid black;
  border-radius: 20px;
  width: 100%;
  z-index: 2;
  backdrop-filter: blur(5px);
  -webkit-backdrop-filter: blur(5px);
}
#stock-media img.backdrop {
  position: absolute;
  left: 8%;
  z-index: 1;
  top: 4%;
  width: 40vw;
  max-width: 400px;
}

#boost-sales .grid picture {
  align-self: center;
  max-width: 460px;
  box-shadow: -40px -40px 0px #DAE1EB;
  border-radius: 20px;
  width: 80%;
  overflow: hidden;
  display: flex;
}

#your-business {
  background: #D8E0EC;
  position: relative;
  margin-top: 0;
}
#your-business video {
  box-shadow: none;
}
#your-business .grid {
  padding-top: 0;
}
#your-business .grid > div {
  width: 100%;
  height: 100%;
  display: flex;
  flex-direction: column;
  justify-content: center;
}
#your-business::before {
  content: "";
  position: absolute;
  width: 350px;
  height: 350px;
  display: block;
  background: url(https://dl-asset.cyberlink.com/web/stat/edms/product-version-images/2023/Promeo/sticker-plus.png);
  top: -40%;
  right: 20px;
  z-index: 1;
  background-size: cover;
}
#your-business::after {
  content: "";
  position: absolute;
  width: 200px;
  height: 200px;
  display: block;
  background: url(https://dl-asset.cyberlink.com/web/stat/edms/product-version-images/2023/Promeo/sticker-star.png);
  top: -80%;
  left: 10%;
  z-index: 1;
  background-size: cover;
}

@media (max-width: 1600px) {
  #boost-sales .grid::before {
    right: 9%;
  }
}
@media (max-width: 1500px) {
  :is(#boost-sales, #stock-media, #ready-to-share, #your-business, #cohesive-branding) video {
    max-width: 400px;
  }
}
@media (max-width: 1100px) {
  #stock-media .grid {
    grid-template-rows: clamp(0px, 16vw, 20rem) 1.4fr;
  }
}
@media (max-width: 1080px) {
  #boost-sales div video, #boost-sales div picture {
    box-shadow: 30px 30px 0px #DAE1EB !important;
  }
  #boost-sales div.invert-mobile video, #boost-sales div.invert-mobile picture {
    box-shadow: -30px -30px 0px #DAE1EB !important;
  }
  #boost-sales .grid > div {
    column-gap: 2rem;
  }
}
@media (max-width: 1050px) {
  #stock-media .grid {
    grid-template-rows: clamp(0px, 9vw, 20rem) 1.4fr;
  }
}
@media (max-width: 1024px) {
  #boost-sales .grid picture {
    max-width: 300px;
  }
  :is(#boost-sales, #stock-media, #ready-to-share, #your-business, #cohesive-branding) video {
    max-width: 300px;
  }
}
@media (max-width: 1000px) {
  #boost-sales .grid > div {
    column-gap: 2rem;
  }
  #stock-media .grid {
    grid-template-rows: clamp(0px, 3vw, 20rem) 1.4fr;
  }
}
@media (max-width: 900px) {
  #stock-media .grid {
    grid-template-rows: 0px 1.4fr;
  }
  #stock-media img.backdrop {
    left: -4%;
    top: 2%;
  }
}
@media (max-width: 870px) {
  #stock-media .grid .txt {
    padding: 2rem 1rem 2rem 2rem;
  }
}
@media (max-width: 767px) {
  :is(#boost-sales, #stock-media, #ready-to-share, #your-business, #cohesive-branding) video {
    max-width: 300px;
    box-shadow: -20px -20px 0px #DAE1EB;
  }
  #boost-sales .grid {
    row-gap: 2rem;
  }
  #boost-sales .grid > div {
    flex-direction: column !important;
    row-gap: 1.5rem;
  }
  #boost-sales .grid picture, #boost-sales .grid video {
    max-width: 400px;
  }
  #stock-media .grid {
    grid-template-columns: 1fr;
    grid-template-rows: auto;
    padding: 2rem 0 0 0;
  }
  #stock-media .grid .txt {
    padding: 0 2rem 2rem 2rem;
  }
  #stock-media .grid .black-border {
    grid-row: 1/3;
    backdrop-filter: blur(2px);
    -webkit-backdrop-filter: blur(2px);
  }
  #stock-media .grid picture {
    align-self: center;
    grid-row: 2;
    grid-row: 1;
    grid-column: 1;
    padding: 1rem;
  }
  #your-business .grid {
    grid-template-columns: 1fr;
  }
}
@media (max-width: 601px) {
  #your-business::after, #your-business::before {
    display: none;
  }
  :is(#boost-sales, #stock-media, #ready-to-share, #your-business, #cohesive-branding) .grid video, :is(#boost-sales, #stock-media, #ready-to-share, #your-business, #cohesive-branding) .grid picture {
    box-shadow: unset !important;
  }
  #boost-sales .grid > div:nth-of-type(2n + 1):not(.intro) video, #boost-sales .grid > div:nth-of-type(2n + 1):not(.intro) picture {
    box-shadow: unset !important;
  }
}
/*--------------------------------------------------
 *              Grab Attention section
 * ----------------------------------------------------*/
:is(#grab-attention, #studio-quality) {
  display: grid;
  row-gap: 3rem;
  padding-top: 5rem;
  margin: 0 auto;
  margin-bottom: 5rem;
}
:is(#grab-attention, #studio-quality) h2 {
  text-align: center;
  font-size: clamp(1.8rem, 5vw, 2.6rem);
  line-height: 1.2;
  margin: 0 auto;
  max-width: 25ch;
}
:is(#grab-attention, #studio-quality) h3 {
  font-size: clamp(1.3rem, 2vw, 1.3rem);
  margin: 1rem auto 0.7rem auto !important;
}
:is(#grab-attention, #studio-quality) .dynamic-box {
  display: flex;
  gap: 3rem;
  flex-wrap: wrap;
  justify-content: center;
}
:is(#grab-attention, #studio-quality) .dynamic-box > div {
  width: clamp(200px, 16vw, 330px);
}
@media (max-width: 769px) {
  :is(#grab-attention, #studio-quality) .dynamic-box > div {
    width: 100% !important;
  }
}
:is(#grab-attention, #studio-quality) .dynamic-box > div :is(h3, p) {
  text-align: center;
}
:is(#grab-attention, #studio-quality) .dynamic-box video {
  box-shadow: 0px 0px 25px rgba(0, 0, 0, 0.1411764706);
}
:is(#grab-attention, #studio-quality) a.trial-btn {
  margin: 0 auto;
}

#studio-quality {
  background: #f3f2f3;
  padding-bottom: 100px;
}

#grab-attention {
  background: #fff5e1;
  padding-bottom: 100px;
  margin-bottom: -100px;
}

@media (max-width: 769px) {
  #grab-attention {
    margin-bottom: -50px;
  }
}
/*--------------------------------------------------
 *             Ready to Share section
 * ----------------------------------------------------*/
#ready-to-share {
  background: #D8E0EC;
}
#ready-to-share .grid {
  row-gap: 3rem;
  padding-bottom: 2rem;
}
#ready-to-share .grid > div {
  padding: 0;
  display: flex;
  flex-direction: column;
}
#ready-to-share .grid > div :is(h3, p) {
  text-align: center;
}
#ready-to-share .grid > div p {
  height: auto;
  padding: 0 30px;
}
#ready-to-share .grid > div video {
  box-shadow: unset;
  border: 2px solid #000;
}

@media (max-width: 767px) {
  #ready-to-share .grid {
    display: flex;
    flex-direction: column;
  }
}
/*--------------------------------------------------
 *             Promote your business section
 * ----------------------------------------------------*/
#your-business h3 {
  margin: 0 0 0.7rem;
}

/*--------------------------------------------------
 *             efficiency section
 * ----------------------------------------------------*/
#efficiency {
  margin: 7rem 1rem;
  padding: 0;
}
#efficiency .grid {
  display: grid;
  grid-template-columns: 1.5fr 1fr;
  border-radius: 20px;
  place-items: center;
  padding: 3rem;
  background: linear-gradient(125deg, #C2EBEF 13.82%, #AFFDE2 86.34%);
  background: #D8E0EC;
  margin: 0 auto;
  overflow: hidden;
  max-width: 1400px;
  position: relative;
}
#efficiency .grid video {
  max-width: 550px;
  z-index: 1;
}
#efficiency .grid .text-block {
  width: 100%;
  padding: 2rem;
  height: fit-content;
}

@media (max-width: 1150px) {
  #efficiency .grid {
    gap: 2rem;
  }
}
@media (max-width: 767px) {
  #efficiency .grid {
    grid-template-columns: 1fr;
    gap: 1rem;
  }
  #efficiency .grid .text-block {
    width: fit-content;
  }
}
@media (max-width: 600px) {
  #efficiency {
    margin: 1rem 0 4rem;
  }
  #efficiency .grid {
    border-radius: 0;
    padding: 2rem;
  }
  #efficiency .grid .text-block {
    width: fit-content;
    padding: 2rem 0;
  }
}
/*--------------------------------------------------
 *            cohesive-branding section
 * ----------------------------------------------------*/
:is(#cohesive-branding, #japan-branding) .grid {
  padding-top: 0;
}
:is(#cohesive-branding, #japan-branding) .grid > div {
  padding: 2rem;
  height: fit-content;
  place-self: center;
  max-width: 550px;
  z-index: 2;
  display: flex;
  flex-direction: column;
  align-content: flex-start;
}
:is(#cohesive-branding, #japan-branding) .grid > div p {
  text-align: center;
}
:is(#cohesive-branding, #japan-branding) video, :is(#cohesive-branding, #japan-branding) .square-video {
  filter: drop-shadow(4px 4px 9px rgba(195, 232, 238, 0.5882352941));
}

@media (max-width: 767px) {
  :is(#cohesive-branding, #japan-branding) .grid {
    grid-template-columns: 1fr;
    row-gap: 2rem;
  }
}
@media (max-width: 601px) {
  :is(#cohesive-branding, #japan-branding) .grid > div {
    padding: 2rem 0;
  }
}
/*--------------------------------------------------
 *            japan-branding section
 * ----------------------------------------------------*/
#japan-branding .grid {
  row-gap: 0;
}
#japan-branding .grid > div {
  display: block;
}
#japan-branding h3 {
  font-size: clamp(1rem, 1.2vw, 1.2rem);
  font-weight: 500;
  margin: 1rem 0 !important;
}
#japan-branding a {
  font-weight: 800;
  width: fit-content;
  transition: all 0.2s;
  padding: 0.3rem 0.5rem;
  border-radius: 7px;
}
#japan-branding a:hover {
  transform: scale(1.05);
  color: white;
  background: black;
}
#japan-branding .ig-story {
  grid-row: span 2;
}
#japan-branding .square-video {
  position: relative;
  padding-bottom: 56.25%;
  overflow: hidden;
  --yt-video-border-radius: 20px;
  border-radius: var(--yt-video-border-radius);
}
#japan-branding #embedded-video {
  position: absolute;
  top: 0;
  left: 0;
  height: auto;
  aspect-ratio: 16/9;
  border-radius: var(--yt-video-border-radius);
}

/*--------------------------------------------------
 *                   utilities
 * --------------------------------------------------*/
main .hero {
  padding: 0 3rem;
}
main .hero .wrapper {
  padding: 0;
  margin: 5rem auto;
}
main .hero h1 {
  line-height: 1.2 !important;
  font-weight: 700;
  font-size: clamp(3rem, 5vw, 3.3rem);
  color: white;
}
main .hero p {
  text-align: left;
  font-size: clamp(1rem, 2vw, 1.1rem);
  color: black;
  line-height: 1.6;
  font-weight: normal !important;
  color: white;
}
main p a {
  color: #00aeff;
  font-weight: 400;
  font-size: clamp(1rem, 2vw, 1.1rem);
}
main p a:hover {
  text-decoration: underline !important;
  text-underline-offset: 3px;
}

.sp-font {
  background: -webkit-linear-gradient(45deg, #2a39ff, #8b2ded 100%);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
}

section.simple3 .wrapper {
  background: linear-gradient(125deg, #C2EBEF 13.82%, #AFFDE2 86.34%);
}

.intro {
  padding: 2rem;
}
.intro p {
  text-align: center;
  max-width: 1200px;
  margin: 0 auto;
}

.ff-list li .cover-btn {
  background: linear-gradient(125deg, rgba(70, 162, 252, 0.6) 13.82%, rgba(215, 99, 193, 0.9411764706) 86.34%);
  background: rgba(31, 32, 32, 0.6784313725);
  backdrop-filter: blur(2px);
}
.ff-list li p {
  line-height: normal;
}

@media (max-width: 1100px) {
  main .hero {
    padding: 0 3rem;
  }
}
@media (max-width: 601px) {
  .intro {
    padding: 2rem 0;
  }
}
/*----------------------------------------------------
 *                 Bottom Hero
 * ----------------------------------------------------*/
.bottom-hero {
  display: flex;
  padding: 0;
  width: 100%;
  justify-content: center;
}
.bottom-hero .backdrop {
  position: absolute;
  width: 100%;
  height: 100%;
  z-index: 1;
  background: linear-gradient(90deg, #0F3EB0 0%, #5E2C9A 100%);
}
.bottom-hero .grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  z-index: 2;
  padding: 4rem 0;
  width: 100%;
  max-width: 1200px;
  place-items: center;
}
.bottom-hero .grid .product {
  display: flex;
  align-items: center;
  gap: 1rem;
  font-weight: 600;
  font-family: "Poppins", sans-serif;
  font-size: clamp(20px, 5vw, 23px);
  padding-bottom: 0.7rem;
  color: white;
}
.bottom-hero .grid .product img.icon {
  max-width: 50px;
}
.bottom-hero .grid h1 {
  line-height: 1;
  font-weight: 700;
  font-size: clamp(30px, 2.2vw, 55px);
  color: white;
}
.bottom-hero .grid .btn-cta {
  justify-content: center;
}

@media (max-width: 1200px) {
  .bottom-hero .grid {
    grid-template-columns: 1fr 1.5fr;
    padding: 3rem 2rem;
  }
}
@media (max-width: 900px) {
  .bottom-hero .grid {
    grid-template-columns: 1fr 1fr;
  }
}
@media (max-width: 767px) {
  .bottom-hero .grid {
    display: flex;
    flex-direction: column;
  }
}