/*
Theme Name:cpstyle
Author: yasukun
Theme URI: https://twheel.co.jp/
Description: twheel Corp用のワードプレステーマ
Version: 1.0
Text Domain: cpstyle
Tags:cpstyle yasukun
*/
/*License: Copyright 2025 twheel Corp.*/

/*-------------cpstyle-base.css----------------*/
@charset "UTF-8";
/*-------------------------------------------------------
メニュー設定
-------------------------------------------------------*/
/* メニュー黒ポチを消す */
.nav_list {
  list-style: none;
}
li.menu a:hover {
    background: none;
    border-radius: 10px;
    color: #1F4FA1 !important;
}
/*----------------------------------
ヘッダーナビゲーション設定
----------------------------------*/
#mainmenu{
    background:rgba(245,245,245,0.8);
    min-height: 56px;
    box-shadow: 0px 0px 10px #ccc;
}

#logo{
    position: relative;
    z-index: 9;
}
ul.menu > li{
        position: relative;
        display: flex;
    justify-content: center;
}
li.menu{
        list-style-type:none;
        text-align: center;
}
#mainmenu {
    position: absolute;
    top: 0;
    left: 0;
    z-index:1;
    width: 100%;
}
li.menu a{
    padding:5px 10px;
}
#mainmenu li.menu a {
    color: #333;
    font-size:0.9rem;
    text-shadow: 1px 1px 1px #FFF;
    text-decoration: none;
}
#mainmenu li.menu a:hover {
    background: none;
    border-radius: 10px;
    color: #1F4FA1 !important;
}
@media (min-width: 768px){
    .accord  ul.menu ul.sub-menu{
        display: none;
        top: 36px;
        position: absolute;
        background:#FFF;
        padding:0 5px;
        width: fit-content;
        margin-left: calc(-50px);
        margin-right: calc(-50px);
    }
    .accord  ul.menu ul.sub-menu:hover{
            display:flex;
        flex-wrap:wrap;
        justify-content:center; 
    }
    .accord  ul.menu ul.sub-menu li{
        position: relative;
        display:flex;
        flex-wrap:wrap;
        justify-content:center; 
    }
    #mainmenu ul.menu {
        display: flex;
        flex-wrap:wrap;
        justify-content: flex-end;
        padding: 0 20px;
        margin:10px auto;
    }
    #menu-main ul.menu ul.sub-menu{
    padding-inline-start: 0px;
    width: 100%;
    }
}
/*--------スマホメニュー表示部分---------*/
@media only screen and (max-width: 767px){
#menu-main,
#mainmenu > div > ul.menu{
    width: 100%;
    color: #FFF;
    padding: 1rem 0px;
    margin: 60px auto auto;
    font-size:1.2rem;
}
#menu-main > li,
#mainmenu > div > ul.menu > li{
	padding:20px;
	margin:5px auto;
	background:rgba(255,255,255,0.1);
}
#menu-main ul.menu > li,
#mainmenu > div > ul.menu > li{
        display: block;
}
#mainmenu li.menu a {
    color: #ffe;
    text-shadow: 1px 1px 1px #333;
    text-decoration: none;
    padding:5px;
}
#menu-main > li.menu > a,
#mainmenu > div > ul.menu > li.menu > a{
 color:#fff;
}
#mainmenu ul.sub-menu{
	padding:0;
	font-size:90%;
}
/* アイコンがクリックされたらメニューを表示 */
#wrapper:has(#Smenu-button:checked) #mainmenu > div,
#mainmenu:has(#Smenu-button:checked) .menu-main-container {
       left: 0;/* メニューを画面に入れる */
    }
