/*
Theme Name: サカエギケン
Theme URI: https://sakae-giken.com/
Author: FLOWS
Description: サカエギケン様 公式サイト用テーマ（MVP / フェーズ1）。表＝手書きチラシ感、潜ると綺麗。モノクロ・文字大きめ・電話導線優先。
Version: 0.1.0
Requires at least: 6.0
Tested up to: 6.5
Requires PHP: 8.0
Text Domain: sakae-giken
*/

/* ============================================================
   デザイントークン（ワイヤー _wireframe-base.css 由来）
   ============================================================ */
:root{
  --ink:#1a1a1a; --sub:#666; --line:#d9d9d9; --line-strong:#1a1a1a;
  --bg:#fff; --paper:#faf8f4; --tint:#f4f4f4; --tint2:#ececec;
  --maxw:980px; --accent:#b3382c;
}
*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  font-family:-apple-system,"Hiragino Kaku Gothic ProN","Hiragino Sans","Noto Sans JP","Yu Gothic",sans-serif;
  color:var(--ink); background:var(--paper); line-height:1.85; margin:0;
  -webkit-font-smoothing:antialiased; font-size:16px;
}
img{max-width:100%;height:auto;display:block;}
a{color:inherit;}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 22px;}

/* 手書き見出し用フォント（ヒーロー・要所のみ。本文は読みやすいゴシックのまま） */
.hand{font-family:"Klee One","Yomogi","Hiragino Maru Gothic ProN",cursive;}

/* ============================================================
   ヘッダー
   ============================================================ */
