@charset "UTF-8";
/*font--------------------------------*/
/*---
Noto Sans JP
---*/
@font-face {
    font-family: "Noto Sans JP";
    font-weight: 400;
    src: local("Noto Sans JP Regular"), local("NotoSansJP-Regular"), url("../fonts/NotoSansJP-Regular.woff2") format("woff2");
    font-style: normal;
    font-display: swap;
}
@font-face {
    font-family: "Noto Sans JP";
    font-weight: 500;
    src: local("Noto Sans JP Medium"), local("NotoSansJP-Medium"), url("../fonts/NotoSansJP-Medium.woff2") format("woff2");
    font-style: normal;
    font-display: swap;
}
@font-face {
    font-family: "Noto Sans JP";
    font-weight: 600;
    src: local("Noto Sans JP SemiBold"), local("NotoSansJP-SemiBold"), url("../fonts/NotoSansJP-SemiBold.woff2") format("woff2");
    font-style: normal;
    font-display: swap;
}
@font-face {
    font-family: "Noto Sans JP";
    font-weight: 700;
    src: local("Noto Sans JP Bold"), local("NotoSansJP-Bold"), url("../fonts/NotoSansJP-Bold.woff2") format("woff2");
    font-style: normal;
    font-display: swap;
}
@font-face {
    font-family: "Noto Sans JP";
    font-weight: 900;
    src: local("Noto Sans JP Black"), local("NotoSansJP-Black"), url("../fonts/NotoSansJP-Black.woff2") format("woff2");
    font-style: normal;
    font-display: swap;
}
/*---
Poppins
---*/
@font-face {
    font-family: "Poppins";
    font-weight: 900;
    src: local("Poppins Bold Italic"), local("Poppins-BoldItalic"), url("../fonts/Poppins-BoldItalic.woff2") format("woff2");
    font-style: normal;
    font-display: swap;
}

/*=======================================
設定
=======================================*/
:root {
    interpolate-size: allow-keywords;
    /*container  =============================*/
    /*container size*/
    --container-max: 1366px;
    /*左右padding*/
    --container-pd: clamp(16px, 80vw/13.66, 80px);
    /*上padding*/
    --section-top: clamp(24px, 110vw/13.66, 110px);
    /*下padding*/
    --section-bottom: clamp(24px, 120vw/13.66, 120px);
    /*header height(js)*/
    --header-h: 76px;
    /*font  =============================*/
    --font-ja: "Noto Sans JP";
    --font-ja-weight: 400;
    --font-en: "Poppins", sans-serif;
    --font-en-weight: 700;
    --font-base: clamp(1.5rem, 18vw/13.66, 1.8rem);
    --font-s: clamp(1.2rem, 14vw/13.66, 1.4rem);
    --font-l: clamp(1.6rem, 18vw/13.66, 1.8rem);

    /*color  =============================*/
    /*site color ---------*/
    --maincolor: #00bad5;
    --subcolor: #f39700;
    --accentcolor: #f8da00;
    --maincolor-dark: #0096ac;
    /*text color ---------*/
    --base-tx-color: #000;
    --light-tx-color: #fff;
    --error-color: #c43d33;
    /*基本色 ------*/
    --white: #fff;
    --black: #000;
    --gray: #666;
    --light-gray: #f8f8f8;
    /*線 ------*/
    --border-color: #c0c0c0;
    /*背景色 ------*/
    --bg-white: #fff;
    --bg-color01: #def5f9;
    --bg-color02: #f8f8f8;
    /*a ------*/
    --a-tx: #49aad7;
    --a-hover: color-mix(in srgb, var(--a-tx), var(--white) 40%);
    --a-visited: color-mix(in srgb, var(--a-tx), var(--black) 20%);

    /*other =============================*/
    --base-radius: 3px;
    --inner-radius: 8px;
    --btn-radius:100vmax;

    /*z-index =============================*/
    --pagetop-z: 997;
    --toggle-z: 1000;
    --nav-z: 999;
    --header-z: 998;
}

/*reset--------------------------------*/
* {
    box-sizing: border-box;
}
body,
div,
pre,
p,
blockquote,
form,
fieldset,
input,
textarea,
select,
option,
dl,
dt,
dd,
ul,
ol,
li,
h1,
h2,
h3,
h4,
h5,
h6,
table,
th,
td,
tr,
embed,
object,
a,
img,
figure,
figcaption {
    margin: 0;
    padding: 0;
    vertical-align: baseline;
}
/*font*/
h1,
h2,
h3,
h4,
h5,
h6,
p,
em {
    font-style: normal;
    font-weight: normal;
}
/*others*/
table {
    border-spacing: 0;
}
* html table {
    border-collapse: collapse;
}
*:first-child + html table {
    border-collapse: collapse;
}
th,
td {
    vertical-align: middle;
    border-collapse: collapse;
}
table,
th,
td,
tr,
img {
    border: 0;
}
img {
    vertical-align: bottom;
}
q:before,
q:after {
    content: "";
}
ul {
    list-style: none;
}

/*base--------------------------------*/
html {
    height: 100%;
    font: 62.5%/1.7 "メイリオ", Meiryo, "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN W3", sans-serif; /*メイリオベース*/
    /*font: 62.5%/1.7 "Yu Gothic Medium", "Yu Gothic", "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN W3", sans-serif;*/ /*游ゴシックベース*/
    /*font: 62.5%/1.7 "Yu Mincho Medium", "Yu Mincho", "Hiragino Mincho ProN", "ヒラギノ明朝 ProN W3", serif;*/ /*游明朝ベース*/
}
/*body*/
body {
    height: 100%;
    text-align: center;
    word-break: break-all;
    background-color: #fff;
    font-family: var(--font-ja);
    font-weight: var(--font-ja-weight);
    font-size: var(--font-base);
    color: var(--base-tx-color);
    /*font-feature-settings: "palt";
    -webkit-text-size-adjust: 100%;*/
    overflow-x: hidden;
}

/*link*/
a {
    color: var(--a-tx);
    text-decoration: underline;
}
a img {
    border-style: none;
}
a:visited {
    color: var(--a-visited);
}
a:hover {
    color: var(--a-hover);
}

/*font size*/
h1,
h2,
h3,
h4,
h5,
p {
    font-size: var(--font-base);
}
li,
dt,
dd {
    font-size: var(--font-base);
}
table {
    font-size: var(--font-base);
}

/*other*/
figure {
    padding: 0;
    margin: 0;
}
svg:where(:not([fill])) {
    fill: currentColor;
}
