/*
Theme Name: Miyama Accounting
Theme URI: https://miyama-kaikei.com/
Author: Miyama Accounting
Description: Custom WordPress theme for Miyama Accounting Office in Nagoya. Navy x fresh-green, right-rail navigation.
Version: 2.0.0
Requires at least: 6.0
Tested up to: 6.9
Requires PHP: 8.0
License: GPL v2 or later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: miyama-accounting
*/

/* =========================================================
   Tokens
   ========================================================= */
:root {
  --navy: #1656a4;         /* bright royal blue — backgrounds & headings */
  --navy-deep: #11428a;    /* deep royal — gradient bottoms / footer */
  --navy-2: #2f7fda;       /* sky blue — gradient tops / hover */
  --navy-ink: #0f3168;     /* dark ink for strong text */
  --blue-bright: #4a9bee;  /* bright accent (facets/highlights) */
  --green: #2fa84f;        /* 新緑（アクセント） */
  --green-2: #46bb63;
  --green-deep: #1f8c40;
  --green-soft: #e8f6ec;
  --forest: #1c6b3e;       /* コーポレート深緑（メイン） */
  --forest-top: #2a8e54;   /* 深緑グラデ上 */
  --forest-deep: #0e4527;  /* 深緑グラデ下 */
  --green-pale: #e8f5ec;   /* 薄緑（PROMISE等の明るい背景） */
  --blue-soft: #7fc1ff;    /* 深緑上で映える明るい青アクセント */
  --lav: #eef4fc;          /* light blue-tinted band */
  --lav-2: #dde9f8;
  --paper: #ffffff;
  --ink: #1b2a45;
  --muted: #5f6f8e;
  --line: rgba(22, 86, 164, 0.15);
  --line-strong: rgba(22, 86, 164, 0.28);
  --rail: 230px;
  --shadow: 0 26px 60px rgba(22, 86, 164, 0.18);
  --shadow-sm: 0 10px 26px rgba(22, 86, 164, 0.12);
  --sans: "Noto Sans JP", "Hiragino Kaku Gothic ProN", "Yu Gothic", "Meiryo", system-ui, sans-serif;
  --max: 1040px;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }

body {
  margin: 0;
  background: var(--paper);
  color: var(--ink);
  font-family: var(--sans);
  font-size: 16px;
  line-height: 1.85;
  font-feature-settings: "palt" 1;
  -webkit-font-smoothing: antialiased;
}

a { color: inherit; text-decoration: none; }
img { max-width: 100%; height: auto; display: block; }
h1, h2, h3, h4 { font-weight: 900; line-height: 1.3; letter-spacing: 0.01em; margin: 0; }
p { margin: 0 0 1em; }

/* =========================================================
   Shell / rail offset
   ========================================================= */
.site-shell { position: relative; }
.site-main { display: block; }

/* =========================================================
   Top header (horizontal nav)
   ========================================================= */
