/* ===== リフォームのおりはし（折橋板金）サンプルHP ===== */
/* 案A：温かみ・人間性重視型／ブラウン系＋オフホワイト＋オレンジ */

:root{
  --brown:#5b4636;        /* メイン：濃いブラウン */
  --brown-light:#8a6f57;  /* サブブラウン */
  --cream:#faf6f0;        /* オフホワイト背景 */
  --cream-card:#fffdfa;   /* カード背景 */
  --orange:#e8821e;       /* アクセント：オレンジ */
  --orange-dark:#cf6f12;
  --navy:#33404d;         /* CTA背景の紺 */
  --text:#1f1c18;
  --text-light:#3d3833;
  --line:#e6ddd2;
  --shadow:0 4px 18px rgba(91,70,54,.10);
}

*{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  font-family:"Hiragino Kaku Gothic ProN","Yu Gothic",-apple-system,sans-serif;
  color:var(--text);background:var(--cream);line-height:1.8;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block;}
a{color:inherit;text-decoration:none;}
.serif{font-family:"Hiragino Mincho ProN","Yu Mincho",serif;}

/* ---- レイアウト ---- */
.wrap{max-width:1080px;margin:0 auto;padding:0 20px;}
section{padding:64px 0;}
.sec-head{text-align:center;margin-bottom:40px;}
.sec-head .en{display:block;color:var(--orange);font-size:13px;letter-spacing:.2em;font-weight:700;margin-bottom:6px;}
.sec-head h2{font-size:27px;font-weight:700;color:var(--brown);}
.sec-head .lead{color:var(--text-light);font-size:15px;margin-top:10px;}

/* ---- ヘッダー ---- */
header.site{
  position:sticky;top:0;z-index:100;background:rgba(250,246,240,.96);
  border-bottom:1px solid var(--line);backdrop-filter:blur(6px);
}
.site-inner{display:flex;align-items:center;justify-content:space-between;height:64px;}
.logo{font-weight:700;color:var(--brown);font-size:20px;letter-spacing:.02em;}
.logo small{display:block;font-size:11px;color:var(--text-light);font-weight:500;letter-spacing:.05em;}
.gnav ul{display:flex;gap:24px;list-style:none;align-items:center;}
.gnav a{font-size:14px;font-weight:600;padding:6px 0;border-bottom:2px solid transparent;transition:.2s;}
.gnav a:hover{color:var(--orange);border-color:var(--orange);}
.gnav .tel{color:var(--brown);font-weight:700;font-size:15px;}
.hamburger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:8px;}
.hamburger span{width:26px;height:2px;background:var(--brown);transition:.3s;}

/* ---- ファーストビュー（全幅・三浦建築板金スタイル） ---- */
.hero{position:relative;min-height:78vh;display:flex;align-items:center;
  background:url('../images/roof_d.jpg') center top/cover no-repeat;}
.hero::before{content:"";position:absolute;inset:0;
  background:linear-gradient(90deg,rgba(40,28,18,.78) 0%,rgba(40,28,18,.50) 40%,rgba(40,28,18,.18) 75%,rgba(40,28,18,.05) 100%);}
