@charset "utf-8";
/*
Theme Name: TYPE-A
Theme URI: http://
Description: 専用テーマです。ご不明な点は作成者までご連絡ください。
Author: EMALICA
Author URI: http://www.emalica.com/
Version: 1.0
*/
article,aside,details,figcaption,figure,footer,header,hgroup,hr,menu,nav,section{display:block}a,hr{padding:0}abbr,address,article,aside,audio,b,blockquote,body,canvas,caption,cite,code,dd,del,details,dfn,div,dl,dt,em,fieldset,figcaption,figure,footer,form,h1,h2,h3,h4,h5,h6,header,hgroup,html,i,iframe,img,ins,kbd,label,legend,li,mark,menu,nav,object,ol,p,pre,q,samp,section,small,span,strong,sub,summary,sup,table,tbody,td,tfoot,th,thead,time,tr,ul,var,video{margin:0;padding:0;border:0;outline:0;font-size:100%;vertical-align:baseline;background:0 0;font-weight:300}ins,mark{background-color:#ff9;color:#000}body{line-height:1}nav ul{list-style:none}blockquote,q{quotes:none}blockquote:after,blockquote:before,q:after,q:before{content:'';content:none}a{margin:0;font-size:100%;vertical-align:baseline;background:0 0}ins{text-decoration:none}mark{font-style:italic;font-weight:500}del{text-decoration:line-through}abbr[title],dfn[title]{border-bottom:1px dotted;cursor:help}table{border-collapse:collapse;border-spacing:0}hr{height:1px;border:0;border-top:1px solid #ccc;margin:1em 0}input,select{vertical-align:middle}img.bgmaximage{position:fixed!important}
.material-symbols-outlined {
    font-variation-settings:
    'FILL' 0,
    'wght' 100,
    'GRAD' 0,
    'opsz' 48
}
/* 共通
*************************************************/
html {
    width: 100%;
    min-height: 100%;
    margin: 0;
    padding: 0;
    -webkit-overflow-scrolling: touch;
    font-size: 62.5%;
    font-display: swap;
    height: -webkit-fill-available;
    font-family: 'Noto Sans JP', sans-serif;
    background-color: #ffffff;
    color: #082d3f;
}
body {
    width: 100%;
    font-size: 1.6rem;
    line-height: 1.5;
    margin: 0;
    padding: 0;
    background-color: #ffffff;
    color: #082d3f;
    -webkit-text-size-adjust: 100%;
    min-height: 100vh;
    min-height: -webkit-fill-available;
}
h1, h2, h3, h4, h5 {
    line-height: 1.5;
    font-weight: bold;
    margin-bottom: .5em;
}
h1 {
    font-size: clamp(3.2rem, 5.625vw, 4.5rem);
}
h2 {
    font-size: clamp(2.4rem, 4vw, 3.2rem);
}
h3 {
    font-size: clamp(2rem, 3vw, 2.4rem);
}
h4 {
    font-size: clamp(1.6rem, 2.5vw, 2rem);
}
h5 {
    font-size: 1.6rem;
}
p { margin: 1em 0; }
p:first-child {
    margin: 0;
}
strong {
    color: #c1272d;
}
del {
    text-decoration: line-through 2px solid #E0465A;
}
img {
    vertical-align: bottom;
    max-width: 100%;
    height: auto;
    line-height: 0;
    object-fit: contain;
}
table {
    width: 100%;
    margin-bottom: 1em;
    text-align: left;
    border-collapse: collapse;
    & th, td {
        padding: .5em;
        border: 1px solid #ccc;
        width: auto !important;
    }
}
ul, ol {
    margin: 0 0 1em 2em;
}
.table-scroll {
    overflow: scroll;
    position: relative;
    & table {
        width: calc( 768px - 64px );
    }
}
a:link, a:visited {
    transition: .2s;
    color: #000;
}
a:hover {}
img.alignleft,
img.alignright {
    margin: 0 0 1em 0;
}
video {
    vertical-align: bottom;
    max-width: 640px;
    margin: 0 auto;
}
@media(min-width: 768px) {
    img.alignleft {
        width: calc(50% - 16px);
        float: left;
        margin: 0 16px 16px 0;
    }
    img.alignright {
        width: calc(50% - 16px);
        float: right;
        margin: 0 0 16px 16px;
    }
}
.link {
    text-align: center;
}
.link a {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 44px;
    border: 3px double #a4752d;
    text-decoration: none;
    padding: 0 1em;
    width: 50%;
    max-width: 414px;
    transition: .2s;
}
.link a:hover {
    background-color: #a4752d;
    color: #fff;
}
.title-border {
	display: flex;
	align-items: center;
	color: #fa0000;
}
.title-border:before,
.title-border:after {
	border-top: 1px dashed #666;
	content: "";
	flex-grow: 1;
}
.title-border:before {
	margin-right: 1rem;
}
.title-border:after {
	margin-left: 1rem;
}
/* レイアウト
***************************************************/
.row,
.col,
.cols-1,
.cols-2,
.cols-3 {
    box-sizing: border-box;
    margin: 0;
    padding: 0;
    width: 100%;
}
.wrapper {
    margin: 0;
    padding: 0;
    min-height: 100%;
    height: 100%;
    width: 100%;
    position: relative;
}
.container {
    box-sizing: border-box;
    min-height: 100vh;
    margin: 0;
    padding: 0;
    overflow: hidden;
}
.row {
    padding: 32px 16px;
}
.col {}
@media(min-width: 768px) {
    .wrapper {}
    .row {
        padding-top: 64px;
        padding-right: calc( ( 100% - 768px - 32px ) / 2 );
        padding-bottom: 64px;
        padding-left: calc( ( 100% - 768px - 32px ) / 2 );
    }
    .col {
        padding: 32px;
    }
    .cols-1 {
        & .col {
            padding: 8px 32px;
        }
    }
    .cols-2,
    .cols-3 {
        display: flex;
        flex-wrap: wrap;
        justify-content: space-between;
    }
    .cols-2 > .col,
    .cols-3 > .col {
        width: calc( 50% - 0px );
    }
    .container {
        height: 100%;
        width: 100%;
    }
}
/* エラーページ
***************************************************/
#error404 {
    text-align: center;
    min-height: calc( 100vh - 48px );
}
@media(min-width: 768px) {
    #eroor-404 {
        min-height: calc( 100vh - 72px );
    }
}
/* YouTube
***************************************************/
.embed-responsive {
    position: relative;
    width: 100%;
    padding-top: 56.25%;
}
.embed-responsive iframe{
    position: absolute;
    top: 0;
    right: 0;
    width: 100% !important;
    height: 100% !important;
}
/* Googleマップ
***************************************************/
.google-map {
    box-sizing: border-box;
    position: relative;
    width: 100%;
    height: 0;
    padding-bottom: 100vw;
    overflow: hidden;
    border: 1px solid #333333;
    margin: 1em 0;
}
.google-map iframe {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    pointer-events: none;
}
@media(min-width: 768px) {
    .google-map {
        padding-bottom: calc( 100vmin * .58 );
    }
}
/* グローバルヘッダー
***************************************************/
/* グローバルヘッダー：レイアウト
***************************************************/
#global-header {
    text-align: center;
    background-color: #082d3f;
    color: #fff;
}
#global-header #logo {
    flex-grow: 0;
    margin-right: auto;
    display: flex;
    align-items: center;
    box-sizing: border-box;
    height: 48px;
    width: auto;
    padding: 0 16px;
}
#global-header #logo img {
    object-fit: contain;
    height: 32px;
}
#global-header #btn-list {
    list-style: none;
    display: flex;
    margin: 0;
    width: auto;
    position: absolute;
    top: 0;
    right: 0;
}
#global-header #btn-list li {
    margin: 0;
    padding: 0;
    min-width: 48px;
    line-height: 0;
}
#global-header #btn-list li span,
#global-header #btn-list li a {
    display: flex;
    align-items: center;
    justify-content: center;
    color: #082d3f;
    text-decoration: none;
    cursor: pointer;
    padding: 0;
    margin: 0;
    height: 48px;
    min-width: 48px;
    font-size: 2rem;
    box-sizing: border-box;
}
#global-header #btn-list li span {
	font-size: 32px;
}
/* グローバルナビ
***************************************************/
#global-nav {
    display: none;
}
@media(min-width: 1024px) {
    #global-nav {
    box-sizing: border-box;
    display: block;
    margin: 0 16px;
    padding: 0;
    }
    #global-nav ul {
    display: flex;
    margin: 0;
    padding: 0;
    }
    #global-nav ul li {
    margin: 0;
    padding: 0;
    position: relative;
    }
    #global-nav ul li a {
    display: flex;
    height: 64px;
    align-items: center;
    text-decoration: none;
    padding: 0 16px;
    position: relative;
    color: rgba(68,65,64,1);
    }
    #global-nav ul li a:hover {
    color: rgba(68,65,64,.8);
    }
    #global-nav ul li a::after {
    position: absolute;
    left: 0;
    bottom: 0px;
    display: block;
    content: "";
    height: 1px;
    background-color: #259999;
    transition: .5s;
    width: 0;
    }
    #global-nav ul li.current-menu-item a,
    #global-nav ul li.current-post-ancestor a {
    color: #259999;
    }
    #global-nav ul li a:hover::after {
    width: 100%;
    }
    #global-nav ul li.current-menu-item a:hover::after,
    #global-nav ul li.current-post-ancestor a:hover::after {
    width: 0;
    }
    #global-nav ul.sub-menu {
    position: absolute;
    background-color: rgba(68,65,64,1);
    transition: all .5s ease;
    top: 72px;
    width: auto;
    display: block;
    visibility: hidden;
    opacity: 0;
    }
    #global-nav ul li a:hover ul.sub-menu {
    visibility: visible;
    }
    }
