@charset "UTF-8";
/* ------------------
Campaign Page
------------------*/
/* Color Palette */
/* Padding */
/* Header Space */
/* Wrap */
/* Padding */
/*-----------
Root
-------------*/
:root {
  --large: 8rem;
  --medium: 5rem;
  --small: 2rem;
  --section-padding: 8rem 0;
  --transition: all 0.3s ease;
  --gutter: calc((100vw - 90vw) / 2); }

@media screen and (max-width: 1412px) {
  :root {
    --large: 6rem;
    --medium: 4rem;
    --small: 1.5rem;
    --section-padding: 6rem 0; } }
@media screen and (max-width: 880px) {
  :root {
    --large: 5rem;
    --medium: 3rem;
    --small: 1.5rem;
    --section-padding: 5rem 0; } }
@media screen and (max-width: 640px) {
  :root {
    --large: 3rem;
    --medium: 2rem;
    --small: 1rem;
    --section-padding: 3rem 0; } }
h2 {
  font-size: min(6vw, 30px);
  text-align: center; }

/* ------------------
Campaign MAIN VISUAL
------------------*/
.mv_wrapper {
  margin: 90px 0 0;
  width: 100%;
  height: 70svh;
  overflow: hidden;
  background: #1414d2; }
  @media (max-width: 1200px) {
    .mv_wrapper {
      height: 60svh; } }
  @media (max-width: 880px) {
    .mv_wrapper {
      height: 48svh; } }
  @media (max-width: 640px) {
    .mv_wrapper {
      margin: 52px 0 0;
      display: flex;
      flex-wrap: wrap;
      max-height: none;
      height: auto; } }
  .mv_wrapper .mv_inner {
    width: 100%;
    height: 100%;
    display: flex;
    overflow: hidden; }
    @media (max-width: 640px) {
      .mv_wrapper .mv_inner {
        flex-direction: column-reverse; } }
    .mv_wrapper .mv_inner__text {
      width: 50%;
      display: flex;
      align-items: center;
      justify-content: flex-end;
      padding: 2rem; }
      @media (max-width: 1412px) {
        .mv_wrapper .mv_inner__text {
          width: 57%;
          justify-content: center; } }
      @media (max-width: 640px) {
        .mv_wrapper .mv_inner__text {
          width: 100%;
          padding: 0; } }
      .mv_wrapper .mv_inner__text h1 {
        color: #ffffff;
        text-align: left;
        font-size: min(4vw, 52px);
        line-height: 1.8;
        padding: 0 0 1rem; }
        @media (max-width: 640px) {
          .mv_wrapper .mv_inner__text h1 {
            font-size: min(7.5vw, 36px);
            padding: 2rem 0 4rem; } }
        .mv_wrapper .mv_inner__text h1 span {
          font-size: 130%;
          color: #1414d2;
          background: #ffffff;
          padding: 0.6rem 1.5rem;
          margin-right: 2rem; }
          @media (max-width: 880px) {
            .mv_wrapper .mv_inner__text h1 span {
              padding: 0.4rem 0.8rem;
              margin-right: 1rem; } }
    .mv_wrapper .mv_inner__image {
      width: 50%;
      height: 100%;
      padding: 1.5rem;
      overflow: hidden;
      display: flex;
      justify-content: center;
      align-items: center; }
      @media (max-width: 1412px) {
        .mv_wrapper .mv_inner__image {
          width: 43%; } }
      @media (max-width: 640px) {
        .mv_wrapper .mv_inner__image {
          width: 100%;
          height: auto;
          padding: 0; } }
      .mv_wrapper .mv_inner__image .mv_pc, .mv_wrapper .mv_inner__image .mv_sp {
        width: 100%;
        height: 100%;
        display: flex;
        align-items: center;
        justify-content: center; }
        .mv_wrapper .mv_inner__image .mv_pc > .pic, .mv_wrapper .mv_inner__image .mv_sp > .pic {
          width: auto;
          height: auto;
          max-width: 100%;
          max-height: 100%;
          object-fit: contain;
          display: block; }
      .mv_wrapper .mv_inner__image .mv_pc {
        display: flex; }
        @media (max-width: 640px) {
          .mv_wrapper .mv_inner__image .mv_pc {
            display: none; } }
      .mv_wrapper .mv_inner__image .mv_sp {
        display: none; }
        @media (max-width: 640px) {
          .mv_wrapper .mv_inner__image .mv_sp {
            display: flex;
            height: auto; } }

/* ------------------
Introduction 
------------------*/
.intro {
  padding: 5rem 0;
  background: #f7f4f2; }
  @media (max-width: 640px) {
    .intro {
      padding: 4rem 0 3rem; } }
  .intro img.pic {
    max-width: 600px; }
    @media (max-width: 880px) {
      .intro img.pic {
        max-width: 400px; } }
    @media (max-width: 640px) {
      .intro img.pic {
        max-width: 280px; } }
  .intro p {
    font-weight: 600;
    margin-top: var(--medium);
    line-height: 2;
    font-size: min(4.5vw, 24px); }
    @media (max-width: 640px) {
      .intro p {
        margin-top: 3rem; } }

/* ------------------
Date
------------------*/
.cp-date {
  padding: 5rem 0;
  background: #a5ebff; }
  @media (max-width: 640px) {
    .cp-date {
      padding: 3rem 0; } }
  .cp-date p {
    line-height: 1;
    font-size: min(3.8vw, 21px);
    font-feature-settings: 'palt'; }
    .cp-date p span {
      font-size: 260%;
      font-weight: 700; }
      @media (max-width: 640px) {
        .cp-date p span {
          font-size: 220%; } }
    .cp-date p.date {
      margin-top: 2rem;
      padding-left: 3rem; }
      @media (max-width: 640px) {
        .cp-date p.date {
          margin-top: 1.5rem;
          padding-left: 0; } }

/* ------------------
Swiper
------------------*/
.california-swiper {
  width: 100%;
  overflow: hidden;
  margin: 8px 0; }
  .california-swiper .swiper-wrapper {
    align-items: stretch; }
  .california-swiper .swiper-slide {
    width: calc((100% - 4 * 8px) / 5);
    margin-right: 8px; }
    @media (max-width: 1200px) {
      .california-swiper .swiper-slide {
        width: calc((100% - 3 * 8px) / 4); } }
    @media (max-width: 1200px) {
      .california-swiper .swiper-slide {
        width: calc((100% - 2 * 8px) / 3); } }
    @media (max-width: 640px) {
      .california-swiper .swiper-slide {
        width: calc(64%); } }
  .california-swiper img {
    display: block;
    width: 100%;
    height: auto; }

/* ------------------
賞品
------------------*/
#prize {
  background: #051464;
  padding: var(--large) 0; }
  @media (max-width: 640px) {
    #prize {
      padding: calc( var(--large) + 2rem ) 0; } }
  #prize .large-wrapper {
    text-align: center; }
    #prize .large-wrapper .present-icon {
      width: 20%;
      max-width: 40px;
      margin: 0 auto 2rem; }
    #prize .large-wrapper h2 {
      color: #1414d2;
      background: #ffffff;
      display: inline-block;
      padding: 1rem 3rem;
      border-radius: 10px; }
    #prize .large-wrapper h3 {
      color: #ffffff;
      line-height: 2.4;
      font-size: min(5vw, 21px);
      margin-top: 3rem; }
      #prize .large-wrapper h3 span {
        font-size: 180%;
        line-height: 1.4; }
  #prize .choice {
    margin-top: 5rem;
    display: flex;
    flex-direction: row;
    justify-content: center;
    align-items: center;
    gap: 3rem;
    font-size: min(4vw, 21px);
    color: #ffffff; }
    @media (max-width: 640px) {
      #prize .choice {
        gap: 0;
        margin-top: 3rem; } }
    #prize .choice.for-deco {
      position: relative;
      width: 100%; }
    #prize .choice .deco {
      width: 100%;
      height: 8px;
      position: absolute;
      top: 50%;
      left: 0;
      transform: translateY(-50%);
      background: radial-gradient(circle, #1414d2 3px, transparent 4px);
      background-size: 16px 8px;
      background-repeat: repeat-x;
      z-index: 0; }
      @media (max-width: 640px) {
        #prize .choice .deco {
          background: radial-gradient(circle, #1414d2 1.5px, transparent 2px);
          background-size: 8px 8px; } }
    #prize .choice .origin {
      width: 40%;
      max-width: 180px;
      text-align: center;
      display: flex;
      align-items: center;
      justify-content: center; }
      @media (max-width: 640px) {
        #prize .choice .origin {
          width: calc( ( 100% - 1.5rem ) / 2 );
          max-width: none; } }
      @media (max-width: 640px) {
        #prize .choice .origin p {
          font-size: 110%; } }
      #prize .choice .origin.matawa {
        font-size: 140%; }
        #prize .choice .origin.matawa p {
          display: inline-block;
          padding: 2.5rem;
          background: #051464;
          position: absolute;
          z-index: 5; }
    #prize .choice .flight-icon {
      width: 10%;
      max-width: 50px; }
      @media (max-width: 640px) {
        #prize .choice .flight-icon {
          max-width: none;
          margin-right: 1.5rem; } }
    #prize .choice .choice_image {
      display: flex;
      flex-direction: column;
      width: 40%;
      max-width: 300px; }
      @media (max-width: 640px) {
        #prize .choice .choice_image {
          width: calc( ( 100% - 1.5rem ) / 2 );
          max-width: none; } }
      #prize .choice .choice_image img {
        width: 100%; }
      #prize .choice .choice_image__name {
        background: #1414d2;
        padding: 1rem;
        text-align: center; }

