/* Extracted from umj-official/Page-house-solution.php */
.umj-house-solution { --umj-green:#1D5D4E; --umj-green-soft:#edf7f3; --umj-gold:#F6C343; --umj-text:#1A1A1A; --umj-bg:#ffffff; }
.umj-house-solution * { box-sizing: border-box; }
.umj-house-solution a { text-decoration: none; }
.umj-wrap { width:min(1160px, 92%); margin-inline:auto; }
.umj-section { padding: clamp(56px, 7vw, 96px) 0; }
.umj-section-head {
  max-width:760px;
  margin:0 auto 34px;
  text-align:center;
}
.umj-section-lead {
  max-width:680px;
  margin:0 auto;
  color:#555;
  font-size:15px;
  line-height:1.85;
}
.umj-kicker {
  margin:0 0 12px;
  color: var(--umj-green);
  font-weight: 800;
  letter-spacing: .08em;
  font-size: .82rem;
}
.umj-title {
  font-size: clamp(28px, 4.2vw, 42px);
  line-height: 1.36;
  margin:0 0 18px;
  color:var(--umj-text);
  font-weight:800;
}
.umj-line {
  display:block;
}
.umj-lead {
  max-width:680px;
  font-size: clamp(15px, 2vw, 18px);
  line-height:1.95;
  color:#333;
}
/* ===============================
   爽やかCTAボタン（改）
=============================== */
.umj-btn {
  --cta-main: #1D5D4E;
  --cta-sub: #4FAF9A;

  display: inline-flex;
  align-items: center;
  gap: 8px;

  min-height: 48px;
  padding: 13px 24px;
  border-radius: 999px;
  font-weight: 800;
  font-size: 15px;

  color: #fff;
  background: linear-gradient(135deg, var(--cta-main), var(--cta-sub));
  border: none;

  box-shadow:
    0 8px 18px rgba(79, 175, 154, 0.25),
    inset 0 1px 0 rgba(255,255,255,0.25);

  transition:
    transform .25s ease,
    box-shadow .25s ease,
    filter .25s ease;
}

.umj-btn::after {
  content: "→";
  transition: transform .25s ease;
}

.umj-btn:hover {
  transform: translateY(-2px);
  box-shadow:
    0 14px 28px rgba(79, 175, 154, 0.35),
    inset 0 1px 0 rgba(255,255,255,0.35);
  filter: brightness(1.05);
}

.umj-btn:hover::after {
  transform: translateX(4px);
}
.umj-btn--ghost {
  color:var(--umj-green);
  background:#fff;
  border:1px solid rgba(29,93,78,.22);
  box-shadow:0 8px 18px rgba(29,93,78,.08);
}
.umj-btn--ghost:hover {
  box-shadow:0 12px 24px rgba(29,93,78,.14);
}

.umj-hero {
  position:relative;
  overflow:hidden;
  background:linear-gradient(135deg,#f3faf7 0%,#e7f3ef 58%,#fff7e4 100%);
}
.umj-hero__bg { position:absolute; inset:0; opacity:.18; overflow:hidden; }
.umj-hero__bg img {
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}
.umj-hero__inner { position:relative; z-index:2; padding: clamp(72px, 10vw, 132px) 0 clamp(64px, 8vw, 112px); }
.umj-hero__grid { display:grid; grid-template-columns:minmax(0, 1.05fr) minmax(360px, .82fr); gap:clamp(36px, 6vw, 72px); align-items:center; }
@media (max-width: 900px){ .umj-hero__grid{ grid-template-columns:1fr; } }
.umj-hero__title {
  max-width:780px;
  font-size:clamp(34px, 5.4vw, 58px);
  line-height:1.22;
  letter-spacing:0;
}
.umj-hero__actions {
  display:flex;
  flex-wrap:wrap;
  gap:14px;
  margin-top:30px;
}
.umj-cards { display:grid; grid-template-columns: repeat(3, 1fr); gap:20px; margin-top:28px; }
@media (max-width: 1080px){ .umj-cards{ grid-template-columns:1fr 1fr; } }
@media (max-width: 720px){ .umj-cards{ grid-template-columns:1fr; } }
.umj-card { background:#fff; border:1px solid #e5ece9; border-radius:12px; overflow:hidden; box-shadow:0 10px 26px rgba(29,93,78,.06); display:flex; flex-direction:column; }
.umj-card__img { aspect-ratio: 16/9; background:#f2f6f4; overflow:hidden; }
.umj-card__img img,
.umj-thumb img {
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}
.umj-hero__thumb {
  width:100%;
  aspect-ratio:4/3;
  height:auto;
  object-fit:cover;
  border-radius:16px;
  box-shadow:0 22px 54px rgba(29,93,78,.14);
}
.umj-hero__placeholder {
  aspect-ratio:4/3;
  background:#fff;
  border:1px dashed #cfd9d4;
  border-radius:18px;
  display:grid;
  place-items:center;
  color:#789;
}
.umj-section--consult {
  background:
    linear-gradient(180deg, #fff 0%, #f6fbf8 100%);
}
.umj-consult-grid {
  display:grid;
  grid-template-columns: minmax(0, 1.02fr) minmax(320px, .9fr);
  gap:clamp(24px, 4vw, 48px);
  align-items:start;
}
.umj-consult-panel {
  background:#fff;
  border:1px solid #dfe9e5;
  border-radius:14px;
  padding:clamp(22px, 3vw, 32px);
  box-shadow:0 14px 36px rgba(29,93,78,.08);
}
.umj-consult-panel h3 {
  margin:0 0 16px;
  color:var(--umj-green);
  font-size:20px;
}
.umj-check-list {
  display:grid;
  gap:12px;
  margin:0;
  padding:0;
  list-style:none;
}
.umj-check-list li {
  position:relative;
  padding-left:28px;
  color:#333;
  line-height:1.8;
  font-size:15px;
}
.umj-check-list li::before {
  content:"";
  position:absolute;
  left:0;
  top:.55em;
  width:18px;
  height:18px;
  border-radius:50%;
  background:var(--umj-green);
  box-shadow:inset 0 0 0 5px #dcefe9;
}
.umj-method-map {
  display:grid;
  grid-template-columns: minmax(280px, .38fr) minmax(0, 1fr);
  gap:22px;
  margin-top:42px;
}
.umj-method-map__core {
  background:var(--umj-green);
  color:#fff;
  border-radius:14px;
  padding:32px;
  display:flex;
  flex-direction:column;
  justify-content:center;
  min-height:300px;
  box-shadow:0 18px 44px rgba(29,93,78,.18);
}
.umj-method-map__core span,
.umj-method-map__items span {
  font-size:13px;
  font-weight:700;
  letter-spacing:.08em;
}
.umj-method-map__core span {
  color:#cce8df;
}
.umj-method-map__core strong {
  display:block;
  margin:14px 0;
  font-size:clamp(25px, 3vw, 36px);
  line-height:1.32;
}
.umj-method-map__core p,
.umj-method-map__items p {
  margin:0;
  line-height:1.75;
}
.umj-method-map__items {
  display:grid;
  grid-template-columns:1fr;
  gap:12px;
}
.umj-method-map__items article {
  background:#fff;
  border:1px solid #e4ece8;
  border-radius:12px;
  padding:20px 22px;
}
.umj-method-map__items span {
  color:var(--umj-green);
}
.umj-method-map__items h3 {
  margin:8px 0 6px;
  font-size:20px;
}
.umj-method-map__items p {
  color:#444;
  font-size:15px;
}
.umj-consult-cta {
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:24px;
  margin-top:28px;
  padding:30px 32px;
  border-radius:14px;
  background:#123f36;
  color:#fff;
  box-shadow:0 18px 44px rgba(29,93,78,.16);
}
.umj-consult-cta h3 {
  margin:0 0 8px;
  font-size:clamp(20px, 2.5vw, 26px);
  line-height:1.45;
}
.umj-consult-cta p {
  max-width:760px;
  margin:0;
  color:rgba(255,255,255,.78);
  font-size:14px;
  line-height:1.8;
}
.umj-consult-cta .umj-btn {
  flex:0 0 auto;
  background:#fff;
  color:var(--umj-green);
  box-shadow:0 10px 24px rgba(0,0,0,.16);
}
.umj-section--logos {
  background:#fff;
  border-top:1px solid #e8efec;
  border-bottom:1px solid #e8efec;
}
.umj-client-intro {
  display:grid;
  grid-template-columns:minmax(0, .9fr) minmax(320px, .7fr);
  gap:clamp(22px, 4vw, 48px);
  align-items:end;
  margin-bottom:30px;
}
.umj-client-intro .umj-title {
  margin-bottom:0;
}
.umj-client-intro .umj-section-lead {
  margin:0;
  max-width:none;
}
.umj-logo-wall {
  display:grid;
  grid-template-columns:repeat(6, minmax(0, 1fr));
  gap:12px;
}
.umj-logo-wall__item {
  min-height:78px;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:14px 18px;
  border:1px solid #e3eae7;
  border-radius:10px;
  background:linear-gradient(180deg, #fff 0%, #f8fbfa 100%);
  box-shadow:0 8px 20px rgba(29,93,78,.045);
}
.umj-logo-wall__item img {
  max-width:100%;
  max-height:46px;
  width:auto;
  height:auto;
  object-fit:contain;
  filter:saturate(.88) contrast(.98);
}
.umj-logo-wall__note {
  margin:18px 0 0;
  color:#66736f;
  font-size:12px;
  text-align:right;
}
.umj-flow {
  display:grid;
  grid-template-columns:repeat(4, minmax(0, 1fr));
  gap:14px;
  margin-top:0;
}
.umj-flow__item {
  position:relative;
  min-height:220px;
  padding:24px 20px 22px;
  border:1px solid #e4ece8;
  border-top:3px solid var(--umj-green);
  border-radius:0 0 12px 12px;
  background:#fff;
  box-shadow:0 8px 24px rgba(29,93,78,.06);
}
.umj-flow__item span {
  color:var(--umj-green);
  font-size:12px;
  font-weight:800;
  letter-spacing:.08em;
}
.umj-flow__item h3 {
  margin:12px 0 12px;
  font-size:18px;
}
.umj-flow__item p {
  margin:0;
  padding-top:12px;
  border-top:1px solid #e4ece8;
  color:#444;
  font-size:14px;
  line-height:1.75;
}
.umj-card__body { padding:20px 22px; }
.umj-card h3 { font-size:18px; line-height:1.5; margin:0 0 10px; }
.umj-card p { color:#444; font-size:15px; line-height:1.8; margin:0; }
.umj-card .umj-card__cta { margin-top:auto; padding:16px 22px 22px; }

@media (max-width: 900px) {
  .umj-consult-grid,
  .umj-method-map {
    grid-template-columns:1fr;
  }
  .umj-method-map__core {
    min-height:auto;
  }
  .umj-method-map__items {
    grid-template-columns:1fr;
  }
  .umj-consult-cta {
    align-items:flex-start;
    flex-direction:column;
  }
  .umj-client-intro {
    grid-template-columns:1fr;
    align-items:start;
  }
  .umj-logo-wall {
    grid-template-columns:repeat(4, minmax(0, 1fr));
  }
  .umj-flow {
    grid-template-columns:1fr 1fr;
  }
}

@media (max-width: 640px) {
  .umj-section {
    padding:52px 0;
  }
  .umj-section-head {
    margin-bottom:26px;
    text-align:left;
  }
  .umj-title {
    font-size:clamp(25px, 8vw, 32px);
  }
  .umj-line {
    display:inline;
  }
  .umj-hero__inner {
    padding:64px 0 56px;
  }
  .umj-hero__title {
    font-size:clamp(32px, 10vw, 42px);
  }
  .umj-lead {
    line-height:1.85;
  }
  .umj-hero__actions,
  .umj-hero__actions .umj-btn,
  .umj-consult-cta .umj-btn {
    width:100%;
  }
  .umj-method-map__core,
  .umj-consult-cta {
    padding:24px;
  }
  .umj-logo-wall {
    grid-template-columns:repeat(2, minmax(0, 1fr));
    gap:10px;
  }
  .umj-logo-wall__item {
    min-height:70px;
    padding:12px;
  }
  .umj-logo-wall__note {
    text-align:left;
  }
  .umj-flow {
    grid-template-columns:1fr;
  }
}

/* Extracted from umj-official/Page-house-solution.php */
.umj-column-swiper {
  margin-top: 40px;
  padding-bottom: 48px;
}

.umj-slide {
  background: #fff;
  border-radius: 16px;
  overflow: hidden;
  box-shadow: 0 4px 16px rgba(0,0,0,0.08);
  transition: transform .3s ease, box-shadow .3s ease;
  position: relative;
  height: auto;
}

.umj-slide:hover {
  transform: translateY(-5px);
  box-shadow: 0 6px 20px rgba(0,0,0,0.12);
}

.umj-thumb {
  aspect-ratio: 16/9;
  background: #f2f6f4;
  overflow:hidden;
}

.umj-body {
  padding: 16px 18px 22px;
}

.umj-body h3 {
  font-size: 16px;
  line-height: 1.45;
  font-weight: 700;
  margin: 0 0 8px;
  color: #1A1A1A;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  overflow: hidden;
}

.umj-body p {
  font-size: 14px;
  color: #555;
  margin: 0 0 10px;
  line-height: 1.7;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  overflow: hidden;
}

.umj-body a {
  font-weight: 700;
  color: var(--umj-green);
  font-size: 14px;
  text-decoration: none;
}

.umj-rank {
  position: absolute;
  top: 10px;
  left: 10px;
  background: var(--umj-gold);
  color: #111;
  font-weight: 700;
  font-size: 14px;
  padding: 4px 10px;
  border-radius: 999px;
  z-index: 2;
}
.umj-source {
  position:absolute;
  top:10px;
  right:10px;
  z-index:2;
  display:inline-flex;
  align-items:center;
  min-height:26px;
  padding:4px 10px;
  border-radius:999px;
  background:rgba(29,93,78,.9);
  color:#fff;
  font-size:12px;
  font-weight:800;
}

.swiper-button-prev,
.swiper-button-next {
  color: var(--umj-green);
}

.swiper-pagination-bullet-active {
  background: var(--umj-green);
}

@media (prefers-reduced-motion: reduce) {
  .umj-house-solution *,
  .umj-house-solution *::before,
  .umj-house-solution *::after {
    animation-duration: .001ms !important;
    animation-iteration-count: 1 !important;
    scroll-behavior: auto !important;
    transition-duration: .001ms !important;
  }
}

.umj-house-solution .umj-card a,
.umj-house-solution .umj-btn,
.umj-house-solution .swiper-button-prev,
.umj-house-solution .swiper-button-next {
  min-height:44px;
  min-width:44px;
}

.umj-house-solution .umj-card a,
.umj-house-solution .umj-btn {
  display:inline-flex;
  align-items:center;
  justify-content:center;
}

.umj-house-solution .umj-card a:focus-visible,
.umj-house-solution .umj-btn:focus-visible,
.umj-house-solution .swiper-button-prev:focus-visible,
.umj-house-solution .swiper-button-next:focus-visible {
  outline:3px solid rgba(13,94,60,.85);
  outline-offset:3px;
}
