/*
Theme Name: Densha de Tabi (電車で旅する)
Theme URI: https://st-direct.jp/
Author: 電車で旅する
Description: 元HTMLに忠実な2カラム（右サイドバー）ニュース×コーポレートのハイブリッドテーマ。差し色 #348de1。Yoast / Contact Form 7 / カスタムロゴ対応。
Version: 1.1.0
*/

/* ==============================================================
   0) Reset / Base
   ============================================================== */
* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  color: #1a1a1a;
  background: #fff;
  font: 16px/1.75 system-ui,-apple-system,"Segoe UI",Roboto,"Helvetica Neue",
        "Hiragino Kaku Gothic ProN","Noto Sans JP","Yu Gothic",Meiryo,sans-serif;
  text-rendering: optimizeLegibility;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}
img, svg, video, canvas { display:block; max-width:100%; height:auto; }
a { color: inherit; text-decoration: none; }
a:focus-visible, button:focus-visible, [tabindex]:focus-visible {
  outline: 2px solid #348de1; outline-offset: 2px; border-radius: 6px;
}

/* ==============================================================
   1) Design Tokens
   ============================================================== */
:root{
  --accent: #348de1;            /* 差し色 */
  --accent-ink: #0e3f6e;        /* 濃いアクセント */
  --ink: #1a1a1a;               /* 本文 */
  --sub: #666;                  /* 補助 */
  --line: #e7e7e7;              /* 罫線 */
  --bg: #f7f7f7;                /* 淡背景 */
  --card: #ffffff;              /* カード白 */
  --radius: 16px;
  --radius-lg: 20px;
  --shadow: 0 6px 20px rgba(0,0,0,.06);
  --container: 1200px;
}

/* ==============================================================
   2) Layout: container / grid
   ============================================================== */
.container{ max-width: var(--container); margin: 0 auto; padding: 0 20px; }
.main{ padding: 28px 0 60px; }
.grid{ display: grid; grid-template-columns: 2fr 1fr; gap: 32px; }
.content{ min-width: 0; }

/* ==============================================================
   3) Header（元HTMLの .header 構造）
   ============================================================== */
.header{
  border-bottom: 1px solid var(--line);
  background: #fff; position: sticky; top: 0; z-index: 50;
  backdrop-filter: saturate(180%) blur(8px);
}
.header__inner{ display:flex; align-items:center; gap:24px; padding:14px 0; }
.brand{ display:flex; align-items:center; gap:14px; color:var(--ink); }
.brand__title{ font-weight:700; letter-spacing:.02em; }
.brand__tag{ font-size:.85rem; color: var(--sub); }

/* カスタムロゴ（600px登録 → 300pxで表示） */
.site-logo img,
.custom-logo{ width:300px; height:auto; display:block; }

/* Nav */
.nav{ margin-left:auto; }
.nav ul{ display:flex; gap:20px; list-style:none; padding:0; margin:0; }
.nav a{
  color: var(--ink); padding: 8px 10px; border-radius: 10px;
}
.nav a:hover{ background: var(--bg); }

/* ==============================================================
   4) Hero
   ============================================================== */
