/*
Theme Name: swear
Theme URI: 
Description: swear写真館のHP
Version: 1.0.0
Author: kotawa
Author URI: http://www.kotawa0303.shop/
*/


/* PC、スマホ共通スタイル */

#header-logo img{
  width: 100px;
  height: auto;
}

*{
  box-sizing: border-box; 
}

p{
  font-size: 16px;
}


h1,h2 {
  font-family: "Cormorant Garamond", serif;
  font-optical-sizing: auto;
  font-weight: 400;
  font-style: normal;
}
p {
  font-family: "Shippori Mincho", serif;
  font-weight: 400;
  font-style: normal;
}

h3 { 
  font-family: "Open Sans", sans-serif;
  font-optical-sizing: auto;
  font-weight: 400;
  font-style: normal;
  font-variation-settings:
    "wdth" 100;
}


body {
  margin: 0;
  background-color: #FCF8F0;
}

.container{
 max-width:1080px;
 margin:0 auto;
}

/* ==================ヘッダー ==================*/
header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  height: 100px;
}

#header-logo img {
  margin: auto 60px;
}

/* ナビゲーションのリンクの装飾設定 */
#nav-pc a,
#nav-pc span {
  font-size: 14px;
  white-space: nowrap;
}

#nav-pc > ul {
  display: flex;
  padding-left: 0;
}

#nav-pc li {
  list-style: none;
}

#nav-pc a,
#nav-pc span {
  text-decoration: none;
  margin: 20px;
  color: #633418;
}

#nav-pc a:hover {
  text-decoration: underline;
}

.has-child {
  position: relative;
}

.submenu {
 display:none;
 position:absolute;
 top:100%;
 left:0;
 list-style:none;
 padding:15px;
 background:#fff;
}

.has-child:hover .submenu{
 display:block;
}

.submenu li a{
 display:block;
 padding:12px 20px;
 margin:0;
 white-space:nowrap;
}


#menu-sp {
  display: none;
}

#nav-sp {
  display: none;
}

#nav-sp.open {
  display: block;
}


/* ==================メインビジュアル================== */
#main-visual{
 width:100%;
 min-height:100vh;
}

#main-visual img {
   width:100%;
   min-height:100vh;
   object-fit:cover;
   display:block;
}

#concept{
  position:relative;
  text-align:center;
  padding:50px 40px;
}

.decoration {
   position:absolute;
   inset:0;
   pointer-events:none;
}

.left {
 position:absolute;
 top: -50px;
 left:-70px;

 width:300px;
 height:300px;

 background-image:url("images/decoration/21-2.png");
 background-repeat:no-repeat;
 background-size:contain;
 background-position:center;
 z-index: 1;
}

.right{
 position:absolute;

 right:-50px;
 bottom:10px;

 width:200px;
 height:200px;

 background-image:url("images/decoration/23-2.png");
 background-repeat:no-repeat;
 background-size:contain;
 background-position:center;
 z-index: 1;
}

.title,
#concept p{
  position: relative;
  z-index: 2;
}

.entitle {
  display: block;
  font-size: 90px;
  color: #7E6D64;
  text-align: center;
  z-index: 10;
}

.jptitle {
  display: block;
  font-size: 45px;
  color: #7E6D64;
  text-align: center;
  z-index: 9;
}

 #concept p {
 font-size: 24px;
 text-align: center;
 margin: 40px 30px 70px 30px; 
 color: #4B3020;
} 


/* ==================プラン================== */

/* ======プランタイトル===== */
#plans {
  position: relative;
  width: 100%;
  height: auto;
  padding: 100px 0;
  margin-bottom: 100px;
  z-index: 1;
}

#plans::before {
  content: "";
  position: absolute;
  top: 0; left: 0;
  width: 100%;
  height: 100%;
  background: #E3D5D1;
  border-top-right-radius: 90% 40%;
  z-index: -1;
}

/* =====セクションタイトル===== */
.section-title {
 text-align: center;
}

.section-title .en{
 display: block;
 font-size:46px;
 line-height:1.1;
 color: #633418;
}

.section-title .jp{
  display:block;
  font-size:24px;
  color: #633418;
}




