/* Top B — まるごと安心（friendly / rounded / playful） */


/* hero with organic blob */
.hero{position:relative;background:var(--green-700);color:#fff;overflow:hidden;padding-block:50px 80px;}
.hero::before{content:"";position:absolute;right:-12%;top:-30%;width:60%;height:120%;z-index:0;
  background:var(--green-500);border-radius:46% 54% 42% 58%/55% 45% 55% 45%;opacity:.4;}
.hero::after{content:"";position:absolute;left:-8%;bottom:-40%;width:42%;height:90%;z-index:0;
  background:var(--green-800);border-radius:50%;opacity:.4;}
.hero .container{position:relative;z-index:1;display:grid;grid-template-columns:1.08fr .92fr;gap:46px;align-items:center;}
.hero .eyebrow{color:#dff0d8;}.hero .eyebrow::before{background:var(--sun-300);}
.hero h1{font-size:clamp(34px,5vw,58px);color:#fff;line-height:1.34;font-weight:900;}
.hero h1 em{font-style:normal;color:var(--sun-300);}
.hero .lead{margin-top:22px;font-size:18px;color:#e7f1e3;line-height:2;}
.trust{display:flex;flex-wrap:wrap;gap:10px 24px;margin-top:26px;}
.trust li{display:flex;align-items:center;gap:9px;
  font-family:var(--font-disp);font-weight:700;font-size:15px;color:#fff;white-space:nowrap;}
.trust li .icon{width:22px;height:22px;padding:3px;flex:none;color:#f3d28a;
  background:rgba(255,255,255,.16);border:1.5px solid rgba(243,210,138,.6);border-radius:4px;}
.trust li span{text-decoration:underline;text-decoration-color:rgba(243,210,138,.85);
  text-decoration-thickness:1.5px;text-underline-offset:4px;}
.hero .cta{display:flex;gap:14px;margin-top:28px;flex-wrap:wrap;}

/* hero card with stamp */
.card{position:relative;background:#fff;border-radius:16px;padding:34px;box-shadow:var(--sh-lg);color:var(--ink);}
.card .stamps{position:absolute;top:-30px;right:-14px;display:flex;gap:10px;z-index:2;}
.card .stamp{position:static;width:88px;height:88px;font-size:12px;line-height:1.3;transform:none;border-width:2px;}
.card .stamp-wash{width:88px;height:88px;font-size:11px;line-height:1.3;transform:none;
  box-shadow:0 10px 24px rgba(40,138,95,.28);}
.card h3{color:var(--green-900);font-size:20px;margin-bottom:18px;}
/* FVタイル：2行の横カルーセル（PCは2列＝4枚表示、残り2枚はチラ見せ＋スクロールボタン） */
.tiles-wrap{position:relative;}
.tiles{display:grid;grid-auto-flow:column;grid-template-rows:1fr 1fr;grid-auto-columns:calc(44% - 6px);
  gap:12px;overflow-x:auto;scroll-snap-type:x mandatory;scroll-behavior:smooth;
  scrollbar-width:none;-webkit-overflow-scrolling:touch;}
.tiles::-webkit-scrollbar{display:none;}
.tiles .tile{scroll-snap-align:start;}
/* スクロールボタン */
.tiles-nav{position:absolute;top:50%;right:-4px;transform:translateY(-50%);z-index:3;
  width:44px;height:44px;border-radius:50%;border:none;cursor:pointer;
  background:var(--orange-600);color:#fff;display:grid;place-items:center;box-shadow:var(--sh-md);
  transition:background .15s,transform .15s;}
.tiles-nav:hover{background:var(--orange-700);transform:translateY(-50%) scale(1.06);}
.tiles-nav .icon{width:20px;height:20px;}
.tiles-wrap.is-end .tiles-nav .icon{transform:rotate(180deg);}
/* 右端フェードで「まだ続く」ことを示す */
.tiles-wrap::after{content:"";position:absolute;top:0;right:0;width:56px;height:100%;pointer-events:none;
  border-radius:0 16px 16px 0;background:linear-gradient(to right,rgba(255,255,255,0),#fff 92%);
  opacity:1;transition:opacity .2s;}
.tiles-wrap.is-end::after{opacity:0;}
.tile{background:var(--green-50);border-radius:10px;padding:16px;text-align:center;font-family:var(--font-disp);font-weight:700;font-size:14px;color:var(--green-800);}
.tile .ic{width:48px;height:48px;border-radius:8px;background:#fff;display:grid;place-items:center;margin:0 auto 10px;color:var(--green-600);box-shadow:var(--sh-sm);}
.tile .ic .icon{width:26px;height:26px;}
.tile:nth-child(2) .ic,.tile:nth-child(3) .ic{color:var(--orange-600);}
/* photo variant tile (FV) */
.tile.photo{position:relative;padding:0;overflow:hidden;aspect-ratio:4/3;display:block;}
.tile.photo img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block;}
.tile.photo .tile-label{position:absolute;left:8px;bottom:8px;z-index:1;
  background:rgba(40,138,95,.92);color:#fff;font-family:var(--font-disp);font-weight:700;font-size:13px;
  padding:5px 12px;border-radius:var(--r-pill,999px);backdrop-filter:blur(2px);}
@media(max-width:860px){.hero .container{grid-template-columns:1fr;gap:34px;}}
/* mobile: FVタイルを横スクロール（縦長解消） */
@media(max-width:560px){
  /* スマホはタイル大きめ＋次の列をチラ見せ */
  .tiles{grid-auto-columns:calc(64% - 6px);}
  /* lead小さめ / CTA中央寄せ */
  .hero .lead{font-size:16px;}
  .trust li{font-size:16px;}
  .hero .cta{justify-content:center;}
  /* 背景ブロブの縦伸び解消（縦横比1で円形に） */
  .hero::before{width:108%;height:auto;aspect-ratio:1/1;top:-4%;right:-30%;}
  .hero::after{width:87%;height:auto;aspect-ratio:1/1;bottom:-6%;left:-32%;}
}


/* pain bubbles */
.pain{background:var(--cream);padding-block:72px 80px;text-align:center;}
.pain .lead-q{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;margin-bottom:28px;}
.pain .q{background:#fff;border:2px dashed var(--orange-300);border-radius:10px;padding:14px 22px;
  font-family:var(--font-disp);font-weight:700;color:var(--ink);box-shadow:var(--sh-sm);}
.pain h2{font-size:clamp(26px,3.6vw,40px);color:var(--green-900);line-height:1.45;}
.pain h2 mark{background:linear-gradient(transparent 60%,var(--sun-300) 60%);color:inherit;padding:0 2px;}
.pain .arrow{margin:22px auto 0;width:54px;height:54px;border-radius:50%;background:var(--orange-600);color:#fff;display:grid;place-items:center;}
.pain .arrow .icon{width:28px;height:28px;}

/* services — colorful tiles */
.serv{background:var(--green-50);}
.serv .grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:44px;}
.stile{background:#fff;border-radius:12px;text-align:center;position:relative;overflow:hidden;
  box-shadow:var(--sh-sm);}
.stile-photo{display:block;width:100%;height:170px;object-fit:cover;}
.stile-body{position:relative;padding:22px 24px 28px;}
.stile h3{font-size:18px;color:var(--green-900);position:relative;}
.stile p{margin-top:9px;font-size:14px;color:var(--ink-soft);position:relative;line-height:1.8;}
@media(max-width:860px){.serv .grid{grid-template-columns:1fr 1fr;}}
@media(max-width:560px){
  .serv .grid{grid-template-columns:1fr;gap:14px;}
  /* できることカードの高さを抑える */
  .stile-photo{height:130px;}
  /* 水まわり・リフォームの写真は上の部分が見えるようにする */
  .stile:nth-child(1) .stile-photo,
  .stile:nth-child(2) .stile-photo{object-position:center 25%;}
  /* ハウスクリーニングの写真も上の部分を見せる */
  .stile:nth-child(3) .stile-photo{object-position:center 30%;}
  .stile-body{padding:16px 20px 20px;}
  .stile h3{font-size:16px;}
  .stile p{margin-top:7px;font-size:13px;line-height:1.7;}
}

/* reasons — big numbers, alternating rows */
.reason{background:var(--cream-2);}
.reason .row{display:grid;grid-template-columns:auto 1fr;gap:28px;align-items:center;
  background:#fff;border-radius:12px;border-left:6px solid var(--green-500);padding:26px 32px;box-shadow:var(--sh-sm);margin-top:18px;}
.reason .row:nth-child(even){border-left-color:var(--orange-500);}
.reason .row .num{font-family:var(--font-disp);font-weight:900;font-size:56px;color:var(--green-200);line-height:1;}
.reason .row h3{font-size:21px;color:var(--green-900);}
.reason .row p{margin-top:6px;color:var(--ink-soft);font-size:15px;}
.reason .row .ic{width:84px;height:84px;border-radius:50%;background:var(--green-100);color:var(--green-600);display:grid;place-items:center;}
.reason .row:nth-child(even) .ic{background:var(--orange-100);color:var(--orange-600);}
.reason .row .ic .icon{width:42px;height:42px;}
@media(max-width:680px){.reason .row{grid-template-columns:auto 1fr;}.reason .row .ic{display:none;}}

/* area */
.area{background:var(--orange-100);}
.area .container{display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:center;}
.area h2{font-size:clamp(26px,3.4vw,38px);color:var(--green-900);}
.area p{margin-top:14px;color:var(--ink-soft);}
.area .pins{display:flex;gap:10px;flex-wrap:wrap;margin-top:20px;}
.area .pin{background:#fff;border-radius:var(--r-pill);padding:9px 18px;font-family:var(--font-disp);font-weight:700;
  font-size:14px;color:var(--orange-700);display:flex;align-items:center;gap:6px;box-shadow:var(--sh-sm);}
.area .pin .icon{width:16px;height:16px;color:var(--orange-600);}
.area .mapcard{background:#fff;border-radius:14px;padding:30px;box-shadow:var(--sh-md);text-align:center;}
.area .mapcard .big-ic{width:120px;height:120px;border-radius:16px;background:var(--green-600);color:#fff;display:grid;place-items:center;margin:0 auto 16px;}
.area .mapcard .big-ic .icon{width:64px;height:64px;}
@media(max-width:760px){.area .container{grid-template-columns:1fr;gap:28px;}}

/* company + license (B tone: rounded, soft) */
.company{background:var(--green-50);}
.company .head{text-align:center;margin-bottom:44px;}
.company .grid{display:grid;grid-template-columns:1fr 1fr;gap:24px;align-items:start;}
.cocard{background:#fff;border-radius:14px;padding:36px 34px;box-shadow:var(--sh-sm);}
.cocard .ttl{display:flex;align-items:center;gap:12px;margin-bottom:22px;}
.cocard .ttl .ic{width:52px;height:52px;border-radius:9px;background:var(--green-100);color:var(--green-600);
  display:grid;place-items:center;flex:none;}
.cocard.lic .ttl .ic{background:var(--orange-100);color:var(--orange-600);}
.cocard .ttl .ic .icon{width:28px;height:28px;}
.cocard .ttl h3{font-size:23px;color:var(--green-900);font-weight:900;}
.cotable{width:100%;border-collapse:collapse;}
.cotable th,.cotable td{text-align:left;padding:14px 0;border-bottom:1px dashed var(--green-200);
  font-size:14.5px;vertical-align:top;line-height:1.7;}
.cotable tr:last-child th,.cotable tr:last-child td{border-bottom:none;}
.cotable th{width:96px;color:var(--green-700);font-family:var(--font-disp);font-weight:700;white-space:nowrap;}
.cotable td{color:var(--ink-soft);}
.cocard.lic .lead{color:var(--ink-soft);font-size:14.5px;margin-bottom:20px;line-height:1.8;}
.quals{display:flex;flex-wrap:wrap;gap:10px;}
.qual{background:var(--green-50);border:1.5px solid var(--green-200);border-radius:var(--r-pill);
  padding:9px 17px;font-family:var(--font-disp);font-weight:700;font-size:13.5px;color:var(--green-800);}
.qual.soon{background:var(--orange-100);border-color:var(--orange-200);color:var(--orange-700);}
@media(max-width:820px){.company .grid{grid-template-columns:1fr;}}

/* works (施工事例) — B tone: rounded cards */
.works{background:var(--cream);}
.works .head{display:flex;justify-content:space-between;align-items:flex-end;flex-wrap:wrap;gap:18px;margin-bottom:42px;}
.works .grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;}
.wcard{background:#fff;border-radius:12px;overflow:hidden;box-shadow:var(--sh-sm);display:flex;flex-direction:column;
  text-decoration:none;color:inherit;transition:transform .2s,box-shadow .2s;}
.wcard:hover{transform:translateY(-6px);box-shadow:var(--sh-lg);}
.wphoto{position:relative;aspect-ratio:4/3;background:var(--green-100);display:grid;place-items:center;color:var(--green-500);overflow:hidden;}
.wphoto .icon{width:64px;height:64px;}
.wphoto img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;}
.wphoto .ph{position:absolute;bottom:10px;left:50%;transform:translateX(-50%);font-size:11px;color:var(--ink-faint);
  font-family:var(--font-disp);font-weight:700;letter-spacing:.06em;white-space:nowrap;}
.wbody{padding:22px 24px 26px;display:flex;flex-direction:column;flex:1;}
.wtags{display:flex;flex-wrap:wrap;gap:7px;margin-bottom:12px;}
.wtags span{background:var(--green-50);color:var(--green-700);border-radius:var(--r-pill);padding:5px 12px;
  font-family:var(--font-disp);font-weight:700;font-size:12px;}
.wdate{font-size:12.5px;color:var(--ink-faint);font-family:var(--font-disp);font-weight:700;letter-spacing:.04em;}
.wcard h3{font-size:19px;color:var(--green-900);margin:6px 0 10px;line-height:1.5;}
.wcard p{font-size:14px;color:var(--ink-soft);line-height:1.8;flex:1;}
.wmore{margin-top:16px;display:flex;align-items:center;gap:7px;color:var(--orange-600);
  font-family:var(--font-disp);font-weight:700;font-size:14.5px;}
.wmore .icon{width:18px;height:18px;}
@media(max-width:820px){.works .grid{grid-template-columns:1fr;}}

/* header nav CTA (orange button) */
.nav-cta{background:var(--orange-600);color:#fff;font-family:var(--font-disp);font-weight:700;font-size:15px;
  padding:11px 22px;border-radius:var(--r-pill);white-space:nowrap;
  box-shadow:0 6px 16px rgba(242,110,69,.32);transition:transform .18s ease,background .18s ease;}
.nav-cta:hover{background:var(--orange-700);color:#fff;transform:translateY(-2px);}
@media(max-width:940px){.nav-cta{display:none;}}

/* concept (社名にこめた想い) — B tone */
.concept{background:var(--green-50);}
.concept-head{text-align:center;margin-bottom:36px;}
.concept-head .eyebrow{display:inline-block;white-space:nowrap;margin-bottom:12px;}
.concept-card{background:#fff;border-radius:16px;box-shadow:var(--sh-md);max-width:860px;margin:0 auto;
  padding:54px 48px 52px;text-align:center;position:relative;}
.concept-badge{position:absolute;top:-32px;left:50%;transform:translateX(-50%);
  width:66px;height:66px;border-radius:50%;background:var(--orange-600);color:#fff;display:grid;place-items:center;
  box-shadow:0 10px 22px rgba(242,110,69,.32);border:4px solid #fff;}
.concept-badge .icon{width:34px;height:34px;}
.equation{display:flex;align-items:center;justify-content:center;gap:18px;flex-wrap:wrap;margin-bottom:28px;}
.eq-name{font-family:var(--font-disp);font-weight:900;font-size:clamp(22px,3.2vw,36px);color:var(--green-800);letter-spacing:.02em;white-space:nowrap;}
.eq-sign{font-family:var(--font-disp);font-weight:900;font-size:clamp(20px,2.8vw,30px);color:var(--green-500);}
.eq-mean{font-family:var(--font-disp);font-weight:900;font-size:clamp(22px,3.2vw,36px);color:#fff;
  background:var(--orange-600);padding:8px 22px;border-radius:9px;box-shadow:0 10px 22px rgba(242,110,69,.28);white-space:nowrap;}
.concept-sub{font-family:var(--font-disp);font-weight:900;font-size:clamp(21px,2.8vw,30px);color:var(--green-900);
  line-height:1.55;margin-bottom:26px;}
.concept-body{max-width:600px;margin:0 auto;display:flex;flex-direction:column;gap:18px;}
.concept-body p{color:var(--ink-soft);font-size:16px;line-height:2.05;text-wrap:pretty;}
.sp-br{display:none;}
@media(max-width:560px){.concept-card{padding:56px 22px 44px;}.sp-br{display:inline;}}

/* contact */
.cta-section{background:var(--green-700);color:#fff;text-align:center;}
.cta-section h2{color:#fff;font-size:clamp(26px,3.6vw,42px);font-weight:900;}
.cta-section p{color:#dbe9d6;margin-top:14px;max-width:640px;margin-inline:auto;}

/* contact form (B tone: white rounded card, soft fields) */
.form{background:#fff;border-radius:14px;padding:44px 46px;box-shadow:var(--sh-lg);text-align:left;
  max-width:760px;margin:38px auto 0;display:grid;grid-template-columns:1fr 1fr;gap:20px 24px;}
.field{display:flex;flex-direction:column;gap:8px;}
.field.full{grid-column:1 / -1;}
.form > .full{grid-column:1 / -1;}
.field label{font-family:var(--font-disp);font-weight:700;font-size:14px;color:var(--green-900);display:flex;align-items:center;gap:6px;}
.field .req{color:var(--orange-600);font-size:13px;}
.form input,.form select,.form textarea{font-family:var(--font-body);font-size:15px;color:var(--ink);
  background:var(--green-50);border:1.5px solid var(--green-100);border-radius:8px;padding:13px 16px;width:100%;
  transition:border-color .15s,background .15s,box-shadow .15s;}
.form input::placeholder,.form textarea::placeholder{color:var(--ink-faint);}
.form input:focus,.form select:focus,.form textarea:focus{outline:none;background:#fff;
  border-color:var(--green-500);box-shadow:0 0 0 4px rgba(73,181,131,.16);}
.form textarea{resize:vertical;min-height:120px;line-height:1.8;}
.form select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%2333a072' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 16px center;background-size:18px;padding-right:44px;}
.agree{grid-column:1 / -1;display:flex;align-items:center;gap:10px;justify-content:center;
  font-size:14px;color:var(--ink-soft);margin-top:4px;}
.agree input{width:20px;height:20px;flex:none;accent-color:var(--green-600);}
.agree a{color:var(--green-700);font-weight:700;text-decoration:underline;}
.form-note{font-size:12.5px;color:var(--ink-faint);margin-top:14px;line-height:1.7;}
@media(max-width:680px){.form{grid-template-columns:1fr;padding:30px 22px;}}
