.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; }
}.blog-article-header { margin-bottom: 32px; }
.blog-article-meta {
display: flex;
align-items: center;
gap: 12px;
margin-bottom: 12px;
font-family: "Noto Sans JP", sans-serif;
font-size: 14px;
color: #777;
}
.blog-article-cat {
background: rgba(40,167,69,0.1);
border: 1px solid rgba(40,167,69,0.2);
color: #1B2A41;
font-weight: 700;
font-size: 12px;
padding: 4px 12px;
border-radius: 999px;
}
.blog-article-title {
font-family: "Noto Sans JP", sans-serif;
font-size: 28px;
font-weight: 900;
line-height: 1.4;
color: #1B2A41;
margin-bottom: 24px;
}
.blog-article-eyecatch {
border-radius: 12px;
overflow: hidden;
max-height: 400px;
}
.blog-article-eyecatch img {
width: 100%;
height: 400px;
object-fit: cover;
display: block;
} .miyake-article .ma-date { display: none; } .blog-mid-cta {
background: linear-gradient(135deg, #e8f5e9 0%, #fff8e1 100%);
border: 2px solid #28A745;
border-radius: 12px;
padding: 28px 24px;
margin: 48px 0;
text-align: center;
box-sizing: border-box;
overflow: hidden;
}
.blog-mid-cta-text {
font-family: "Noto Sans JP", sans-serif;
font-size: 16px;
font-weight: 700;
color: #1B2A41;
margin-bottom: 16px;
}
.blog-mid-cta-btns {
display: flex;
justify-content: center;
gap: 12px;
flex-wrap: wrap;
}
.blog-mid-cta-btn {
display: inline-flex;
align-items: center;
justify-content: center;
gap: 8px;
padding: 14px 28px;
border-radius: 9999px;
font-family: "Noto Sans JP", sans-serif;
font-size: 15px;
font-weight: 700;
color: #fff;
text-decoration: none;
transition: opacity 0.3s, transform 0.3s;
box-sizing: border-box;
max-width: 100%;
}
.blog-mid-cta-btn:hover { opacity: 0.85; transform: translateY(-2px); }
.blog-mid-cta-btn img { width: 24px; height: 24px; }
.blog-mid-cta-btn--line { background: #06C755; }
.blog-mid-cta-btn--form { background: #FF6B00; } .blog-bottom-cta {
max-width: 800px;
margin: 0 auto;
padding: 48px 24px;
text-align: center;
}
.blog-bottom-cta-title {
font-family: "Noto Sans JP", sans-serif;
font-size: 28px;
font-weight: 900;
color: #1B2A41;
margin-bottom: 12px;
}
.blog-bottom-cta-text {
font-family: "Noto Sans JP", sans-serif;
font-size: 16px;
color: #555;
line-height: 1.8;
margin-bottom: 24px;
}
.blog-bottom-cta-btns {
display: flex;
justify-content: center;
gap: 12px;
flex-wrap: wrap;
} .blog-floating-cta {
position: fixed;
bottom: 0;
left: 0;
right: 0;
z-index: 9999;
display: flex;
justify-content: center;
padding: 10px 16px;
pointer-events: none;
}
.blog-floating-cta-btn {
display: flex;
align-items: center;
justify-content: center;
width: 100%;
max-width: 480px;
padding: 16px 36px;
background: #FF6B00;
color: #fff;
font-family: "Noto Sans JP", sans-serif;
font-size: 16px;
font-weight: 800;
border-radius: 9999px;
text-decoration: none;
box-shadow: 0 4px 20px rgba(255,107,0,0.35);
transition: background 0.3s, transform 0.3s;
pointer-events: auto;
}
.blog-floating-cta-btn:hover {
background: #e55b00;
transform: translateY(-2px);
}  .single-bottom {
max-width: 1200px;
margin: 0 auto;
padding: 0 20px;
}
.sb-section { margin: 80px 0; }
.sb-section-title {
font-family: "Noto Sans JP", sans-serif;
font-size: 28px;
font-weight: 800;
color: #1B2A41;
margin-bottom: 24px;
padding-bottom: 12px;
border-bottom: 3px solid #28A745;
}
.sb-section-subtitle {
font-size: 16px;
font-weight: 400;
margin-left: 12px;
}
@media (max-width: 767px) {
.sb-section-subtitle {
display: block;
margin-left: 0;
margin-top: 4px;
}
}
.sb-divider {
border: none;
border-top: 1px solid #e0e0e0;
margin: 0;
} .sb-case-viewall {
display: inline-flex;
align-items: center;
gap: 8px;
margin-top: 16px;
color: #28A745;
font-weight: 700;
font-size: 15px;
}
.sb-case-viewall:hover { text-decoration: underline; } .sb-comparison-lead {
font-size: 15px;
line-height: 1.8;
margin-bottom: 24px;
}
.sb-comparison-lead strong {
color: #28A745;
font-weight: 700;
}
.sb-comparison-scroll {
overflow-x: auto;
-webkit-overflow-scrolling: touch;
}
.sb-comparison-scroll::-webkit-scrollbar { height: 6px; }
.sb-comparison-scroll::-webkit-scrollbar-thumb { background: #ccc; border-radius: 3px; }
.sb-comparison-table {
width: 100%;
border-collapse: collapse;
font-size: 14px;
line-height: 1.6;
}
.sb-comparison-table th,
.sb-comparison-table td {
padding: 14px 16px;
border: 1px solid #e0e0e0;
vertical-align: top;
}
.sb-comparison-table thead th {
background: #1B2A41;
color: #fff;
font-weight: 700;
text-align: center;
}
.sb-comparison-table thead th:first-child { background: #2a3f57; }
.sb-comparison-table thead th.sb-highlight { background: #28A745; }
.sb-comparison-table tbody th {
background: #f7f7f7;
font-weight: 600;
white-space: nowrap;
}
.sb-comparison-table tbody td:first-of-type { background: #f0faf2; }
.sb-badge-green {
display: inline-block;
background: #FF6B00;
color: #fff;
font-size: 11px;
padding: 2px 8px;
border-radius: 4px;
margin-left: 8px;
font-weight: 700;
}
@media (max-width: 767px) {
.sb-comparison-table {
font-size: 13px;
min-width: 600px;
}
.sb-comparison-table th,
.sb-comparison-table td {
padding: 10px 8px;
}
} .sb-faq-list {
display: flex;
flex-direction: column;
gap: 0;
}
.sb-faq-item {
border-bottom: 1px solid #e0e0e0;
}
.sb-faq-item summary {
display: flex;
justify-content: space-between;
align-items: center;
padding: 18px 0;
font-size: 15px;
font-weight: 700;
cursor: pointer;
list-style: none;
}
.sb-faq-item summary::-webkit-details-marker { display: none; }
.sb-faq-item summary::after {
content: "+";
font-size: 24px;
font-weight: 400;
color: #28A745;
flex-shrink: 0;
margin-left: 16px;
transition: transform 0.3s;
}
.sb-faq-item[open] summary::after { content: "-"; }
.sb-faq-answer {
padding: 0 0 18px;
font-size: 14px;
line-height: 1.8;
color: #444;
}
.sb-faq-answer ul {
list-style: disc;
margin-left: 1.5em;
margin-top: 8px;
}
.sb-faq-answer li { margin-bottom: 4px; } .sb-operator {
display: flex;
gap: 40px;
align-items: flex-start;
}
.sb-operator-photo {
flex: 0 0 200px;
width: 200px;
height: 200px;
border-radius: 50%;
overflow: hidden;
background: #f3f3f3;
}
.sb-operator-photo img {
width: 100%;
height: 100%;
object-fit: cover;
}
.sb-operator-info { flex: 1; }
.sb-operator-name {
font-size: 22px;
font-weight: 800;
margin-bottom: 4px;
}
.sb-operator-name-en {
font-size: 13px;
color: #888;
margin-bottom: 16px;
}
.sb-operator-details {
display: grid;
grid-template-columns: 80px 1fr;
gap: 8px 16px;
font-size: 14px;
margin-bottom: 20px;
}
.sb-operator-details dt {
font-weight: 700;
color: #28A745;
}
.sb-operator-details dd { margin: 0; }
.sb-operator-message {
font-size: 14px;
line-height: 1.8;
color: #444;
}
.sb-operator-message h4 {
font-size: 15px;
font-weight: 700;
color: #1B2A41;
margin: 16px 0 8px;
}
@media (max-width: 767px) {
.sb-operator {
flex-direction: column;
align-items: center;
gap: 20px;
}
.sb-operator-photo {
flex: none;
width: 150px;
height: 150px;
}
} .sb-related-grid {
display: grid;
grid-template-columns: repeat(3, 1fr);
gap: 24px;
}
.sb-related-card {
display: block;
background: #fff;
border-radius: 10px;
overflow: hidden;
box-shadow: 0 2px 8px rgba(0,0,0,0.08);
transition: transform 0.3s, box-shadow 0.3s;
}
.sb-related-card:hover {
transform: translateY(-4px);
box-shadow: 0 6px 16px rgba(0,0,0,0.12);
}
.sb-related-card__thumb {
width: 100%;
height: 180px;
object-fit: cover;
}
.sb-related-card__body { padding: 14px; }
.sb-related-card__date { font-size: 12px; color: #888; }
.sb-related-card__cat {
display: inline-block;
font-size: 11px;
font-weight: 700;
background: rgba(40,167,69,.10);
color: #28A745;
padding: 2px 8px;
border-radius: 999px;
margin-left: 8px;
}
.sb-related-card__title {
font-size: 14px;
font-weight: 700;
line-height: 1.6;
margin-top: 8px;
color: #1B2A41;
}
@media (max-width: 767px) {
.sb-related-grid {
grid-template-columns: 1fr;
gap: 16px;
}
} .sb-share { text-align: center; }
.sb-share-title {
font-size: 18px;
font-weight: 700;
margin-bottom: 20px;
}
.sb-share-list {
display: flex;
justify-content: center;
gap: 16px;
flex-wrap: wrap;
}
.sb-share-btn {
display: inline-flex;
align-items: center;
gap: 8px;
padding: 12px 24px;
border-radius: 8px;
font-size: 14px;
font-weight: 700;
color: #fff;
text-decoration: none;
transition: opacity 0.3s, transform 0.3s;
}
.sb-share-btn:hover {
opacity: 0.85;
transform: translateY(-2px);
}
.sb-share-btn--x { background: #000; }
.sb-share-btn--ig { background: linear-gradient(45deg, #f09433, #e6683c, #dc2743, #cc2366, #bc1888); }
.sb-share-btn--fb { background: #1877F2; }
.sb-share-btn--copy { background: #6c757d; cursor: pointer; border: none; }
@media (max-width: 767px) {
.sb-share-list { gap: 10px; }
.sb-share-btn { padding: 10px 18px; font-size: 13px; }
} @media (max-width: 767px) {
.blog-article-title { font-size: 22px; }
.blog-article-meta { flex-wrap: wrap; }
.blog-article-eyecatch img { height: 240px; }
.blog-mid-cta { padding: 20px 16px; }
.blog-mid-cta-btns { flex-direction: column; align-items: center; }
.blog-mid-cta-btn { width: 100%; max-width: 320px; justify-content: center; }
.blog-bottom-cta { padding: 32px 16px; }
.blog-bottom-cta-title { font-size: 22px; }
.blog-bottom-cta-btns { flex-direction: column; align-items: center; }
.blog-floating-cta { padding: 8px 12px 12px; }
.blog-floating-cta-btn { font-size: 15px; padding: 14px 24px; }
}html {
height: 100%;
background-color: #eee;
overflow-x: hidden;
}
body {
min-height: 100%;
background-color: #eee;
margin: 0;
padding: 0;
overflow-x: hidden;
}
p, h3, h4, h5, h6, ol, ul {
margin: 0;
} .text-black {
color: #000; } .btn-custom {
svg {
width: 40px !important;
height: 40px !important;
}
} ul,ol {
margin: 0 0 0 1em;
} p {
margin-bottom: 0;
} .custom-list li::marker {
color: #FF6B00; }
.privacy-policy {
font-family: "Noto Sans JP", sans-serif;
line-height: 1.8;
padding: 20px;
font-size: 14px; }
.privacy-policy h2 {
font-size: 16px; font-weight: bold;
margin-top: 24px;
margin-bottom: 8px;
color: #222;
}
.privacy-policy p,
.privacy-policy li,
.privacy-policy address {
font-size: 14px; color: #333;
}
.privacy-policy ul {
margin-bottom: 1em;
list-style-position: inside;
}
.privacy-policy li {
margin-bottom: 0.5em;
text-indent: 0em;
}
.privacy-policy address {
font-style: normal;
line-height: 1.6;
}    .hp-cf-container p {
display: flex;
align-items: center; gap: 16px; margin: 0 0 25px; flex-wrap: nowrap; } .hp-cf-container label.left-label {
width: 264px;
min-width: 180px;
font-family: "zen-kaku-gothic-new", sans-serif;
font-size: 20px;
font-weight: 700;
display: flex;
align-items: center;
justify-content: flex-start;
gap: 8px;
} .hp-cf-container label.left-label .required {
margin-left: auto;
} .hp-cf-container label.left-label .label-text {
margin-right: 8px;
} .hp-cf-container .wpcf7-form-control,
.hp-cf-container input[type="text"],
.hp-cf-container input[type="email"],
.hp-cf-container input[type="tel"],
.hp-cf-container textarea,
.hp-cf-container select,
.hp-cf-container .wpcf7-form-control-wrap {
flex: 1 1 0;
min-width: 0;
} .hp-cf-container textarea {
width: 100%;
min-height: 160px;
resize: vertical;
box-sizing: border-box;
} .hp-cf-container .wpcf7-form-control-wrap input[type="radio"],
.hp-cf-container .wpcf7-form-control-wrap input[type="checkbox"] {
margin-right: 8px;
} .hp-cf-container .required {
background-color: #FF6600;
color: #fff;
font-size: 13px;
padding: 2px 6px;
border-radius: 4px;
display: inline-block;
line-height: 1.2;
flex-shrink: 0;
vertical-align: middle;
} .hp-cf-container hr {
flex-basis: 100%;
height: 1px;
border: none;
background-color: #ccc;
margin: 24px 0;
order: 99;
} @media (max-width: 767px) {
.hp-cf-container p {
flex-direction: column;
align-items: stretch;
gap: 0px;
}
.hp-cf-container label.left-label {
width: auto;
text-align: left;
justify-content: flex-start;
margin-bottom: 8px;
}
.hp-cf-container .wpcf7-form-control { width: 100%; }
}
.wpcf7-text {
width: 100% !important;
}
.hp-cf-sub {
width: 500px !important;
margin: 0 auto;
justify-content: center;
}
.wpcf7-spinner {
display: none !important;
}
.hp-cf-sub input[type="submit"] {
display: block !important;
background-color: #FF6600;
color: #fff;
font-family: "zen-kaku-gothic-new", sans-serif;
font-weight: 700;
font-size: 16px;
padding: 14px 48px;
border: none;
border-radius: 9999px;
cursor: pointer;
transition: all 0.3s ease;
text-align: center;
box-shadow: 0 4px 10px rgba(0, 0, 0, 0.1);
}
.hp-cf-sub input[type="submit"]:hover {
background-color: #e55b00;
transform: translateY(-2px);
box-shadow: 0 6px 14px rgba(0, 0, 0, 0.15);
}
.hp-cf-sub input[type="submit"]:active {
transform: translateY(0);
box-shadow: 0 3px 8px rgba(0, 0, 0, 0.1);
}
@media (max-width: 767px) {
.hp-cf-sub {
width: 90% !important;
}
}
.agree {
display: flex !important;
justify-content: center !important;
align-items: center;
width: 100%;
text-align: center;
} ul.top-news{
list-style: none !important;
margin: 0 !important;
padding: 0 !important;
border-top: 1px solid #eaeaea;
}
ul.top-news .top-news__item{
display: grid;
grid-template-columns: 120px 1fr 260px;
gap: 18px;
align-items: center;
padding: 14px 0;
border-bottom: 1px solid #eaeaea;
}
ul.top-news .top-news__item:hover{
background: rgba(0,0,0,.02);
}
ul.top-news .top-news__date{
color: #6b6b6b;
font-size: 0.92rem;
letter-spacing: .02em;
padding-top: 2px;
}
ul.top-news .top-news__title{
color: #1B2A41;
text-decoration: none;
font-weight: 700;
line-height: 1.6;
display: flex;
align-items: center;
gap: 12px;
}
ul.top-news .top-news__title:hover{
text-decoration: underline;
}
ul.top-news .top-news__thumb{
flex: 0 0 44px;
width: 44px;
height: 44px;
border-radius: 8px;
overflow: hidden;
background: #f1f1f1;
margin-top: 2px;
}
ul.top-news .top-news__thumb img{
width: 100%;
height: 100%;
display: block;
object-fit: cover;
}
ul.top-news .top-news__text{
display: block;
}
ul.top-news .top-news__terms{
display: flex;
justify-content: flex-end;
gap: 8px;
flex-wrap: wrap;
padding-top: 2px;
}
ul.top-news .top-news__pill{
display: inline-flex;
align-items: center;
font-size: 0.85rem;
font-weight: 700;
color: #1B2A41;
text-decoration: none;
padding: 6px 10px;
border-radius: 999px;
line-height: 1;
background: #f3f3f3;
}
ul.top-news .top-news__pill.is-cat{
background: rgba(40,167,69,.10);
border: 1px solid rgba(40,167,69,.20);
}
ul.top-news .top-news__pill.is-tag{
background: rgba(249,115,22,.10);
border: 1px solid rgba(249,115,22,.20);
}
@media (max-width: 767px){
ul.top-news .top-news__item{
grid-template-columns: 1fr;
gap: 10px;
padding: 14px 0;
}
ul.top-news .top-news__terms{
justify-content: flex-start;
padding-top: 0;
}
ul.top-news .top-news__thumb{
flex-basis: 48px;
width: 48px;
height: 48px;
}
} .case-grid {
display: flex;
gap: 28px;
font-family: "Noto Sans JP", system-ui, -apple-system, "Segoe UI", Arial, sans-serif;
}
.case-grid :is(a, p, li, span, div) { font-family: inherit; }
.case-grid::-webkit-scrollbar { display: none; }
.case-card {
background: #fff;
padding: 16px;
border-radius: 14px;
box-shadow: 0 2px 8px rgba(0,0,0,0.06);
}
.case-card .case-thumb img { transition: transform 0.3s; }
.case-card:hover .case-thumb img { transform: scale(1.05); }
.case-card:hover .case-more { color: #1B8C3A; }
.case-thumb {
background: #f3f3f3;
border-radius: 14px;
overflow: hidden;
}
.case-thumb img {
width: 100%;
height: 240px;
object-fit: contain;
display: block;
}
.case-meta {
margin: 14px 0 0;
padding: 0;
list-style: none;
color: #111;
font-size: 16px;
line-height: 1.75;
}
.case-meta li {
position: relative;
padding-left: 18px;
margin: 4px 0;
}
.case-meta li::before {
content: "";
position: absolute;
left: 0;
top: 0.72em;
width: 6px;
height: 6px;
border-radius: 50%;
background: #ff7a00;
transform: translateY(-50%);
}
.case-more {
display: inline-block;
margin-top: 10px;
color: #28A745;
font-weight: 700;
text-decoration: underline;
text-underline-offset: 3px;
}
.case-price {
margin-top: 10px;
color: #ff7a00;
font-weight: 800;
font-size: 18px;
}
.case-link {
display: block;
color: inherit;
text-decoration: none;
} .scroll-drag {
cursor: grab;
user-select: none;
}
.scroll-drag::-webkit-scrollbar { display: none; }
.scroll-drag a { pointer-events: auto; }
.scroll-drag img {
pointer-events: none;
user-select: none;
-webkit-user-drag: none;
} .case-grid.is-slider {
overflow-x: auto;
overflow-y: hidden;
-webkit-overflow-scrolling: touch;
scroll-snap-type: x mandatory;
padding-right: 12vw;
padding-bottom: 12px;
touch-action: pan-x;
}
.case-grid.is-slider > .case-card {
flex: 0 0 auto;
width: 360px;
scroll-snap-align: start;
}
@media (max-width: 1024px) {
.case-grid.is-slider > .case-card { width: 320px; }
.case-grid.is-slider { touch-action: pan-x pan-y; scroll-snap-type: x proximity; }
}
@media (max-width: 600px) {
.case-grid.is-slider { padding-right: 18vw; }
.case-grid.is-slider > .case-card { width: 80vw; }
.case-thumb img { height: 220px; }
} .case-grid.is-grid {
display: grid;
grid-template-columns: repeat(2, minmax(0, 1fr));
gap: 60px;
overflow: visible;
scroll-snap-type: none;
padding: 0;
touch-action: auto;
}
.case-grid.is-grid > .case-card { width: 450px; }
@media (max-width: 1220px) {
.case-grid.is-grid { grid-template-columns: 1fr; justify-items: center; }
.case-grid.is-grid > .case-card { max-width: 300px; }
}  .related{
border: 1px solid #28A745;
background: #fff;
margin: 24px 0;
width: 80%;
max-width: 680px;
}
@media (max-width: 767px) {
.related{
width: 100%;
}
}
.related__header{
background: #28A745;
color: #fff;
font-weight: 700;
padding: 10px 14px;
font-size: 14px;
line-height: 1.2;
}
.related__body{
padding: 14px;
}
.related__item{
display: flex;
gap: 16px;
align-items: center;
text-decoration: none;
color: inherit;
padding: 8px 0;
}
.related__thumb{
flex: 0 0 150px;
}
.related__thumb img{
width: 150px;
height: 100px;
object-fit: cover;
border-radius: 4px;
}
.related__title{
font-weight: 700;
font-size: 15px;
line-height: 1.6;
flex: 1;
}
.related__item:hover .related__title{
text-decoration: underline;
}
.related__item--error{
color: #b00020;
padding: 8px 0;
} body.single-post { background-color: #fff; }
.num-index {
padding-left: 16px;
}
.single-container {
max-width: 1200px;
margin: 150px auto 100px;
padding: 0 20px;
box-sizing: border-box;
}
@media (max-width: 767px){
.single-container {
margin: 70px auto 50px;
}
}
.posted-on,
.byline,
.cat-links,
.edit-link {
display: none;
}
.post-thumbnail {
display: none;
}
.entry-header {
font-family: "M PLUS 1p", sans-serif;
background-color: #f3f3f3;
color: #3a3a3a;
border-radius: 10px;
padding: 5px 5px;
display: flex;
justify-content: center;
margin-bottom: 20px;
}
.entry-header h1 {
font-size: 22px;
}  .contact-sns-row {
display: flex;
justify-content: center;
gap: 20px;
margin-bottom: 24px;
}
.contact-sns-btn {
display: inline-flex;
align-items: center;
gap: 10px;
padding: 16px 32px;
border-radius: 9999px;
font-family: "Noto Sans JP", sans-serif;
font-size: 16px;
font-weight: 700;
color: #fff;
transition: opacity 0.3s;
}
.contact-sns-btn:hover { opacity: 0.85; }
.contact-sns-btn img { width: 28px; height: 28px; }
.contact-sns-btn--line { background: #06C755; }
.contact-sns-btn--ig { background: linear-gradient(45deg, #f09433, #e6683c, #dc2743, #cc2366, #bc1888); } .contact-divider {
display: flex;
align-items: center;
gap: 16px;
margin: 32px 0;
width: 100%;
max-width: 700px;
color: #999;
font-size: 14px;
}
.contact-divider::before,
.contact-divider::after {
content: "";
flex: 1;
height: 1px;
background: #ddd;
} .contact-form {
width: 100%;
max-width: 700px;
margin: 0 auto;
}
.form-row {
display: flex;
align-items: flex-start;
gap: 16px;
margin-bottom: 20px;
}
.form-label {
width: 200px;
min-width: 160px;
font-family: "Noto Sans JP", sans-serif;
font-size: 15px;
font-weight: 700;
padding-top: 10px;
display: flex;
align-items: center;
gap: 8px;
}
.form-required {
background: #FF6B00;
color: #fff;
font-size: 11px;
padding: 2px 6px;
border-radius: 4px;
font-weight: 700;
flex-shrink: 0;
}
.form-optional {
background: #ccc;
color: #fff;
font-size: 11px;
padding: 2px 6px;
border-radius: 4px;
font-weight: 700;
flex-shrink: 0;
}
.form-field { flex: 1; }
.form-field input,
.form-field textarea {
width: 100%;
padding: 12px 16px;
font-family: "Noto Sans JP", sans-serif;
font-size: 15px;
border: none;
border-radius: 10px;
background: #F2F4F8;
box-shadow: 0 2px 4px rgba(0,0,0,0.08);
outline: none;
transition: box-shadow 0.3s;
}
.form-field input:focus,
.form-field textarea:focus {
box-shadow: 0 0 0 2px #28A745;
}
.form-field textarea { resize: vertical; }
.form-radio {
display: inline-flex;
align-items: center;
gap: 6px;
font-size: 15px;
margin-right: 20px;
padding-top: 10px;
cursor: pointer;
}
.form-radio input { accent-color: #FF6B00; }
.form-agree {
text-align: center;
margin: 24px 0 16px;
font-size: 14px;
}
.form-agree a { color: #28A745; text-decoration: underline; }
.form-agree input { margin-right: 6px; accent-color: #FF6B00; }
.form-submit { text-align: center; margin-bottom: 16px; }
.form-submit-note {
text-align: center;
font-size: 13px;
color: #777;
margin-top: 12px;
}
.form-submit-note a {
color: #28A745;
text-decoration: underline;
}
.form-recaptcha-note {
text-align: center;
font-size: 12px;
color: #999;
margin-top: 8px;
}
.form-recaptcha-note a { color: #999; text-decoration: underline; }
@media (max-width: 767px) {
.contact-sns-row { flex-direction: column; align-items: center; }
.form-row { flex-direction: column; gap: 4px; }
.form-label { width: auto; padding-top: 0; margin-bottom: 4px; }
.contact-divider { max-width: 90%; }
.contact-form { max-width: 90%; }
}  .news-tabs {
display: flex;
gap: 12px;
margin-bottom: 24px;
}
.news-tab {
font-family: "Noto Sans JP", sans-serif;
font-size: 14px;
font-weight: 600;
padding: 10px 24px;
border-radius: 9999px;
border: 2px solid #ddd;
background: #fff;
color: #1B2A41;
cursor: pointer;
transition: all 0.3s;
white-space: nowrap;
flex-shrink: 0;
}
.news-tab:hover {
border-color: #28A745;
}
.news-tab.is-active {
background: #28A745;
color: #fff;
border-color: #28A745;
} .news-grid {
display: grid;
grid-template-columns: repeat(3, 1fr);
gap: 24px;
}
.news-card {
display: flex;
flex-direction: column;
background: #fff;
border-radius: 12px;
overflow: hidden;
box-shadow: 0 2px 8px rgba(0,0,0,0.06);
transition: transform 0.3s, box-shadow 0.3s;
}
.news-card:hover {
transform: translateY(-4px);
box-shadow: 0 8px 24px rgba(0,0,0,0.1);
}
.news-card.is-hidden { display: none; }
.news-card__thumb {
width: 100%;
aspect-ratio: 16 / 10;
overflow: hidden;
background: #e8e8e8;
}
.news-card__thumb img {
width: 100%;
height: 100%;
object-fit: cover;
transition: transform 0.3s;
}
.news-card:hover .news-card__thumb img { transform: scale(1.05); }
.news-card__body {
padding: 16px 20px 20px;
display: flex;
flex-direction: column;
gap: 10px;
flex: 1;
}
.news-card__meta {
display: flex;
align-items: center;
gap: 10px;
}
.news-card__date {
font-family: "Noto Sans JP", sans-serif;
font-size: 13px;
color: #999;
letter-spacing: 0.02em;
}
.news-card__pill {
display: inline-flex;
align-items: center;
font-family: "Noto Sans JP", sans-serif;
font-size: 12px;
font-weight: 700;
color: #1B2A41;
padding: 4px 10px;
border-radius: 999px;
line-height: 1;
}
.news-card__pill.is-cat {
background: rgba(40,167,69,0.1);
border: 1px solid rgba(40,167,69,0.2);
}
.news-card__pill.is-news {
background: rgba(27,42,65,0.08);
border: 1px solid rgba(27,42,65,0.15);
}
.news-card__title {
font-family: "Noto Sans JP", sans-serif;
font-size: 15px;
font-weight: 700;
line-height: 1.6;
color: #1B2A41;
}
.news-more {
display: flex;
justify-content: center;
margin-top: 40px;
}
@media (max-width: 1220px) {
.news-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 767px) {
.news-grid { grid-template-columns: 1fr; gap: 16px; }
.news-card__body { padding: 12px 16px 16px; }
}[data-class="wpcf7cf_group"], .wpcf7cf_remove, .wpcf7cf_add {
display:none;
}
.wpcf7cf_repeater_sub {
margin-bottom: 20px;
}
.wpcf7cf_repeater_controls, .wpcf7cf_step_controls {
display: flex;
justify-content: space-between;
flex-wrap: wrap;
margin-top: 20px;
}
.wpcf7cf_multistep .wpcf7cf_step { width: 100%;
}
.wpcf7cf_multistep .wpcf7cf_step .step-title {
display: none;
}
.wpcf7cf_multistep .wpcf7cf_steps-dots {
display: flex;
width: 100%;
margin-bottom: 20px;
flex-wrap: wrap;
}
.wpcf7cf_multistep .wpcf7cf_steps-dots .dot .step-index {
display: inline-block;
border-radius: 50%;
background: #dfdfdf;
color: #000000;
width: 40px;
height: 40px;
line-height: 40px;
text-align: center;
}
.wpcf7cf_multistep .wpcf7cf_steps-dots .dot {
border-bottom: 5px solid #dfdfdf;
text-align: center;
flex: 1;
padding: 15px;
min-width: 120px;
}
.wpcf7cf_multistep .wpcf7cf_steps-dots .dot.completed {
border-bottom: 5px solid #333;
}
.wpcf7cf_multistep .wpcf7cf_steps-dots .dot.active {
border-bottom: 5px solid #333;
font-weight: bold;
}
.wpcf7cf_multistep .wpcf7cf_steps-dots .dot.completed .step-index {
background-color: #333;
color: #ffffff;
}
.wpcf7cf_multistep .wpcf7cf_steps-dots .dot.active .step-index {
background-color: #333;
color: #ffffff;
}
.wpcf7cf_step_controls .disabled {
pointer-events: none;
cursor: default;
opacity: .5;
} .wpcf7cf_repeater_sub_controls {
display: inline-flex;
gap: 4px;
margin: 4px 0;
align-items: center;
}