@charset "UTF-8";
/* CSS Document */

:root{
    --odds: 0.8;
  --mainColor:#8c633c;
  --mainColor02:#c09035;
}

.img {
    transform: scale(var(--odds));
    transform-origin: 0 0; /* 左上を基準に縮小 */
}

.img.ct {
    transform-origin: center;
}

input[type="text"],
button,
textarea {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  background: transparent;
  border: none;
  border-radius: 0;
  font: inherit;
  outline: none;
}

textarea {
  resize: vertical;
}


input[type='submit'],
input[type='button'],
label,
button,
select {
  cursor: pointer;
}


html, body, div, span, object, iframe,
h1, h2, h3, h4, h5, h6, p,
dl, dt, dd, ol, ul, li
{
  margin:0;
  padding:0;
  border:0;
  outline:0;
  font-size:100%;
  vertical-align:baseline;
  background:transparent;
}

body {
 	line-height:1.5;
	font-family: "Shippori Mincho", serif;
	font-weight: 400;
  margin: auto;
  position: relative;
  color:#3d3a39;
  background:url("../images/bg.png");
}


body *{
	 font-family: "Shippori Mincho", serif;
}

ul {
  list-style:none;
}

a {
  margin:0;
  padding:0;
  font-size:100%;
  vertical-align:baseline;
  background:transparent;
  transition: 0.5s;
}

a:hover img{
  opacity: 0.8;
}

/* change colours to suit your needs */
ins {
  background-color:#ff9;
  color:#000;
  text-decoration:none;
}

/* change colours to suit your needs */
mark {
  background-color:#ff9;
  color:#000; 
  font-style:italic;
   font-weight:bold;
}

del {
  text-decoration: line-through;
}

abbr[title], dfn[title] {
  border-bottom:1px dotted;
  cursor:help;
}

table {
  border-collapse:collapse;
  border-spacing:0;
}

*{
  box-sizing: border-box;
}

a{
  text-decoration: none;
}

/* change border colour to suit your needs */
hr {
  display:block;
  height:1px;
  border:0;   
  border-top:1px solid #cccccc;
  margin:1em 0;
  padding:0;
}

input, select {
  vertical-align:middle;
}

img{
	max-width: 100%;
}

.sp{
  display: none;
}

a{
  transition: 0.5s;
}

a:hover{
  opacity: 0.8;
}

.min,.min *{
  font-family: "Noto Serif JP", serif;
  font-optical-sizing: auto;
  font-weight: 400;
  font-style: normal;
}

.oz,.oz *{
  font-family: "kozuka-gothic-pr6n", sans-serif;
}

  #wraper{
    overflow-x:hidden;
  }

/* main */
        .header {
            padding: 0 20px;
        }



.logo{
  position: absolute;
  left: 90px;
  top:26px;
}

.content{
  width: calc(1350px * var(--odds));
  margin: auto;
  max-width: 90%;
}

        /* 基本スタイル */
.mainImageWrap{
  position: absolute;
  top:0;
  width: 100%;
  left: 0;
  aspect-ratio:1 / 0.589;
  height: auto;
  z-index: -1;
}

        .mainImage {
            position: relative;
            width: 100%;
            height: auto;
            margin: auto;
            overflow: hidden;
            cursor: pointer;
          aspect-ratio:1 / 0.589;
          
        }

        .mainCont {
            position: absolute;
            top: 0;
            left: 0;
            width: 100%;
            height: 100%;
            background-size: cover;
            background-position: center;
            transition: opacity 1s ease;
        }


.mainText{
  position: absolute;
  top:20px;
  right: 5%;
  z-index: 10;
}

.logo02{
  margin-bottom: 30px;
  position: relative;
}

.logo02:after{
  content:" ";
  width: 100%;
  height: auto;
  display: block;
  aspect-ratio:1 / 0.053;
  left: 0;
  bottom:0;
  background: url("../images/obj01.png");
  background-size: contain;
  background-repeat: no-repeat;
}


