/* ==========================================================
   Nicole BMW M2 SPECIAL ORDER WEEK
   File : css/m2-special-order-week.css
   ========================================================== */

:root{
  --bmw-blue:#1c69d4;
  --bmw-deep-blue:#0051a8;
  --text-main:#111;
  --text-sub:#555;
  --bg-light:#f5f5f5;
  --bg-dark:#050505;
  --border-light:#e5e5e5;
  --shadow-soft:0 8px 24px rgba(0,0,0,.08);
}

body{
  color:var(--text-main);
  background:#fff;
}

img{
  max-width:100%;
  height:auto;
}

a{
  transition:all .25s ease;
}

.logo_wrap{
  display:flex;
  align-items:center;
  justify-content:flex-start;
  width:100%;
  height:8vw;
  margin:1vw auto auto 2vw;
}

.logo2{
  width:8vw !important;
  max-width:80px !important;
  min-width:60px !important;
}

.logo_wrap::after{
  content:"駆けぬける歓び";
  margin-left:1.2em;
  color:#fff;
  font-size:1.2rem;
  font-weight:300;
}

.lead-copy{
  line-height:2;
}

.section-title-en{
  letter-spacing:.08em;
  color:var(--bmw-blue);
}

.fair-section{
  padding:4rem 0;
}

.fair-section.bg-light-gray{
  background:var(--bg-light);
}

.fair-section.bg-dark-section{
  background:var(--bg-dark);
  color:#fff;
}

.kv-copy{
  background:#000;
  color:#fff;
  padding:3rem 1rem;
}

.event-label{
  display:inline-block;
  margin-bottom:1rem;
  padding:.45rem 1rem;
  border:1px solid #000;
  color:#000;
  font-size:1.85rem;
  letter-spacing:.1em;
}

.cta-btn{
  display:inline-block;
  min-width:260px;
  padding:15px 30px;
  background:var(--bmw-blue);
  color:#fff !important;
  font-weight:700;
  text-decoration:none;
  text-align:center;
  transition:opacity .2s ease-in-out;
}

.cta-btn:hover{
  opacity:.85;
  color:#fff !important;
}

.outline-btn{
  display:inline-block;
  min-width:260px;
  padding:14px 30px;
  border:1px solid var(--bmw-blue);
  background:#fff;
  color:var(--bmw-blue) !important;
  font-weight:700;
  text-decoration:none;
  text-align:center;
  transition:all .2s ease-in-out;
}

.outline-btn:hover{
  background:var(--bmw-blue);
  color:#fff !important;
}

.program-nav-section{
  padding:4rem 0;
  background:#fff;
}

/* ==========================================================
   Program Cards
   ========================================================== */

.program-card{
  display:flex;
  flex-direction:column;
  height:100%;
  background:#fff;
  border:1px solid var(--border-light);
  text-decoration:none;
  color:var(--text-main);
  overflow:hidden;
  transition:all .25s ease;
}

.program-card:hover{
  transform:translateY(-4px);
  box-shadow:0 10px 30px rgba(0,0,0,.12);
  color:var(--text-main);
}

.program-card-image img{
  width:100%;
  aspect-ratio:16 / 9;
  object-fit:cover;
  display:block;
}

.program-card-body{
  display:flex;
  flex-direction:column;
  flex:1;
  padding:2rem;
}

.program-label{
  display:inline-block;
  width:max-content;
  margin-bottom:1rem;
  padding:.4rem .8rem;
  background:#000;
  color:#fff;
  font-size:.75rem;
  font-weight:700;
  letter-spacing:.08em;
}

.program-date{
  color:var(--bmw-blue);
  font-weight:700;
  letter-spacing:.04em;
}

.program-btn-wrap{
  margin-top:auto;
  padding-top:2rem;
}

.program-btn-wrap .cta-btn{
  display:flex;
  align-items:center;
  justify-content:center;
  width:100%;
  min-width:auto;
  min-height:54px;
  padding:14px 20px;
  line-height:1.5;
}

/* ==========================================================
   Cards
   ========================================================== */

