@charset "UTF-8";
/* ==============================================================
*  base
* ============================================================ */
/*! normalize.css v8.0.0 | MIT License | github.com/necolas/normalize.css */
html {
  line-height: 1.15;
  -webkit-text-size-adjust: 100%;
}

body {
  margin: 0;
}

h1 {
  font-size: inherit;
  margin: 0;
}

hr {
  box-sizing: content-box;
  height: 0;
  overflow: visible;
}

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

a {
  background-color: transparent;
    color: #5785c2;
}

abbr[title] {
  border-bottom: none;
  text-decoration: underline;
  -webkit-text-decoration: underline dotted;
          text-decoration: underline dotted;
}

b, strong {
  font-weight: bolder;
}

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

small {
  font-size: 80%;
}

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

sub {
  bottom: -0.25em;
}

sup {
  top: -0.5em;
}

img {
  border-style: none;
}

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

button, input {
  overflow: visible;
}

button, select {
  text-transform: none;
}

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

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

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

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

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

progress {
  vertical-align: baseline;
}

textarea {
  overflow: auto;
}

[type=checkbox], [type=radio] {
  box-sizing: border-box;
  padding: 0;
}

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

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

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

::-webkit-file-upload-button {
  -webkit-appearance: button;
  font: inherit;
}

details {
  display: block;
}

summary {
  display: list-item;
}

template {
  display: none;
}

[hidden] {
  display: none;
}

body {
  word-wrap: break-word;
}

section, main {
  display: block;
}

*, *::before, *::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
  outline: none;
}

i, em {
  font-style: normal;
}

table {
  border-collapse: collapse;
}

li {
  list-style: none;
}

img {
  max-width: 100%;
  line-height: 0;
}

* {
  background-repeat: no-repeat;
  background-position: 50% 50%;
  background-size: cover;
}

/*   ==============================================================
*  contents
*  ============================================================ */

#loading {
  position: fixed;
  width: 100%;
  height: 100%;
  z-index: 200;
  top: 0;
  overflow: hidden;
  opacity: 1;
  transition: opacity 1.5s;
    background: #B9E4FF;
}
#loading img {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: min(20%, 100px);
  height: auto;
  animation: logoanim 1s linear infinite;
}

@keyframes logoanim {
  0% {
    transform: translate(-50%, -50%) rotateY(0deg);
  }
  100% {
    transform: translate(-50%, -50%) rotateY(360deg);
  }
}
body.loaded_delay #loading {
  opacity: 0;
  transition: opacity 0.5s;
}

body.all-clear #loading {
  display: none;
}

body {
  position: fixed;
}
body.all-clear {
  position: static;
}

html {
  visibility: hidden;
}

html.wf-active,
html.loading-delay {
  visibility: visible;
}
html.wf-active .content-main,
html.loading-delay .content-main {
  opacity: 1;
}

html {
  font-size: 62.5%;
}

html, body {
  height: 100%;
}

body {
  background: #B9E4FF;
  color:#6c6c6c;
  font-family: "ヒラギノ角ゴ ProN", "Hiragino Kaku Gothic ProN", "Hiragino Sans", "Noto Sans JP", "Helvetica Neue", Arial, "メイリオ", Meiryo, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-weight: 600;
  font-size: 1.6rem;
  line-height: 1.4;
  letter-spacing: 0.05em;
  word-wrap: break-word;
  overflow-wrap: break-word;
  overflow-x: hidden;
}

a {
  text-decoration: none;
  line-height: 1;
}

img {
  max-width: 100%;
  background-repeat: no-repeat;
  background-position: 50% 50%;
  background-size: cover;
  line-height: 0;
}

.clearfix::after {
  content: "";
  display: block;
  clear: both;
}

::-moz-selection {
  background: rgba(118, 118, 118, 0.2);
}

::selection {
  background: rgba(118, 118, 118, 0.2);
}

::-moz-selection {
  background: rgba(118, 118, 118, 0.2);
}