@media screen and (min-width:950px){
  .menuWrap:before{
    content:" ";
    width: 100vw;
    display: block;
    height: auto;
    aspect-ratio:1 / 0.54;
  }
  
  .menuWrap{
    text-align: center;
    width: calc(1350px * var(--odds));
    margin: auto;
    max-width: 90%;
    margin-top: 100px;
  }
  
  .menu{
    display: flex;
    justify-content: space-between;
    margin-bottom: 60px;
  }
  
  .menu a{
    color:var(--mainColor);
    text-decoration: none;
    font-size: calc(24px * var(--odds));
  }
  
}

  .bgSec{
    padding: 60px 0;
    background: #fffdf0;
  }
  
  .secTitle{
    text-align: center;
    font-size: calc(55px * var(--odds));
    font-weight: normal;
    color:var(--mainColor);
  }
  
  .secTitle span{
    display: inline-block;
    background: url("../images/titleObj.png");
    background-size: contain;
    background-repeat: no-repeat;
    background-position: center;
    width: calc(771px * var(--odds));
    height: auto;
    letter-spacing: 0.2em;
  }

  .topSec01Cont{
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 40px;
    margin-top: 60px;
    padding: 0 calc(50px * var(--odds))
  }
  
  .topSec01Cont .box01{
    width: 45%;
  }
  
  .topSec01Cont .box02{
    width: 50%;
  }
  
  .topSec01Cont .pt01{
    margin-bottom: 25px;
    color:var(--mainColor);
    font-size: calc(36px * var(--odds));
  }
  
  .topSec01Cont .pt02{
    font-size: calc(22px * var(--odds));
  } 

  .sec{
    padding: 50px 0;
  }
  
  .secTitle02{
    padding: 5px 0;
    background: linear-gradient(to left,#e2c686 0%,#c09035 50%,#e2c686 100% );
    font-size: calc(42px * var(--odds));
    text-align: center;
    color:#ffffff;
    letter-spacing: 0.2em;
    margin-bottom: 40px;
  }
  
  .secTitle03{
    text-align: center;
    color:var(--mainColor);
    letter-spacing: 0.2em;
    margin-bottom: 20px;
    font-size: calc(44px * var(--odds));
  }
  
  .secText01{
    text-align: center;
    font-size: calc(24px * var(--odds));
    color:var(--mainColor);
    margin-bottom: 20px;
    letter-spacing: 0.1em;
  }

  .topSec02Cont01{
    display: flex;
    justify-content: space-between;
    margin-bottom: 50px;
  }
  
  .topSec02Cont01 .box01{
    width: 45%;
  }
  
  .topSec02Cont01 .box02{
    width: 52%;
  }  
  
  .topSec02Cont01 .pt01{
    text-align: center;
    background: var(--mainColor02);
    padding: 3px 0;
    font-size: calc(36px * var(--odds));
    color:#ffffff;
    margin-bottom: 10px;
  }
  
  .topSec02Cont01 .pt02{
    padding: 10px;
    border-radius: 10px;
    margin-bottom: 10px;
    border:1px solid var(--mainColor02);
  }  
  
  .topSec02Ul{
    display: flex;
    flex-wrap: wrap;
  }
  
  .topSec02Ul li{
    width: 50%;
    line-height: 2.5em;
    font-size: calc(23px * var(--odds));
  }
  
  .topSec02Ul li:before{
    content:"■ ";
    color:var(--mainColor02);
  } 
  
  .topSec02Cont01 .pt03{
    font-size: calc(18px * var(--odds));
  }
  
  .topSec02Cont01 .pt03 span{
    font-size: calc(20px * var(--odds));
  }

  .topSec02Cont02{
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
    margin-top: 10px;
  }
  
  .topSec02Cont02 .box{
    width: calc((100% - 30px) / 2);
  }
  
  .topSec02Cont02 .pt01{
    margin-bottom: 10px;
  }  
  
  .topSec02Cont02 .pt02{
    margin-bottom: 25px;
    font-size: calc(20px * var(--odds));
    font-family: "kozuka-gothic-pr6n", sans-serif;
  } 

  .priceText{
    margin-bottom: 20px;
    text-align: center;
    font-size: calc(36px * var(--odds));
    letter-spacing: 0.2em;
  }
  
  .priceText .pt01{
    font-size: calc(84px * var(--odds));
  } 
  
  .priceText .pt02{
    font-size: calc(31px * var(--odds));
  } 
  
  .topSec03Table{
    width: 100%;
    border-bottom: 1px solid #c09035;
    letter-spacing: 0.2em;
  }
  
  .topSec03Table th{
    padding: 30px 0;
    text-align: center;
    vertical-align: middle;
    font-weight: normal;
    width: 300px;
    font-size: calc(24px * var(--odds));
    border-bottom: 1px dashed #000000;
  }
  
  .topSec03Table td{
    padding: 20px 0;
    font-weight: normal;
    width: calc(100% - 300px);
    font-size: calc(24px * var(--odds));
    border-bottom: 1px dashed #000000;
  }
  
  .topSec03Table td span{
    font-size: calc(20px * var(--odds));
  }
  
  .topSec03Table tr:last-child td,
  .topSec03Table tr:last-child th{
    border-bottom:none;
  }

  .topSec04Text{
    margin-top: 20px;
    font-size: calc(20px * var(--odds));
  }
  
  .topSec04Text span{
    font-size: calc(23px * var(--odds));
    font-weight: bold;
  }  

  .topSec04Cont{
    display: flex;
    justify-content: space-between;
  }
  
  .topSec04Cont .box{
    width: calc((100% - 30px) / 2);
    display: flex;
    flex-wrap: wrap;
  }
  
  .topSec04Cont .box .pt01{
    align-self: flex-start;
    padding-top: 10px;
    width: 100%;
    color:var(--mainColor);
    letter-spacing: 0.2em;
  }
  
  .topSec04Cont .box .text01{
    font-size: calc(40px * var(--odds));
    margin-bottom: 10px;
  }
  
  .topSec04Cont .box .text02{
    font-size: calc(27px * var(--odds));
  } 
  
  .topSec04Cont .box .pt02{
    letter-spacing: 0.1em;
    align-self: flex-end;
    width: 100%;
    font-size: calc(22px * var(--odds));
  }  

.footSec{
  background-image: url("../images/footBg.png");
  background-size: cover;
  background-position: top left;
  padding: 80px 0;
}
  
  .footSecCont{
    display: flex;
    justify-content: space-between;
  }
  
  .footSecCont .box{
    width:calc((100% - 40px) / 2);
  }

  .mainFoot{
    position: relative;
  }
  
  .footerCont{
    padding: 20px 0;
  }
  
  .pagetop{
    position: absolute;
    right: 5%;
    bottom:180px;
  }
  
  .footLogo{
    text-align: center;
  }
  
  .footNav{
    display: flex;
    justify-content: space-between;
    margin-top: 20px;
    margin-bottom: 20px;
  }

  .footNav a{
    color:#603813;
    letter-spacing: 0.1em;
    font-size: calc(24px * var(--odds));
  }

.copy{
  padding: 20px 5%;
  text-align: center;
  color:#ffffff;
  background: #aa8350;
  font-size: calc(16px * var(--odds));
}