/*
Theme Name: matsuoka
Author: you-plan
*/

@charset "UTF-8";

@import url('https://fonts.googleapis.com/css2?family=Kiwi+Maru:wght@400;500&display=swap');

/* reset */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}:where([hidden]:not([hidden='until-found'])){display:none!important}:where(html){-webkit-text-size-adjust:none;color-scheme:dark light;tab-size:2;scrollbar-gutter:stable}:where(html:has(dialog:modal[open])){overflow:clip}@media (prefers-reduced-motion:no-preference){:where(html:focus-within){scroll-behavior:smooth}}:where(body){line-height:1.5;font-family:system-ui,sans-serif;-webkit-font-smoothing:antialiased}:where(button){all:unset}:where(input,button,textarea,select){font:inherit;color:inherit}:where(textarea){resize:vertical;resize:block}:where(button,label,select,summary,[role='button'],[role='option']){cursor:pointer}:where(:disabled){cursor:not-allowed}:where(label:has(>input:disabled),label:has(+input:disabled)){cursor:not-allowed}:where(a){color:inherit;text-underline-offset:.2ex}:where(ul,ol){list-style:none}:where(img,svg,video,canvas,audio,iframe,embed,object){display:block}:where(img,picture,svg,video){max-inline-size:100%;block-size:auto}:where(p,h1,h2,h3,h4,h5,h6){overflow-wrap:break-word;font-weight:500}:where(h1,h2,h3){line-height:calc(1em + 0.5rem);text-wrap:balance}:where(hr){border:none;border-block-start:1px solid;color:inherit;block-size:0;overflow:visible}:where(dialog){border:none;background:none;inset:unset;max-width:unset;max-height:unset}:where(dialog:not([open])){display:none!important}:where(:focus-visible){outline:3px solid CanvasText;box-shadow:0 0 0 5px Canvas;outline-offset:1px}:where(:focus-visible,:target){scroll-margin-block:8vh}:where(.visually-hidden:not(:focus-within,:active)){clip-path:inset(50%)!important;height:1px!important;width:1px!important;overflow:hidden!important;position:absolute!important;white-space:nowrap!important;border:0!important}

