﻿:root{
  --red:#9B2335;--red-dark:#721a27;
  --kuro:#1a1a18;
  --green:#2e5c3e;--green-mid:#4a7c5e;--green-pale:#e6f0e9;
  --gold:#C0903A;--gold-light:#d4a84a;
  --cream:#f8f4ee;--cream-dark:#ede7db;
  --white:#fff;
  --text:#1e1e1c;--text-mid:#333330;--text-muted:#5a5a54;
  --line:#06C755;
  --shadow:0 4px 24px rgba(0,0,0,0.12);
  --shadow-sm:0 2px 12px rgba(0,0,0,0.08);
}
*{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{font-family:'Noto Sans JP',sans-serif;color:var(--text);background:var(--white);line-height:1.8;overflow-x:hidden;}
a{color:inherit;text-decoration:none;}

/* 幕アニメーション */
#kc{position:fixed;inset:0;z-index:9999;display:flex;flex-direction:column;pointer-events:none;}
.kcp{flex:1;display:flex;align-items:center;justify-content:center;background:linear-gradient(to right,var(--red) 33.33%,var(--kuro) 33.33% 66.66%,var(--green) 66.66%);transition:transform 1.1s cubic-bezier(0.77,0,0.175,1);}
.kcp.top{transform-origin:top;}
.kcp.bot{transform-origin:bottom;}
.kcl{font-family:'Shippori Mincho',serif;font-size:clamp(1rem,3vw,1.5rem);color:rgba(255,255,255,0.9);letter-spacing:0.2em;text-align:center;transition:opacity 0.4s;}
.kcl small{display:block;font-size:0.55em;letter-spacing:0.3em;color:var(--gold-light);margin-top:6px;}
#kc.open .kcp.top{transform:translateY(-100%);}
#kc.open .kcp.bot{transform:translateY(100%);}
#kc.open .kcl{opacity:0;}

.ks{height:5px;background:linear-gradient(to right,var(--red) 33.33%,var(--kuro) 33.33% 66.66%,var(--green) 66.66%);}

/* ★ HEADER 2段 - ボタンサイズ修正 */
header{position:fixed;top:0;left:0;right:0;z-index:200;background:rgba(26,26,24,0.97);backdrop-filter:blur(8px);}
.htb{display:flex;align-items:center;justify-content:flex-end;gap:12px;padding:0 24px;height:38px;border-bottom:1px solid rgba(255,255,255,0.06);}
.htb-tel{font-family:'Shippori Mincho',serif;font-size:1.05rem;color:var(--gold-light);font-weight:600;letter-spacing:0.05em;}
.htb-hrs{font-size:0.67rem;color:rgba(255,255,255,0.4);margin-left:-6px;}
/* ★ ボタンをheight固定でoverflow解消 */
.htb-btn{
  display:inline-flex;align-items:center;justify-content:center;
  height:26px;padding:0 11px;border-radius:2px;
  font-weight:700;font-size:0.65rem;letter-spacing:0.03em;white-space:nowrap;
  flex-shrink:0;
}
.htb-btn.ln{background:var(--line);color:var(--white);}
.htb-btn.ct{background:var(--red);color:var(--white);}
.htb-btn:hover{opacity:.85;}
.hmb{display:flex;align-items:center;justify-content:space-between;padding:0 24px;height:58px;}
.lw{display:flex;align-items:center;gap:9px;flex-shrink:0;}
.lm{width:32px;height:32px;background:var(--red);border-radius:3px;display:flex;align-items:center;justify-content:center;font-family:'Shippori Mincho',serif;font-size:0.95rem;color:var(--white);font-weight:600;}
.lt{display:flex;flex-direction:column;line-height:1.2;}
.lj{font-family:'Shippori Mincho',serif;font-size:0.9rem;color:var(--white);font-weight:600;letter-spacing:0.06em;}
.le{font-size:0.56rem;color:rgba(255,255,255,0.35);letter-spacing:0.12em;text-transform:uppercase;}
nav{display:flex;gap:16px;align-items:center;}
nav a{color:rgba(255,255,255,0.72);font-size:0.72rem;letter-spacing:0.05em;transition:color .2s;white-space:nowrap;}
nav a:hover{color:var(--gold-light);}
.hbg{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:4px;}
.hbg span{display:block;width:21px;height:2px;background:var(--white);border-radius:2px;transition:transform 0.25s,opacity 0.25s;}
.hbg.open span:nth-child(1){transform:translateY(7px) rotate(45deg);}
.hbg.open span:nth-child(2){opacity:0;}
.hbg.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg);}
.mmenu{display:none;position:fixed;top:96px;left:0;right:0;z-index:190;background:rgba(26,26,24,0.99);padding:16px 22px 24px;border-top:1px solid rgba(255,255,255,0.07);}
.mmenu.open{display:block;}
.mmenu a{display:block;color:rgba(255,255,255,0.82);font-size:0.87rem;padding:10px 0;border-bottom:1px solid rgba(255,255,255,0.07);}
.mbtns{margin-top:16px;display:flex;flex-direction:column;gap:9px;}
.mbtn{display:block;text-align:center;padding:13px;border-radius:3px;font-size:0.9rem;font-weight:700;}
.mbtn.tel{background:var(--red);color:var(--white);}
.mbtn.ln2{background:var(--line);color:var(--white);}
.mbtn.ml{background:rgba(255,255,255,0.1);color:var(--white);border:1px solid rgba(255,255,255,0.2);}

