/* ファイル: /wp-content/themes/ryuji01/css/pages/front-page-new.css */
:root{
    --bg: #ffffff;
    --ink: #0f172a;          /* slate-900 */
    --sub: #334155;          /* slate-700 */
    --line: #e5e7eb;         /* gray-200 */
    --accent: #2563eb;       /* blue-600 */
    --accent-ink: #ffffff;
    --muted: #f8fafc;        /* slate-50 */
    --radius: 14px;
    --shadow: 0 8px 24px rgba(15,23,42,0.08);
  }
  
  html,body{background:var(--bg);color:var(--ink);font-family:-apple-system,BlinkMacSystemFont,"Segoe UI","Hiragino Sans","Yu Gothic",sans-serif;line-height:1.6}
  img{max-width:100%;height:auto;display:block}
  
  /* ==== ヘッダー ==== */
  .tw-header{position:sticky;top:0;z-index:1000;background:#fff;border-bottom:1px solid var(--line)}
  .tw-header__inner{max-width:1200px;margin:0 auto;padding:14px 20px;display:flex;align-items:center;justify-content:space-between;gap:16px}
  .tw-header__brand{display:flex;align-items:center;gap:12px}
  .tw-header__tag{font-size:12px;padding:2px 8px;border:1px solid var(--line);border-radius:999px;color:var(--sub)}
  .tw-header__nav{display:flex;align-items:center;gap:12px}
  .tw-nav__list{display:flex;gap:20px;list-style:none;margin:0;padding:0}
  .tw-nav__list a{color:var(--ink);text-decoration:none;font-weight:500}
  .tw-header__cta{display:inline-block;padding:10px 14px;border:1px solid var(--ink);border-radius:10px;text-decoration:none;color:var(--ink)}
  .tw-header__cta:hover{background:var(--ink);color:#fff}
  
  .tw-burger{display:none;width:40px;height:40px;border:1px solid var(--line);border-radius:10px;background:#fff;position:relative}
  .tw-burger span{position:absolute;left:8px;right:8px;height:2px;background:var(--ink);transform-origin:left}
  .tw-burger span:nth-child(1){top:12px}
  .tw-burger span:nth-child(2){top:19px}
  .tw-burger span:nth-child(3){top:26px}
  
  .tw-drawer{position:fixed;inset:0 0 0 auto;width:84vw;max-width:360px;background:#fff;box-shadow:var(--shadow);padding:20px;overflow:auto;z-index:1001}
  .tw-drawer__list{list-style:none;margin:0 0 16px 0;padding:0}
  .tw-drawer__list a{display:block;padding:12px 8px;color:var(--ink);text-decoration:none;border-bottom:1px solid var(--line)}
  .tw-drawer__cta{display:block;margin-top:12px;text-align:center;padding:12px 14px;border:1px solid var(--ink);border-radius:10px;color:var(--ink);text-decoration:none}
  .tw-dim{position:fixed;inset:0;background:rgba(0,0,0,.3)}
  
  .tw-no-scroll{overflow:hidden}
  
  @media (max-width: 980px){
    .tw-nav__list{display:none}
    .tw-header__cta{display:none}
    .tw-burger{display:inline-block}
  }
  
  /* ==== セクション共通 ==== */
  .tw-main{display:block}
  .tw-section__head{max-width:1200px;margin:0 auto;padding:48px 20px 18px}
  .tw-section__title{font-size:28px;line-height:1.3;margin:6px 0 0}
  .tw-kicker{font-size:12px;color:var(--sub);letter-spacing:.08em;text-transform:uppercase}
  .tw-section__foot{max-width:1200px;margin:0 auto;padding:12px 20px 0}
  .tw-link{color:var(--ink);text-underline-offset:4px}
  .tw-link:hover{text-decoration:none;border-bottom:1px solid var(--ink)}
  
  /* ==== パターン（SVG data URI） ==== */
  .tw-hero__pattern--dots{
    position:absolute;inset:auto 0 0 0;height:38%;pointer-events:none;
    background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='8' height='8'><circle cx='1' cy='1' r='1' fill='%23e5e7eb'/></svg>");
    background-repeat:repeat;background-position:top left;opacity:.8
  }
  .tw-cta__pattern--grid{
    position:absolute;inset:0;pointer-events:none;opacity:.5;
    background-image:url(\"data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='16' height='16'><path d='M16 0H0V16' fill='none' stroke='%23e5e7eb' stroke-width='1'/></svg>\");
    background-repeat:repeat
  }
  
  /* ==== ヒーロー ==== */
  .tw-hero{position:relative;overflow:hidden;border-bottom:1px solid var(--line);background:var(--muted)}
  .tw-hero__inner{max-width:1200px;margin:0 auto;padding:56px 20px;display:grid;grid-template-columns:1.15fr .85fr;gap:24px;align-items:center}
  .tw-hero__title{font-size:34px;line-height:1.25}
  .tw-hero__title strong{font-weight:800}
  .tw-hero__lead{color:var(--sub);margin-top:10px}
  .tw-hero__actions{display:flex;gap:12px;margin-top:16px}
  .tw-hero__media{margin:0}
  @media (max-width: 980px){
    .tw-hero__inner{grid-template-columns:1fr}
  }
  
  /* ==== ボタン ==== */
  .tw-btn{display:inline-block;padding:12px 16px;border-radius:12px;text-decoration:none;font-weight:700;border:1px solid var(--ink)}
  .tw-btn--primary{background:var(--accent);border-color:var(--accent);color:var(--accent-ink)}
  .tw-btn--primary:hover{filter:brightness(0.95)}
  .tw-btn--ghost{background:#fff;color:var(--ink)}
  .tw-btn--ghost:hover{background:#f1f5f9}
  
  /* ==== 特徴 ==== */
  .tw-features{padding:16px 0 8px}
  .tw-features__grid{max-width:1200px;margin:0 auto;padding:12px 20px 32px;display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
  @media (max-width: 980px){
    .tw-features__grid{grid-template-columns:1fr}
  }
  .tw-card{padding:18px;border:1px solid var(--line);border-radius:var(--radius);background:#fff;box-shadow:var(--shadow)}
  .tw-card--pattern{background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='10' height='10'><circle cx='1' cy='1' r='1' fill='%23f1f5f9'/></svg>");background-repeat:repeat}
  
  /* ==== サービス ==== */
  .tw-services{padding:12px 0 24px}
  .tw-services__grid{max-width:1200px;margin:0 auto;padding:0 20px 20px;display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
  @media (max-width: 980px){
    .tw-services__grid{grid-template-columns:1fr}
  }
  .tw-service{display:block;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;text-decoration:none;background:#fff;box-shadow:var(--shadow)}
  .tw-service__media img{width:100%;height:210px;object-fit:cover}
  .tw-service__body{padding:14px 14px 16px}
  .tw-service__body h3{margin:0 0 6px 0;color:var(--ink)}
  .tw-service__body p{margin:0;color:var(--sub)}
  
  /* ==== お知らせ ==== */
  .tw-news{padding:8px 0 30px;border-top:1px solid var(--line)}
  .tw-news__list{max-width:1200px;margin:0 auto;padding:0 20px;display:grid;grid-template-columns:repeat(2,1fr);gap:12px}
  @media (max-width: 980px){
    .tw-news__list{grid-template-columns:1fr}
  }
  .tw-news__item{border:1px solid var(--line);border-radius:12px;overflow:hidden;background:#fff}
  .tw-news__link{display:grid;grid-template-columns:140px 1fr auto;gap:8px;align-items:center;padding:12px 14px;color:var(--ink);text-decoration:none}
  @media (max-width: 680px){
    .tw-news__link{grid-template-columns:100px 1fr}
  }
  .tw-news__date{font-variant-numeric:tabular-nums;color:var(--sub)}
  .tw-news__title{margin:0}
  .tw-badge{margin-left:8px;padding:2px 6px;font-size:11px;border:1px solid var(--ink);border-radius:999px}
  
  /* ==== CTA ==== */
  .tw-cta{position:relative;background:#fff;border-top:1px solid var(--line);overflow:hidden}
  .tw-cta__inner{max-width:1200px;margin:0 auto;padding:40px 20px;text-align:center}
  .tw-cta__title{font-size:26px;margin:0}
  .tw-cta__lead{color:var(--sub);margin:8px 0 16px}
  .tw-cta__actions{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}
  
  /* アクセシビリティ微調整 */
  .tw-header__logo img{image-rendering:-webkit-optimize-contrast}
  
  /* === Reveal Animations (ふわっと表示) === */
.tw-reveal{opacity:0;transform:translateY(14px) scale(.98);transition:opacity .7s ease,transform .7s ease;will-change:opacity,transform}
.tw-reveal[data-reveal="fade"]{transform:none}
.tw-reveal[data-reveal="up"]{transform:translateY(18px)}
.tw-reveal[data-reveal="scale"]{transform:scale(.96)}
.tw-reveal.is-revealed{opacity:1;transform:none}
.tw-reveal[data-stagger]{transition-delay:calc(var(--i,0) * 60ms)}

@media (prefers-reduced-motion: reduce){
  .tw-reveal, .tw-reveal *{transition:none !important;animation:none !important}
}

/* ナビ下線のさりげない出現 */
.tw-nav__list a{position:relative}
.tw-nav__list a::after{content:"";position:absolute;left:0;bottom:-6px;width:0;height:1px;background:currentColor;transition:width .25s ease}
.tw-nav__list a:hover::after{width:100%}

/* サービスカードのホバー微浮き */
.tw-service{transition:transform .2s ease, box-shadow .2s ease}
.tw-service:hover{transform:translateY(-2px);box-shadow:0 12px 28px rgba(15,23,42,.10)}

/* === Header: ロゴ左／電話画像右／最右ハンバーガー === */
.tw-header__inner{display:flex;align-items:center;justify-content:space-between}
.tw-header__right{margin-left:auto;display:flex;align-items:center;gap:12px}

/* 電話番号画像のサイズ（高さ基準） */
.tw-phone img{display:block;height:36px;width:auto}
@media (min-width:981px){ .tw-phone img{height:44px} }
@media (max-width:380px){ .tw-phone img{height:30px} }

/* ハンバーガーはPCでも表示したい場合は有効、SPだけにするなら削除 */
.tw-burger{display:inline-block}

/* アクセシビリティ用スクリーンリーダー専用テキスト */
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}

/* ドロワー内のショートCTA */
.tw-drawer__cta--tel, .tw-drawer__cta--sms{margin-top:8px}

/* =========================
   Hero（背景：PC/スマホで切替）
   ========================= */
   .hero-bg{
    /* PC(>=768px)は横長 1920×1080 推奨 */
    background-image: url('/wp-content/themes/ryuji01/images/hero/hero-desktop.jpg');
    background-size: cover;
    background-repeat: no-repeat;
    /* 人物の位置に合わせて微調整（中央少し下） */
    background-position: 60% 40%;
    position: relative;
    color: #fff;
    padding: clamp(56px, 8vw, 120px) 20px;
    min-height: 540px;
  }
  .hero-bg::before{
    /* 可読性のためのオーバーレイ */
    content:"";
    position:absolute; inset:0;
    background: linear-gradient(90deg, rgba(8,19,64,.55) 0%, rgba(8,19,64,.30) 50%, rgba(8,19,64,.15) 100%);
    z-index:0;
  }
  .tw-hero__inner{
    position:relative; z-index:1;
    max-width: 1200px; margin: 0 auto;
    display: grid; gap: 16px;
  }
  
  /* 見出し：1行目は大きく、2行目（サブ）は小さく */
  .tw-hero__title{
    font-size: clamp(28px, 4.2vw, 44px);
    line-height: 1.32;
    margin: 0;
    letter-spacing: .02em;
  }
  .tw-hero__title .highlight{
    color: #ffd45e; /* アクセント（お好みでブランド色に） */
    font-weight: 700;
  }
  .tw-hero__subtitle{
    display: block;
    margin-top: .4em;
    font-size: clamp(14px, 1.9vw, 20px); /* ← 2行目を小さく */
    font-weight: 500;
    opacity: .95;
  }
  
  /* リード・ボタン */
  .tw-hero__lead{
    font-size: clamp(14px, 1.6vw, 18px);
    max-width: 56ch;
  }
  .tw-hero__actions{ display:flex; gap: 12px; flex-wrap: wrap; }
  
  /* -------------------------
     スマホ（<768px）
     画像を縦長/人物が切れないように差し替え
     例：900×1300 程度推奨（人物中央）
     ------------------------- */
  @media (max-width: 767.98px){
    .hero-bg{
      background-image: url('/wp-content/themes/ryuji01/images/hero/hero-mobile.jpg');
      /* 顔が見えるよう中央上寄せ */
      background-position: 50% 20%;
      min-height: 480px;
      padding: 72px 20px;
    }
    .tw-hero__inner{ gap: 12px; }
  }
  
  /* 高解像度向け(任意)：image-set でDPR別を用意 */
  @supports (background-image: image-set(url('x') 1x)){
    .hero-bg{
      background-image: image-set(
        url('/wp-content/themes/ryuji01/images/hero/hero-desktop.jpg') 1x,
        url('/wp-content/themes/ryuji01/images/hero/hero-desktop@2x.jpg') 2x
      );
    }
    @media (max-width: 767.98px){
      .hero-bg{
        background-image: image-set(
          url('/wp-content/themes/ryuji01/images/hero/hero-mobile.jpg') 1x,
          url('/wp-content/themes/ryuji01/images/hero/hero-mobile@2x.jpg') 2x
        );
      }
    }
  }
  
  /* ===== Hero レイアウトを上下詰め＆2カラム ===== */
.tw-hero__grid{
  display:grid;
  grid-template-columns: minmax(0, 640px) 1fr; /* 左見出し、右リード */
  align-items: start;                 /* ← タイトルを少し上に */
  gap: clamp(16px, 3vw, 40px);
}

/* 右リードは白文字＋読みやすさのための影 */
.tw-hero__right { color:#fff; }
.tw-hero__lead{
  color:#fff;
  text-shadow: 0 1px 2px rgba(0,0,0,.28);
  font-size: clamp(14px, 1.6vw, 18px);
  line-height: 1.8;
  margin-top: clamp(4px, .6vw, 8px);
}

/* タイトルブロックをやや上げる（ヒーロー間隔を詰める） */
.hero-bg{
  padding-top: clamp(44px, 6.5vw, 96px); /* ← 以前より上に */
  padding-bottom: clamp(40px, 7vw, 110px);
  background-position: 60% 40%;
}

/* 電話問い合わせ帯（ボタン下） */
.tw-contact-lane{
  display:flex;
  align-items:center;
  gap: 12px;
  margin-top: 14px;
  padding: 10px 12px;
  border: 1px solid rgba(255,255,255,.25);
  border-radius: 999px;
  background: rgba(255,255,255,.08);
  backdrop-filter: saturate(140%) blur(3px);
  width: fit-content;
}
.tw-contact-lane__tel{
  display:flex; align-items:center; gap:8px;
  color:#fff; text-decoration:none; font-weight:700;
  letter-spacing:.02em;
}
.tw-contact-lane__icon{ flex:0 0 auto; opacity:.95; }
.tw-contact-lane__number{
  font-size: clamp(16px, 1.8vw, 20px);
}
.tw-contact-lane__meta{
  color:#e6efff; opacity:.9;
  font-size: clamp(12px, 1.2vw, 14px);
}

/* スマホ時は1カラム＆背景切替（すでに導入済みのメディアクエリに追記OK） */
@media (max-width: 767.98px){
  .tw-hero__grid{ grid-template-columns: 1fr; }
  .tw-hero__right{ order: 3; }           /* 右リードを下に */
  .tw-contact-lane{ order: 2; }          /* 電話帯はボタンの直後に続く */
  .hero-bg{
    background-position: 50% 20%;
    padding-top: 2px;                   /* モバイルでもやや上に */
  }
}

/* =========================
   Hero: モバイル余白さらに圧縮 & ボタン横並び
   ========================= */
   @media (max-width: 767.98px){

    /* 上下余白をさらに圧縮 */
    .hero-bg{
      padding-top: 20px;       /* かなり詰める */
      padding-bottom: 36px;    /* 下も詰める */
      min-height: auto;        /* 高さ指定解除で内容に合わせる */
      background-position: 50% 18%; /* 背景人物位置を上に */
    }
  
    /* タイトルとサブタイトルの余白も最小限に */
    .tw-hero__title{
      margin: 0 0 2px;
      line-height: 1.2;
      font-size: clamp(22px, 6.8vw, 28px);
    }
    .tw-hero__subtitle{
      margin-top: 0;
      font-size: clamp(12px, 3.6vw, 15px);
    }
  
    /* ボタン横並び化 */
    .tw-hero__actions{
      flex-direction: row;    /* 横並び */
      flex-wrap: nowrap;      /* 改行なし */
      gap: 6px;               /* 間隔を少し詰める */
      margin-top: 8px;
    }
    .tw-hero__actions .tw-btn{
      flex: 1 1 auto;         /* 横幅均等配分 */
      font-size: clamp(12px, 3.4vw, 14px); /* 小さめ文字 */
      padding: 8px 6px;       /* 高さもコンパクトに */
      white-space: nowrap;    /* 折り返さない */
    }
  
    /* 電話帯も少し近づける */
    .tw-contact-lane{
      margin-top: 8px;
    }
  }

  @media (max-width: 767.98px){

    /* 上余白の圧縮 */
    .tw-hero__inner {
      padding: 20px 16px; /* 上下パディング大幅削減 */
      grid-template-columns: 1fr; /* 1カラム表示 */
      gap: 16px; /* 間隔も少し詰める */
    }
  
    /* 電話番号の改行防止 */
    .tw-contact-lane a,
    .tw-contact-lane span {
      white-space: nowrap; /* 改行させない */
    }
  
    /* 電話番号フォントサイズ調整（スマホでの3行防止） */
    .tw-contact-lane {
      font-size: clamp(14px, 4.5vw, 16px);
    }
  }
  
/* =========================
   モバイル: 余白圧縮 + 横はみ出し防止 + ボタン横並び
   ========================= */
   @media (max-width: 767.98px){

    /* 1) ヒーローの上部余白を強制的に小さくする */
    .hero-bg{
      padding-top: 14px !important;   /* ← 上余白をギリまで圧縮 */
      padding-bottom: 28px !important;
      background-position: 50% 16%;
    }
  
    /* 2) .tw-hero__inner の56pxパディングを上書き */
    .tw-hero__inner{
      padding: 12px 16px !important;  /* ← 56px → 12px に */
      grid-template-columns: 1fr;
      gap: 12px;
      box-sizing: border-box;
      width: 100%;
    }
    .tw-hero__left,
    .tw-hero__right{ min-width: 0; }   /* フレックス収縮時に溢れないように */
  
    /* 3) 見出しのサイズと余白も詰める */
    .tw-hero__title{
      margin: 0 0 2px;
      line-height: 1.18;
      font-size: clamp(22px, 6.6vw, 28px);
    }
    .tw-hero__subtitle{
      margin-top: 0;
      font-size: clamp(12px, 3.6vw, 15px);
    }
  
    /* 4) ボタンを横並び（はみ出し防止） */
    .tw-hero__actions{
      display: flex;
      flex-direction: row;
      flex-wrap: nowrap;          /* 横並び維持 */
      gap: 6px;
      margin-top: 8px;
      width: 100%;
      box-sizing: border-box;
    }
    .tw-hero__actions .tw-btn{
      flex: 1 1 0;               /* 均等配分で縮む */
      min-width: 0;              /* 収縮を許可 */
      margin: 0;                 /* 余計なマージンを消す */
      white-space: nowrap;       /* 1行に収める */
      font-size: clamp(12px, 3.4vw, 14px);
      padding: 9px 8px;          /* コンパクトに */
    }
  
    /* 5) 電話帯の横はみ出し防止（幅と改行制御） */
    .tw-contact-lane{
      width: 100%;
      max-width: 100%;
      box-sizing: border-box;
      margin-top: 8px;
      padding: 10px 12px;
      border-radius: 12px;
      overflow: hidden;          /* 角丸内に収める */
    }
    .tw-contact-lane__tel{ min-width: 0; }
    .tw-contact-lane__tel,
    .tw-contact-lane__number,
    .tw-contact-lane__meta{
      white-space: nowrap;       /* 改行させない（番号が3行になるのを防止） */
      overflow: hidden;
      text-overflow: ellipsis;   /* 万一はみ出す場合は…で省略 */
    }
  
    /* 念のため、ページ全体の横スクロールも封じる */
    html, body{ overflow-x: hidden; }
  }
  

  /* ハンバーガーメニューの背景オーバーレイ */
.menu-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,0.4); /* 背景グレー */
  z-index: 998; /* メニュー本体より1つ下 */
  opacity: 0;
  pointer-events: none; /* ← 初期状態ではクリック無効 */
  transition: opacity 0.3s ease;
}

/* メニュー開いた時 */
.menu-overlay.is-active {
  opacity: 1;
  pointer-events: auto; /* ← 開いている時だけクリック可能に */
}

/* ナビゲーション本体 */
.mobile-nav {
  position: fixed;
  top: 0;
  right: -100%;
  width: 80%;
  height: 100%;
  background: #fff;
  z-index: 999;
  transition: right 0.3s ease;
  overflow-y: auto;
}

/* メニュー開いた時に右からスライドイン */
.mobile-nav.is-active {
  right: 0;
}
