/* ===== まちのクリーニング LP ===== */
:root{
  --primary:#1f62b2;
  --primary-dark:#1a5499;
  --heading:#16386c;
  --ink:#43505f;
  --muted:#7c8794;
  --star:#fbbc2b;
  --tint:#ecf4fc;
  --tint-soft:#f5f9fd;
  --card:#ffffff;
  --line:#e3ecf5;
  --radius:16px;
  --radius-sm:10px;
  --shadow:0 8px 24px rgba(31,98,178,.08);
  --shadow-sm:0 4px 14px rgba(31,98,178,.06);
  --font-head:'Zen Maru Gothic',sans-serif;
  --font-body:'Noto Sans JP',sans-serif;
  --maxw:1060px;
}

*{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;}
body{
  font-family:var(--font-body);
  color:var(--ink);
  background:#fff;
  line-height:1.75;
  -webkit-font-smoothing:antialiased;
  font-feature-settings:"palt" 1;
}
img{display:block;max-width:100%;}
a{color:inherit;text-decoration:none;}
.container{max-width:var(--maxw);margin:0 auto;padding:0 24px;}

/* ---------- Header ---------- */
.site-header{
  position:sticky;top:0;z-index:50;
  background:rgba(255,255,255,.92);
  backdrop-filter:blur(8px);
  border-bottom:1px solid var(--line);
}
.header-inner{display:flex;align-items:center;gap:16px;padding:12px 24px;max-width:1180px;margin:0 auto;}
.brand{display:flex;align-items:center;gap:12px;flex:none;}
.brand img{width:42px;height:42px;}
.brand-name{font-family:var(--font-head);color:var(--heading);font-size:21px;font-weight:700;letter-spacing:.02em;line-height:1.2;white-space:nowrap;}
.brand-tag{font-size:11.5px;color:var(--muted);letter-spacing:.02em;}
.main-nav{display:flex;gap:14px;margin-left:auto;}
.main-nav a{font-size:13.5px;color:var(--heading);font-weight:500;transition:color .2s;white-space:nowrap;}
.main-nav a:hover{color:var(--primary);}
.header-phone{
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  background:var(--primary);color:#fff;border-radius:12px;flex:none;
  padding:8px 22px;text-align:center;box-shadow:var(--shadow-sm);white-space:nowrap;
}
.header-phone .num{font-family:var(--font-head);font-size:20px;font-weight:700;display:flex;align-items:center;gap:8px;line-height:1.2;white-space:nowrap;}
.header-phone .hours{font-size:11px;opacity:.92;white-space:nowrap;}

