* { margin:0; padding:0; box-sizing:border-box; }
body {  font-family: 'Noto Sans JP', sans-serif; line-height:1.6; color:#333; background:#f5f9fb; }
a { text-decoration:none; color:inherit; } header.site-header {
position: fixed;
top: 0; left: 0; width: 100%;
background-color: rgba(255, 255, 255, 0.9);
transition: background-color 0.3s ease, box-shadow 0.3s ease; z-index: 1200;
}
header.site-header h1,
header.site-header h2 {
display: none;
} .site-header.scrolled {
background-color: rgba(255, 255, 255, 1);
box-shadow: 0 4px 12px rgba(0,0,0,0.12);
} .header-inner {
max-width: 1200px;
margin: 0 auto;
padding: 12px 5%;
display: flex;
align-items: center;
justify-content: space-between;
}
.logo img { height: 50px; display:block; } .hamburger {
display: none;
background: transparent;
border: none;
padding: 6px;
cursor: pointer;
flex-shrink: 0;
}
.hamburger span {
display:block;
width: 26px; height: 3px;
background: #333;
margin: 4px 0;
border-radius: 2px;
transition: transform .25s, opacity .25s;
} .main-nav { flex: 1; margin-left: 20px; }
nav ul.nav-menu {
display: flex;
align-items: center;
gap: 5px;
list-style: none;
margin: 0;
white-space: nowrap;
}
nav ul.nav-menu > li { position: relative; }
nav ul.nav-menu > li > a {
display:inline-block;
padding:4px 8px;
border-radius:20px;
font-weight:600;
font-size: 0.85rem;
transition: background .18s, color .18s;
color: #333;
}
nav ul.nav-menu > li > a:hover {
color: #6fc0a9;
background: #f1faf7;
} .menu-item-has-children > a::after {
content: "▼";
font-size: 0.65rem;
margin-left: 6px;
color: #5aa689;
display: inline-block;
transition: transform .2s;
}
.sub-menu {
display: none;
position: absolute;
top: 100%;
left: 0;
background: #fff;
border-radius: 10px;
box-shadow: 0 6px 20px rgba(0,0,0,0.10);
min-width: 200px;
padding: 8px 0;
list-style: none;
z-index: 1500;
}
.sub-menu li a {
display: block;
padding: 10px 16px;
font-size: 0.95rem;
color: #333;
}
.sub-menu li a:hover { background: #f1faf7; color: #5aa689; } .header-right { display: flex; align-items: center; gap: 10px; }
.tel-pc img, .tel-mobile img { display: block; }
.tel-pc img{ margin-left:10px; } @media (min-width: 769px) {
a[href^="tel:"] { pointer-events: none; cursor: default; }
.tel-mobile { display: none !important; }
} @media (max-width: 768px) {
.hamburger { display: flex; flex-direction: column; }
nav ul.nav-menu {
flex-direction: column;
position: fixed;
top: 0;
left: 0;
width: 80%;
max-width: 320px;
height: 100%;
padding-top: 84px;
background: #fff;
transform: translateX(-100%);
transition: transform .28s ease;
box-shadow: 6px 0 18px rgba(0,0,0,0.12);
border-top-right-radius: 40px;
border-bottom-right-radius: 40px;
z-index: 1400;
}
nav ul.nav-menu.show { transform: translateX(0); }
nav ul.nav-menu > li { width: 100%; margin: 6px 0; position: relative; }
nav ul.nav-menu > li > a { padding: 12px 18px; font-size: 1.05rem; display: block; text-align: left; } .menu-item-has-children > a::after { content: ""; }
.submenu-toggle {
display: inline-block;
width: 36px;
height: 36px;
border-radius: 6px;
background: transparent;
border: none;
position: absolute;
right: 10px;
top: 50%;
transform: translateY(-50%);
cursor: pointer;
}
.submenu-toggle::after {
content: "▼";
display: inline-block;
font-size: 0.8rem;
color: #5aa689;
transition: transform .2s;
}
.menu-item-has-children.open .submenu-toggle::after { transform: rotate(180deg); }
.menu-item-has-children > .sub-menu {
position: static;
display: none;
flex-direction: column;
background: #f8f8f8;
border-left: 3px solid #6fc0a9;
margin: 6px 12px;
padding: 6px 0;
border-radius: 8px;
}
.menu-item-has-children.open > .sub-menu { display: flex; }
.overlay { display: none; position: fixed; inset: 0; background: rgba(0,0,0,0.38); z-index: 1300; }
.overlay.show { display: block; }
.tel-pc { display: none; }
.tel-mobile { display: block; }
} @media (min-width: 769px) {
nav ul.nav-menu > li.menu-item-has-children:hover > .sub-menu { display: block; }
nav, .header-inner { overflow: visible; }
} .hero {
margin-top: -80px; background: url(https://www.sato-futon.com/wp-content/themes/sato-futon-2025/images/hero-futon.jpg) center/cover no-repeat;
height: 80vh;
display:flex; align-items:center; justify-content:center;
text-align:center; color:#fff; position:relative;
border-bottom-left-radius:50px; border-bottom-right-radius:50px;
overflow:hidden;
}
.hero::before { content:""; position:absolute; top:0; left:0; right:0; bottom:0; background:rgba(106,156,141,0.35); }
.hero-content { position:relative; z-index:1; padding:0 20px; transform: translateY(40px); }
.hero h1 { font-size:2rem; margin-bottom:20px; font-weight:bold; text-shadow:1px 1px 5px rgba(0,0,0,0.3); } @media (max-width: 768px) {
.hero h1{
font-size: 1.5rem;
}
} .btn { display:inline-block; background:linear-gradient(135deg,#6fc0a9,#5aa689); color:#fff; padding:12px 25px; border-radius:30px; font-weight:bold; box-shadow:0 4px 8px rgba(0,0,0,0.2); transition:all 0.3s; }
.btn:hover { transform:translateY(-3px); box-shadow:0 8px 15px rgba(0,0,0,0.3); }
.hero-btn {
display: inline-block;
padding: 12px 30px;
background: linear-gradient(135deg, #f18f01, #f6b73c);
color: #fff;
font-weight: bold;
border-radius: 30px;
text-decoration: none;
transition: transform 0.3s ease, box-shadow 0.3s ease;
}
.hero-btn:hover {
transform: translateY(-3px);
box-shadow: 0 6px 14px rgba(0,0,0,0.15);
} .glass-section { padding:60px 5%; text-align:center; }  .glass-section h2 {
text-align: center; color: #5aa689;
position: relative;
font-weight: 700;
letter-spacing: 0.05em;
margin-bottom: 3.5rem; }
.glass-section h2::after {
content: "";
position: absolute;
bottom: -16px; left: 50%;
transform: translateX(-50%);
width: 80px;
height: 4px;
border-radius: 4px;
background: linear-gradient(90deg, #a8e0cf, #6fc0a9, #5aa689);
box-shadow: 0 2px 6px rgba(0, 0, 0, 0.1); opacity: 0;
transform: translate(-50%, 10px);
animation: lineFadeIn 1s ease forwards;
animation-delay: 0.3s;
}
@keyframes lineFadeIn {
to {
opacity: 1;
transform: translate(-50%, 0);
}
}
.service-list { display:grid; grid-template-columns:repeat(auto-fit,minmax(220px,1fr)); gap:30px; }
.glass-card {
background: rgba(255,255,255,0.3);
backdrop-filter: blur(12px);
-webkit-backdrop-filter: blur(12px);
border-radius: 25px;
box-shadow: 0 8px 25px rgba(0,0,0,0.1);
padding: 25px 20px;
transition: all 0.3s ease;
}
.glass-card:hover {
transform: translateY(-5px);
box-shadow: 0 12px 35px rgba(0,0,0,0.2);
}
.glass-card img { width:100%; border-radius:15px; margin-bottom:15px; }
.glass-card h3 { color:#5aa689; margin-bottom:10px; font-size:1.2rem; }
.glass-card p { color:#333; font-size:0.95rem; margin-bottom:10px; }
.glass-card .service-btn {
display:inline-block;
padding:10px 20px;
background: rgba(111,192,169,0.85);
color:#fff;
border-radius:20px;
font-weight:bold;
transition: all 0.3s;
}
.glass-card .service-btn:hover {
background: rgba(90,166,137,0.95);
transform: translateY(-2px);
} .button-accent {
display: inline-block;
margin-top: 1.2rem;
padding: 12px 30px;
background: linear-gradient(135deg, #f18f01, #f6b73c);
color: #fff;
font-weight: bold;
border-radius: 30px;
text-decoration: none;
transition: transform 0.3s ease, box-shadow 0.3s ease;
}
.button-accent:hover {
transform: translateY(-3px);
box-shadow: 0 6px 14px rgba(0,0,0,0.15);
} section h2,
.main-content h2,
.block h2 {
text-align: center;
font-size: 1.9rem!important;
color: #5aa689; 
position: relative;
font-weight: 700;
letter-spacing: 0.05em;
margin-bottom: 3.5rem;
opacity: 0;
transform: translateY(20px);
transition: all 0.6s ease;
}
section h2::after,
.main-content h2::after,
.block h2::after {
content: "";
position: absolute;
bottom: -16px;
left: 50%;
transform: translateX(-50%) translateY(10px);
width: 80px;
height: 4px;
border-radius: 4px;
background: linear-gradient(90deg, #a8e0cf, #6fc0a9, #5aa689);
box-shadow: 0 2px 6px rgba(0, 0, 0, 0.1);
opacity: 0;
transition: all 0.6s ease;
} section h2.inview,
.main-content h2.inview,
.block h2.inview {
opacity: 1;
transform: translateY(0);
}
section h2.inview::after,
.main-content h2.inview::after,
.block h2.inview::after {
opacity: 1;
transform: translateX(-50%) translateY(0);
} h3 {
font-size: 1.4rem;
color: #5a7b6f;
font-weight: 600;
text-align: center;
position: relative;
margin-bottom: 1.8rem;
letter-spacing: 0.05em;
} h3.underline::after {
content: "";
position: absolute;
bottom: -8px;
left: 50%;
transform: translateX(-50%) scaleX(0);
width: 50px;
height: 2px;
background: linear-gradient(90deg, #a0d6c2, #7bb89e);
border-radius: 2px;
transition: transform 0.4s ease;
opacity: 0.8;
} h3.underline.inview::after {
transform: translateX(-50%) scaleX(1);
} @media (max-width: 768px) {
section h2,
.main-content h2,
.block h2 {
font-size: 1.4rem!important; margin-bottom: 2.8rem;
}
section h2::after,
.main-content h2::after,
.block h2::after {
width: 60px;
height: 3px;
}
h3 {
font-size: 1.2rem;
margin-bottom: 1.6rem;
}
h3::after {
width: 40px;
height: 2px;
}
}  .news, .column { padding:60px 5%; }
.news h2, .column h2 { text-align:center; margin-bottom:40px; color:#5aa689; }
.news-list, .column-list { display:grid; grid-template-columns:repeat(auto-fit,minmax(250px,1fr)); gap:20px; }
.news-card, .column-card {
background: rgba(255,255,255,0.3);
backdrop-filter: blur(12px);
-webkit-backdrop-filter: blur(12px);
border-radius:20px;
padding:20px;
box-shadow:0 8px 20px rgba(0,0,0,0.08);
transition: all 0.3s ease;
}
.news-card:hover, .column-card:hover {
transform: translateY(-3px);
box-shadow: 0 12px 28px rgba(0,0,0,0.15);
}
.news-card img, .column-card img { width:100%; border-radius:12px; margin-bottom:12px; }
.news-card h3, .column-card h3 { margin-bottom:10px; font-size:1.05rem; color:#6fc0a9; }
.news-card p, .column-card p { font-size:0.9rem; color:#333; } .contact {
text-align:center;
padding:60px 5%;
background: rgba(111,192,169,0.15);
backdrop-filter: blur(10px);
border-radius:30px;
margin:50px auto;
max-width:1000px;
box-shadow:0 6px 20px rgba(0,0,0,0.08);
}
.contact h2 { font-size:2rem; margin-bottom:20px; color:#5aa689; }
.contact p { margin-bottom:20px; color:#333; } .contact-section-top {
background: linear-gradient(135deg, #f7fdfb, #e9f9f3);
text-align: center;
padding: 80px 20px;
border-radius: 20px;
box-shadow: 0 4px 20px rgba(0,0,0,0.05);
margin:50px auto;
max-width:1000px;
}
.contact-section-top h2 {
color: #5aa689; margin-bottom: 1rem;
}
.contact-lead-top {
font-size: 1rem;
color: #555;
margin-bottom: 2.5rem;
margin-top: 2.5rem;
}
.contact-actions-top {
display: flex;
flex-wrap: wrap;
justify-content: center;
gap: 20px;
}
.contact-btn-top {
display: flex;
align-items: center;
justify-content: center;
gap: 10px;
padding: 16px 32px;
font-size: 1.1rem;
font-weight: bold;
border-radius: 40px;
text-decoration: none;
transition: all 0.3s ease;
min-width: 260px;
}
.contact-btn-top i {
font-size: 1.3rem;
} .contact-btn-top.phone {
background: linear-gradient(135deg, #f18f01, #f6b73c);
color: #fff;
box-shadow: 0 6px 14px rgba(241,143,1,0.25);
}
.contact-btn-top.phone:hover {
transform: translateY(-3px);
box-shadow: 0 8px 18px rgba(241,143,1,0.35);
} .contact-btn-top.form {
background: linear-gradient(135deg, #6fc0a9, #5aa689);
color: #fff;
box-shadow: 0 6px 14px rgba(111,192,169,0.25);
}
.contact-btn-top.form:hover {
transform: translateY(-3px);
box-shadow: 0 8px 18px rgba(111,192,169,0.35);
}
.contact-btn-top small {
font-size: 0.85rem;
font-weight: normal;
opacity: 0.9;
margin-left: 6px;
} @media (max-width: 768px) {
.contact-section-top {
padding: 60px 16px;
}
.contact-btn-top {
min-width: 220px;
font-size: 1rem;
padding: 14px 24px;
}
.contact-btn-top span {
display: none; }
} footer {   background: linear-gradient(135deg, rgba(90,166,137,0.95), rgba(111,192,169,0.95));
color: #fff;
text-align: center;
padding: 24px;
font-size: 0.9rem;
border-top: 4px solid rgba(255,255,255,0.4); 
} .footer-nav {
margin-bottom: 20px;
}
.footer-nav ul {
list-style: none;
padding: 0;
margin: 0 auto;
display: flex;
flex-wrap: wrap;
justify-content: center;
gap: 0.8em 2em;
}
.footer-nav a {
color: #fff;
text-decoration: none;
font-size: 0.9rem;
position: relative;
transition: all 0.3s ease;
}
.footer-nav a::after {
content: "";
position: absolute;
bottom: -3px;
left: 50%;
width: 0;
height: 1px;
background: rgba(255, 255, 255, 0.8);
transition: all 0.3s ease;
transform: translateX(-50%);
}
.footer-nav a:hover::after {
width: 100%;
}
.footer-nav a:hover {
opacity: 0.9;
} @media (max-width: 768px) {
.footer-nav ul {
gap: 0.5em 1.2em;
}
.footer-nav a {
font-size: 0.85rem;
}
}   .news {
padding: 60px 5%;
background: #f9fdfb;
}
.news h2 {
text-align: center;
color: #5aa689;
margin-bottom: 40px;
font-weight: bold;
letter-spacing: 0.05em;
} .news-list {
display: grid;
grid-template-columns: repeat(2, 1fr);
gap: 24px;
}
@media (max-width: 768px) {
.news-list {
grid-template-columns: 1fr;
}
} .news-card {
display: block;
text-decoration: none;
color: #333;
background: linear-gradient(180deg, #ffffff 0%, #f2fbf7 100%);
border-radius: 16px;
padding: 20px 24px;
box-shadow: 0 4px 15px rgba(0,0,0,0.05);
transition: all 0.3s ease;
border: 1px solid rgba(111,192,169,0.15);
}
.news-card:hover {
transform: translateY(-4px);
box-shadow: 0 8px 22px rgba(0,0,0,0.12);
background: linear-gradient(180deg, #f8fffb 0%, #e9f8f2 100%);
} .news-date {
display: block;
font-size: 0.85rem;
color: #6fc0a9;
margin-bottom: 6px;
} .news-title {
font-size: 1rem;
font-weight: bold;
color: #333;
line-height: 1.5;
transition: color 0.3s ease;
}
.news-card:hover .news-title {
color: #5aa689;
} .news-more {
text-align: center;
margin-top: 40px;
}
.news-more .btn {
background: linear-gradient(135deg, #6fc0a9, #5aa689);
color: #fff;
padding: 12px 25px;
border-radius: 30px;
font-weight: bold;
display: inline-block;
transition: all 0.3s;
}
.news-more .btn:hover {
transform: translateY(-3px);
box-shadow: 0 8px 15px rgba(0, 0, 0, 0.3);
} .news-archive {
padding: 60px 0;
margin-top:45px;
}
.news-archive .inner {
max-width: 1000px;
margin: 0 auto;
padding: 0 20px;
}
.news-archive h1 {
font-size: 2rem;
text-align: center;
margin-bottom: 40px;
color: #5aa689;
} .news-archive-list {
display: grid;
grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
gap: 30px;
} .news-archive-list a.news-card {
display: flex;
flex-direction: column;
background: #fff;
border-radius: 18px;
overflow: hidden;
text-decoration: none;
color: inherit;
box-shadow: 0 4px 15px rgba(0, 0, 0, 0.05);
transition: all 0.3s ease;
}
.news-archive-list a.news-card:hover {
transform: translateY(-5px);
box-shadow: 0 12px 30px rgba(0, 0, 0, 0.15);
} .news-archive-list .news-thumb img {
width: 100%;
height: 180px;
object-fit: cover;
} .news-card-body {
padding: 15px 18px 20px;
display: flex;
flex-direction: column;
flex-grow: 1;
} .news-card-body .news-date {
font-size: 0.85rem;
color: #6fa593;
font-weight: 500;
margin-bottom: 0.4rem;
font-family: "Noto Sans JP", sans-serif;
letter-spacing: 0.03em;
} .news-card-body .news-title {
font-size: 1.05rem;
font-weight: 700;
color: #333;
margin-bottom: 0.6rem;
line-height: 1.5;
border-left: 4px solid #5aa689;
padding-left: 10px;
transition: color 0.3s ease;
}
.news-archive-list a.news-card:hover .news-title {
color: #5aa689;
} .news-card-body .news-excerpt {
font-size: 0.9rem;
color: #555;
line-height: 1.7;
margin-top: auto;
} @media (max-width: 480px) {
.news-archive h1 {
font-size: 1.6rem;
}
.news-archive-list {
gap: 20px;
}
.news-card-body {
padding: 12px 15px 16px;
}
.news-card-body .news-title {
font-size: 1rem;
border-left-width: 3px;
}
.news-card-body .news-excerpt {
font-size: 0.85rem;
}
} body.single-news {
margin: 0;
padding: 0;
} body.single-news header.site-header {
height: 72px; display: flex;
align-items: center;
padding: 0 5%;
box-shadow: 0 2px 10px rgba(0,0,0,0.08);
z-index: 1200;
} body.single-news .logo img {
height: 50px; width: auto;
display: block;
} body.single-news .header-right {
display: flex;
align-items: center;
gap: 10px;
} body.single-news nav ul.nav-menu {
display: flex;
align-items: center;
gap: 5px;
} body.single-news .single-news {
max-width: 1000px; margin: 100px auto 80px; padding: 0 20px;
} body.single-news .single-news img { width:100%; border-radius:12px; margin-bottom:25px; }
body.single-news .single-news .content { line-height:1.8; color:#333; font-size:1rem; } body.single-news .single-news .back-link { text-align:center; margin-top:50px; }
body.single-news .single-news .back-link a {
display:inline-block;
padding:10px 20px;
background: linear-gradient(135deg,#6fc0a9,#5aa689);
color:#fff;
border-radius:25px;
text-decoration:none;
transition: all 0.3s;
}
body.single-news .single-news .back-link a:hover {
transform: translateY(-3px);
box-shadow:0 8px 15px rgba(0,0,0,0.2);
} @media (max-width: 768px) {
body.single-news-page header.site-header {
padding: 0 5%; height: 64px;
display: flex;
align-items: center;
justify-content: space-between;
}
body.single-news-page .header-inner {
padding: 0; width: 100%;
display: flex;
align-items: center;
justify-content: space-between;
}
body.single-news-page .logo {
margin-left: 0; }
body.single-news-page .header-right {
margin-right: 0; } body.single-news-page .hamburger {
display: flex;
} body.single-news-page .tel-pc {
display: none;
}
body.single-news-page .tel-mobile {
display: block;
}
}  .single-news h1 {
font-size: 2.2rem;
font-weight: 700;
color: #333;
text-align: center;
position: relative;
margin: 2.5rem auto 1.2rem;
line-height: 1.5;
letter-spacing: 0.05em;
font-family: "Noto Sans JP", sans-serif;
} .single-news h1::after {
content: "";
display: block;
width: 80px;
height: 4px;
background: linear-gradient(90deg, #a8e0cf, #6fc0a9, #5aa689);
border-radius: 4px;
margin: 0.8rem auto 0;
box-shadow: 0 2px 6px rgba(0, 0, 0, 0.1);
} .single-news .post-date {
text-align: center;
color: #6fa593;
font-size: 0.95rem;
margin-bottom: 2.5rem;
font-weight: 500;
letter-spacing: 0.03em;
font-family: "Noto Sans JP", sans-serif;
position: relative;
} .single-news .post-date::before {
content: "\f133"; font-family: "Font Awesome 6 Free";
font-weight: 900;
margin-right: 6px;
color: #5aa689;
}
@media (max-width: 480px) {
.single-news h1 {
font-size: 1.6rem;
margin: 2rem auto 1rem;
}
.single-news .post-date {
font-size: 0.85rem;
margin-bottom: 2rem;
}
} .single-news .post-content,
.single-column .post-content {
max-width: 800px;
margin: 0 auto;
}   .news-article {
max-width: 800px;
margin: 2em auto;
padding: 2.5em 2em;
line-height: 1.9;
color: #333;
font-size: 1rem;
background: #fff;
border-radius: 16px;
box-shadow: 0 4px 12px rgba(90,166,137,0.08);
border: 1px solid rgba(90,166,137,0.08);
transition: box-shadow 0.2s ease, transform 0.2s ease;
}
.news-article:hover {
transform: translateY(-2px);
box-shadow: 0 6px 18px rgba(90,166,137,0.12);
} .news-article h1 {
font-size: 1.8rem;
line-height: 1.4;
text-align: center;
color: #356b57;
margin-bottom: 1em;
}
.news-article h1 small {
display: block;
font-size: 1rem;
color: #666;
margin-top: 0.5em;
}
.news-article h2 {
font-size: 1.3rem;
color: #5aa689;
border-left: 5px solid #5aa689;
padding-left: 0.7em;
margin: 2em 0 1em;
}
.news-article h3 {
font-size: 1.1rem;
color: #356b57;
margin-top: 1.5em;
} .news-article p {
margin-bottom: 1.2em;
} .news-article ul,
.news-article ol {
margin: 1em 0 1.5em 1.5em;
}
.news-article ul li,
.news-article ol li {
margin-bottom: 0.5em;
} .news-article .cta-box {
background: #f5faf7;
border-left: 5px solid #5aa689;
padding: 1.5em;
margin: 2em 0;
border-radius: 8px;
box-shadow: 0 2px 6px rgba(0,0,0,0.05);
} .news-article .btn {
display: inline-block;
background: #5aa689;
color: #fff !important;
padding: 0.8em 1.5em;
border-radius: 4px;
text-decoration: none;
transition: background 0.3s ease;
}
.news-article .btn:hover {
background: #498f74;
} .news-article blockquote {
border-left: 4px solid #5aa689;
background: #f9fdfb;
padding: 1em 1.5em;
font-style: italic;
color: #555;
margin: 1.5em 0;
} @media (max-width: 768px) {
.news-article {
padding: 1.5em 1em;
font-size: 0.95rem;
}
.news-article h1 {
font-size: 1.5rem;
}
.news-article h2 {
font-size: 1.15rem;
}
} .post-navigation {
display: flex;
justify-content: space-between;
align-items: center;
gap: 1rem;
margin: 3rem auto 5rem;
max-width: 800px;
padding-top: 2rem;
border-top: 1px solid #d8e8e1;
font-family: "Noto Sans JP", sans-serif;
}
.post-navigation a {
display: inline-block;
padding: 0.7em 1.4em;
border-radius: 30px;
background: #fff;
border: 1.5px solid #5aa689;
color: #5aa689;
text-decoration: none;
font-weight: 600;
font-size: 0.95rem;
transition: all 0.25s ease;
box-shadow: 0 2px 6px rgba(90, 166, 137, 0.1);
} .post-navigation a:hover {
background: linear-gradient(135deg, #5aa689, #6fc0a9);
color: #fff;
transform: translateY(-2px);
box-shadow: 0 4px 10px rgba(90, 166, 137, 0.25);
} .post-navigation .nav-previous {
text-align: left;
flex: 1;
}
.post-navigation .nav-next {
text-align: right;
flex: 1;
} @media (max-width: 480px) {
.post-navigation {
flex-direction: column;
gap: 1rem;
}
.post-navigation .nav-previous,
.post-navigation .nav-next {
text-align: center;
}
} .column-card {
display: block; text-decoration: none;
color: inherit;
background: rgba(255,255,255,0.3);
backdrop-filter: blur(12px);
-webkit-backdrop-filter: blur(12px);
border-radius: 20px;
padding: 20px;
box-shadow: 0 8px 20px rgba(0,0,0,0.08);
transition: all 0.3s ease;
}
.column-card:hover {
transform: translateY(-3px);
box-shadow: 0 12px 28px rgba(0,0,0,0.15);
}
.column-thumb img {
width: 100%;
border-radius: 12px;
margin-bottom: 12px;
}
.column-content {
display: flex;
flex-direction: column;
gap: 8px;
}
.column-title {
font-size: 1.05rem;
font-weight: bold;
color: #6fc0a9;
}
.column-excerpt {
font-size: 0.9rem;
color: #333;
line-height: 1.6;
} .column-more {
text-align: center;
margin-top: 40px;
}
.column-more .btn {
background: linear-gradient(135deg, #6fc0a9, #5aa689);
color: #fff;
padding: 12px 25px;
border-radius: 30px;
font-weight: bold;
display: inline-block;
transition: all 0.3s;
}
.column-more .btn:hover {
transform: translateY(-3px);
box-shadow: 0 8px 15px rgba(0,0,0,0.3);
} body.single-column {
margin: 0;
padding: 0;
} body.single-column header.site-header {
height: 72px; display: flex;
align-items: center;
padding: 0 5%;
box-shadow: 0 2px 10px rgba(0,0,0,0.08);
z-index: 1200;
} body.single-column .logo img {
height: 50px; width: auto;
display: block;
} body.single-column .header-right {
display: flex;
align-items: center;
gap: 10px;
} body.single-column nav ul.nav-menu {
display: flex;
align-items: center;
gap: 5px;
} body.single-column .single-column {
max-width: 1000px; margin: 100px auto 80px; padding: 0 20px;
} body.single-column .single-column img { width:100%; border-radius:12px; margin-bottom:25px; }
body.single-column .single-column .content { line-height:1.8; color:#333; font-size:1rem; } body.single-column .single-column .back-link { text-align:center; margin-top:50px; }
body.single-column .single-column .back-link a {
display:inline-block;
padding:10px 20px;
background: linear-gradient(135deg,#6fc0a9,#5aa689);
color:#fff;
border-radius:25px;
text-decoration:none;
transition: all 0.3s;
}
body.single-column .single-column .back-link a:hover {
transform: translateY(-3px);
box-shadow:0 8px 15px rgba(0,0,0,0.2);
}  .single-column h1 {
font-size: 2.2rem;
font-weight: 700;
color: #333;
text-align: center;
position: relative;
margin: 2.5rem auto 1.2rem;
line-height: 1.5;
letter-spacing: 0.05em;
font-family: "Noto Sans JP", sans-serif;
} .single-column h1::after {
content: "";
display: block;
width: 80px;
height: 4px;
background: linear-gradient(90deg, #a8e0cf, #6fc0a9, #5aa689);
border-radius: 4px;
margin: 0.8rem auto 0;
box-shadow: 0 2px 6px rgba(0, 0, 0, 0.1);
} .single-column .post-date {
text-align: center;
color: #6fa593;
font-size: 0.95rem;
margin-bottom: 2.5rem;
font-weight: 500;
letter-spacing: 0.03em;
font-family: "Noto Sans JP", sans-serif;
position: relative;
} .single-column .post-date::before {
content: "\f133"; font-family: "Font Awesome 6 Free";
font-weight: 900;
margin-right: 6px;
color: #5aa689;
}
@media (max-width: 480px) {
.single-column h1 {
font-size: 1.6rem;
margin: 2rem auto 1rem;
}
.single-column .post-date {
font-size: 0.85rem;
margin-bottom: 2rem;
}
}  .column-article {
max-width: 800px;
margin: 2em auto;
padding: 2.5em 2em;
line-height: 1.9;
color: #333;
font-size: 1rem;
background: #fff;
border-radius: 16px;
box-shadow: 0 4px 12px rgba(90,166,137,0.08);
border: 1px solid rgba(90,166,137,0.08);
transition: box-shadow 0.2s ease, transform 0.2s ease;
}
.column-article:hover {
transform: translateY(-2px);
box-shadow: 0 6px 18px rgba(90,166,137,0.12);
} .column-article h1 {
font-size: 1.8rem;
line-height: 1.4;
text-align: center;
color: #356b57;
margin-bottom: 1em;
}
.column-article h1 small {
display: block;
font-size: 1rem;
color: #666;
margin-top: 0.5em;
}
.column-article h2 {
font-size: 1.3rem;
color: #5aa689;
border-left: 5px solid #5aa689;
padding-left: 0.7em;
margin: 2em 0 1em;
}
.column-article h3 {
font-size: 1.1rem;
color: #356b57;
margin-top: 1.5em;
} .column-article p {
margin-bottom: 1.2em;
} .column-article ul,
.column-article ol {
margin: 1em 0 1.5em 1.5em;
}
.column-article ul li,
.column-article ol li {
margin-bottom: 0.5em;
} .column-article .cta-box {
background: #f5faf7;
border-left: 5px solid #5aa689;
padding: 1.5em;
margin: 2em 0;
border-radius: 8px;
box-shadow: 0 2px 6px rgba(0,0,0,0.05);
} .column-article .btn {
display: inline-block;
background: #5aa689;
color: #fff !important;
padding: 0.8em 1.5em;
border-radius: 4px;
text-decoration: none;
transition: background 0.3s ease;
}
.column-article .btn:hover {
background: #498f74;
} .column-article blockquote {
border-left: 4px solid #5aa689;
background: #f9fdfb;
padding: 1em 1.5em;
font-style: italic;
color: #555;
margin: 1.5em 0;
} @media (max-width: 768px) {
.column-article {
padding: 1.5em 1em;
font-size: 0.95rem;
}
.column-article h1 {
font-size: 1.5rem;
}
.column-article h2 {
font-size: 1.15rem;
}
} .column-faq {
margin-top: 2em;
}
.column-faq h2 {
font-size: 1.4rem;
color: #5aa689;
border-left: 5px solid #5aa689;
padding-left: 0.6em;
margin-bottom: 1em;
}
.faq-item {
border-bottom: 1px solid #e0e0e0;
padding: 0.6em 0;
}
.faq-question {
background: none;
border: none;
font-weight: bold;
font-size: 1rem;
width: 100%;
text-align: left;
padding: 0.6em 0;
cursor: pointer;
color: #333;
position: relative;
}
.faq-question::after {
content: '+';
position: absolute;
right: 0;
color: #5aa689;
font-size: 1.2rem;
transition: transform 0.2s ease;
}
.faq-question.active::after {
content: '?';
}
.faq-answer {
display: none;
padding: 0.4em 0 0.8em 0.5em;
color: #555;
line-height: 1.7;
} .futon-table {
width: 100%;
border-collapse: collapse;
margin: 1.5em 0;
font-size: 0.95rem;
}
.futon-table th, .futon-table td {
border: 1px solid #ddd;
padding: 10px;
text-align: left;
}
.futon-table th {
background: #f5faf7;
color: #356b57;
}
.futon-table tr:nth-child(even) {
background: #fafdfb;
} @media (max-width: 768px) {
.faq-question {
font-size: 0.95rem;
}
.futon-table th, .futon-table td {
padding: 8px;
font-size: 0.9rem;
}
} @media (max-width: 768px) {
body.single-column-page header.site-header {
padding: 0 5%; height: 64px;
display: flex;
align-items: center;
justify-content: space-between;
}
body.single-column-page .header-inner {
padding: 0; width: 100%;
display: flex;
align-items: center;
justify-content: space-between;
}
body.single-column-page .logo {
margin-left: 0; }
body.single-column-page .header-right {
margin-right: 0; } body.single-column-page .hamburger {
display: flex;
} body.single-column-page .tel-pc {
display: none;
}
body.single-column-page .tel-mobile {
display: block;
}
} .pagination {
display: flex;
justify-content: center;
margin: 3rem 0;
}
.pagination .nav-links {
display: flex;
gap: 8px;
flex-wrap: wrap;
justify-content: center;
}
.pagination .page-numbers {
display: inline-flex;
justify-content: center;
align-items: center;
width: 42px;
height: 42px;
border-radius: 50%;
border: 1.5px solid #5aa689;
color: #5aa689;
background: #fff;
font-weight: 600;
text-decoration: none;
transition: all 0.25s ease;
} .pagination .page-numbers.current {
background: linear-gradient(135deg, #5aa689, #6fc0a9);
color: #fff;
border: none;
box-shadow: 0 3px 8px rgba(90, 166, 137, 0.3);
} .pagination .page-numbers:hover:not(.current) {
background: #5aa689;
color: #fff;
transform: translateY(-2px);
box-shadow: 0 3px 6px rgba(90, 166, 137, 0.25);
} .pagination .prev,
.pagination .next {
width: auto;
padding: 0 1.2em;
border-radius: 20px;
font-size: 0.95rem;
} @media (max-width: 480px) {
.pagination .page-numbers {
width: 36px;
height: 36px;
font-size: 0.85rem;
}
.pagination .prev,
.pagination .next {
padding: 0 1em;
font-size: 0.9rem;
}
} .back-to-top {
position: fixed;
bottom: 90px;
right: 10px;
width: 55px;
height: 55px;
background: #3fa36c;
border-radius: 50%;
box-shadow: 0 4px 10px rgba(0,0,0,0.2);
cursor: pointer;
opacity: 0;
visibility: hidden;
transform: translateY(30px);
transition: all 0.4s ease;
z-index: 999;
} .back-to-top::before {
content: "";
position: absolute;
top: 50%;
left: 50%;
width: 14px;
height: 14px;
border-left: 3px solid #fff;
border-top: 3px solid #fff;
transform: translate(-50%, -30%) rotate(45deg);
} .back-to-top:hover {
background: #2f8b5a;
transform: translateY(0) scale(1.1);
} .back-to-top.show {
opacity: 1;
visibility: visible;
transform: translateY(0);
} @media screen and (max-width: 768px) {
.back-to-top {
display: none;
}
} body.page {
background: #f5f9fb;
color: #333;
font-family: "Noto Sans JP",sans-serif;
line-height: 1.6;
} .page-content {
max-width: 1000px;
margin: 100px auto 80px auto; padding: 0 20px;
} .page-header {
margin-bottom: 40px;
}
.page-header .page-title {
font-size: 2rem;
color: #5aa689;
border-left: 6px solid #6fc0a9;
padding-left: 12px;
margin-bottom: 20px;
} .page-body {
font-size: 1rem;
line-height: 1.8;
color: #333;
}
.page-body p {
margin-bottom: 20px;
}
.page-body h2, .page-body h3 {
color: #5aa689;
margin: 30px 0 15px 0;
}
.page-body a {
color: #6fc0a9;
text-decoration: underline;
}
.page-body img {
max-width: 100%;
height: auto;
border-radius: 12px;
margin-bottom: 25px;
} .breadcrumb {
font-size: 0.9rem;
margin-bottom: 20px;
color: #555;
}
.breadcrumb a {
color: #5aa689;
text-decoration: none;
transition: color 0.3s;
}
.breadcrumb a:hover {
color: #6fc0a9;
}
.breadcrumb span {
color: #333;
} @media (max-width: 768px) {
.page-content {
margin: 80px 15px 60px 15px;
padding: 0;
}
.page-header .page-title {
font-size: 1.6rem;
} } .hero-page-rental {
margin-top: -54px; background: url(https://www.sato-futon.com/wp-content/themes/sato-futon-2025/images/hero-futon-rental.jpg) center/cover no-repeat;
height: 80vh;
display:flex; align-items:center; justify-content:center;
text-align:center; color:#fff; position:relative;
border-bottom-left-radius:50px; border-bottom-right-radius:50px;
overflow:hidden;
}
.hero-page-rental::before { content:""; position:absolute; top:0; left:0; right:0; bottom:0; background:rgba(106,156,141,0.35); }
.hero-page-rental-content { position:relative; z-index:1; padding:0 20px; transform: translateY(40px); }
.hero-page-rental h1 { font-size:2rem; margin-bottom:20px; font-weight:bold; text-shadow:1px 1px 5px rgba(0,0,0,0.3); } @media (max-width: 768px) {
.hero-page-rental h1{
font-size: 1.5rem;
}
.hero-page-rental-baby h1{
font-size: 1.5rem;
}
.hero-page-shop h1{
font-size: 1.5rem;
}
.hero-page-contact h1{
font-size: 1.5rem;
}
.hero-page-reform h1{
font-size: 1.5rem;
}
.hero-page-contact h1{
font-size: 1.5rem;
}
.hero-page-reform h1{
font-size: 1.5rem;
}
.hero-page-cleaning h1{
font-size: 1.5rem;
}
.hero-page-sales h1{
font-size: 1.5rem;
}
} .hero-page-rental-baby {
margin-top: -54px; background: url(https://www.sato-futon.com/wp-content/themes/sato-futon-2025/images/hero-futon-rental-baby.jpg) center/cover no-repeat;
height: 80vh;
display:flex; align-items:center; justify-content:center;
text-align:center; color:#fff; position:relative;
border-bottom-left-radius:50px; border-bottom-right-radius:50px;
overflow:hidden;
}
.hero-page-rental-baby::before { content:""; position:absolute; top:0; left:0; right:0; bottom:0; background:rgba(106,156,141,0.35); }
.hero-page-rental-content-baby { position:relative; z-index:1; padding:0 20px; transform: translateY(40px); }
.hero-page-rental-baby h1 { font-size:2rem; margin-bottom:20px; font-weight:bold; text-shadow:1px 1px 5px rgba(0,0,0,0.3); } @media (max-width: 768px) {
.hero-page-rental-baby h1{
font-size: 1.5rem;
}
} .hero-page-shop {
margin-top: -95px; background: url(https://www.sato-futon.com/wp-content/themes/sato-futon-2025/images/hero-shop.jpg) center/cover no-repeat;
height: 80vh;
display:flex; align-items:center; justify-content:center;
text-align:center; color:#fff; position:relative;
border-bottom-left-radius:50px; border-bottom-right-radius:50px;
overflow:hidden;
}
.hero-page-shop::before { content:""; position:absolute; top:0; left:0; right:0; bottom:0; background:rgba(106,156,141,0.35); }
.hero-page-shop { position:relative; z-index:1; padding:0 20px; transform: translateY(40px); }
.hero-page-shop h1 { font-size:2rem; margin-bottom:20px; font-weight:bold; text-shadow:1px 1px 5px rgba(0,0,0,0.3); } @media (max-width: 768px) {
.hero-page-shop h1{
font-size: 1.5rem;
}
} .hero-page-contact {
margin-top: -95px; background: url(https://www.sato-futon.com/wp-content/themes/sato-futon-2025/images/hero-contact.jpg) center/cover no-repeat;
height: 80vh;
display:flex; align-items:center; justify-content:center;
text-align:center; color:#fff; position:relative;
border-bottom-left-radius:50px; border-bottom-right-radius:50px;
overflow:hidden;
}
.hero-page-contact::before { content:""; position:absolute; top:0; left:0; right:0; bottom:0; background:rgba(106,156,141,0.35); }
.hero-page-contact { position:relative; z-index:1; padding:0 20px; transform: translateY(40px); }
.hero-page-contact h1 { font-size:2rem; margin-bottom:20px; font-weight:bold; text-shadow:1px 1px 5px rgba(0,0,0,0.3); } @media (max-width: 768px) {
.hero-page-contact h1{
font-size: 1.5rem;
}
} .hero-page-reform {
margin-top: -95px; background: url(https://www.sato-futon.com/wp-content/themes/sato-futon-2025/images/hero-reform.jpg) center/cover no-repeat;
height: 80vh;
display:flex; align-items:center; justify-content:center;
text-align:center; color:#fff; position:relative;
border-bottom-left-radius:50px; border-bottom-right-radius:50px;
overflow:hidden;
}
.hero-page-reform::before { content:""; position:absolute; top:0; left:0; right:0; bottom:0; background:rgba(106,156,141,0.35); }
.hero-page-reform { position:relative; z-index:1; padding:0 20px; transform: translateY(40px); }
.hero-page-reform h1 { font-size:2rem; margin-bottom:20px; font-weight:bold; text-shadow:1px 1px 5px rgba(0,0,0,0.3); } @media (max-width: 768px) {
.hero-page-reform h1{
font-size: 1.5rem;
}
} .hero-page-cleaning {
margin-top: -95px; background: url(https://www.sato-futon.com/wp-content/themes/sato-futon-2025/images/hero-cleaning.jpg) center/cover no-repeat;
height: 80vh;
display:flex; align-items:center; justify-content:center;
text-align:center; color:#fff; position:relative;
border-bottom-left-radius:50px; border-bottom-right-radius:50px;
overflow:hidden;
}
.hero-page-cleaning::before { content:""; position:absolute; top:0; left:0; right:0; bottom:0; background:rgba(106,156,141,0.35); }
.hero-page-cleaning { position:relative; z-index:1; padding:0 20px; transform: translateY(40px); }
.hero-page-cleaning h1 { font-size:2rem; margin-bottom:20px; font-weight:bold; text-shadow:1px 1px 5px rgba(0,0,0,0.3); } @media (max-width: 768px) {
.hero-page-cleaning h1{
font-size: 1.5rem;
}
} .hero-page-sales {
margin-top: -95px; background: url(https://www.sato-futon.com/wp-content/themes/sato-futon-2025/images/hero-sales.jpg) center/cover no-repeat;
height: 80vh;
display:flex; align-items:center; justify-content:center;
text-align:center; color:#fff; position:relative;
border-bottom-left-radius:50px; border-bottom-right-radius:50px;
overflow:hidden;
}
.hero-page-sales::before { content:""; position:absolute; top:0; left:0; right:0; bottom:0; background:rgba(106,156,141,0.35); }
.hero-page-sales { position:relative; z-index:1; padding:0 20px; transform: translateY(40px); }
.hero-page-sales h1 { font-size:2rem; margin-bottom:20px; font-weight:bold; text-shadow:1px 1px 5px rgba(0,0,0,0.3); } @media (max-width: 768px) {
.hero-page-sales h1{
font-size: 1.5rem;
}
} body.page.all-page {
background: #f9fcfa;
}
body.page.all-page-area {
background: #f9fcfa;
}  .page-hero {
text-align: center;
background: linear-gradient(135deg, #e5f5ef, #ffffff);
padding: 60px 20px;
border-radius: 16px;
margin-bottom: 50px;
}
.page-hero .page-title {
font-size: 2.2rem;
color: #5aa689;
margin-bottom: 15px;
}
.page-hero .lead {
font-size: 1.1rem;
color: #333;
} .all-page section {
margin-bottom: 60px;
} .page-table-wrapper {
position: relative;
margin-bottom: 2em;
} .page-table {
width: 100%; border-collapse: collapse;
border-radius: 8px;
overflow: hidden;
background: #fff;
}
.page-table th, .page-table td {
padding: 12px 15px;
border-bottom: 1px solid #eee;
word-break: break-word;
}
.page-table th {
background: #2e7d32;
color: #fff;
width:30%;
text-align: center;
}
.page-table td {
width:70%;
}
.page-table tr:last-child td {
border-bottom: none;
}
.page-section {
background: #f9fafb;
padding: 60px 20px;
color: #333;
}
.page-section .container {
max-width: 900px;
margin: 0 auto;
}
.page-section p{
margin-bottom:20px;
} body.page.rental-page {
background: #f9fcfa;
}
body.page.rental-page-area {
background: #f9fcfa;
}
body.page.rental-page-area .flow-step {
opacity: 1 !important;
transform: none !important;
} .rental-hero {
text-align: center;
background: linear-gradient(135deg, #e5f5ef, #ffffff);
padding: 60px 20px;
border-radius: 16px;
margin-bottom: 50px;
}
.rental-hero .page-title {
font-size: 2.2rem;
color: #5aa689;
margin-bottom: 15px;
}
.rental-hero .lead {
font-size: 1.1rem;
color: #333;
}
.rental-hero .sub{
margin-top:10px;
font-size:0.9rem;
} .rental-page section {
margin-bottom: 60px;
}  .price-table {
width: 100%;
border-collapse: collapse;
}
.price-table th, .price-table td {
border: 1px solid #ccc;
padding: 12px;
text-align: center;
}
.price-table th {
background: #f0f7f5;
} .rental-section {
background: #f9fafb;
padding: 60px 20px;
color: #333;
}
.rental-section .container {
max-width: 900px;
margin: 0 auto;
}
.rental-section p{
margin-bottom:20px;
} .section-sub {
text-align: center;
margin-bottom: 2em;
color: #555;
}
.rental-subtitle {
display: flex;
justify-content: center;
align-items: center;
width: 100%;
background: linear-gradient(135deg, #4caf50, #2e7d32); color: #fff; font-weight: 700;
font-size: 1.6rem;
padding: 16px 24px;
border-radius: 12px;
box-shadow: 0 4px 14px rgba(0,0,0,0.12);
margin: 2.5em 0;
position: relative;
border-bottom: 4px solid rgba(255,255,255,0.8);
box-sizing: border-box;
text-shadow: 1px 1px 2px rgba(0,0,0,0.3); }
.rental-subtitle-text {
text-align: center;
line-height: 1.2;
}
.rental-subtitle-text small {
display: block;
font-size: 0.9rem;
color: rgba(255,255,255,0.85);
margin-top: 4px;
} .rental-subtitle-icon {
position: absolute;
right: 16px;
top: 50%;
transform: translateY(-50%);
}
.rental-image {
text-align: center;
margin-bottom: 2em;
}
.rental-image img {
max-width: 100%;
height: auto;
border-radius: 10px;
box-shadow: 0 4px 12px rgba(0,0,0,0.1);
}
.rental-items {
list-style: none;
background: #fff;
padding: 20px 30px;
border-radius: 10px;
margin-bottom: 40px;
box-shadow: 0 2px 8px rgba(0,0,0,0.05);
line-height: 1.6;
}
.rental-items li {
display: flex;
align-items: flex-start;
margin-bottom: 14px;
}
.rental-items span {
display: inline-flex;
align-items: center;
justify-content: center;
width: 28px;
height: 28px;
background: #6fc0a9;
color: #fff;
font-weight: 700;
border-radius: 50%;
margin-right: 10px;
font-size: 1rem;
box-shadow: 0 2px 6px rgba(0,0,0,0.1);
flex-shrink: 0;
} .rental-items li div {
flex: 1;
white-space: normal;
word-break: break-word;
line-height: 1.6;
}
.red{
color:#cc0000;
} .price-title {
font-size: 1.4rem;
margin-bottom: 0.5em;
color: #2e7d32;
}
.note {
font-size: 0.9rem;
color: #666;
margin-bottom: 1em;
} .rental-table-wrapper {
position: relative;
margin-bottom: 2em;
} .rental-table {
width: 100%;
table-layout: fixed; border-collapse: collapse;
border-radius: 8px;
overflow: hidden;
background: #fff;
}
.rental-table th, .rental-table td {
padding: 12px 15px;
border-bottom: 1px solid #eee;
text-align: center;
word-break: break-word;
}
.rental-table th {
background: #2e7d32;
color: #fff;
}
.rental-table tr:last-child td {
border-bottom: none;
} .rental-hidden {
display: none;
} .table-fade {
position: absolute;
bottom: 50px; left: 0;
width: 100%;
height: 100px;
background: linear-gradient(to bottom, rgba(255,255,255,0), #fff 90%);
pointer-events: none;
border-radius: 0 0 8px 8px;
} .toggle-table-btn {
display: block;
margin: 0 auto;
padding: 12px 28px;
background: #6fc0a9;
color: #fff;
border: none;
border-radius: 30px;
font-weight: bold;
font-size: 1rem;
cursor: pointer;
text-align: center;
transition: 0.3s;
}
.toggle-table-btn:hover {
background: #5aa689;
box-shadow: 0 4px 12px rgba(0,0,0,0.15);
} .rental-table-wrapper.open .rental-hidden {
display: table-row;
}
.rental-table-wrapper.open .table-fade {
display: none;
} .rental-notes {
list-style: none;
margin-top: 1.5em;
font-size: 0.95rem;
color: #555;
}
.rental-notes li {
margin-bottom: 0.3em;
} .shipping-title {
font-size: 1.2rem;
margin-top: 2em;
margin-bottom: 0.5em;
color: #2e7d32;
} .shipping-wrapper {
margin: 20px 0 40px 0;
position: relative;
} .toggle-shipping-btn {
display: block;
margin: 0 auto 10px auto;
padding: 12px 28px;
background: #f39c12; color: #fff;
border: none;
border-radius: 30px;
font-weight: bold;
font-size: 1rem;
cursor: pointer;
text-align: center;
transition: 0.3s;
box-shadow: 0 2px 6px rgba(0,0,0,0.1);
}
.toggle-shipping-btn:hover {
background: #e67e22; box-shadow: 0 4px 12px rgba(0,0,0,0.15);
} .shipping-table-wrapper {
overflow: hidden;
max-height: 0;
opacity: 0;
transition: all 0.5s ease;
}
.shipping-table-wrapper.open {
max-height: 1000px; opacity: 1;
}
.shipping-table {
width: 100%;
border-collapse: collapse;
background: #fff;
box-shadow: 0 2px 8px rgba(0,0,0,0.05);
border-radius: 8px;
overflow: hidden;
}
.shipping-table td {
padding: 12px 15px;
border-bottom: 1px solid #eee;
text-align: center;
}
.shipping-table tr:last-child td {
border-bottom: none;
} .rental-items {
list-style: none;
background: #fff;
padding: 20px 30px;
border-radius: 10px;
margin-bottom: 40px;
box-shadow: 0 2px 8px rgba(0,0,0,0.05);
line-height: 1.6;
}
.rental-items li {
margin-bottom: 10px;
line-height: 1.6;
display: flex;
align-items: flex-start;
flex-wrap: wrap;
}
.rental-items span {
display: inline-flex;
align-items: center;
justify-content: center;
width: 28px;
height: 28px;
background: #6fc0a9;
color: #fff;
font-weight: 700;
border-radius: 50%;
margin-right: 8px;
font-size: 1rem;
box-shadow: 0 2px 6px rgba(0,0,0,0.1);
flex-shrink: 0;
}
.rental-items li > br {
flex-basis: 100%;
height: 0;
}
@media (max-width: 600px) {
.section-title {
font-size: 1.6rem;
}
.rental-items {
padding: 15px 20px;
}
.rental-table th, .rental-table td {
font-size: 0.9rem;
}
}  .rental-flow {
background: #f9fafb;
padding: 60px 20px;
color: #333;
}
.rental-flow .container {
max-width: 900px;
margin: 0 auto;
} .rental-flow .section-title {
text-align: center;
font-size: 2rem;
color: #5aa689;
font-weight: 700;
margin-bottom: 3.5rem;
position: relative;
} .flow-step {
display: flex;
gap: 20px;
margin-bottom: 40px;
align-items: flex-start;
opacity: 0;
transform: translateY(20px);
transition: opacity 0.8s ease, transform 0.8s ease;
}
.flow-step.inview {
opacity: 1;
transform: translateY(0);
}
.flow-step .step-number {
flex-shrink: 0;
width: 80px;
height: 80px;
border-radius: 50%;
background: linear-gradient(135deg, #f18f01, #f6b73c);
color: #fff;
font-weight: bold;
display: flex;
align-items: center;
justify-content: center;
font-size: 1rem;
box-shadow: 0 4px 10px rgba(0,0,0,0.15);
}
.flow-step .step-content {
flex: 1;
background: #fff;
padding: 20px 25px;
border-radius: 12px;
box-shadow: 0 4px 12px rgba(0,0,0,0.08);
}  .flow-step h3.has-line::after {
content: "";
position: absolute;
bottom: -6px;
left: 0;
width: 50px;
height: 2px;
background: linear-gradient(90deg, #a0d6c2, #7bb89e);
border-radius: 2px;
} .flow-step p {
font-size: 1rem;
line-height: 1.7;
color: #555;
margin-bottom: 12px;
} @media (max-width: 768px) {
.flow-step {
flex-direction: column;
}
.flow-step .step-number {
width: 60px;
height: 60px;
font-size: 0.9rem;
margin-bottom: 10px;
}
.flow-step .step-content {
padding: 15px 20px;
}
}  .rental-area {
background: #f9fafb;
padding: 60px 20px;
color: #333;
text-align: center;
}
.rental-area .container {
max-width: 900px;
margin: 0 auto;
}
.rental-area .area-note {
font-size: 0.95rem;
color: #555;
margin-bottom: 2rem;
}
.area-grid {
display: grid;
grid-template-columns: repeat(auto-fit, minmax(120px, 1fr));
gap: 12px;
justify-items: center;
}
.area-card {
display: block;
width: 100%;
max-width: 160px;
padding: 14px 8px;
background: #fff;
border-radius: 12px;
box-shadow: 0 3px 10px rgba(0,0,0,0.08);
color: #333;
font-weight: 600;
text-align: center;
font-size: 0.95rem;
transition: all 0.3s ease;
}
.area-card:hover {
transform: translateY(-3px);
box-shadow: 0 6px 16px rgba(0,0,0,0.12);
background: linear-gradient(135deg,#f18f01,#f6b73c);
color:#fff;
} @media (max-width: 768px) {
.area-grid {
grid-template-columns: repeat(4, 1fr);
gap: 10px;
}
} @media (min-width: 769px) and (max-width: 1024px) {
.area-grid {
grid-template-columns: repeat(4, 1fr);
gap: 12px;
}
} @media (min-width: 1025px) {
.area-grid {
grid-template-columns: repeat(6, 1fr);
gap: 14px;
}
} .area-toggle-btn {
display: inline-block;
background: #5aa689;
color: #fff;
padding: 10px 20px;
border-radius: 30px;
border: none;
cursor: pointer;
margin-bottom: 20px;
font-weight: 600;
font-size: 1rem;
transition: background 0.3s;
}
.area-toggle-btn:hover {
background: #6fc0a9;
} .area-content {
max-height: 0;
overflow: hidden;
transition: max-height 0.5s ease;
} .area-content.open {
max-height: 3000px; }  .contact-section {
background: linear-gradient(135deg, #f7fdfb, #e9f9f3);
text-align: center;
padding: 80px 20px;
border-radius: 20px;
box-shadow: 0 4px 20px rgba(0,0,0,0.05);
margin: 4em 0;
}
.contact-section h2 {
color: #5aa689; margin-bottom: 1rem;
}
.contact-lead {
font-size: 1rem;
color: #555;
margin-bottom: 2.5rem;
margin-top: 2.5rem;
}
.contact-actions {
display: flex;
flex-wrap: wrap;
justify-content: center;
gap: 20px;
}
.contact-btn {
display: flex;
align-items: center;
justify-content: center;
gap: 10px;
padding: 16px 32px;
font-size: 1.1rem;
font-weight: bold;
border-radius: 40px;
text-decoration: none;
transition: all 0.3s ease;
min-width: 260px;
}
.contact-btn i {
font-size: 1.3rem;
} .contact-btn.phone {
background: linear-gradient(135deg, #f18f01, #f6b73c);
color: #fff;
box-shadow: 0 6px 14px rgba(241,143,1,0.25);
}
.contact-btn.phone:hover {
transform: translateY(-3px);
box-shadow: 0 8px 18px rgba(241,143,1,0.35);
} .contact-btn.form {
background: linear-gradient(135deg, #6fc0a9, #5aa689);
color: #fff;
box-shadow: 0 6px 14px rgba(111,192,169,0.25);
}
.contact-btn.form:hover {
transform: translateY(-3px);
box-shadow: 0 8px 18px rgba(111,192,169,0.35);
}
.contact-btn small {
font-size: 0.85rem;
font-weight: normal;
opacity: 0.9;
margin-left: 6px;
} @media (max-width: 768px) {
.contact-section {
padding: 60px 16px;
}
.contact-btn {
min-width: 220px;
font-size: 1rem;
padding: 14px 24px;
}
.contact-btn span {
display: none; }
} .order-form-section {
background: #f9fafb;
padding: 60px 20px;
color: #333;
}
.order-form-section .container {
max-width: 900px;
margin: 0 auto;
}
.order-form-section p{
margin-bottom:20px;
}
.rental-form label {
display: block;
margin-bottom: 1.5rem;
font-weight: 600;
color: #555;
}
.rental-form input,
.rental-form select,
.rental-form textarea {
width: 100%;
padding: 10px 12px;
border: 1px solid #ccc;
border-radius: 8px;
font-size: 1rem;
box-sizing: border-box;
}
.rental-form .note {
font-size: 0.9rem;
color: #777;
margin-top: -1rem;
margin-bottom: 1.5rem;
}
.form-submit {
text-align: center;
margin-top: 2rem;
}
.form-submit input[type="submit"] {
background: linear-gradient(135deg, #f18f01, #f6b73c);
color: #fff;
border: none;
padding: 14px 40px;
border-radius: 30px;
font-size: 1.1rem;
font-weight: bold;
transition: transform 0.3s, box-shadow 0.3s;
}
.form-submit input[type="submit"]:hover {
transform: translateY(-3px);
box-shadow: 0 6px 12px rgba(0,0,0,0.15);
} .required {
display: inline-block;
background: #fff7f7; color: #d46a6a; border: 1px solid #f3c8c8; font-size: 0.75em;
padding: 0.15em 0.55em;
border-radius: 4px;
margin-left: 0.45em;
font-weight: 500;
line-height: 1;
} .wpcf7-form p.checkbox-center {
text-align: center; margin-bottom: 1.5em;
} .wpcf7-form p.checkbox-center span.wpcf7-list-item {
display: inline-flex;
align-items: center; white-space: nowrap; margin: 0 0.5em; } .wpcf7-form p.checkbox-center input[type="checkbox"] {
vertical-align: middle;
margin: 0; } .wpcf7-form p.checkbox-center label {
display: inline-flex;        
align-items: center;         
gap: 0.25em; font-size: 1rem;
} @media (max-width: 768px) {
.wpcf7-form p.checkbox-center span.wpcf7-list-item {
display: flex; flex-direction: row; align-items: flex-start; justify-content: flex-start;
width: 100%; margin: 0.4em 0; }
.wpcf7-form p.checkbox-center input[type="checkbox"] {
margin-top: 0.2em; flex-shrink: 0; }
.wpcf7-form p.checkbox-center label {
display: flex;
flex: 1; flex-wrap: wrap; gap: 0.4em; }
}
@media (max-width: 768px) {
.rental-form label {
margin-bottom: 1.2rem;
}
}
.date-picker-popup {
position: absolute;
background: #fff;
border: 1px solid #ccc;
padding: 10px;
z-index: 1500;
max-height: 250px; overflow-y: auto;
border-radius: 6px;
box-shadow: 0 4px 12px rgba(0,0,0,0.15);
}
.date-picker-popup div {
padding: 8px 12px;
cursor: pointer;
}
.date-picker-popup div:hover {
background: #f6b73c; color: #fff;
} .rental-faq dt {
font-weight: bold;
margin-top: 15px;
color: #333;
}
.rental-faq dd {
margin-left: 10px;
margin-bottom: 10px;
} .rental-contact .btn {
display: inline-block;
padding: 12px 28px;
background: #6fc0a9;
color: #fff;
border-radius: 30px;
text-decoration: none;
transition: 0.3s;
}
.rental-contact .btn:hover {
background: #5aa689;
} @media (max-width: 768px) {
.rental-hero {
padding: 40px 15px;
}
.rental-hero .page-title {
font-size: 1.8rem;
}
.rental-page h2 {
font-size: 1.3rem;
}
} .cover-gallery {
display: grid;
grid-template-columns: repeat(5, 1fr);
gap: 20px;
justify-items: center;
margin-bottom:40px;
}
.cover-item {
background: #fff;
border-radius: 10px;
box-shadow: 0 4px 10px rgba(0,0,0,0.08);
overflow: hidden;
transition: transform 0.3s ease, box-shadow 0.3s ease;
}
.cover-item:hover {
transform: translateY(-6px);
box-shadow: 0 8px 20px rgba(0,0,0,0.12);
}
.cover-item img {
width: 100%;
height: auto;
display: block;
}
.cover-name {
font-size: 0.95rem;
padding: 12px 8px;
color: #333;
background: #f9f9f9;
text-align:center;
} @media (max-width: 1024px) {
.cover-gallery {
grid-template-columns: repeat(3, 1fr);
}
}
@media (max-width: 768px) {
.cover-gallery {
grid-template-columns: repeat(2, 1fr);
}
}
@media (max-width: 480px) {
.cover-gallery {
grid-template-columns: 1fr;
}
} .float-nav {
position: fixed;
bottom: 20px;
left: 50%;
transform: translateX(-50%);
background: rgba(255, 255, 255, 0.95);
box-shadow: 0 2px 10px rgba(0,0,0,0.15);
border-radius: 40px;
z-index: 9999;
padding: 8px 20px;
transition: opacity 0.3s;
}
.float-nav ul {
display: flex;
gap: 16px;
overflow-x: auto;
white-space: nowrap;
scrollbar-width: none;
list-style: none; }
.float-nav ul::-webkit-scrollbar { display: none; }
.float-nav a {
display: inline-block;
padding: 6px 14px;
border-radius: 20px;
font-size: 14px;
color: #333;
background: #f4f4f4;
text-decoration: none;
transition: all 0.3s;
font-weight: 600;
}
.float-nav a:hover,
.float-nav a.active {
background: #58a87a;
color: #fff;
} @media (max-width: 768px) {
.float-nav {
bottom: 10px;
width: 95%;
left: 50%;
transform: translateX(-50%);
border-radius: 20px;
padding: 6px 10px;
}
.float-nav a {
font-size: 13px;
padding: 5px 10px;
}
} .reform-check {
margin: 40px auto;
box-sizing: border-box;
}
.reform-check h2 {
text-align: center;
color: #5aa689;
font-weight: 700;
font-size: 1.6rem;
margin-bottom: 30px;
letter-spacing: 0.02em;
} .reform-box {
display: flex;
align-items: center;
gap: 32px;
background: #fff;
border-radius: 16px;
padding: 28px;
box-shadow: 0 6px 18px rgba(0,0,0,0.06);
border: 1px solid rgba(111,192,169,0.10);
box-sizing: border-box;
} .reform-image {
flex: 0 0 240px;
display: block;
}
.reform-image img {
width: 100%;
height: auto;
display: block;
border-radius: 12px;
object-fit: cover;
box-shadow: 0 4px 12px rgba(0,0,0,0.06);
} .reform-content {
flex: 1 1 auto;
} .reform-list {
list-style: none !important;
margin: 0;
padding: 0;
text-align: left; }
.reform-list li {
position: relative;
padding-left: 34px;
margin-bottom: 10px;
font-size: 1.05rem;
color: #333;
line-height: 1.8;
text-align: left; box-sizing: border-box;
} .reform-list li::before {
content: "\2713";
position: absolute;
left: 0;
top: 0.55em;
transform: none; display: inline-block;
width: 24px;
height: 24px;
line-height: 24px;
text-align: center;
font-weight: 700;
color: #6fc0a9;
background: rgba(111,192,169,0.10);
border-radius: 6px;
box-shadow: 0 1px 3px rgba(0,0,0,0.04);
font-family: inherit;
} @media (max-width: 768px) {
.reform-box {
flex-direction: column;
text-align: left; gap: 18px;
padding: 22px;
}
.reform-image {
flex: 0 0 auto;
width: 80%;
max-width: 360px;
margin: 0 auto 10px;
}
.reform-list li {
padding-left: 34px; }
.reform-list li::before {
left: 0;
top: 0.55em;
transform: none;
}
} .reform-links {
border-top: 4px solid #5aa689; border-bottom: 4px solid #5aa689;
background: #f9fdfb;
padding: 60px 20px;
text-align: center;
}
.reform-links-title {
font-size: 1.8rem;
font-weight: bold;
color: #2d6a4f;
margin-bottom: 40px;
}
.reform-link-cards {
display: grid;
grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
gap: 30px;
justify-items: center;
}
.reform-card {
border: 2px solid #5aa689;
border-radius: 16px;
background: #fff;
box-shadow: 0 4px 12px rgba(0, 0, 0, 0.08);
transition: transform 0.3s ease, box-shadow 0.3s ease;
max-width: 500px;
width: 100%;
}
.reform-card:hover {
transform: translateY(-4px);
box-shadow: 0 6px 18px rgba(0, 0, 0, 0.12);
}
.reform-card-content {
padding: 30px;
}
.reform-card h3 {
font-size: 1.4rem;
color: #333;
margin-bottom: 15px;
}
.reform-card p {
color: #555;
font-size: 0.95rem;
line-height: 1.6;
margin-bottom: 25px;
}
.reform-btn {
display: inline-block;
background: #f28c38; color: #fff;
font-weight: bold;
padding: 12px 30px;
border-radius: 25px;
text-decoration: none;
transition: background 0.3s ease, transform 0.2s ease;
}
.reform-btn:hover {
background: #e6721e;
transform: translateY(-2px);
} @media (max-width: 768px) {
.reform-links {
padding: 40px 15px;
}
.reform-links-title {
font-size: 1.5rem;
margin-bottom: 30px;
}
.reform-card-content {
padding: 25px 20px;
}
} .reform-links.visual {
border-top: 4px solid #5aa689;
border-bottom: 4px solid #5aa689;
background: linear-gradient(180deg, #f9fdfb 0%, #ffffff 100%);
padding: 60px 20px;
text-align: center;
}
.reform-link-cards {
display: grid;
grid-template-columns: repeat(auto-fit, minmax(340px, 1fr));
gap: 40px;
justify-items: center;
}
.reform-card {
border: 2px solid #5aa689;
border-radius: 18px;
background: #fff;
box-shadow: 0 6px 20px rgba(0, 0, 0, 0.08);
overflow: hidden;
transition: transform 0.3s ease, box-shadow 0.3s ease;
max-width: 520px;
}
.reform-card:hover {
transform: translateY(-5px);
box-shadow: 0 8px 24px rgba(0, 0, 0, 0.12);
}
.reform-card-icon {
background: #e7f5ef;
padding: 30px;
display: flex;
align-items: center;
justify-content: center;
border-bottom: 2px solid #5aa689;
}
.reform-card-icon img {
width: 70px;
height: 70px;
object-fit: contain;
}
.reform-card-content {
padding: 30px;
}
.reform-card h3 {
font-size: 1.4rem;
color: #2d6a4f;
margin-bottom: 15px;
font-weight: 700;
}
.reform-card p {
color: #555;
font-size: 0.95rem;
line-height: 1.6;
margin-bottom: 25px;
}
.reform-btn {
display: inline-block;
background: #f28c38;
color: #fff;
font-weight: bold;
padding: 12px 30px;
border-radius: 25px;
text-decoration: none;
transition: background 0.3s ease, transform 0.2s ease;
}
.reform-btn:hover {
background: #e6721e;
transform: translateY(-2px);
} @media (max-width: 768px) {
.reform-card-content {
padding: 25px 20px;
}
.reform-card-icon {
padding: 20px;
}
.reform-card-icon img {
width: 55px;
height: 55px;
}
} .cleaning-tips {
background: #f9fbfa;
padding: 60px 5%;
border-top: 3px solid #6fc0a9;
border-bottom: 3px solid #6fc0a9;
}
.cleaning-tips h2 {
margin-bottom: 30px;
}
.cleaning-tips .sub-heading {
margin-top: 80px;
color: #5aa689;
} .tip-box {
display: flex;
align-items: center;
gap: 40px;
background: #fff;
border-radius: 18px;
padding: 30px;
margin-bottom: 40px;
box-shadow: 0 8px 18px rgba(0,0,0,0.05);
border-left: 6px solid #a3d9c4;
transition: transform 0.3s ease, box-shadow 0.3s ease;
}
.tip-box:hover {
transform: translateY(-3px);
box-shadow: 0 12px 24px rgba(0,0,0,0.08);
} .tip-image {
flex: 0 0 240px;
}
.tip-image img {
width: 100%;
height: auto;
border-radius: 12px;
display: block;
box-shadow: 0 4px 10px rgba(0,0,0,0.05);
}
.tip-content {
flex: 1 1 auto;
}
.tip-content h3 {
color: #5aa689;
font-weight: 700;
margin-bottom: 10px;
text-align:left;
}
.tip-content p {
font-size: 1rem;
color: #333;
line-height: 1.8;
} .tip-box.reverse {
flex-direction: row-reverse;
} @media (max-width: 768px) {
.tip-box {
flex-direction: column;
text-align: center;
padding: 20px;
}
.tip-box.reverse {
flex-direction: column;
}
.tip-image {
width: 80%;
max-width: 300px;
}
}  .before-after-section {
text-align: center;
padding: 60px 20px;
background: linear-gradient(to bottom right, #e9f9f9, #ffffff);
border-radius: 20px;
box-shadow: 0 4px 15px rgba(0,0,0,0.05);
} .before-after-section h2 {
margin-bottom: 30px;
} .before-after-container {
display: flex;
justify-content: center;
align-items: center;
gap: 40px;
flex-wrap: wrap;
} .image-box {
position: relative;
width: 260px;
height: 260px;
border-radius: 50%;
overflow: hidden;
box-shadow: 0 6px 15px rgba(0,0,0,0.15);
background: #fff;
display: flex;
justify-content: center;
align-items: center;
} .image-box img {
width: 100%;
height: 100%;
object-fit: cover;
} .image-box p {
position: absolute;
bottom: 15px;
font-size: 1.3em;
font-weight: bold;
color: #fff;
text-shadow: 0 2px 6px rgba(0,0,0,0.4);
} .before img {
filter: grayscale(60%) brightness(0.9);
}
.after img {
filter: brightness(1.1) saturate(1.3);
}
.after p {
color: #ffe66d;
} .arrow {
font-size: 3em;
color: #2a8573;
animation: arrowMove 1.8s infinite alternate;
}
@keyframes arrowMove {
from { transform: translateX(-5px); }
to { transform: translateX(5px); }
} .caption {
margin-top: 25px;
color: #555;
font-size: 1.1em;
} .after::before,
.after::after {
content: "";
position: absolute;
border-radius: 50%;
background: rgba(255, 255, 255, 0.5);
animation: bubble 6s infinite ease-in-out;
z-index: 2;
}
.after::before {
width: 40px;
height: 40px;
left: 20%;
bottom: -10%;
animation-delay: 0s;
}
.after::after {
width: 25px;
height: 25px;
right: 25%;
bottom: -10%;
animation-delay: 2s;
}
@keyframes bubble {
0% {
transform: translateY(0) scale(0.8);
opacity: 0.6;
}
50% {
opacity: 1;
}
100% {
transform: translateY(-260px) scale(1.2);
opacity: 0;
}
} @media screen and (max-width: 768px) {
.before-after-container {
flex-direction: column;
gap: 25px;
}
.arrow {
font-size: 2.5em;
transform: rotate(90deg);
animation: arrowMoveY 1.8s infinite alternate;
}
@keyframes arrowMoveY {
from { transform: rotate(90deg) translateY(-5px); }
to { transform: rotate(90deg) translateY(5px); }
}
.image-box {
width: 220px;
height: 220px;
}
.caption {
font-size: 1em;
line-height: 1.6;
} .after::before {
width: 30px;
height: 30px;
left: 25%;
}
.after::after {
width: 20px;
height: 20px;
right: 30%;
}
} .futon-sales {
text-align: center;
background: linear-gradient(to bottom right, #f9fbf8, #ffffff);
padding: 80px 5%;
border-radius: 16px;
margin-bottom: 60px;
}
.futon-sales .section-title {
font-size: 1.9rem;
color: #5aa689;
font-weight: 700;
margin-bottom: 20px;
}
.futon-sales .lead {
font-size: 1.1rem;
color: #444;
line-height: 1.9;
margin-bottom: 40px;
}
.futon-sales .sales-image img {
width: 100%;
max-width: 700px;
border-radius: 20px;
box-shadow: 0 6px 20px rgba(0,0,0,0.08);
} .futon-craft {
text-align: center;
padding: 60px 5%;
background: #fff;
border-top: 2px solid #6fc0a9;
border-bottom: 2px solid #6fc0a9;
margin-bottom: 60px;
}
.futon-craft .section-subtitle {
font-size: 1.4rem;
color: #5aa689;
font-weight: bold;
margin-bottom: 20px;
}
.futon-craft p {
color: #444;
font-size: 1rem;
line-height: 1.8;
margin-bottom: 30px;
}
.craft-points {
display: grid;
grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
gap: 15px;
list-style: none;
padding: 0;
margin: 0 auto;
max-width: 800px;
}
.craft-points li {
background: rgba(111,192,169,0.08);
border: 1px solid rgba(111,192,169,0.2);
border-radius: 10px;
padding: 15px;
color: #333;
font-weight: 600;
font-size: 0.95rem;
box-shadow: 0 3px 8px rgba(0,0,0,0.05);
transition: all 0.3s ease;
}
.craft-points li:hover {
background: #6fc0a9;
color: #fff;
transform: translateY(-3px);
} .shop-links {
text-align: center;
background: #f9fbf8;
padding: 60px 20px;
border-top: 3px solid #6fc0a9;
border-radius: 16px;
margin-top: 60px;
box-shadow: 0 6px 20px rgba(0,0,0,0.05);
}
.shop-links h2 {
color: #5aa689;
font-size: 1.6rem;
margin-bottom: 15px;
font-weight: 700;
}
.shop-links p {
color: #555;
font-size: 1rem;
margin-bottom: 25px;
margin-top: 40px;
}
.shop-buttons {
display: flex;
flex-wrap: wrap;
justify-content: center;
gap: 20px;
}
.btn-yahoo, .btn-mercari {
display: inline-block;
padding: 14px 30px;
font-weight: bold;
border-radius: 30px;
color: #fff;
transition: all 0.3s ease;
text-decoration: none;
}
.btn-yahoo {
background: #ff6400;
}
.btn-mercari {
background: #e60012;
}
.btn-yahoo:hover, .btn-mercari:hover {
transform: translateY(-3px);
box-shadow: 0 8px 15px rgba(0,0,0,0.25);
} @media (max-width: 768px) {
.futon-sales .section-title { font-size: 1.6rem; }
.futon-craft .section-subtitle { font-size: 1.2rem; }
.craft-points li { font-size: 0.9rem; padding: 12px; }
.shop-links h2 { font-size: 1.4rem; }
}
.page-tel-area{
text-align:center;
width:400px;
margin-left:auto;
margin-right:auto;
}
.page-tel-area p{
text-align:left;
}
.contact-page-tel{
width:300px;
margin-bottom:30px;
margin-left:auto;
margin-right:auto;
} @media (max-width: 768px) {
.page-tel-area{
width:100%;
}
.contact-page-tel{
width:80%;
margin-left:auto;
margin-right:auto;
}
} .thanks-message {
text-align: center;
background: #f6fbf8;
border: 2px solid #6fc0a9;
border-radius: 16px;
padding: 60px 30px;
margin: 40px auto;
max-width: 700px;
color: #333;
box-shadow: 0 6px 18px rgba(0,0,0,0.08);
animation: fadeIn 0.7s ease-in;
}
.thanks-message h2 {
color: #5aa689;
font-size: 1.8rem;
margin-bottom: 20px;
}
.thanks-message p {
font-size: 1.1rem;
margin-bottom: 15px;
line-height: 1.7;
}
.thanks-message .small {
font-size: 0.95rem;
color: #666;
margin-bottom: 25px;
}
.thanks-message .back-btn {
display: inline-block;
background: linear-gradient(135deg, #f9a825, #ffb74d);
color: #fff;
padding: 12px 30px;
border-radius: 30px;
text-decoration: none;
font-weight: bold;
box-shadow: 0 4px 10px rgba(0,0,0,0.15);
transition: all 0.3s;
}
.thanks-message .back-btn:hover {
transform: translateY(-3px);
box-shadow: 0 8px 20px rgba(0,0,0,0.25);
}
@keyframes fadeIn {
from { opacity: 0; transform: translateY(15px); }
to { opacity: 1; transform: translateY(0); }
}
.column-faq dl {
margin: 0;
padding: 0;
}
.column-faq dt {
font-weight: bold;
margin-top: 1.4em; line-height: 1.6;
}
.column-faq dd {
margin: 0.4em 0 1em 1em; line-height: 1.7;
}
.page-template-rental-area section{
margin-bottom:40px;
}
.oshirase{
display:none;
} .area-section {
text-align: center;
padding: 70px 20px;
background: linear-gradient(to bottom right, #f7fcfa, #ffffff);
border-radius: 20px;
}
.area-section h2 {
font-size: 1.9em;
color: #5aa689;
margin-bottom: 25px;
letter-spacing: 0.05em;
}
.area-section .lead {
color: #555;
font-size: 1.05em;
margin-bottom: 8px;
}
.area-section .note {
font-size: 0.9em;
color: #888;
margin-bottom: 45px;
}
.area-grid2 {
display: grid;
grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
gap: 25px;
max-width: 1100px;
margin: 0 auto;
}
.area-card2 {
background: #fff;
border: 2px solid #5aa689;
border-radius: 14px;
padding: 30px 22px 40px;
box-shadow: 0 5px 15px rgba(0,0,0,0.08);
transition: 0.35s ease;
position: relative;
overflow: hidden;
}
.area-card2::before {
content: "";
position: absolute;
top: 0; left: 0;
width: 100%; height: 5px;
background: linear-gradient(90deg, #5aa689, #7edbb8);
}
.area-card2:hover {
transform: translateY(-6px);
box-shadow: 0 10px 25px rgba(0,0,0,0.12);
}
.area-card2 h3 {
color: #5aa689;
font-size: 1.25em;
margin-bottom: 12px;
}
.area-card2 p {
color: #333;
font-size: 0.95em;
margin-bottom: 20px;
line-height: 1.6;
}
.btn-area {
display: inline-block;
background: #ff9933;
color: #fff;
padding: 8px 16px;
border-radius: 6px;
font-size: 0.9em;
text-decoration: none;
transition: 0.3s ease;
}
.btn-area:hover {
background: #e5831c;
} .pref-area {
max-width: 1000px;
margin: 0 auto;
padding: 40px 20px;
background: #f8fbf9;
border-radius: 16px;
}
.pref-area h2 {
text-align: center;
font-size: 1.8rem;
color: #2d6a4f;
margin-bottom: 15px;
}
.pref-area .lead {
text-align: center;
color: #555;
margin-bottom: 40px;
line-height: 1.8;
}
.area-list {
margin-bottom: 40px;
}
.area-list h3 {
font-size: 1.3rem;
color: #40916c;
border-left: 5px solid #52b788;
padding-left: 10px;
margin-bottom: 20px;
}
.area-list ul {
display: grid;
grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
gap: 10px;
list-style: none;
padding: 0;
margin: 0;
}
.area-list li a {
display: block;
background: #fff;
border: 1px solid #dcefe3;
padding: 10px;
border-radius: 8px;
text-align: center;
color: #1b4332;
text-decoration: none;
transition: all 0.2s ease;
}
.area-list li a:hover {
background: #d8f3dc;
transform: translateY(-2px);
} .prefecture-section {
background: linear-gradient(135deg, #f5fdfb, #ffffff);
border: 1px solid #c8e7dd;
border-radius: 16px;
padding: 60px 25px;
margin: 40px auto;
max-width: 1000px;
box-shadow: 0 4px 16px rgba(0,0,0,0.06);
}
.prefecture-header {
text-align: center;
margin-bottom: 40px;
}
.prefecture-header h2 {
color: #2a8573;
}
.prefecture-header p {
color: #555;
font-size: 1.05em;
line-height: 1.8;
}
.area-block {
margin-bottom: 40px;
}
.area-block h3 {
font-size: 1.3em;
color: #2a8573;
margin-bottom: 20px;
text-align: center;
position: relative;
}
.area-block h3 span {
background: #fff;
padding: 0 15px;
position: relative;
z-index: 2;
}
.area-block h3::before {
content: "";
position: absolute;
top: 50%;
left: 10%;
right: 10%;
height: 1px;
background: #a5d8c2;
z-index: 1;
}
.city-list {
display: flex;
flex-wrap: wrap;
gap: 10px 15px;
justify-content: center;
list-style: none;
padding: 0;
margin: 0;
}
.city-list li a,
.city-list li span {
display: inline-block;
background: #e8f9f2;
color: #2a8573;
border-radius: 20px;
padding: 6px 14px;
font-size: 0.95em;
text-decoration: none;
transition: all 0.3s ease;
}
.city-list li a:hover {
background: #2a8573;
color: #fff;
}
.city-list.small li a,
.city-list.small li span {
background: #f5fbf8;
color: #444;
}
.city-list.small li a:hover {
background: #2a8573;
color: #fff;
}
.cta-area {
text-align: center;
margin-top: 50px;
}
.cta-area p {
color: #444;
margin-bottom: 15px;
}
.btn-green {
display: inline-block;
background: #ff8c42;
color: #fff;
padding: 12px 28px;
border-radius: 30px;
text-decoration: none;
font-weight: bold;
box-shadow: 0 4px 8px rgba(255,140,66,0.3);
transition: all 0.3s ease;
}
.btn-green:hover {
background: #e96c23;
transform: translateY(-2px);
} .sp-br {
display: none;
}
@media screen and (max-width: 768px) {
.sp-br {
display: block;
}
}  .sp-fixed-btns {
position: fixed;
bottom: 60px; right: 10px;
display: flex;
flex-direction: column;
gap: 10px;
z-index: 9998;
opacity: 0;
pointer-events: none;
transition: opacity 0.3s ease;
}
.sp-fixed-btns a {
background: #58a87a;
color: #fff;
text-decoration: none;
font-weight: bold;
font-size: 13px;
border-radius: 30px;
padding: 10px 16px;
box-shadow: 0 3px 6px rgba(0,0,0,0.2);
text-align: center;
}
.sp-fixed-btns a.btn-order {
background: #e87b00;
} .sp-fixed-btns.visible {
opacity: 1;
pointer-events: auto;
} @media (min-width: 769px) {
.sp-fixed-btns { display: none; }
} .rental-scenes {
background: #f5f9fb;
padding: 60px 20px;
text-align: center;
}
.rental-scenes .inner {
max-width: 1000px;
margin: 0 auto;
}
.rental-scenes h2 {
font-size: 2rem;
color: #5aa689;
margin-bottom: 50px;
position: relative;
}
.rental-scenes h2::after {
content: "";
display: block;
width: 60px;
height: 3px;
background: #5aa689;
margin: 15px auto 0;
border-radius: 2px;
}
.scene-list {
display: grid;
grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
gap: 30px;
}
.scene-card {
background: #fff;
border-radius: 18px;
overflow: hidden;
box-shadow: 0 4px 12px rgba(0,0,0,0.06);
transition: transform 0.3s ease, box-shadow 0.3s ease;
}
.scene-card:hover {
transform: translateY(-5px);
box-shadow: 0 6px 18px rgba(0,0,0,0.1);
}
.scene-card img {
width: 100%;
height: 200px;
object-fit: cover;
}
.scene-card h3 {
font-size: 1.2rem;
margin: 1.2em 0 0.5em;
color: #333;
}
.scene-card p {
color: #555;
font-size: 0.95rem;
line-height: 1.8;
padding: 0 1.5em 1.8em;
} @media (max-width: 600px) {
.rental-scenes {
padding: 40px 15px;
}
.rental-scenes h2 {
font-size: 1.6rem;
}
.scene-card img {
height: 180px;
}
} .contact-time-sp {
display: none;
color: #555;
font-size: 0.9rem;
margin-bottom: 1rem;
} @media (max-width: 768px) {
.contact-time-sp {
display: block;
}
} .simulator-wrap {
max-width: 100%;
width: 100%;
overflow-x: hidden;
box-sizing: border-box;
margin: 30px auto;
padding: 20px 18px;
background: #f5f9fb;
border-radius: 16px;
box-shadow: 0 6px 16px rgba(0,0,0,0.06);
font-size: 15px;
color: #333;
} .simulator-wrap * {
max-width: 100%;
box-sizing: border-box;
}
.simulator-wrap h2 {
font-size: 1.4rem;
margin-bottom: 12px;
color: #2c7a5e;
text-align: center;
}
.simulator-wrap .sim-note {
font-size: 0.85rem;
margin-bottom: 18px;
text-align: center;
color: #666;
} .simulator-form {
display: grid;
grid-template-columns: 1fr 1fr;
gap: 14px 20px;
width: 100%;
} .simulator-form .field {
display: flex;
flex-direction: column;
gap: 4px;
width: 100%;
}
.simulator-form label {
font-weight: 600;
font-size: 0.9rem;
}
.simulator-form select {
padding: 10px 12px;
border-radius: 10px;
border: 1px solid #ccc;
font-size: 1rem;
background: #fff;
width: 100%;
}
.simulator-form select:focus {
outline: none;
border-color: #5aa689;
box-shadow: 0 0 0 2px rgba(90,166,137,0.25);
} .simulator-result {
margin-top: 22px;
padding: 20px 16px;
background: linear-gradient(180deg, #ffffff, #f7fbfa);
border-radius: 20px;
border: 1px solid rgba(90,166,137,0.25);
box-shadow: 0 6px 18px rgba(0,0,0,0.06);
width: 100%;
overflow: hidden;
opacity: 0;
transform: translateY(8px);
transition: opacity 0.35s ease, transform 0.35s ease;
}
.simulator-result.show {
opacity: 1;
transform: translateY(0);
}
.simulator-result h3 {
font-size: 1.2rem;
margin-bottom: 10px;
color: #2c7a5e;
font-weight: 700;
}
.simulator-result p {
margin: 6px 0;
font-size: 0.98rem;
}
.simulator-result .total {
margin-top: 12px;
font-weight: 800;
font-size: 1.25rem;
color: #c0392b;
} .ship-alert {
margin-top: 12px;
color: #2c7a5e;
font-size: 0.9rem;
background: #e9f7f3;
padding: 8px 12px;
border-left: 4px solid #5aa689;
border-radius: 6px;
} @media (max-width: 640px) {
.simulator-form {
grid-template-columns: 1fr !important;
}
.simulator-form .field,
.simulator-form select {
width: 100%;
}
} .ribbon-notice {
position: relative;
max-width: 1000px;
margin: 35px auto;
padding: 20px 22px;
background: #fff;
border-radius: 14px;
text-align: center;
font-size: 1.05rem;
color: #444;
box-shadow: 0 2px 8px rgba(0,0,0,0.05);
}
.ribbon-notice::before {
content: "お知らせ";
position: absolute;
top: -10px;
left: 20px;
background: #6fc0a9; color: #fff;
padding: 4px 10px;
font-size: 0.75rem;
border-radius: 4px;
letter-spacing: 0.05em;
}
.ribbon-notice p {
margin: 0;
line-height: 1.7;
}