@charset "UTF-8";
/* =========================================================
   新エナジーハウス リニューアル プロトタイプ  v3
   テーマ: California / 雑誌風エディトリアル
   白基調 × サンド × 緑アクセント(#31e043) / 余白・大判タイポ / 正方形カード
   ========================================================= */

:root{
  --green:#31e043;       /* アクセント（ボタン・ハイライト・帯） */
  --green-600:#27c93a;   /* ホバー */
  --green-700:#17a838;   /* 白地に乗せる緑文字（可読性確保） */
  --green-pale:#edf8ee;  /* ごく淡い緑 */
  --ink:#1c1b19;         /* 本文（温かみのある黒） */
  --ink-soft:#4c4a44;
  --paper:#ffffff;
  --sand:#f4efe7;        /* 暖色ニュートラル（カリフォルニアの砂） */
  --sand-2:#ece4d7;
  --line:#e7e1d6;        /* ヘアライン */
  --muted:#6f6a62;
  --radius:6px;          /* ボタン等の小さな角丸 */
  --shadow:0 18px 40px rgba(28,27,25,.10);
  --shadow-sm:0 8px 20px rgba(28,27,25,.07);
  --container:1180px;
  --head-h:88px;
  --display:'Zen Kaku Gothic New',sans-serif;
  --en:'Oswald',sans-serif;
  --sans:'Noto Sans JP',sans-serif;
}

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;scroll-padding-top:var(--head-h)}
body{margin:0;font-family:var(--sans);color:var(--ink);background:var(--paper);
  line-height:1.85;font-size:16px;-webkit-font-smoothing:antialiased;letter-spacing:.02em;overflow-x:hidden}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
ul{list-style:none;margin:0;padding:0}
h1,h2,h3,p{margin:0}
table{border-collapse:collapse;width:100%}

.container{width:min(var(--container),90%);margin-inline:auto}
.pc{display:inline}
.skip-link{position:absolute;left:-9999px;top:0;background:var(--green);color:var(--ink);padding:8px 16px;z-index:999;font-weight:700}
.skip-link:focus{left:8px;top:8px}

/* ---------- Buttons ---------- */
.btn{--bg:var(--green);--fg:var(--ink);
  display:inline-flex;align-items:center;justify-content:center;gap:.55em;
  background:var(--bg);color:var(--fg);
  font-family:var(--display);font-weight:900;line-height:1;letter-spacing:.04em;
  padding:1em 1.9em;border:2px solid transparent;border-radius:var(--radius);
  transition:transform .18s,box-shadow .2s,background .2s,color .2s,border-color .2s;cursor:pointer}