.m2-card,
.package-card,
.session-card{
  height:100%;
  background:#fff;
  border:1px solid var(--border-light);
}

.package-card img{
  width:100%;
  aspect-ratio:4 / 3;
  object-fit:cover;
}

.m2-card img{
  width:100%;
  object-fit:cover;
}

.m2-card-body,
.package-card-body{
  padding:1.5rem;
}

.m2-label{
  display:inline-block;
  margin-bottom:.75rem;
  padding:.35rem .65rem;
  background:#000;
  color:#fff;
  font-size:.75rem;
  letter-spacing:.08em;
}

.feature-img{
  width:100%;
  height:auto;
  object-fit:contain;
  background:#fff;
}

.event-info-box{
  border-top:1px solid #d8d8d8;
  border-bottom:1px solid #d8d8d8;
}

.event-info-box dt{
  font-weight:700;
}

.event-info-box dd{
  margin-bottom:0;
}

.note-list{
  color:var(--text-sub);
  font-size:.875rem;
  line-height:1.8;
}

.session-card{
  padding:1.4rem;
}

.session-time{
  color:var(--bmw-blue);
  font-weight:700;
  letter-spacing:.04em;
}

.dark-card{
  height:100%;
  background:#151515;
  border:1px solid rgba(255,255,255,.15);
  padding:1.5rem;
}

.form-wrap{
  background:#fff;
}

.formrun-embed{
  min-height:300px;
}

/* ==========================================================
   Floating Banner
   ========================================================== */

.floating-banner{
  position:fixed;
  right:24px;
  bottom:24px;
  z-index:1050;
  width:min(320px, calc(100vw - 40px));
  filter:drop-shadow(0 8px 18px rgba(0,0,0,.28));
}

.floating-banner a{
  display:block;
  line-height:0;
}

.floating-banner img{
  display:block;
  width:100%;
  height:auto;
  border-radius:4px;
}

.floating-banner-close{
  position:absolute;
  top:-12px;
  right:-12px;
  display:flex;
  align-items:center;
  justify-content:center;
  width:30px;
  height:30px;
  border:0;
  border-radius:50%;
  background:var(--text-main);
  color:#fff;
  font-size:20px;
  line-height:1;
  cursor:pointer;
  box-shadow:0 2px 8px rgba(0,0,0,.25);
}

.floating-banner-close:hover{
  opacity:.85;
}

body.has-floating-banner{
  padding-bottom:0;
}

/* ==========================================================
   Footer
   ========================================================== */

#footer{
  background:#fff;
  padding:4rem 0 2rem;
}

#footer .footer-ttl{
  font-weight:700;
  margin-bottom:.75rem;
}

#footer p{
  line-height:1.8;
}

/* ==========================================================
   Responsive
   ========================================================== */

@media (max-width:991px){
  .fair-section,
  .program-nav-section{
    padding:3rem 0;
  }

  .program-card-body{
    padding:1.5rem;
  }
}

@media (max-width:767px){
  .logo_wrap{
    margin:4vw auto auto 2.5vw;
  }

  .logo_wrap::after{
    font-size:.8rem;
  }

  .logo2{
    min-width:40px !important;
  }

  .fair-section,
  .program-nav-section{
    padding:2.8rem 0;
  }

  .kv-copy{
    padding:2.25rem 1rem;
  }

  .lead-copy{
    line-height:1.8;
  }

  .cta-btn,
  .outline-btn{
    width:100%;
    min-width:auto;
  }

  .program-card-image img{
    aspect-ratio:4 / 3;
  }

  .program-card-body{
    padding:1.5rem;
  }

  .program-btn-wrap{
    padding-top:1.5rem;
  }

  .floating-banner{
    right:10px;
    bottom:10px;
    width:calc(100vw - 20px);
    max-width:420px;
  }

  .floating-banner-close{
    top:-10px;
    right:-6px;
    width:28px;
    height:28px;
    font-size:18px;
  }

  body.has-floating-banner{
    padding-bottom:92px;
  }
}