.delighter.started {
  transform: translate3d(0, 0, 0);
  opacity: 1;
}

.delighter {
  opacity: 0;
  transform: translate3d(0, 20px, 0);
  transition: opacity 0.4s, transform 1.2s;
}

.svg-symbol {
  display: none;
}

span.br {
  display: inline-block;
}

.btn {
  text-align: center;
}

.btn-base-style {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  display: inline-block;
  border: none;
  cursor: pointer;
}

.btn--main {
    padding: 20px;
    display: inline-block;
    width: 300px;
    line-height: 1;
    cursor: pointer;
    text-align: center;
    text-decoration: none;
    color: #fffce9;
    background-color: #5785c2;
    box-shadow: 4px 5px 0px #fffce9;
    transition: 0.3s;
    border-radius: 100px;
    position: relative;
    letter-spacing: 0.1em;
}

.btn--main:hover {
  box-shadow: unset;
  transform: translate(4px, 5px);
}

.btn--long {
  letter-spacing: normal;
}

.btn + .btn {
  margin-top: 2em;
}

.btnArea{
    text-align: center;
}
.btnTxt{
    position: relative;
    display: inline-block;
    padding: 0 60px;
    color: #5785c2;
    font-size: 23px;
    margin: 0 0 30px 0;
}
.btnTxt:before, .btnTxt:after {
  content: '';
  position: absolute;
  top: 50%;
  display: inline-block;
  width: 30px;
  height: 2px;
  background-color: #5785c2;
  -webkit-transform: rotate(-45deg);
  transform: rotate(-45deg);
}
.btnTxt:before {
  left:0;
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
}
.btnTxt:after {
  right: 0;
}

.txt--basic {
  margin: 1em 0 0;
}

.txt--note {
  font-weight: 500;
}

.txt--sub {
  line-height: 1.8em;
  font-weight: normal;
  text-indent: -1em;
  padding-left: 1em;
}

.right {
  text-align: right;
}

.center {
  text-align: center;
}

.bold {
  font-weight: bold;
}

.italic {
  font-style: italic;
}

p.date,
.category {
  display: inline-block;
  font-family: gyst-variable, sans-serif;
  font-variation-settings: "wght" 400;
  font-style: italic;
  letter-spacing: 0;
}

p.date {
  display: inline-block;
  font-family: gyst-variable, sans-serif;
  font-variation-settings: "wght" 400;
  font-style: italic;
  letter-spacing: 0;
  font-size: 1.6rem;
}

.tit {
  font-weight: 600;
}

.txt > p:not(:last-child) {
  margin-bottom: 0.75em;
}

.ph, .thumb {
  position: relative;
  line-height: 0;
  text-align: center;
}
.ph::after, .thumb::after {
  content: "";
  display: block;
  width: 100%;
  height: 100%;
  position: absolute;
  background: url(/../static/common/global-image/dummy.gif);
  background-size: cover;
  top: 0;
  left: 0;
}
.ph .dummy, .thumb .dummy {
  display: block;
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
}
.ph img, .thumb img {
  width: 100%;
  pointer-events: none;
}

footer .inner {
  width: calc(100% - 13vw);
  color: #767676;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  align-items: center;
}
footer .inner img {
  width: 60px;
}
footer .list--link {
  margin: 0 auto;
}
footer .list--link li {
  text-align: center;
  color: #83A061;
}
footer .list--link li:not(:first-child) {
  margin-top: 0.2em;
}
footer .list--link .sml {
  font-size: 80%;
}
footer .copyright {
  text-align: center;
  line-height: 1;
  margin-top: 4em;
  color: #5785c2;
  font-weight: 400;
  font-size: 1.4rem;
}

.wrap {
  position: relative;
  min-height: 100%;
  width: 100%;
  overflow: hidden;
  z-index: 1;
}

