.header-contaciner,
.header-contaciner *,
.header-contaciner *::before,
.header-contaciner *::after,
.sp-header-logo,
.sp-header-logo *,
.sp-hamburger-wrap,
.sp-hamburger-wrap *,
.burger-menu,
.burger-menu *,
.burger-menu *::before,
.burger-menu *::after,
.menu-overlay {
box-sizing: border-box;
}
.header-contaciner ul,
.burger-menu ul {
margin: 0;
padding: 0;
list-style: none;
}
.header-contaciner a,
.sp-header-logo a,
.burger-menu a {
color: inherit;
text-decoration: none;
}
.header-contaciner img,
.sp-header-logo img,
.burger-menu img {
max-width: 100%;
height: auto;
border: none;
display: block;
} .header-contaciner {
position: fixed;
top: 0;
left: 0;
width: 100%;
min-height: 120px;
background-color: #FFFFFF;
z-index: 151;
}
.pc-header {
max-width: 1600px;
margin: 0 auto;
display: flex;
justify-content: space-between;
align-items: center;
min-height: 120px;
padding: 0 30px;
}
.header-logo img {
width: 176px;
transition: transform 0.3s;
}
.header-logo img:hover { transform: scale(1.1); }
.header-nav {
display: flex;
align-items: center;
gap: 20px;
}
.header-nav-menu {
display: flex;
align-items: center;
}
.header-nav-menu li a {
font-family: "Noto Sans JP", sans-serif;
font-size: 18px;
font-weight: 600;
color: #000;
padding: 30px 10px;
display: block;
position: relative;
transition: color 0.3s;
}
.header-nav-menu li a:hover { color: #FF6B00; }
.header-nav-menu li a::after {
content: "";
position: absolute;
bottom: 20px;
left: 10px;
right: 10px;
height: 2px;
background-color: #28A745;
transform: scaleX(0);
transition: transform 0.3s;
}
.header-nav-menu li a:hover::after { transform: scaleX(1); }
.header-nav-menu .header-nav-cta a {
background-color: #FF6B00;
color: #FFF !important;
border-radius: 50px;
padding: 18px 40px !important;
font-family: "Noto Sans JP", sans-serif;
font-size: 18px;
font-weight: 600;
transition: background-color 0.3s;
white-space: nowrap;
}
.header-nav-menu .header-nav-cta a::after { display: none !important; }
.header-nav-menu .header-nav-cta a:hover {
background-color: #FFA869;
color: #FFF !important;
} .pc-header .btn-trigger { display: none; }
.header-social-icon {
width: 60px;
transition: opacity 0.2s, transform 0.3s;
}
.header-social-icon:hover {
opacity: 0.6;
transform: scale(1.1);
} .sp-header-logo {
position: fixed;
top: 50px;
left: 50px;
z-index: 151;
}
.sp-header-logo img {
width: 176px;
transition: transform 0.3s;
}
.sp-header-logo img:hover { transform: scale(1.1); }
.sp-hamburger-wrap {
position: fixed;
top: 75px;
right: 50px;
z-index: 210;
}
@media (min-width: 1221px) {
.sp-header-logo,
.sp-hamburger-wrap { display: none; }
}
@media (max-width: 1220px) {
.header-contaciner { display: none; }
}
@media (max-width: 767px) {
.sp-header-logo     { top: 20px; left: 20px; }
.sp-header-logo img { width: 70px; }
.sp-hamburger-wrap  { top: 20px; right: 20px; }
} .btn-trigger {
position: relative;
width: 50px;
height: 44px;
cursor: pointer;
}
.btn-trigger span {
position: absolute;
left: 0;
width: 100%;
height: 4px;
background-color: #000;
border-radius: 4px;
}
.btn-trigger, .btn-trigger span {
display: inline-block;
transition: all .5s;
}
.btn-trigger span:nth-of-type(1) { top: 0; }
.btn-trigger span:nth-of-type(2) { top: 20px; }
.btn-trigger span:nth-of-type(3) { bottom: 0; }
.btn07 span:nth-of-type(1) { animation: btn07-bar01 .75s forwards; }
.btn07 span:nth-of-type(2) { transition: all .25s .25s; opacity: 1; }
.btn07 span:nth-of-type(3) { animation: btn07-bar03 .75s forwards; }
.btn07.active span:nth-of-type(1) { animation: active-btn07-bar01 .75s forwards; }
.btn07.active span:nth-of-type(2) { opacity: 0; }
.btn07.active span:nth-of-type(3) { animation: active-btn07-bar03 .75s forwards; }
@keyframes btn07-bar01   { 0%{transform:translateY(20px) rotate(45deg)} 50%{transform:translateY(20px) rotate(0)} 100%{transform:translateY(0) rotate(0)} }
@keyframes btn07-bar03   { 0%{transform:translateY(-20px) rotate(-45deg)} 50%{transform:translateY(-20px) rotate(0)} 100%{transform:translateY(0) rotate(0)} }
@keyframes active-btn07-bar01 { 0%{transform:translateY(0) rotate(0)} 50%{transform:translateY(20px) rotate(0)} 100%{transform:translateY(20px) rotate(45deg)} }
@keyframes active-btn07-bar03 { 0%{transform:translateY(0) rotate(0)} 50%{transform:translateY(-20px) rotate(0)} 100%{transform:translateY(-20px) rotate(-45deg)} }
@media (max-width: 767px) {
.btn-trigger { width: 32px !important; height: 26px !important; }
.btn-trigger span {
height: 3px !important;
border-radius: 3px !important;
transition: all 0.4s ease !important;
transform-origin: center !important;
}
.btn-trigger span:nth-of-type(1) { top: 0 !important; }
.btn-trigger span:nth-of-type(2) { top: 11.5px !important; }
.btn-trigger span:nth-of-type(3) { bottom: 0 !important; }
.btn07.active span:nth-of-type(1) { transform: translateY(11.5px) rotate(45deg) !important; }
.btn07.active span:nth-of-type(2) { opacity: 0 !important; }
.btn07.active span:nth-of-type(3) { transform: translateY(-11.5px) rotate(-45deg) !important; }
} .burger-menu {
position: fixed !important;
top: 0 !important;
right: -100% !important;
width: 500px;
height: 100svh !important;
background-color: #fff !important;
box-shadow: -4px 0 12px rgba(0,0,0,0.15);
transition: right 0.4s ease;
z-index: 9999 !important;
padding: 80px 24px 24px;
overflow-y: auto;
}
.burger-menu.is-active { right: 0 !important; }
.burger-menu-social {
display: flex;
justify-content: center;
align-items: center;
gap: 20px;
padding-bottom: 30px;
}
.burger-menu-social img { width: 50px; }
.burger-menu-nav { padding: 0; }
.burger-menu-nav li a {
font-family: "Noto Sans JP", sans-serif;
font-size: 20px;
font-weight: 600;
color: #000;
display: block;
padding: 30px 15px;
transition: color 0.3s;
}
.burger-menu-nav li a:hover { color: #FF6B00; }
.burger-nav-cta a {
background-color: #FF6B00;
color: #FFF !important;
border-radius: 50px;
padding: 30px;
text-align: center;
}
.burger-nav-cta a:hover { background-color: #FFA869; }
.menu-overlay {
display: none;
position: fixed;
top: 0; left: 0;
width: 100vw;
height: 100svh;
background: rgba(0,0,0,0.4);
z-index: 98;
}
.menu-overlay.is-active { display: block; }
body.menu-open {
overflow: hidden;
touch-action: none;
}
body.menu-open .sp-header-logo,
body.menu-open .sp-hamburger-wrap {
z-index: 10000;
}
body.menu-open .floating-cta,
body.menu-open .floating-cta.is-visible,
body.menu-open .grecaptcha-badge {
display: none !important;
}
@media (max-width: 1220px) {
.burger-menu { width: 100vw; box-shadow: none; }
.burger-menu-nav li a { font-size: 26px; }
}
@media (max-width: 767px) {
.menu-overlay.is-active { display: none; }
.burger-menu {
width: 100% !important;
height: calc(100svh + env(safe-area-inset-top) + env(safe-area-inset-bottom)) !important;
padding: calc(80px + env(safe-area-inset-top)) 24px calc(24px + env(safe-area-inset-bottom));
-webkit-overflow-scrolling: touch;
}
.burger-menu-nav li a { font-size: 20px; padding: 20px 15px; }
}.pc-only { display: block; }
.sp-only { display: none; }
@media (max-width: 767px) {
.pc-only { display: none; }
.sp-only { display: block; }
}
.site-footer { background-color: #7089A4; }
.footer-inner {
max-width: 1200px;
margin: 0 auto;
padding: 40px 0;
display: flex;
flex-direction: column;
align-items: center;
}
.footer-logo { align-self: flex-start; }
.footer-logo img {
width: 175px;
height: auto;
transition: transform 0.3s;
}
.footer-logo img:hover { transform: scale(1.1); }
.footer-divider {
width: 100%;
border: none;
border-top: 1px solid #050505;
margin: 4px 0;
}
.footer-content {
display: flex;
justify-content: space-between;
align-items: flex-start;
width: 100%;
margin: 30px 0;
}
.footer-info-left {
display: flex;
align-items: flex-start;
gap: 20px;
width: 65%;
}
.footer-title {
font-family: "Noto Sans JP", sans-serif;
font-size: 35px;
font-weight: 600;
color: #F2F2F2;
}
.logo-chara { color: #E10032; } .footer-info-table {
display: grid;
grid-template-columns: 0.9fr 1.5fr;
gap: 20px 0;
width: 500px;
}
.footer-info-table dt,
.footer-info-table dd {
font-family: "Noto Sans JP", sans-serif;
font-size: 18px;
color: #FFF;
margin: 0;
}
.footer-info-table dt { font-weight: 600; }
.footer-info-table .logo-chara { color: #E10032 !important; font-weight: 700; }
.footer-info-table .footer-name-blue { color: #0E3668; font-weight: 700; }
.footer-info-right {
width: 50%;
display: flex;
justify-content: flex-end;
}
.footer-links {
display: grid;
grid-template-columns: repeat(2, 1fr);
grid-template-rows: repeat(5, 1fr);
gap: 10px 0;
width: 450px;
}
.footer-links a {
font-family: "Noto Sans JP", sans-serif;
font-size: 18px;
color: #FFF;
text-decoration: none;
transition: color 0.3s;
}
.footer-links a:hover { color: #D6D3D3; }
.footer-bottom {
display: flex;
justify-content: flex-start;
align-items: center;
gap: 10px;
width: 100%;
}
.footer-bottom img {
height: 50px;
width: auto;
transition: opacity 0.3s;
}
.footer-bottom img:hover { opacity: 0.7; }
.footer-copy {
width: 100%;
margin: 18px 0 0;
font-family: "Noto Sans JP", sans-serif;
font-size: 13px;
font-weight: 400;
line-height: 1.6;
color: rgba(255,255,255,0.75);
text-align: left;
}
@media (max-width: 1220px) {
.footer-inner { width: 90%; }
.footer-content { flex-direction: column; align-items: center; gap: 30px; }
.footer-info-left { width: 100%; justify-content: center; }
.footer-info-right { width: 100%; flex-direction: column; align-items: center; }
.footer-links { width: 600px; max-width: 100%; gap: 0; }
}
@media (max-width: 767px) {
.footer-logo { align-self: center; }
.footer-info-left { flex-direction: column; gap: 15px; }
.footer-info-table { grid-template-columns: 1fr 1.44fr; gap: 16px 0; width: 100%; }
.footer-info-table dt,
.footer-info-table dd { font-size: 16px; }
.footer-info-right { justify-content: flex-start; }
.footer-links {
width: 300px;
grid-template-columns: 1fr;
grid-template-rows: repeat(9, 1fr);
gap: 10px 0;
}
.footer-links a { font-size: 16px; }
.footer-bottom {
display: flex;
flex-direction: row;
justify-content: center;
gap: 20px;
margin-top: 15px;
padding-bottom: 0;
}
.footer-copy {
margin-top: 18px;
padding-bottom: 80px;
text-align: center;
}
}.section-contact {
display: flex;
flex-direction: column;
align-items: center;
gap: 15px;
background-color: #fff;
}
.contact-title {
font-family: "Zen Kaku Gothic New", sans-serif;
font-size: 100px;
font-weight: 800;
color: #1B2A41;
}
.contact-desc {
text-align: center;
font-family: "BIZ UDGothic", sans-serif;
font-size: 20px;
line-height: 30px;
letter-spacing: 0.6px;
}
.contact-cta-row {
display: flex;
justify-content: center;
gap: 30px;
align-items: center;
}
.contact-btn {
background-color: #FF6B00;
color: #FFF;
font-family: "Zen Kaku Gothic New", sans-serif;
font-size: 20px;
font-weight: 600;
line-height: 25px;
letter-spacing: 0.5px;
border-radius: 50px;
padding: 25px 50px;
display: inline-block;
transition: transform 0.3s, background-color 0.3s;
}
.contact-btn:hover { transform: scale(1.1); background-color: #e55b00; }
.contact-social {
display: flex;
gap: 30px;
justify-content: center;
}
.contact-social img {
width: 100px;
height: 100px;
object-fit: contain;
aspect-ratio: 1 / 1;
transition: opacity 0.2s, transform 0.3s;
}
.contact-social img:hover { opacity: 0.6; transform: scale(1.1); } .contact-map-row {
display: flex;
gap: 30px;
width: 1200px;
max-width: 90%;
margin: 0 auto 100px;
}
.contact-map-row iframe {
width: 55%; height: 500px;
max-width: 100%;
border-radius: 10px;
border: none;
}
.contact-shop-img {
width: 45%;
height: 500px;
border-radius: 10px;
object-fit: cover;
}
@media (max-width: 1220px) {
.contact-map-row { flex-direction: column; }
.contact-map-row iframe,
.contact-shop-img { width: 100%; }
}
@media (max-width: 767px) {
.section-contact { width: 100%; padding: 100px 0 0; }
.contact-title { font-size: 58px; }
.contact-desc { font-size: 16px; }
.contact-cta-row { flex-direction: column; align-items: center; gap: 15px; }
.contact-btn { font-size: 18px; padding: 20px 50px; }
.contact-social img { width: 60px; }
}