/*
Theme Name: Shikoku Yumetabi Bus
Theme URI: https://yumetabisikoku.jp/
Description: 四国夢旅バス 公式サイト専用テーマ（1ページLP＋Contact Form 7 お問い合わせフォーム）。
Author: 四国夢旅バス
Version: 1.0.0
*/

:root{
  --navy:#0a3b7c; --navy-deep:#062a5c; --navy-ink:#0b1f3a;
  --accent:#f4a12a; --accent-deep:#e08a10;
  --bg:#f6f9fd; --card:#ffffff; --line:#e3ebf5;
  --text:#1b2635; --muted:#5a6b82;
  --maxw:1080px; --radius:16px;
  --shadow:0 6px 24px rgba(10,59,124,.08);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:"Hiragino Kaku Gothic ProN","Hiragino Sans","Noto Sans JP","Yu Gothic",Meiryo,sans-serif;
  color:var(--text); background:var(--bg); line-height:1.9;
  -webkit-font-smoothing:antialiased; letter-spacing:.01em;
}
a{color:inherit;text-decoration:none}
img,svg{max-width:100%;display:block}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 22px}

/* ---------- Header ---------- */
header.site{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.92);backdrop-filter:blur(8px);border-bottom:1px solid var(--line)}
.site .bar{display:flex;align-items:center;justify-content:space-between;height:66px}
.brand{display:flex;align-items:center;gap:11px;font-weight:800;color:var(--navy);font-size:20px;letter-spacing:.02em}
.brand .mark{width:40px;height:40px;flex:none}
.brand small{display:block;font-size:10.5px;font-weight:600;color:var(--muted);letter-spacing:.14em}
.nav-cta{display:inline-flex;align-items:center;gap:7px;background:var(--accent);color:#3a2600;font-weight:800;padding:11px 20px;border-radius:999px;font-size:14px;box-shadow:0 6px 16px rgba(244,161,42,.35);transition:.2s}
.nav-cta:hover{transform:translateY(-1px);background:var(--accent-deep);color:#fff}

/* ---------- Hero ---------- */
.hero{position:relative;overflow:hidden;color:#fff;
  background:
    linear-gradient(165deg, rgba(6,42,92,.82) 0%, rgba(10,31,58,.86) 60%, rgba(11,31,58,.92) 100%),
    url("hero.jpg") center 58%/cover no-repeat;
}
.hero::after{content:"";position:absolute;left:0;right:0;bottom:-1px;height:70px;background:var(--bg);clip-path:polygon(0 100%,100% 100%,100% 30%,0 100%)}
.hero .wrap{position:relative;z-index:2;padding:96px 22px 110px;text-align:center}
.hero h1{font-size:clamp(30px,6vw,56px);font-weight:900;line-height:1.28;letter-spacing:.02em;text-shadow:0 2px 24px rgba(0,0,0,.35)}
.hero h1 .big{color:var(--accent);white-space:nowrap}
.hero .lead{font-size:clamp(18px,2.8vw,24px);margin-top:22px;font-weight:700;color:#fff;text-shadow:0 2px 16px rgba(0,0,0,.35)}
.hero .sub{margin-top:14px;font-size:clamp(14px,2vw,17px);color:#e7eefb;font-weight:500;text-shadow:0 1px 10px rgba(0,0,0,.35)}
.hero .btns{margin-top:36px;display:flex;gap:14px;justify-content:center;flex-wrap:wrap}
.btn{display:inline-flex;align-items:center;gap:8px;font-weight:800;font-size:15px;padding:15px 30px;border-radius:999px;transition:.2s}
.btn-primary{background:var(--accent);color:#3a2600;box-shadow:0 10px 24px rgba(244,161,42,.4)}
.btn-primary:hover{transform:translateY(-2px);background:#fff;color:var(--navy)}
.btn-ghost{background:rgba(255,255,255,.14);color:#fff;border:1.5px solid rgba(255,255,255,.6)}
.btn-ghost:hover{background:#fff;color:var(--navy)}

/* ---------- Sections ---------- */
section.block{padding:66px 0}
.eyebrow{color:var(--accent-deep);font-weight:800;letter-spacing:.16em;font-size:13px;text-align:center}
h2.sec{text-align:center;font-size:clamp(24px,4.4vw,34px);font-weight:900;color:var(--navy);margin:8px 0 10px;letter-spacing:.02em}
h2.sec::after{content:"";display:block;width:56px;height:4px;border-radius:4px;background:var(--accent);margin:16px auto 0}
.sec-lead{text-align:center;color:var(--muted);max-width:760px;margin:22px auto 0;font-size:16px}

.intro-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:40px}
.pill-card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:26px 22px;text-align:center;box-shadow:var(--shadow)}
.pill-card .ic{font-size:30px}
.pill-card h3{color:var(--navy);font-size:17px;margin:12px 0 6px;font-weight:800}
.pill-card p{color:var(--muted);font-size:14px;line-height:1.8}

/* ---------- サービス内容（1カラム） ---------- */
.mech{background:linear-gradient(180deg,#fff,#eef4fc)}
.services{display:flex;flex-direction:column;gap:22px;margin-top:42px;max-width:900px;margin-left:auto;margin-right:auto}
.svc{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:30px 30px;box-shadow:var(--shadow);border-left:5px solid var(--accent)}
.svc h3{color:var(--navy);font-size:21px;font-weight:900;margin:0 0 12px}
.svc h4{color:var(--accent-deep);font-size:15px;font-weight:800;margin:16px 0 6px}
.svc p{color:var(--text);font-size:15px;margin:6px 0}
.svc ul{list-style:none;margin:8px 0}
.svc li{position:relative;padding-left:20px;color:var(--text);font-size:15px;margin:5px 0}
.svc li::before{content:"";position:absolute;left:2px;top:12px;width:7px;height:7px;border-radius:50%;background:var(--accent)}
.formula{background:#f1f6fd;border:1px dashed var(--navy);border-radius:12px;padding:16px 18px;font-weight:800;color:var(--navy);text-align:center;margin:14px 0;font-size:15px;line-height:1.7}
.cols2{display:grid;grid-template-columns:1fr 1fr;gap:8px 28px}
.flow{counter-reset:flow;list-style:none;margin-top:8px}
.flow li{position:relative;padding:8px 8px 8px 44px;margin:8px 0;background:#f6f9fd;border-radius:10px;font-size:15px;font-weight:600;color:var(--navy-ink)}
.flow li::before{counter-increment:flow;content:counter(flow);position:absolute;left:8px;top:50%;transform:translateY(-50%);width:26px;height:26px;border-radius:50%;background:var(--accent);color:#fff;font-weight:800;display:grid;place-items:center;font-size:13px}

/* ---------- 想い / news ---------- */
.feature{background:var(--navy);color:#fff}
.feature h2.sec{color:#fff}.feature h2.sec::after{background:var(--accent)}.feature .eyebrow{color:var(--accent)}
.prose{max-width:820px;margin:34px auto 0;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.14);border-radius:var(--radius);padding:34px}
.prose p{margin:0 0 14px;font-size:16px;line-height:2;color:#eaf1fb}.prose p:last-child{margin-bottom:0}
.sign{margin-top:22px;text-align:right;color:#c6d6ee;font-size:14px}.sign b{color:#fff;font-size:18px;letter-spacing:.04em}
.news .prose{background:#fff;border:1px solid var(--line);box-shadow:var(--shadow)}.news .prose p{color:var(--text)}

/* ---------- 会社概要 ---------- */
.company{background:linear-gradient(180deg,#eef4fc,#fff)}
.table{max-width:820px;margin:40px auto 0;background:var(--card);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow)}
.table dl{display:grid;grid-template-columns:200px 1fr}
.table dt{background:#f3f7fd;color:var(--navy);font-weight:800;padding:16px 22px;border-bottom:1px solid var(--line);font-size:14.5px}
.table dd{padding:16px 22px;border-bottom:1px solid var(--line);font-size:15px;color:var(--text)}
.table dl:last-of-type dt,.table dl:last-of-type dd{border-bottom:none}
.table ul{margin:0;padding-left:1.1em}.table li{margin:3px 0;font-size:14.5px}
.table a{color:var(--navy);font-weight:700;text-decoration:underline;text-underline-offset:3px}
.table .snsrow a{margin-right:14px;white-space:nowrap}

/* ---------- Contact / footer ---------- */
.contact{background:var(--navy-deep);color:#fff;text-align:center;padding:64px 0}
.contact h2{font-size:clamp(22px,4vw,30px);font-weight:900;letter-spacing:.03em}
.contact p{color:#c6d6ee;margin-top:12px}
.contact .cbtns{margin-top:22px;display:flex;gap:14px;justify-content:center;flex-wrap:wrap}
.contact .or{margin-top:34px;color:#c6d6ee;font-size:14px;font-weight:600}
.contact .line-note{max-width:720px;margin:24px auto 0;background:rgba(6,199,85,.10);border:1px solid rgba(6,199,85,.4);border-radius:14px;padding:20px 24px;display:flex;align-items:center;justify-content:center;gap:18px;flex-wrap:wrap}
.contact .line-note__text{margin:0;color:#eaf1fb;font-size:15.5px;font-weight:700}
@media(max-width:600px){.contact .line-note{flex-direction:column;gap:14px}}
.btn-line{background:#06c755;color:#fff;box-shadow:0 10px 24px rgba(6,199,85,.35)}
.btn-line:hover{transform:translateY(-2px);filter:brightness(1.06)}
.sns{margin-top:28px;display:flex;gap:14px;justify-content:center;flex-wrap:wrap}
.sns a{width:46px;height:46px;border-radius:50%;background:rgba(255,255,255,.12);display:grid;place-items:center;color:#fff;transition:.2s;border:1px solid rgba(255,255,255,.25)}
.sns a svg{width:22px;height:22px;fill:currentColor}
.sns a:hover{background:var(--accent);color:#3a2600;transform:translateY(-2px)}
footer.foot{background:var(--navy-ink);color:#9fb4d4;text-align:center;padding:24px;font-size:13px}
footer.foot .brand2{color:#fff;font-weight:800;font-size:15px;margin-bottom:4px}

/* ---------- Contact Form 7 ---------- */
.yts-formcard{max-width:720px;margin:30px auto 0;background:#fff;border-radius:18px;padding:36px 32px;
  box-shadow:0 24px 60px -22px rgba(0,0,0,.45);text-align:left}
.yts-form-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px 20px}
.yts-f{display:flex;flex-direction:column;gap:7px;margin:0}
.yts-f.yts-full{grid-column:1 / -1}
.yts-f label{font-size:13.5px;font-weight:800;color:var(--navy);letter-spacing:.02em}
.yts-f .req{display:inline-block;background:var(--accent);color:#3a2600;font-size:10px;font-weight:800;
  padding:2px 8px;border-radius:999px;margin-left:6px;vertical-align:middle;letter-spacing:.04em}
.yts-formcard input:not([type=submit]),.yts-formcard select,.yts-formcard textarea{
  width:100%;padding:12px 14px;border:1.5px solid var(--line);border-radius:10px;font-size:15px;
  font-family:inherit;color:var(--text);background:#fbfcfe;transition:.15s;line-height:1.6}
.yts-formcard input:focus,.yts-formcard select:focus,.yts-formcard textarea:focus{
  outline:none;border-color:var(--accent);background:#fff;box-shadow:0 0 0 3px rgba(244,161,42,.15)}
.yts-formcard textarea{min-height:120px;resize:vertical}
.yts-submit{text-align:center;margin:24px 0 0}
.yts-formcard input[type=submit]{
  width:auto;background:var(--accent);color:#3a2600;font-weight:800;font-size:16px;border:none;
  padding:15px 56px;border-radius:999px;cursor:pointer;box-shadow:0 10px 24px rgba(244,161,42,.4);transition:.2s}
.yts-formcard input[type=submit]:hover{transform:translateY(-2px);background:var(--accent-deep);color:#fff}
.yts-formcard .wpcf7-spinner{margin:0 auto;display:block}
.yts-formcard .wpcf7-not-valid-tip{color:#d33;font-size:12.5px;font-weight:700;margin-top:5px}
.yts-formcard .wpcf7-response-output{border-radius:10px;padding:13px 16px !important;font-size:14px;
  margin:20px 0 0 !important;text-align:center;color:#1b2635}

/* ---------- 3ステップ（入力→確認→完了） ---------- */
.yts-formcard[data-step="input"] .yts-review,
.yts-formcard[data-step="input"] .yts-actions--confirm{display:none}
.yts-formcard[data-step="confirm"] .yts-form-grid,
.yts-formcard[data-step="confirm"] .yts-actions--input{display:none}
.yts-actions{margin-top:24px;display:flex;gap:14px;justify-content:center;flex-wrap:wrap}
.yts-actions input[type=submit],.yts-actions .btn{cursor:pointer}
.yts-btn-edit{background:#fff;color:var(--navy);border:1.5px solid var(--line);box-shadow:none}
.yts-btn-edit:hover{background:#f3f7fd;color:var(--navy);transform:translateY(-2px)}
.yts-inline-warn{color:#d33;font-weight:700;font-size:14px;text-align:center;margin:18px 0 -4px;
  background:rgba(211,51,51,.06);border:1px solid rgba(211,51,51,.3);border-radius:10px;padding:12px 16px}
.yts-inline-warn:empty{display:none}
.yts-formcard[data-step="confirm"] .yts-inline-warn,
.yts-formcard[data-step="done"] .yts-inline-warn{display:none}
.yts-review{margin-top:2px}
.yts-review__note{background:#f1f6fd;border:1px dashed var(--navy);border-radius:12px;padding:14px 18px;color:var(--navy);font-weight:700;font-size:14px;text-align:center;margin-bottom:20px;line-height:1.7}
.yts-review__row{display:grid;grid-template-columns:150px 1fr;gap:6px 18px;padding:14px 6px;border-bottom:1px solid var(--line);align-items:start}
.yts-review__row:first-of-type{border-top:1px solid var(--line)}
.yts-review__k{font-weight:800;color:var(--navy);font-size:13.5px;letter-spacing:.02em}
.yts-review__v{color:var(--text);font-size:15.5px;word-break:break-word;line-height:1.8}
.yts-review__empty{color:var(--muted)}
/* 完了画面 */
.yts-done{text-align:center;padding:22px 8px}
.yts-done__badge{width:66px;height:66px;border-radius:50%;background:#06c755;color:#fff;font-size:34px;font-weight:800;display:grid;place-items:center;margin:0 auto 20px;box-shadow:0 12px 26px -8px rgba(6,199,85,.5)}
.yts-done__title{color:var(--navy);font-size:23px;font-weight:900;margin-bottom:14px;letter-spacing:.02em}
.yts-formcard .yts-done__text{color:var(--text);font-size:15px;line-height:2}
.yts-formcard .yts-done__text strong{color:var(--accent-deep);font-weight:800}

@media(max-width:820px){
  .intro-grid{grid-template-columns:1fr}
  .cols2{grid-template-columns:1fr}
  .table dl{grid-template-columns:1fr}
  .table dt{border-bottom:none;padding-bottom:4px}
  .brand small{display:none}
  .hero .wrap{padding:74px 22px 96px}
  .yts-form-grid{grid-template-columns:1fr}
  .yts-formcard{padding:26px 20px}
}