.content-main {
  min-height: 100vh;
  position: relative;
  width:100%;
  margin: 0 auto 6vw;
}
.content-main [class^=section--] {
  margin: 0 auto 50px;
  position: relative;
}
.content-main [class^=section--] .inner {
    position: relative;
    border-radius: 20px;
    z-index: 0;
    text-align: center;
    background-color: #fffce9;
    max-width: 800px;
    margin: auto;
    outline: dotted;
    outline-offset: 5px;
    outline-width: 2px;
    outline-color: #fffce9;
}
.content-main [class^=section--] .inner:before {
    content: "";
    position: absolute;
    background-repeat: no-repeat;
    background-size: contain;
    background-image: url(/static/twice/official/feature/lovely_card_collection/images/ph_ribbon_5e63af47195d592c9fdb6467e36a7fe0.png);
    width: 400px;
    height: 27px;
    top: 35px;
    left: 50%;
    transform: translate(-50%, 0);
    z-index: -1;
    pointer-events: none;
}

.content-main [class^=section--] .inner .tit{
    color: #5785c2;
    margin: 0 auto 20px;
}
.content-main [class^=section--] .inner > .txt{
    margin: 0 auto;
}
.content-main [class^=section--] .inner .detail{
	display: -webkit-flex;
    display: flex;
    flex-flow: row wrap;
    justify-content: space-between;
    align-items: center;
    background: #5785c2;
    color: #fff;
    padding: 20px;
    border-radius: 20px;
    margin: 0 0 20px 0;
}
.content-main [class^=section--] .inner .detail dt{
    width: 30%;
    font-size: 14px;
    border-right: 1px solid;
}
.content-main [class^=section--] .inner .detail dd{
    width: 65%;
    text-align: left;
    font-size: 14px;
    font-weight: 500;
    line-height: 1.8;
}
.content-main [class^=section--] .inner .detail dd .mini{
    font-size: 12px;
    font-weight: 400;
}
.content-main [class^=section--] .inner .stepList{
    margin: 0 auto 30px;
}
.content-main [class^=section--] .inner .stepList > li{
    text-align: left;
    position: relative;
    margin: 0 0 30px 0;
    padding: 0 0 30px 100px;
    border-bottom: dotted 1px #5785c2;
}
.content-main [class^=section--] .inner .stepList > li:last-child{
    margin: 0;
    padding: 0 0 0 100px;
    border-bottom: none;
}
.content-main [class^=section--] .inner .stepList li .icon{
    display: inline-block;
    width: 80px;
    height: 80px;
    position: absolute;
    background: #5785c2;
    border-radius: 999px;
    text-align: center;
    color: #fff;
    left: 0;
    top: -10px;
}
.content-main [class^=section--] .inner .stepList li .icon .iconInner{
    position: absolute;
    width: 100%;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%);
    line-height: 1.5;
    font-size: 12px;
}
.content-main [class^=section--] .inner .stepList li .icon .iconInner .number{
    display: block;
    font-size: 200%;
}
.content-main [class^=section--] .inner .attentionList{

}
.content-main [class^=section--] .inner .attentionList > li{
    font-weight: 400;
    font-size: 12px;
    text-indent: -1em;
    margin: 0 0 5px 1em;
}
.content-main [class^=section--] .inner .attentionList > li:last-chihld{
    margin: 0 0 0 1em;
}


.section-tit {
  line-height: 1.3;
  text-align: center;
}


/*-- GENERAL STYLE --*/
.red {
  color:#db3d66;
}

.bold {
  font-weight: bold;
}

.text-sub {
  font-size: 83%;
}

/*-- parts --*/
.winners .sml {
  font-style: normal;
  font-size: 40%;
}

.wrap {
  position: relative;
}
.list--attention, .list--period, .list--present {
  margin: 0 auto;
  font-weight: 600;
  max-width: 500px;
}

