/* =========================================================
   MORE LIVING リニューアル ワイヤーフレーム
   シンプル・モノクロ共通スタイル
   ========================================================= */

:root{
  --ink:#222;          /* 主要テキスト */
  --ink-2:#555;        /* 補助テキスト */
  --ink-3:#888;        /* 注釈・ラベル */
  --line:#bbb;         /* 罫線 */
  --line-2:#ddd;       /* 薄い罫線 */
  --fill:#f4f4f4;      /* 面 */
  --fill-2:#eaeaea;    /* 面（濃） */
  --box:#e2e2e2;       /* プレースホルダ面 */
  --white:#fff;
  --note:#666;         /* 注釈枠 */
  --maxw:1080px;
  --gap:24px;
}

*{box-sizing:border-box;}

html{scroll-behavior:smooth;}

body{
  margin:0;
  font-family:-apple-system,BlinkMacSystemFont,"Hiragino Sans","Hiragino Kaku Gothic ProN","Noto Sans JP","Yu Gothic",Meiryo,sans-serif;
  color:var(--ink);
  background:#cfcfcf;
  line-height:1.7;
  font-size:14px;
  -webkit-font-smoothing:antialiased;
}

a{color:inherit;text-decoration:none;}

/* ---- ページ枠（紙のイメージ） ---- */
.page{
  max-width:var(--maxw);
  margin:0 auto;
  background:var(--white);
  min-height:100vh;
  box-shadow:0 0 0 1px #aaa, 0 8px 40px rgba(0,0,0,.15);
}

