@charset "utf-8";

/* =========================================================
   companytrip.css 統合版
   PC/SP共通。旧 companytrip.css / companytrip-device.css の差し替え用。
========================================================= */

#itemlist.companytrip-page {
  --ct-brown: #745536;
  --ct-brown-dark: #5c3f27;
  --ct-gold: #c5a437;
  --ct-gold-light: #f6ecd0;
  --ct-orange: #f39800;
  --ct-cream: #fffaf0;
  --ct-bg: #fffdf8;
  --ct-text: #333;
  --ct-muted: #6b6258;
  --ct-border: #ead9b8;
  --ct-shadow: 0 14px 34px rgba(92, 63, 39, 0.14);
  max-width: 1280px;
  margin: 0 auto;
  color: var(--ct-text);
  font-family: "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", "メイリオ", Meiryo, sans-serif;
}

#itemlist.companytrip-page *,
#itemlist.companytrip-page *::before,
#itemlist.companytrip-page *::after { box-sizing: border-box; }

#itemlist.companytrip-page a { color: inherit; text-decoration: none; }
#itemlist.companytrip-page img { max-width: 100%; height: auto; display: block; }

#itemlist.companytrip-page .breadcrumb ul {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin: 0 0 18px;
  padding: 0;
  list-style: none;
  font-size: 13px;
  color: var(--ct-muted);
}

#itemlist.companytrip-page .ct-label {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  margin: 0 0 10px;
  color: var(--ct-brown);
  font-weight: 700;
  letter-spacing: 0.04em;
}

#itemlist.companytrip-page .ct-label::before {
  content: "";
  width: 28px;
  height: 2px;
  background: var(--ct-gold);
}

#itemlist.companytrip-page .ct-hero {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 390px;
  gap: 32px;
  align-items: center;
  margin: 0 0 28px;
  padding: 46px;
  border-radius: 28px;
  background:
    radial-gradient(circle at top right, rgba(243, 152, 0, 0.18), transparent 34%),
    linear-gradient(115deg, rgba(255, 250, 240, 0.98), rgba(246, 236, 208, 0.93));
  box-shadow: var(--ct-shadow);
  overflow: hidden;
}

#itemlist.companytrip-page .ct-hero h1 {
  margin: 0 0 18px;
  color: var(--ct-brown-dark);
  font-family: "游明朝", YuMincho, "Hiragino Mincho ProN", serif;
  font-size: 42px;
  line-height: 1.28;
  letter-spacing: 0.03em;
}

#itemlist.companytrip-page .ct-hero__lead {
  margin: 0 0 26px;
  max-width: 730px;
  line-height: 1.9;
  font-size: 16px;
}

#itemlist.companytrip-page .ct-hero__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 14px;
  align-items: center;
}

#itemlist.companytrip-page .ct-btn {
  display: inline-flex;
  justify-content: center;
  align-items: center;
  min-width: 230px;
  min-height: 52px;
  padding: 13px 24px;
  border-radius: 999px;
  font-weight: 700;
  line-height: 1.4;
  transition: transform 0.2s ease, box-shadow 0.2s ease, opacity 0.2s ease;
}

#itemlist.companytrip-page .ct-btn:hover { transform: translateY(-2px); opacity: 0.9; }
#itemlist.companytrip-page .ct-btn--primary { color: #fff; background: var(--ct-orange); box-shadow: 0 10px 20px rgba(243, 152, 0, 0.25); }
#itemlist.companytrip-page .ct-btn--secondary { color: var(--ct-brown); background: #fff; border: 2px solid var(--ct-gold); }

#itemlist.companytrip-page .ct-hero__points {
  padding: 26px;
  border-radius: 22px;
  background: rgba(255, 255, 255, 0.92);
  border: 1px solid rgba(197, 164, 55, 0.35);
}

#itemlist.companytrip-page .ct-hero__points p {
  margin: 0 0 14px;
  color: var(--ct-brown);
  font-weight: 700;
  font-size: 18px;
}

#itemlist.companytrip-page .ct-hero__points ul { margin: 0; padding: 0; list-style: none; }
#itemlist.companytrip-page .ct-hero__points li {
  position: relative;
  padding: 10px 0 10px 28px;
  border-top: 1px dashed var(--ct-border);
  line-height: 1.6;
}
#itemlist.companytrip-page .ct-hero__points li::before {
  content: "✓";
  position: absolute;
  left: 0;
  color: var(--ct-orange);
  font-weight: 700;
}