.hero{
  position: relative; overflow: hidden;
  background: linear-gradient(180deg, #fff 0%, #f9fbff 100%);
  border-bottom: 1px solid var(--line);
}
.hero::before{
  content:""; position:absolute; inset:auto -20% 0 -20%; height:240px;
  background: radial-gradient(1200px 120px at 50% 100%, rgba(52,141,225,.18), transparent 60%);
}
.hero__inner{ display:grid; grid-template-columns:1.15fr .85fr; gap:36px; padding:36px 0 28px; }
.hero__copy .kicker{
  display:inline-flex; align-items:center; gap:8px;
  padding:6px 12px; background:#fafcff; border:1px solid var(--line);
  border-radius:999px; font-size:.85rem;
}
.hero__copy h1{ margin:.6rem 0 .4rem; font-size:clamp(1.4rem,2.2vw,2rem); }
.hero__copy p{ margin:.6rem 0 1rem; color:var(--ink); }
.badges{ display:flex; gap:10px; flex-wrap:wrap; }
.badge{
  font-size:.78rem; padding:5px 10px; border:1px dashed var(--accent);
  border-radius:999px; background: #e9f3ff;
}
.hero__media{ display:grid; place-items:center; }
.hero__media img{
  width:100%; height:auto; border-radius: var(--radius-lg);
  border:1px solid var(--line); box-shadow: var(--shadow);
}

/* ==============================================================
   5) Sections（共通）
   ============================================================== */
.section{
  background: var(--card); border: 1px solid var(--line);
  border-radius: var(--radius-lg); padding: 26px; box-shadow: var(--shadow);
}
.section + .section{ margin-top: 28px; }
.section__head{ display:flex; align-items:center; justify-content:space-between; gap:16px; margin-bottom:14px; }
.section__title{ font-size:1.25rem; margin:0; }
.section__lead{ color: var(--sub); margin:0 0 14px; }

/* バリエーション */
.section--intro{
  background: linear-gradient(180deg, #fff 0%, #f7fbff 100%);
}
.section--intro .section__head{ border-bottom:1px solid var(--line); padding-bottom:6px; }

.section--recommend{ background: var(--bg); border-style: dashed; }

/* ==============================================================
   6) Cards / Posts（一覧カード & 記事カード）
   ============================================================== */
.cards{ display:grid; grid-template-columns: repeat(3, 1fr); gap:16px; margin-top:14px; }
.card{
  background:#fff; border:1px solid var(--line); border-radius:14px; padding:16px;
  transition: transform .12s ease, box-shadow .12s ease;
}
.card:hover{ transform: translateY(-2px); box-shadow: 0 8px 24px rgba(0,0,0,.08); }
.card__media img{
  width:72px; height:72px; border-radius:12px; border:1px solid var(--line); background:#fff;
}
.card__title{ font-weight:700; margin:10px 0 4px; }
.card p{ margin:0; color: var(--sub); }

/* ニュース一覧（トップ＆アーカイブで共通） */
.section--news .list{
  display:grid; grid-template-columns: repeat(3,1fr); gap:16px; margin-top:14px;
}
.post{
  background:#fff; border:1px solid var(--line); border-radius:14px; overflow:hidden;
  display:flex; flex-direction:column; transition: transform .12s ease, box-shadow .12s ease;
}
.post:hover{ transform: translateY(-1px); box-shadow: 0 6px 18px rgba(0,0,0,.06); }
.post__thumb img{ width:100%; height:auto; display:block; }
.post__body{ padding:12px; }
.post__meta{
  display:flex; align-items:center; gap:10px; font-size:.85rem; color: var(--sub); margin-bottom:4px;
}
.cat{
  display:inline-flex; align-items:center; padding:2px 8px;
  background:#e9f3ff; border:1px solid var(--accent); color:#0d4574;
  border-radius:999px;
}
.post__title{ margin:0; }
.post__title a{ color: var(--ink); }
.post__title a:hover{ background: linear-gradient(transparent 60%, rgba(52,141,225,.25) 0); }
.more{
  display:inline-block; margin-top:10px; color: var(--accent-ink);
  border-bottom:2px solid var(--accent);
}

/* ==============================================================
   7) Profile / Contact（元HTMLセクション）
   ============================================================== */
.section--profile{ background:#fff; border:1px solid var(--line); }
.profile{ display:grid; grid-template-columns: 1fr 1.6fr; gap:20px; align-items:center; }
.profile__media img{ width:100%; height:auto; border-radius: var(--radius); border:1px solid var(--line); }
.profile__name{ font-size:1.15rem; font-weight:700; margin:.2rem 0 .4rem; }
.profile__role{ font-size:.9rem; color: var(--sub); margin:0 0 .6rem; }

.section--contact{
  background:
    radial-gradient(600px 100px at 10% 0%, rgba(52,141,225,.12), transparent 60%),
    radial-gradient(600px 100px at 90% 0%, rgba(52,141,225,.12), transparent 60%),
    #fff;
  border:1px solid var(--line);
}
.form{ display:grid; grid-template-columns:1fr 1fr; gap:14px; margin-top:14px; }
.form__row{ display:flex; flex-direction:column; gap:6px; }
.form__row--full{ grid-column: 1 / -1; }
label{ font-weight:600; }
input[type="text"], input[type="email"], textarea{
  border:1px solid var(--line); border-radius:10px; padding:10px; font:inherit; background:#fff;
}
textarea{ min-height:140px; resize: vertical; }
button[type="submit"]{
  appearance:none; border:none; padding:12px 16px; border-radius:999px;
  background: var(--accent); color:#fff; font-weight:700; cursor:pointer;
  transition: filter .15s ease, transform .05s ease;
}
button[type="submit"]:hover{ filter: saturate(110%); }
button[type="submit"]:active{ transform: translateY(1px); }

/* Contact Form 7（統一デザイン） */
.wpcf7 form p{ margin:0 0 12px; }
.wpcf7 .wpcf7-form-control{
  width:100%; padding:10px 12px; border:1px solid var(--line); border-radius:10px; background:#fff;
}
.wpcf7 textarea{ min-height:160px; }
.wpcf7 .wpcf7-submit{
  display:inline-block; padding:12px 16px; border-radius:999px; background:var(--accent); color:#fff; border:0; cursor:pointer;
}
.wpcf7 .wpcf7-submit:hover{ filter:saturate(110%); }
.wpcf7 .wpcf7-not-valid-tip{ color:#b30000; font-size:.9rem; margin-top:6px; }
.wpcf7 .wpcf7-response-output{
  margin: 12px 0 0; border:1px solid var(--line);
  border-left:3px solid var(--accent); padding: 10px 12px; border-radius: 10px; background:#f5faff;
}

/* ==============================================================
   8) Sidebar
   ============================================================== */
.sidebar .widget{
  background:#fff; border:1px solid var(--line); border-radius:14px; padding:16px; box-shadow: var(--shadow);
}
.sidebar .widget + .widget{ margin-top:16px; }
.widget h3{ margin:0 0 10px; font-size:1.05rem; }
.widget ul{ list-style:none; margin:0; padding:0; display:grid; gap:8px; }
.widget a{ color: var(--ink); }
.widget a:hover{ color:#000; background: linear-gradient(transparent 60%, rgba(52,141,225,.25) 0); }

/* 検索フォーム（サイドバー/404内） */
.widget_search input[type="search"],
.search-form input[type="search"]{
  width:100%; padding:10px 12px; border:1px solid var(--line); border-radius:10px; background:#fff;
}

/* ==============================================================
   9) Footer（フッターメニュー化）
   ============================================================== */
.footer{ margin-top:40px; border-top:1px solid var(--line); background:#111; color:#ccc; }
.footer__inner{
  display:grid; grid-template-columns: 1fr auto; gap:16px; align-items:center; padding:16px 0;
}
.footer a{ color:#ddd; }
.footer a:hover{ color:#fff; text-decoration: underline; }
.footnav ul{ display:flex; gap:16px; list-style:none; margin:0; padding:0; }

/* ==============================================================
   10) Utilities
   ============================================================== */
.kbd{
  font:600 .85rem/1.2 ui-monospace,SFMono-Regular,Menlo,monospace;
  background:#f4f6f9; border:1px solid var(--line); border-bottom-width:2px; border-radius:6px; padding:2px 6px;
}
.note{ font-size:.92rem; color: var(--sub); }
.hr{ height:1px; background: var(--line); border:0; margin:16px 0; }

/* ==============================================================
   11) Template-specific Enhancements
   ============================================================== */
/* Yoast パンくず */
#breadcrumbs{ color: var(--sub); font-size:.95rem; }
#breadcrumbs a{ color:#3a3a3a; }
#breadcrumbs a:hover{ color: var(--accent-ink); text-decoration: underline; }

/* Single */
.single .section .entry-content img{ max-width:100%; height:auto; border-radius:12px; border:1px solid var(--line); }
.single .post-nav{
  display:flex; gap:12px; justify-content:space-between; margin-top:18px;
}
.single .post-nav a{
  color: var(--accent-ink);
  border-bottom:2px solid var(--accent);
  padding: 6px 2px;
}

/* 関連記事（single内） */
.related .list{ display:grid; grid-template-columns: repeat(3,1fr); gap:16px; }

/* Archive */
.pagination{ margin-top: 18px; }
.pagination .page-numbers{
  display:inline-block; padding:8px 12px; margin-right:6px;
  border:1px solid var(--line); border-radius:10px; color:#1a1a1a;
}
.pagination .page-numbers:hover{ background:#f4f9ff; }
.pagination .current{ border-color: var(--accent); font-weight:700; }

/* 404 */
.error-404 .widget{ background:#fff; }

/* Gutenberg / WP標準 */
.wp-caption{ max-width: 100%; }
.wp-caption-text{ color:#777; font-size:.9rem; margin-top:4px; }
.alignleft{ float:left; margin:0 1em 1em 0; }
.alignright{ float:right; margin:0 0 1em 1em; }
.aligncenter{ display:block; margin-left:auto; margin-right:auto; }

/* ==============================================================
   12) WordPress Bridge（WPの出力クラスと元HTMLを接続）
   ============================================================== */
/* ヘッダー（.site-header を .header 見た目に） */
.site-header{
  border-bottom:1px solid var(--line);
  background:#fff; position:sticky; top:0; z-index:50;
  backdrop-filter:saturate(180%) blur(8px);
}
.header-inner{ max-width: var(--container); margin:0 auto; padding:14px 20px; display:flex; align-items:center; gap:24px; }
.site-branding a{ color:var(--ink); }
.site-description{ font-size:.85rem; color:var(--sub); margin:0; }
/* ナビ（.primary-nav -> .nav） */
.primary-nav .menu{ display:flex; gap:20px; list-style:none; margin:0; padding:0; }
.primary-nav .menu a{ color:var(--ink); padding:8px 10px; border-radius:10px; }
.primary-nav .menu a:hover{ background: var(--bg); }

/* メイン2カラム（header.phpで開く #content > .content-inner を .grid相当に） */
#content{ max-width: var(--container); margin:0 auto; padding: 0 20px; }
.content-inner{ display:grid; grid-template-columns: 2fr 1fr; gap:32px; }

/* サイドバーのウィジェット共通 */
#secondary .widget{ background:#fff; border:1px solid var(--line); border-radius:14px; padding:16px; box-shadow: var(--shadow); }
#secondary .widget + .widget{ margin-top:16px; }

/* フッター（.site-footer -> .footer 見た目に） */
.site-footer{ margin-top:40px; border-top:1px solid var(--line); background:#111; color:#ccc; }
.footer-inner{ max-width: var(--container); margin:0 auto; padding:16px 20px; display:grid; grid-template-columns:1fr auto; gap:16px; align-items:center; }
.footer-menu{ list-style:none; margin:0; padding:0; display:flex; gap:16px; }
.footer-menu a{ color:#ddd; }
.footer-menu a:hover{ color:#fff; text-decoration: underline; }

/* ==============================================================
   13) Responsive
   ============================================================== */
@media (max-width: 1024px){
  .hero__inner{ grid-template-columns: 1.1fr .9fr; }
  .section--news .list{ grid-template-columns: repeat(2,1fr); }
}
@media (max-width: 840px){
  .nav{ display:none; }                /* 元HTML準拠：SPでヘッダーナビ非表示（必要なら後でドロワー化） */
  .hero__inner{ grid-template-columns: 1fr; }
  .grid, .content-inner{ grid-template-columns: 1fr; }
  .cards{ grid-template-columns: 1fr 1fr; }
  .profile{ grid-template-columns: 1fr; }
  .form{ grid-template-columns: 1fr; }
  .related .list{ grid-template-columns: 1fr 1fr; }
}
@media (max-width: 480px){
  .cards{ grid-template-columns: 1fr; }
  .section{ padding: 20px; }
  .section--news .list{ grid-template-columns: 1fr; }
  .related .list{ grid-template-columns: 1fr; }
}

/* ==============================================================
   14) Print (軽量化)
   ============================================================== */
@media print{
  .header, .nav, .sidebar, .footer { display:none !important; }
  .container{ max-width:none; padding:0; }
  a{ text-decoration: underline; }
}
