
.page-template-page-home .title-ruler, .title-ruler{
  margin:0 0 clamp(18px,3vw,30px);
  text-align:center;
}
.hero-title, .entry .hero-title, .page-template-page-home .title-ruler > h1, .page-template-page-home .title-ruler .hero-title{
  margin:0 auto;
  max-width:900px;
  font-size:clamp(1.5rem,2vw,2.2rem);
  line-height:1.16;
  font-weight:1000;
  text-wrap:balance;
}
.hero.hero--official{
  position:relative;
}
.hero-shell{
  position:relative;
}
.hero-shell::before{
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;
}
.hero-main-panel{
  position:relative;
  z-index:1;
}
.hero-main-title{
  grid-column:1 / -1;
  display:block;
  width:100%;
  inline-size:100%;
  min-width:0;
  margin:0;
  padding:0;
}
.hero-main-title .hero-title{
  display:block;
  width:100%;
  inline-size:100%;
  max-width:none;
  margin:0;
  font-size:clamp(1.5rem,2vw,2.2rem);
  text-wrap:wrap;
  overflow-wrap:normal;
  word-break:normal;
}
.hero-logo-card{
  margin-inline:auto;
}
.hero-main-copy{
  min-width:0;
}
.hero-actions :is(.btn-download,.btn-ios,.btn-bonus) > span:last-child{
  white-space:nowrap;
}
.hero-spec-panel{
  position:relative;
  z-index:1;
}
.hero-spec{
  min-width:0;
  position:relative;
  overflow:hidden;
}
.hero-spec::before{
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;
}
.hero-spec > *{
  position:relative;
  z-index:1;
}
.hero-spec dt{
  align-items:center;
}
.hero-spec dd{
  line-height:1.25;
  overflow-wrap:anywhere;
}
.hero-ico{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  flex:0 0 38px;
}
.hero-ico svg{
  stroke:currentColor;
}
@media (max-width:1023px){
  .hero-shell{
    grid-template-columns:1fr;
  }
  .hero-main-panel{
    max-width:760px;
    margin-inline:auto;
  }
  .hero-spec{
    display:grid;
    grid-template-columns:minmax(0,1fr) minmax(118px,.9fr);
    align-items:center;
    column-gap:14px;
  }
  .hero-spec dt{
    margin:0;
    min-width:0;
    justify-self:stretch;
    text-align:left;
  }
  .hero-spec dd{
    justify-self:stretch;
    margin:0;
    padding-left:14px;
    text-align:left;
    border-left:1px solid var(--border-soft);
  }
}
@media (max-width:767px){
  .hero-shell{
    padding:14px;
    border-radius:22px;
  }
  .hero-main-panel{
    grid-template-columns:1fr;
    text-align:center;
    background:linear-gradient(180deg,var(--surface-tint),var(--surface-sheen-soft));
  }
  .hero-main-title{
    text-align:center;
  }
  .hero-logo-card{
    max-width:154px;
  }
  .hero-actions{
    grid-template-columns:1fr;
  }
  .hero-specs{
    grid-template-columns:1fr;
  }
  .hero-spec{
    grid-template-columns:minmax(0,1fr) minmax(112px,.9fr);
    column-gap:12px;
  }
  .hero-spec dd{
    padding-left:12px;
  }
}
.page-template-page-home .hero-main-title .hero-title{
  width:100%;
  inline-size:100%;
  max-width:none;
  margin:0;
  font-size:clamp(1.5rem,2vw,2.2rem);
  text-wrap:wrap;
  text-wrap-style:auto;
  overflow-wrap:normal;
  word-break:normal;
}
.hero-title, .entry .hero-title, .page-template-page-home .title-ruler > h1, .page-template-page-home .title-ruler .hero-title{
  color:var(--content-title-text);
  text-shadow:none;
  letter-spacing:-.045em;
}
.hero-shell{
  border-color:var(--surface-panel-border);
}
@media (min-width:1200px){
  .hero-shell{
    align-items:stretch;
  }
  .hero-main-panel{
    align-content:center;
  }
}
@media (max-width:767px){
  .hero-shell{
    border-radius:24px;
  }
  .hero-main-panel{
    background:#ffffff;
  }
}
.hero-main-panel{
  border-color:rgba(14,122,102,.14);
}
.hero-title, .entry .hero-title, .page-template-page-home .title-ruler .hero-title{
  color:var(--dk777-ink,#11231d);
  text-shadow:none;
}
.hero-main-title .hero-title::after{
  content:"";
  width:clamp(70px,9vw,132px);
  height:4px;
  margin-top:12px;
  border-radius:999px;
  background:linear-gradient(90deg,var(--dk777-green-700,#0e7a66),var(--dk777-gold-600,#d6a334));
}
.hero-logo-card{
  border-color:rgba(214,163,52,.44);
}
.hero-spec{
  border-color:rgba(14,122,102,.14);
}
.hero-spec:nth-child(6n+2), .hero-spec:nth-child(6n+5){
  border-color:rgba(214,163,52,.24);
}
.hero-ico{
  border-color:rgba(14,122,102,.14);
}
@media (max-width:767px){
  .hero-main-title .hero-title::after{
    margin-inline:auto;
  }
}
.hero.hero--official{
  padding:0;
  background:transparent;
}
.hero-shell{
  overflow:hidden;
}
.hero-shell::before{
  display:none;
}
.hero-main-panel{
  min-height:auto;
  color:#ffffff;
}
.hero-main-title{
  align-self:end;
}
.hero-main-title.title-ruler{
  margin:0;
  padding:0;
}
.hero-title, .hero-main-title .hero-title{
  max-width:980px;
  margin:0;
  color:#ffffff;
  font-size:clamp(2.7rem,5.2vw,5.7rem);
  line-height:1.12;
  letter-spacing:-.055em;
  font-weight:520;
  text-align:left;
  text-shadow:none;
}
.hero-main-title .hero-title::after{
  display:none;
}
.hero-logo-card{
  justify-self:end;
  aspect-ratio:1;
}
.hero-main-copy{
  align-self:start;
}
.hero-cta-text{
  text-align:left;
}
.hero-actions{
  margin-top:clamp(28px,4vw,52px);
}
.hero-actions :is(.btn-download,.btn-ios,.btn-bonus){
  border-radius:999px;
}
.hero-spec-panel{
  padding-top:clamp(16px,2vw,24px);
  border-top:4px solid rgba(182,69,82,.54);
}
.hero-spec, .hero-spec:nth-child(n){
  min-height:clamp(130px,11vw,170px);
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  text-align:center;
  padding:clamp(14px,1.4vw,22px);
  border-radius:12px;
}
.hero-spec::before{
  display:none;
}
.hero-spec dt{
  justify-items:center;
  margin:0 0 12px;
  font-size:clamp(.95rem,1vw,1.12rem);
}
@media (min-width:1024px){
  .hero.hero--official{
    margin-top:clamp(14px,1.8vw,26px);
  }
}
@media (max-width:1180px){
  .hero-specs{
    grid-template-columns:repeat(3,minmax(0,1fr));
  }
}
@media (max-width:900px){
  .hero-main-panel{
    grid-template-columns:1fr;
    grid-template-areas:"title" "art" "copy";
  }
  .hero-logo-card{
    justify-self:center;
    width:min(72vw,360px);
  }
  .hero-title,.hero-main-title .hero-title,.hero-cta-text{
    text-align:center;
    margin-inline:auto;
  }
  .hero-actions{
    margin-inline:auto;
  }
}
@media (max-width:767px){
  .hero-shell{
    padding:24px 18px;
    border-radius:0;
  }
  .hero-title,.hero-main-title .hero-title{
    font-size:clamp(2.1rem,12vw,3.3rem);
  }
  .hero-actions{
    grid-template-columns:1fr;
    margin-top:24px;
  }
  .hero-specs{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }
  .hero-spec{
    min-height:118px;
  }
}
.hero.hero--official{
  margin:0 0 var(--section-gap);
}
.hero-shell{
  display:grid;
  grid-template-columns:minmax(0,1fr);
  gap:clamp(18px,2.6vw,28px);
}
.hero-main-panel{
  display:grid;
  grid-template-columns:minmax(0,1.35fr) minmax(260px,.65fr);
  grid-template-areas:"title art" "copy art";
  align-items:center;
  padding:0;
  background:transparent;
  border:0;
  border-radius:0;
  box-shadow:none;
}
.hero-main-title{
  grid-area:title;
  text-align:left;
}
.hero-main-title .hero-title, .page-template-page-home .title-ruler .hero-title{
  margin:0;
  font-size:clamp(2.1rem,4.7vw,3.1rem);
  line-height:1.08;
  text-align:left;
}
.hero-main-copy{
  grid-area:copy;
  max-width:850px;
}
.hero-cta-text{
  margin:0 0 clamp(18px,2.4vw,30px);
  font-size:clamp(1.05rem,1.55vw,1.45rem);
  line-height:1.75;
  text-shadow:none;
}
.hero-logo-card{
  grid-area:art;
  max-width:min(440px,100%);
  width:100%;
  border-radius:30px;
}
.hero-actions :is(.btn-download,.btn-ios,.btn-bonus){
  font-size:1rem;
}
.hero-spec-panel{
  min-width:0;
}
.hero-specs{
  display:grid;
  grid-template-columns:repeat(6,minmax(0,1fr));
  gap:clamp(10px,1.2vw,18px);
  margin:0;
}
.hero-spec{
  min-height:142px;
  padding:18px 16px;
  border-radius:18px;
  backdrop-filter:blur(12px);
}
.hero-spec dt{
  display:grid;
  place-items:center;
  gap:8px;
  text-align:center;
  font-weight:850;
}
.hero-spec dd{
  margin:14px 0 0;
  text-align:center;
  font-size:1.05rem;
  font-weight:820;
}
.hero-ico{
  width:34px;
  height:34px;
}
@media (max-width:1180px){
  .hero-specs{
    grid-template-columns:repeat(3,minmax(0,1fr));
  }
}
@media (max-width:860px){
  .hero-main-panel{
    grid-template-columns:1fr;
    grid-template-areas:"art" "title" "copy";
    text-align:center;
  }
  .hero-main-title .hero-title,.page-template-page-home .title-ruler .hero-title{
    text-align:center;
    font-size:clamp(2rem,9vw,3.5rem);
  }
  .hero-main-copy{
    margin-inline:auto;
  }
  .hero-actions{
    grid-template-columns:1fr;
    justify-content:stretch;
  }
  .hero-logo-card{
    max-width:260px;
    margin-inline:auto;
  }
  .hero-specs{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }
}
@media (max-width:560px){
  .hero-shell{
    padding:20px 16px;
    border-radius:24px;
  }
  .hero-specs{
    grid-template-columns:1fr;
  }
}
.hero-shell{
  color:#edf4ff;
  background:radial-gradient(circle at 78% 8%,rgba(255,201,75,.18),transparent 24%), radial-gradient(circle at 9% 0%,rgba(50,230,255,.20),transparent 30%), radial-gradient(circle at 56% 40%,rgba(141,92,255,.22),transparent 34%), linear-gradient(135deg,#080d21 0%,#111b3c 52%,#21134d 100%);
  border:1px solid rgba(255,255,255,.16);
  border-radius:34px;
  box-shadow:0 34px 90px rgba(0,0,0,.42), inset 0 1px 0 rgba(255,255,255,.12);
}
.hero-shell::before{
  background:linear-gradient(90deg,rgba(50,230,255,.20),transparent 30%,transparent 70%,rgba(255,201,75,.18));
  opacity:.8;
}
.hero-main-panel{
  gap:clamp(22px,3.4vw,52px);
}
.hero-main-title .hero-title, .page-template-page-home .title-ruler .hero-title{
  color:#ffffff;
  max-width:980px;
  font-weight:880;
  letter-spacing:-.055em;
  text-shadow:0 18px 48px rgba(0,0,0,.38);
}
.hero-cta-text{
  max-width:860px;
  color:#dce7ff;
  font-weight:520;
}
.hero-specs{
  padding-top:clamp(10px,1.6vw,20px);
  border-top:1px solid rgba(255,255,255,.13);
}
.hero-spec{
  background:linear-gradient(180deg,rgba(255,255,255,.085),rgba(255,255,255,.045));
  border:1px solid rgba(255,255,255,.14);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.10),0 14px 34px rgba(0,0,0,.16);
}
.hero-spec::before{
  background:radial-gradient(circle at 50% 0%,rgba(50,230,255,.16),transparent 52%);
}
.hero-spec dt{
  color:#b9c8ea;
}
.hero-spec dd{
  color:#ffffff;
}
.hero-spec:nth-child(2n) .hero-ico{
  border-color:rgba(255,201,75,.25);
}
@media (max-width:860px){
  .hero-main-panel{
    gap:22px;
  }
}
.hero-logo-card{
  padding:0;
}
.hero-logo{
  width:100%;
  border-radius:0;
}
.hero-actions{
  justify-content:stretch;
}
.hero-actions.has-bonus .btn-bonus{
  grid-column:auto;
}
.hero-actions :is(.btn-download,.btn-ios,.btn-bonus){
  padding-inline:clamp(12px,1.2vw,20px);
  white-space:nowrap;
}
.hero-ico, .hero-spec:nth-child(2n) .hero-ico{
  width:36px;
  height:36px;
  color:var(--toc-icon-color,#32e6ff);
  background:transparent;
  border:0;
  box-shadow:none;
  border-radius:0;
  padding:0;
}
.hero-spec:nth-child(2n) .hero-ico{
  color:#ffc94b;
}
.hero-ico svg{
  width:100%;
  height:100%;
}
@media (max-width:1040px){
  .hero-actions.has-bonus{
    grid-template-columns:1fr;
  }
}
@media (min-width:1041px){
  .hero-main-copy{
    max-width:1120px;
  }
}
@media (max-width:860px){
  .hero-actions, .hero-actions.has-bonus{
    grid-template-columns:1fr;
  }
}
.hero-shell{
  padding-top:clamp(22px,3vw,44px);
  padding-bottom:clamp(22px,3vw,44px);
}
.hero-logo-card{
  display:flex;
  align-items:center;
  justify-content:center;
  background:transparent;
  border:0;
  box-shadow:none;
  overflow:visible;
}
.hero-logo{
  display:block;
  max-width:min(100%,520px);
  height:auto;
  object-fit:contain;
  background:transparent;
  border:0;
  box-shadow:none;
  filter:drop-shadow(0 24px 42px rgba(0,0,0,.36));
}
.hero-actions{
  display:grid;
}
.hero-actions :is(.btn-download,.btn-ios,.btn-bonus){
  min-width:0;
}
@media (max-width:1120px){
  .hero-actions.has-bonus{
    grid-template-columns:repeat(3,minmax(0,1fr));
  }
  .hero-actions :is(.btn-download,.btn-ios,.btn-bonus){
    font-size:.92rem;
    padding-inline:12px;
  }
}
@media (max-width:860px){
  .hero-actions, .hero-actions.has-bonus{
    grid-template-columns:1fr;
  }
}
.hero-actions{
  width:100%;
  grid-template-columns:repeat(2,minmax(0,1fr));
}
.hero-actions.has-bonus{
  grid-template-columns:repeat(3,minmax(0,1fr));
}
.hero-actions :is(.btn-download,.btn-ios,.btn-bonus){
  width:100%;
}
@media (max-width:860px){
  .hero-actions,.hero-actions.has-bonus{
    grid-template-columns:1fr;
  }
}
.hero.hero--official{
  margin-top:0;
  margin-bottom:var(--dk-module-gap);
}
.hero-shell{
  padding:clamp(22px,3.6vw,56px) clamp(18px,3.8vw,54px);
}
.hero-actions{
  gap:clamp(12px,1.4vw,18px);
}
.hero-actions :is(.btn-download,.btn-ios,.btn-bonus){
  min-height:52px;
}
@media (min-width:861px){
  .hero-actions{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }
  .hero-actions.has-bonus{
    grid-template-columns:repeat(3,minmax(0,1fr));
  }
}
@media (max-width:767px){
  .hero-shell{
    padding:20px 16px;
    border-radius:24px;
  }
  .hero-main-panel{
    gap:18px;
  }
  .hero-main-title .hero-title, .page-template-page-home .title-ruler .hero-title{
    font-size:clamp(2rem,10vw,3.1rem);
    line-height:1.08;
  }
  .hero-cta-text{
    margin-bottom:16px;
    font-size:1rem;
    line-height:1.62;
  }
  .hero-actions, .hero-actions.has-bonus{
    grid-template-columns:1fr;
    gap:12px;
  }
  .hero-specs{
    grid-template-columns:repeat(2,minmax(0,1fr));
    gap:10px;
    padding-top:14px;
  }
  .hero-spec{
    min-height:112px;
    padding:13px 10px;
    border-radius:14px;
  }
  .hero-spec dt{
    display:grid;
    place-items:center;
    gap:6px;
    margin:0;
    font-size:.84rem;
    line-height:1.22;
    text-align:center;
  }
  .hero-spec dd{
    margin-top:8px;
    font-size:.92rem;
    line-height:1.2;
    text-align:center;
  }
  .hero-ico, .hero-spec:nth-child(2n) .hero-ico{
    width:28px;
    height:28px;
  }
}
@media (max-width:359px){
  .hero-specs{
    grid-template-columns:1fr;
  }
}