#itemlist.companytrip-page .ct-anchor {
  position: sticky;
  top: 0;
  z-index: 5;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 10px;
  margin: 0 0 48px;
  padding: 14px;
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.94);
  border: 1px solid var(--ct-border);
  box-shadow: 0 10px 24px rgba(92, 63, 39, 0.08);
}

#itemlist.companytrip-page .ct-anchor a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 126px;
  padding: 10px 14px;
  border-radius: 999px;
  background: var(--ct-cream);
  color: var(--ct-brown);
  font-weight: 700;
  font-size: 14px;
}

#itemlist.companytrip-page .ct-section {
  margin: 0 0 64px;
  padding: 0 10px;
}

#itemlist.companytrip-page .ct-section h2,
#itemlist.companytrip-page .ct-cta h2,
#itemlist.companytrip-page .ct-finalCta h2 {
  margin: 0 0 18px;
  color: var(--ct-brown-dark);
  font-family: "游明朝", YuMincho, "Hiragino Mincho ProN", serif;
  font-size: 34px;
  line-height: 1.35;
  text-align: center;
}

#itemlist.companytrip-page .ct-section__head {
  max-width: 820px;
  margin: 0 auto 28px;
  text-align: center;
}

#itemlist.companytrip-page .ct-section__head .ct-label { justify-content: center; }
#itemlist.companytrip-page .ct-section__head p:not(.ct-label) { margin: 0; line-height: 1.9; color: var(--ct-muted); }

#itemlist.companytrip-page .ct-problem { padding: 42px 34px; border-radius: 26px; background: var(--ct-bg); border: 1px solid var(--ct-border); }
#itemlist.companytrip-page .ct-problem > .ct-label { display: flex; justify-content: center; }

#itemlist.companytrip-page .ct-problem__grid,
#itemlist.companytrip-page .ct-purpose__grid,
#itemlist.companytrip-page .ct-service__grid,
#itemlist.companytrip-page .ct-review__grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 22px;
}

#itemlist.companytrip-page .ct-card,
#itemlist.companytrip-page .ct-purposeCard,
#itemlist.companytrip-page .ct-review article {
  padding: 24px;
  border-radius: 20px;
  background: #fff;
  border: 1px solid var(--ct-border);
  box-shadow: 0 10px 22px rgba(92, 63, 39, 0.08);
}

#itemlist.companytrip-page .ct-card h3,
#itemlist.companytrip-page .ct-purposeCard h3,
#itemlist.companytrip-page .ct-serviceCard h3,
#itemlist.companytrip-page .ct-review h3,
#itemlist.companytrip-page .ct-stepList h3 {
  margin: 0 0 10px;
  color: var(--ct-brown);
  font-size: 20px;
  line-height: 1.4;
}

#itemlist.companytrip-page .ct-card p,
#itemlist.companytrip-page .ct-purposeCard p,
#itemlist.companytrip-page .ct-serviceCard p,
#itemlist.companytrip-page .ct-review p,
#itemlist.companytrip-page .ct-stepList p {
  margin: 0;
  line-height: 1.8;
  color: var(--ct-muted);
}

#itemlist.companytrip-page .ct-purpose__grid { grid-template-columns: repeat(4, minmax(0, 1fr)); }
#itemlist.companytrip-page .ct-purposeCard { position: relative; overflow: hidden; }
#itemlist.companytrip-page .ct-purposeCard::after {
  content: "";
  position: absolute;
  right: -24px;
  bottom: -24px;
  width: 90px;
  height: 90px;
  border-radius: 50%;
  background: rgba(197, 164, 55, 0.16);
}
#itemlist.companytrip-page .ct-purposeCard span {
  display: inline-flex;
  margin: 0 0 12px;
  padding: 4px 10px;
  border-radius: 999px;
  color: #fff;
  background: var(--ct-brown);
  font-size: 13px;
  font-weight: 700;
}

#itemlist.companytrip-page .ct-categoryGrid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 20px;
}

#itemlist.companytrip-page .ct-categoryGrid a {
  overflow: hidden;
  border-radius: 18px;
  background: #fff;
  border: 1px solid var(--ct-border);
  box-shadow: 0 10px 22px rgba(92, 63, 39, 0.08);
}