/* 共通 */
section{padding:88px 0;}
.container{max-width:1080px;margin:0 auto;padding:0 40px;}
.slabel{font-size:0.67rem;letter-spacing:0.24em;color:var(--red);text-transform:uppercase;font-family:'Shippori Mincho',serif;margin-bottom:10px;}
.stitle{font-family:'Noto Serif JP',serif;font-size:clamp(1.5rem,3vw,2.1rem);font-weight:700;color:var(--kuro);line-height:1.5;margin-bottom:14px;}
.stitle em{font-style:normal;color:var(--red);}
.slead{color:var(--text-mid);font-size:0.93rem;font-weight:400;max-width:580px;line-height:2;}
.shead{margin-bottom:52px;}
.shead.center{text-align:center;}
.shead.center .slead{margin:0 auto;}
.div{width:36px;height:2px;background:var(--red);margin:16px 0 24px;}
.div.c{margin:16px auto 24px;}

/* ★ HERO - 左右2カラム + 背景画像 */
.hero{
  min-height:100vh;padding-top:96px;
  position:relative;overflow:hidden;
  display:flex;flex-direction:column;
}
/* 背景画像 */
.hero-bg{
  position:absolute;inset:0;width:100%;height:100%;
  object-fit:cover;object-position:center;z-index:0;
}
/* オーバーレイ：文字が読めるように */
.hero-overlay{
  position:absolute;inset:0;z-index:1;
  background:linear-gradient(
    135deg,
    rgba(10,18,12,0.82) 0%,
    rgba(10,18,12,0.72) 50%,
    rgba(10,18,12,0.60) 100%
  );
}
.hero>.ks{position:relative;z-index:2;}