.list--attention {
  position: relative;
}
.list--attention dt {
  padding: 2em 0;
}
.list--attention dd {
  text-align: left;
  padding-left: 1em;
  text-indent: -1em;
  font-weight: 400;
}
.list--attention dd + dd {
  margin-top: 0.3em;
}
.list--attention dd:nth-child(4) {
  margin-bottom: 2em;
}
.list--attention .list--attention--txt {
  margin-bottom: 2em;
  display: flex;
  position: relative;
  left: 50%;
  transform: translateX(-50%);
  flex-wrap: wrap;
}

.list--period {
  background-color: rgba(255, 255, 255, 0.45);
  border-radius: 10px;
}
.list--period .list--line01 {
  position: relative;
  display: block;
}
.list--period .list--line01:before {
  content: "";
  position: absolute;
  background-repeat: no-repeat;
  background-size: contain;
  background-image: url(/static/twice/official/feature/once_present2025_4sfkh9ot/img/li--line.png);
  z-index: 2;
  width: 26px;
  height: 18px;
  left: 0;
  bottom: -10px;
}
.list--period .list--line01:after {
  content: "";
  position: absolute;
  background-repeat: no-repeat;
  background-size: contain;
  background-image: url(/static/twice/official/feature/once_present2025_4sfkh9ot/img/li--line.png);
  z-index: 2;
  width: 26px;
  height: 18px;
  right: 0;
  bottom: -10px;
  transform: scale(-1, 1);
}
.list--period .list--line02 {
  position: relative;
  display: block;
}
.list--period .list--line02:before {
  content: "";
  position: absolute;
  border: 1px solid #EAF4DE;
  width: 100%;
  bottom: -2px;
  left: 50%;
  transform: translateX(-50%);
  width: calc(100% - 26px);
}
.list--period .list--line02:after {
  content: "";
  position: absolute;
  border: 1px solid #D3E3C0;
  width: 100%;
  bottom: -6px;
  left: 50%;
  transform: translateX(-50%);
  width: calc(100% - 26px);
}
.list--period .list--line03 {
  position: relative;
  display: block;
}
.list--period .list--line03:before {
  content: "";
  position: absolute;
  background-repeat: no-repeat;
  background-size: contain;
  background-image: url(/static/twice/official/feature/once_present2025_4sfkh9ot/img/li--line.png);
  z-index: 2;
  width: 26px;
  height: 18px;
  left: 0;
  top: -10px;
  transform: rotate(-180deg) scale(-1, 1);
}
.list--period .list--line03:after {
  content: "";
  position: absolute;
  background-repeat: no-repeat;
  background-size: contain;
  background-image: url(/static/twice/official/feature/once_present2025_4sfkh9ot/img/li--line.png);
  z-index: 2;
  width: 26px;
  height: 18px;
  right: 0;
  top: -10px;
  transform: rotate(-180deg);
}
.list--period .list--line04 {
  position: relative;
  display: block;
}
.list--period .list--line04:before {
  content: "";
  position: absolute;
  border: 1px solid #D3E3C0;
  width: 100%;
  top: -6px;
  left: 50%;
  transform: translateX(-50%);
  width: calc(100% - 26px);
  z-index: 2;
}
.list--period .list--line04:after {
  content: "";
  position: absolute;
  border: 1px solid #EAF4DE;
  width: 100%;
  top: -2px;
  left: 50%;
  transform: translateX(-50%);
  width: calc(100% - 26px);
  z-index: 2;
}
.list--period dt {
  padding-top: 2em;
  position: relative;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  margin: 0 auto;
  font-weight: 700;
  color: #FFB2B9;
}
.list--period dd {
  padding: 2em 0 2.2em;
  line-height: 1.4;
}
.list--period dd .tilde {
  transform: rotate(-90deg);
  display: block;
  padding: 8px 0;
}