/* --------------------
   COMMON
-------------------- */
a { transition: .25s all;}
:where(html) { color-scheme: #fff;}
html {
  scroll-behavior: smooth;
  font-size: 100%;
  overflow-x: hidden;}
body {
  overflow-x: hidden;
  margin: 0;
  padding: 0;
  background: #fff;
  font-family: "Kiwi Maru", sans-serif;
  font-optical-sizing: auto;
  font-weight: 500;
  font-style: normal;
  letter-spacing: 0.02rem;
  color: #292929;
  font-size: 100%;
  -webkit-font-smoothing: antialiased;}
a {
  color: #292929;
  text-decoration: none;}
img { max-width: 100%;}

@media screen and (max-width: 480px){
  body { letter-spacing: normal;}}

@media screen and (max-width: 1280px){
  body.active,html.active { overflow-y: hidden;}}

/* text */
p { font-size: 1rem; line-height: 1.8;}

.txs-14 { font-size: 0.875rem; }
.txs-16 { font-size: 1rem; }
.txs-18 { font-size: 1.125rem; }
.txs-20 { font-size: 1.25rem; }
.txs-22 { font-size: 1.375rem; }
.txs-24 { font-size: 1.5rem; }
.txs-28 { font-size: 1.75rem; }
.txs-32 { font-size: 2rem; }
.txs-36 { font-size: 2.25rem; }
.txs-44 { font-size: 2.75rem; }
.txs-48 { font-size: 3rem; }
.txs-64 { font-size: 4rem; }

.l-1 { line-height: 1;}
.l-15 { line-height: 1.5;}
.l-18 { line-height: 1.8;}

.w-r { font-weight: 400;}
.w-m { font-weight: 500;}

.center { text-align: center;}
.right { text-align: right;}
.left { text-align: left;}

.clor0 { color: #fff;}
.clor1 { color: #059EC9;}
.clor2 { color: #50C905;}

@media screen and (max-width: 768px){
  .txs-14 { font-size: 0.875rem;}
  .txs-16 { font-size: 1rem;}
  .txs-18 { font-size: 1.125rem;}
  .txs-20 { font-size: 1.125rem;}
  .txs-22 { font-size: 1.25rem;}
  .txs-24 { font-size: 1.375rem;}
  .txs-28 { font-size: 1.5rem;}
  .txs-32 { font-size: 1.75rem;}
  .txs-36 { font-size: 2rem;}
  .txs-44 { font-size: 2.25rem;}
  .txs-48 { font-size: 2.5rem;}
  .txs-64 { font-size: 2rem;}}

/* --------------------
   ALL
-------------------- */
.wrap {
  margin: 0 auto;
  max-width: 1280px;
  width: 100%;}
.contents {
  padding: 0 50px;
  position: relative;
  margin: 0 auto;
  width: 100%;}
.pc { display: block;}
.pd { display: none;}
.sp { display: none;}

@media screen and (max-width: 1280px){
  body { width: 100%; overflow: hidden;}}
@media screen and (max-width: 768px){
  .pc { display: none;}
  .pd { display: block;}
  .sp { display: none;}}
@media screen and (max-width: 480px){
	.contents { padding: 0 5vw;}
  .pc { display: none;}
  .pd { display: block;}
  .sp { display: block;}}

/* --------------------
   PARTS
-------------------- */
a.next {
  pointer-events:auto;
  display: inline-block;
  line-height: 60px;
  font-size: 18px;
  color: #fff;
  padding-left: 80px;
  position: relative;}
a.next.black { color: #292929;}
a.next::before {
  position: absolute;
  left: 0;
  top: 0;
  content: "";
  background: #fff;
  display: inline-block;
  width: 60px;
  height: 60px;
  border-radius: 30px;}
a.next::after {
  position: absolute;
  top: 0;
  left: 0;
  content: "";
  display: block;
  width: 60px;
  height: 60px;
  background: url("asset/images/common/arrow-right2.png") no-repeat center center;
  background-size: 22px auto;}
a.next.black::before {
  background: #292929;}
a.next.black::after {
  background: url("asset/images/common/arrow-right.png") no-repeat center center;
  background-size: 22px auto;}

@media screen and (max-width: 480px){
  a.next { padding-left: 35px;line-height: 30px;margin-top: 10px; font-size: 16px;}
  a.next::before { width: 30px;height: 30px;}
  a.next::after { width: 30px;height: 30px;background-size: 14px auto;}
  a.next.black::after { background-size: 14px auto;}}

/* --------------------
   HEADER
-------------------- */
#header {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  z-index: 2;
  padding-top: 40px;
  display: flex;
  justify-content: space-around;
  align-items: center;}
#header h1 {
  display: flex;
  align-items: center;
  gap: 9px;}
#header p { padding-top: 4px;}

/* -- hdnav -- */
@media screen and (min-width: 1281px){
#hdnav ul {
  display: flex;
  gap: 30px;}
#hdnav ul li:last-child a {
  padding: 6px 20px;
  border-radius: 20px;
  background: #fff;}
  .hamburger { display: none;}}

@media screen and (max-width: 1280px){
  .hamburger { display: none;}
  #header {
    padding-top: 30px;
    justify-content:flex-start;
    z-index: 4;}
  #header h1 { padding-left: 20px;}
  #hdnav {
    transition: 1s all;
    background: rgba(0,164,224,0.9);
    width: 100%;
    height: 100%;
    position: fixed;
    display: none;
    justify-content: center;
    align-items: center;
    top: 0;
    overflow: scroll;
    left: 0;}
  #hdnav.active {
    display: flex;
    opacity: 1;
    z-index: 98;
    -ms-filter: blur(0);
    filter: blur(0);}
  #header .hamburger {
    display : block;
    position: fixed;
    background: #EDF3F4;
    z-index : 99;
    right : 0;
    top   : 0;
    width : 100px;
    height: 100px;
    box-shadow: 0 0 10px 0 rgba(0,100,149,0.1);
    border-radius: 0 0 0 40px;
    cursor: pointer;
    text-align: center;}
  #header .hamburger span {
    display : block;
    position: absolute;
    width   : 40px;
    height  : 2px ;
    left    : 35px;
    background : #00A4E0;
    -webkit-transition: 0.3s ease-in-out;
    -moz-transition   : 0.3s ease-in-out;
    transition        : 0.3s ease-in-out;}
  #header .hamburger span:nth-child(1) { top: 40px;}
  #header .hamburger span:nth-child(2) { top: 50px;}
  #header .hamburger span:nth-child(3) { top: 60px;}
  #header .hamburger.active span:nth-child(1) {
    top : 50px;
    left: 35px;
    -webkit-transform: rotate(-45deg);
    -moz-transform   : rotate(-45deg);
    transform        : rotate(-45deg);}
  #header .hamburger.active span:nth-child(2) { opacity: 0;}
  #header .hamburger.active span:nth-child(3) {
    top: 50px;
    -webkit-transform: rotate(45deg);
    -moz-transform   : rotate(45deg);
    transform        : rotate(45deg);}
  #hdnav ul { padding: 20px;}
  #hdnav li { text-align: center;}
  #hdnav li a {
    line-height: 2.2em;
    font-size: 20px;
    font-weight: 700;
    color: #fff;
    text-decoration:none;}}