/* ★ 2カラムグリッド */
.hero-body{
  flex:1;display:grid;
  grid-template-columns:58% 42%;
  align-items:center;gap:48px;
  position:relative;z-index:2;
}
.hero-left{padding:56px 0;}
.hero-poem{
  font-family:'Shippori Mincho',serif;
  font-size:clamp(0.84rem,1.5vw,0.98rem);
  color:rgba(255,255,255,0.55);line-height:2.4;
  letter-spacing:0.1em;margin-bottom:26px;
  border-left:2px solid rgba(155,35,53,0.55);
  padding-left:18px;font-style:italic;
}
.hero-badge{
  display:inline-flex;align-items:center;gap:8px;
  background:rgba(155,35,53,0.2);border:1px solid rgba(155,35,53,0.42);
  color:rgba(255,200,200,0.9);font-size:0.7rem;letter-spacing:0.12em;
  padding:5px 15px;border-radius:2px;margin-bottom:18px;
}
.hero-badge-dot{width:6px;height:6px;background:var(--red);border-radius:50%;flex-shrink:0;animation:pulse 2s infinite;}
@keyframes pulse{0%,100%{opacity:1;}50%{opacity:0.3;}}
.hero h1{
  font-family:'Noto Serif JP',serif;
  font-size:clamp(1.9rem,4vw,3rem);
  color:var(--white);font-weight:700;line-height:1.5;
  margin-bottom:18px;letter-spacing:0.03em;
}
.hero h1 .ac{color:#e8a0a8;}
.hero-lead{
  font-size:0.9rem;color:rgba(255,255,255,0.75);
  font-weight:300;line-height:2;max-width:520px;margin-bottom:32px;
}
.hero-lead strong{color:rgba(255,255,255,0.95);font-weight:500;}
.hero-ctas{display:flex;flex-direction:column;gap:12px;}
.h-tel{
  display:inline-flex;align-items:center;gap:14px;
  background:var(--red);color:var(--white);
  padding:15px 26px;border-radius:3px;width:fit-content;
  transition:background .2s,transform .2s;
}
.h-tel:hover{background:var(--red-dark);transform:translateY(-1px);}
.h-tel-i{font-size:1.2rem;}
.h-tel-in{display:flex;flex-direction:column;}
.h-tel-l{font-size:0.62rem;letter-spacing:0.1em;opacity:.82;margin-bottom:2px;}
.h-tel-n{font-family:'Shippori Mincho',serif;font-size:1.45rem;font-weight:600;letter-spacing:0.08em;line-height:1;}
.h-subs{display:flex;gap:10px;flex-wrap:wrap;}
.btn-ln{display:inline-flex;align-items:center;gap:7px;background:var(--line);color:var(--white);padding:11px 20px;border-radius:3px;font-size:0.82rem;font-weight:700;transition:opacity .2s;}
.btn-ln:hover{opacity:.85;}
.btn-ol{border:1px solid rgba(255,255,255,0.35);color:rgba(255,255,255,0.82);padding:11px 20px;border-radius:3px;font-size:0.82rem;transition:border-color .2s;}
.btn-ol:hover{border-color:rgba(255,255,255,0.7);}

/* ★ 右カラム：信頼パネル縦並び */
.hero-right{padding:56px 0;display:flex;flex-direction:column;gap:12px;}
.hero-right-ttl{
  font-family:'Shippori Mincho',serif;
  font-size:0.78rem;color:rgba(255,255,255,0.45);
  letter-spacing:0.14em;margin-bottom:4px;
}
.tpanel{
  background:rgba(0,0,0,0.48);
  border:1px solid rgba(255,255,255,0.12);
  border-left:3px solid var(--gold);
  border-radius:3px;padding:16px 22px;
  display:flex;align-items:center;gap:18px;
  backdrop-filter:blur(4px);
}
.tpanel-num{
  font-family:'Shippori Mincho',serif;
  font-size:2.4rem;color:var(--gold-light);
  font-weight:600;line-height:1;white-space:nowrap;flex-shrink:0;
}
.tpanel-u{font-size:1rem;}
.tpanel-info{}
.tpanel-label{font-size:0.82rem;color:rgba(255,255,255,0.88);font-weight:500;display:block;}
.tpanel-sub{font-size:0.68rem;color:rgba(255,255,255,0.45);margin-top:3px;display:block;line-height:1.5;}

/* お悩み */
.pain{background:var(--cream);}
.pgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;}
.pcard{background:var(--white);border-radius:3px;padding:22px 20px;border-top:3px solid transparent;transition:border-color .2s,box-shadow .2s;}
.pcard.s{border-top-color:var(--red);}
.pcard:hover{box-shadow:var(--shadow-sm);}
.pico{font-size:1.4rem;margin-bottom:10px;}
.ptxt{font-size:0.87rem;color:var(--text-mid);line-height:1.85;}
.ptxt strong{color:var(--kuro);font-weight:600;display:block;margin-bottom:4px;}
.pcta{margin-top:32px;background:var(--kuro);color:var(--white);border-radius:3px;padding:22px 26px;display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;}
.pcta-t p{font-family:'Noto Serif JP',serif;font-size:1rem;font-weight:700;margin-bottom:4px;}
.pcta-t span{font-size:0.82rem;color:rgba(255,255,255,0.7);font-weight:300;}
.pcta-b{background:var(--red);color:var(--white);padding:12px 24px;border-radius:3px;font-size:0.85rem;font-weight:700;white-space:nowrap;transition:background .2s;}
.pcta-b:hover{background:var(--red-dark);}