.list--present li {
  position: relative;
  background-color: #fff;
  border-radius: 20px;
}
.list--present li:before {
  content: "";
  position: absolute;
  background-repeat: no-repeat;
  background-size: contain;
  background-image: url(/static/twice/official/feature/once_present2025_4sfkh9ot/img/limited.png);
  z-index: 2;
}
.list--present li:after {
  content: "";
  position: absolute;
  background-repeat: no-repeat;
  background-size: contain;
  z-index: 2;
  background-image: url(/static/twice/official/feature/once_present2025_4sfkh9ot/img/ribbon03.png);
  width: 109px;
  height: 64px;
  bottom: -18px;
  left: -8px;
}
.list--present li:nth-child(2):before {
  background-image: url(/static/twice/official/feature/once_present2025_4sfkh9ot/img/everyone.png);
}
.list--present .target {
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  margin: 0 auto;
  font-weight: 700;
  line-height: 1.6;
  background: #FFB2B8;
  color: #fff;
  border-radius: 100px;
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
}
.list--present .target.all {
  background: #AAC187;
  color: #fff;
}
.list--present .tit {
  margin-top: 0.5em;
  color: #FFA0A8;
}
.list--present .tit span {
  display: block;
}
.list--present .winners {
  margin: 0.3em 0;
}

.section--top {
  position: relative;
  height: 90vh;
  margin: 0 auto;
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.section--top .frame{
    outline: dotted;
    outline-offset: -10px;
    outline-width: 2px;
    outline-color: #fffce9;
    width: 100%;
    height: 100%;
    position: fixed;
    z-index: -1;
    pointer-events: none;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%);
}
.section--top .logo{
    display: -webkit-flex;
    display: flex;
    flex-flow: row wrap;
    justify-content: space-between;
    align-items: center;
    position: absolute;
    top: 8%;
    left: 50%;
    transform: translate(-50%, -50%);
    -webkit-transform: translate(-50%, -50%);
    -ms-transform: translate(-50%, -50%);
    width: 20vh;
    opacity: 0;
    transition: opacity 1s 1.3s;
}
.all-clear .section--top .logo{
    opacity: 1;
}
.section--top .logo p{

}
.section--top .logo p:nth-child(1){
    width: 37%;
}
.section--top .logo p:nth-child(2){
    width: 50%;
}
.section--top h1 {
  z-index: 10;
}
.section--top .logoArea{
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    -webkit-transform: translate(-50%, -50%);
    -ms-transform: translate(-50%, -50%);
    width: 68vh;
    opacity: 0;
    transition: opacity 1s 1s;
}
.all-clear .section--top .logoArea{
  opacity: 1;
}
.scroll_down{
    position: absolute;
    bottom: 15vh;
    left: 50%;
    transform: translate(-50%, 0);
    width: 4vh;
    opacity: 0;
    transition: opacity 1s 1.5s;
}
.all-clear .scroll_down{
    opacity: 1;
}
.arrow {
    position: absolute;
    width: 100%;
    opacity: 0;
    transform: scale3d(0.5, 0.5, 0.5);
    animation: move 2s ease-out infinite;
}

.arrow:first-child {
  animation: move 2s ease-out 1s infinite;
}