.site-header{position:sticky;top:0;z-index:50;background:#fff;border-bottom:2px solid var(--ink);}
.site-header .inner{max-width:var(--maxw);margin:0 auto;display:flex;align-items:center;justify-content:space-between;gap:12px;padding:11px 22px;}
.site-header .logo{font-weight:700;font-size:17px;letter-spacing:.02em;line-height:1.25;text-decoration:none;}
.site-header .logo small{display:block;font-size:10.5px;color:var(--sub);font-weight:400;letter-spacing:.08em;}
.site-header nav{display:flex;gap:18px;font-size:13.5px;}
.site-header nav a{text-decoration:none;color:var(--ink);padding:4px 0;border-bottom:2px solid transparent;}
.site-header nav a:hover{border-bottom-color:var(--ink);}
.tel-btn{display:inline-flex;align-items:center;gap:8px;background:var(--ink);color:#fff;
  text-decoration:none;font-weight:700;padding:9px 16px;border-radius:3px;font-size:14px;white-space:nowrap;}
.tel-btn small{display:block;font-size:10px;font-weight:400;color:#ccc;line-height:1;margin-bottom:2px;}
.tel-btn .n{font-size:16px;letter-spacing:.02em;}
@media(max-width:820px){
  .site-header nav{display:none;}
  .site-header .inner{padding:9px 14px;}
  .site-header .logo{font-size:15px;}
}

/* ============================================================
   ヒーロー（手書きチラシ感）
   ============================================================ */
.hero{background:var(--bg);border-bottom:1px solid var(--line);}
.hero .inner{max-width:var(--maxw);margin:0 auto;padding:48px 22px 44px;}
.hero-grid{display:grid;grid-template-columns:1.12fr .88fr;gap:34px;align-items:center;}
@media(max-width:840px){ .hero-grid{grid-template-columns:1fr;gap:26px;} }

/* チラシ画像（本物安心の受け皿） */
.hero-flyer{margin:0;}
.flyer-thumb{display:block;width:100%;padding:0;border:1px solid var(--line);background:#fff;
  cursor:zoom-in;box-shadow:0 6px 22px rgba(0,0,0,.12);border-radius:2px;overflow:hidden;transition:box-shadow .15s,transform .15s;}
.flyer-thumb img{display:block;width:100%;height:auto;}
.flyer-thumb:hover{box-shadow:0 10px 30px rgba(0,0,0,.22);transform:translateY(-2px);}
.hero-flyer figcaption{font-size:12.5px;color:var(--sub);margin-top:10px;text-align:center;line-height:1.7;}
.hero-flyer figcaption .tap{color:#999;margin-left:4px;}
.hero-flyer .lb-link{display:inline-block;margin-top:4px;appearance:none;border:0;background:none;
  font:inherit;color:var(--ink);text-decoration:underline;cursor:pointer;padding:0;}
@media(max-width:840px){ .hero-flyer{max-width:360px;margin:6px auto 0;} }

/* ライトボックス */
.lb-overlay{position:fixed;inset:0;z-index:100;background:rgba(0,0,0,.88);
  display:flex;align-items:center;justify-content:center;padding:24px;
  opacity:0;visibility:hidden;transition:opacity .18s;}
.lb-overlay.open{opacity:1;visibility:visible;}
.lb-overlay img{max-width:100%;max-height:92vh;width:auto;height:auto;background:#fff;box-shadow:0 12px 44px rgba(0,0,0,.5);}
.lb-btn{position:absolute;background:rgba(255,255,255,.16);color:#fff;border:0;cursor:pointer;
  font-size:26px;line-height:1;width:48px;height:48px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;}
.lb-btn:hover{background:rgba(255,255,255,.30);}
.lb-close{top:16px;right:16px;}
.lb-prev{left:16px;top:50%;transform:translateY(-50%);}
.lb-next{right:16px;top:50%;transform:translateY(-50%);}
@media(max-width:640px){ .lb-btn{width:42px;height:42px;font-size:22px;} .lb-prev{left:8px;} .lb-next{right:8px;} }
.eyebrow{font-size:12px;letter-spacing:.16em;color:var(--sub);margin:0 0 14px;}
.hero h1{font-size:34px;line-height:1.5;margin:0 0 20px;font-weight:700;letter-spacing:.01em;}
.hero h1 .mark{position:relative;white-space:nowrap;}
.hero h1 .mark::after{content:"";position:absolute;left:-2px;right:-2px;bottom:2px;height:10px;
  background:rgba(179,56,44,.22);z-index:-1;transform:rotate(-.6deg);}
.hero .sub{font-size:16px;color:#333;margin:0 0 26px;max-width:38em;}
.hero .who{font-size:13px;color:var(--sub);margin:22px 0 0;}
.hero .who b{color:var(--ink);font-size:14.5px;}
.hero-portrait{margin:6px 0 24px;max-width:460px;}
.hero-portrait img{width:100%;height:auto;display:block;border-radius:6px;border:1px solid var(--line);box-shadow:0 5px 18px rgba(0,0,0,.10);}
.hero-portrait figcaption{font-size:12.5px;color:var(--sub);margin-top:9px;}
.hero-portrait figcaption b{color:var(--ink);font-size:14px;}
@media(max-width:840px){ .hero-portrait{max-width:100%;} }
@media(max-width:760px){ .hero h1{font-size:26px;line-height:1.55;} .hero .inner{padding:34px 18px 32px;} }

/* CTAボタン */
.cta-actions{display:flex;gap:12px;flex-wrap:wrap;}
.btn-lg{display:inline-flex;align-items:center;gap:8px;text-decoration:none;font-weight:700;
  font-size:16px;padding:14px 24px;border-radius:4px;border:2px solid var(--ink);line-height:1.2;}
.btn-lg.solid{background:var(--ink);color:#fff;}
.btn-lg.ghost{background:#fff;color:var(--ink);}
.btn-lg .x{font-size:11px;font-weight:400;display:block;margin-top:2px;opacity:.85;}
@media(max-width:760px){ .btn-lg{font-size:15px;padding:13px 20px;} .cta-actions{gap:10px;} }

/* ============================================================
   セクション共通
   ============================================================ */
.section{padding:46px 0;border-top:1px solid var(--line);background:var(--bg);}
.section.alt{background:var(--paper);}
.section h2{font-size:24px;margin:0 0 6px;font-weight:700;letter-spacing:.01em;}
.section .lead{color:var(--sub);font-size:14px;margin:0 0 26px;}
.tag-eyebrow{font-size:11px;letter-spacing:.2em;color:var(--sub);margin:0 0 8px;}
@media(max-width:760px){ .section{padding:36px 0;} .section h2{font-size:21px;} }

/* サービス */
.grid-svc{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;}
.scard{border:1px solid var(--line);padding:18px 16px;background:#fff;border-radius:3px;}
.scard h3{font-size:16px;margin:0 0 6px;font-weight:700;}
.scard p{font-size:13px;color:#555;margin:0;line-height:1.7;}
.scard.more{display:flex;align-items:center;justify-content:center;text-align:center;background:var(--tint);}
.scard.more p{font-size:13.5px;color:#333;font-weight:600;}
@media(max-width:760px){ .grid-svc{grid-template-columns:1fr 1fr;gap:10px;} .scard{padding:14px 13px;} }
@media(max-width:420px){ .grid-svc{grid-template-columns:1fr;} }

/* 施工事例（準備中の正直見せ） */
.works-soon{border:1px dashed var(--line-strong);background:#fff;border-radius:4px;padding:26px 22px;text-align:center;}
.works-soon p{margin:0 0 6px;font-size:14.5px;}
.works-soon .small{color:var(--sub);font-size:13px;margin:0;}

/* お客様の声 */
.tabs{display:flex;gap:0;border-bottom:2px solid var(--ink);flex-wrap:wrap;}
.tabs button{appearance:none;border:0;background:transparent;font:inherit;cursor:pointer;
  padding:11px 20px;font-weight:700;font-size:14.5px;color:var(--sub);border-bottom:3px solid transparent;margin-bottom:-2px;}
.tabs button[aria-selected="true"]{color:var(--ink);border-bottom-color:var(--ink);}
.tabpanel{padding:20px 0 2px;}
.tabpanel[hidden]{display:none;}
.voice{border:1px solid var(--line);background:#fff;border-radius:3px;padding:14px 16px;margin:0 0 10px;font-size:14.5px;}
.voice .who{color:var(--sub);font-size:12px;margin-top:6px;}
.voice.hard{border-left:4px solid #999;}
.voice .reply{color:var(--sub);font-size:12.5px;margin-top:6px;}

/* FAQ */
.acc{border:1px solid var(--line);background:#fff;border-radius:3px;overflow:hidden;}
.acc details{border-top:1px solid var(--line);}
.acc details:first-child{border-top:0;}
.acc summary{cursor:pointer;padding:15px 18px;font-weight:700;font-size:15px;list-style:none;
  display:flex;justify-content:space-between;align-items:center;gap:10px;}
.acc summary::-webkit-details-marker{display:none;}
.acc summary::after{content:"＋";color:var(--sub);font-weight:400;}
.acc details[open] summary::after{content:"−";}
.acc .a{padding:0 18px 18px;font-size:14px;color:#333;}

/* 対応分野 */
.scope{display:flex;gap:10px;flex-wrap:wrap;}
.scope div{flex:1 1 180px;border:1px solid var(--line);background:#fff;border-radius:3px;padding:14px 16px;font-size:13.5px;text-align:center;}
.scope div b{display:block;margin-bottom:3px;font-size:14.5px;}

/* 会社・代表 */
.about{display:grid;grid-template-columns:1fr;gap:14px;max-width:720px;}
.about .yrs{display:inline-block;background:var(--ink);color:#fff;font-size:12px;font-weight:700;padding:3px 12px;border-radius:2px;margin-bottom:10px;}
.about h3{margin:0 0 10px;font-size:20px;}
.about p{font-size:14.5px;color:#333;margin:0 0 10px;}

/* CTAバンド */
.cta-band{background:var(--ink);color:#fff;padding:42px 22px;text-align:center;}
.cta-band h3{font-size:23px;margin:0 0 8px;font-weight:700;}
.cta-band p{color:#ccc;font-size:14.5px;margin:0 0 22px;}
.cta-band .cta-actions{justify-content:center;}
.cta-band .btn-lg.solid{background:#fff;color:var(--ink);border-color:#fff;}
.cta-band .btn-lg.ghost{background:transparent;color:#fff;border-color:#fff;}

/* 連絡先（フォーム代替・電話/メール導線） */
.contact-box{display:grid;grid-template-columns:1fr 1fr;gap:14px;}
.contact-box a{display:block;border:1px solid var(--line);background:#fff;border-radius:4px;padding:20px;text-decoration:none;text-align:center;}
.contact-box .k{font-size:12px;letter-spacing:.1em;color:var(--sub);margin:0 0 6px;}
.contact-box .v{font-size:22px;font-weight:700;letter-spacing:.02em;margin:0;}
.contact-box .v small{display:block;font-size:12px;color:var(--sub);font-weight:400;margin-top:4px;}
.contact-note{font-size:13px;color:var(--sub);margin:14px 0 0;}
@media(max-width:560px){ .contact-box{grid-template-columns:1fr;} }

/* ============================================================
   フッター
   ============================================================ */
.site-footer{background:var(--ink);color:#ddd;padding:34px 0;font-size:13.5px;}
.site-footer .cols{display:grid;grid-template-columns:1.5fr 1fr 1fr;gap:24px;max-width:var(--maxw);margin:0 auto;padding:0 22px;}
.site-footer h4{color:#fff;font-size:14px;margin:0 0 10px;font-weight:700;}
.site-footer p{margin:0 0 6px;}
.site-footer ul{list-style:none;padding:0;margin:0;}
.site-footer li{margin:4px 0;}
.site-footer a{color:#ddd;text-decoration:none;}
.site-footer a:hover{color:#fff;text-decoration:underline;}
.site-footer .small{color:#999;font-size:12px;}
.site-footer .copy{border-top:1px solid #444;margin-top:24px;padding-top:16px;color:#999;font-size:12px;text-align:center;}
@media(max-width:760px){ .site-footer .cols{grid-template-columns:1fr;gap:18px;} }

/* 上に戻るボタン */
.to-top{position:fixed;right:18px;bottom:18px;z-index:55;width:46px;height:46px;border-radius:50%;
  border:2px solid var(--ink);background:#fff;color:var(--ink);font-size:20px;line-height:1;cursor:pointer;
  box-shadow:0 3px 12px rgba(0,0,0,.18);display:flex;align-items:center;justify-content:center;
  opacity:0;visibility:hidden;transition:opacity .2s,visibility .2s;}
.to-top.show{opacity:1;visibility:visible;}
.to-top:hover{background:var(--ink);color:#fff;}
@media(max-width:820px){ .to-top{right:14px;bottom:66px;} } /* 固定電話バーの上 */

/* スマホ固定電話バー */
.mobile-call{display:none;}
@media(max-width:820px){
  .mobile-call{display:flex;position:fixed;left:0;right:0;bottom:0;z-index:60;
    background:var(--ink);color:#fff;text-decoration:none;align-items:center;justify-content:center;gap:10px;
    padding:13px;font-weight:700;font-size:16px;box-shadow:0 -2px 10px rgba(0,0,0,.18);}
  body{padding-bottom:54px;}
}