.btn svg{width:1.05em;height:1.05em;fill:currentColor}
.btn:hover{transform:translateY(-2px)}
.btn--accent{--bg:var(--green);--fg:var(--ink)}
.btn--accent:hover{--bg:var(--green-600);box-shadow:0 12px 26px rgba(49,224,67,.34)}
.btn--outline{--bg:transparent;--fg:var(--ink);border-color:var(--ink)}
.btn--outline:hover{--bg:var(--ink);--fg:#fff}
.btn--ghost{--bg:transparent;--fg:#fff;border-color:rgba(255,255,255,.7)}
.btn--ghost:hover{--bg:#fff;--fg:var(--ink);border-color:#fff}
.btn--white{--bg:#fff;--fg:var(--ink)}
.btn--white:hover{--bg:var(--green);--fg:var(--ink)}
.btn--lg{padding:1.15em 2.3em;font-size:1.05rem}
.btn--sm{padding:.7em 1.3em;font-size:.85rem}

/* ---------- Editorial heading ---------- */
.section{padding:clamp(70px,9vw,124px) 0}
.kicker{font-family:var(--en);font-weight:700;text-transform:uppercase;letter-spacing:.16em;
  font-size:clamp(1rem,1.6vw,1.3rem);color:var(--green-700);margin-bottom:14px}
.kicker--light{color:var(--green)}
.sec-head{margin-bottom:50px;text-align:center}
.sec-head__en{display:block;font-family:var(--en);font-weight:700;text-transform:uppercase;
  letter-spacing:.16em;font-size:clamp(1.1rem,1.9vw,1.5rem);color:var(--green-700);margin-bottom:4px}
.sec-head__ja{font-family:var(--display);font-weight:900;font-size:clamp(1.3rem,2.2vw,1.75rem);
  color:var(--ink);line-height:1.4;letter-spacing:.04em}
.sec-head--left{text-align:left}
.sec-head--sm{margin-bottom:26px}
.sec-head--sm .sec-head__ja{font-size:1.2rem}
.lead-c{text-align:center;color:var(--ink-soft);max-width:680px;margin:-30px auto 46px}
.sec-more{text-align:center;margin-top:50px}
.sec-more--left{text-align:left;margin-top:26px}

/* ---------- Header ---------- */
.header{position:fixed;inset:0 0 auto 0;z-index:100;transition:.3s}
.header__inner{height:var(--head-h);display:flex;align-items:center;gap:26px;
  width:min(1320px,94%);margin-inline:auto;transition:.3s}
.header::before{content:"";position:absolute;inset:0;background:rgba(255,255,255,.97);
  backdrop-filter:blur(8px);transition:.3s;z-index:-1}
.header.is-scrolled::before{border-bottom:1px solid var(--line);box-shadow:0 6px 18px rgba(0,0,0,.05)}
.logo{margin-right:auto;display:flex;align-items:center}
.logo__img{height:54px;width:auto;transition:.3s}
.header.is-scrolled .logo__img{height:46px}

.gnav ul{display:flex;gap:26px}
.gnav a{font-family:var(--display);font-weight:700;font-size:.95rem;color:var(--ink);position:relative;padding:6px 0;white-space:nowrap}
.gnav a::after{content:"";position:absolute;left:0;bottom:0;width:0;height:3px;background:var(--green);transition:.25s}
.gnav a:hover{color:var(--green-700)}
.gnav a:hover::after{width:100%}

.header__cta{display:flex;align-items:center;gap:18px}
.tel{display:flex;align-items:center;gap:9px;color:var(--ink);justify-content:center;}
.tel svg{width:26px;height:26px;fill:var(--green-700)}
.tel__num{display:flex;flex-direction:column;line-height:1.05}
.tel__num small{font-size:.6rem;color:var(--muted)}
.tel__num strong{font-family:var(--en);font-weight:700;font-size:1.5rem;letter-spacing:.02em;white-space:nowrap}

.hamburger{display:none;flex-direction:column;justify-content:center;gap:6px;width:48px;height:48px;
  background:var(--green);border:none;cursor:pointer;padding:0 12px;border-radius:var(--radius);-webkit-appearance:none;appearance:none}
.hamburger span{display:block;width:100%;height:3px;background:var(--ink);border-radius:2px;transition:.3s}
.nav-open .hamburger span:nth-child(1){transform:translateY(9px) rotate(45deg)}
.nav-open .hamburger span:nth-child(2){opacity:0}
.nav-open .hamburger span:nth-child(3){transform:translateY(-9px) rotate(-45deg)}
.gnav__close{display:none}
/* ドロワー開時：背景ディマー＋スクロールロック */
body.nav-open{overflow:hidden}
body.nav-open::before{content:"";position:fixed;inset:0;background:rgba(13,23,17,.42);z-index:89;animation:navFade .3s ease}
@keyframes navFade{from{opacity:0}to{opacity:1}}

/* ---------- Hero (white / editorial) ---------- */
.hero{background:var(--paper);overflow:hidden;padding-top:calc(var(--head-h) + 30px)}
.hero__main{display:grid;grid-template-columns:1.05fr .95fr;gap:54px;align-items:center;padding-bottom:60px;min-height:64vh}
.hero__kicker{display:flex;align-items:center;gap:14px;font-family:var(--en);font-weight:600;
  text-transform:uppercase;letter-spacing:.2em;font-size:.82rem;color:var(--ink-soft)}
.hero__kicker .rule{width:44px;height:2px;background:var(--green)}
.hero__title{font-family:var(--display);font-weight:900;font-size:clamp(2.4rem,5vw,3.8rem);
  line-height:1.12;letter-spacing:.01em;color:var(--ink);margin-top:24px}
.hero__kinetic{font-family:var(--display);font-weight:900;font-size:clamp(1.3rem,3.2vw,1.7rem);
  margin-top:18px;color:var(--ink)}
.hero__kinetic .rot{display:inline-block;background:var(--green);color:var(--ink);
  padding:.04em .34em;margin-right:.1em;animation:rotIn .45s ease}
.hero__lead{margin-top:22px;color:var(--ink-soft);font-size:clamp(.95rem,2vw,1.08rem)}
.hero__btns{margin-top:32px;display:flex;gap:14px;flex-wrap:wrap}

.hero__media{position:relative;height:clamp(420px,58vh,600px)}
.hslider{position:absolute;inset:0;display:grid;grid-template-columns:1fr 1fr;gap:14px;overflow:hidden;
  -webkit-mask:linear-gradient(180deg,transparent,#000 7%,#000 93%,transparent);
  mask:linear-gradient(180deg,transparent,#000 7%,#000 93%,transparent)}
.hslide{display:flex;flex-direction:column;gap:14px;will-change:transform}
.hslide img{width:100%;aspect-ratio:3/4;object-fit:cover}
.hslide--up{animation:vUp 30s linear infinite}
.hslide--down{animation:vDown 30s linear infinite}
.hero__tag{position:absolute;left:-10px;top:7%;z-index:3;background:var(--green);color:var(--ink);
  font-family:var(--en);font-weight:600;letter-spacing:.1em;padding:.5em 1.1em;font-size:.85rem;box-shadow:var(--shadow-sm)}
@keyframes rotIn{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}
@keyframes vUp{from{transform:translateY(0)}to{transform:translateY(-50%)}}
@keyframes vDown{from{transform:translateY(-50%)}to{transform:translateY(0)}}

/* ---------- Marquee ribbon ---------- */
.marquee{background:var(--green);overflow:hidden}
.marquee__track{display:flex;align-items:center;white-space:nowrap;width:max-content;animation:marquee 78s linear infinite}
.marquee__track span{font-family:var(--display);font-weight:900;font-size:1.05rem;color:var(--ink);padding:15px 30px;letter-spacing:.04em}
.marquee__track i{width:7px;height:7px;border-radius:50%;background:var(--ink);flex:none}
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ---------- Concept ---------- */
.concept__head{max-width:880px;margin:0 auto 50px;text-align:center}
.concept__catch{font-family:var(--display);font-weight:900;font-size:clamp(2rem,4.6vw,3.2rem);
  line-height:1.22;color:var(--ink);margin-bottom:24px;letter-spacing:.02em}
.concept__body{color:var(--ink-soft);line-height:2.05}
.concept__en{margin-top:22px;font-family:var(--en);font-weight:500;letter-spacing:.1em;
  text-transform:uppercase;color:var(--green-700);font-size:.95rem}
.concept__movie{margin:0 auto;max-width:1000px}
.concept__movie video,.concept__movie iframe{width:100%;aspect-ratio:16/9;object-fit:cover;display:block;background:#000;box-shadow:var(--shadow);border:0}
.concept__movie figcaption{margin-top:16px;font-family:var(--display);font-weight:700;color:var(--ink);text-align:center;font-size:.95rem}
.concept__movie figcaption span{font-family:var(--en);font-weight:700;text-transform:uppercase;letter-spacing:.16em;color:var(--green-700);margin-right:12px;font-size:.82rem}

/* ---------- Service ---------- */
.service{background:var(--sand)}
.req-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);border:1px solid var(--line)}
.req-card{background:#fff;padding:46px 24px;display:flex;flex-direction:column;align-items:center;gap:15px;text-align:center;transition:.25s}
.req-card:hover{background:var(--green-pale)}
.req-card svg{width:54px;height:54px;color:var(--ink);stroke:currentColor;transition:.25s}
.req-card:hover svg{color:var(--green-700)}
.req-card strong{font-family:var(--display);font-weight:700;color:var(--ink);font-size:1.04rem;line-height:1.5}
.req-card__en{font-family:var(--en);text-transform:uppercase;letter-spacing:.18em;font-size:.7rem;color:var(--muted)}

/* ---------- Works ---------- */
.works{background:var(--paper)}
.works__filter{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;align-items:center;margin-bottom:42px}
.chip{font-family:var(--display);font-weight:700;font-size:.82rem;padding:.5em 1.1em;
  border:1px solid var(--line);color:var(--ink-soft);background:#fff;border-radius:var(--radius);transition:.2s}
.chip:hover,.chip--on{background:var(--green);color:var(--ink);border-color:var(--green);font-weight:900}
/* 未実装UIの飾り（WP化で本実装予定。クリック不可・既定カーソル） */
.is-deco{cursor:default}
.chip.is-deco:not(.chip--on):hover{background:#fff;color:var(--ink-soft);border-color:var(--line);font-weight:700}
.pager span.is-deco{color:var(--ink-soft)}
.pager span.is-deco:hover{border-color:var(--line);color:var(--ink-soft)}
.works__filter-div{width:1px;height:22px;background:var(--line);margin:0 6px}
.work-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:30px}
.work-card{display:block;transition:.25s}
.work-card__img{position:relative;aspect-ratio:1/1;overflow:hidden;background:var(--sand)}
.work-card__img img{width:100%;height:100%;object-fit:cover;transition:.5s}
.work-card:hover .work-card__img img{transform:scale(1.05)}
.ba-badge{position:absolute;left:0;top:14px;background:var(--green);color:var(--ink);
  font-family:var(--en);font-weight:600;font-size:.72rem;padding:.4em .9em;letter-spacing:.05em;text-transform:uppercase}
.work-card__body{padding:16px 2px 0}
.work-card__tags{display:flex;gap:8px;margin-bottom:8px}
.tag{font-family:var(--display);font-weight:700;font-size:.72rem;padding:.3em .8em}
.tag--type{background:var(--green);color:var(--ink)}
.tag--area{background:transparent;color:var(--ink-soft);border:1px solid var(--line)}
.work-card__body p{font-weight:500;font-size:.96rem;color:var(--ink)}

/* ---------- Statement band (photo) ---------- */
.band{position:relative;color:#fff;text-align:center;padding:clamp(90px,12vw,150px) 0;overflow:hidden}
.band__bg{position:absolute;inset:0;background-size:cover;background-position:center;filter:grayscale(.35) brightness(.5)}
.band__bg::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(28,27,25,.45),rgba(28,27,25,.72))}
.band__inner{position:relative;z-index:1;text-align:center}
.band__title{font-family:var(--display);font-weight:900;font-size:clamp(2rem,5vw,3.2rem);line-height:1.25;margin:6px 0 18px;letter-spacing:.02em}
.band__txt{opacity:.92;margin-bottom:32px}

/* ---------- Reason (editorial collage + guide) ---------- */
.reason{background:var(--paper)}
/* 参照(Dolive CITY STYLE)構図：背景ブロック＋写真4枚＋イラスト2点 */
.reason__editorial{position:relative;height:760px;margin-bottom:60px}
.reason__head{position:absolute;left:0;top:6px;z-index:5;margin:0}
.reason__block{position:absolute;left:0;top:10%;width:62%;height:74%;background:var(--sand);z-index:1}
.reason__copy{position:absolute;left:5%;top:33%;width:33%;z-index:2}
.reason__pt{font-family:var(--en);font-weight:700;letter-spacing:.2em;color:var(--green-700);font-size:1rem;margin-bottom:14px}
.reason__txt{color:var(--ink-soft);line-height:2.05}
.reason__ph{position:absolute;overflow:hidden;box-shadow:var(--shadow);z-index:3}
.reason__ph img{width:100%;height:100%;object-fit:cover}
.reason__ph--1{left:31%;top:0;width:19%;aspect-ratio:3/4}        /* 上中央：縦 */
.reason__ph--2{right:3%;top:23%;width:38%;aspect-ratio:4/3}       /* 右：大きな横 */
.reason__ph--3{right:5%;bottom:0;width:19%;aspect-ratio:1/1}      /* 右下：小 */
.reason__ph--4{left:0;bottom:5%;width:34%;aspect-ratio:4/3}       /* 左下：横 */
.reason__art{position:absolute;height:auto;z-index:4}
.reason__art--palm{right:11%;top:1%;width:13%}                    /* 右上：ヤシ */
.reason__art--house{right:28%;bottom:8%;width:19%}               /* 中央下：住宅 */
.reason__guide{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:var(--line);border:1px solid var(--line)}
.guide-card{background:#fff;display:flex;align-items:center;gap:18px;padding:28px 30px;transition:.2s}
.guide-card:hover{background:var(--green-pale)}
.guide-card__no{font-family:var(--en);font-weight:700;font-size:2rem;color:var(--green-700);line-height:1;flex:none}
.guide-card__txt{display:flex;flex-direction:column;line-height:1.3}
.guide-card__txt strong{font-family:var(--display);font-weight:700;font-size:1.06rem;color:var(--ink)}
.guide-card__en{font-family:var(--en);text-transform:uppercase;letter-spacing:.14em;font-size:.68rem;color:var(--muted)}
.guide-card__arrow{width:22px;height:22px;fill:var(--ink-soft);margin-left:auto;flex:none;transition:.2s}
.guide-card:hover .guide-card__arrow{fill:var(--green-700);transform:translateX(3px)}
/* 選ばれる理由：強み3点 */
.reason__points{display:grid;grid-template-columns:repeat(3,1fr);gap:34px;margin-top:6px}
.reason__point-no{display:block;font-family:var(--en);font-weight:700;font-size:2.2rem;color:var(--green);line-height:1;margin-bottom:10px}
.reason__point h3{font-family:var(--display);font-weight:900;font-size:1.12rem;color:var(--ink);margin-bottom:8px;line-height:1.5}
.reason__point p{color:var(--ink-soft);line-height:1.95;font-size:.92rem}
@media(max-width:1024px){.reason__points{grid-template-columns:1fr;gap:26px}}

/* ---------- Cards layout ---------- */
.cards-4{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}

/* ---------- Voice ---------- */
.voice-card{background:#fff;border:1px solid var(--line)}
.voice-card img{width:100%;aspect-ratio:1/1;object-fit:cover}
.voice-card__body{padding:18px 18px 22px}
.voice-card__body .tag{display:inline-block;margin-bottom:10px}
.voice-card__body p{font-size:.88rem;color:var(--ink);line-height:1.7}

/* ---------- News / Column ---------- */
.news{background:var(--sand)}
.news__cols{display:grid;grid-template-columns:1fr 1fr;gap:60px}
.news__head{display:flex;justify-content:space-between;align-items:flex-end;gap:12px;border-bottom:2px solid var(--ink);margin-bottom:4px}
.news__head .sec-head{margin-bottom:0;padding-bottom:8px}
.news__more{display:inline-flex;align-items:center;gap:.3em;font-family:var(--display);font-weight:700;font-size:.82rem;color:var(--green-700);white-space:nowrap;padding-bottom:10px;transition:.2s}
.news__more svg{width:1em;height:1em;fill:currentColor}
.news__more:hover{gap:.5em}
.news-list li{border-bottom:1px solid var(--line)}
.news-list a,.news-list .news-row{display:block;padding:13px 2px;transition:.2s}
.news-list a:hover{color:var(--green-700)}
.news-meta{display:flex;align-items:center;gap:10px;margin-bottom:5px}
.news-meta time{font-family:var(--en);font-size:.76rem;color:var(--muted);font-weight:600;letter-spacing:.04em}
.news-cat{font-size:.66rem;font-family:var(--display);font-weight:700;color:var(--ink);background:var(--green);padding:.22em .7em;min-width:50px;text-align:center}
.news-ttl{font-size:.88rem;font-weight:500;line-height:1.5;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
/* ===== お知らせ 一覧ページ / 個別記事（③）===== */
.news-archive{max-width:860px;margin:0 auto}
.news-list--full .news-row{padding:18px 2px}
.news-ttl--full{white-space:normal;overflow:visible;font-size:1rem;line-height:1.6}
.news-empty{text-align:center;color:var(--muted);padding:40px 0}
.article-body{color:var(--ink-soft);line-height:2.05}
.article-body > *{margin-bottom:1.3em}
.article-body > *:last-child{margin-bottom:0}
.article-body h2{font-family:var(--display);font-weight:900;font-size:1.3rem;color:var(--ink);line-height:1.5;margin:1.8em 0 .7em}
.article-body h3{font-family:var(--display);font-weight:700;font-size:1.1rem;color:var(--ink);margin:1.6em 0 .5em}
.article-body a{color:var(--green-700);text-decoration:underline}
.article-body img{max-width:100%;height:auto}
.article-body ul,.article-body ol{padding-left:1.4em}
.article-body ul{list-style:disc}
.article-body ol{list-style:decimal}
.article-body li{margin-bottom:.4em}
.article-body blockquote{border-left:3px solid var(--green);padding-left:1em;color:var(--muted)}
.article-body + .sec-more{margin-top:44px}
/* ページネーション */
.pagination{display:flex;justify-content:center;flex-wrap:wrap;gap:8px;margin-top:46px}
.pagination .page-numbers{display:inline-flex;align-items:center;justify-content:center;min-width:44px;height:44px;padding:0 13px;border:1px solid var(--line);font-family:var(--display);font-weight:700;font-size:.9rem;color:var(--ink);transition:.2s}
.pagination a.page-numbers:hover{border-color:var(--green);color:var(--green-700)}
.pagination .page-numbers.current{background:var(--green);border-color:var(--green);color:var(--ink)}
.pagination .page-numbers.dots{border:none;min-width:auto}
/* Instagram 埋め込み枠 */
.insta__grid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px;margin:2px 0 22px}
.insta__item{aspect-ratio:1/1;overflow:hidden;display:block;background:var(--sand-2)}
.insta__item img{width:100%;height:100%;object-fit:cover;transition:.3s}
.insta__item:hover img{transform:scale(1.06);opacity:.92}
.insta__follow{display:inline-flex;align-items:center;gap:.55em;font-family:var(--display);font-weight:900;
  letter-spacing:.02em;border:2px solid var(--ink);border-radius:var(--radius);padding:.7em 1.3em;transition:.2s}
.insta__follow svg{width:1.25em;height:1.25em;stroke:currentColor}
.insta__follow:hover{background:var(--ink);color:#fff}

/* ---------- Partners ---------- */
.partners{background:var(--paper)}
.logo-row{display:flex;flex-wrap:wrap;justify-content:center;gap:14px}
.logo-row li{background:#fff;border:1px solid var(--line);color:var(--ink);font-family:var(--display);font-weight:700;
  width:240px;min-height:66px;padding:12px 16px;box-sizing:border-box;text-align:center;display:flex;align-items:center;justify-content:center;
  font-size:1.05rem;letter-spacing:.04em;transition:.2s}
.logo-row li:hover{border-color:var(--green);color:var(--green-700)}
/* バナー枠：均一サイズの箱に提供サイズのまま中央配置（バナーは改変不可のため拡大せず原寸まで） */
.logo-row li.logo-row__banner{padding:6px 14px}
.logo-row__banner a{display:flex;align-items:center;justify-content:center;line-height:0;width:100%;height:100%}
.logo-row__banner img{width:auto;height:auto;max-width:100%;max-height:100%;object-fit:contain}
/* クリナップ：画像自体に赤枠があるため外枠を外し、余白を詰めて原寸表示 */
.logo-row li.logo-row__banner--framed{border:none;padding:3px}
.logo-row li.logo-row__banner--framed:hover{opacity:.85}
/* メーカー公式ロゴ（バナーではなくロゴ画像。リンクなし＝許諾前）。バナー枠と同寸で中央配置 */
.logo-row li.logo-row__logo{padding:10px 16px}
.logo-row__logo img{width:auto;height:auto;max-width:100%;max-height:42px;object-fit:contain}
.logo-row li.logo-row__logo:hover{border-color:var(--line)}
/* メーカー名：許諾が要る公式ロゴの代わりに社名をテキスト表示（バナー箱と同寸の白箱） */
.logo-row li.logo-row__name{font-size:1.15rem;font-weight:900;letter-spacing:.06em;color:var(--ink)}

/* ---------- Mission ---------- */
.mission__list{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:4px;list-style:none}
.mission__item{position:relative;background:var(--paper);border:1px solid var(--line);padding:38px 30px 34px 36px;
  display:flex;flex-direction:column;gap:10px;overflow:hidden}
.mission__item::before{content:"";position:absolute;left:0;top:0;bottom:0;width:8px;background:var(--green)}
.mission__no{font-family:var(--en);font-weight:700;font-size:1.05rem;letter-spacing:.12em;color:var(--green-700)}
.mission__ja{font-family:var(--display);font-weight:900;font-size:clamp(1.35rem,2.2vw,1.7rem);color:var(--ink);line-height:1.4}
.mission__en{font-family:var(--en);font-weight:500;font-style:italic;font-size:1.15rem;letter-spacing:.02em;color:var(--ink-soft)}
@media(max-width:1024px){.mission__list{grid-template-columns:1fr;gap:16px}
  .mission__item{flex-direction:row;align-items:baseline;flex-wrap:wrap;padding:24px 26px}
  .mission__no{flex:0 0 auto}
  .mission__ja{flex:1 1 auto}
  .mission__en{flex:0 0 100%}}

/* ---------- Company ---------- */
.company{background:var(--sand)}
.company__inner{display:grid;grid-template-columns:1fr 1.1fr;gap:60px;align-items:center}
.company__media img{width:100%;aspect-ratio:1/1;object-fit:cover}
.company__table{margin:8px 0 30px;font-size:.92rem}
.company__table th,.company__table td{text-align:left;padding:15px 4px;border-bottom:1px solid var(--line);vertical-align:top}
.company__table th{width:114px;color:var(--green-700);font-family:var(--display);font-weight:700;white-space:nowrap}

/* ---------- Lower page (下層ページ) ---------- */
.page-head{padding:calc(var(--head-h) + 54px) 0 56px;background:var(--sand)}
.breadcrumb{font-family:var(--en);font-size:.82rem;letter-spacing:.05em;color:var(--muted);margin-bottom:16px}
.breadcrumb a{color:var(--ink-soft)}
.breadcrumb a:hover{color:var(--green-700)}
.breadcrumb span{margin:0 .6em;color:var(--ink-soft)}
.page-head__en{display:block;font-family:var(--en);font-weight:700;text-transform:uppercase;letter-spacing:.16em;font-size:clamp(1.1rem,1.9vw,1.5rem);color:var(--green-700)}
.page-head__title{font-family:var(--display);font-weight:900;font-size:clamp(1.7rem,3.2vw,2.4rem);color:var(--ink);letter-spacing:.04em;margin-top:2px}
.map-embed{border:1px solid var(--line);background:var(--sand);overflow:hidden}
.map-embed iframe{display:block;width:100%;height:400px;border:0}

/* ---------- Lower page: common helpers ---------- */
.lead-lg{max-width:760px;color:var(--ink-soft);line-height:2.05;margin-bottom:8px}
.intro{text-align:center;margin-bottom:54px}
.intro .lead-lg{margin-inline:auto;text-align:center}

/* ---------- Works list ---------- */
.works-bar{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:14px;margin-bottom:28px}
.works-count{font-family:var(--en);font-weight:600;letter-spacing:.06em;color:var(--muted);font-size:.9rem}
.works-count b{font-size:1.5rem;color:var(--green-700);margin:0 .15em}
.pager{display:flex;justify-content:center;gap:8px;margin-top:56px}
.pager a,.pager span{min-width:46px;height:46px;display:inline-flex;align-items:center;justify-content:center;
  font-family:var(--en);font-weight:600;border:1px solid var(--line);color:var(--ink-soft);transition:.2s}
.pager a:hover{border-color:var(--green);color:var(--green-700)}
.pager .is-current{background:var(--ink);color:#fff;border-color:var(--ink)}

/* ---------- Work single ---------- */
.section .single{width:min(920px,90%);margin-inline:auto}
.single__tags{display:flex;gap:8px;margin-bottom:14px}
.single__title{font-family:var(--display);font-weight:900;font-size:clamp(1.5rem,3vw,2.1rem);color:var(--ink);line-height:1.45;margin-bottom:20px}
.single__hero{aspect-ratio:16/10;overflow:hidden;margin-bottom:18px}
.single__hero img{width:100%;height:100%;object-fit:cover}
.single__lead{color:var(--ink-soft);line-height:2.05;margin:0 0 44px}
.block-head{font-family:var(--display);font-weight:900;font-size:1.3rem;color:var(--ink);margin:0 0 18px;padding-left:16px;border-left:8px solid var(--green)}
.ba{margin:0 0 46px}
.ba__set{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.ba__item{margin:0}
.ba__item img{width:100%;aspect-ratio:4/3;object-fit:cover}
.ba__cap{margin-top:8px;font-family:var(--en);font-weight:700;letter-spacing:.12em;text-transform:uppercase;font-size:.78rem;color:var(--green-700)}
.ba__item--before .ba__cap{color:var(--muted)}
.spec{width:100%;margin:0 0 46px;font-size:.92rem}
.spec th,.spec td{text-align:left;padding:14px 4px;border-bottom:1px solid var(--line);vertical-align:top}
.spec th{width:120px;color:var(--green-700);font-family:var(--display);font-weight:700;white-space:nowrap}
.single__gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:46px}
.single__gallery img{width:100%;aspect-ratio:1/1;object-fit:cover}

/* ---------- Service page ---------- */
.svc-row{display:grid;grid-template-columns:1fr 1fr;gap:54px;align-items:center;padding:48px 0;border-bottom:1px solid var(--line)}
.svc-row:last-child{border-bottom:none}
.svc-row:nth-child(even) .svc-row__media{order:2}
.svc-row__media img{width:100%;aspect-ratio:4/3;object-fit:cover}
.svc-row__no{font-family:var(--en);font-weight:700;color:var(--green);font-size:1.05rem;letter-spacing:.12em}
.svc-row__title{display:flex;align-items:center;gap:12px;font-family:var(--display);font-weight:900;font-size:1.5rem;color:var(--ink);margin:6px 0 14px}
.svc-row__title svg{width:36px;height:36px;color:var(--green-700);stroke:currentColor;flex:none}
.svc-row__body p{color:var(--ink-soft);line-height:2.05;margin-bottom:18px}
.svc-tags{display:flex;flex-wrap:wrap;gap:8px}
.svc-tags span{font-size:.78rem;font-family:var(--display);font-weight:700;background:var(--green-pale);color:var(--green-700);padding:.32em .85em}
/* サービス内セクションメニュー */
.secmenu{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;align-items:center;margin-bottom:54px}
.secmenu a{font-family:var(--display);font-weight:700;font-size:.85rem;color:var(--ink-soft);border:1px solid var(--line);padding:.5em 1.1em;border-radius:var(--radius);transition:.2s}
.secmenu a:hover{background:var(--ink);color:#fff;border-color:var(--ink)}
/* 取扱商品：性質が違うので区切り＋緑CTAで分離 */
.secmenu__sep{width:1px;align-self:stretch;background:var(--line);margin:.2em 6px}
.secmenu__cta{display:inline-flex;align-items:center;gap:.5em;background:var(--green-pale);color:var(--green-700)!important;border-color:transparent!important}
.secmenu__cta svg{width:1.05em;height:1.05em;fill:none;stroke:currentColor;stroke-width:2.4}
.secmenu__cta:hover{background:var(--green)!important;color:var(--ink)!important;border-color:var(--green)!important}
@media(max-width:768px){.secmenu__sep{display:none}.secmenu__cta{flex-basis:100%;justify-content:center;margin-top:4px}}
/* 取扱商品 */
.product-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);border:1px solid var(--line);margin-bottom:8px}
.product{background:#fff;display:flex;flex-direction:column}
.product img{width:100%;height:128px;object-fit:cover}
.product__txt{padding:16px 18px 18px;display:flex;flex-direction:column;gap:4px}
.product strong{font-family:var(--display);font-weight:700;color:var(--ink);font-size:1.02rem}
.product span{font-size:.84rem;color:var(--muted)}
@media(max-width:1024px){.product-grid{grid-template-columns:1fr 1fr}}
@media(max-width:768px){.product-grid{grid-template-columns:1fr}}

/* ---------- FAQ ---------- */
.faq{max-width:860px;margin:0 auto}
.faq__cat{font-family:var(--display);font-weight:900;font-size:1.2rem;color:var(--ink);margin:46px 0 8px;padding-left:16px;border-left:8px solid var(--green)}
.faq__cat:first-of-type{margin-top:0}
.faq__item{border-bottom:1px solid var(--line)}
.faq__item summary{list-style:none;cursor:pointer;display:flex;gap:14px;align-items:flex-start;padding:20px 4px;font-family:var(--display);font-weight:700;color:var(--ink);transition:color .2s}
.faq__item summary::-webkit-details-marker{display:none}
.faq__item summary::before{content:"Q";font-family:var(--en);font-weight:700;color:var(--green-700);flex:none;font-size:1.15rem;line-height:1.5}
.faq__item summary::after{content:"+";margin-left:auto;color:var(--muted);font-size:1.5rem;line-height:1;flex:none;transition:.2s}
.faq__item[open] summary::after{content:"–"}
.faq__item summary:hover{color:var(--green-700)}
.faq__a{display:flex;gap:14px;padding:0 4px 22px;color:var(--ink-soft);line-height:2}
.faq__a::before{content:"A";font-family:var(--en);font-weight:700;color:var(--muted);flex:none;font-size:1.15rem}

/* ---------- Flow (steps) ---------- */
.flow{max-width:820px;margin:0 auto}
.flow__step{display:flex;gap:26px;padding-bottom:38px;position:relative}
.flow__step:last-child{padding-bottom:0}
.flow__step:not(:last-child)::before{content:"";position:absolute;left:27px;top:60px;bottom:6px;width:2px;background:var(--line)}
.flow__num{flex:none;width:56px;height:56px;background:var(--green);color:var(--ink);display:flex;align-items:center;justify-content:center;font-family:var(--en);font-weight:700;font-size:1.3rem;z-index:1}
.flow__body{padding-top:4px;flex:1}
.flow__body h3{font-family:var(--display);font-weight:900;font-size:1.2rem;color:var(--ink);margin-bottom:8px}
.flow__body p{color:var(--ink-soft);line-height:2}
.flow__icon{flex:none;width:48px;height:48px;color:var(--green-700);align-self:center}
.inline-link{color:var(--green-700);font-weight:700;text-decoration:underline}
@media(max-width:768px){.flow__icon{display:none}}

/* ===== 統合ページ：ご相談・お見積り（大番号エディトリアル タイムライン＋費用） ===== */
.fe{max-width:980px;margin:0 auto}
.fe__intro{margin:0 auto 60px;max-width:760px;text-align:center;color:var(--ink-soft);line-height:2.05}
.fe__intro strong{color:var(--green-700)}

/* 大番号タイムライン */
.fstep{position:relative;display:grid;grid-template-columns:128px 1fr;gap:34px;padding:0 0 56px 0}
.fstep:last-child{padding-bottom:0}
.fstep:not(:last-child)::before{content:"";position:absolute;left:63px;top:120px;bottom:-8px;width:2px;background:var(--line)}
.fstep__num{position:relative;justify-self:center;align-self:start}
.fstep__big{display:inline-block;position:relative;font-family:var(--en);font-weight:700;font-size:7rem;line-height:.82;color:var(--sand-2);letter-spacing:-.02em}
.fstep__ic{position:absolute;left:50%;top:calc(50% - 11px);transform:translate(-50%,-50%);width:54px;height:54px;color:var(--green-700)}
.fstep__ic svg{width:100%;height:100%;fill:none;stroke:currentColor}
.fstep__body{padding-top:30px;min-width:0}
.fstep__ttl{font-family:var(--display);font-weight:900;font-size:1.35rem;color:var(--ink);margin-bottom:10px}
.fstep__body>p{color:var(--ink-soft);line-height:2}
/* ステップ内に差し込む費用パネル */
.fstep__panel{margin-top:22px;border:1px solid var(--line);border-left:8px solid var(--green);background:var(--paper);padding:26px 28px}
.fstep__panel-ttl{font-family:var(--display);font-weight:900;font-size:1.05rem;color:var(--ink);margin-bottom:16px;display:flex;align-items:center;gap:10px}
.fstep__panel-ttl span{font-family:var(--en);font-weight:700;font-size:.8rem;color:var(--green-700);letter-spacing:.1em}
/* 料金カード（パネル内） */
.price2{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin:0 0 6px}
.price2__card{border:1px solid var(--line);padding:20px 18px;display:flex;flex-direction:column;gap:8px}
.price2__name{font-family:var(--display);font-weight:700;font-size:.95rem;color:var(--ink)}
.price2__price{font-family:var(--en);font-weight:700;font-size:1.9rem;color:var(--green-700);line-height:1;letter-spacing:.01em}
.price2__price small{font-size:.5em;color:var(--muted);margin-left:2px;font-family:var(--sans)}
.price2__desc{font-size:.82rem;color:var(--muted);line-height:1.75}
.price2__note{font-size:.84rem;color:var(--muted);margin-top:10px}
/* ローン図解（横並びステップ） */
.loan{display:flex;flex-wrap:wrap;gap:12px;margin-top:8px}
.loan__item{flex:1 1 0;min-width:150px;background:var(--sand);padding:16px 18px;display:flex;flex-direction:column;gap:5px}
.loan__item strong{font-family:var(--display);font-weight:700;color:var(--ink);font-size:.98rem}
.loan__item span{font-size:.82rem;color:var(--ink-soft);line-height:1.7}
/* LINE導線（パネル内のかんたん見積り） */
.line-cta{display:flex;align-items:center;gap:14px;margin-top:18px;padding:14px 18px;background:#06C755;color:#fff;transition:.2s}
.line-cta:hover{background:#05b34c}
.line-cta__ic{flex:none;width:30px;height:30px;fill:#fff}
.line-cta__txt{flex:1;display:flex;flex-direction:column;line-height:1.3}
.line-cta__txt strong{font-family:var(--display);font-weight:900;font-size:1rem}
.line-cta__txt span{font-size:.8rem;opacity:.92}
.line-cta__arrow{flex:none;width:20px;height:20px;fill:none;stroke:#fff;stroke-width:2}
/* LINEボタン（.btn バリアント：電話/フォームと同寸で揃える） */
.btn--line{background:#06C755;color:#fff;gap:10px}
.btn--line:hover{background:#05b34c;color:#fff}
.btn--line svg{width:1.4em;height:1.4em;fill:#fff}

@media(max-width:768px){
  .fstep{grid-template-columns:64px 1fr;gap:18px;padding-bottom:40px}
  .fstep:not(:last-child)::before{left:31px;top:70px}
  .fstep__big{font-size:3.6rem}
  .fstep__ic{width:30px;height:30px;top:calc(50% - 6px)}
  .fstep__body{padding-top:10px}
  .fstep__panel{padding:20px 18px}
  .price2{grid-template-columns:1fr;gap:10px}
  .price2__price{font-size:1.7rem}
  .loan__item{flex-basis:100%}
  .freebar{padding:18px 20px;margin-bottom:48px}
}

/* ---------- Note box ---------- */
.note{background:var(--green-pale);border-left:4px solid var(--green);padding:18px 22px;color:var(--ink-soft);line-height:1.9;margin-top:10px}
.estimate{max-width:860px;margin:0 auto}
.estimate .block-head{margin-top:48px}
.estimate .block-head:first-of-type{margin-top:0}
/* 料金表カード */
.pricecards{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);border:1px solid var(--line);margin:14px 0}
.pricecard{background:#fff;display:flex;flex-direction:column}
.pricecard__head{background:var(--green);color:var(--ink);font-family:var(--display);font-weight:900;text-align:center;padding:16px 14px;font-size:1.02rem}
.pricecard__price{font-family:var(--en);font-weight:700;font-size:1.7rem;color:var(--ink);text-align:center;padding:22px 14px;border-bottom:1px solid var(--line)}
.pricecard__price small{font-size:.9rem;margin-left:2px;font-family:var(--sans)}
.pricecard__desc{padding:20px 22px;color:var(--ink-soft);font-size:.9rem;line-height:1.9;margin:0}
@media(max-width:768px){.pricecards{grid-template-columns:1fr}}

/* ---------- Privacy policy ---------- */
.privacy{max-width:820px;margin:0 auto}
.privacy>p{color:var(--ink-soft);line-height:2;margin-bottom:8px}
.privacy .block-head{margin-top:42px}
.privacy ul{margin:8px 0 0;padding:0}
.privacy li{color:var(--ink-soft);line-height:1.95;padding-left:1.3em;position:relative}
.privacy li::before{content:"・";position:absolute;left:0;color:var(--green-700)}

/* ---------- Contact form ---------- */
.form{max-width:760px;margin:0 auto}
.form__row{margin-bottom:24px}
.form__label{display:block;font-family:var(--display);font-weight:700;color:var(--ink);margin-bottom:8px}
.form__label .req{font-family:var(--sans);font-size:.66rem;font-weight:700;color:#fff;background:var(--green);color:var(--ink);padding:.18em .6em;margin-left:.6em;vertical-align:middle}
.form__label .opt{font-size:.7rem;color:var(--muted);margin-left:.6em;font-family:var(--sans);font-weight:500}
.form input[type=text],.form input[type=email],.form input[type=tel],.form textarea,.form select{
  width:100%;font-family:var(--sans);font-size:1rem;color:var(--ink);background:#fff;
  border:1px solid var(--line);border-radius:var(--radius);padding:14px 16px;transition:.2s}
.form input:focus,.form textarea:focus,.form select:focus{outline:none;border-color:var(--green);box-shadow:0 0 0 3px rgba(49,224,67,.2)}
.form textarea{min-height:150px;resize:vertical}
.form__choices{display:flex;flex-wrap:wrap;gap:10px}
.form__choice{display:inline-flex;align-items:center;gap:.5em;border:1px solid var(--line);border-radius:var(--radius);padding:11px 18px;cursor:pointer;transition:.2s;font-weight:500}
.form__choice:hover{border-color:var(--green);background:var(--green-pale)}
.form__consent{display:flex;gap:.6em;align-items:center;justify-content:center;font-size:.9rem;color:var(--ink-soft);margin:6px 0 26px}
.form__submit{text-align:center}
.form__submit .btn{min-width:280px}
/* Contact Form 7 の出力マークアップをフォーム意匠へ橋渡し（⑤ 問い合わせフォームCSS） */
.form__row .wpcf7-form-control-wrap{display:block}
.form__choices .wpcf7-radio{display:flex;flex-wrap:wrap;gap:10px}
.form__choices .wpcf7-list-item{margin:0}
.form__choices .wpcf7-list-item label{display:inline-flex;align-items:center;gap:.5em;border:1px solid var(--line);border-radius:var(--radius);padding:11px 18px;cursor:pointer;transition:.2s;font-weight:500}
.form__choices .wpcf7-list-item label:hover{border-color:var(--green);background:var(--green-pale)}
.form .wpcf7-not-valid-tip{color:#c00;font-size:.8rem;margin-top:6px}
.form .wpcf7-response-output{margin:18px 0 0;padding:12px 16px;border-radius:var(--radius);font-size:.9rem}
.form-alt{margin:56px auto 0;max-width:760px;padding-top:42px;border-top:1px solid var(--line);text-align:center}
.form-alt p{color:var(--ink-soft);margin-bottom:6px}
.form-alt__tel{font-family:var(--en);font-weight:700;font-size:2rem;color:var(--ink);display:inline-flex;align-items:center;gap:.3em}
.form-alt__tel svg{width:.9em;height:.9em;fill:var(--green-700)}

/* ---------- Lower page responsive (≤768 / Mobile) ---------- */
@media (max-width:768px){
  .svc-row{grid-template-columns:1fr;gap:24px;padding:34px 0}
  .svc-row:nth-child(even) .svc-row__media{order:0}
  .ba__set{grid-template-columns:1fr}
  .single__gallery{grid-template-columns:repeat(2,1fr)}
}

/* ---------- Contact ---------- */
.contact{background:var(--sand-2);text-align:center;padding:clamp(80px,10vw,128px) 0}
.contact__title{font-family:var(--display);font-weight:900;font-size:clamp(2rem,5.2vw,2.9rem);margin:6px 0 16px;color:var(--ink);letter-spacing:.03em}
.contact__lead{margin-bottom:38px;color:var(--ink-soft)}
.contact__line{margin-top:24px;display:flex;flex-direction:column;align-items:center;gap:10px}
.contact__line-txt{font-family:var(--display);font-weight:700;color:var(--ink);font-size:1.02rem;letter-spacing:.02em}
.contact__line .btn--line{width:100%;max-width:360px;min-height:80px;box-sizing:border-box}
.contact__btns{display:flex;gap:20px;justify-content:center;align-items:stretch;flex-wrap:wrap}
.contact__btns>*{flex:1 1 300px;max-width:360px;min-height:80px;box-sizing:border-box}
.tel--lg{background:#fff;padding:14px 28px;box-shadow:var(--shadow-sm);color:var(--ink);border-radius:var(--radius)}
.tel--lg .tel__num strong{font-size:1.9rem;color:var(--ink)}
.tel--lg .tel__num small{color:var(--muted)}
.tel--lg svg{width:34px;height:34px;fill:var(--green-700)}

/* ---------- Footer ---------- */
.footer{background:var(--paper);border-top:1px solid var(--line);padding:56px 0 0}
.footer__inner{display:flex;justify-content:space-between;gap:40px;flex-wrap:wrap;padding-bottom:46px}
.footer__logo{height:64px;width:auto}
.footer__addr{margin-top:18px;font-size:.85rem;color:var(--muted);line-height:1.9}
.footer__nav{display:flex;gap:56px}
.footer__nav a{font-size:.9rem;color:var(--ink-soft);padding:8px 0;display:inline-block;transition:.2s}
.footer__nav a:hover{color:var(--green-700)}
.footer__copy{text-align:center;font-family:var(--en);letter-spacing:.1em;font-size:.78rem;
  padding:20px;margin:0;color:var(--muted);border-top:1px solid var(--line)}

/* ---------- Mobile floating CTA ---------- */
.mobile-cta{display:none}

/* =========================================================
   Responsive — 3段階：PC(既定) / タブレット ≤1024px / スマホ ≤768px
   ※スマホは375px幅で最終確認
   ========================================================= */

/* 横並びナビ維持：1025–1160px は gap/フォントを詰めて1行に収める（ハンバーガー化しない） */
@media (min-width:1025px) and (max-width:1160px){
  .header__inner{gap:16px}
  .gnav ul{gap:14px}
  .gnav a{font-size:.9rem}
  .header__cta{gap:12px}
}

@media (max-width:1024px){
  /* グローバルナビ → ドロワー */
  .gnav{position:fixed;inset:0 0 0 auto;width:min(320px,82%);background:#fff;
    padding:calc(var(--head-h) + 20px) 30px 30px;transform:translateX(100%);transition:.35s;z-index:90;
    box-shadow:-10px 0 40px rgba(0,0,0,.12)}
  .nav-open .gnav{transform:translateX(0)}
  /* リンクを段階的にフェードイン */
  .gnav li{opacity:0;transform:translateX(16px);transition:opacity .3s ease,transform .3s ease}
  .nav-open .gnav li{opacity:1;transform:none}
  .nav-open .gnav li:nth-child(1){transition-delay:.10s}
  .nav-open .gnav li:nth-child(2){transition-delay:.15s}
  .nav-open .gnav li:nth-child(3){transition-delay:.20s}
  .nav-open .gnav li:nth-child(4){transition-delay:.25s}
  .nav-open .gnav li:nth-child(5){transition-delay:.30s}
  .nav-open .gnav li:nth-child(6){transition-delay:.35s}
  .gnav__close{display:block;position:absolute;top:16px;right:20px;background:none;border:none;cursor:pointer;font-family:var(--display);font-weight:400;font-size:2.4rem;line-height:1;color:var(--ink)}
  .gnav ul{flex-direction:column;gap:0}
  .gnav a{display:block;padding:15px 4px;border-bottom:1px solid var(--line);font-size:1.05rem}
  .gnav a::after{display:none}
  .hamburger{display:flex;order:3}
  .nav-open .hamburger{display:none}
  .header__cta .btn--accent{display:none}
  .tel__num small{display:none}
  .tel__num strong{font-size:1.2rem}
  .header__inner{gap:14px}
  /* 横並びセクション→縦積み／多列グリッド→2列 */
  .concept__inner,.company__inner,.news__cols{grid-template-columns:1fr;gap:40px}
  .req-grid,.cards-4,.work-grid{grid-template-columns:repeat(2,1fr)}
  /* スマホ/タブレット：縦スライダーをヒーローテキストの背面レイヤーに敷く（green-care型） */
  .hero{padding-top:0}
  .hero__main{display:block;position:relative;overflow:hidden;min-height:88vh;gap:0;padding:0;width:100%;max-width:none;text-align:center}
  .hero__media{position:absolute;inset:0;height:auto;max-width:none;width:auto;margin:0;z-index:0}
  .hero__media::after{content:"";position:absolute;inset:0;z-index:1;pointer-events:none;
    background:linear-gradient(180deg,rgba(255,255,255,.84),rgba(255,255,255,.66) 46%,rgba(255,255,255,.9))}
  .hero__text{position:relative;z-index:2;max-width:600px;margin:0 auto;padding:calc(var(--head-h) + 7vh) 24px 9vh}
  .hero__kicker{justify-content:center}
  .hero__btns{justify-content:center}
  .hero__tag{left:auto;right:12px;top:calc(var(--head-h) + 12px);z-index:2;font-size:.66rem;padding:.35em .75em;letter-spacing:.06em}
  /* 選ばれる理由：Doliveスマホ構図（見出し+小写真／大写真+イラスト／テキスト／小写真+イラスト／大写真） */
  .reason__editorial{display:flex;flex-direction:column;position:relative;height:auto;min-height:0;gap:0;margin-bottom:40px}
  .reason__head{order:1;position:static;width:62%;min-height:100px;margin:0}
  .reason__head .sec-head__en{font-size:.98rem;letter-spacing:.1em}
  .reason__block{display:none}
  .reason__ph{position:static;width:auto !important;margin:0;box-shadow:var(--shadow)}
  .reason__ph--1{order:0;position:absolute;top:0;left:auto;right:0;width:34% !important;aspect-ratio:1/1;z-index:1}  /* 見出し右上の小写真 */
  .reason__ph--2{order:2;aspect-ratio:4/3}                                                          /* 大きな横写真 */
  .reason__art--palm{order:3;display:block;position:relative;width:26%;align-self:flex-start;margin:-38px 0 0 6px;z-index:3} /* ph2左下に重ねる */
  .reason__copy{order:4;position:static;width:auto;background:var(--sand);padding:30px 24px;margin:6px 0 0}
  .reason__ph--3{order:5;width:56% !important;aspect-ratio:4/3;margin-top:18px}                      /* 左の小写真 */
  .reason__art--house{order:6;display:block;position:relative;width:42%;align-self:flex-end;margin:-78px 0 0;z-index:3} /* 右にイラスト */
  .reason__ph--4{order:7;aspect-ratio:16/10;margin-top:16px}                                         /* 大きな横写真 */
  .reason__guide{grid-template-columns:1fr}
}
@media (max-width:768px){
  /* グリッド→1列（施工事例・お客様の声） */
  .cards-4,.work-grid{grid-template-columns:1fr}
  /* 対応できるご要望：2列コンパクトでスクロール削減 */
  .req-grid{grid-template-columns:repeat(2,1fr)}
  .req-card{padding:22px 12px;gap:9px}
  .req-card svg{width:40px;height:40px}
  .req-card strong{font-size:.9rem;line-height:1.45}
  .req-card__en{font-size:.62rem}
  /* トップの施工事例はスマホで初期3件のみ表示 */
  .works .work-card:nth-child(n+4){display:none}
  /* セクション余白・ヘッダー */
  .section{padding:56px 0}
  .header__cta .tel{display:none}
  .pc{display:none}
  .news-list time{width:auto}
  /* 選ばれる理由（スマホ微調整） */
  .reason__ph--1{right:-5vw}                                          /* 小写真を画面右端へ */
  .reason__block{display:block;position:absolute;left:-5vw;top:86px;bottom:0;height:auto;width:78%;background:var(--sand);z-index:0}  /* 縦長サンド帯：ph2上端より少し上〜ph4下端、左は画面端まで */
  .reason__copy{background:transparent;position:relative;z-index:2;padding:26px 20px 34px 20px}
  .reason__copy .reason__txt{max-width:none}   /* 帯からはみ出してOK＝自然な幅で流す */
  /* デスクトップ基底のinset(left/right等)を打ち消してから配置 */
  .reason__ph--2,.reason__ph--3,.reason__ph--4{position:relative;inset:auto;z-index:1}
  .reason__ph--2{align-self:center}                                  /* ph4と同じく中央（全幅） */
  .reason__ph--3{align-self:flex-start;margin-left:-5vw;z-index:2}    /* 左＝画面端にくっつける／ph4の上に重ねる */
  .reason__ph--4{margin-top:-14px}                                   /* ph3に少し重なるよう上げる */
  .reason__art--palm{inset:auto;align-self:flex-start;margin-left:20px}   /* 左に少し余白 */
  .reason__art--house{position:absolute;left:auto;right:20px;top:702px;bottom:auto;width:42%;margin:0;z-index:3}   /* flow外：ph3右隣・ph4より上に固定（ph4を押し下げない） */
  /* ヒーロー：375px想定でフォント抑制・改行を自然に */
  .hero__kicker{font-size:.66rem;letter-spacing:.1em;gap:10px}
  .hero__kicker .rule{width:28px}
  .hero__title{font-size:clamp(2rem,8vw,2.4rem)}
  .hero__kinetic{font-size:1.15rem;margin-top:14px}
  .hero__lead{font-size:.9rem;line-height:1.9;margin-top:18px}
  /* CONTACT：スマホは全幅・コンパクト・中央寄せ */
  .contact__btns{flex-direction:column;gap:14px}
  .contact__btns>*{flex:0 0 auto;width:100%;max-width:none;min-height:0}
  .contact__line .btn--line{max-width:none;min-height:0}
  .contact__btns .btn{padding:16px 20px}
  .contact .tel--lg{justify-content:center;padding:13px 20px}
  .contact .tel--lg .tel__num{align-items:center}
  .contact .tel--lg .tel__num small{display:none}
  .contact .tel--lg .tel__num strong{font-size:1.5rem}
  /* Instagram フォローボタン：全幅・中央 */
  .insta__follow{display:flex;width:100%;justify-content:center}
  .footer__nav{gap:34px}
  /* スマホ追従CTA */
  .mobile-cta{display:flex;position:fixed;left:0;right:0;bottom:0;z-index:80;box-shadow:0 -4px 16px rgba(0,0,0,.16)}
  .mobile-cta a{flex:1;display:flex;align-items:center;justify-content:center;gap:6px;
    padding:14px 0;font-family:var(--display);font-weight:700;font-size:.92rem;line-height:1}
  .mobile-cta svg{width:1.05em;height:1.05em;fill:currentColor}
  .mobile-cta__tel{background:var(--ink);color:#fff}
  .mobile-cta__btn{background:var(--green);color:var(--ink)}
  body{padding-bottom:48px}
}

/* ---------- Motion ---------- */
@media (prefers-reduced-motion:reduce){
  .hslide--up,.hslide--down,.marquee__track,.hero__kinetic .rot{animation:none}
  html{scroll-behavior:auto}
}