.site-top { position: sticky; top: 0; z-index: 60; background: rgba(255,255,255,0.96); backdrop-filter: blur(8px); border-bottom: 1px solid var(--line); }
body.admin-bar .site-top { top: 32px; }
.top-inner { width: min(100% - 40px, 1200px); margin-inline: auto; display: flex; align-items: center; justify-content: space-between; gap: 20px; min-height: 72px; }
.top-brand { display: flex; align-items: center; gap: 10px; }
.top-brand .brand-mark { flex: none; width: 32px; height: 32px; }
.top-brand .brand-name { font-size: 15px; font-weight: 900; color: var(--forest); line-height: 1.3; }
.top-brand .brand-sub { display: block; font-size: 8.5px; letter-spacing: 0.12em; color: var(--muted); font-weight: 700; margin-top: 2px; }
.top-nav { display: flex; align-items: center; gap: clamp(14px, 1.8vw, 28px); }
.top-nav > a { font-size: 14px; font-weight: 800; color: var(--forest); letter-spacing: 0.04em; transition: color .2s; }
.top-nav > a:hover { color: var(--green-deep); }
.top-nav .top-cta { background: var(--forest); color: #fff; padding: 11px 22px; border-radius: 999px; transition: background .2s; }
.top-nav .top-cta:hover { background: var(--green); color: #fff; }
.top-svc-icons { display: inline-flex; align-items: center; gap: 5px; padding-left: 10px; margin-left: 2px; border-left: 1px solid var(--line); }
.top-svc-icons .tsi { width: 30px; height: 30px; display: grid; place-items: center; border-radius: 8px; color: var(--forest); transition: background .2s, color .2s; }
.top-svc-icons .tsi svg { width: 19px; height: 19px; }
.top-svc-icons .tsi:hover { background: var(--green-soft); color: var(--green-deep); }
.nav-toggle { display: none; }

.container {
  width: min(100% - 48px, var(--max));
  margin-inline: auto;
}

/* =========================================================
   Right rail navigation (desktop)
   ========================================================= */
.site-rail {
  position: fixed;
  top: 0; right: 0; bottom: 0;
  width: var(--rail);
  background: var(--paper);
  border-left: 1px solid var(--line);
  display: flex;
  flex-direction: column;
  z-index: 60;
  overflow-y: auto;
}
body.admin-bar .site-rail { top: 32px; }

.rail-brand {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 22px 22px 18px;
  border-bottom: 1px solid var(--line);
}
.rail-brand .brand-mark {
  flex: none;
  width: 34px; height: 34px;
}
.rail-brand .brand-name {
  font-size: 16px; font-weight: 900; color: var(--navy);
  line-height: 1.35;
}
.rail-brand .brand-sub {
  display: block;
  font-size: 9px; letter-spacing: 0.14em; color: var(--muted); font-weight: 700;
  margin-top: 3px;
}

.rail-scroll { padding: 14px 0 0; flex: 1; }

.rail-link {
  display: flex; align-items: center; justify-content: space-between;
  padding: 11px 22px;
  font-size: 14px; font-weight: 800; color: var(--navy-ink);
  transition: color .2s, background .2s;
}
.rail-link::after { content: "→"; color: var(--line-strong); font-weight: 700; transition: transform .2s, color .2s; }
.rail-link:hover { color: var(--green-deep); background: var(--green-soft); }
.rail-link:hover::after { color: var(--green); transform: translateX(3px); }

.rail-heading {
  display: flex; align-items: center; gap: 7px;
  padding: 18px 22px 8px;
  font-size: 11px; letter-spacing: 0.12em; font-weight: 900; color: var(--green-deep);
}
.rail-heading::before { content: ""; width: 12px; height: 12px; background: var(--green); border-radius: 2px; }

.rail-services { list-style: none; margin: 0; padding: 0 22px 6px; }
.rail-services a {
  display: flex; align-items: center; gap: 10px;
  padding: 7px 0; font-size: 13px; font-weight: 700; color: var(--navy-ink);
}
.rail-services a .ri { width: 22px; height: 22px; color: var(--navy-2); flex: none; }
.rail-services a .ri svg { width: 22px; height: 22px; }
.rail-services a:hover { color: var(--green-deep); }
.rail-services a:hover .ri { color: var(--green); }

.rail-sns {
  display: flex; align-items: center; gap: 14px;
  padding: 12px 22px;
}
.rail-sns .rail-heading { padding: 0; }
.rail-sns a { color: var(--navy-2); }
.rail-sns a:hover { color: var(--green); }

.rail-cta {
  margin-top: auto;
  display: flex; align-items: center; justify-content: space-between;
  padding: 18px 22px;
  background: var(--navy);
  color: #fff; font-weight: 900; font-size: 15px; letter-spacing: 0.08em;
}
.rail-cta::after { content: "→"; transition: transform .2s; }
.rail-cta:hover { background: var(--green); }
.rail-cta:hover::after { transform: translateX(4px); }

/* =========================================================
   Mobile top bar + drawer
   ========================================================= */
.mobile-bar { display: none; }
.drawer { display: none; }

@media (max-width: 920px) {
  .site-rail { display: none; }
  .top-nav { display: none; }
  .top-brand .brand-sub { display: none; }
  .drawer { display: block; }
  .mobile-bar {
    position: sticky; top: 0; z-index: 60;
    display: flex; align-items: center; justify-content: space-between;
    padding: 12px 18px;
    background: rgba(255,255,255,0.92);
    backdrop-filter: blur(8px);
    border-bottom: 1px solid var(--line);
  }
  body.admin-bar .mobile-bar { top: 46px; }
  .mobile-bar .brand-name { font-size: 15px; font-weight: 900; color: var(--navy); }
  .mobile-bar .brand-mark { width: 28px; height: 28px; }
  .mobile-brand { display: flex; align-items: center; gap: 8px; }
  .nav-toggle {
    appearance: none; border: 0; background: var(--forest); color: #fff;
    width: 44px; height: 40px; border-radius: 8px; cursor: pointer;
    display: grid; place-items: center; gap: 4px;
  }
  .nav-toggle span { display: block; width: 20px; height: 2px; background: #fff; border-radius: 2px; transition: transform .25s, opacity .2s; }
  .drawer {
    position: fixed; inset: 0; z-index: 70;
    background: linear-gradient(160deg, var(--forest-top) 0%, var(--forest-deep) 85%); color: #fff;
    padding: 80px 28px 40px;
    transform: translateX(100%); transition: transform .3s ease;
    overflow-y: auto;
  }
  .drawer.is-open { transform: translateX(0); }
  .drawer a { display: block; color: #fff; font-size: 18px; font-weight: 800; padding: 13px 0; border-bottom: 1px solid rgba(255,255,255,0.12); }
  .drawer .drawer-heading { color: var(--green-2); font-size: 12px; letter-spacing: 0.12em; margin-top: 18px; font-weight: 900; }
  .drawer-close {
    position: absolute; top: 20px; right: 22px;
    appearance: none; background: none; border: 0; color: #fff; font-size: 30px; cursor: pointer; line-height: 1;
  }
  body.nav-open { overflow: hidden; }
}

/* =========================================================
   Buttons
   ========================================================= */
.btn {
  display: inline-flex; align-items: center; gap: 10px;
  padding: 15px 28px; border-radius: 999px;
  font-weight: 900; font-size: 15px; letter-spacing: 0.04em;
  transition: transform .2s, background .2s, color .2s, box-shadow .2s;
}
.btn::after { content: "→"; transition: transform .2s; }
.btn:hover::after { transform: translateX(4px); }
.btn-green { background: var(--green); color: #fff; box-shadow: 0 14px 30px rgba(47,168,79,0.3); }
.btn-green:hover { background: var(--green-deep); }
.btn-navy { background: var(--navy); color: #fff; }
.btn-navy:hover { background: var(--navy-2); }
.btn-ghost { border: 2px solid currentColor; color: #fff; }
.btn-ghost:hover { background: #fff; color: var(--navy); }
.btn-outline { border: 2px solid var(--navy); color: var(--navy); }
.btn-outline:hover { background: var(--navy); color: #fff; }

/* =========================================================
   Section system + vertical watermark + heading
   ========================================================= */
.section { position: relative; padding: clamp(64px, 9vw, 116px) 0; overflow: hidden; }
.section--navy { background: linear-gradient(155deg, #2168c6 0%, var(--navy-deep) 80%); color: #fff; }
.section--lav { background: var(--lav); }
.section--green { background: var(--green); color: #fff; }
.section--forest { background: linear-gradient(155deg, var(--forest-top) 0%, var(--forest-deep) 80%); color: #fff; }
.section--green-pale { background: var(--green-pale); }

.section[data-label]::before {
  content: attr(data-label);
  position: absolute; left: -6px; top: 40px;
  writing-mode: vertical-rl;
  font-size: clamp(58px, 11vw, 132px);
  font-weight: 900; letter-spacing: 0.04em;
  color: currentColor; opacity: 0.05;
  pointer-events: none; user-select: none;
  line-height: 1;
}

.sec-head { text-align: center; margin-bottom: clamp(34px, 5vw, 56px); }
.sec-head .en {
  display: inline-flex; align-items: center; gap: 14px;
  font-size: clamp(22px, 3vw, 30px); font-weight: 900; letter-spacing: 0.14em;
  color: var(--navy);
}
.section--navy .sec-head .en, .section--green .sec-head .en, .section--forest .sec-head .en { color: #fff; }
.sec-head .en::before, .sec-head .en::after { content: ""; width: 34px; height: 2px; background: currentColor; opacity: 0.6; }
.sec-head .ja { display: block; margin-top: 12px; font-size: 15px; font-weight: 700; color: var(--muted); }
.section--navy .sec-head .ja, .section--green .sec-head .ja, .section--forest .sec-head .ja { color: rgba(255,255,255,0.8); }

/* =========================================================
   Hero (split)
   ========================================================= */
.hero { position: relative; display: grid; grid-template-columns: 1.05fr 0.95fr; min-height: clamp(560px, 78vh, 760px); background: linear-gradient(150deg, #e9f6ee 0%, #d5ecdd 72%); color: var(--ink); overflow: hidden; }
.hero-copy { position: relative; z-index: 2; align-self: center; padding: clamp(40px, 6vw, 88px); }
.hero-eyebrow {
  display: inline-flex; align-items: center; gap: 10px;
  font-size: 12px; font-weight: 800; letter-spacing: 0.18em; color: var(--green-2); margin-bottom: 22px;
}
.hero-eyebrow::before { content: ""; width: 26px; height: 2px; background: var(--forest); }
.hero h1 {
  font-size: clamp(36px, 6.4vw, 72px); line-height: 1.16; letter-spacing: 0.01em;
  color: var(--green-deep);
}
.hero h1 .accent { color: var(--navy); }
.hero h1 .quote { position: relative; }
.hero-lead { margin: 26px 0 34px; max-width: 30em; font-size: clamp(15px, 1.5vw, 17px); color: #3a4a64; }
.hero-actions { display: flex; flex-wrap: wrap; gap: 14px; }
.hero .btn-ghost { color: var(--navy); }
.hero .btn-ghost:hover { background: var(--navy); color: #fff; }

.hero-visual { position: relative; overflow: hidden; }
.hero-visual .hero-scene { position: absolute; inset: 0; width: 100%; height: 100%; }
.hero-photo { position: absolute; inset: 0; background-size: cover; background-position: center; z-index: 0; }
.hero-visual::before { content: ""; position: absolute; inset: 0; z-index: 1; background: linear-gradient(90deg, #d5ecdd, rgba(213,236,221,0.45) 30%, rgba(213,236,221,0.05)); }
.hero-watermark {
  position: absolute; left: clamp(20px, 4vw, 64px); bottom: -8px; z-index: 3;
  writing-mode: vertical-rl;
  font-size: clamp(44px, 7vw, 96px); font-weight: 900; letter-spacing: 0.06em;
  color: rgba(28,107,62,0.12); line-height: 1; pointer-events: none;
}
.hero-tri { position: absolute; right: clamp(20px, 4vw, 56px); bottom: 30px; z-index: 3; display: flex; gap: 12px; }
.hero-tri span { width: 40px; height: 40px; border-radius: 50%; display: grid; place-items: center; background: rgba(255,255,255,0.12); color: #fff; }
.hero-tri svg { width: 22px; height: 22px; }

@media (max-width: 760px) {
  .hero { grid-template-columns: 1fr; min-height: auto; }
  .hero-visual { height: 280px; order: -1; }
  .hero-watermark { font-size: 56px; }
}

/* =========================================================
   TOPICS (green cards)
   ========================================================= */
.topics-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 22px; }
.topic-card {
  display: flex; flex-direction: column;
  background: var(--green); color: #fff; border-radius: 14px; overflow: hidden;
  box-shadow: var(--shadow-sm); transition: transform .25s, box-shadow .25s;
}
.topic-card:hover { transform: translateY(-6px); box-shadow: var(--shadow); }
.topic-card .topic-media {
  position: relative; padding: 22px 22px 18px;
  background: linear-gradient(135deg, var(--green-2), var(--green-deep));
  background-size: cover; background-position: center;
  min-height: 156px;
}
.topic-card .topic-date, .topic-card .topic-cat { position: relative; z-index: 2; }
.topic-card .topic-date {
  font-size: clamp(40px, 5vw, 56px); font-weight: 900; line-height: 1; letter-spacing: -0.01em;
  font-family: Georgia, "Times New Roman", serif; color: rgba(255,255,255,0.95);
}
.topic-card .topic-cat {
  display: inline-block; margin-top: 12px;
  background: rgba(255,255,255,0.22); border-radius: 999px;
  padding: 4px 12px; font-size: 11px; font-weight: 800; letter-spacing: 0.06em;
}
.topic-card .topic-body { padding: 18px 22px 24px; background: var(--forest); flex: 1; display: flex; flex-direction: column; }
.topic-card .topic-title { font-size: 16px; font-weight: 800; line-height: 1.55; }
.topic-card .topic-more { margin-top: auto; padding-top: 16px; font-size: 12px; font-weight: 800; letter-spacing: 0.08em; color: rgba(255,255,255,0.85); }
.topics-foot { text-align: center; margin-top: 44px; }

/* =========================================================
   INFORMATION (rows)
   ========================================================= */
.info-list { display: flex; flex-direction: column; gap: 12px; }
.info-row {
  display: grid; grid-template-columns: 200px 1fr auto; align-items: center; gap: 18px;
  background: #fff; border: 1px solid var(--line); border-radius: 12px;
  padding: 18px 22px; transition: border-color .2s, transform .2s, box-shadow .2s;
}
.info-row:hover { border-color: var(--green); transform: translateX(4px); box-shadow: var(--shadow-sm); }
.info-meta { display: flex; align-items: center; gap: 12px; }
.info-date { font-size: 13px; font-weight: 800; color: var(--navy); font-family: Georgia, serif; letter-spacing: 0.02em; }
.info-tag { background: var(--navy); color: #fff; font-size: 10px; font-weight: 800; letter-spacing: 0.06em; padding: 3px 10px; border-radius: 999px; }
.info-title { font-size: 15px; font-weight: 700; color: var(--ink); }
.info-row .chev { color: var(--line-strong); font-weight: 900; }
.info-row:hover .chev { color: var(--green); }
.info-foot { text-align: center; margin-top: 40px; }

@media (max-width: 640px) {
  .info-row { grid-template-columns: 1fr auto; }
  .info-meta { grid-column: 1 / -1; }
}

/* =========================================================
   SERVICE (navy cards)
   ========================================================= */
.svc-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; }
.svc-card {
  position: relative; display: flex; flex-direction: column;
  background: var(--forest); color: #fff; border-radius: 16px;
  padding: 0; min-height: 300px; overflow: hidden;
  transition: transform .25s, box-shadow .25s;
}
.svc-photo { position: relative; height: 146px; background-size: cover; background-position: center; }
.svc-photo::after { content: ""; position: absolute; inset: 0; background: linear-gradient(to bottom, rgba(14,69,39,0.18), var(--forest) 96%); }
.svc-card:hover { transform: translateY(-6px); box-shadow: var(--shadow); }
.svc-card:hover .svc-photo { transform: none; }
.svc-num { position: absolute; top: 14px; right: 18px; z-index: 3; font-family: Georgia, serif; font-size: 13px; font-weight: 700; color: #fff; letter-spacing: 0.1em; opacity: 0.85; }
.svc-body { position: relative; z-index: 2; margin-top: -34px; padding: 0 26px 58px; }
.svc-icon { width: 58px; height: 58px; border-radius: 14px; display: grid; place-items: center; background: var(--forest); color: #fff; box-shadow: 0 12px 26px rgba(28,107,62,0.42); }
.svc-icon svg { width: 30px; height: 30px; }
.svc-card h3 { font-size: 20px; margin: 16px 0 12px; }
.svc-card p { font-size: 13.5px; color: rgba(255,255,255,0.78); line-height: 1.8; margin: 0; }
.svc-card .svc-arrow {
  position: absolute; right: 18px; bottom: 18px; z-index: 3;
  width: 38px; height: 38px; border-radius: 50%; display: grid; place-items: center;
  border: 1px solid rgba(255,255,255,0.28); color: #fff; font-weight: 700; transition: background .2s, border-color .2s;
}
.svc-card:hover .svc-arrow { background: var(--forest); border-color: var(--forest); }

@media (max-width: 900px) { .svc-grid, .topics-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 560px) { .svc-grid, .topics-grid { grid-template-columns: 1fr; } }

/* =========================================================
   ABOUT
   ========================================================= */
.about-layout { display: grid; grid-template-columns: 0.9fr 1.1fr; gap: clamp(28px, 5vw, 64px); align-items: center; }
.about-portrait {
  position: relative; border-radius: 18px; overflow: hidden; min-height: 380px;
  background: linear-gradient(160deg, var(--navy-2), var(--navy-deep));
  background-size: cover; background-position: center;
  display: grid; place-items: center;
}
.about-portrait::after { content: ""; position: absolute; inset: 0; background: linear-gradient(165deg, rgba(16,60,120,0.28), rgba(16,60,120,0.62)); }
.about-portrait .about-mtn { position: relative; z-index: 2; width: 62%; }
.about-portrait .about-mtn .mountain { display: block; width: 100%; color: rgba(255,255,255,0.92); filter: drop-shadow(0 6px 18px rgba(0,0,0,0.3)); }
.about-portrait .about-badge {
  position: absolute; left: 20px; bottom: 20px; z-index: 3; background: var(--green); color: #fff;
  padding: 10px 16px; border-radius: 10px; font-weight: 900; font-size: 13px; letter-spacing: 0.08em;
}
/* 3つの峰の少し上に、左からスイム・バイク・ランのピクトグラムを配置 */
.about-tri { position: absolute; inset: 0; z-index: 3; pointer-events: none; }
.about-tri span { position: absolute; width: 36px; height: 36px; border-radius: 50%; display: grid; place-items: center; background: rgba(255,255,255,0.20); color: #fff; backdrop-filter: blur(2px); transform: translate(-50%, -50%); box-shadow: 0 3px 10px rgba(0,0,0,0.22); }
.about-tri span:nth-child(1) { left: 23%; top: 26%; }
.about-tri span:nth-child(2) { left: 50%; top: 8%; }
.about-tri span:nth-child(3) { left: 77%; top: 29%; }
.about-tri svg { width: 21px; height: 21px; }
.about-body .about-kicker { color: var(--green-deep); font-weight: 900; letter-spacing: 0.12em; font-size: 12px; }
.about-body h2 { font-size: clamp(24px, 3.4vw, 36px); margin: 12px 0 18px; color: var(--navy); }
.about-body p { color: #354560; }
.about-meta { margin-top: 22px; display: flex; flex-wrap: wrap; gap: 10px 26px; font-size: 14px; }
.about-meta b { color: var(--navy); }

@media (max-width: 820px) { .about-layout { grid-template-columns: 1fr; } }

/* =========================================================
   CTA strip
   ========================================================= */
.cta {
  position: relative; background: var(--green-pale); color: var(--ink); overflow: hidden;
  text-align: center; padding: clamp(56px, 8vw, 96px) 0;
}
.cta::after { content: ""; position: absolute; inset: 0; background: radial-gradient(circle at 80% 120%, rgba(47,168,79,0.4), transparent 55%); }
.cta > .container { position: relative; z-index: 2; }
.cta h2 { font-size: clamp(26px, 4vw, 44px); margin-bottom: 14px; }
.cta p { color: #3a4a64; margin-bottom: 30px; }
.cta-actions { display: flex; gap: 14px; justify-content: center; flex-wrap: wrap; }

/* =========================================================
   Footer
   ========================================================= */
.site-footer { background: linear-gradient(160deg, var(--forest-top) 0%, var(--forest-deep) 85%); color: rgba(255,255,255,0.78); padding: 56px 0 28px; }
.footer-top { display: grid; grid-template-columns: 1.4fr 1fr; gap: 40px; }
.footer-brand-name { color: #fff; font-size: 20px; font-weight: 900; }
.footer-rep { margin: 10px 0 2px; color: #fff; font-size: 14px; }
.footer-company { font-size: 13px; color: rgba(255,255,255,0.6); }
.footer-contact { margin-top: 16px; font-size: 14px; line-height: 2; }
.footer-contact a { color: var(--blue-soft); }
.footer-nav { display: flex; flex-wrap: wrap; gap: 10px 24px; align-content: start; }
.footer-nav a { font-size: 14px; font-weight: 700; color: rgba(255,255,255,0.8); }
.footer-nav a:hover { color: var(--blue-soft); }
.footer-bottom { margin-top: 40px; padding-top: 20px; border-top: 1px solid rgba(255,255,255,0.12); display: flex; justify-content: space-between; flex-wrap: wrap; gap: 8px; font-size: 12px; color: rgba(255,255,255,0.5); }

@media (max-width: 720px) { .footer-top { grid-template-columns: 1fr; gap: 28px; } }

/* =========================================================
   Page hero (sub pages)
   ========================================================= */
.page-hero {
  position: relative; background: var(--navy); color: #fff; overflow: hidden;
  padding: clamp(56px, 8vw, 96px) 0 clamp(48px, 6vw, 72px);
}
.page-hero::before {
  content: attr(data-label); position: absolute; right: 12px; bottom: -18px;
  writing-mode: vertical-rl; font-size: clamp(60px, 10vw, 120px); font-weight: 900;
  color: rgba(255,255,255,0.07); line-height: 1;
}
.page-hero .en { color: var(--green-2); font-weight: 900; letter-spacing: 0.14em; font-size: 13px; }
.page-hero h1 { font-size: clamp(30px, 5vw, 52px); margin: 12px 0 14px; }
.page-hero .page-lead { color: rgba(255,255,255,0.82); max-width: 38em; }
/* 薄緑（明色）ページ見出し */
.page-hero.ph-light { color: var(--ink); }
.page-hero.ph-light h1 { color: var(--navy); }
.page-hero.ph-light .en { color: var(--green-deep); }
.page-hero.ph-light .page-lead { color: #3a4a64; }
.page-hero.ph-light::before { color: rgba(28,107,62,0.08); }

/* =========================================================
   Office table
   ========================================================= */
.office-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 36px; align-items: start; }
.office-table { width: 100%; border-collapse: collapse; }
.office-table th, .office-table td { text-align: left; padding: 16px 8px; border-bottom: 1px solid var(--line); vertical-align: top; font-size: 15px; }
.office-table th { width: 110px; color: var(--navy); font-weight: 800; white-space: nowrap; }
.office-table td a { color: var(--green-deep); font-weight: 700; }
.map-frame { border-radius: 14px; overflow: hidden; min-height: 320px; border: 1px solid var(--line); }
.map-frame iframe { width: 100%; height: 100%; min-height: 360px; border: 0; display: block; }
.map-placeholder { display: grid; place-items: center; min-height: 320px; background: var(--lav); color: var(--muted); padding: 24px; text-align: center; }
.value-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; }
.value-card { background: #fff; border: 1px solid var(--line); border-radius: 14px; padding: 26px; }
.value-card .vc-en { color: var(--green-deep); font-weight: 900; font-size: 12px; letter-spacing: 0.1em; }
.value-card h3 { color: var(--navy); font-size: 19px; margin: 10px 0 10px; }
.value-card p { font-size: 14px; color: #44546e; margin: 0; }

@media (max-width: 820px) { .office-grid, .value-grid { grid-template-columns: 1fr; } }

/* =========================================================
   Contact
   ========================================================= */
.contact-grid { display: grid; grid-template-columns: 0.85fr 1.15fr; gap: clamp(28px, 5vw, 54px); align-items: start; }
.contact-aside h2 { color: var(--navy); font-size: clamp(22px, 3vw, 30px); margin-bottom: 14px; }
.contact-aside p { color: #44546e; }
.contact-meta { margin-top: 22px; display: grid; gap: 8px; font-size: 14px; }
.contact-meta a { color: var(--green-deep); font-weight: 700; }
.contact-card { background: #fff; border: 1px solid var(--line); border-radius: 18px; padding: clamp(24px, 4vw, 40px); box-shadow: var(--shadow-sm); }

.miyama-contact-form .miyama-field { margin-bottom: 18px; }
.miyama-contact-form label { display: block; font-weight: 800; font-size: 13px; color: var(--navy); margin-bottom: 7px; }
.miyama-contact-form input, .miyama-contact-form textarea {
  width: 100%; padding: 13px 15px; border: 1px solid var(--line-strong); border-radius: 10px;
  font-family: inherit; font-size: 15px; background: #fbfcfe; transition: border-color .2s, box-shadow .2s;
}
.miyama-contact-form input:focus, .miyama-contact-form textarea:focus { outline: none; border-color: var(--green); box-shadow: 0 0 0 3px rgba(47,168,79,0.16); }
.miyama-contact-form textarea { min-height: 150px; resize: vertical; }
.miyama-contact-form button { margin-top: 6px; cursor: pointer; border: 0; }
.miyama-hp-field { position: absolute; left: -9999px; }
.miyama-form-message { background: var(--green-soft); border: 1px solid var(--green); color: var(--green-deep); padding: 14px 18px; border-radius: 10px; margin-bottom: 20px; font-weight: 700; }
.miyama-form-message.is-error { background: #fdecec; border-color: #d76d54; color: #b8402c; }

@media (max-width: 820px) { .contact-grid { grid-template-columns: 1fr; } }

/* =========================================================
   Posts (single / archive)
   ========================================================= */
.post-wrap { width: min(100% - 48px, 760px); margin: 0 auto; padding: clamp(48px,7vw,84px) 0; }
.post-wrap .post-meta { color: var(--muted); font-size: 13px; font-weight: 700; }
.post-wrap h1 { color: var(--navy); font-size: clamp(26px,4vw,40px); margin: 10px 0 24px; }
.post-content { line-height: 2; }
.post-content h2 { color: var(--navy); margin: 1.6em 0 .6em; font-size: 24px; border-left: 5px solid var(--green); padding-left: 14px; }
.post-content h3 { color: var(--navy); margin: 1.4em 0 .5em; font-size: 19px; }
.post-content a { color: var(--green-deep); text-decoration: underline; }
.post-content img { border-radius: 10px; margin: 1em 0; }

.archive-head { text-align: center; }
.news-archive { display: flex; flex-direction: column; gap: 12px; margin-top: 40px; }

/* =========================================================
   Utilities
   ========================================================= */
.text-link { display: inline-flex; align-items: center; gap: 8px; color: var(--green-deep); font-weight: 800; font-size: 14px; }
.text-link::after { content: "→"; transition: transform .2s; }
.text-link:hover::after { transform: translateX(3px); }
.elementor-page-wrap { width: min(100% - 48px, var(--max)); margin-inline: auto; padding: 40px 0; }
.screen-reader-text { position: absolute; left: -9999px; }

/* =========================================================
   Rich content components
   ========================================================= */
.lead-text { max-width: 46em; margin: 0 auto clamp(36px, 5vw, 56px); text-align: center; color: #44546e; font-size: clamp(15px, 1.6vw, 17px); }
.section--navy .lead-text, .section--green .lead-text, .section--forest .lead-text { color: rgba(255,255,255,0.85); }

/* service detail rows */
.svc-detail { display: grid; grid-template-columns: 0.92fr 1.08fr; gap: clamp(28px, 5vw, 60px); align-items: center; padding: clamp(40px, 6vw, 64px) 0; border-bottom: 1px solid var(--line); scroll-margin-top: 90px; }
.svc-detail:last-child { border-bottom: 0; }
.svc-detail:nth-child(even) .svc-detail-media { order: 2; }
.svc-detail-media { position: relative; border-radius: 18px; overflow: hidden; aspect-ratio: 4 / 3; background-size: cover; background-position: center; box-shadow: var(--shadow-sm); }
.svc-detail-media::after { content: ""; position: absolute; inset: 0; background: linear-gradient(160deg, rgba(16,60,120,0.05), rgba(16,60,120,0.35)); }
.svc-detail-media .num { position: absolute; left: 18px; top: 14px; z-index: 2; font-family: Georgia, serif; font-size: 40px; font-weight: 700; color: #fff; opacity: 0.92; text-shadow: 0 2px 12px rgba(0,0,0,0.35); }
.svc-detail-head { display: flex; align-items: center; gap: 14px; }
.svc-detail-head .svc-icon { width: 50px; height: 50px; box-shadow: 0 10px 22px rgba(31,140,64,0.34); }
.svc-detail-head .svc-icon svg { width: 26px; height: 26px; }
.svc-detail-head h2 { color: var(--navy); font-size: clamp(22px, 2.6vw, 30px); }
.svc-detail .d-lead { margin: 16px 0 18px; color: #3a4a64; }
.svc-detail .needs { display: flex; flex-wrap: wrap; gap: 8px; margin: 0 0 18px; }
.svc-detail .needs span { background: var(--green-soft); color: var(--green-deep); border: 1px solid rgba(47,168,79,0.3); border-radius: 999px; padding: 6px 14px; font-size: 12.5px; font-weight: 700; }
.svc-detail .includes { list-style: none; margin: 0; padding: 0; display: grid; gap: 10px; }
.svc-detail .includes li { position: relative; padding-left: 30px; font-size: 14.5px; color: #2b3a52; }
.svc-detail .includes li::before { content: ""; position: absolute; left: 0; top: 3px; width: 18px; height: 18px; border-radius: 50%; background: var(--green); }
.svc-detail .includes li::after { content: ""; position: absolute; left: 6px; top: 8px; width: 6px; height: 9px; border: solid #fff; border-width: 0 2px 2px 0; transform: rotate(45deg); }
.svc-detail .d-note { margin: 16px 0 0; font-size: 12.5px; color: var(--muted); }

@media (max-width: 800px) {
  .svc-detail { grid-template-columns: 1fr; gap: 22px; }
  .svc-detail:nth-child(even) .svc-detail-media { order: 0; }
}

/* fee */
.fee-wrap { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(28px, 5vw, 48px); align-items: start; }
.fee-points { list-style: none; margin: 0; padding: 0; display: grid; gap: 16px; }
.fee-points li { background: #fff; border: 1px solid var(--line); border-left: 4px solid var(--green); border-radius: 10px; padding: 16px 20px; font-size: 14.5px; color: #2b3a52; }
.fee-points li b { color: var(--navy); }
.fee-table { width: 100%; border-collapse: collapse; background: #fff; border: 1px solid var(--line); border-radius: 12px; overflow: hidden; }
.fee-table th, .fee-table td { padding: 14px 16px; text-align: left; border-bottom: 1px solid var(--line); font-size: 14px; }
.fee-table thead th { background: var(--navy); color: #fff; font-weight: 800; }
.fee-table tbody th { color: var(--navy); font-weight: 700; white-space: nowrap; }
.fee-table td { color: #3a4a64; font-family: Georgia, "Hiragino Kaku Gothic ProN", sans-serif; }
.fee-note { margin: 14px 0 0; font-size: 12.5px; color: var(--muted); }
@media (max-width: 800px) { .fee-wrap { grid-template-columns: 1fr; } }

/* flow steps */
.flow-steps { display: grid; gap: 16px; max-width: 760px; margin: 0 auto; }
.flow-step { position: relative; display: grid; grid-template-columns: 64px 1fr; gap: 20px; align-items: start; background: #fff; border: 1px solid var(--line); border-radius: 14px; padding: 22px 24px; }
.section--lav .flow-step { background: #fff; }
.flow-step .step-no { width: 52px; height: 52px; border-radius: 50%; background: var(--navy); color: #fff; display: grid; place-items: center; font-family: Georgia, serif; font-weight: 700; font-size: 20px; }
.flow-step:nth-child(odd) .step-no { background: var(--green); }
.flow-step h3 { color: var(--navy); font-size: 18px; margin: 2px 0 6px; }
.flow-step p { margin: 0; font-size: 14px; color: #44546e; }

/* faq accordion */
.faq { max-width: 820px; margin: 0 auto; display: grid; gap: 12px; }
.faq details { background: #fff; border: 1px solid var(--line); border-radius: 12px; overflow: hidden; }
.faq summary { cursor: pointer; list-style: none; padding: 18px 52px 18px 54px; position: relative; font-weight: 800; color: var(--navy); font-size: 15px; }
.faq summary::-webkit-details-marker { display: none; }
.faq summary::before { content: "Q"; position: absolute; left: 20px; top: 16px; width: 24px; height: 24px; border-radius: 6px; background: var(--green); color: #fff; display: grid; place-items: center; font-family: Georgia, serif; font-size: 13px; }
.faq summary::after { content: "+"; position: absolute; right: 22px; top: 14px; font-size: 22px; color: var(--green); transition: transform .2s; }
.faq details[open] summary::after { transform: rotate(45deg); }
.faq .faq-a { padding: 0 24px 20px 54px; color: #44546e; font-size: 14px; line-height: 1.9; }

/* feature/strength cards */
.feature-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; }
.feature-card { background: #fff; border: 1px solid var(--line); border-radius: 16px; padding: 32px 28px; transition: transform .2s, box-shadow .2s; }
.section--navy .feature-card { background: rgba(255,255,255,0.05); border-color: rgba(255,255,255,0.12); }
.feature-card:hover { transform: translateY(-5px); box-shadow: var(--shadow-sm); }
.feature-card .fc-no { font-family: Georgia, serif; color: var(--green); font-weight: 700; font-size: 14px; letter-spacing: 0.1em; }
.feature-card .fc-icon { margin: 10px 0 14px; width: 54px; height: 54px; border-radius: 14px; display: grid; place-items: center; background: var(--green-soft); color: var(--green-deep); }
.section--navy .feature-card .fc-icon { background: rgba(47,168,79,0.18); color: var(--green-2); }
.feature-card .fc-icon svg { width: 28px; height: 28px; }
.feature-card h3 { color: var(--navy); font-size: 19px; margin: 0 0 10px; }
.section--navy .feature-card h3 { color: #fff; }
.feature-card p { margin: 0; font-size: 14px; color: #44546e; }
.section--navy .feature-card p { color: rgba(255,255,255,0.78); }
@media (max-width: 820px) { .feature-grid { grid-template-columns: 1fr; } }

/* representative message */
.message-layout { display: grid; grid-template-columns: 0.85fr 1.15fr; gap: clamp(28px, 5vw, 56px); align-items: start; }
.message-portrait { position: relative; border-radius: 18px; overflow: hidden; min-height: 360px; background-size: cover; background-position: center; background-color: var(--navy-deep); }
.message-body p { color: #354560; margin: 0 0 1.1em; line-height: 1.95; }
.message-body .message-sign { margin-top: 22px; color: var(--navy); }
@media (min-width: 821px) { .message-portrait { position: sticky; top: 90px; aspect-ratio: 4 / 5; min-height: 0; } }
.message-portrait::after { content: ""; position: absolute; inset: 0; background: linear-gradient(165deg, rgba(16,60,120,0.2), rgba(16,60,120,0.55)); }
.message-portrait .mountain { position: absolute; left: 50%; top: 46%; transform: translate(-50%,-50%); z-index: 2; width: 50%; color: rgba(255,255,255,0.92); }
.message-body .about-kicker { color: var(--green-deep); font-weight: 900; letter-spacing: 0.12em; font-size: 12px; }
.message-body h2 { color: var(--navy); font-size: clamp(22px, 3vw, 32px); margin: 12px 0 18px; }
.message-body p { color: #3a4a64; }
.message-sign { margin-top: 20px; font-size: 14px; color: var(--navy); }
.message-sign b { font-size: 18px; }
@media (max-width: 820px) { .message-layout { grid-template-columns: 1fr; } }

/* full-width philosophy band */
.band { position: relative; padding: clamp(72px, 11vw, 150px) 0; text-align: center; color: var(--ink); background-size: cover; background-position: center; overflow: hidden; }
.band::after { content: ""; position: absolute; inset: 0; background: linear-gradient(rgba(232,245,236,0.92), rgba(223,240,229,0.95)); }
.band > .container { position: relative; z-index: 2; }
.band .band-en { color: var(--forest); font-weight: 900; letter-spacing: 0.16em; font-size: 13px; }
.band h2 { font-size: clamp(24px, 4vw, 44px); line-height: 1.5; margin: 14px 0 0; color: var(--navy-ink); }
.band p { margin: 18px auto 0; max-width: 40em; color: #3a4a64; }
.band-actions { margin-top: 30px; }

/* contact methods */
.method-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; }
.method-card { background: #fff; border: 1px solid var(--line); border-radius: 14px; padding: 28px 24px; text-align: center; }
.method-card .m-icon { width: 56px; height: 56px; border-radius: 50%; margin: 0 auto 14px; display: grid; place-items: center; background: var(--green-soft); color: var(--green-deep); }
.method-card .m-icon svg { width: 28px; height: 28px; }
.method-card h3 { color: var(--navy); font-size: 17px; margin: 0 0 6px; }
.method-card p { margin: 0; font-size: 13.5px; color: #44546e; }
.method-card .m-val { display: block; margin-top: 8px; font-size: 18px; font-weight: 900; color: var(--green-deep); font-family: Georgia, "Hiragino Kaku Gothic ProN", sans-serif; }
@media (max-width: 720px) { .method-grid { grid-template-columns: 1fr; } }

/* generic prose for page content */
.prose h2 { color: var(--navy); font-size: 24px; margin: 1.6em 0 .6em; border-left: 5px solid var(--green); padding-left: 14px; }
.prose h3 { color: var(--navy); font-size: 19px; margin: 1.4em 0 .5em; }
.prose ul { padding-left: 1.2em; } .prose li { margin: .3em 0; }

/* =========================================================
   Trust & careful-service components
   ========================================================= */
/* hero trust checklist */
.hero-trust { list-style: none; margin: 24px 0 0; padding: 0; display: flex; flex-wrap: wrap; gap: 9px 22px; }
.hero-trust li { position: relative; padding-left: 26px; font-size: 13.5px; font-weight: 700; color: #2b3a52; }
.hero-trust li::before { content: ""; position: absolute; left: 0; top: 2px; width: 18px; height: 18px; border-radius: 50%; background: var(--forest); }
.hero-trust li::after { content: ""; position: absolute; left: 6px; top: 5px; width: 6px; height: 9px; border: solid #fff; border-width: 0 2px 2px 0; transform: rotate(45deg); }

/* trust bar */
.trust-section { padding: clamp(44px, 6vw, 70px) 0; }
.trust-bar { display: grid; grid-template-columns: repeat(3, 1fr); background: #fff; border: 1px solid var(--line); border-radius: 18px; box-shadow: var(--shadow-sm); overflow: hidden; }
.trust-item { text-align: center; padding: 30px 18px; border-right: 1px solid var(--line); }
.trust-item:last-child { border-right: 0; }
.trust-item .t-val { display: block; font-family: var(--sans); font-size: clamp(28px, 3.6vw, 42px); font-weight: 900; color: var(--navy); line-height: 1.1; font-feature-settings: "palt" 0; }
.trust-item .t-val small { font-size: 0.5em; font-weight: 700; }
.trust-item .t-val .u { color: var(--green-deep); }
.trust-item .t-label { display: block; margin-top: 9px; font-size: 13px; font-weight: 800; color: var(--muted); letter-spacing: 0.04em; }
.trust-note { text-align: center; margin: 16px 0 0; font-size: 12.5px; color: var(--muted); }
@media (max-width: 760px) {
  .trust-bar { grid-template-columns: 1fr; }
  .trust-item { border-right: 0; border-bottom: 1px solid var(--line); }
  .trust-item:last-child { border-bottom: 0; }
}

/* promise cards */
.promise-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; }
.promise-card { position: relative; background: #fff; border: 1px solid var(--line); border-radius: 16px; padding: 32px 28px; box-shadow: var(--shadow-sm); }
.promise-card .p-no { position: absolute; right: 22px; top: 16px; font-family: Georgia, serif; font-size: 34px; font-weight: 700; color: rgba(28,107,62,0.4); }
.promise-card .p-icon { width: 56px; height: 56px; border-radius: 14px; display: grid; place-items: center; background: rgba(28,107,62,0.12); color: var(--forest); margin-bottom: 16px; }
.promise-card .p-icon svg { width: 28px; height: 28px; }
.promise-card h3 { color: var(--navy); font-size: 19px; margin: 0 0 10px; }
.promise-card p { margin: 0; font-size: 14px; color: #44546e; }
@media (max-width: 820px) { .promise-grid { grid-template-columns: 1fr; } }

/* consultation examples */
.consult-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 18px; }
.consult-card { display: grid; grid-template-columns: auto 1fr; gap: 16px; background: #fff; border: 1px solid var(--line); border-radius: 14px; padding: 22px 24px; transition: transform .2s, box-shadow .2s; }
.consult-card:hover { transform: translateY(-3px); box-shadow: var(--shadow-sm); }
.consult-card .c-mark { width: 42px; height: 42px; border-radius: 50%; background: var(--navy); color: #fff; display: grid; place-items: center; font-weight: 900; font-family: Georgia, serif; align-self: start; }
.consult-card .c-q { font-weight: 800; color: var(--navy); font-size: 15px; line-height: 1.6; }
.consult-card .c-a { margin-top: 8px; font-size: 13.5px; color: #44546e; line-height: 1.8; }
.consult-card .c-a::before { content: "→ "; color: var(--green-deep); font-weight: 900; }
@media (max-width: 680px) { .consult-grid { grid-template-columns: 1fr; } }

/* article featured image (single) */
.post-thumb { margin: 0 0 32px; border-radius: 14px; overflow: hidden; box-shadow: var(--shadow-sm); }
.post-thumb img { width: 100%; height: auto; display: block; }
.post-cats { display: inline-flex; gap: 8px; margin-left: 10px; }
.post-cats a { background: var(--green-soft); color: var(--green-deep); font-size: 11px; font-weight: 800; padding: 3px 10px; border-radius: 999px; }

/* blog archive cards (news / index) */
.post-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
.post-card { display: flex; flex-direction: column; background: #fff; border: 1px solid var(--line); border-radius: 14px; overflow: hidden; transition: transform .2s, box-shadow .2s; }
.post-card:hover { transform: translateY(-5px); box-shadow: var(--shadow); }
.post-card .pc-thumb { aspect-ratio: 3 / 2; background-size: cover; background-position: center; background-color: var(--lav-2); }
.post-card .pc-body { padding: 18px 20px 22px; display: flex; flex-direction: column; flex: 1; }
.post-card .pc-cat { align-self: flex-start; background: var(--green-soft); color: var(--green-deep); font-size: 11px; font-weight: 800; padding: 3px 10px; border-radius: 999px; }
.post-card .pc-date { color: var(--muted); font-size: 12px; font-weight: 700; margin-top: 10px; font-family: Georgia, serif; letter-spacing: 0.02em; }
.post-card h2 { font-size: 16px; color: var(--navy); margin: 6px 0 0; line-height: 1.6; }
.post-card .pc-more { margin-top: auto; padding-top: 14px; color: var(--green-deep); font-weight: 800; font-size: 13px; }
@media (max-width: 900px) { .post-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 560px) { .post-grid { grid-template-columns: 1fr; } }

/* pagination */
.pagination { display: flex; justify-content: center; align-items: center; flex-wrap: wrap; gap: 8px; margin-top: clamp(40px, 6vw, 60px); }
.pagination .nav-links { display: contents; }
.pagination .page-numbers {
  display: inline-flex; align-items: center; justify-content: center;
  min-width: 46px; height: 46px; padding: 0 14px;
  border: 1px solid var(--line); border-radius: 12px; background: #fff;
  color: var(--navy); font-weight: 800; font-size: 15px;
  font-family: Georgia, "Hiragino Kaku Gothic ProN", sans-serif;
  transition: background .2s, color .2s, border-color .2s, transform .2s, box-shadow .2s;
}
.pagination a.page-numbers:hover { background: var(--green-soft); border-color: var(--green); color: var(--green-deep); transform: translateY(-2px); box-shadow: var(--shadow-sm); }
.pagination .page-numbers.current { background: var(--navy); border-color: var(--navy); color: #fff; }
.pagination .page-numbers.dots { border: 0; background: transparent; min-width: 24px; color: var(--muted); }
.pagination .page-numbers.prev, .pagination .page-numbers.next { color: var(--green-deep); font-size: 18px; }