/* --------------------
   FOOTER
-------------------- */
#footer {
  position: relative;
  padding: 130px 0 0;
  background-color: #EFF9FB;
  background-image: url("asset/images/common/ft-back1.png"), url("asset/images/common/ft-back2.png");
  background-repeat: no-repeat, no-repeat;
  background-position: bottom right, bottom left;}
#footer .contents {
  padding-bottom: 200px;
  display: flex;
  justify-content: space-between;}
#ftnav {
  padding-right: 160px;
  gap:60px;
  display: flex;}
#ftnav li {
  margin-bottom: 8px;
  padding-left: 16px;
  position: relative;}
#ftnav li::before {
  position: absolute;
  top: 10px;
  left: 0;
  width: 6px;
  height: 6px;
  border-radius: 3px;
  background: #50C905;
  content: "";
  display: block;}

/* -- toplink -- */
#toplink {
  position: absolute;
  bottom: 180px;
  right: 110px;}
#toplink a {
  padding-top: 70px;
  position: relative;}
#toplink a::before {
  position: absolute;
  left: 0;
  top: 0;
  content: "";
  background: #292929;
  display: block;
  width: 60px;
  height: 60px;
  border-radius: 30px;}
#toplink a::after {
  position: absolute;
  top: 0;
  left: 0;
  content: "";
  display: block;
  transform: rotate(-90deg);
  width: 60px;
  height: 60px;
  background: url("asset/images/common/arrow-right.png") no-repeat center center;
  background-size: 22px auto;}

/* -- copy -- */
#copy {
  background: #292929;
  text-align: center;
  color: #fff;
  font-size: 14px;
  letter-spacing: 1px;
  height: 60px;
  line-height: 60px;}

@media screen and (max-width: 1280px){
  #footer { padding: 80px 0 0;}
  #footer .contents { gap: 20px; flex-wrap: wrap;}}
@media screen and (max-width: 768px){
  #toplink { bottom: 60px;right: 50%;margin-right: -30px;}
  #toplink a { text-align: center;width: 80px;}
  #toplink a::before,#toplink a::after { left: 10px;}
  #ftnav { padding: 0;}}
@media screen and (max-width: 480px){
  #footer { padding: 60px 0 0;}
  #toplink { bottom: 20px;}}