#itemlist.companytrip-page .ct-categoryGrid img {
  width: 100%;
  aspect-ratio: 4 / 3;
  object-fit: cover;
  transition: transform 0.25s ease;
}
#itemlist.companytrip-page .ct-categoryGrid a:hover img { transform: scale(1.04); }
#itemlist.companytrip-page .ct-categoryGrid span {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 56px;
  padding: 10px;
  color: var(--ct-brown);
  font-weight: 700;
  text-align: center;
}

#itemlist.companytrip-page .ct-search {
  padding: 42px 34px;
  border-radius: 26px;
  background: linear-gradient(180deg, #fff, var(--ct-cream));
  border: 1px solid var(--ct-border);
}

#itemlist.companytrip-page .ct-chipGrid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 14px;
}

#itemlist.companytrip-page .ct-chipGrid a {
  display: flex;
  justify-content: center;
  align-items: center;
  min-height: 54px;
  padding: 12px 16px;
  border-radius: 12px;
  color: var(--ct-brown);
  background: #fff;
  border: 2px solid var(--ct-gold);
  font-weight: 700;
}

#itemlist.companytrip-page .ct-cta,
#itemlist.companytrip-page .ct-finalCta {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 28px;
  margin: 0 0 64px;
  padding: 34px 38px;
  border-radius: 26px;
  color: #fff;
  background: linear-gradient(135deg, var(--ct-brown), var(--ct-brown-dark));
  box-shadow: var(--ct-shadow);
}

#itemlist.companytrip-page .ct-cta .ct-label,
#itemlist.companytrip-page .ct-finalCta .ct-label,
#itemlist.companytrip-page .ct-cta h2,
#itemlist.companytrip-page .ct-finalCta h2,
#itemlist.companytrip-page .ct-cta p,
#itemlist.companytrip-page .ct-finalCta p { color: #fff; text-align: left; }

#itemlist.companytrip-page .ct-cta .ct-label::before,
#itemlist.companytrip-page .ct-finalCta .ct-label::before { background: #fff; }
#itemlist.companytrip-page .ct-cta p { margin: 0; line-height: 1.8; }

#itemlist.companytrip-page .ct-service__grid { grid-template-columns: 1fr; }
#itemlist.companytrip-page .ct-serviceCard {
  display: grid;
  grid-template-columns: 280px 1fr;
  gap: 24px;
  align-items: center;
  padding: 20px;
  border-radius: 22px;
  background: #fff;
  border: 1px solid var(--ct-border);
  box-shadow: 0 10px 22px rgba(92, 63, 39, 0.08);
}
#itemlist.companytrip-page .ct-serviceCard img {
  width: 100%;
  aspect-ratio: 4 / 3;
  object-fit: cover;
  border-radius: 16px;
}
#itemlist.companytrip-page .ct-serviceCard a {
  display: inline-flex;
  margin: 14px 0 0;
  color: var(--ct-orange);
  font-weight: 700;
}

#itemlist.companytrip-page .ct-stepList {
  max-width: 920px;
  margin: 0 auto;
  padding: 0;
  list-style: none;
}
#itemlist.companytrip-page .ct-stepList li {
  display: grid;
  grid-template-columns: 76px 1fr;
  gap: 20px;
  padding: 22px 0;
  border-bottom: 1px solid var(--ct-border);
}
#itemlist.companytrip-page .ct-stepList span {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 60px;
  height: 60px;
  border-radius: 50%;
  color: #fff;
  background: var(--ct-orange);
  font-weight: 700;
}

#itemlist.companytrip-page .ct-review__grid { grid-template-columns: repeat(3, minmax(0, 1fr)); }
#itemlist.companytrip-page .ct-finalCta { display: block; text-align: center; }
#itemlist.companytrip-page .ct-finalCta .ct-label,
#itemlist.companytrip-page .ct-finalCta h2 { justify-content: center; text-align: center; }
#itemlist.companytrip-page .ct-finalCta .ct-hero__actions { justify-content: center; }
#itemlist.companytrip-page .ct-finalCta__tel { margin: 18px 0 0 !important; text-align: center !important; }
#itemlist.companytrip-page .ct-finalCta__tel a { font-weight: 700; text-decoration: underline; }