/* =====プラン===== */
.pricing-plans {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 24px;
}

.plan {
  flex: 1 1 400px;
  max-width: 400px;
  min-width: 280px;
  box-sizing: border-box;
  text-align: center;
}



.thumbnail {
  width: 100%;
  aspect-ratio: 16 / 10; /* 好きな比率 */
  overflow: hidden;
}

.thumbnail img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}


.btn {
  margin: 0.5px;
  padding: 5px 30px;
  background: #633418;
  border: #633418 1px solid;
  color: #fff;
  font-size: 16px;
  font-weight: 400;
  line-height: 1.5;
  text-align: center;
  letter-spacing: 0.05em;
  border-radius: 80px;
  text-decoration: none;
  white-space: nowrap;
  cursor: pointer;
  min-width: 70px;
}

.btn:hover {
  background: #D6956F;
  border: 1px solid #D6956F;
}


/* ==================衣装一覧================== */

/* =====衣装背景===== */
#costume {
  position: relative;
}

#costume .container {
  position: relative;
  z-index: 1;
}

.decoration1 {
  width: 500px;
  height: 500px;
  background-color: #F7F3E9;
  border-radius: 50%;
  position: absolute;
  top: -200px;
  left: -20px;
  z-index: 0;
}

.decoration2 {
  width: 300px;
  height: 300px;
  background-color: #F7F3E9;
  border-radius: 50%;
  position: absolute;
  bottom: 400px;
  right: -30px;
  z-index: 0;
}

.decoration3 {
  width: 200px;
  height: 200px;
  background-color: #F7F3E9;
  border-radius: 50%;
  position: absolute;
  bottom: -100px;
  left: 20px;
  z-index: 0;
}


.costume-decoration1 {
 position: absolute;
 top: 5%;
 right: -170px;

 width:400px;
 height:400px;

 background-image:url("images/decoration/22.png");
 background-repeat:no-repeat;
 background-size:contain;
 z-index: 2;
}


.costume-decoration2 {
 position: absolute;
 top: 55%;
 left: -170px;

 width:400px;
 height:400px;

 background-image:url("images/decoration/22-2.png");
 background-repeat:no-repeat;
 background-size:contain;
 z-index: 2;
}

/* =====衣装一覧===== */

#dresscostume {
  margin-bottom: 100px;
}

#kimonocostume {
  margin-bottom: 100px;
}

.slider {
  overflow: hidden;
  width: 100%;
}

.slider-track {
  display: flex;
  width: max-content;
}

.slider-track img {
  width: 300px;
  height: auto;
  margin: 0 20px;
}


#dresscostume .btn,
#kimonocostume .btn {
  display: block;
  width: fit-content;
  margin-left: auto;
  margin-top: 10px;
}


/* ==========ギャラリー========== */

/* 背景 */
#gallery {
  position: relative;
  margin-bottom: 200px;
}

#gallery .container {
  position: relative;
  z-index: 1;
}

.gallery-decoration1 {
  width: 400px;
  height: 400px;
  background-color: #F7F3E9;
  border-radius: 50%;
  position: absolute;
  bottom: 400px;
  right: -30px;
  z-index: 0;
}

.gallery-decoration2 {
  width: 200px;
  height: 200px;
  background-color: #F7F3E9;
  border-radius: 50%;
  position: absolute;
  bottom: -100px;
  left: 80px;
  z-index: 0;
}

/* カルーセル */

.carousel {
  position: relative;
  width: 100%;
  max-width: 1000px;
  margin: auto;
  overflow: visible;
}

.carousel-window {
  overflow: hidden;
  width: 100%;
  height: auto;
}

.carousel-images {
  display: flex;
  transition: transform 1.0s ease;
}

.carousel-images img {
  width: 100%;
  max-width: 1000px;
  height: 600px;
  object-fit: cover;
  flex-shrink: 0;
}

/* ボタン */
.prev, .next {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  background: none;
  color: #633418;
  font-size: 30px;
  padding: 10px;
  border: none;
  cursor: pointer;
}

.prev {
  left: -50px;
}
.next { 
  right: -50px;
}

.prev:hover,
.next:hover {
  opacity: 0.6;
}


