/*
Theme Name: SPASIBA BRIDAL
*/
/* =========================
reset
========================= */

*{
  margin:0;
  padding:0;
  box-sizing:border-box;
}

html{
  scroll-behavior:smooth;
}

body{
  font-family: 'Noto Sans JP', sans-serif;
  background:#efefef;
  color:#333;
  line-height:1.9;
  overflow-x:hidden;
}
 
/* body{
  font-family: 'Noto Sans JP', sans-serif;
  background: linear-gradient(to bottom, #cfe9ff, #ffffff);
  color:#333;
  line-height:1.9;
  overflow-x:hidden;
} */

img{
  width:100%;
  display:block;
}

a{
  text-decoration:none;
  color:#333;
}

ul{
  list-style:none;
}

/* =========================
common
========================= */

.container{
  width:min(90%, 1100px);
  margin:0 auto;
}

.section{
  padding:120px 0;
}

.section-title{
  font-size:clamp(36px, 5vw, 58px);
  margin-bottom:60px;
  font-family: 'Roboto Slab', serif;
  letter-spacing:1px;
}

/* =========================
header
========================= */

.header{
  width:100%;
  padding:25px 5%;
  display:flex;
  justify-content:space-between;
  align-items:center;
  position:sticky;
  top:0;
  z-index:1000;
  background:rgba(239,239,239,0.95);
  backdrop-filter:blur(8px);
}

.logo{
  font-size:clamp(24px, 3vw, 42px);
  font-weight:700;
  letter-spacing:2px;
  font-family: 'Roboto Slab', serif;
}

.nav ul{
  display:flex;
  align-items:center;
  gap:40px;
}

.nav a{
  font-size:14px;
  position:relative;
  transition:.3s;
}

.nav a:hover{
  opacity:.7;
}

/* =========================
fv
========================= */

.fv{
  width:100%;
  margin-top:60px;
}
/* .slider {
  position: relative;
  width: 100%;
  height: 100vh;
  overflow: hidden;
} */

.slider{
  position:relative;
  width:100%;
  max-width:900px;
  margin:0 auto;
  height:70vh;
  overflow:hidden;
}

.slide {
  position: absolute;
  width: 100%;
  height: 100%;

  opacity: 0;
  transition: opacity 1s ease-in-out;
}

.slide.active {
  opacity: 1;
}

.slide img{
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:center center;
}

/* =========================
concept
========================= */

.concept-wrapper{
  display:flex;
  justify-content:space-between;
  align-items:flex-start;
  gap:80px;
}

.concept-text{
  width:55%;
}

.concept-text p{
  margin-bottom:28px;
  font-size:15px;
}

.concept-images{
  width:35%;
}

.gray-box{
  width:100%;
  aspect-ratio:1/1;
  background:#bcbcbc;
  margin-bottom:40px;
}

.concept-images img{
  width:100%;
  aspect-ratio:4/3;
  object-fit:cover;
  margin-bottom:20px;
}
/* =========================
plan
========================= */

.plan-lead{
  margin-bottom:80px;
  font-size:15px;
}

.plan-item{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:70px;
  margin-bottom:100px;
}

.plan-left{
  width:48%;
}

.plan-right{
  width:48%;
}

.plan-label{
  display:block;
  font-family: 'Roboto Slab', serif;
  font-size:28px;
  margin-bottom:5px;
}

.plan-left h3{
  font-size:48px;
  margin-bottom:25px;
}

.plan-image{
  position:relative;
  overflow:hidden;
  border-radius:12px;
}

.plan-image img{
  height:260px;
  object-fit:cover;
  transition:0.5s;
}

.plan-image:hover img{
  transform:scale(1.05);
}

.plan-overlay{
  position:absolute;
  inset:0;
  background:rgba(0,0,0,0.35);
  color:#fff;
  display:flex;
  flex-direction:column;
  justify-content:center;
  align-items:center;
}

.plan-overlay p{
  font-size:20px;
}

.plan-overlay span{
  font-size:clamp(32px, 5vw, 54px);
  font-weight:bold;
}

.plan-right ul{
  text-align:center;
}

.plan-right li{
  margin-bottom:10px;
  font-size:15px;
}

/* =========================
special
========================= */

.special-box{
  background:#e5cb8d;
  padding:35px;
  border-radius:16px;
  margin-bottom:120px;
}

.special-box h4{
  margin-bottom:15px;
  font-size:24px;
}

.special-box p{
  font-size:15px;
}

/* =========================
new plan
========================= */

.new-plan{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:70px;
}

.new-plan-left{
  width:48%;
}

.new-plan-right{
  width:48%;
}

.new{
  display:inline-block;
  margin-bottom:10px;
  transform:rotate(-12deg);
  font-family: 'Roboto Slab', serif;
}

.new-plan-left h3{
  font-size:40px;
  margin-bottom:20px;
  font-family: 'Roboto Slab', serif;
}

.new-plan-image img{
  border-radius:12px;
}

.new-plan-right h4{
  margin-bottom:30px;
  line-height:1.7;
}

.new-plan-right li{
  margin-bottom:12px;
}

.new-plan-right small{
  display:block;
  margin-top:20px;
}

/* =========================
gallery
========================= */