/* ---- ワイヤー注釈バー ---- */
.wf-bar{
  background:var(--ink);
  color:#fff;
  font-size:12px;
  letter-spacing:.04em;
  padding:8px 20px;
  display:flex;
  gap:16px;
  flex-wrap:wrap;
  align-items:center;
}
.wf-bar strong{font-weight:700;}
.wf-bar .tag{
  border:1px solid #888;
  border-radius:2px;
  padding:1px 8px;
  font-size:11px;
  color:#ddd;
}
.wf-bar a{color:#bcd;border-bottom:1px dotted #789;}

/* ---- セクション共通 ---- */
section{position:relative;}
.wrap{max-width:920px;margin:0 auto;padding:0 28px;}

.sec{padding:48px 0;border-bottom:1px dashed var(--line);}
.sec:last-child{border-bottom:none;}

/* セクション番号ラベル（左上の付箋） */
.sec-no{
  position:absolute;top:0;left:0;
  background:var(--fill-2);
  border-right:1px solid var(--line);
  border-bottom:1px solid var(--line);
  color:var(--ink-3);
  font-size:11px;
  font-weight:700;
  letter-spacing:.08em;
  padding:4px 10px;
}

h1,h2,h3,h4{margin:0;font-weight:700;line-height:1.4;}

.sec-head{
  font-size:20px;
  letter-spacing:.06em;
  margin-bottom:4px;
  display:flex;align-items:baseline;gap:10px;
}
.sec-head .en{font-size:11px;color:var(--ink-3);letter-spacing:.2em;font-weight:600;}
.lead{color:var(--ink-2);margin:6px 0 24px;font-size:13px;}

/* ---- プレースホルダ（画像・動画枠） ---- */
.ph{
  background:
    repeating-linear-gradient(45deg,#e8e8e8 0 10px,#e0e0e0 10px 20px);
  border:1px solid var(--line);
  color:var(--ink-3);
  display:flex;align-items:center;justify-content:center;
  text-align:center;
  font-size:12px;letter-spacing:.08em;
  min-height:120px;
  position:relative;
}
.ph::after{
  content:"";
  position:absolute;inset:0;
  background:
    linear-gradient(to top right,transparent calc(50% - 1px),var(--line) 50%,transparent calc(50% + 1px)),
    linear-gradient(to top left, transparent calc(50% - 1px),var(--line) 50%,transparent calc(50% + 1px));
  opacity:.5;
  pointer-events:none;
}
.ph span{position:relative;z-index:1;background:rgba(244,244,244,.85);padding:2px 8px;}

/* ---- ボタン（ワイヤー） ---- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  border:1.5px solid var(--ink);
  background:var(--white);
  color:var(--ink);
  padding:12px 22px;
  font-size:13px;font-weight:700;letter-spacing:.04em;
  border-radius:2px;
  cursor:pointer;
}
.btn.solid{background:var(--ink);color:#fff;}
.btn.sm{padding:7px 14px;font-size:12px;}
.btn.block{display:flex;width:100%;}
.btn::after{content:"→";font-weight:400;}
.btn.nolink::after{content:"";}

/* ---- カード/グリッド ---- */
.grid{display:grid;gap:var(--gap);}
.g2{grid-template-columns:repeat(2,1fr);}
.g3{grid-template-columns:repeat(3,1fr);}
.g4{grid-template-columns:repeat(4,1fr);}

.card{
  border:1px solid var(--line);
  background:var(--white);
}
.card .ph{min-height:130px;border:none;border-bottom:1px solid var(--line);}
.card .body{padding:12px 14px;}
.card .meta{font-size:11px;color:var(--ink-3);margin-bottom:4px;letter-spacing:.04em;}
.card h4{font-size:14px;margin-bottom:6px;}
.card p{margin:0;font-size:12px;color:var(--ink-2);}

/* ---- 注釈テキスト ---- */
.note{
  font-size:11px;color:var(--note);
  border-left:3px solid var(--line);
  background:var(--fill);
  padding:6px 10px;margin-top:10px;
}
.note::before{content:"※ ";color:var(--ink-3);}

/* ダミーテキスト行 */
.tx{height:9px;background:var(--fill-2);border-radius:2px;margin:7px 0;}
.tx.w90{width:90%}.tx.w80{width:80%}.tx.w70{width:70%}.tx.w60{width:60%}.tx.w50{width:50%}.tx.w40{width:40%}

/* =========================================================
   ヘッダー
   ========================================================= */
.gh{
  position:sticky;top:0;z-index:30;
  background:var(--white);
  border-bottom:1px solid var(--line);
}
.gh .row{
  display:flex;align-items:center;gap:18px;
  max-width:var(--maxw);margin:0 auto;padding:10px 24px;
}
.gh .logo{
  font-weight:800;letter-spacing:.12em;font-size:16px;
  border:1px solid var(--line);padding:6px 12px;
}
.gh .logo small{display:block;font-size:9px;letter-spacing:.05em;color:var(--ink-3);font-weight:600;}
.gh nav{display:flex;gap:16px;font-size:12px;color:var(--ink-2);margin-left:6px;}
.gh nav a{padding:4px 2px;border-bottom:2px solid transparent;}
.gh nav a:hover{border-color:var(--ink);}
.gh .right{margin-left:auto;display:flex;gap:8px;align-items:center;}
.gh .tel{font-size:12px;color:var(--ink-2);text-align:right;line-height:1.3;}
.gh .tel b{font-size:15px;color:var(--ink);letter-spacing:.02em;}

/* =========================================================
   フッター
   ========================================================= */
.gf{background:var(--fill);border-top:1px solid var(--line);padding:36px 0 20px;}
.gf .cols{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:24px;}
.gf h5{font-size:12px;letter-spacing:.08em;margin:0 0 10px;border-bottom:1px solid var(--line-2);padding-bottom:6px;}
.gf ul{list-style:none;margin:0;padding:0;font-size:12px;color:var(--ink-2);}
.gf li{padding:3px 0;}
.gf .sns{display:flex;gap:8px;margin-top:10px;}
.gf .sns span{border:1px solid var(--line);border-radius:50%;width:30px;height:30px;display:flex;align-items:center;justify-content:center;font-size:10px;color:var(--ink-3);}
.gf .copy{text-align:center;font-size:11px;color:var(--ink-3);margin-top:28px;border-top:1px solid var(--line-2);padding-top:14px;}

/* 固定追従CTA（モバイル想定の注釈） */
.fixcta{
  position:sticky;bottom:0;z-index:25;
  display:flex;gap:1px;background:var(--line);
  border-top:1px solid var(--line);
}
.fixcta a{flex:1;background:var(--ink);color:#fff;text-align:center;padding:12px;font-size:12px;font-weight:700;letter-spacing:.04em;}
.fixcta a.alt{background:#555;}

/* パンくず */
.crumb{font-size:11px;color:var(--ink-3);padding:10px 0;letter-spacing:.04em;}
.crumb span{color:var(--ink-2);}

/* ページタイトル帯 */
.ptitle{background:var(--fill);border-bottom:1px dashed var(--line);padding:34px 0;}
.ptitle h1{font-size:24px;letter-spacing:.08em;}
.ptitle .en{font-size:11px;color:var(--ink-3);letter-spacing:.24em;font-weight:600;display:block;margin-top:4px;}

/* =========================================================
   ハンバーガー／ドロワーナビ（CSS only・checkbox方式）
   ※PCではnavインライン表示。SPでバーガー→ドロワー展開
   ========================================================= */
.gh .navtoggle{position:absolute;opacity:0;pointer-events:none;width:1px;height:1px;}
.gh .burger{
  display:none;margin-left:auto;
  width:42px;height:34px;border:1px solid var(--line);
  cursor:pointer;align-items:center;justify-content:center;flex-direction:column;gap:5px;
}
.gh .burger span,
.gh .burger::before,
.gh .burger::after{content:"";display:block;width:20px;height:2px;background:var(--ink);transition:.2s;}
.gh .burger span{margin:0;}

/* =========================================================
   汎用パーツ（テンプレHTML用）
   ========================================================= */
/* タブ／セグメント切替 */
.seg{display:inline-flex;border:1.5px solid var(--ink);}
.seg .opt{padding:9px 18px;font-size:13px;font-weight:700;letter-spacing:.04em;cursor:pointer;border-right:1.5px solid var(--ink);background:var(--white);color:var(--ink);}
.seg .opt:last-child{border-right:none;}
.seg .opt.on{background:var(--ink);color:#fff;}

/* フィルタピル列 */
.pills{display:flex;flex-wrap:wrap;gap:6px;}
.pills .pill{border:1px solid var(--line);padding:5px 12px;font-size:12px;color:var(--ink-2);cursor:pointer;background:var(--white);}
.pills .pill.on{background:var(--ink);color:#fff;border-color:var(--ink);}

/* アコーディオン（FAQ等・CSS only） */
.acc{border:1px solid var(--line);margin-bottom:8px;background:var(--white);}
.acc>summary{list-style:none;cursor:pointer;padding:13px 16px;font-size:13px;font-weight:700;display:flex;align-items:center;gap:10px;}
.acc>summary::-webkit-details-marker{display:none;}
.acc>summary::before{content:"Q";font-size:12px;color:var(--ink-3);border:1px solid var(--line);width:20px;height:20px;display:inline-flex;align-items:center;justify-content:center;flex:0 0 20px;}
.acc>summary::after{content:"＋";margin-left:auto;color:var(--ink-3);font-weight:400;}
.acc[open]>summary::after{content:"−";}
.acc .acc-body{padding:0 16px 14px 46px;font-size:13px;color:var(--ink-2);}

/* ステップ（来店予約・申込フロー等） */
.steps{display:flex;gap:0;margin:8px 0 20px;}
.steps .st{flex:1;text-align:center;font-size:11px;color:var(--ink-3);padding:8px 4px;border:1px solid var(--line);border-right:none;position:relative;}
.steps .st:last-child{border-right:1px solid var(--line);}
.steps .st b{display:block;font-size:13px;color:var(--ink-3);}
.steps .st.on{background:var(--ink);color:#fff;}
.steps .st.on b{color:#fff;}

/* 入力欄（フォーム用） */
.field{height:38px;border:1px solid var(--line);background:var(--white);margin-top:6px;}
.field.ta{height:100px;}
.lb{font-size:12px;display:block;}
.lb .req{color:#999;margin-left:4px;}

/* 目次 */
.toc{border:1px solid var(--line);background:var(--fill);padding:14px 18px;font-size:13px;}
.toc h5{font-size:12px;letter-spacing:.08em;margin:0 0 8px;}
.toc ol{margin:0;padding-left:18px;color:var(--ink-2);line-height:1.9;}

/* WF代替案ラベル（比較ページ用） */
.altbar{display:flex;align-items:center;gap:12px;background:var(--ink);color:#fff;padding:10px 18px;font-size:13px;letter-spacing:.04em;}
.altbar .ix{border:1px solid #777;padding:2px 9px;font-weight:700;font-size:12px;}
.prosbox{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:14px;}
.prosbox div{border:1px solid var(--line);padding:10px 14px;font-size:12px;line-height:1.9;}
.prosbox .pro b,.prosbox .con b{display:block;font-size:11px;letter-spacing:.08em;margin-bottom:4px;}
.prosbox .pro b{color:var(--ink);}
.prosbox .con b{color:var(--ink-3);}

/* =========================================================
   レスポンシブ（スマホ作り込み）
   ========================================================= */
@media(max-width:1100px){
  .page{box-shadow:none;}
  .wrap{max-width:100%;}
}

/* タブレット */
@media(max-width:900px){
  .gf .cols{grid-template-columns:1fr 1fr;}
  .prosbox{grid-template-columns:1fr;}
}

/* スマホ：ナビをドロワー化 */
@media(max-width:760px){
  body{font-size:14px;}
  .sec{padding:32px 0;}
  .wrap{padding:0 18px;}
  .g3,.g4{grid-template-columns:repeat(2,1fr);}

  /* ヘッダー */
  .gh .row{padding:8px 16px;gap:10px;flex-wrap:wrap;}
  .gh .logo{font-size:14px;padding:5px 10px;}
  .gh .burger{display:flex;}
  .gh nav{
    order:10;flex-basis:100%;display:none;flex-direction:column;gap:0;margin:0;
    border-top:1px solid var(--line);
  }
  .gh nav a{padding:13px 4px;border-bottom:1px solid var(--line-2);border-top:none;}
  .gh .navtoggle:checked ~ nav{display:flex;}
  .gh .navtoggle:checked ~ .burger span{opacity:0;}
  .gh .right{order:5;margin-left:0;}
  .gh .tel{display:none;}

  /* ページタイトル */
  .ptitle{padding:24px 0;}
  .ptitle h1{font-size:20px;}

  /* WORKS等の2カラム（サイド＋本体）を縦積み */
  .wrap[style*="grid-template-columns:240px"],
  .wrap[style*="grid-template-columns: 240px"]{display:block!important;}

  /* 固定追従CTA分の余白 */
  .page{padding-bottom:0;}
}

/* スマホ小：1カラムへ */
@media(max-width:520px){
  .g2,.g3,.g4{grid-template-columns:1fr;}
  .gf .cols{grid-template-columns:1fr;}
  .sec-head{font-size:18px;}
  .gh .right .tel{display:none;}
  .steps{flex-wrap:wrap;}
  .steps .st{flex:1 0 33%;border-right:1px solid var(--line);border-bottom:none;}
  .seg{display:flex;width:100%;}
  .seg .opt{flex:1;text-align:center;}
}