.mm-listitem .mm-listitem__text {
    color: #fff;
}
/* お問い合わせ
***************************************************/
#contact {
    position: fixed;
    left: 0;
    bottom: 0;
    z-index: 999;
    background-color: #fcf4f2;
}
#contact .col {
  padding: 16px;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 8px;
}
#contact img.logo {
  width: 128px;
}
#contact p {
  font-size: 1.4rem;
}
#contact a {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 48px;
}
#contact a img {
  height: 48px;
  object-fit: contain;
}
#contact ul {
  list-style: none;
  margin: 0;
  padding: 0;
}
#contact ul li a img {}
#contact ul li a img {}
#contact ul li a img {
    height: 48px;
    width: 48px;
}
/* グローバルフッター
***************************************************/
#global-footer {
    position: relative;
    background-color: #082d3f;
    color: #fff;
    margin-top: 32px;
}
#global-footer .col {
}
#global-footer #copyright {
    font-size: 1.2rem;
    text-align: center;
    margin: 32px 0 80px 0;
}
/* フッターナビ
***************************************************/
#footer-nav {
    font-size: 1.2rem;
}
#footer-nav ul {
    margin: 0;
}
#footer-nav > ul:last-child {
    border-bottom: 1px solid rgba(255,255,255,.3);
}
#footer-nav ul li {
    margin: 0;
}
#footer-nav ul li a {
    position: relative;
    box-sizing: border-box;
    text-decoration: none;
    color: #fff;
    display: flex;
    align-items: center;
    min-height: 40px;
    padding: 0 8px 0 32px;
    background-color: rgba(0,0,0,0);
    border-top: 1px solid rgba(255,255,255,.3);
}
#footer-nav .sub-menu {
    display: flex;
    flex-wrap: wrap;
}
#footer-nav .sub-menu li {
    width: 50%;
    flex-grow: 1;
}
#footer-nav .sub-menu a {
    color: #fff;
    background-color: rgba(0,0,0,0);
}
#footer-nav a::before {
    position: absolute;
    top: 0;
    left: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    font-family: "Material Symbols Outlined";
    content: "keyboard_arrow_right";
    width: 32px;
}
#footer-nav .sub-menu a::before {
    content: "remove";
}
#footer-nav a::before {
    height: 100%;
}
@media( min-width: 1024px ) {
    #footer-nav ul {
        display: flex;
        justify-content: flex-start;
        flex-wrap: wrap;
        width: 100%;
        margin: 0;
    }
    #footer-nav ul:last-child {
		border: none;
    }
    #footer-nav ul li:first-child {
        width: 100%;
    }
    #footer-nav ul li a {
        min-height: 32px;
        background-color: rgba(0,0,0,0);
        border-top: 1px solid rgba(0,0,0,.0);
    }
    #footer-nav ul li a:hover {
        text-decoration: underline;
    }
    #footer-nav ul li ul {
        flex-direction: column;
        margin: 0;
    }
    #footer-nav ul li ul li {
        float: none;
    }
    #footer-nav .sub-menu li {
        width: 100%;
    }
}
/* イントロ
***************************************************/
#intro {
    box-sizing: border-box;
	display: block;
    & .col {
        position: relative;
        padding: 0;
        & header {
            & h1 {
                margin: 0;
            }
            & .title {
                display: flex;
                flex-direction: column;
                align-items: center;
                justify-content: center;
                height: 100%;
                width: 100%;
                box-sizing: border-box;
                text-shadow: 0 0 5px rgba(255,255,255,1);
                & span {
                    display: block;
                    font-size: 1.2rem;
                }
            }
            & #txt-title {
                & .subtitle {
                    font-size: 1.4rem;
                    color: #259999;
                }
            }
            & #img-title {
                justify-content: center;
                    & img {
                    width: 100%;
                    margin: 0;
                    padding: 0;
                }
            }
        }
        & ul.bg-images {
            box-sizing: border-box;
            list-style: none;
            margin: 0;
            padding: 0;
            & li {
                display: block;
                width: 100%;
                display: flex;
                align-items: center;
                & img {
                	object-fit: cover;
                }
            }
        }
    }
}
#home {
    & #intro {
        padding: 16px;
        & .col {
            & header {
                & img {
                    max-width: 320px;
                }
            }
        }
    }
}
#overview .col {
    margin: 0 auto;
    padding-top: calc( 32px - 2.1em );
    font-size: clamp(2rem, 3vw, 2.4rem);
}
#overview p {}
@media (min-width: 768px) {}
/* コンテンツ
***************************************************/
.contents {
    margin: 0;
    padding: 0;
	z-index: 99;
    & h2 {
        & em {
            font-weight: normal;
            font-size: 1.6rem;
            font-style: normal;
            display: block
        }
    }
    & h2::before, h2::after {
        display: inline-block;
        font-family: "Material Symbols Outlined";
        align-items: center;
        vertical-align: bottom;
        color: #910000;
    }
    & h2::before {
        content: "";
        background-image: url('https://dendenmushi.ms-t-op.com/cms2023/wp-content/uploads/2023/12/ddm-thumbup.jpg');
        background-size: contain;
        background-repeat: no-repeat;
        background-position: center;
        height: 48px;
        width: 48px;
        margin-right: 0;
    }
    & h3 {}
    & h3:first-child {
        margin-top: 0;
    }
    & h4 {}
    & img {
        box-sizing: border-box;
    }
    & header, footer {
        padding-top: 0;
        padding-bottom: 0;
    }
    & .withbg .cols-1 {
        background-color: rgba( 255,255,255,.75 );
        border-radius: 10px;
        padding: 16px;
    }
}
@media( min-width: 768px ) {
    .contents .cols-2,
    .contents .cols-3,
    .contents .cols-4 {
        display: flex;
        flex-wrap: wrap;
    }
    .contents .cols-2 .col {
        justify-content: center;
    }
    .contents .cols-3 .col {
    }
    .contents .cols-2 .col {
        width: calc( 100% / 2 - 16px );
        margin: 8px;
    }
    .contents .cols-3 .col {
        width: calc( 100% / 3 - 16px );
        margin: 8px;
    }
    .contents .cols-4 .col {
        width: calc( 100% / 4 - 16px );
    }
    .contents .withbg .cols-1 {
        padding: 16px 0;
    }
}
/* コンテンツ：ページリンク
***************************************************/
.contents .page-link ul {
  display: flex;
  flex-wrap: wrap;
  list-style: none;
  gap: 32px;
  margin: 0;
  padding: 0;
}
.contents .page-link ul li {
  width: 100%;
}
.contents .page-link ul li a {
  box-sizing: border-box;
  padding: 32px;
  display: flex;
  align-items: center;
  justify-content: center;
  height: 128px;
  width: 100%;
  border: 1px solid #ccc;
  text-decoration: none;
  background-color: #fff;
}
@media(min-width: 768px) {
  .contents .page-link ul li {
    width: calc( 100% / 2 - 16px );
  }
  .contents .page-link ul li a:hover {
    border: 1px solid #fff;
    box-shadow: 4px 4px 0 #333;
  }
}
/* コンテンツ：パーツ類
***************************************************/
.contents table {
    background-color: #fff;
}
.contents table thead {
    background-color: #0198b5;
    color: #fff;
    text-align: center;
    font-weight: bold;
}
.contents table tbody tr:nth-of-type(even) {
    background-color: #f2f2f2;
}
/* LINE
***************************************************/
.contents {
    & .line-contact {
        text-align: center;
    }
}
/* フォーム
***************************************************/
form {
	width: 100%;
	margin: 0 auto;
}
form dl {}
form dl dt {
  padding: 1em 0 0 0;
}
form dl dd {
  padding: .5em 0 2em 0;
  display: flex;
  flex-wrap: wrap;
}
form dl dt.required::after {
  content: "※";
  color: #910000;
  font-weight: normal;
  margin-left: .5em;
}
form dd p.note {
  color: #144961;
  font-size: 1.2rem;
}
input[type=radio],
input[type=checkbox] {
  appearance: none;
  display: none;
  float: none;
}
input[type=radio] + span:before,
input[type=checkbox] + span:before {
  font-family: "Material Symbols Outlined";
  display: inline-flex;
  margin: 0;
  padding: 0;
  margin-right: .25em;
  font-size: 2rem;
  color: #999;
}
input[type=radio]:checked + span:before,
input[type=checkbox]:checked + span:before {
  color: #910000;
}
input[type=radio] + span:before {
  content: 'radio_button_unchecked';
}
input[type=radio]:checked + span:before {
  content: "radio_button_checked";
}
input[type=checkbox] + span:before {
  content: 'check_box_outline_blank';
}
input[type=checkbox]:checked + span:before {
  content: "select_check_box";
}
.mw_wp_form .mwform-radio-field,
.mw_wp_form .mwform-checkbox-field {
  margin-right: 3em;
}
.mw_wp_form .mwform-radio-field-text,
.mw_wp_form .mwform-checkbox-field-text {
  display: flex;
  align-items: center;
}
.mw_wp_form .horizontal-item{
    display: block;
    margin-left:0 !important;
    margin-bottom:0.5em;
}
input[type=text],
input[type=number],
input[type=email],
input[type=url],
input[type=submit],
select,
button,
textarea,
submit {
  margin: 0;
  padding: 0;
  background: none;
  border: none;
  border-radius: 0;
  outline: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  box-sizing: border-box;
  font-size: 1.4rem;
}
input[type=text],
input[type=number],
input[type=email],
input[type=url],
textarea,
select {
  background-color: #f7f7f7;
  border: 1px solid #fff;
  border-bottom: 1px solid #999;
  padding: 1em;
  width: 100%;
}
select#pref {
  width: 8em;
}
input[type=text].date {
  width: 12em;
}
textarea {
  height: 10em;
}
input[type=text]:focus,
input[type=number]:focus,
input[type=email]:focus,
input[type=url]:focus,
select:focus,
textarea:focus {
  background-color: #fff;
  border: 1px solid #910000;
}
form input[type=submit] {
	font-size: 1.6rem;
	padding: 1em 2em;
	display: block;
	margin: 32px auto;
	cursor: pointer;
	border-radius: 4px;
	border: none;
	transition: .2s;
	background-color: #E06D46;
	color: #fff;
	box-shadow: 2px 2px 4px rgba(0,0,0,.5);
	white-space: normal;
	line-height: 1.5;
}
form input[type=submit]:hover {
	background-color: #910000;
}
form input[type=number]#age {
    width: 6em;
}
form label {
	cursor: pointer;
}
.ui-datepicker-week-end:first-child {
    color: #f00;
}
.ui-datepicker-week-end:last-child {
    color: #00f;
}
form ::placeholder {
    color: #ccc;
}
form .name input {
	width: 49%;
}
form .zip input:nth-of-type(1) {
	width: 3em;
	margin: 0 .2em;
	display: inline;
}
form .zip input:nth-of-type(2) {
	width: 4em;
	margin: 0 0 0 .2em;
}
form .tel input:nth-of-type(1) {
	width: 5em;
	margin: 0 .2em 0 0;
	display: inline;
}
form .tel input:nth-of-type(2) {
	width: 5em;
	margin: 0 .2em;
	display: inline;
}
form .tel input:nth-of-type(3) {
	width: 5em;
	margin: 0 0 0 .2em;
}
form .date input {
	width: 16em;
}
::-webkit-input-placeholder {
	color: #ccc;
}
.contents form h2 {
	margin: 32px 0;
  padding: 0;
}
.contents form h2::before {
  display: none;
}
form .address input:last-child {
	margin-top: 8px;
}
p.toggle {
	text-align: center;
	cursor: pointer;
	line-height: 44px;
	border: 1px solid #ccc;
	display: block;
	width: auto;
	padding: 0 16px;
	box-sizing: border-box;
}
form .error {
	color: #910000;
  display: block;
  width: 100%;
}
#agree {
  text-align: center;
  margin: 2em 0;
  padding: 1em;
  border: 1px solid #e83e0b;
}
#agree p {
    margin: 0 0 1em 0;
}
#agree span {
    color: #e83e0b;
}
.date {
    padding-bottom: 1em;
}
.time {
    padding-top: 0;
}
@media(max-width: 600px) {
  .time {
    display: flex;
  }
  .time .time-title {
    padding-top: 1em;
  }
  .time-area {
    display: flex;
    align-items: center;
    flex-direction: column;
  }
  .time-area span:nth-of-type(2) {
    transform: rotate(-90deg);
    align-self: center;
    padding: .5em 0;
  }
}
@media (min-width: 768px) {
  form {
    width: 768px;
    margin: 0 auto;
  }
  form dl {
    display: flex;
    flex-wrap: wrap;
  }
  form dl dt {
    width: 12em;
  }
  form dl dd {
    width: calc( 100% - 12em );
  }
  input[type=text],
  input[type=email] {
    width: 50%;
  }
  .address input {
    width: 100%;
  }
  form .name input {
    width: 10em;
  }
}
@media (min-width: 1024px) {}