/* ------------------
応募方法
------------------*/
#apply {
  padding: var(--large) 0 calc( var(--large) + 2rem );
  background: #1414d2; }

.apply h2 {
  color: #ffffff;
  margin-bottom: 2rem; }

.apply-flexbox {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 2rem; }

.child-card {
  width: 32%;
  padding: 3rem 2rem;
  box-sizing: border-box;
  border-radius: 10px;
  text-align: center;
  display: flex;
  flex-direction: column; }
  .child-card .btn {
    margin-top: 3rem;
    width: 100%; }
  @media (max-width: 1200px) {
    .child-card {
      width: 100%;
      max-width: 600px;
      padding: 3rem 4rem; } }
  @media (max-width: 640px) {
    .child-card {
      padding: 3rem 2rem; } }
  .child-card__ttl {
    text-align: center; }
    .child-card__ttl h3 {
      display: inline-block;
      font-size: clamp(18px, 6.5vw, 24px);
      color: #1414d2;
      font-weight: 700;
      line-height: 1;
      margin: 0;
      padding: 0;
      border-bottom: solid 3px #1414d2; }
  .child-card__content {
    margin-top: 3rem;
    display: flex;
    flex-direction: row;
    align-items: flex-start;
    text-align: left;
    gap: 2rem; }
    @media (max-width: 1200px) {
      .child-card__content {
        gap: 3rem; } }
    @media (max-width: 640px) {
      .child-card__content {
        gap: 2rem; } }
    .child-card__content .icon {
      width: 50px;
      flex: 0 0 50px;
      margin-top: 7px; }
      @media (max-width: 1200px) {
        .child-card__content .icon {
          margin-top: 0; } }
    .child-card__content p {
      max-width: 340px; }
      @media (max-width: 1200px) {
        .child-card__content p {
          max-width: none; } }
  .child-card p {
    font-weight: 500; }
  .child-card p.note {
    font-weight: normal;
    margin-top: 3rem;
    opacity: 70%; }
    @media (max-width: 640px) {
      .child-card p.note {
        margin-top: 2rem; } }
  .child-card .quiz {
    width: 100%;
    background: #f7f4f2;
    margin-top: auto;
    padding: 1rem 1rem 2rem; }
    @media (max-width: 1200px) {
      .child-card .quiz {
        margin-top: 3rem; } }
    .child-card .quiz p.question {
      background: #ffffff;
      border: 1px solid #1414d2;
      font-size: 120%;
      font-weight: 500;
      margin-top: 1rem;
      padding: 0.5rem; }

.btn-addfriend {
  margin-top: 1rem;
  display: flex;
  flex-wrap: nowrap;
  flex-direction: row;
  align-items: center;
  border-radius: 4px;
  box-sizing: border-box;
  border: solid 1px #5ad28c;
  background-color: #5ad28c; }
  .btn-addfriend__icon {
    padding: 15px;
    width: auto;
    background-color: #ffffff;
    border-radius: 4px 0 0 4px; }
    .btn-addfriend__icon img {
      width: 50px; }
  .btn-addfriend__txt {
    margin: auto;
    width: 100%;
    height: 100%;
    font-weight: 600;
    font-size: clamp(13px, 3.8vw, 18px);
    line-height: 1.5;
    color: #000000; }

.remove {
  text-decoration: none; }

/* ------------------
Rules
------------------*/
#rule-regu {
  background: #276ef1;
  padding: var(--large) 0; }
  @media (max-width: 640px) {
    #rule-regu {
      padding: calc( var(--large) + 2rem ) 0; } }

.rules {
  line-height: 1.8;
  font-size: 14px;
  border-radius: 10px;
  padding: 2rem;
  box-sizing: border-box; }
  @media (max-width: 640px) {
    .rules {
      padding: 1rem; } }
  .rules p {
    line-height: 1.8; }
  .rules__ttl {
    padding: 1rem;
    font-weight: 600;
    font-feature-settings: 'palt'; }
    .rules__ttl + p {
      margin: 1rem 0; }
    .rules__ttl p:first-child {
      font-size: clamp(14px, 3.2vw, 20px);
      padding: 1rem 0;
      margin: 0 0 1rem;
      font-weight: 600;
      background: #f7f4f2; }
  .rules dl {
    display: flex;
    flex-wrap: wrap;
    padding: 0 0 10rem; }
    .rules dl li {
      list-style: unset;
      margin: 0 0 0 1.8rem;
      text-align: left;
      padding: 0; }
    .rules dl dt, .rules dl dd {
      padding: .5rem 0;
      border-top: solid #D7D7D4 1px; }
      @media (max-width: 640px) {
        .rules dl dt, .rules dl dd {
          border: none; } }
    .rules dl dt {
      width: 140px;
      font-weight: 600; }
      @media (max-width: 640px) {
        .rules dl dt {
          width: 100%;
          border-bottom: solid #D7D7D4 1px; } }
    .rules dl dd {
      width: calc(100% - 140px);
      padding: .5rem 0 .5rem 1rem;
      border-left: solid 1px #D7D7D4; }
      @media (max-width: 640px) {
        .rules dl dd {
          width: 100%;
          border: none; } }
  .rules .container {
    position: relative;
    overflow: hidden; }
  .rules .content {
    position: relative;
    overflow: hidden;
    max-height: 300px;
    transition: max-height 0.5s ease; }
    @media (max-width: 640px) {
      .rules .content {
        max-height: 330px; } }
    .rules .content:after {
      content: '';
      width: 100%;
      height: 100px;
      position: absolute;
      left: 0;
      bottom: 0; }
  .rules .content.bg-grad-white:after {
    background: linear-gradient(180deg, rgba(255, 255, 255, 0) 0%, white 100%); }
  .rules .content.expanded {
    max-height: 1000px;
    background: none; }
  .rules .content.expanded:after {
    content: none; }
  .rules .toggle-btn {
    margin: 20px 0 0;
    padding: 10px 20px;
    cursor: pointer;
    position: absolute;
    bottom: 0;
    left: 50%;
    transform: translateX(-50%); }
    @media (max-width: 640px) {
      .rules .toggle-btn {
        bottom: 1.6rem; } }
    .rules .toggle-btn::after {
      content: none; }
  .rules .toggle-btn.close-btn {
    border-radius: 30px; }
  .rules ol li {
    list-style: auto; }

/*カリフォルニア観光局バナー*/
.bg-banner {
  background-size: cover;
  background-position: center;
  padding: 6rem 0; }
  @media (max-width: 640px) {
    .bg-banner {
      padding: var(--large) 0; } }
  .bg-banner .wrap {
    width: 88%;
    max-width: 1380px; }
  .bg-banner__main {
    padding: 6rem 0;
    background: #fff;
    color: #000;
    text-align: center;
    max-width: 440px; }
    @media (max-width: 880px) {
      .bg-banner__main {
        margin: auto; } }
    @media (max-width: 640px) {
      .bg-banner__main {
        padding: var(--large) 0; } }
    .bg-banner__main .vca-logo {
      margin-bottom: 2rem; }
      @media (max-width: 880px) {
        .bg-banner__main .vca-logo {
          width: 50%; } }
    .bg-banner__main .btn {
      margin-top: 3rem; }
      @media (max-width: 640px) {
        .bg-banner__main .btn {
          margin-top: var(--medium); } }

/* ------------------
Banner
------------------*/
#banner-section {
  display: flex;
  flex-direction: column;
  gap: 6rem;
  margin: 10rem auto 12rem; }
  @media (max-width: 1200px) {
    #banner-section {
      margin: 6rem auto 8rem; } }
  @media (max-width: 640px) {
    #banner-section {
      gap: 4rem;
      margin: 4rem auto 5rem; } }

.top-page-banner {
  box-shadow: 0px 2px 5px rgba(0, 0, 0, 0.15); }

.banner p {
  text-align: center;
  margin-bottom: 2rem;
  font-size: 120%;
  font-weight: 600; }

.footer-logo {
  width: 25%;
  max-width: 250px;
  margin: 3rem auto; }
  @media (max-width: 640px) {
    .footer-logo {
      width: 40%; } }