.hero-inner{position:relative;z-index:2;width:100%;}
.hero-copy{color:#fff;max-width:600px;}
.hero-copy .brand{font-size:14px;letter-spacing:.14em;margin-bottom:14px;opacity:.95;}
.hero-copy h1{font-size:48px;font-weight:700;line-height:1.4;text-shadow:0 2px 14px rgba(0,0,0,.4);}
.hero-copy h1 .accent{color:#ffd29a;}
.hero-copy p{margin-top:20px;font-size:16px;line-height:1.9;text-shadow:0 1px 8px rgba(0,0,0,.5);}
.hero-copy .since{display:inline-block;margin-top:24px;background:rgba(232,130,30,.95);
  padding:9px 22px;border-radius:30px;font-size:14px;font-weight:700;}

/* ---- 選ばれる理由 ---- */
.reasons{background:var(--cream);}
.reason-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;}
.reason{background:var(--cream-card);border-radius:14px;padding:32px 24px;text-align:center;
  box-shadow:var(--shadow);border:1px solid var(--line);}
.reason .num{display:inline-flex;width:48px;height:48px;border-radius:50%;
  background:var(--orange);color:#fff;font-size:20px;font-weight:700;
  align-items:center;justify-content:center;margin-bottom:16px;font-family:serif;}
.reason h3{font-size:19px;color:var(--brown);margin-bottom:10px;}
.reason p{font-size:15.5px;color:var(--text-light);line-height:1.85;}

/* ---- サービス ---- */
.services{background:#f3ebe1;}
.svc-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px;}
.svc{background:var(--cream-card);border-radius:14px;overflow:hidden;box-shadow:var(--shadow);
  display:flex;flex-direction:column;}
.svc .ph{aspect-ratio:16/10;overflow:hidden;}
.svc .ph img{width:100%;height:100%;object-fit:cover;transition:.4s;}
.svc:hover .ph img{transform:scale(1.05);}
.svc .body{padding:20px 22px;flex:1;display:flex;flex-direction:column;}
.svc h3{font-size:20px;color:var(--brown);margin-bottom:8px;}
.svc p{font-size:15.5px;color:var(--text-light);flex:1;line-height:1.85;}
.svc .more{margin-top:14px;color:var(--orange);font-weight:700;font-size:14.5px;}
.svc-note{text-align:center;margin-top:24px;font-size:15px;color:var(--text-light);}
.svc-note a{color:var(--orange);font-weight:700;text-decoration:underline;}

/* ---- 施工事例 ---- */
.works{background:var(--cream);}
.work-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;}
.work{border-radius:12px;overflow:hidden;box-shadow:var(--shadow);background:var(--cream-card);}
.work .ph{aspect-ratio:4/3;overflow:hidden;}
.work .ph img{width:100%;height:100%;object-fit:cover;transition:.4s;}
.work:hover .ph img{transform:scale(1.06);}
.work .cap{padding:12px 14px;font-size:14px;font-weight:600;color:var(--brown);}
.work .cap span{display:block;font-size:11px;color:var(--orange);font-weight:700;margin-bottom:3px;}
.center-btn{text-align:center;margin-top:36px;}
.btn{display:inline-block;padding:14px 38px;border-radius:32px;font-weight:700;font-size:15px;transition:.25s;}
.btn-orange{background:var(--orange);color:#fff;box-shadow:0 4px 14px rgba(232,130,30,.35);}
.btn-orange:hover{background:var(--orange-dark);transform:translateY(-2px);}
.btn-outline{border:2px solid var(--brown);color:var(--brown);}
.btn-outline:hover{background:var(--brown);color:#fff;}

/* ---- 私たち ---- */
.about{background:#f3ebe1;}
.about-inner{display:grid;grid-template-columns:1.1fr 1fr;gap:40px;align-items:center;}
.about-photo{position:relative;}
.about-photo>img{border-radius:14px;box-shadow:var(--shadow);width:100%;}
.about-text h2{font-size:25px;color:var(--brown);margin-bottom:18px;line-height:1.5;}
.about-text p{font-size:16px;color:var(--text-light);margin-bottom:16px;line-height:1.9;}
.daihyo-card{position:absolute;right:-12px;bottom:-18px;
  background:var(--cream-card);border-radius:12px;box-shadow:var(--shadow);
  padding:12px 14px;display:flex;align-items:center;gap:10px;max-width:240px;
  border:1px solid var(--line);}
.daihyo-card img{width:54px;height:54px;border-radius:50%;object-fit:cover;flex-shrink:0;
  border:2px solid var(--orange);}
.daihyo-card .d-quote{font-size:12.5px;color:var(--brown);font-weight:700;margin:0 0 2px;line-height:1.4;}
.daihyo-card .d-name{font-size:11px;color:var(--text-light);margin:0;}

/* ---- 流れ ---- */
.flow{background:var(--cream);}
.flow-steps{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;counter-reset:step;}
.step{background:var(--cream-card);border-radius:12px;padding:24px 16px;text-align:center;
  box-shadow:var(--shadow);position:relative;}
.step::before{counter-increment:step;content:"0" counter(step);
  font-family:serif;font-size:30px;color:var(--orange);font-weight:700;display:block;margin-bottom:8px;}
.step h4{font-size:16px;color:var(--brown);margin-bottom:6px;}
.step p{font-size:14px;color:var(--text-light);line-height:1.75;}
.flow-note{text-align:center;margin-top:20px;font-size:14.5px;color:var(--text-light);}

/* ---- CTA ---- */
.cta{background:var(--navy);color:#fff;text-align:center;}
.cta h2{font-size:26px;margin-bottom:14px;}
.cta p{font-size:16px;opacity:.95;margin-bottom:24px;line-height:1.85;}
.cta .tel-big{font-size:34px;font-weight:700;letter-spacing:.02em;margin-bottom:6px;}
.cta .tel-big a{color:#fff;}
.cta .hours{font-size:13px;opacity:.8;margin-bottom:22px;}
.cta .btn-orange{font-size:16px;padding:16px 46px;}

/* ---- フッター ---- */
footer.site{background:var(--brown);color:#f0e4d6;padding:40px 0 28px;font-size:14px;line-height:1.85;}
.foot-inner{display:flex;justify-content:space-between;flex-wrap:wrap;gap:24px;}
.foot-info .fname{font-size:17px;font-weight:700;color:#fff;margin-bottom:8px;}
.foot-nav ul{list-style:none;line-height:2;}
.foot-nav a:hover{color:#fff;text-decoration:underline;}
.copy{text-align:center;margin-top:28px;padding-top:18px;border-top:1px solid rgba(255,255,255,.15);opacity:.7;font-size:12px;}

/* ---- フローティングCTA（スマホ） ---- */
.float-cta{display:none;}

/* ---- サンプル帯 ---- */
.sample-bar{background:#fff3d6;color:#6a4d0e;text-align:center;font-size:13px;padding:7px 12px;border-bottom:1px solid #f0e0b8;}

/* ===== レスポンシブ ===== */
@media(max-width:880px){
  .reason-grid,.work-grid,.flow-steps{grid-template-columns:repeat(2,1fr);}
  .about-inner{grid-template-columns:1fr;}
  .hero{min-height:64vh;}
  .hero-copy h1{font-size:36px;}
  .daihyo-card{position:static;margin-top:14px;max-width:none;}
}
@media(max-width:600px){
  section{padding:48px 0;}
  .gnav{position:fixed;inset:64px 0 auto 0;background:var(--cream);
    flex-direction:column;border-bottom:1px solid var(--line);
    max-height:0;overflow:hidden;transition:max-height .3s;}
  .gnav.open{max-height:420px;}
  .gnav ul{flex-direction:column;gap:0;padding:8px 0;}
  .gnav li{width:100%;text-align:center;border-bottom:1px solid var(--line);}
  .gnav a{display:block;padding:14px;}
  .hamburger{display:flex;}
  .svc-grid{grid-template-columns:1fr;}
  .work-grid{grid-template-columns:repeat(2,1fr);}
  .reason-grid,.flow-steps{grid-template-columns:1fr;}
  .hero-copy h1{font-size:30px;}
  .hero{min-height:58vh;}
  .sec-head h2{font-size:22px;}
  /* スマホ常時表示のフローティング電話CTA */
  .float-cta{display:flex;position:fixed;bottom:0;left:0;right:0;z-index:90;}
  .float-cta a{flex:1;text-align:center;padding:14px;font-weight:700;font-size:15px;color:#fff;}
  .float-cta .f-tel{background:var(--brown);}
  .float-cta .f-mail{background:var(--orange);}
  body{padding-bottom:52px;}
}

/* ===================================================== */
/* ==========  サブページ共通スタイル（追加） ========== */
/* ===================================================== */

/* ---- ページタイトル帯（全サブページ共通） ---- */
.page-hero{
  position:relative;padding:64px 0 52px;text-align:center;color:#fff;overflow:hidden;
  background:linear-gradient(135deg,var(--brown) 0%,var(--brown-light) 100%);
}
.page-hero::before{
  content:"";position:absolute;inset:0;
  background:url('../images/roof_d.jpg') center/cover no-repeat;
  opacity:.16;z-index:0;
}
.page-hero .wrap{position:relative;z-index:1;}
.page-hero .en{display:block;color:#ffd29a;font-size:12.5px;letter-spacing:.28em;font-weight:700;margin-bottom:8px;}
.page-hero h1{font-family:"Hiragino Mincho ProN","Yu Mincho",serif;font-size:32px;font-weight:700;line-height:1.4;}
.page-hero .lead{margin-top:14px;font-size:15.5px;opacity:.95;line-height:1.85;}

/* ---- サブセクション共通 ---- */
.page-section{padding:64px 0;}
.page-section.bg-card{background:#f3ebe1;}
.section-title{text-align:center;margin-bottom:36px;}
.section-title .en{display:block;color:var(--orange);font-size:12px;letter-spacing:.2em;font-weight:700;margin-bottom:6px;}
.section-title h2{font-size:25px;font-weight:700;color:var(--brown);}
.section-title p{color:var(--text-light);font-size:15px;margin-top:8px;line-height:1.85;}

/* ---- 仮置き注釈ボックス ---- */
.note-box{
  background:#fff8ed;border-left:4px solid var(--orange);
  padding:14px 18px;font-size:14px;color:#6a4d0e;
  margin:18px 0;border-radius:6px;line-height:1.8;
}

/* ===== about.html : 私たちについて ===== */
.greeting{
  background:var(--cream-card);border-radius:14px;
  padding:32px;box-shadow:var(--shadow);
  display:grid;grid-template-columns:200px 1fr;gap:32px;align-items:center;
}
.greeting img{width:200px;height:200px;object-fit:cover;border-radius:50%;border:4px solid var(--orange);}
.greeting h3{font-size:22px;color:var(--brown);margin-bottom:16px;
  font-family:"Hiragino Mincho ProN","Yu Mincho",serif;line-height:1.5;}
.greeting p{font-size:16.5px;color:var(--text-light);margin-bottom:14px;line-height:2.0;}
.greeting .signature{text-align:right;font-size:16px;color:var(--brown);font-weight:700;margin-top:10px;}

.staff-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;}
.staff-card{
  background:var(--cream-card);border-radius:12px;
  padding:22px 16px;text-align:center;box-shadow:var(--shadow);
}
.staff-card .ph{
  width:90px;height:90px;border-radius:50%;
  background:linear-gradient(135deg,var(--brown-light),var(--brown));
  margin:0 auto 12px;display:flex;align-items:center;justify-content:center;
  color:#fff;font-size:30px;font-weight:700;font-family:serif;
  border:3px solid var(--orange);
}
.staff-card h4{font-size:16px;color:var(--brown);margin-bottom:4px;}
.staff-card .role{font-size:13px;color:var(--orange);font-weight:700;margin-bottom:8px;}
.staff-card p{font-size:14px;color:var(--text-light);line-height:1.8;}

.craftsman-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;}
.craftsman{
  background:var(--cream-card);border-radius:10px;padding:16px;
  display:flex;align-items:center;gap:14px;box-shadow:var(--shadow);
}
.craftsman .ph{
  width:54px;height:54px;border-radius:50%;flex-shrink:0;
  background:var(--brown-light);color:#fff;font-family:serif;
  display:flex;align-items:center;justify-content:center;font-weight:700;font-size:22px;
}
.craftsman .info h4{font-size:14.5px;color:var(--brown);margin-bottom:2px;}
.craftsman .info p{font-size:13px;color:var(--text-light);}

/* ===== company.html : 会社案内 ===== */
.company-table{
  background:var(--cream-card);border-radius:12px;overflow:hidden;
  box-shadow:var(--shadow);
}
.company-table dl{display:grid;grid-template-columns:160px 1fr;}
.company-table dt{
  background:#efe4d4;padding:14px 18px;
  font-size:14.5px;font-weight:700;color:var(--brown);
  border-bottom:1px solid var(--line);
}
.company-table dd{
  padding:14px 18px;font-size:15.5px;color:var(--text);line-height:1.8;
  border-bottom:1px solid var(--line);
}
.company-table dl > *:nth-last-of-type(1),
.company-table dl > *:nth-last-of-type(2){border-bottom:none;}

.cert-list{
  background:var(--cream-card);border-radius:12px;padding:24px 28px;
  box-shadow:var(--shadow);
}
.cert-list h3{
  font-size:16px;color:var(--brown);margin-bottom:14px;padding-bottom:8px;
  border-bottom:2px solid var(--orange);display:inline-block;
}
.cert-list ul{list-style:none;margin-bottom:20px;}
.cert-list li{
  font-size:15.5px;color:var(--text);padding:7px 0 7px 22px;position:relative;line-height:1.75;
}
.cert-list li::before{
  content:"●";color:var(--orange);position:absolute;left:0;font-size:10px;top:11px;
}
.cert-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px;}

.access-info{background:var(--cream-card);border-radius:12px;padding:24px 28px;box-shadow:var(--shadow);}
.access-info dl{display:grid;grid-template-columns:90px 1fr;gap:10px 16px;margin-top:8px;}
.access-info dt{font-size:14px;color:var(--orange);font-weight:700;padding-top:3px;}
.access-info dd{font-size:15.5px;color:var(--text);line-height:1.8;}
.map-frame{
  margin-top:18px;border-radius:10px;overflow:hidden;
  border:1px solid var(--line);aspect-ratio:16/9;background:#eee;
}
.map-frame iframe{width:100%;height:100%;border:0;display:block;}

/* ===== services.html : サービス ===== */
.service-detail{
  background:var(--cream-card);border-radius:14px;overflow:hidden;
  box-shadow:var(--shadow);margin-bottom:30px;
  display:grid;grid-template-columns:1fr 1fr;
}
.service-detail .ph{overflow:hidden;}
.service-detail .ph img{width:100%;height:100%;object-fit:cover;min-height:280px;}
.service-detail.reverse .ph{order:2;}
.service-detail .body{padding:34px 32px;display:flex;flex-direction:column;justify-content:center;}
.service-detail h3{
  font-size:23px;color:var(--brown);margin-bottom:6px;
  font-family:"Hiragino Mincho ProN","Yu Mincho",serif;
}
.service-detail .en{color:var(--orange);font-size:11.5px;letter-spacing:.2em;font-weight:700;margin-bottom:14px;display:block;}
.service-detail p{font-size:15.5px;color:var(--text-light);margin-bottom:14px;line-height:1.9;}
.feature-list{margin-top:8px;list-style:none;}
.feature-list li{
  font-size:15px;color:var(--text);padding:6px 0 6px 22px;position:relative;line-height:1.75;
}
.feature-list li::before{content:"✓";color:var(--orange);font-weight:700;position:absolute;left:0;}

.service-cta{
  background:#fff8ed;border-radius:12px;padding:22px 26px;
  text-align:center;margin-top:24px;border:1px dashed var(--orange);
  font-size:15px;line-height:1.85;color:var(--text);
}
.service-cta a{color:var(--orange-dark);font-weight:700;text-decoration:underline;}

/* ===== works.html : 施工事例 ===== */
.works-tabs{
  display:flex;justify-content:center;gap:10px;margin-bottom:30px;flex-wrap:wrap;
}
.works-tab{
  padding:9px 22px;border-radius:24px;
  background:var(--cream-card);border:2px solid var(--brown-light);
  font-size:13.5px;color:var(--brown);font-weight:700;cursor:pointer;transition:.2s;
}
.works-tab.active{background:var(--brown);color:#fff;border-color:var(--brown);}
.works-tab:hover:not(.active){background:#efe4d4;}

.work-card{background:var(--cream-card);border-radius:12px;overflow:hidden;box-shadow:var(--shadow);}
.work-card .ph{aspect-ratio:4/3;overflow:hidden;}
.work-card .ph img{width:100%;height:100%;object-fit:cover;transition:.4s;}
.work-card:hover .ph img{transform:scale(1.05);}
.work-card .body{padding:14px 16px;}
.work-card .cat{font-size:12px;color:var(--orange);font-weight:700;letter-spacing:.1em;margin-bottom:4px;}
.work-card h4{font-size:15.5px;color:var(--brown);margin-bottom:6px;}
.work-card p{font-size:14px;color:var(--text-light);line-height:1.8;}

.works-note{text-align:center;font-size:14.5px;color:var(--text-light);margin-top:30px;line-height:1.85;}

/* ===== flow.html : ご依頼の流れ・FAQ ===== */
.flow-extended{
  display:grid;grid-template-columns:repeat(4,1fr);gap:16px;counter-reset:fstep;
}
.flow-extended .fstep{
  background:var(--cream-card);border-radius:12px;padding:22px 14px;
  text-align:center;box-shadow:var(--shadow);position:relative;
}
.flow-extended .fstep::before{
  counter-increment:fstep;content:"STEP " counter(fstep,decimal-leading-zero);
  font-family:serif;font-size:11px;color:var(--orange);
  font-weight:700;letter-spacing:.1em;display:block;margin-bottom:6px;
}
.flow-extended .icon{
  width:50px;height:50px;border-radius:50%;
  background:var(--brown);color:#ffd29a;
  display:flex;align-items:center;justify-content:center;
  margin:0 auto 10px;font-size:20px;
}
.flow-extended .fstep h4{font-size:15.5px;color:var(--brown);margin-bottom:6px;}
.flow-extended .fstep p{font-size:13.5px;color:var(--text-light);line-height:1.75;}

.support-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;}
.support-item{
  background:var(--cream-card);border-radius:12px;padding:22px;
  box-shadow:var(--shadow);border-top:4px solid var(--orange);
}
.support-item .num{
  display:inline-block;background:var(--orange);color:#fff;
  font-family:serif;font-size:12px;font-weight:700;
  padding:2px 10px;border-radius:12px;margin-bottom:10px;letter-spacing:.05em;
}
.support-item h4{font-size:16px;color:var(--brown);margin-bottom:8px;}
.support-item p{font-size:14.5px;color:var(--text-light);line-height:1.85;}

.faq-list{max-width:820px;margin:0 auto;}
.faq{
  background:var(--cream-card);border-radius:10px;
  margin-bottom:12px;box-shadow:var(--shadow);overflow:hidden;
}
.faq summary{
  list-style:none;cursor:pointer;padding:18px 22px 18px 56px;
  font-size:16px;font-weight:700;color:var(--brown);
  position:relative;
}
.faq summary::-webkit-details-marker{display:none;}
.faq summary::before{
  content:"Q";position:absolute;left:18px;top:50%;transform:translateY(-50%);
  width:26px;height:26px;border-radius:50%;
  background:var(--orange);color:#fff;font-family:serif;
  display:flex;align-items:center;justify-content:center;font-size:13px;
}
.faq summary::after{
  content:"＋";position:absolute;right:22px;top:50%;
  transform:translateY(-50%);color:var(--orange);font-weight:700;font-size:18px;
}
.faq[open] summary::after{content:"−";}
.faq .ans{padding:0 22px 20px 56px;font-size:15px;color:var(--text-light);line-height:1.9;position:relative;}
.faq .ans::before{
  content:"A";position:absolute;left:18px;top:0;
  width:26px;height:26px;border-radius:50%;
  background:var(--brown);color:#fff;font-family:serif;
  display:flex;align-items:center;justify-content:center;font-size:13px;
}

.payment-icons{
  display:flex;justify-content:center;gap:14px;flex-wrap:wrap;margin-top:14px;
}
.payment-icons span{
  padding:9px 22px;border-radius:6px;background:#fff;
  border:1px solid var(--line);font-size:14px;color:var(--text);font-weight:700;
}

/* ===== contact.html : お問い合わせ ===== */
.contact-grid{display:grid;grid-template-columns:1.4fr 1fr;gap:30px;}
.contact-form{
  background:var(--cream-card);border-radius:14px;padding:32px;box-shadow:var(--shadow);
}
.contact-form .field{margin-bottom:18px;}
.contact-form label{
  display:block;font-size:14.5px;font-weight:700;color:var(--brown);margin-bottom:6px;
}
.contact-form .req{
  color:#fff;background:var(--orange);font-size:10px;padding:2px 8px;
  border-radius:4px;margin-left:6px;vertical-align:1px;letter-spacing:.05em;
}
.contact-form input, .contact-form textarea{
  width:100%;padding:13px 14px;font-size:15.5px;
  border:1px solid var(--line);border-radius:8px;
  background:var(--cream);font-family:inherit;color:var(--text);transition:.2s;
}
.contact-form textarea{min-height:140px;resize:vertical;}
.contact-form input:focus, .contact-form textarea:focus{
  outline:none;border-color:var(--orange);background:#fff;
}
.contact-form button{
  display:block;width:100%;background:var(--orange);color:#fff;
  font-size:16px;font-weight:700;padding:16px;border:none;border-radius:8px;
  cursor:pointer;margin-top:8px;transition:.25s;
}
.contact-form button:hover{background:var(--orange-dark);transform:translateY(-1px);}
.form-note{font-size:13px;color:var(--text-light);text-align:center;margin-top:14px;line-height:1.75;}

.contact-side{display:flex;flex-direction:column;gap:18px;}
.tel-card{
  background:var(--brown);color:#fff;border-radius:14px;padding:26px;text-align:center;
}
.tel-card h3{font-size:15px;font-weight:700;margin-bottom:10px;opacity:.9;}
.tel-card .num{font-size:30px;font-weight:700;letter-spacing:.02em;margin-bottom:4px;}
.tel-card .num a{color:#fff;}
.tel-card .hours{font-size:13.5px;opacity:.9;margin-top:6px;line-height:1.7;}

.access-card{background:var(--cream-card);border-radius:14px;padding:24px;box-shadow:var(--shadow);}
.access-card h3{font-size:16px;color:var(--brown);margin-bottom:10px;}
.access-card p{font-size:14.5px;color:var(--text);margin-bottom:6px;line-height:1.85;}
.access-card a{color:var(--orange-dark);font-weight:700;}

/* ===== サブページ用レスポンシブ ===== */
@media(max-width:880px){
  .greeting{grid-template-columns:1fr;text-align:center;}
  .greeting img{width:160px;height:160px;margin:0 auto;}
  .staff-grid, .craftsman-grid{grid-template-columns:repeat(2,1fr);}
  .company-table dl{grid-template-columns:120px 1fr;}
  .cert-grid{grid-template-columns:1fr;}
  .service-detail, .service-detail.reverse{grid-template-columns:1fr;}
  .service-detail.reverse .ph{order:0;}
  .service-detail .ph img{min-height:220px;}
  .flow-extended{grid-template-columns:repeat(2,1fr);}
  .support-grid{grid-template-columns:repeat(2,1fr);}
  .contact-grid{grid-template-columns:1fr;}
  .page-hero h1{font-size:26px;}
}
@media(max-width:600px){
  .staff-grid, .craftsman-grid, .support-grid, .flow-extended{grid-template-columns:1fr;}
  .company-table dl{grid-template-columns:100px 1fr;}
  .company-table dt, .company-table dd{padding:10px 12px;font-size:13px;}
  .greeting, .cert-list, .access-info, .contact-form, .access-card{padding:20px;}
  .service-detail .body{padding:24px 20px;}
  .page-hero{padding:42px 0 36px;}
  .page-hero h1{font-size:22px;}
}