#gallery a {
  padding: 5px 30px;
  background: #633418;
  border: #633418 1px solid;
  color: #fff;
  font-size: 20px;
  font-weight: 400;
  line-height: 42px;
  text-align: center;
  letter-spacing: 0.05em;
  border-radius: 80px;
  text-decoration: none;
  white-space: nowrap;
  cursor: pointer;
  min-width: 70px;
  display: block;
  width: fit-content;
  margin: 30px auto;
}

#gallery a:hover {
  background: #D6956F;
  border: #D6956F; 
}


/* ==========撮影の流れ＆FAQ========== */
#banner .container {
  display: block;
  margin-bottom: 100px;
}


@media screen and (min-width: 768px) {
  #banner .container {
    display: flex;
    gap: 40px;
    justify-content: center;
  }
}

.photo-flow,
.faq {
  flex: 1;
  max-width: 500px;
  position: relative;
}

.photo-flow img,
.faq img {
  width: 100%;
  height: 250px;
  object-fit: cover;
  display: block;
}


.photo-flow a,
.faq a {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%,-50%);

  padding: 20px 40px;
  background: rgba(255, 255, 255, 0.7);

  color: #633418;
  font-size: 28px;

  text-decoration: none;
}


/* ========== お問い合わせ・相談予約========== */
#inquiry {
  display: flex;
  justify-content: center;
  padding: 100px 0;
}

.inquiry-inner {
  background: #E3D5D1;
  padding: 50px; /* 内側余白 */
  border-radius: 40px; /* 角丸 */
  text-align: center;
  z-index: 1;
}

#inquiry h2 {
  font-size: 32px;
  color: #4B3020;
  margin-bottom: 50px;
}


.inquiries-buttons {
  display: flex;
  gap: 20px;
}

.inquiry-btn a {
  padding: 20px 80px;
  border: #633418 1px solid;
  color: #633418;
  font-size: 24px;
  font-weight: 400;
  line-height: 1.5;
  text-align: center;
  letter-spacing: 0.05em;
  border-radius: 30px;
  text-decoration: none;
  white-space: nowrap;
  min-width: 70px;
}

.consultation-btn a {
  padding: 20px 80px;
  border: #633418 1px solid;
  color: #633418;
  font-size: 24px;
  font-weight: 400;
  line-height: 1.5;
  text-align: center;
  letter-spacing: 0.05em;
  border-radius: 30px;
  text-decoration: none;
  white-space: nowrap;
  min-width: 70px;
}

.inquiry-btn a,
.consultation-btn a {
  display: flex;
  align-items: center;
  justify-content: center;
}


/* =========アクセス========== */
#access {
  display: flex;
  position: relative;
  flex-direction: column;
}

.access-back {
 background-color: #F0EDE7;
 padding: 50px 0;
 z-index: 1;
}

.access-decoration1 {
  width: 400px;
  height: 400px;
  background-color: #F7F3E9;
  border-radius: 50%;
  position: absolute;
  bottom: 400px;
  right: -30px;
  z-index: 0;
}

.map {
  width: 65%;
}

.map iframe {
  width: 100%;
  height: 500px;
  border: 0;
}

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

.adress {
  width: 35%;
}

.address p {
  font-size: 20px;
  color: #4B3020;
  white-space: nowrap;
}


/* ========フッター========= */

#footer-icon {
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 50px;
}

#footer-logo img {
  width: 300px;
  height: auto;
}

#footer-icon p {
  font-size: 32px;
  color: #6A5422;
}

.footer-inquiries {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 20px;
  margin-bottom: 80px;
}

.footer-inquiry a {
  padding: 20px 80px;
  border: #633418 1px solid;
  color: #633418;
  font-size: 24px;
  font-weight: 400;
  line-height: 1.5;
  text-align: center;
  letter-spacing: 0.05em;
  border-radius: 30px;
  text-decoration: none;
  white-space: nowrap;
  min-width: 70px;
}

.footer-consultation a {
  padding: 20px 80px;
  border: #633418 1px solid;
  color: #633418;
  font-size: 24px;
  font-weight: 400;
  line-height: 1.5;
  text-align: center;
  letter-spacing: 0.05em;
  border-radius: 30px;
  text-decoration: none;
  white-space: nowrap;
  min-width: 70px;
}