/*-メニューボタンに文字を入れる場合---*/
    #Smenu-wrapper p {
    position: absolute;
    top: 0;
    padding: 0;
    margin: 0;
    width: 100%;
    text-align: center;
    font-size: 12px;
    height: 100%;
    /* align-self: end; */
    vertical-align: text-bottom;
    display: inline;
    line-height: 56px;
	}
}
/*-------------------スマホメニューCSS-----------------------*/
/* スマホメニュー及びチェックボックスを非表示にする */
.button_hidden,
#Smenu-wrapper {
  display: none;
}
@media only screen and (max-width: 767px){
/* メニューのデザイン*/
#mainmenu > div,
.menu-main-container {
  width: 100%;
  height: 100%;
  position: fixed;
  top: 0;
  left: 100%; /* メニューを画面の外に飛ばす */
  z-index: 99;
  background:rgba(0, 0, 0, 0.7);
  transition: .5s;
}
#mainmenu #Smenu-wrapper{
    display: block;
        position: absolute!important;
        height: 56px;
        width: 56px;
        top: 0!important;
        right: 0!important;
        left: auto!important;
        background: none!important;
}
/* スマホメニューを表示 */
	#Smenu-wrapper {
  display: block;
  position: absolute;
  height: 56px;
  width: 56px;
  top: 0;
  right: 0;
}
/* ハンバーガーアイコンの設置スペース */
.Smenu-open {
  display: flex;
  justify-content: center;
  align-items: center;
  position: relative;
  z-index: 100;/* 重なり順を一番上にする */
  width: 100%;
  height: 100%;
  cursor: pointer;
}

/* ハンバーガーメニューのアイコン */
span.menubar1,
span.menubar2,
span.menubar3 {
  content: '';
  display: block;
  height: 3px;
  width: 40px;
  border-radius: 3px;
  background: #333;
  transition: 0.5s;
  position: absolute;
}

/* 三本線の一番上の棒の位置調整 */
span.menubar1 {
  margin-bottom: 22px;
}

/* 三本線の一番下の棒の位置調整 */
span.menubar3  {
  margin-top: 22px;
}
/*アイコンがクリックされたらロゴ文字を白くする　＃ｈｅａｄｅｒ基準 */
#header:has(#Smenu-button:checked) .logo-words a{
    color: #FFF;
 }
/* アイコンがクリックされたら真ん中の線を透明にする */
#mainmenu:has(#Smenu-button:checked) span.menubar2 {
  background: rgba(255, 255, 255, 0);
}

/* アイコンがクリックされたらアイコンが×印になように上下の線を回転 */
#mainmenu:has(#Smenu-button:checked) span.menubar1{
  margin-bottom: 0;
  transform: rotate(45deg);
    background:#FFF;
}

#mainmenu:has(#Smenu-button:checked) span.menubar3 {
  margin-top: 0;
  transform: rotate(-45deg);
  background:#FFF;
}
}
/*------------------------------------------------------------------------------------
フッターメニュー
-----------------------------------------------------*/
#footermenu  {
    position: relative;
    top: 0;
    left: 0;
    z-index:0;
    background:#eee;
    min-height: 56px;
}
#footermenu ul.menu {
        display: flex;
        flex-wrap:wrap;
        justify-content:flex-start;
}
#footermenu ul.menu > li{
        position: relative;
        padding:6px 10px;
        display:block;
}
#footermenu ul.menu > li > a{
    padding:3px 5px;
    display: block;
    border-bottom: solid 1px #666;
    margin-bottom: 5px;
}
#footermenu li.menu{
        list-style-type:none;
        text-align: left;
}
#footermenu li.menu a{
    padding:5px 10px;
}
#footermenu  li.menu a {
    color: #333;
    text-decoration: none;
}
#footermenu ul.menu .sub-menu{
        font-size: 0.8em;
}
@media (min-width: 768px){
    #footermenu{
        display: flex;
        flex-wrap:wrap;
        justify-content:flex-start;
        align-items:flex-end;
        font-size: 92%;
    }
    #footermenu ul.menu {
        display: flex;
        flex-wrap:wrap;
        justify-content:flex-start;
    }
    #footermenu  ul.menu {
        display: flex;
        flex-wrap:wrap;
        justify-content: flex-end;
        padding: 0 20px;
    }
    #footermenu ul.menu ul.sub-menu{
    padding-inline-start: 0px;
    }
}
@media only screen and (max-width: 767px){
    #footermenu  ul.menu {
    padding: 0;    
}
#footermenu ,
#footermenu ul.menu > li {
    width:100%;
}
    #footermenu li.menu a {
        color: #333;
        text-decoration: none;
        text-align: center;
        background: #ddd;
        border-bottom: solid 1px #ccc !important;
        margin-bottom: 0px !important;
}
#footermenu ul.menu .sub-menu{
    font-size: 0.9em;
    padding-left: 10px;
}
}