/* 選ばれる理由 */
.reasons{background:var(--white);}
.rgrid{display:grid;grid-template-columns:repeat(2,1fr);gap:22px;}
.rcard{display:flex;gap:18px;padding:26px 22px;background:var(--cream);border-radius:3px;border-left:3px solid var(--red);}
.rnum{font-family:'Shippori Mincho',serif;font-size:2rem;color:var(--red);font-weight:600;line-height:1;flex-shrink:0;width:38px;}
.rtitle{font-family:'Noto Serif JP',serif;font-size:0.97rem;font-weight:700;color:var(--kuro);margin-bottom:8px;line-height:1.5;}
.rtext{font-size:0.84rem;color:var(--text-mid);line-height:1.85;}
.dbanner{background:linear-gradient(135deg,var(--red) 0%,#c94060 100%);color:var(--white);padding:20px 26px;border-radius:3px;margin-top:28px;display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;}
.dbt p{font-family:'Noto Serif JP',serif;font-size:1rem;font-weight:700;margin-bottom:4px;}
.dbt span{font-size:0.8rem;color:rgba(255,255,255,0.78);font-weight:300;}
.dbadge{background:rgba(255,255,255,0.15);border:1px solid rgba(255,255,255,0.3);border-radius:3px;padding:11px 18px;text-align:center;flex-shrink:0;}
.dbadge .pct{font-family:'Shippori Mincho',serif;font-size:2rem;color:var(--white);font-weight:600;line-height:1;}
.dbadge .dl{font-size:0.7rem;color:rgba(255,255,255,0.7);margin-top:2px;}

/* ★ サービス - 新猫画像をメイン写真に */
.services{background:var(--cream);}
.sgrid{display:grid;grid-template-columns:repeat(2,1fr);gap:22px;}
.scard{background:var(--white);border-radius:3px;overflow:hidden;display:flex;flex-direction:column;}
.scard.feat{grid-column:span 2;}
.simg{position:relative;overflow:hidden;}
.scard.feat .simg{height:280px;}
.scard:not(.feat) .simg{height:220px;}
/* ★ 画像全体を見せる：object-fit:coverで猫が中心に */
.simg img.main{width:100%;height:100%;object-fit:cover;object-position:center;display:block;}
/* 猫画像は横長なのでtop寄せが良い場合も */
.simg img.main.top{object-position:center top;}
.sbadge{position:absolute;top:14px;left:14px;background:var(--red);color:var(--white);font-size:0.68rem;padding:4px 10px;border-radius:2px;letter-spacing:0.08em;z-index:2;}
/* 下グラデ */
.simg::after{content:'';position:absolute;bottom:0;left:0;right:0;height:60px;background:linear-gradient(to top,rgba(0,0,0,0.4),transparent);pointer-events:none;}
.sbody{padding:22px 24px 26px;flex:1;}
.sname{font-family:'Noto Serif JP',serif;font-size:1.05rem;font-weight:700;color:var(--kuro);margin-bottom:8px;}
.sdesc{font-size:0.84rem;color:var(--text-mid);line-height:1.9;}
.spts{display:flex;gap:7px;flex-wrap:wrap;margin-top:12px;}
.sp{font-size:0.72rem;background:var(--green-pale);color:var(--green);padding:3px 10px;border-radius:2px;font-weight:500;}

/* 料金 */
.pricing{background:var(--kuro);}
.pricing .slabel{color:var(--gold-light);}
.pricing .stitle{color:var(--white);}
.pricing .div{background:var(--gold);}
.ptables{display:grid;grid-template-columns:repeat(2,1fr);gap:18px;}
.ptable{background:rgba(255,255,255,0.05);border:1px solid rgba(255,255,255,0.1);border-radius:3px;overflow:hidden;}
.pth{background:var(--red);padding:13px 18px;font-family:'Noto Serif JP',serif;font-size:0.93rem;font-weight:700;color:var(--white);}
.pr{display:flex;justify-content:space-between;align-items:center;padding:11px 18px;border-bottom:1px solid rgba(255,255,255,0.06);font-size:0.84rem;}
.pr:last-child{border-bottom:none;}
.pi{color:rgba(255,255,255,0.82);}
.pv{color:var(--gold-light);font-family:'Shippori Mincho',serif;font-size:1rem;font-weight:600;white-space:nowrap;}
.pnote{margin-top:22px;background:rgba(255,255,255,0.04);border-radius:3px;padding:18px 22px;border-left:3px solid var(--gold);}
.pnote p{font-size:0.81rem;color:rgba(255,255,255,0.68);line-height:1.9;padding:2px 0;}
.pnote p::before{content:'※ ';color:var(--gold-light);}
.pcta2{margin-top:26px;text-align:center;}
.pcta2 p{font-size:0.87rem;color:rgba(255,255,255,0.6);margin-bottom:14px;}
.btn-red{display:inline-block;background:var(--red);color:var(--white);padding:13px 34px;border-radius:3px;font-size:0.87rem;font-weight:700;letter-spacing:0.08em;transition:background .2s;}
.btn-red:hover{background:var(--red-dark);}

/* ★ 施工事例 - object-fit:contain で全体表示 */
.works{background:var(--white);}
.wgrid{display:grid;grid-template-columns:repeat(2,1fr);gap:26px;}
.wcard{background:var(--cream);border-radius:3px;overflow:hidden;display:flex;flex-direction:column;}
.wcard.wide{grid-column:span 2;}
.wba{display:grid;grid-template-columns:1fr 1fr;position:relative;}
.wcard.wide .wba{height:280px;}
.wcard:not(.wide) .wba{height:220px;}
.wside{position:relative;overflow:hidden;display:flex;align-items:center;justify-content:center;}
/* ★ before側：暗い自然な背景 */
.wside.bef{background:#1a1e16;}
/* ★ after側：深緑の背景 */
.wside.aft{background:#1a2e1c;}
/* ★ object-fit:contain で全体が見えるように */
.wside img{
  width:100%;height:100%;
  object-fit:contain;
  display:block;
}
.wtag{position:absolute;top:10px;left:10px;font-size:0.68rem;letter-spacing:0.1em;padding:4px 10px;border-radius:2px;font-weight:700;z-index:2;}
.wside.bef .wtag{background:rgba(0,0,0,0.6);color:rgba(255,255,255,0.9);}
.wside.aft .wtag{background:var(--green);color:var(--white);}
.warrow{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);z-index:3;background:var(--white);border-radius:50%;width:30px;height:30px;display:flex;align-items:center;justify-content:center;font-size:0.72rem;color:var(--red);font-weight:900;box-shadow:0 2px 8px rgba(0,0,0,0.2);}
.wbody{padding:18px 20px 22px;flex:1;}
.wtags{display:flex;gap:7px;flex-wrap:wrap;margin-bottom:10px;}
.wt{font-size:0.68rem;padding:3px 9px;border-radius:2px;letter-spacing:0.05em;}
.wt.tp{background:var(--red);color:var(--white);}
.wt.ar{background:var(--cream-dark);color:var(--text-mid);}
.wt.bg{background:rgba(192,144,58,0.12);color:var(--gold);border:1px solid rgba(192,144,58,0.3);}
.wtitle{font-family:'Noto Serif JP',serif;font-size:0.95rem;font-weight:700;color:var(--kuro);margin-bottom:9px;line-height:1.5;}
.wrow{display:flex;gap:7px;margin-bottom:6px;font-size:0.81rem;}
.wrl{color:var(--red);font-weight:600;white-space:nowrap;flex-shrink:0;}
.wrv{color:var(--text-mid);line-height:1.7;}
.wcta{text-align:center;margin-top:40px;}
.btn-green{display:inline-block;background:var(--green);color:var(--white);padding:13px 34px;border-radius:3px;font-size:0.86rem;font-weight:700;letter-spacing:0.08em;transition:background .2s;}
.btn-green:hover{background:var(--green-mid);}

/* 対応エリア */
.area{background:var(--cream);}
.ainner{display:grid;grid-template-columns:1fr 1fr;gap:52px;}
.amw{border-radius:3px;overflow:hidden;background:var(--green-pale);margin-top:200px;}
.amw iframe{width:100%;height:100%;border:0;display:block;}
.atags{display:flex;flex-wrap:wrap;gap:9px;margin-bottom:18px;}
.atag{background:var(--green);color:var(--white);font-size:0.82rem;padding:7px 15px;border-radius:2px;letter-spacing:0.04em;}
.atag.m{background:var(--red);}
.anote{font-size:0.83rem;color:var(--text-mid);line-height:1.9;padding:15px 18px;background:var(--white);border-left:3px solid var(--gold);border-radius:2px;margin-bottom:16px;}
.aremote{background:var(--kuro);color:var(--white);border-radius:3px;padding:20px 22px;}
.aremote h4{font-family:'Noto Serif JP',serif;font-size:0.93rem;font-weight:700;margin-bottom:10px;color:var(--gold-light);}
.aremote ul{list-style:none;display:flex;flex-direction:column;gap:6px;}
.aremote ul li{font-size:0.82rem;color:rgba(255,255,255,0.85);display:flex;gap:8px;}
.aremote ul li::before{content:'✓';color:var(--gold-light);flex-shrink:0;}

/* 流れ */
.flow{background:var(--white);}
.fsteps{display:grid;grid-template-columns:repeat(4,1fr);gap:0;position:relative;}
.fsteps::before{content:'';position:absolute;top:34px;left:12.5%;right:12.5%;height:1px;background:var(--cream-dark);z-index:0;}
.fstep{text-align:center;position:relative;z-index:1;padding:0 14px;}
.fcircle{width:68px;height:68px;border-radius:50%;background:var(--white);border:2px solid var(--red);display:flex;align-items:center;justify-content:center;margin:0 auto 20px;}
.fcircle span{font-family:'Shippori Mincho',serif;font-size:1.45rem;color:var(--red);font-weight:600;}
.ftitle{font-family:'Noto Serif JP',serif;font-size:0.9rem;font-weight:700;color:var(--kuro);margin-bottom:8px;}
.ftext{font-size:0.8rem;color:var(--text-mid);line-height:1.85;}

/* ★ FAQ - 質問をShippori Minchoに */
.faq{background:var(--cream);}
.flist{max-width:740px;margin:0 auto;}
.fitem{border-bottom:1px solid var(--cream-dark);}
.fq{padding:20px 0;display:flex;justify-content:space-between;align-items:flex-start;gap:14px;cursor:pointer;user-select:none;}
/* ★ 質問テキスト → Shippori Mincho */
.fqt{
  font-size:0.97rem;
  color:var(--kuro);
  font-weight:600;
  line-height:1.65;
  flex:1;
  font-family:'Shippori Mincho',serif;
  letter-spacing:0.04em;
}
.fqt::before{content:'Q.';color:var(--red);font-size:1rem;margin-right:10px;}
.ficon{width:24px;height:24px;border:1.5px solid var(--red);border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:3px;transition:transform .3s,background .2s;}
.ficon::before{content:'+';color:var(--red);font-size:1rem;line-height:1;}
.fitem.open .ficon{background:var(--red);transform:rotate(45deg);}
.fitem.open .ficon::before{color:var(--white);}
/* ★ 回答はNoto Sans JPのまま */
.fa{display:none;padding:0 0 20px 28px;font-size:0.88rem;color:var(--text-mid);line-height:2;font-family:'Noto Sans JP',sans-serif;}
.fitem.open .fa{display:block;}

/* Instagram */
.instagram{background:var(--white);}
.igrid{display:grid;grid-template-columns:repeat(4,1fr);gap:4px;margin-bottom:22px;}
.ithumb{aspect-ratio:1;background:var(--green-pale);overflow:hidden;cursor:pointer;transition:opacity .2s;}
.ithumb:hover{opacity:.85;}
.ithumb img{width:100%;height:100%;display:block;object-fit:cover;object-position:center;}
.ilink{text-align:center;}
.ilink a{display:inline-flex;align-items:center;gap:8px;background:linear-gradient(135deg,#f09433,#e6683c,#dc2743,#cc2366,#bc1888);color:var(--white);padding:12px 28px;border-radius:3px;font-size:0.84rem;font-weight:700;transition:opacity .2s;}
.ilink a:hover{opacity:.88;}
/* クリック案内（PC表示・スマホ非表示） */
.insta-pc-hint{display:block;text-align:center;font-size:0.9rem;font-weight:700;color:var(--text-muted);margin-bottom:10px;letter-spacing:.04em;animation:insta-pulse 1.6s ease-in-out infinite;}
/* タップ案内（スマホのみ表示・PC非表示） */
.insta-tap-hint{display:none;}
@keyframes insta-pulse{
  0%,100%{transform:scale(1);opacity:.82;}
  50%{transform:scale(1.05);opacity:1;}
}
/* Instagram ライトボックス */
#insta-lb{display:none;position:fixed;inset:0;background:rgba(0,0,0,.88);z-index:9999;align-items:center;justify-content:center;}
#insta-lb.open{display:flex;}
#insta-lb img{max-width:92vw;max-height:88vh;object-fit:contain;border-radius:4px;display:block;}
#insta-lb-close{position:absolute;top:14px;right:18px;font-size:2.4rem;color:#fff;background:none;border:none;cursor:pointer;line-height:1;padding:4px 10px;}

/* 会社情報 */
.company{background:var(--cream);}
.cinner{display:grid;grid-template-columns:1.1fr 1fr;gap:52px;align-items:start;}
.ctable{width:100%;border-collapse:collapse;}
.ctable tr{border-bottom:1px solid var(--cream-dark);}
.ctable th{text-align:left;padding:13px 0;font-size:0.81rem;color:var(--text-muted);font-weight:500;width:105px;vertical-align:top;padding-top:15px;}
.ctable td{padding:13px 0;font-size:0.89rem;color:var(--text);line-height:1.85;}
.ctable td a{color:var(--red);text-decoration:underline;text-underline-offset:3px;}
.cmw{border-radius:3px;overflow:hidden;aspect-ratio:4/3;background:var(--green-pale);}
.cmw iframe{width:100%;height:100%;border:0;display:block;}

/* お問い合わせ */
.contact{background:var(--kuro);padding:88px 0;}
.contact .slabel{color:var(--gold-light);}
.contact .stitle{color:var(--white);}
.contact .div{background:var(--gold);}
.cgrid{display:grid;grid-template-columns:1fr 1fr 1.5fr;gap:16px;}
.cc{border-radius:3px;padding:26px 20px;}
.cc.tel{background:var(--red);text-align:center;display:flex;flex-direction:column;}
.cc.ln3{background:rgba(6,199,85,0.14);border:1px solid rgba(6,199,85,0.3);text-align:center;display:flex;flex-direction:column;}
.cc.ln3 .cc-top{padding-bottom:35px;}
.cc.fm{background:rgba(255,255,255,0.05);border:1px solid rgba(255,255,255,0.1);}
.cc-ico{font-size:1.7rem;margin-bottom:8px;}
.cc-lbl{font-size:0.67rem;letter-spacing:0.12em;color:rgba(255,255,255,0.65);margin-bottom:8px;}
.cc-num{font-family:'Shippori Mincho',serif;font-size:1.75rem;color:var(--white);font-weight:600;letter-spacing:0.05em;line-height:1.1;margin-bottom:4px;}
.cc-note{font-size:0.73rem;color:rgba(255,255,255,0.65);margin-bottom:14px;line-height:1.6;}
.cc-btn{display:flex;align-items:center;justify-content:center;height:44px;line-height:44px;padding:11px;border-radius:3px;font-size:0.83rem;font-weight:700;transition:opacity .2s;margin-bottom:6px;margin-top:16px;}
.cc-btn.tb{background:rgba(255,255,255,0.18);color:var(--white);}
.cc-btn.lb{background:var(--line);color:var(--white);}
.cc-btn:hover{opacity:.85;}
.cc-mail{margin-top:12px;background:rgba(255,255,255,0.07);border-radius:3px;padding:12px 14px;}
.cc-mail-l{font-size:0.65rem;color:rgba(255,255,255,0.5);letter-spacing:0.1em;margin-bottom:6px;}
.cc-mail-a{font-size:0.78rem;color:rgba(255,255,255,0.85);line-height:1.8;}
.cc-mail-a span{font-size:0.66rem;color:rgba(255,255,255,0.45);margin-right:4px;}
.cc-qr{width:128px;height:128px;border-radius:6px;margin:14px auto 0;overflow:hidden;background:var(--white);flex-shrink:0;}
.cc-qr img{width:100%;height:100%;display:block;object-fit:contain;}
.fm-ttl{font-family:'Noto Serif JP',serif;font-size:0.92rem;color:var(--white);font-weight:700;margin-bottom:16px;}
.frow{margin-bottom:12px;}
.flbl{display:block;font-size:0.75rem;color:rgba(255,255,255,0.72);margin-bottom:5px;}
.req{color:var(--gold-light);margin-left:3px;font-size:0.67rem;}
.finput{width:100%;background:rgba(255,255,255,0.09);border:1px solid rgba(255,255,255,0.18);border-radius:2px;padding:10px 12px;color:var(--white);font-size:0.86rem;font-family:'Noto Sans JP',sans-serif;outline:none;transition:border-color .2s;}
.finput::placeholder{color:rgba(255,255,255,0.25);}
.finput:focus{border-color:var(--gold-light);}
textarea.finput{resize:vertical;min-height:88px;}
select.finput option{background:var(--kuro);}
.fg2{display:grid;grid-template-columns:1fr 1fr;gap:10px;}
.fsubmit{width:100%;background:var(--red);border:none;color:var(--white);padding:13px;border-radius:3px;font-size:0.88rem;font-family:'Noto Sans JP',sans-serif;letter-spacing:0.1em;cursor:pointer;transition:background .2s;margin-top:4px;font-weight:700;}
.fsubmit:hover{background:var(--red-dark);}
.fsubmit:disabled{opacity:.6;cursor:not-allowed;}
.fmsg{display:none;margin-top:14px;padding:14px 16px;border-radius:3px;font-size:0.87rem;line-height:1.75;text-align:center;}
.fmsg.success{display:block;background:rgba(255,255,255,0.07);border:1px solid rgba(255,255,255,0.2);color:rgba(255,255,255,0.92);}
.fmsg.error{display:block;background:rgba(220,39,67,0.12);border:1px solid rgba(220,39,67,0.4);color:#ff8ea0;}
.fm-retry{display:none;width:100%;margin-top:10px;background:transparent;border:1px solid rgba(255,255,255,0.28);color:rgba(255,255,255,0.78);padding:11px;border-radius:3px;font-size:0.84rem;font-family:'Noto Sans JP',sans-serif;letter-spacing:0.08em;cursor:pointer;transition:border-color .2s,color .2s;}
.fm-retry:hover{border-color:rgba(255,255,255,0.6);color:var(--white);}
.hp-field{display:none;}

/* フッター */
footer{background:#111110;}
.finner{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:38px;padding:46px 0 34px;}
.flw{display:flex;align-items:center;gap:9px;margin-bottom:13px;}
.flm{width:30px;height:30px;background:var(--red);border-radius:2px;display:flex;align-items:center;justify-content:center;font-family:'Shippori Mincho',serif;font-size:0.9rem;color:var(--white);font-weight:600;}
.fln{font-family:'Shippori Mincho',serif;font-size:0.92rem;color:var(--white);font-weight:600;}
.fdesc{font-size:0.79rem;color:rgba(255,255,255,0.42);font-weight:300;line-height:1.85;margin-bottom:14px;}
.ftel{font-family:'Shippori Mincho',serif;font-size:1.2rem;color:var(--gold-light);font-weight:600;}
.fteln{font-size:0.67rem;color:rgba(255,255,255,0.32);}
.fcol h4{font-size:0.7rem;color:rgba(255,255,255,0.45);letter-spacing:0.14em;text-transform:uppercase;margin-bottom:13px;font-weight:400;}
.fcol ul{list-style:none;}
.fcol ul li{margin-bottom:8px;}
.fcol ul li a{color:rgba(255,255,255,0.48);font-size:0.8rem;font-weight:300;transition:color .2s;}
.fcol ul li a:hover{color:var(--gold-light);}
.fbot{border-top:1px solid rgba(255,255,255,0.07);padding:18px 0;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:8px;}
.fcopy{font-size:0.7rem;color:rgba(255,255,255,0.25);}

/* 代表紹介カード */
.pres-card{
  display:flex;align-items:center;gap:40px;
  background:var(--white);border-radius:4px;
  padding:34px 38px;margin-bottom:52px;
  box-shadow:var(--shadow-sm);
  border-left:3px solid var(--gold);
}
.pres-img{
  width:180px;height:216px;
  object-fit:cover;object-position:55% top;
  border-radius:10px;flex-shrink:0;
  box-shadow:0 4px 18px rgba(0,0,0,0.14);
}
.pres-body{}
.pres-ttl{
  font-family:'Noto Serif JP',serif;
  font-size:1.18rem;font-weight:700;
  color:var(--kuro);line-height:1.5;
  margin-bottom:2px;
}
.pres-name{
  font-size:0.83rem;color:var(--text-muted);
  font-weight:500;margin-top:6px;margin-bottom:18px;
  letter-spacing:0.04em;
}
.pres-text{
  font-size:0.92rem;color:var(--text-mid);
  line-height:2.2;
  font-family:'Shippori Mincho',serif;
  letter-spacing:0.05em;
}

/* レスポンシブ */
@media(max-width:960px){
  .htb{display:none;}
  .hmb{padding:0 16px;}
  nav{display:none;}
  .hbg{display:flex;margin-right:8px;}
  .mmenu{top:0;bottom:0;overflow-y:auto;padding:0;border-top:none;}
  .mmenu.open{display:flex;flex-direction:column;}
.mmenu a{padding:15px 22px;border-bottom:1px solid rgba(255,255,255,0.07);font-size:0.95rem;}
  .mbtns{margin-top:16px;padding:20px 22px 36px;border-top:1px solid rgba(255,255,255,0.1);gap:10px;}
  .mbtn{padding:15px;font-size:0.92rem;}
  .container{padding:0 20px;}
  section{padding:64px 0;}
  .hero{padding-top:58px;}
  .hero-body{grid-template-columns:1fr;gap:0;}
  .hero-right{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:8px;
  padding:0 0 36px;
}
  .hero-left{padding:36px 0 16px;}
  .pgrid{grid-template-columns:1fr;}
  .rgrid{grid-template-columns:1fr;}
  .sgrid{grid-template-columns:1fr;}
  .scard.feat{grid-column:span 1;}
  .ptables{grid-template-columns:1fr;}
  .wgrid{grid-template-columns:1fr;}
  .wcard.wide{grid-column:span 1;}
  .wcard.wide .wba{height:220px;}
  .ainner{grid-template-columns:1fr;gap:32px;}
  .amw{aspect-ratio:4/3;margin-top:0;}
  .fsteps{grid-template-columns:repeat(2,1fr);gap:28px;}
  .fsteps::before{display:none;}
  .igrid{grid-template-columns:repeat(2,1fr);}
  /* クリック案内：スマホで非表示 */
  .insta-pc-hint{display:none;}
  /* タップ案内：スマホのみ表示 */
  .insta-tap-hint{display:block;text-align:center;font-size:0.93rem;font-weight:700;color:var(--text-muted);margin-bottom:10px;letter-spacing:.04em;animation:insta-pulse 1.6s ease-in-out infinite;}
  .cinner{grid-template-columns:1fr;gap:30px;}
  .pres-card{flex-direction:column;align-items:center;padding:24px 20px;gap:22px;text-align:center;}
  .pres-img{width:150px;height:180px;}
  .pres-card .div{margin:12px auto 18px;}
  .cgrid{grid-template-columns:1fr;}
  .finner{grid-template-columns:1fr;gap:24px;padding:34px 0 26px;}
  .fbot{flex-direction:column;text-align:center;}
  .fg2{grid-template-columns:1fr;}
  .h-tel{width:100%;}
  .h-subs{flex-direction:column;}
  .dbanner{flex-direction:column;text-align:center;}
  .pcta{flex-direction:column;text-align:center;}
}
@media(max-width:480px){
  .hero h1{font-size:1.75rem;}
  .fsteps{grid-template-columns:1fr;}
}

/* =============================================
   スマホ専用 追加スタイル
============================================= */

/* iOS SafariのVH問題を修正 */
@supports(min-height:100svh){
  .hero{min-height:100svh;}
}

/* スマホの信頼パネル：コンパクトに */
@media(max-width:960px){
  .hero-right .hero-right-ttl{display:none;}
  .hero-right .tpanel{
    padding:10px 12px;
    border-left-width:2px;
  }
  .hero-right .tpanel-num{
    font-size:1.6rem;
  }
  .hero-right .tpanel-sub{display:none;}
  .hero-right .tpanel-label{font-size:0.74rem;}

  /* サービスカード画像：スマホで少し低く */
  .scard.feat .simg{height:220px;}
  .scard:not(.feat) .simg{height:180px;}

  /* 施工事例：スマホ用高さ調整 */
  .wcard:not(.wide) .wba{height:180px;}
  .wcard.wide .wba{height:200px;}

  /* お悩みセクション：スマホでCTAを縦積み */
  .pcta{flex-direction:column;text-align:center;}
  .pcta-b{width:100%;text-align:center;}

  /* ヒーロー：テキストサイズ最適化 */
  .hero-poem{font-size:0.8rem;line-height:2.1;}
  .hero-lead{font-size:0.86rem;}

  /* ヘッダーボタンのタップ領域を広げる（スマホ） */
  .htb-btn{
    height:30px;
    padding:0 12px;
    font-size:0.68rem;
  }

  /* フッター */
  .fbot{flex-direction:column;text-align:center;}
}

/* さらに小さい画面（375px以下）向け追加調整 */
@media(max-width:390px){
  .hero h1{font-size:1.6rem;}
  .hero-right{grid-template-columns:1fr 1fr;gap:6px;}
  .hero-right .tpanel-num{font-size:1.4rem;}
  .htb-tel{font-size:0.9rem;}
  .htb-hrs{display:none;}
}