@media screen and (max-width: 767px) {
  #itemlist.companytrip-page {
    width: 100%;
    padding: 0 4vw;
    font-size: 3.8vw;
  }

  #itemlist.companytrip-page .breadcrumb ul {
    margin-bottom: 3vw;
    font-size: 3vw;
  }

  #itemlist.companytrip-page .ct-label {
    font-size: 3.4vw;
  }

  #itemlist.companytrip-page .ct-hero {
    grid-template-columns: 1fr;
    gap: 5vw;
    margin-bottom: 5vw;
    padding: 8vw 5vw;
    border-radius: 5vw;
  }

  #itemlist.companytrip-page .ct-hero h1 {
    font-size: 7.2vw;
    line-height: 1.35;
  }

  #itemlist.companytrip-page .ct-hero__lead {
    font-size: 3.8vw;
    line-height: 1.8;
  }

  #itemlist.companytrip-page .ct-hero__actions,
  #itemlist.companytrip-page .ct-cta,
  #itemlist.companytrip-page .ct-finalCta .ct-hero__actions {
    display: grid;
    grid-template-columns: 1fr;
  }

  #itemlist.companytrip-page .ct-btn {
    width: 100%;
    min-width: 0;
    min-height: 12vw;
    padding: 3vw 4vw;
    font-size: 4vw;
  }

  #itemlist.companytrip-page .ct-hero__points {
    padding: 5vw;
    border-radius: 4vw;
  }

  #itemlist.companytrip-page .ct-anchor {
    position: static;
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 2.5vw;
    margin-bottom: 9vw;
    padding: 3vw;
    border-radius: 4vw;
  }

  #itemlist.companytrip-page .ct-anchor a {
    min-width: 0;
    padding: 2.8vw 2vw;
    font-size: 3.5vw;
  }

  #itemlist.companytrip-page .ct-section {
    margin-bottom: 11vw;
    padding: 0;
  }

  #itemlist.companytrip-page .ct-section h2,
  #itemlist.companytrip-page .ct-cta h2,
  #itemlist.companytrip-page .ct-finalCta h2 {
    font-size: 6.2vw;
    line-height: 1.42;
  }

  #itemlist.companytrip-page .ct-problem,
  #itemlist.companytrip-page .ct-search {
    padding: 7vw 4vw;
    border-radius: 5vw;
  }

  #itemlist.companytrip-page .ct-problem__grid,
  #itemlist.companytrip-page .ct-purpose__grid,
  #itemlist.companytrip-page .ct-review__grid,
  #itemlist.companytrip-page .ct-categoryGrid,
  #itemlist.companytrip-page .ct-chipGrid {
    grid-template-columns: 1fr;
    gap: 4vw;
  }

  #itemlist.companytrip-page .ct-categoryGrid {
    grid-template-columns: repeat(2, 1fr);
  }

  #itemlist.companytrip-page .ct-card,
  #itemlist.companytrip-page .ct-purposeCard,
  #itemlist.companytrip-page .ct-review article {
    padding: 5vw;
    border-radius: 4vw;
  }

  #itemlist.companytrip-page .ct-card h3,
  #itemlist.companytrip-page .ct-purposeCard h3,
  #itemlist.companytrip-page .ct-serviceCard h3,
  #itemlist.companytrip-page .ct-review h3,
  #itemlist.companytrip-page .ct-stepList h3 {
    font-size: 4.6vw;
  }

  #itemlist.companytrip-page .ct-categoryGrid span {
    min-height: 13vw;
    font-size: 3.5vw;
  }

  #itemlist.companytrip-page .ct-chipGrid {
    grid-template-columns: repeat(2, 1fr);
    gap: 3vw;
  }

  #itemlist.companytrip-page .ct-chipGrid a {
    min-height: 12vw;
    padding: 2.5vw;
    font-size: 3.8vw;
    text-align: center;
  }

  #itemlist.companytrip-page .ct-cta,
  #itemlist.companytrip-page .ct-finalCta {
    margin-bottom: 11vw;
    padding: 7vw 5vw;
    border-radius: 5vw;
  }

  #itemlist.companytrip-page .ct-cta .ct-label,
  #itemlist.companytrip-page .ct-cta h2,
  #itemlist.companytrip-page .ct-cta p { text-align: center; justify-content: center; }

  #itemlist.companytrip-page .ct-serviceCard {
    grid-template-columns: 1fr;
    gap: 4vw;
    padding: 4vw;
    border-radius: 5vw;
  }

  #itemlist.companytrip-page .ct-stepList li {
    grid-template-columns: 13vw 1fr;
    gap: 4vw;
    padding: 5vw 0;
  }

  #itemlist.companytrip-page .ct-stepList span {
    width: 12vw;
    height: 12vw;
    font-size: 3.4vw;
  }
}