.arrow:nth-child(2) {
  animation: move 2s ease-out 2s infinite;
}
@keyframes move {
  25% { opacity: 1; }
  33% { opacity: 1; transform: translateY(30px); }
  67% { opacity: 1; transform: translateY(60px); }
  100% { opacity: 0; transform: translateY(75px) scale3d(0.5, 0.5, 0.5); }
}
.block--lead {
    position: relative;
    background: #fffce9;
    padding: 3vw;
    color: #6c6c6c;
    margin: 0 auto 20vw;
    opacity: 0;
    transition: opacity 1s 2s;
}
.all-clear .block--lead {
    opacity: 1;
}
.block--lead:before {
    content: "";
    position: absolute;
    background-repeat: no-repeat;
    background-size: cover;
    background-image: url(/static/twice/official/feature/lovely_card_collection/images/ph_frame_top_5e63af47195d592c9fdb6467e36a7fe0.png);
    width: 100%;
    height: 11vw;
    top: -10vw;
    left: 0;
    z-index: -1;
    pointer-events: none;
}
.block--lead:after {
    content: "";
    position: absolute;
    background-repeat: no-repeat;
    background-size: cover;
    background-image: url(/static/twice/official/feature/lovely_card_collection/images/ph_frame_bottom_5e63af47195d592c9fdb6467e36a7fe0.png);
    width: 100%;
    height: 12vw;
    bottom: -11vw;
    left: 0;
    z-index: -1;
    pointer-events: none;
    background-position: center;
}
.block--lead .tit{
    letter-spacing: 0.1em;
    color: #5785c2;
    text-align: center;
    margin: 0 0 20px 0;
    font-size: 2.5rem;
}
.block--lead .txt{
    position: relative;
    letter-spacing: 0.1em;
    color: #5785c2;
    font-weight: 400;
    font-size: 1.8rem;
}
@media screen and (min-width: 961px) {
  .sp {
    display: none !important;
  }
  .btn input {
    transition: 0.3s;
  }
  .btn--main {
    font-size: 1.8rem;
    width: min(100%, 304px);
  }
  .btn--long {
    font-size: 1.6rem;
  }
  .btn.diseable {
    font-size: 1.8rem;
    width: min(100%, 480px);
  }
  .tit {
    font-size: 2.2rem;
    line-height: 1.4;
  }
  .txt {
    font-size: 1.6rem;
    line-height: 1.75;
  }
  footer .inner {
    padding: 0 0 4em;
  }
  footer .inner img {
    margin: 0 auto 1.6em;
    pointer-events: none;
  }
  footer .list--link li {
    font-size: 2rem;
    transition: opacity 0.3s;
  }
  footer .list--link li:hover {
    opacity: 0.7;
  }
  .content-main {
    margin-top: 10vw;
  }
  .content-main [class^=section--] {

  }
  .content-main [class^=section--] .inner {
    padding: 100px 40px 60px;
  }
  .section-tit-sub {
    display: inline-block;
  }
  .section-tit {
    font-size: min(2.7vw, 2.8rem);
  }
  .section--top {
        padding: 40px 0;
        min-height: 500px;
  }
  .block--lead .txt {
        text-align: center;
    	font-size: 2.2rem;
  }

}
@media screen and (min-width: 1px) and (max-width: 960px) {
  .pc {
    display: none !important;
  }
  .btn + .btn {
    margin-top: 1em;
}
	.btnTxt {
	    padding: 0 40px;
	    font-size: 14px;
	    margin: 0 0 20px 0;
	}
  .btn--main {
    padding: 22px 16px 18px;
    width: min(100%, 280px);
    font-size: min(3.8vw, 1.5rem);
  }
  .section--top {
        height: auto;
        display: block;
        padding: 0 0 7vh 0;
  }
.section--top .logoArea{
        width: 80vw;
        max-width: 500px;
        position: relative;
        top: auto;
        transform: none;
        -webkit-transform: none;
        -ms-transform: none;
        margin: auto;
        left: auto;
}
.section--top .logo {
        width: 30vw;
        position: relative;
        margin: 20px auto;
        top: auto;
        left: auto;
        transform: none;
        -webkit-transform: none;
        -ms-transform: none;
}
.scroll_down {
    bottom: 8vh;
    left: 50%;
    width: 3vh;
}
@keyframes move {
  25% { opacity: 1; }
  33% { opacity: 1; transform: translateY(30px); }
  67% { opacity: 1; transform: translateY(40px); }
  100% { opacity: 0; transform: translateY(55px) scale3d(0.5, 0.5, 0.5); }
}
  .list--present li:nth-child(2) .btn--main,
  .section--special02 .btn--main {
    padding: 12px 16px;
    line-height: 1.2;
  }
  .btn.diseable {
    width: 40%;
    min-width: 190px;
    font-size: 1.4rem;
  }
  .tit {
    font-size: 1.6rem;
    line-height: 1.45;
  }
  .txt {
    font-size: min(3.6vw, 1.4rem);
    line-height: 1.8;
  }
  footer .inner {
    padding: 60px 0 40px;
  }
  footer .inner img {
    margin: 0 auto 2em;
  }
  footer .list--link {
    -moz-column-gap: 24px;
         column-gap: 24px;
  }
  footer .list--link .sml {
    font-size: 60%;
  }
  .content-main {
    margin-top: 18vw;
  }
  .content-main [class^=section--] {
    margin-bottom: 30px;
  }
  .content-main [class^=section--] .inner{
        padding: 50px 20px 20px;
        width: 85%;
        outline-width: 1px;
  }
  .content-main [class^=section--] .inner:before {
    width: 200px;
    height: 14px;
    top: 20px;
 }
 .content-main [class^=section--] .inner .tit {
    font-size: 15px;
 }
 .content-main [class^=section--] .inner .detail {
    padding: 20px;
    border-radius: 15px;
    margin: 0 0 10px 0;
}
.content-main [class^=section--] .inner .detail dt {
    width: 100%;
    font-size: 12px;
    border-right: none;
    border-bottom: 1px solid;
    padding: 0 0 10px 0;
    margin: 0 0 10px 0;
}
.content-main [class^=section--] .inner .detail dd {
    width: 100%;
    text-align: center;
    font-size: 12px;
}
.content-main [class^=section--] .inner .detail dd .mini {
    font-size: 11px;
    font-weight: 400;
}
.content-main [class^=section--] .inner .stepList li .icon {
    display: inline-block;
    width: 60px;
    height: 60px;
    top: -10px;
}
.content-main [class^=section--] .inner .stepList li .icon .iconInner {
    line-height: 1.2;
    font-size: 10px;
}
.content-main [class^=section--] .inner .stepList > li {
    margin: 0 0 20px 0;
    padding: 0 0 20px 80px;
}
.content-main [class^=section--] .inner .stepList > li:last-child {
    padding: 0 0 0 80px;
}
  .section-tit-sub {
    width: min(68%, 260px);
    top: -16px;
    left: -20px;
  }
  .section-tit {
    margin-bottom: 8px;
    font-size: min(7vw, 1.8rem);
  }
  /*-- parts --*/
  .winners {
    font-size: 3.6rem;
  }
  .list--attention, .list--period, .list--present {
    margin: 0 auto;
  }
  .list--attention dt, .list--period dt, .list--present dt {
    font-size: 1.4rem;
  }
  .list--period, .list--present {
    width: min(100%, 460px);
  }
  .list--attention {
    width: min(100%, 460px);
  }
  .list--attention dd {
    font-size: 1.3rem;
  }
  .list--attention .list--attention--txt {
    width: 90%;
  }
  .list--period dt::after {
    bottom: -0.2em;
  }
  .list--period dd {
    font-size: min(3vw, 1.4rem);
  }
  .list--period dd span {
    font-size: min(6vw, 1.6rem);
  }
  .list--present li {
    padding: 40px 20px 50px;
  }
  .list--present li:not(:first-child) {
    margin-top: 4em;
  }
  .list--present li:before {
    width: 77px;
    height: 52px;
    top: -18px;
    right: -25px;
  }
  .list--present li:nth-child(2):before {
    width: 100px;
    height: 58px;
    right: -32px;
  }
  .list--present .target {
    font-size: 1.6rem;
    padding: 8px 24px;
    line-height: 1.2;
    top: -17px;
  }
  .list--present .tit {
    font-size: min(6vw, 2.2rem);
    line-height: 1.25;
  }
  .list--present .winners {
    font-size: 3.6rem;
  }

  .block--lead {
        padding: 40px 20px;
        margin: 0 auto 100px;
        width: 100%;
  }
.block--lead .tit{
    margin: 0 0 15px 0;
    font-size: 15px;
}
.block--lead .txt {
    font-size: 14px;
}
.block--lead .txt:before {
    background-size: 20px;
    width: 180px;
    height: 14px;
    top: -30px;
}






}