/* フッターナビ */
.footer-nav {
  display: flex;
  justify-content: center;
  gap: 60px;
  padding: 0;
  margin: 50px 0;
}

.footer-nav > li {
  list-style: none;
  text-align: left;
}

/* 見出し */
.footer-nav span {
  display: block;
  font-weight: bold;
  margin-bottom: 10px;
  color: #633418;
}

/* 子リスト */
.footer-nav ul {
  padding: 0;
}

.footer-nav ul li {
  list-style: none;
  margin-bottom: 5px;
}

/* リンク */
.footer-nav a {
  text-decoration: none;
  color: #633418;
  font-size: 16px;
}

.footer-nav a:hover {
  opacity: 0.6;
}



#sns-footer {
  display: flex;
  flex-direction: column; 
  align-items: center;    
  gap: 20px;             
}

/* SNSアイコン横並び */
.sns-btns {
  display: flex;
  gap: 30px; /* アイコン同士の間隔 */
}

/* アイコンサイズ */
#sns-footer img {
  width: 50px;
  height: auto;
}

/* コピー */
#copyright {
  color: #4B3020;
  margin: 0;
  text-align: center;
}

/* ===============================================================================
　　　　　　　　　　　　　　　　　　　　　　　　　スマホ用のスタイル 
====================================================================================*/

/* 画面幅が767px以下のとき */
@media screen and (max-width: 767px) {
   /* PC用ナビゲーション非表示 */

  header {
    height: 80px;
  }

   #nav-pc {
     display: none;
   }
 
  #header-logo img {
    width: 50px;
    height: 50px;
    margin: auto 20px;
  }

   #menu-sp img {
  width: 40px;
  height: 40px;
  display: block;
}

  #close img {
    width: 40px;
    height: 40px;
    display: block;
  }
   /* ハンバーガーメニュー */
   #menu-sp {
    display: flex;
    align-items: center;
    justify-content: center;
    background-color: transparent;
    border: none;
    padding: 0;
    margin-right: 20px;
   }
 
   /* スマホ用ナビゲーションの表示切替*/
   /* 初期状態、レイアウトと非表示設定 */

   #nav-sp ul {
      padding: 0;
      margin: 0;
    }

    #nav-sp li {
      list-style: none;
      margin-bottom: 20px;
    }

    #nav-sp a,
    #nav-sp span {
      color: #633418;
      text-decoration: none;
      font-size: 14px;
    }

    #nav-sp .submenu {
      display: block;
      position: static;
      background: transparent;
      padding: 10px 0 0 15px;
    }

    #nav-sp .submenu li {
      margin-bottom: 10px;
    }


   #nav-sp {

      position: fixed;
      top: 0;
      right: 0;

      width: 50%;

      height: 80dvh;

      background: #E3D5D1;

      z-index: 100;

      padding: 80px 30px;

      display: none;
   }

   #nav-sp.open {
    display: block;
   }

   #close {
  position: absolute;
  top: 20px;
  right: 100px;

  background: transparent;
  border: none;

  padding: 0;
  z-index: 200;
}

  /* ============共通============ */
  .container {
    padding: 0 16px;
  }

  p {
    font-size: 14px;
    line-height: 1.8;
  }

  h3 {
    font-size: 18px;
  }

 .section-title .en{
  font-size:36px;
 }

.section-title .jp{
  font-size:20px;
}

.btn {
  font-size: 14px;
}

  /* ============FV============== */

  .entitle {
    font-size: 42px;
  }

  .jptitle {
    font-size: 24px;
  }

  #main-visual,
  #main-visual img {
    min-height: auto;
  }

  #concept {
    padding: 40px 20px;
  }

  #concept p {
    font-size: 14px;
    margin: 20px 0 40px;
    white-space: nowrap;
  }

  /* 装飾 */
  .left {
    width: 180px;
    height: 180px;
    left: -40px;
    top: -20px;
  }

  .right {
    width: 120px;
    height: 120px;
    right: -20px;
  }

/* ==========プラン========== */
  .pricing-plans {
    flex-direction: column;
    align-items: center;
  }

  .plan {
  flex: 1 1 300px;
  max-width: 300px;
  min-width: 200px;
  box-sizing: border-box;
  text-align: center; 
  }
  