/* ---------- Buttons ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:10px;
  font-family:var(--font-head);font-weight:700;font-size:16px;
  padding:15px 30px;border-radius:var(--radius-sm);cursor:pointer;border:none;
  transition:transform .15s ease, box-shadow .2s ease, background .2s ease;white-space:nowrap;}
.btn:hover{transform:translateY(-2px);}
.btn-primary{background:var(--primary);color:#fff;box-shadow:0 8px 18px rgba(31,98,178,.22);}
.btn-primary:hover{background:var(--primary-dark);box-shadow:0 12px 24px rgba(31,98,178,.28);}
.btn-outline{background:#fff;color:var(--primary);border:1.5px solid #cdddef;box-shadow:var(--shadow-sm);}
.btn-outline:hover{border-color:var(--primary);}
.btn .ic{width:20px;height:20px;stroke:currentColor;fill:none;stroke-width:1.8;}

/* ---------- Hero ---------- */
.hero{position:relative;background:linear-gradient(160deg,#e9f2fb 0%,#f5f9fe 46%,#ffffff 100%);overflow:hidden;}
.hero-inner{max-width:1180px;margin:0 auto;padding:78px 24px 92px;position:relative;z-index:2;}
.hero-text{max-width:560px;}
.hero h1{font-family:var(--font-head);color:var(--heading);font-weight:700;
  font-size:54px;line-height:1.32;letter-spacing:.02em;margin-bottom:26px;}
.hero-sub{font-size:18px;color:#4d5a68;line-height:1.9;margin-bottom:36px;}
.hero-actions{display:flex;gap:18px;flex-wrap:wrap;}
.hero-photo{position:absolute;right:0;top:0;height:100%;width:46%;z-index:1;}
.hero-photo img{width:100%;height:100%;object-fit:cover;object-position:left center;
  -webkit-mask-image:linear-gradient(to right,transparent 0%,#000 22%);
  mask-image:linear-gradient(to right,transparent 0%,#000 22%);}

/* ---------- Section frame ---------- */
section.block{padding:64px 0;}
.block.tint{background:linear-gradient(180deg,var(--tint) 0%,var(--tint-soft) 100%);}
.section-title{font-family:var(--font-head);color:var(--heading);font-weight:700;
  font-size:32px;text-align:center;letter-spacing:.04em;margin-bottom:40px;}
.section-title .sm{font-size:18px;color:var(--muted);font-weight:500;margin-left:8px;}

/* ---------- Worry cards ---------- */
.worry-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;}
.worry-card{background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow);
  padding:24px 22px;display:flex;align-items:center;gap:16px;}
.worry-card .ill{width:64px;height:76px;flex:none;object-fit:contain;}
.worry-card .body{flex:1;}
.worry-card p{font-size:15.5px;color:#3f4b59;font-weight:500;line-height:1.75;word-break:keep-all;line-break:strict;}
.worry-card .chk{width:24px;height:24px;flex:none;}

/* ---------- Service cards ---------- */
.svc-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:16px;}
.svc-card{background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden;
  display:flex;flex-direction:column;}
.svc-card .photo{aspect-ratio:1/.66;overflow:hidden;background:#f0f0f0;}
.svc-card .photo img{width:100%;height:100%;object-fit:cover;}
.svc-card .info{padding:16px 16px 20px;text-align:center;}
.svc-card .name{display:flex;align-items:center;justify-content:center;gap:7px;
  font-family:var(--font-head);color:var(--heading);font-weight:700;font-size:18px;margin-bottom:9px;}
.svc-card .name .ic{width:22px;height:22px;stroke:var(--primary);fill:none;stroke-width:1.6;}
.svc-card .desc{font-size:13.5px;color:var(--muted);line-height:1.7;}

/* ---------- Reasons ---------- */
.reason-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;}
.reason-card{background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow);
  padding:30px 24px;display:flex;gap:18px;align-items:center;}
.reason-card .ic{width:54px;height:80px;flex:none;object-fit:contain;}
.reason-card h3{font-family:var(--font-head);color:var(--heading);font-weight:700;font-size:20px;margin-bottom:12px;white-space:nowrap;}
.reason-card p{font-size:14.5px;color:var(--ink);line-height:1.85;word-break:keep-all;line-break:strict;}

/* ---------- Flow ---------- */
.flow-grid{display:flex;align-items:stretch;justify-content:center;gap:8px;}
.flow-step{background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow);
  padding:22px 20px 18px;flex:1;max-width:230px;display:flex;flex-direction:column;}
.flow-step .head{display:flex;align-items:center;gap:11px;margin-bottom:12px;}
.flow-step .badge{width:30px;height:30px;border-radius:50%;background:var(--primary);color:#fff;
  font-family:var(--font-head);font-weight:700;font-size:15px;display:flex;align-items:center;justify-content:center;flex:none;}
.flow-step h4{font-family:var(--font-head);color:var(--heading);font-weight:700;font-size:18px;white-space:nowrap;}
.flow-step p{font-size:13.5px;color:var(--ink);line-height:1.7;margin-bottom:14px;word-break:keep-all;line-break:strict;}
.flow-step .ill{margin-top:auto;height:64px;object-fit:contain;align-self:center;}
.flow-arrow{display:flex;align-items:center;color:var(--primary);flex:none;}
.flow-arrow svg{width:26px;height:26px;}

/* ---------- Price ---------- */
.price-wrap{background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden;max-width:920px;margin:0 auto;}
.price-grid{display:grid;grid-template-columns:repeat(3,1fr);}
.price-head{background:#5d7196;color:#fff;font-family:var(--font-head);font-weight:700;font-size:14.5px;
  text-align:center;padding:11px 0;letter-spacing:.06em;}
.price-cell{display:flex;align-items:center;gap:13px;padding:18px 24px;border-top:1px solid var(--line);border-right:1px solid var(--line);}
.price-grid .price-cell:nth-child(3n){border-right:none;}
.price-cell .ic{width:34px;height:34px;flex:none;stroke:var(--primary);fill:none;stroke-width:1.4;}
.price-cell .pname{flex:1;font-size:15px;color:#3f4b59;font-weight:500;word-break:keep-all;line-break:strict;}
.price-cell .pname small{color:var(--muted);font-size:12.5px;margin-left:3px;font-weight:400;display:inline-block;white-space:nowrap;}
.price-cell .amt{font-family:var(--font-head);color:var(--heading);font-weight:700;font-size:19px;white-space:nowrap;}
.price-note{text-align:center;font-size:13px;color:var(--muted);margin-top:18px;}

/* ---------- Testimonials ---------- */
.voice-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;}
.voice-card{background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow);padding:26px 26px 22px;display:flex;gap:18px;}
.voice-card .ava{width:54px;height:54px;border-radius:50%;flex:none;object-fit:cover;background:#eef3f8;}
.voice-card .stars{color:var(--star);font-size:15px;letter-spacing:2px;margin-bottom:8px;}
.voice-card p{font-size:14px;color:var(--ink);line-height:1.8;margin-bottom:10px;word-break:keep-all;line-break:strict;}
.voice-card .who{font-size:12.5px;color:var(--muted);}

/* ---------- Shop ---------- */
.shop-grid{display:grid;grid-template-columns:1fr 1fr 1.05fr;gap:28px;align-items:start;}
.shop-map img{width:100%;border-radius:var(--radius);box-shadow:var(--shadow-sm);border:1px solid var(--line);}
.shop-map .cap{font-size:13.5px;color:var(--ink);margin-top:12px;line-height:1.7;}
.shop-map-frame{width:100%;height:210px;border:0;border-radius:var(--radius);box-shadow:var(--shadow-sm);display:block;}
.shop-map .cap b{color:var(--heading);font-family:var(--font-head);}
.shop-info{display:flex;flex-direction:column;gap:6px;}
.info-row{display:flex;gap:14px;padding:13px 0;border-bottom:1px dashed var(--line);}
.info-row .lab{display:flex;align-items:center;gap:8px;color:var(--primary);font-family:var(--font-head);
  font-weight:700;font-size:14.5px;width:104px;flex:none;}
.info-row .lab .ic{width:18px;height:18px;stroke:currentColor;fill:none;stroke-width:1.7;}
.info-row .val{font-size:14.5px;color:var(--ink);line-height:1.65;}
.shop-cta{background:linear-gradient(165deg,#e4effa,#dceaf8);border-radius:var(--radius);padding:30px 30px 28px;text-align:center;border:1px solid #cfe0f4;}
.shop-cta h3{font-family:var(--font-head);color:var(--heading);font-weight:700;font-size:21px;margin-bottom:6px;}
.shop-cta .lead{font-size:13.5px;color:var(--ink);margin-bottom:14px;}
.shop-cta .num{font-family:var(--font-head);color:var(--primary);font-weight:700;font-size:32px;display:flex;align-items:center;justify-content:center;gap:10px;line-height:1.1;white-space:nowrap;}
.shop-cta .num .ic{width:26px;height:26px;stroke:currentColor;fill:none;stroke-width:1.8;}
.shop-cta .hours{font-size:12.5px;color:var(--muted);margin:6px 0 18px;}
.shop-cta .btn{width:100%;margin-bottom:12px;}
.shop-cta .btn:last-child{margin-bottom:0;}

/* ---------- Closing ---------- */
.closing{background:linear-gradient(180deg,#f5f9fd,#eef5fc);text-align:center;padding:48px 0 56px;}
.closing img{width:54px;height:54px;margin:0 auto 16px;object-fit:contain;}
.closing p{font-size:16px;color:var(--ink);line-height:1.9;}
.copyright{background:var(--heading);color:#cdd9ea;text-align:center;font-size:12.5px;padding:18px 0;}

/* ---------- Responsive ---------- */
@media(max-width:1080px){
  .shop-grid{grid-template-columns:1fr 1fr;}
  .shop-map{grid-column:1 / -1;}
  .shop-map-frame{height:280px;}
}
@media(max-width:900px){
  .main-nav{display:none;}
}
@media(max-width:860px){
  .hero{display:flex;flex-direction:column;}
  .hero-photo{
    order:1;display:block;position:static;width:100%;height:340px;
  }
  .hero-photo img{
    object-position:center;
    -webkit-mask-image:none;
    mask-image:none;
  }
  .hero-inner{order:2;padding:38px 24px 58px;}
  .hero h1{font-size:40px;}
  .worry-grid,.reason-grid,.voice-grid{grid-template-columns:1fr;}
  .svc-grid{grid-template-columns:repeat(2,1fr);}
  .price-grid{grid-template-columns:1fr;}
  .price-grid .price-cell{border-right:none;}
  .flow-grid{flex-direction:column;align-items:stretch;}
  .flow-step{max-width:none;}
  .flow-arrow{transform:rotate(90deg);align-self:center;}
  .shop-grid{grid-template-columns:1fr;}
}
@media(max-width:560px){
  .container{padding:0 18px;}
  section.block{padding:46px 0;}
  .section-title{font-size:25px;margin-bottom:28px;}
  .section-title .sm{font-size:14px;}

  /* header */
  .header-inner{gap:8px;padding:9px 14px;}
  .brand{flex:0 1 auto;min-width:0;}
  .brand>span{display:block;min-width:0;overflow:hidden;}
  .brand img{width:34px;height:34px;}
  .brand-name{font-size:16px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:block;}
  .brand-tag{display:none;}
  .header-phone{flex:none;margin-left:auto;padding:7px 13px;border-radius:10px;}
  .header-phone .num{font-size:15px;gap:6px;}
  .header-phone .num svg{width:14px;height:14px;}
  .header-phone .hours{font-size:10px;}

  /* hero */
  .hero-photo{height:300px;}
  .hero-photo img{object-position:center;}
  .hero-inner{padding:34px 18px 48px;}
  .hero h1{font-size:30px;margin-bottom:20px;}
  .hero-sub{font-size:16px;margin-bottom:28px;}
  .hero-actions{flex-direction:column;gap:12px;}
  .hero-actions .btn{width:100%;}

  /* services single column */
  .svc-grid{grid-template-columns:1fr;}
  .svc-card{flex-direction:row;align-items:center;}
  .svc-card .photo{width:120px;flex:none;aspect-ratio:1/.78;}
  .svc-card .info{flex:1;text-align:left;padding:14px 16px;}
  .svc-card .name{justify-content:flex-start;}
  .svc-card .desc br{display:none;}

  /* shop */
  .shop-map-frame{height:230px;}
  .info-row .lab{width:88px;font-size:13.5px;}
  .shop-cta{padding:26px 18px 24px;}
  .shop-cta .num{font-size:27px;}
  .shop-cta .btn{font-size:15px;padding-left:16px;padding-right:16px;}
}
@media(max-width:380px){
  .brand-name{font-size:15px;}
  .header-phone .num{font-size:14px;}
  .hero h1{font-size:26px;}
}
