@charset "UTF-8";

@font-face {
    font-family: 'Exo';
    
    src: url('../font/Exo-SemiBold.woff') format('woff');
}

#fontplus-trial-banner {display: none;}

:root {
    --backgroundColor: #E5E3E3;
    --mainColor: #C79714;
    --textColor: #242424;
    --gray: #D8D8D8;
    --outer-height: 100vh;
    --pX: 8px;
}


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

html {font-size: 62.5%;}
html, body {
    width: 100vw;
    overflow-x: hidden;
    background-color: var(--backgroundColor);
}


/*font-family:  "Astro", 'TazuganeRegular', TazuganeGothicStdN-Regular, TazuganeGothicStdN-Medium, sans-serif;*/
div, h1, h2, h3, h4, h5, h6, p, a, span, button, textarea, input {
    font-family:  "Exo", 'Zen Kaku Gothic New', sans-serif;
    font-weight: 700;
    color: var(--textColor);
    font-display: swap;
    font-feature-settings: "palt";
    -webkit-font-smoothing: antialiased;
    letter-spacing: .075em;
}

:lang(en) {
    letter-spacing: .0125em;
    line-height: 1.4;
    /*-webkit-font-smoothing: auto;*/
}

.h0 {font-size: 3.6rem;}
h1, .h1 {font-size: 2.8rem;}
h2, .h2 {font-size: 2.4rem;}
h3, .h3 {font-size: 1.8rem;}
h4, .h4 {font-size: 1.6rem;}
h5, .h5 {font-size: 1.4rem;}
h6, .h6 {font-size: 1.2rem;}

p {
    /*font-family: "asty", TazuganeGothicStdN-Regular, sans-serif;*/
    font-family: "Exo", 'Zen Kaku Gothic New', sans-serif;
    font-weight: 500;
    line-height: 1.5625;
    font-size: 1.3rem;
    letter-spacing: 0.025em;
    letter-spacing: 0;
    text-align: justify;
    word-wrap: break-word;
    hyphens: auto;
    word-break: break-all;
}
.p {font-weight: 500;}
li {text-decoration: none;}
a {
    text-decoration: none;
    display: inline-block;
    transition: .75s ease-in-out;
}
a:hover {opacity: .85;}
img {width: 100%;object-fit: cover;}


.heading {
    /*font-family: TazuganeGothicStdN-Medium;*/
    font-family: TsukuOldGothicStd-B;
    -webkit-font-smoothing: auto;
    line-height: 1.8;
    letter-spacing: .0625em;
}
.semitrans {opacity: .7;}
.white {color: var(--bodyColor);}
.gray {color: var(--subColor);}

.flex {display: flex; justify-content: center; align-items: center;}

.wfull {width: 100%;}

.pc {display: none;}


@media screen and (min-width: 720px) {
    html {font-size: 55%;}
}

@media only screen and (min-width: 481px) and (max-width: 720px) {
    html {font-size: 50%;}
}
  
@media only screen and (min-device-width: 481px) and (max-device-width: 1024px) and (orientation:portrait) {
        /* For portrait layouts only */
}

@media screen and (min-width: 1280px) {
    html {font-size: 62.5%;}
    .h0 {font-size: 5.6rem;}
    h1, .h1 {font-size: 3.6rem;}
    h2, .h2 {font-size: 2.8rem;}
    h3, .h3 {font-size: 2.4rem;}
    h4, .h4 {font-size: 2.0rem;}
    h5, .h5 {font-size: 1.6rem;}
    h6, .h6 {font-size: 1.4rem;}
p, .p {
    font-size: 1.6rem;
    text-align: left;
}
.sp {display: none;}
.pc {display: block;}

}