/* .gallery-grid{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:24px;
}

.gallery-grid img{
  width:90%;
  aspect-ratio:1/1;
  object-fit:cover;
  border-radius:12px;
  transition:.4s;
} */

.gallery-grid{
  display:grid;
  grid-template-columns:repeat(2, 320px);
  justify-content:center;
  gap:24px;
}

.gallery-grid img{
  width:320px;
  height:320px;
  object-fit:cover;
  border-radius:12px;
  transition:.4s;
}

.gallery-grid img:hover{
  transform:scale(1.03);
}

/* =========================
access
========================= */

.access-wrapper{
  display:flex;
  justify-content:space-between;
  align-items:flex-start;
  gap:70px;
}

.map-box{
  width:45%;
  aspect-ratio:4/3;
  background:#bcbcbc;
  display:flex;
  justify-content:center;
  align-items:center;
  font-size:clamp(24px, 3vw, 42px);
  font-family: 'Roboto Slab', serif;
}

.map-wrap{
  width:100%;
  aspect-ratio:3 / 4;
  position:relative;
}

.map-wrap iframe{
  position:absolute;
  top:0;
  left:0;
  width:100%;
  height:100%;
}

.map-card{
  width:100%;
  max-width:900px;
  margin:0 auto;
  aspect-ratio:4 / 3;

  border-radius:16px;
  overflow:hidden;

  box-shadow:0 10px 30px rgba(0,0,0,0.15);
  background:#fff;
}

.map-card iframe{
  width:100%;
  height:100%;
  border:0;
}

.contact-box{
  width:50%;
}

.contact-box h3{
  font-size:clamp(32px, 5vw, 54px);
  margin-bottom:30px;
}

.contact-box p{
  margin-bottom:30px;
}

/* =========================
footer
========================= */

.footer{
  background:#2b2b2b;
  color:#fff;
  text-align:center;
  padding:60px 20px;
}

.footer p:first-child{
  margin-bottom:15px;
}

/* ==================================================
tablet
================================================== */

@media screen and (max-width:1199px){

  .section{
    padding:100px 0;
  }

  .concept-wrapper,
  .plan-item,
  .new-plan,
  .access-wrapper{
    gap:50px;
  }

  .nav ul{
    gap:25px;
  }

  .plan-left h3{
    font-size:40px;
  }

}

/* ==================================================
smartphone
================================================== */

@media screen and (max-width:767px){

  .header{
    flex-direction:column;
    gap:18px;
    padding:20px 5%;
  }

  .nav ul{
    gap:18px;
    flex-wrap:wrap;
    justify-content:center;
  }

  .nav a{
    font-size:13px;
  }

  .section{
    padding:80px 0;
  }

  .section-title{
    margin-bottom:40px;
  }

  .concept-wrapper,
  .plan-item,
  .new-plan,
  .access-wrapper{
    flex-direction:column;
    gap:40px;
  }

  .concept-text,
  .concept-images,
  .plan-left,
  .plan-right,
  .new-plan-left,
  .new-plan-right,
  .map-box,
  .contact-box{
    width:100%;
  }

  .concept-text p,
  .plan-lead,
  .plan-right li,
  .special-box p{
    font-size:14px;
  }

  .plan-left h3{
    font-size:36px;
  }

  .plan-image img{
    height:220px;
  }

  .plan-overlay span{
    font-size:38px;
  }

  .special-box{
    padding:25px;
  }

  /* .gallery-grid{
    grid-template-columns:1fr;
    gap:18px;
  } */

  .gallery-grid{
  grid-template-columns:1fr;
}

.gallery-grid img{
  width:100%;
  height:auto;
}
  .contact-box h3{
    margin-bottom:20px;
  }

  .footer{
    padding:40px 20px;
  }

  /* =================================
hamburger menu
================================= */

.hamburger{
  display:none;
  width:40px;
  height:40px;
  border:none;
  background:none;
  cursor:pointer;
  position:relative;
  z-index:2000;
}

.hamburger span{
  display:block;
  width:28px;
  height:2px;
  background:#333;
  position:absolute;
  left:6px;
  transition:.3s;
}

.hamburger span:nth-child(1){
  top:10px;
}

.hamburger span:nth-child(2){
  top:19px;
}

.hamburger span:nth-child(3){
  top:28px;
}

/* active */

.hamburger.active span:nth-child(1){
  transform:rotate(45deg);
  top:19px;
}

.hamburger.active span:nth-child(2){
  opacity:0;
}

.hamburger.active span:nth-child(3){
  transform:rotate(-45deg);
  top:19px;
}

/* =========================
SP only
========================= */

@media screen and (max-width:767px){

  .header{
    flex-direction:row;
    justify-content:space-between;
    align-items:center;
  }

  .hamburger{
    display:block;
  }

  .nav{
    position:fixed;
    top:0;
    right:-100%;
    width:70%;
    height:100vh;
    background:#efefef;
    padding-top:100px;
    transition:.4s;
    z-index:1500;
    box-shadow:-5px 0 10px rgba(0,0,0,0.1);
  }

  .nav.active{
    right:0;
  }

  .nav ul{
    flex-direction:column;
    align-items:center;
    gap:35px;
  }

  .nav a{
    font-size:18px;
  }

}

}