/* ==========衣装=============== */
  /* 背景 */
  .decoration1 {
  width: 300px;
  height: 300px;
  background-color: #F7F3E9;
  border-radius: 50%;
  position: absolute;
  top: -200px;
  left: -20px;
  z-index: 0;
}

.decoration2 {
  width: 200px;
  height: 200px;
  background-color: #F7F3E9;
  border-radius: 50%;
  position: absolute;
  bottom: 400px;
  right: -30px;
  z-index: 0;
}

.decoration3 {
  width: 100px;
  height: 100px;
  background-color: #F7F3E9;
  border-radius: 50%;
  position: absolute;
  bottom: -100px;
  left: 20px;
  z-index: 0;
}

#costume h3 {
  margin-left: 20px;
}

#dresscostume {
  margin-bottom: 60px;
}

#kimonocostume {
  margin-bottom: 60px;
}

.slider-track img {
  width: 200px;
  height: auto;
  margin: 0 20px;
}

.costume-decoration1 {
 position: absolute;
 top: 5%;
 right: -100px;

 width:200px;
 height:200px;

 background-image:url("images/decoration/22.png");
 background-repeat:no-repeat;
 background-size:contain;
 z-index: 2;
}


.costume-decoration2 {
 position: absolute;
 top: 60%;
 left: -80px;

 width:200px;
 height:200px;

 background-image:url("images/decoration/22-2.png");
 background-repeat:no-repeat;
 background-size:contain;
 z-index: 2;
}


/* ===================ギャラリー ================*/



/* 背景 */

.gallery-decoration1 {
  width: 300px;
  height: 300px;
  background-color: #F7F3E9;
  border-radius: 50%;
  position: absolute;
  bottom: 400px;
  right: -80px;
  z-index: 0;
}

.gallery-decoration2 {
  width: 200px;
  height: 200px;
  background-color: #F7F3E9;
  border-radius: 50%;
  position: absolute;
  bottom: -100px;
  left: 80px;
  z-index: 0;
}

/* カルーセル */

.carousel {
  position: relative;
  width: 100%;
  max-width: 700px;
  margin: auto;
  overflow: visible;
}

.carousel-window {
  overflow: hidden;
  width: 100%;
  height: auto;
}

.carousel-images {
  display: flex;
  transition: transform 1.0s ease;
}

.carousel-images img {
  width: 100%;
  max-width: 700px;
  height: 400px;
  object-fit: cover;
  flex-shrink: 0;
}



#gallery a {
font-size: 16px;
}


  .prev,
  .next {
    display: none;
  }

/* ==========撮影の流れ＆FAQ========== */

#banner .container {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 30px;
}

.photo-flow,
.faq {
  flex: 1;
  width: 100%;
  max-width: 400px;
  position: relative;
}

.photo-flow img,
.faq img {
  width: 100%;
  height: 250px;
  object-fit: cover;
  display: block;
}

  #banner a {
    white-space: nowrap;
  }

  /* ====================お問い合わせ============= */
  .inquiries-buttons {
    flex-direction: column;
  }

  .inquiry-btn a,
  .consultation-btn a {
    width: 100%;
    font-size: 16px;
    padding: 16px 20px;
    
  }

  /* ===================Access==================== */
  .guide {
    flex-direction: column;
  }

  .address p {
    font-size: 16px;
  }

  .map {
    width: 100%;
    height: 100%;
    max-width: 500px;
    max-height: 500px;
  }

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

  #footer-logo img {
    width: 180px;
  }

  #footer-icon p {
    font-size: 20px;
  }

.footer-inquiries {
  display: flex;
  flex-direction: column;
  gap: 50px;
}


.footer-inquiry a,
.footer-consultation a {
 font-size: 18px;
  display: block;
  width: 280px;
  padding: 20px 0;
  box-sizing: border-box;
}

.footer-nav {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 30px;
  text-align: center;
  max-width: 500px;
  margin: 50px auto;
}

.footer-nav > li {
  text-align: center;
}

#sns-footer img {
  width: 30px;
  height: 30px;
}

}


