*{box-sizing:border-box}
body {
  font-family: 'Roboto', sans-serif;
  font-size: 16px;
  line-height: 1.6;
  color: #333;
  background: #fff;
  margin: 0;
  padding: 0;
  -webkit-font-smoothing: antialiased;
}
a {
  color: #4DB6AC;
  text-decoration: none;
  transition: color 0.3s ease;
}
a:hover { color: #4DAFA4; }
img{max-width:100%;height:auto}
.container {
  max-width: 1170px;
  margin: 0 auto;
  padding: 0 20px;
}
.top-bar {
  background: #fff;
  padding: 8px 0;
  font-size: 0.8125rem;
  border-bottom: 1px solid #eee;
}
.top-bar .container { display: flex; justify-content: space-between; align-items:center; }
.top-bar a { color: #555; }
.top-bar .top-left { display:flex; gap: 18px; }
.top-bar .top-left i { margin-right: 6px; color: #4db6ac; }
.top-bar .addr{font-size:12px;color:#6a6a6a}
.site-header{
  background:#4DB6AC;
  padding: 15px 0;
  position: sticky;
  top:0;
  width:100%;
  z-index: 99;
  transition: all .3s ease;
}
.site-header .container{
  display:flex;
  align-items: center;
  justify-content:space-between;
  gap:16px;
}
.site-header .logo img { max-height: 50px; }
.main-nav ul{
  list-style:none;
  margin:0;
  padding: 0px;
  display: flex;
  gap: 28px;
}
.main-nav ul li a{
  color:#fff;
  font-weight:500;
  font-size: 15px;
  padding: 6px 2px;
  text-transform: none;
}
.main-nav ul li a:hover{ color:#fff; opacity:.85; }
.cart-toggle{
  position:relative;
  cursor:pointer;
  color:#fff;
  font-size:20px;
  padding:6px;
}
.cart-count{
  position:absolute;
  top:-2px;right:-6px;
  background:#FF6B35;
  color:#fff;
  font-size:11px;
  font-weight:700;
  width:18px;height:18px;
  border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  line-height:1;
}
.header-cta{
  background:#FF6B35;
  color:#fff !important;
  padding: 10px 22px;
  border-radius: 30px;
  font-weight:600;
  font-size:14px;
  display:inline-block;
  transition: background .25s;
}
.header-cta:hover{ background:#e55e2e; }
.hero{
  background:#4DB6AC;
  padding: 70px 0 0 0;
  position:relative;
  overflow: hidden;
  color:#fff;
}
.hero .container{
  display: flex;
  align-items: center;
  gap: 40px;
}
.hero-text{ flex: 1 1 55%; }
.hero-image{ flex: 1 1 45%; text-align:right; }
.hero-image img{ max-width:100%; height:auto; border-radius: 6px; margin-top:-10px; }
.hero h1{
  font-size: 3rem;
  line-height:1.12;
  margin: 0 0 22px;
  font-weight:700;
  color:#fff;
}
.hero .lead{
  font-size:1.0625rem;
  line-height: 1.65;
  margin-bottom:30px;
  max-width: 540px;
  color: rgba(255,255,255,.92);
}
.hero-buttons{ display:flex; gap: 15px; margin-bottom: 25px; padding-top:36px; }
.btn-primary{
  background: #FF6B35;
  border: none;
  padding: 14px 28px;
  border-radius:30px;
  color:#fff;
  font-weight:600;
  font-size:15px;
  cursor:pointer;
  display:inline-block;
  transition: background .25s;
}
.btn-primary:hover { background: #e55e2e; color:#fff; }
.btn-secondary{
  background: transparent;
  border: 2px solid #fff;
  padding: 12px 26px;
  border-radius: 30px;
  color: #fff;
  font-weight:600;
  font-size:0.9375em;
  cursor:pointer;
  transition: background .2s;
}
.btn-secondary:hover{ background: rgba(255,255,255,.15); color:#fff; }
.btn-outline-teal{
  border-color:#4DB6AC;
  color:#4DB6AC;
  background:transparent;
}
.btn-outline-teal:hover{background:rgba(77,182,172,.08);color:#4DB6AC}
.btn-full{width:100%;text-align:center;margin-top:12px}
.hero-drip{
  width:100%;
  height: 60px;
  background: #4DB6AC;
  position: relative;
  margin-top: 0px;
}
.hero-drip::after {
  content: "";
  display: block;
  width: 100%;
  height: 60px;
  background: #fff;
  border-radius: 50% 50% 0 0 / 100% 100% 0 0;
  position: absolute;
  bottom: 0;
}
.hero-drip-thin{height:8px}
.hero-drip-thin::after{height:8px;border-radius:0}
.section{ padding: 78px 0; }
.section-tight{ padding: 58px 0 64px; }
.section h2, .services-head h2{
  font-size: 2rem;
  font-weight:700;
  color:#222;
  margin-bottom: 18px;
  line-height: 1.25;
}
.section p{ color:#555; font-size:15px; margin-bottom: 14px; }
.intro-row{ display:flex; gap:60px; }
.intro-row .col-text{ flex: 1 1 100%; }
.intro-row .col-text ul{padding-left:4px;color:#555;font-size:15px;list-style:none}
.intro-row .col-text ul li{margin-bottom:9px}
.intro-row .col-text ul li i{color:#4DB6AC;margin-right:6px}
.about-cards{padding-top:40px}
.dual-cards .grid{ display:grid; grid-template-columns: 1fr 1fr; gap: 30px; }
.dual-cards .card{
  background: #4DB6AC;
  color:#fff;
  padding: 36px 36px 38px;
  border-radius: 6px;
}
.dual-cards .card h3{ color:#fff; margin: 0 0 8px; font-size: 1.375rem; }
.dual-cards .card .lead{ font-size: 14px; margin-bottom: 0; }
.team-card{
  background-size:cover;
  background-position:center;
  min-height:340px;
  display:flex;
  align-items:flex-end;
  position:relative;
  overflow:hidden;
  padding:0;
}
#team-takahashi{background-image:url('../pic/photo_team-member-428.webp')}
#team-nakamura{background-image:url('../pic/asset-img-staff-portrait-763.webp')}
.team-overlay{
  background:linear-gradient(0deg,rgba(44,62,80,.92) 0%,rgba(44,62,80,.4) 100%);
  padding:28px 32px;
  width:100%;
}
.team-overlay h3{color:#fff;margin:0 0 6px;font-size:1.25rem}
.team-overlay .lead{color:rgba(255,255,255,.85);font-size:14px;margin:0}
.services{ padding: 72px 0 76px; background: #fff; }
.services-head{ text-align:center; margin-bottom: 50px; }
.services-head .deco-line{
  width: 50px; height:3px; background:#4DB6AC; margin: 14px auto 0;
}
.services-grid{ display:grid; grid-template-columns: 1fr 1fr; gap: 36px; }
.service-card{
  background:#fff;
  border:1px solid #eaeaea;
  transition: transform .2s, box-shadow .2s;
}
.service-card:hover{transform:translateY(-3px);box-shadow:0 8px 24px rgba(0,0,0,.08)}
.service-card img{ width:100%; height: 240px; object-fit:cover; display:block; }
.service-card .pad{ padding: 22px 24px 28px; }
.service-card h3{ font-size: 20px; margin: 0 0 6px; color:#222; }
.service-card p{ font-size: 14px; color:#666; margin-bottom: 16px; }
.service-card.last { margin-bottom: 0px !important; }
.price-tag{
  font-size:1.375rem;
  font-weight:700;
  color:#4DB6AC;
  margin-bottom:12px;
}
.price-tag span{font-size:0.75rem;font-weight:400;color:#999;margin-left:4px}
.add-cart-btn{
  width:100%;
  text-align:center;
  padding:12px 20px;
  font-size:14px;
}
.feature-band{
  background: #4DB6AC;
  color:#fff;
  padding: 76px 0 68px;
  text-align:center;
}
.feature-band h2{
  font-size: 2.25rem;
  font-weight: 700;
  margin: 0 0 12px;
  color:#fff;
}
.feature-band h3{
  font-size: 1.25em;
  font-weight: 600;
  margin: 0 0 8px;
  color:#fff;
}
.feature-band .sub{ font-size: 15px; max-width: 620px; margin: 0 auto 44px; color:rgba(255,255,255,.88); }
.feature-band p{color:rgba(255,255,255,.85);font-size:14px;margin:0}
.steps-row{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:32px;
  text-align:left;
  max-width:960px;
  margin:0 auto;
}
.step-item{position:relative}
.step-num{
  font-size:2.5rem;
  font-weight:700;
  color:rgba(255,255,255,.25);
  line-height:1;
  margin-bottom:10px;
}
.feature-band .intro-row{text-align:left;gap:40px}
.feature-band .intro-row h2{color:#fff}
.feature-band .intro-row p{color:rgba(255,255,255,.88)}
.gallery-sec{padding:64px 0 72px}
.gallery-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:12px;
}
.gal-item{overflow:hidden;border-radius:4px}
.gal-item img{width:100%;height:220px;object-fit:cover;display:block;transition:transform .35s}
.gal-item:hover img{transform:scale(1.05)}
.gal-wide{grid-column:span 2}
.gal-wide img{height:260px}
.article-band{
  background-size:cover;
  background-position:center;
  position:relative;
  padding:90px 0 86px;
}
#article-main{background-image:url('../pic/asset-img-article-bg-714.webp')}
.article-band::before{
  content:"";
  position:absolute;
  inset:0;
  background:rgba(256,256,256,.5);
}
.article-band .container{position:relative;z-index:2}
.article-band .row{display:block}
.article-band .col-l{max-width:720px}
.article-band h2{color:#fff;font-size:2rem;margin-bottom:20px;font-weight:700}
.article-band p{color:rgba(255,255,255,.88);font-size:15px;margin-bottom:16px;line-height:1.7}
.quote-band{
  background:#4db6ac;
  color:#fff;
  padding: 72px 0 78px;
}
.quote-band h2{ font-size: 1.75rem; color:#fff; margin-bottom: 10px; text-align:center; }
.quote-band .sub{text-align:center;max-width:560px;margin:0 auto 36px;font-size:14px;color:rgba(255,255,255,.85)}
.contact-form{max-width:640px;margin:0 auto}
.form-row{display:flex;gap:20px;margin-bottom:0}
.form-grp{flex:1;margin-bottom:18px}
.form-grp label{display:block;font-size:13px;margin-bottom:6px;color:rgba(255,255,255,.9);font-weight:500}
.form-grp input,
.form-grp textarea{
  width:100%;
  padding:12px 16px;
  border:none;
  border-radius:6px;
  font-size:15px;
  font-family:'Roboto',sans-serif;
  background:rgba(255,255,255,.95);
  color:#333;
  transition:box-shadow .2s;
}
.form-grp input:focus,
.form-grp textarea:focus{outline:none;box-shadow:0 0 0 3px rgba(255,107,53,.4)}
.form-grp textarea{resize:vertical;min-height:100px}
.contact-form .btn-primary{width:100%;text-align:center;margin-top:6px}
.testimonials{
  background:#2C3E50;
  color:#fff;
  padding: 72px 0 80px;
}
.testimonials h2{ text-align:center; color:#fff; font-size: 1.75rem; margin-bottom: 12px; }
.testimonials .stars{ text-align:center; color: #FFC107; margin-bottom: 36px; font-size: 18px; letter-spacing:2px; }
.testimonials .row{ display:grid; grid-template-columns: 1fr 1fr; gap: 36px; }
.review-product-img{margin-bottom:16px;border-radius:6px;overflow:hidden}
.review-product-img img{width:100%;height:200px;object-fit:cover;display:block}
.testimonial{background:transparent;padding:0 10px}
.testimonial p{ font-size:14px; line-height:1.7; color:#ddd; }
.testimonial .name{ margin-top: 14px; color:#4DB6AC; font-weight: 600; font-size: 0.875em; }
.faq-sec{padding:62px 0 70px}
.faq-wrap{max-width:760px;margin:0 auto}
.faq-item{
  border-bottom:1px solid #e5e5e5;
  cursor:pointer;
}
.faq-q{
  display:flex;
  justify-content:space-between;
  align-items:center;
  padding:20px 0;
  font-size:1.0625rem;
  font-weight:600;
  color:#222;
}
.faq-q i{
  font-size:18px;
  color:#4DB6AC;
  transition:transform .25s;
}
.faq-item.open .faq-q i{transform:rotate(45deg)}
.faq-a{
  max-height:0;
  overflow:hidden;
  transition:max-height .35s ease, padding .35s ease;
  padding:0 0;
}
.faq-item.open .faq-a{
  max-height:300px;
  padding:0 0 20px;
}
.faq-a p{font-size:14px;color:#555;line-height:1.7;margin:0}
.site-footer{
  background:#2c3e50;
  color: #c8c8c8;
  padding: 48px 0 22px;
}
.site-footer .row{
  display: grid;
  grid-template-columns: 2fr 1fr 1fr 1fr;
  gap: 30px;
}
.site-footer .col h4{
  color: #fff;
  font-size: 1.125rem;
  margin: 0 0 14px;
}
.site-footer .col p{
  font-size: 14px;
  line-height: 1.6;
  color: #c8c8c8;
  margin-bottom: 8px;
}
.site-footer .col p i{ margin-right: 4px; }
.site-footer .col ul{list-style: none;padding: 0;margin: 0;}
.site-footer .col ul li{ margin-bottom: 8px; }
.site-footer .col ul li a{color: #c8c8c8;font-size: 14px;}
.site-footer .col ul li a:hover{ color: #4db6ac; }
.site-footer .col:nth-child(1){margin-bottom:20px}
.site-footer .col:nth-child(2){margin-bottom:22px}
.site-footer .col:nth-child(3){margin-bottom:18px}
.site-footer .col:nth-child(4){margin-bottom:20px}
.footer-logo img{max-height:48px;margin-bottom:12px}
.footer-bottom{
  border-top: 1px solid #3d5166;
  margin-top: 32px;
  padding-top: 16px;
  text-align: center;
}
.footer-bottom p{font-size: 13px;color: #999;margin: 0;}
.cart-overlay,
.modal-overlay,
.thankyou-popup{
  position:fixed;inset:0;
  background:rgba(0,0,0,.55);
  z-index:200;
  display:none;
  align-items:center;
  justify-content:center;
}
.modal-overlay{z-index:210}
.thankyou-popup{z-index:220}
.cart-popup{
  background:#fff;
  width:92vw;
  max-width:680px;
  max-height:90vh;
  border-radius:10px;
  display:flex;
  flex-direction:column;
  overflow:hidden;
}
.cart-header{
  display:flex;
  justify-content:space-between;
  align-items:center;
  padding:22px 28px;
  border-bottom:1px solid #eee;
}
.cart-header h2{margin:0;font-size:1.25rem;color:#222}
.cart-header h2 i{margin-right:8px;color:#4DB6AC}
.cart-close{
  background:none;border:none;
  font-size:20px;color:#999;
  cursor:pointer;padding:4px;
}
.cart-close:hover{color:#333}
.cart-body{
  flex:1;
  overflow-y:auto;
  padding:20px 28px;
}
.cart-empty{text-align:center;color:#999;padding:40px 0;font-size:15px}
.cart-item{
  display:flex;
  align-items:center;
  gap:16px;
  padding:14px 0;
  border-bottom:1px solid #f0f0f0;
}
.cart-item img{width:64px;height:64px;object-fit:cover;border-radius:4px;flex-shrink:0}
.cart-item-info{flex:1;min-width:0}
.cart-item-name{font-size:14px;font-weight:600;color:#222;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.cart-item-price{font-size:13px;color:#4DB6AC;font-weight:500;margin-top:2px}
.cart-item-qty{display:flex;align-items:center;gap:0;border:1px solid #e5e5e5;border-radius:4px;overflow:hidden}
.cart-item-qty button{
  width:32px;height:32px;
  background:#f8f8f8;border:none;
  cursor:pointer;font-size:16px;color:#333;
  display:flex;align-items:center;justify-content:center;
}
.cart-item-qty button:hover{background:#eee}
.cart-item-qty span{width:36px;text-align:center;font-size:14px;font-weight:600;background:#fff}
.cart-item-rm{background:none;border:none;color:#ccc;cursor:pointer;font-size:16px;padding:6px;flex-shrink:0}
.cart-item-rm:hover{color:#e74c3c}
.cart-footer{
  padding:18px 28px;
  border-top:1px solid #eee;
  display:none;
}
.cart-total{
  display:flex;
  justify-content:space-between;
  align-items:center;
  margin-bottom:16px;
  font-size:1.125rem;
  color:#222;
}
.cart-total strong{font-size:1.375rem;color:#4DB6AC}
.cart-actions{display:flex;gap:12px}
.cart-actions .btn-primary,
.cart-actions .btn-secondary{
  flex:1;text-align:center;
  padding:12px 16px;
  font-size:14px;
}
.modal-box{
  background:#fff;
  width:92vw;
  max-width:440px;
  border-radius:10px;
  padding:32px 28px;
  position:relative;
}
.modal-box .cart-close{position:absolute;top:14px;right:14px}
.modal-box h3{font-size:1.25rem;color:#222;margin:0 0 22px}
.modal-box .form-grp label{color:#555}
.modal-box .form-grp input{border:1px solid #e5e5e5;background:#fff}
.modal-box .form-grp input:focus{box-shadow:0 0 0 3px rgba(77,182,172,.3);border-color:#4DB6AC}
.thankyou-box{
  background:#fff;
  border-radius:10px;
  padding:40px 36px;
  text-align:center;
  max-width:380px;
  width:90vw;
}
.thankyou-box>i{font-size:48px;color:#4DB6AC;display:block;margin-bottom:16px}
.thankyou-box h3{font-size:1.25rem;color:#222;margin:0 0 10px}
.thankyou-box p{font-size:14px;color:#666;margin-bottom:22px}
.thankyou-box .btn-primary{padding:12px 36px}
.gdpr-banner{
  position:fixed;
  bottom:24px;
  left:50%;
  transform:translateX(-50%);
  z-index:300;
  display:none;
}
.gdpr-box{
  background:#2C3E50;
  color:#e0e0e0;
  border-radius:12px;
  padding:24px 32px;
  max-width:640px;
  width:92vw;
  box-shadow:0 12px 40px rgba(0,0,0,.25);
}
.gdpr-text p{font-size:13px;line-height:1.6;margin:0 0 16px}
.gdpr-text a{color:#4DB6AC;text-decoration:underline}
.gdpr-buttons{display:flex;gap:10px;flex-wrap:wrap;align-items:center}
.gdpr-btn{padding:10px 20px;font-size:13px;border-radius:22px}
.gdpr-settings-btn{
  background:none;border:none;
  color:#c8c8c8;font-size:13px;
  cursor:pointer;padding:8px 12px;
}
.gdpr-settings-btn:hover{color:#fff}
.gdpr-settings{
  margin-top:14px;
  padding-top:14px;
  border-top:1px solid rgba(255,255,255,.12);
}
.gdpr-opt{
  display:flex;
  align-items:center;
  gap:8px;
  font-size:13px;
  color:#c8c8c8;
  margin-bottom:8px;
  cursor:pointer;
}
.gdpr-opt input{accent-color:#4DB6AC}
.gdpr-save{margin-top:10px}
.section-alt{background:#f4f4f4}
.page-title{font-size:2rem;font-weight:700;color:#222;margin-bottom:28px;line-height:1.3}
.page-date{font-size:13px;color:#999;margin-bottom:32px}
.page-content h2{font-size:1.25rem;margin-bottom:12px}
.page-contact{margin-top:36px;padding-top:24px;border-top:1px solid #eee}
.page-contact p{font-size:14px;color:#555}
.section-alt{background:#f4f4f4}
.history-heading{font-size:1.375rem;margin-bottom:14px}
.local-coverage{padding:82px 0 76px;background:#fff}
.local-coverage .row{display:flex;gap:50px;align-items:stretch}
.local-coverage .col-l{flex:1 1 55%}
.local-coverage .col-l h2{color:#2C3E50;font-size:2rem;font-weight:700;margin-bottom:18px}
.local-coverage .col-l p{color:#555;font-size:15px;margin-bottom:14px}
@media (max-width: 1024px){
  .hero h1{ font-size: 2.375rem; }
  .hero .container{ flex-direction: column; }
  .hero-image{ text-align:center; margin-top: 30px; }
  .services-grid{ grid-template-columns: 1fr; }
  .steps-row{grid-template-columns:1fr 1fr;gap:28px}
  .gallery-grid{grid-template-columns:1fr 1fr}
  .gal-wide{grid-column:span 1}
}
@media (max-width: 768px){
  .top-bar{ font-size: 12px; }
  .top-bar .container{ flex-direction: column; gap: 4px; }
  .site-header .container{ flex-wrap: wrap; }
  .main-nav{ display: none; }
  .hero{ padding: 50px 0 0; }
  .hero h1{ font-size: 1.875rem; }
  .hero-buttons{ flex-direction: column; gap: 10px; }
  .section{ padding: 50px 0; }
  .section-tight{ padding: 42px 0; }
  .intro-row{ flex-direction: column; gap: 30px; }
  .dual-cards .grid{grid-template-columns:1fr}
  .testimonials .row{ grid-template-columns: 1fr; }
  .site-footer .row{ grid-template-columns: 1fr; }
  .steps-row{grid-template-columns:1fr}
  .gallery-grid{grid-template-columns:1fr}
  .form-row{flex-direction:column;gap:0}
  .cart-popup{width:100vw;max-width:100vw;height:100vh;max-height:100vh;border-radius:0}
  .cart-actions{flex-direction:column}
  .article-band{padding:60px 0 56px}
  .local-coverage .row{display:block}
  .local-coverage .col-r{margin-top:24px}
}
@media (max-width: 480px){
  .hero h1{ font-size: 1.625rem; }
  .feature-band h2{ font-size: 1.5rem; }
  .btn-primary, .btn-secondary{ width: 100%; text-align:center; }
  .gdpr-box{padding:18px 20px}
  .gdpr-buttons{flex-direction:column;width:100%}
  .gdpr-btn{width:100%;text-align:center}
}
