:root {
  --tlp-black: #11130f;
  --tlp-ink: #151515;
  --tlp-yellow: #efb51d;
  --tlp-orange: #eb5b2a;
  --tlp-green: #49b597;
  --tlp-blue: #214493;
  --tlp-purple: #4f2d90;
  --tlp-pink: #e71786;
  --tlp-gray: #d8d3d0;
  --tlp-light: #f7f5f1;
  --tlp-white: #fff;
  --tlp-max: 1080px;
  --tlp-side: clamp(20px, 5vw, 56px);
  --tlp-radius: 12px;
  --tlp-shadow: 0 20px 50px rgba(0,0,0,.16);
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  background: #fff;
  color: var(--tlp-ink);
  font-family: "Noto Sans JP", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  letter-spacing: .02em;
  line-height: 1.9;
}
img { display: block; max-width: 100%; height: auto; }
a { color: inherit; }

.tlp {
  width: 100%;
  overflow: hidden;
  background: #fff;
}
.tlp-container {
  width: min(var(--tlp-max), calc(100% - var(--tlp-side) * 2));
  margin-inline: auto;
}
.tlp-visually-hidden {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0,0,0,0);
  white-space: nowrap;
  border: 0;
}

/* Header */
.tlp-header {
  position: relative;
  z-index: 10;
  background: var(--tlp-black);
  color: #fff;
}
.tlp-header__inner {
  min-height: 72px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
}
.tlp-header__brand {
  text-decoration: none;
  font-family: "Oswald", "Noto Sans JP", sans-serif;
  font-weight: 700;
  font-size: clamp(22px, 2vw, 30px);
  letter-spacing: .01em;
  line-height: 1;
}
.tlp-header__nav {
  display: flex;
  align-items: center;
  gap: clamp(16px, 2vw, 30px);
  font-size: 14px;
  font-weight: 500;
}
.tlp-header__nav a {
  text-decoration: none;
  opacity: .9;
}
.tlp-header__nav a:hover { opacity: 1; }
.tlp-header__contact {
  min-width: 180px;
  min-height: 38px;
  padding: 8px 22px;
  border: 1px solid rgba(255,255,255,.72);
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
}

/* Hero */
.tlp-hero {
  position: relative;
  overflow: hidden;
  background: var(--tlp-yellow);
  min-height: clamp(620px, 62vw, 760px);
}
.tlp-hero__paint {
  position: absolute;
  pointer-events: none;
  user-select: none;
  z-index: 0;
}
.tlp-hero__paint--warm {
  width: min(830px, 66vw);
  top: -46px;
  right: -120px;
}
.tlp-hero__paint--cool {
  width: min(560px, 50vw);
  bottom: -170px;
  left: -230px;
  transform: rotate(-10deg);
}
.tlp-hero__inner {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: minmax(360px, .9fr) minmax(420px, 1.1fr);
  align-items: center;
  gap: 34px;
  min-height: clamp(620px, 62vw, 760px);
  padding: clamp(44px, 6vw, 74px) 0 52px;
}
.tlp-hero__copy {
  padding-top: 6px;
}
.tlp-hero__title {
  margin: 0 0 42px;
  display: grid;
  gap: 4px;
  width: fit-content;
}
.tlp-hero__mini {
  width: clamp(210px, 29vw, 360px);
  margin-left: -4px;
}
.tlp-hero__lead {
  position: relative;
  margin: 0 0 24px;
  font-size: clamp(25px, 3.4vw, 45px);
  font-weight: 500;
  line-height: 1.5;
  letter-spacing: .04em;
}
.tlp-hero__lead::after {
  content: none;
  display: none;
}
.tlp-price {
  width: fit-content;
  display: grid;
  grid-template-columns: 70px auto auto;
  align-items: stretch;
  border-top: 4px solid #0c0c0c;
  border-bottom: 4px solid #0c0c0c;
  color: #0c0c0c;
  background: rgba(239,181,29,.2);
}
.tlp-price__label {
  display: grid;
  place-items: center;
  padding: 6px 10px;
  border-right: 3px solid #0c0c0c;
  font-weight: 700;
  font-size: 17px;
  line-height: 1.15;
}
.tlp-price__main {
  padding: 2px 10px 4px 14px;
  font-family: "Oswald", "Noto Sans JP", sans-serif;
  font-size: clamp(64px, 7vw, 104px);
  font-weight: 700;
  line-height: .95;
  letter-spacing: -.03em;
}
.tlp-price__unit {
  padding: 18px 12px 0 0;
  font-weight: 700;
  font-size: clamp(26px, 3vw, 44px);
  line-height: 1;
  align-self: center;
  white-space: nowrap;
}
.tlp-price__unit small {
  display: block;
  font-size: 14px;
  line-height: 1;
  margin-bottom: 2px;
}
.tlp-hero__actions {
  display: flex;
  gap: 14px;
  align-items: center;
  flex-wrap: wrap;
  margin-top: 34px;
}
.tlp-hero__visual {
  position: relative;
  min-height: 480px;
  display: grid;
  align-items: end;
  justify-items: center;
}
.tlp-hero__trailer {
  position: relative;
  width: min(560px, 100%);
  filter: drop-shadow(0 18px 20px rgba(0,0,0,.18));
  transform: translateY(10px);
}
.tlp-hero__note {
  position: absolute;
  right: 6px;
  bottom: 44px;
  margin: 0;
  font-size: 11px;
  color: rgba(0,0,0,.55);
  font-weight: 400;
}

/* Buttons */
.tlp-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  min-height: 46px;
  padding: 10px 26px;
  border-radius: 0;
  border: 2px solid transparent;
  text-decoration: none;
  font-weight: 500;
  font-size: 15px;
  line-height: 1.2;
  transition: transform .18s ease, opacity .18s ease, background .18s ease;
}
.tlp-button:hover {
  transform: translateY(-2px);
  opacity: .92;
}
.tlp-button--dark {
  background: var(--tlp-black);
  color: #fff;
}
.tlp-button--line {
  border-color: var(--tlp-black);
  color: var(--tlp-black);
  background: transparent;
}
.tlp-button--outline-dark {
  border-color: var(--tlp-black);
  color: var(--tlp-black);
  background: #fff;
  min-width: 180px;
}
.tlp-button--white {
  background: #fff;
  color: var(--tlp-black);
  min-width: 190px;
}
.tlp-button--tel {
  border-color: #fff;
  color: #fff;
  min-width: 190px;
}

/* Common section */
.tlp-kicker {
  margin: 0 0 8px;
  color: var(--tlp-green);
  font-family: "Oswald", "Noto Sans JP", sans-serif;
  font-weight: 600;
  font-size: 13px;
  letter-spacing: .08em;
}
.tlp-kicker--green { color: var(--tlp-green); }
.tlp-section-title {
  margin: 0;
  font-size: clamp(28px, 3.3vw, 44px);
  line-height: 1.45;
  font-weight: 900;
  letter-spacing: .03em;
}
.tlp-section-title--compact {
  font-size: clamp(26px, 2.7vw, 38px);
}
.tlp-section-lead {
  margin: 18px 0 0;
  font-size: clamp(15px, 1.35vw, 18px);
  font-weight: 400;
  line-height: 2.15;
}

/* About */
.tlp-about {
  position: relative;
  background: #fff;
  padding: clamp(76px, 9vw, 112px) 0 clamp(76px, 9vw, 112px);
}
.tlp-about__paint {
  position: absolute;
  left: -285px;
  top: -130px;
  width: min(680px, 80vw);
  opacity: .18;
  transform: rotate(-12deg);
  pointer-events: none;
}
.tlp-about > .tlp-container {
  position: relative;
  z-index: 1;
}
.tlp-about__cards {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 30px;
  margin-top: 48px;
}
.tlp-note-card {
  background: #ddd8d6;
  border-radius: 8px;
  min-height: 178px;
  padding: clamp(24px, 3vw, 36px);
}
.tlp-note-card h3 {
  margin: 0 0 16px;
  font-size: clamp(20px, 2.1vw, 28px);
  line-height: 1.5;
  font-weight: 900;
}
.tlp-note-card p {
  margin: 0;
  font-size: 14px;
  font-weight: 400;
  line-height: 2.15;
}
.tlp-features {
  margin-top: clamp(68px, 8vw, 96px);
}
.tlp-feature-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 28px;
  margin-top: 36px;
}
.tlp-feature-card {
  display: grid;
  grid-template-columns: 86px 1fr;
  align-items: center;
  gap: 12px;
  min-height: 105px;
  padding: 28px 34px;
  border-radius: 8px;
  background: var(--tlp-green);
  color: #fff;
}
.tlp-feature-card__num {
  font-family: "Oswald", "Noto Sans JP", sans-serif;
  font-size: clamp(38px, 5vw, 55px);
  font-weight: 500;
  line-height: 1;
  color: rgba(255,255,255,.55);
}
.tlp-feature-card h3 {
  margin: 0 0 4px;
  font-size: clamp(18px, 1.65vw, 23px);
  font-weight: 900;
  line-height: 1.35;
}
.tlp-feature-card p {
  margin: 0;
  font-size: 12px;
  font-weight: 400;
  opacity: .95;
  line-height: 1.85;
}

/* Use cases */
.tlp-usecase {
  background: var(--tlp-yellow);
  padding: clamp(78px, 9vw, 112px) 0 clamp(82px, 9vw, 118px);
}
.tlp-use-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 28px;
  margin-top: 50px;
}
.tlp-use-card {
  border-radius: 8px;
  overflow: hidden;
  color: #fff;
  background: #333;
  box-shadow: 0 18px 34px rgba(0,0,0,.14);
}
.tlp-use-card img {
  width: 100%;
  height: 170px;
  object-fit: cover;
}
.tlp-use-card div {
  min-height: 148px;
  padding: 24px 20px 26px;
}
.tlp-use-card span {
  display: block;
  margin-bottom: 14px;
  font-size: clamp(18px, 1.8vw, 22px);
  font-weight: 900;
  text-align: center;
  letter-spacing: .03em;
}
.tlp-use-card p {
  margin: 0;
  font-size: 12px;
  line-height: 1.8;
  font-weight: 400;
}
.tlp-use-card--blue div { background: var(--tlp-blue); }
.tlp-use-card--orange div { background: var(--tlp-orange); }
.tlp-use-card--pink div { background: var(--tlp-pink); }
.tlp-use-card--purple div { background: var(--tlp-purple); }

/* Benefit */
.tlp-benefit {
  background: #171712;
  color: #fff;
  padding: clamp(62px, 7vw, 88px) 0;
}
.tlp-benefit__inner {
  max-width: 1030px;
}
.tlp-benefit p {
  margin: 0;
  font-size: clamp(15px, 1.55vw, 20px);
  line-height: 2.25;
  font-weight: 400;
  letter-spacing: .02em;
}
.tlp-benefit p + p { margin-top: 18px; }

/* Legal */
.tlp-band {
  display: grid;
  place-items: center;
  min-height: 62px;
  color: #fff;
  font-weight: 900;
  font-size: clamp(18px, 1.8vw, 25px);
  letter-spacing: .08em;
}
.tlp-band--orange { background: var(--tlp-orange); }
.tlp-band--dark { background: #161616; }
.tlp-legal {
  background: #fff;
}
.tlp-legal__inner {
  padding: 56px 0 72px;
}
.tlp-table-wrap {
  width: 100%;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}
.tlp-compare-table {
  width: 100%;
  min-width: 760px;
  border-collapse: separate;
  border-spacing: 4px;
  text-align: center;
  table-layout: fixed;
}
.tlp-compare-table th,
.tlp-compare-table td {
  padding: 18px 14px;
  font-size: 14px;
  line-height: 1.8;
  font-weight: 400;
  background: #d1cdca;
}
.tlp-compare-table thead th {
  color: #fff;
  background: #555b64;
  font-weight: 600;
}
.tlp-compare-table thead .tlp-th-kind,
.tlp-compare-table tbody th {
  color: #fff;
  background: #5f90ce;
  font-weight: 600;
}
.tlp-compare-table thead .tlp-th-trailer {
  background: var(--tlp-orange);
}
.tlp-td-em {
  color: var(--tlp-orange);
  font-weight: 600;
}
.tlp-compare-table small {
  display: block;
  font-size: 11px;
  font-weight: 400;
}
.tlp-small-note {
  margin: 12px 0 0;
  font-size: 11px;
  color: #333;
  line-height: 1.85;
}

/* Disaster */
.tlp-disaster {
  background: #fff;
}
.tlp-disaster__inner {
  display: grid;
  grid-template-columns: 1fr 230px;
  gap: 54px;
  align-items: center;
  padding: clamp(60px, 8vw, 92px) 0;
}
.tlp-disaster__copy p {
  margin: 0;
  font-size: clamp(15px, 1.35vw, 18px);
  font-weight: 400;
  line-height: 2.15;
}
.tlp-disaster__copy h3 {
  margin: 28px 0 10px;
  font-size: 16px;
  font-weight: 700;
}
.tlp-disaster__copy ul {
  margin: 0 0 26px;
  padding-left: 0;
  list-style: none;
  font-size: 14px;
  font-weight: 400;
  line-height: 2.05;
}
.tlp-disaster__copy li::before {
  content: "○";
  margin-right: .25em;
}
.tlp-disaster__visual {
  display: grid;
  justify-items: center;
  align-items: center;
  min-height: 190px;
}
.tlp-disaster__visual img {
  width: 210px;
  opacity: .95;
}

/* Spec */
.tlp-spec {
  background: #fff;
}
.tlp-spec__box {
  background: #d6d1cf;
  padding: clamp(58px, 7vw, 84px) clamp(22px, 6vw, 70px) clamp(64px, 8vw, 96px);
}
.tlp-spec-table {
  width: 100%;
  border-collapse: collapse;
  margin-top: 32px;
  border-top: 3px solid #222;
  border-bottom: 3px solid #222;
}
.tlp-spec-table th,
.tlp-spec-table td {
  padding: 24px 16px;
  border-bottom: 1px solid #333;
  text-align: left;
  vertical-align: top;
  font-size: 14px;
  line-height: 2;
  font-weight: 400;
}
.tlp-spec-table tr:last-child th,
.tlp-spec-table tr:last-child td { border-bottom: 0; }
.tlp-spec-table th {
  width: 230px;
  white-space: nowrap;
  font-weight: 500;
}

/* Contact */
.tlp-contact {
  background: #171814;
  color: #fff;
  padding: clamp(76px, 9vw, 110px) 0 clamp(78px, 10vw, 124px);
}
.tlp-contact__inner {
  max-width: 1030px;
  padding-top: 28px;
  border-top: 1px solid rgba(255,255,255,.08);
}
.tlp-contact h2 {
  margin: 0 0 22px;
  font-size: clamp(30px, 3.6vw, 48px);
  font-weight: 900;
  line-height: 1.5;
  letter-spacing: .03em;
}
.tlp-contact p {
  margin: 0;
  font-size: 14px;
  font-weight: 400;
  line-height: 2.15;
}
.tlp-contact__actions {
  display: flex;
  align-items: center;
  gap: 24px;
  flex-wrap: wrap;
  margin-top: 36px;
}
.tlp-footer {
  display: grid;
  place-items: center;
  min-height: 50px;
  background: #fff;
  color: #777;
  font-size: 12px;
}

@media (max-width: 920px) {
  .tlp-header__nav a:not(.tlp-header__contact) { display: none; }
  .tlp-hero { min-height: auto; }
  .tlp-hero__inner {
    grid-template-columns: 1fr;
    gap: 12px;
    padding-top: 48px;
    min-height: auto;
  }
  .tlp-hero__copy { position: relative; z-index: 2; }
  .tlp-hero__visual {
    min-height: auto;
    margin-top: -10px;
  }
  .tlp-hero__trailer {
    width: min(530px, 92vw);
  }
  .tlp-hero__note {
    position: static;
    margin-top: -22px;
    text-align: right;
    width: 100%;
  }
  .tlp-about__cards,
  .tlp-feature-grid { grid-template-columns: 1fr; }
  .tlp-use-grid { grid-template-columns: 1fr 1fr; }
  .tlp-disaster__inner {
    grid-template-columns: 1fr;
    gap: 26px;
  }
  .tlp-disaster__visual { order: -1; min-height: auto; }
  .tlp-disaster__visual img { width: 170px; }
}

@media (max-width: 640px) {
  :root { --tlp-side: 18px; }
  body { line-height: 1.85; }
  .tlp-header__inner { min-height: 64px; }
  .tlp-header__brand { font-size: 18px; }
  .tlp-header__contact {
    min-width: 136px;
    min-height: 34px;
    padding: 7px 13px;
    font-size: 12px;
  }
  .tlp-hero__paint--warm {
    width: 110vw;
    right: -46vw;
    top: -18px;
  }
  .tlp-hero__paint--cool {
    width: 84vw;
    left: -48vw;
    bottom: 210px;
    opacity: .9;
  }
  .tlp-hero__title { margin-bottom: 32px; }
  .tlp-hero__lead { font-size: clamp(25px, 8vw, 36px); }
  .tlp-hero__lead::after { display: none; }
  .tlp-price {
    grid-template-columns: 56px auto auto;
  }
  .tlp-price__label { font-size: 14px; }
  .tlp-price__main { font-size: 62px; padding-left: 10px; }
  .tlp-price__unit { font-size: 26px; padding-right: 8px; }
  .tlp-hero__actions { gap: 10px; }
  .tlp-button {
    width: 100%;
    min-height: 48px;
  }
  .tlp-about,
  .tlp-usecase { padding-block: 66px; }
  .tlp-section-title { font-size: 27px; line-height: 1.55; }
  .tlp-section-lead br { display: none; }
  .tlp-note-card { padding: 24px; }
  .tlp-feature-card {
    grid-template-columns: 62px 1fr;
    padding: 24px 20px;
  }
  .tlp-use-grid { grid-template-columns: 1fr; }
  .tlp-use-card img { height: 210px; }
  .tlp-benefit p { font-size: 14px; line-height: 2.15; font-weight: 400; }
  .tlp-band { min-height: 54px; font-size: 17px; }
  .tlp-legal__inner { padding: 44px 0 56px; }
  .tlp-small-note { font-size: 10px; }
  .tlp-disaster__inner { padding: 56px 0; }
  .tlp-spec__box {
    width: 100%;
    padding: 48px 20px 56px;
  }
  .tlp-spec-table,
  .tlp-spec-table tbody,
  .tlp-spec-table tr,
  .tlp-spec-table th,
  .tlp-spec-table td {
    display: block;
    width: 100%;
  }
  .tlp-spec-table th {
    padding-bottom: 4px;
    border-bottom: 0;
    white-space: normal;
    color: rgba(0,0,0,.72);
  }
  .tlp-spec-table td { padding-top: 0; }
  .tlp-contact__actions { gap: 12px; }
}

/* ===== 2026-05 追加修正 ===== */
html {
  scroll-padding-top: 88px;
}
.tlp {
  overflow-x: clip;
  overflow-y: visible;
}
.tlp-header {
  position: sticky;
  top: 0;
  z-index: 1000;
  box-shadow: 0 10px 24px rgba(0,0,0,.12);
}
.tlp-header__nav {
  gap: 0;
}
.tlp-header__contact {
  min-width: 178px;
  min-height: 42px;
  background: #fff;
  color: var(--tlp-black);
  border-color: #fff;
  font-weight: 600;
  opacity: 1;
}
.tlp-header__contact img,
.tlp-button img {
  width: 20px;
  height: 20px;
  object-fit: contain;
  flex: 0 0 auto;
}
.tlp-icon--tel {
  filter: invert(1);
}
.tlp-hero__title {
  margin-bottom: 36px;
}
.tlp-hero__mini {
  width: min(540px, 88vw);
  max-width: 100%;
}
.tlp-about__cards--single {
  grid-template-columns: minmax(0, 1fr);
  max-width: 760px;
}
.tlp-feature-grid {
  gap: 32px;
}
.tlp-feature-card {
  min-height: 190px;
  padding: 46px 48px;
}
.tlp-feature-card h3 {
  font-size: clamp(21px, 2.1vw, 29px);
}
.tlp-feature-card p {
  font-size: clamp(14px, 1.35vw, 17px);
  line-height: 1.95;
}
.tlp-use-grid {
  gap: 34px;
  margin-top: 56px;
}
.tlp-use-card img {
  height: 330px;
}
.tlp-use-card div {
  min-height: 190px;
  padding: 30px 26px 34px;
}
.tlp-use-card span {
  font-size: clamp(22px, 2.2vw, 30px);
}
.tlp-use-card p {
  font-size: clamp(14px, 1.35vw, 17px);
  line-height: 2;
}
.tlp-benefit p {
  font-size: clamp(22px, 2.25vw, 30px);
  line-height: 1.95;
  font-weight: 400;
}
.tlp-banner {
  background: #fff;
  padding: clamp(50px, 7vw, 90px) 0;
}
.tlp-banner__link {
  display: block;
  overflow: hidden;
  border-radius: 8px;
  box-shadow: 0 20px 48px rgba(0,0,0,.13);
  transition: transform .18s ease, opacity .18s ease;
}
.tlp-banner__link:hover {
  transform: translateY(-2px);
  opacity: .96;
}
.tlp-banner__link img {
  width: 100%;
}
.tlp-compare-table tbody td {
  background: #eeece9;
}
.tlp-disaster__lead {
  font-size: clamp(28px, 2.8vw, 36px) !important;
  line-height: 1.85 !important;
  font-weight: 400 !important;
}
.tlp-dtrace-link {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  margin-top: 28px;
  color: var(--tlp-orange);
  font-size: clamp(18px, 1.7vw, 24px);
  font-weight: 700;
  text-decoration: none;
  border-bottom: 2px solid currentColor;
}
.tlp-dtrace-link::after {
  content: "↗";
  font-size: .95em;
}
.tlp-spec {
  padding-bottom: clamp(82px, 10vw, 132px);
}
.tlp-spec__box {
  background: #eeebe8;
}
.tlp-button--white,
.tlp-button--tel {
  background: #fff;
  color: var(--tlp-black);
  border-color: #fff;
}
.tlp-button--outline-dark img {
  width: 20px;
  height: 20px;
}

@media (max-width: 920px) {
  .tlp-hero__mini {
    width: min(500px, 88vw);
  }
  .tlp-use-grid {
    grid-template-columns: 1fr 1fr;
  }
  .tlp-use-card img {
    height: 300px;
  }
  .tlp-disaster__lead {
    font-size: clamp(24px, 4.6vw, 32px) !important;
  }
}

@media (max-width: 640px) {
  html {
    scroll-padding-top: 76px;
  }
  .tlp-header__brand {
    font-size: 16px;
  }
  .tlp-header__contact {
    min-width: 132px;
    min-height: 36px;
    padding: 7px 12px;
    font-size: 12px;
  }
  .tlp-header__contact img,
  .tlp-button img {
    width: 17px;
    height: 17px;
  }
  .tlp-hero__mini {
    width: min(430px, 90vw);
  }
  .tlp-feature-card {
    min-height: 158px;
    padding: 30px 24px;
  }
  .tlp-feature-card h3 {
    font-size: 21px;
  }
  .tlp-feature-card p {
    font-size: 14px;
  }
  .tlp-use-grid {
    grid-template-columns: 1fr;
  }
  .tlp-use-card img {
    height: 300px;
  }
  .tlp-benefit p {
    font-size: 19px;
    line-height: 2;
  }
  .tlp-banner {
    padding: 46px 0 58px;
  }
  .tlp-disaster__lead {
    font-size: 20px !important;
    line-height: 1.95 !important;
  }
  .tlp-dtrace-link {
    font-size: 17px;
    line-height: 1.5;
  }
}


/* ===== 2026-05 追加修正 2 ===== */
/* 全体のボールド感を抑え、見出しはサイズ・余白・装飾でメリハリを出す */
.tlp,
.tlp * {
  font-weight: 400 !important;
}

body {
  line-height: 2.05;
}

.tlp-section-lead,
.tlp-note-card p,
.tlp-benefit p,
.tlp-disaster__copy p,
.tlp-disaster__copy ul,
.tlp-spec-table th,
.tlp-spec-table td,
.tlp-compare-table th,
.tlp-compare-table td,
.tlp-contact p {
  line-height: 2.25;
}

/* セクション切り替わりのホワイトスペースを拡張 */
.tlp-about {
  padding-top: clamp(104px, 12vw, 156px);
  padding-bottom: clamp(110px, 13vw, 168px);
}
.tlp-usecase {
  padding-top: clamp(108px, 12vw, 160px);
  padding-bottom: clamp(112px, 13vw, 170px);
}
.tlp-benefit {
  padding-top: clamp(88px, 10vw, 132px);
  padding-bottom: clamp(90px, 11vw, 138px);
}
.tlp-banner {
  padding-top: clamp(78px, 9vw, 124px);
  padding-bottom: clamp(82px, 10vw, 132px);
}
.tlp-legal__inner {
  padding-top: clamp(78px, 9vw, 118px);
  padding-bottom: clamp(94px, 11vw, 150px);
}
.tlp-disaster__inner {
  padding-top: clamp(88px, 10vw, 138px);
  padding-bottom: clamp(92px, 11vw, 148px);
}
.tlp-spec {
  padding-top: clamp(78px, 9vw, 124px);
  padding-bottom: clamp(118px, 14vw, 188px);
}
.tlp-contact {
  padding-top: clamp(100px, 12vw, 158px);
  padding-bottom: clamp(104px, 13vw, 170px);
}

/* FUNCTIONS：面積・サイズ・視覚的なインパクトを強化 */
.tlp-features {
  position: relative;
  isolation: isolate;
  margin-top: clamp(90px, 10vw, 132px);
  padding: clamp(54px, 6vw, 76px) clamp(20px, 4vw, 44px) clamp(60px, 7vw, 84px);
  background:
    radial-gradient(circle at 86% 18%, rgba(235, 91, 42, .14) 0 15%, transparent 16%),
    linear-gradient(135deg, rgba(73, 181, 151, .16), rgba(73, 181, 151, .06));
  border-top: 1px solid rgba(73, 181, 151, .38);
  border-bottom: 1px solid rgba(73, 181, 151, .38);
}
.tlp-features::before {
  content: "04";
  position: absolute;
  right: clamp(10px, 4vw, 46px);
  top: clamp(-28px, -2vw, -14px);
  z-index: -1;
  font-family: "Oswald", "Noto Sans JP", sans-serif;
  font-size: clamp(100px, 16vw, 190px);
  line-height: .85;
  letter-spacing: -.04em;
  color: rgba(73, 181, 151, .18);
}
.tlp-features .tlp-kicker {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 14px;
  color: #159477;
  font-size: clamp(19px, 2.1vw, 28px);
  letter-spacing: .16em;
}
.tlp-features .tlp-kicker::before {
  content: "";
  width: clamp(44px, 6vw, 76px);
  height: 2px;
  background: currentColor;
}
.tlp-features .tlp-section-title--compact {
  position: relative;
  width: fit-content;
  padding-bottom: 18px;
  font-size: clamp(46px, 7vw, 78px);
  line-height: 1.05;
  letter-spacing: .06em;
}
.tlp-features .tlp-section-title--compact::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: 0;
  width: 112%;
  height: 10px;
  background: var(--tlp-orange);
  transform: skewX(-16deg);
  opacity: .86;
}
.tlp-feature-grid {
  margin-top: clamp(54px, 6vw, 74px);
  gap: clamp(30px, 4vw, 46px);
}
.tlp-feature-card {
  min-height: 205px;
  padding: clamp(42px, 5vw, 60px) clamp(34px, 5vw, 58px);
}
.tlp-feature-card h3 {
  font-size: clamp(23px, 2.45vw, 34px);
  line-height: 1.45;
}
.tlp-feature-card p {
  margin-top: 10px;
  font-size: clamp(15px, 1.55vw, 19px);
  line-height: 2.05;
}

/* USE CASE：PCで2列×2段。写真は横長にトリミング */
.tlp-use-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: clamp(34px, 4.5vw, 52px);
  margin-top: clamp(58px, 7vw, 84px);
}
.tlp-use-card img {
  height: clamp(230px, 24vw, 285px);
  object-fit: cover;
  object-position: center;
}
.tlp-use-card div {
  min-height: 150px;
  padding: clamp(28px, 3vw, 36px) clamp(28px, 3.5vw, 40px) clamp(32px, 3.5vw, 42px);
}
.tlp-use-card span {
  margin-bottom: 16px;
  font-size: clamp(25px, 2.6vw, 36px);
  line-height: 1.35;
}
.tlp-use-card p {
  font-size: clamp(15px, 1.6vw, 20px);
  line-height: 2.05;
}

@media (max-width: 920px) {
  .tlp-use-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .tlp-use-card img {
    height: clamp(210px, 30vw, 260px);
  }
}

@media (max-width: 640px) {
  body {
    line-height: 1.95;
  }
  .tlp-about,
  .tlp-usecase,
  .tlp-contact {
    padding-top: 82px;
    padding-bottom: 88px;
  }
  .tlp-benefit,
  .tlp-disaster__inner {
    padding-top: 76px;
    padding-bottom: 82px;
  }
  .tlp-banner {
    padding-top: 62px;
    padding-bottom: 70px;
  }
  .tlp-legal__inner {
    padding-top: 62px;
    padding-bottom: 76px;
  }
  .tlp-spec {
    padding-top: 64px;
    padding-bottom: 104px;
  }
  .tlp-features {
    margin-top: 78px;
    padding: 44px 18px 52px;
  }
  .tlp-features::before {
    font-size: 108px;
    right: 8px;
    top: -18px;
  }
  .tlp-features .tlp-kicker {
    font-size: 18px;
  }
  .tlp-features .tlp-section-title--compact {
    font-size: clamp(38px, 12vw, 52px);
  }
  .tlp-feature-card {
    min-height: 168px;
    padding: 30px 22px;
  }
  .tlp-use-grid {
    grid-template-columns: 1fr;
    gap: 32px;
  }
  .tlp-use-card img {
    height: 225px;
  }
  .tlp-use-card span {
    font-size: 26px;
  }
  .tlp-use-card p {
    font-size: 15px;
  }
}


/* ===== 2026-05-11 差し替え修正 v5 ===== */
/* Hero adjustments */
.tlp-hero__title {
  gap: 10px;
  margin-bottom: 30px;
}
.tlp-hero__jp-title {
  display: block;
  font-size: clamp(20px, 2.3vw, 34px);
  line-height: 1.45;
  letter-spacing: .06em;
  color: var(--tlp-black);
}
.tlp-hero__lead {
  line-height: 1.58;
}
.tlp-hero__lead span {
  display: block;
  white-space: nowrap;
}
.tlp-price-image {
  width: min(500px, 92vw);
  max-width: 100%;
  margin-top: 20px;
}

/* Replacement overview / points from 差し替え_1.pdf */
.tlp-overview {
  background: #fff;
  padding: 0 0 clamp(72px, 8vw, 120px);
}
.tlp-overview__bar {
  border-top: 18px solid var(--tlp-yellow);
  background: #1b1110;
  color: #fff;
  padding: clamp(34px, 4vw, 54px) var(--tlp-side) clamp(28px, 3.5vw, 46px);
  font-size: clamp(36px, 5.4vw, 70px);
  line-height: 1.45;
  letter-spacing: .04em;
}
.tlp-overview__bar span {
  display: block;
  width: min(var(--tlp-max), calc(100% - var(--tlp-side) * 2));
  margin-inline: auto;
}
.tlp-overview__leadbox {
  padding: clamp(34px, 4vw, 54px) 0 clamp(54px, 6vw, 76px);
}
.tlp-overview__leadbox p {
  margin: 0;
  font-size: clamp(17px, 1.55vw, 22px);
  line-height: 2.05;
  letter-spacing: .04em;
}
.tlp-points-title {
  font-family: "Oswald", "Noto Sans JP", sans-serif;
  font-size: clamp(38px, 5.6vw, 68px);
  line-height: 1;
  letter-spacing: .03em;
  margin-bottom: 18px;
  color: #1b1110;
}
.tlp-point-rows {
  display: grid;
  gap: clamp(28px, 4vw, 44px);
}
.tlp-point-row {
  background: #5e6268;
  color: #fff;
  min-height: clamp(230px, 21vw, 310px);
  display: grid;
  align-items: center;
}
.tlp-point-row__inner {
  display: grid;
  grid-template-columns: 1fr minmax(280px, 40%);
  gap: clamp(28px, 5vw, 70px);
  align-items: center;
}
.tlp-point-row__copy {
  display: grid;
  grid-template-columns: clamp(48px, 5vw, 72px) 1fr;
  gap: clamp(18px, 2.6vw, 34px);
  align-items: start;
}
.tlp-point-row__check {
  width: clamp(42px, 4.5vw, 66px);
  margin-top: .3em;
}
.tlp-point-row__copy h3 {
  margin: 0 0 12px;
  font-size: clamp(31px, 4vw, 54px);
  line-height: 1.35;
  letter-spacing: .06em;
}
.tlp-point-row__copy p {
  margin: 0;
  font-size: clamp(14px, 1.35vw, 18px);
  line-height: 2.05;
  letter-spacing: .03em;
}
.tlp-point-row__icon {
  width: 100%;
  max-height: 220px;
  object-fit: contain;
  justify-self: end;
}
.tlp-point-row__icon--parking {
  max-width: 440px;
}
.tlp-point-row__icon--towable {
  max-width: 480px;
}

/* New USE CASE */
.tlp-usecase--new {
  background: var(--tlp-yellow);
  padding-top: clamp(78px, 9vw, 128px);
  padding-bottom: clamp(100px, 12vw, 170px);
}
.tlp-usecase__label {
  width: clamp(150px, 16vw, 230px);
  margin-bottom: clamp(24px, 3vw, 38px);
}
.tlp-usecase__title {
  margin: 0;
  font-size: clamp(34px, 4.6vw, 64px);
  line-height: 1.55;
  letter-spacing: .04em;
  color: #111;
}
.tlp-usecase__lead {
  margin: clamp(28px, 3.5vw, 46px) 0 0;
  font-size: clamp(16px, 1.6vw, 21px);
  line-height: 2.1;
  color: #111;
}
.tlp-usecase--new .tlp-use-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: clamp(40px, 4.8vw, 62px);
  margin-top: clamp(56px, 7vw, 90px);
  padding: clamp(28px, 4vw, 46px);
  background: rgba(226, 160, 25, .32);
}
.tlp-usecase--new .tlp-use-card img {
  height: clamp(235px, 23vw, 315px);
  object-fit: cover;
  object-position: center;
}
.tlp-usecase--new .tlp-use-card div {
  min-height: 160px;
  padding: clamp(26px, 3vw, 36px) clamp(24px, 3vw, 36px) clamp(30px, 3.2vw, 42px);
}
.tlp-usecase--new .tlp-use-card span {
  font-size: clamp(25px, 2.6vw, 36px);
}
.tlp-usecase--new .tlp-use-card p {
  font-size: clamp(15px, 1.45vw, 19px);
  line-height: 2.05;
}

/* Benefit size lowered by approx. 2pt */
.tlp-benefit p {
  font-size: clamp(20px, 2.05vw, 28px) !important;
  line-height: 2.05 !important;
}

/* Trailer house size section from 差し替え_2.pdf */
.tlp-size {
  background: #fff;
  padding-bottom: clamp(86px, 10vw, 150px);
}
.tlp-size__bar {
  display: grid;
  place-items: center;
  min-height: clamp(76px, 8vw, 120px);
  border-top: 18px solid var(--tlp-yellow);
  background: #666a6e;
  color: #fff;
  font-size: clamp(28px, 3.4vw, 50px);
  line-height: 1.3;
  letter-spacing: .06em;
}
.tlp-size__inner {
  padding-top: clamp(70px, 9vw, 130px);
}
.tlp-size-grid {
  display: grid;
  grid-template-columns: minmax(170px, .75fr) minmax(260px, 1fr) minmax(320px, 1.32fr);
  align-items: end;
  gap: clamp(34px, 5vw, 82px);
}
.tlp-size-card {
  margin: 0;
  text-align: center;
}
.tlp-size-card figcaption {
  margin-bottom: clamp(22px, 3vw, 38px);
  font-family: "Oswald", "Noto Sans JP", sans-serif;
  font-size: clamp(20px, 2vw, 30px);
  line-height: 1.4;
  color: #241817;
  letter-spacing: .03em;
}
.tlp-size-card img {
  width: 100%;
  max-height: 260px;
  object-fit: contain;
}
.tlp-size-card--mini img { max-width: 260px; margin-inline: auto; }
.tlp-size-card--half img { max-width: 390px; margin-inline: auto; }
.tlp-size-card--long img { max-width: 510px; margin-inline: auto; }
.tlp-size__note {
  margin: clamp(50px, 6vw, 80px) 0 0;
  font-size: clamp(18px, 1.75vw, 25px);
  line-height: 1.8;
  color: #241817;
}
.tlp-size-banner {
  display: block;
  width: min(960px, 100%);
  margin: clamp(70px, 9vw, 120px) auto 0;
  overflow: hidden;
  box-shadow: 0 18px 40px rgba(0,0,0,.12);
  transition: opacity .18s ease, transform .18s ease;
}
.tlp-size-banner:hover {
  opacity: .96;
  transform: translateY(-2px);
}
.tlp-size-banner img {
  width: 100%;
}

/* Disaster adjustments */
.tlp-disaster__inner {
  grid-template-columns: minmax(0, 1fr) minmax(360px, 48%);
}
.tlp-disaster__lead {
  font-size: clamp(26px, 2.55vw, 34px) !important;
  line-height: 1.9 !important;
}
.tlp-disaster__copy ul {
  font-size: clamp(16px, 1.55vw, 20px) !important;
  line-height: 2.05 !important;
  margin-top: 16px;
}
.tlp-disaster__copy h3 {
  font-size: clamp(18px, 1.65vw, 22px) !important;
  margin-top: clamp(34px, 4vw, 48px);
}
.tlp-disaster__visual img {
  width: min(520px, 100%);
  opacity: 1;
}

/* Contact label and company */
.tlp-contact__label {
  width: clamp(210px, 26vw, 360px);
  margin-bottom: clamp(26px, 3.4vw, 44px);
}
.tlp-contact__company {
  margin-top: 24px !important;
  font-size: clamp(15px, 1.4vw, 18px) !important;
  letter-spacing: .05em;
}

/* Button background width 1.5x, keeping icon/text size */
.tlp-header__contact {
  min-width: 267px;
}
.tlp-button--white,
.tlp-button--tel,
.tlp-button--outline-dark {
  min-width: 285px;
}
.tlp-contact__actions .tlp-button {
  padding-inline: 34px;
}

@media (max-width: 920px) {
  .tlp-hero__lead span { white-space: normal; }
  .tlp-overview__bar { font-size: clamp(32px, 6vw, 54px); }
  .tlp-point-row__inner {
    grid-template-columns: 1fr;
    gap: 24px;
    padding-block: 34px;
  }
  .tlp-point-row__icon {
    justify-self: center;
    max-width: min(420px, 82vw);
  }
  .tlp-size-grid {
    grid-template-columns: 1fr;
    gap: 58px;
  }
  .tlp-size-card img {
    max-width: min(560px, 100%) !important;
  }
  .tlp-disaster__inner {
    grid-template-columns: 1fr;
  }
  .tlp-disaster__visual img {
    width: min(560px, 100%);
  }
}

@media (max-width: 640px) {
  .tlp-hero__jp-title {
    font-size: clamp(18px, 5.1vw, 25px);
  }
  .tlp-price-image {
    width: min(430px, 96vw);
  }
  .tlp-overview {
    padding-bottom: 72px;
  }
  .tlp-overview__bar {
    border-top-width: 12px;
    padding-block: 30px;
    font-size: clamp(30px, 8.2vw, 42px);
  }
  .tlp-overview__leadbox p br,
  .tlp-usecase__lead br {
    display: none;
  }
  .tlp-points-title {
    font-size: 42px;
  }
  .tlp-point-row {
    min-height: auto;
  }
  .tlp-point-row__copy {
    grid-template-columns: 42px 1fr;
  }
  .tlp-point-row__copy h3 {
    font-size: clamp(24px, 7.2vw, 33px);
  }
  .tlp-usecase--new .tlp-use-grid {
    grid-template-columns: 1fr;
    padding: 18px;
  }
  .tlp-usecase__title {
    font-size: clamp(28px, 7.7vw, 39px);
  }
  .tlp-size__bar {
    border-top-width: 12px;
  }
  .tlp-size__note {
    font-size: 16px;
  }
  .tlp-benefit p {
    font-size: 17px !important;
    line-height: 2.05 !important;
  }
  .tlp-disaster__lead {
    font-size: 18px !important;
    line-height: 2 !important;
  }
  .tlp-disaster__copy ul {
    font-size: 15px !important;
  }
  .tlp-header__contact {
    min-width: 198px;
  }
  .tlp-button--white,
  .tlp-button--tel,
  .tlp-button--outline-dark {
    min-width: 100%;
  }
}

@media (max-width: 420px) {
  .tlp-header__brand {
    display: none;
  }
  .tlp-header__inner {
    justify-content: center;
  }
  .tlp-header__contact {
    min-width: min(230px, 100%);
  }
}

/* ===== 2026-05-11 微調整 v6 ===== */
/* キービジュアル：和文コピーを英字ロゴ幅内に収める */
.tlp-hero__title {
  width: min(540px, 88vw);
  max-width: 100%;
  gap: 8px;
}
.tlp-hero__jp-title {
  font-size: clamp(15px, 1.55vw, 23px) !important;
  line-height: 1.35;
  letter-spacing: .035em;
  white-space: nowrap;
  max-width: 100%;
}
.tlp-hero__mini {
  width: 100%;
  max-width: min(540px, 88vw);
}

/* 黒帯と黄色背景の間を詰める */
.tlp-overview__bar {
  border-top: 0 !important;
}

/* POINTS：画像差し替え＋上部ホワイトスペースを大きく */
.tlp-overview__leadbox {
  padding-bottom: clamp(120px, 14vw, 180px) !important;
}
.tlp-points-title {
  line-height: 1;
  margin-bottom: clamp(20px, 3vw, 34px) !important;
}
.tlp-points-title__image {
  width: clamp(180px, 24vw, 340px);
  height: auto;
}
.tlp-nowrap {
  white-space: nowrap;
}

/* USE CASE：カード周囲の黄色を背景色と合わせる */
.tlp-usecase--new .tlp-use-grid {
  background: var(--tlp-yellow) !important;
}

/* トレーラーハウスサイズ：帯を法的区分と同じ高さ・文字サイズへ */
.tlp-size__bar {
  border-top: 0 !important;
  min-height: 62px !important;
  font-size: clamp(18px, 1.8vw, 25px) !important;
  line-height: 1.35 !important;
}
.tlp-size__inner {
  padding-top: clamp(58px, 7vw, 92px) !important;
}
.tlp-size-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  align-items: start !important;
  gap: clamp(20px, 3.2vw, 44px) !important;
}
.tlp-size-card {
  display: grid;
  grid-template-rows: auto 1fr;
  align-items: start;
}
.tlp-size-card figcaption {
  min-height: 3.2em;
  display: grid;
  place-items: end center;
  margin-bottom: clamp(20px, 2.4vw, 32px) !important;
}
.tlp-size-card img,
.tlp-size-card--mini img,
.tlp-size-card--half img,
.tlp-size-card--long img {
  width: 100% !important;
  max-width: none !important;
  max-height: none !important;
  margin-inline: auto;
  object-fit: contain;
}

/* 災害対応車両登録制度：PCでは本文幅を広く取り、横方向に読みやすくする */
@media (min-width: 921px) {
  .tlp-disaster__inner {
    grid-template-columns: minmax(0, 1fr) 300px !important;
    align-items: end !important;
    gap: clamp(34px, 4vw, 56px) !important;
  }
  .tlp-disaster__copy {
    min-width: 0;
  }
  .tlp-disaster__lead {
    font-size: clamp(20px, 1.65vw, 25px) !important;
    line-height: 2.05 !important;
  }
  .tlp-disaster__visual {
    align-self: end;
    padding-top: 130px;
  }
  .tlp-disaster__visual img {
    width: 300px !important;
  }
}

@media (max-width: 920px) {
  .tlp-size-grid {
    grid-template-columns: 1fr !important;
    gap: 50px !important;
  }
  .tlp-size-card img,
  .tlp-size-card--mini img,
  .tlp-size-card--half img,
  .tlp-size-card--long img {
    width: 100% !important;
    max-width: min(680px, 100%) !important;
  }
}

@media (max-width: 640px) {
  .tlp-hero__title {
    width: min(430px, 90vw);
  }
  .tlp-hero__jp-title {
    font-size: clamp(14px, 4.2vw, 18px) !important;
    white-space: nowrap;
  }
  .tlp-overview__leadbox {
    padding-bottom: 96px !important;
  }
  .tlp-points-title__image {
    width: min(230px, 58vw);
  }
  .tlp-nowrap {
    white-space: normal;
  }
  .tlp-size-card figcaption {
    min-height: auto;
    margin-bottom: 16px !important;
  }
}

/* ===== 2026-05-12 微調整 v7 ===== */
/* ヘッダーお問い合わせ：背景を確実に白へ */
.tlp-header__contact,
.tlp-header__contact:visited {
  background: #fff !important;
  color: var(--tlp-black) !important;
  border-color: #fff !important;
  box-shadow: none !important;
}

/* キービジュアル：和文コピーをさらに控えめに */
.tlp-hero__jp-title {
  font-size: clamp(13px, 1.25vw, 19px) !important;
  letter-spacing: .025em !important;
}

/* POINTS：USE CASEラベルと同じ見え方に寄せる */
.tlp-points-title__image {
  width: clamp(150px, 16vw, 230px) !important;
}

/* POINTS：注釈追加に合わせて2段とも高さを揃える */
.tlp-point-row {
  min-height: clamp(300px, 27vw, 390px) !important;
}
.tlp-point-row__inner {
  grid-template-columns: minmax(0, 1fr) minmax(230px, 34%) !important;
}
.tlp-point-row__icon--parking {
  width: min(360px, 100%) !important;
  max-width: 360px !important;
  max-height: 165px !important;
}
.tlp-point-row__icon--towable {
  width: min(430px, 100%) !important;
  max-width: 430px !important;
  max-height: 165px !important;
}
.tlp-point-note {
  margin: 14px 0 0 !important;
  font-size: clamp(10px, .95vw, 13px) !important;
  line-height: 1.85 !important;
  color: rgba(255,255,255,.9) !important;
  letter-spacing: .02em !important;
}

/* USE CASE：背景差をさらに抑え、趣味部屋画像を自然に見せる */
.tlp-usecase--new .tlp-use-grid {
  background: transparent !important;
  padding-inline: 0 !important;
}
.tlp-use-card:first-child img {
  object-position: center center !important;
}

/* トレーラーハウスサイズ：画像の縦横比を保持、帯とバナーを調整 */
.tlp-size-card img,
.tlp-size-card--mini img,
.tlp-size-card--half img,
.tlp-size-card--long img {
  height: auto !important;
  aspect-ratio: auto !important;
  object-fit: contain !important;
  display: block !important;
}
.tlp-size-card--mini img {
  width: min(100%, 300px) !important;
}
.tlp-size-card--half img {
  width: min(100%, 380px) !important;
}
.tlp-size-card--long img {
  width: min(100%, 500px) !important;
}
.tlp-size-banner {
  box-shadow: none !important;
}
.tlp-size-banner:hover {
  transform: none !important;
}

/* 法的区分表：本文を少し大きく */
.tlp-compare-table th,
.tlp-compare-table td {
  font-size: clamp(15px, 1.25vw, 17px) !important;
  line-height: 1.9 !important;
}
.tlp-compare-table small {
  font-size: clamp(12px, 1vw, 13px) !important;
}

/* 災害対応車両登録制度：D-TRACEは控えめ、イラストは大きく */
.tlp-dtrace-link {
  font-size: clamp(14px, 1.25vw, 18px) !important;
  border-bottom-width: 1px !important;
}
@media (min-width: 921px) {
  .tlp-disaster__inner {
    grid-template-columns: minmax(0, 1fr) minmax(360px, 450px) !important;
    align-items: center !important;
  }
  .tlp-disaster__visual {
    padding-top: 80px !important;
  }
  .tlp-disaster__visual img {
    width: 450px !important;
    max-width: 100% !important;
  }
}

/* フッター：CONTACTをUSE CASEと同じサイズ感に、会社名リンクを自然に */
.tlp-contact__label {
  width: clamp(150px, 16vw, 230px) !important;
}
.tlp-contact__company a {
  color: inherit !important;
  text-decoration: none !important;
}
.tlp-contact__company a:hover {
  text-decoration: underline !important;
  text-underline-offset: .25em !important;
}

@media (max-width: 920px) {
  .tlp-point-row {
    min-height: auto !important;
  }
  .tlp-point-row__inner {
    grid-template-columns: 1fr !important;
  }
  .tlp-point-row__icon--parking,
  .tlp-point-row__icon--towable {
    width: min(420px, 82vw) !important;
    max-width: min(420px, 82vw) !important;
    max-height: 170px !important;
  }
  .tlp-point-note {
    font-size: 12px !important;
  }
  .tlp-size-card--mini img,
  .tlp-size-card--half img,
  .tlp-size-card--long img {
    width: min(680px, 100%) !important;
  }
}

@media (max-width: 640px) {
  .tlp-hero__jp-title {
    font-size: clamp(12px, 3.5vw, 16px) !important;
  }
  .tlp-points-title__image,
  .tlp-contact__label {
    width: min(210px, 54vw) !important;
  }
  .tlp-point-row__icon--parking,
  .tlp-point-row__icon--towable {
    width: min(360px, 86vw) !important;
    max-width: min(360px, 86vw) !important;
  }
}

/* ===== 2026-05-12 微調整 v8 ===== */
/* USE CASE：PCでカード高さが揃った時も、下部にグレーの隙間が出ないようにする */
.tlp-use-card {
  display: flex !important;
  flex-direction: column !important;
  height: 100% !important;
  background: transparent !important;
}
.tlp-use-card > div {
  flex: 1 1 auto !important;
}
.tlp-use-card--blue { background: var(--tlp-blue) !important; }
.tlp-use-card--orange { background: var(--tlp-orange) !important; }
.tlp-use-card--pink { background: var(--tlp-pink) !important; }
.tlp-use-card--purple { background: var(--tlp-purple) !important; }

/* トレーラーハウスサイズ：再送画像を縦横比そのままで表示 */
.tlp-size-card img,
.tlp-size-card--mini img,
.tlp-size-card--half img,
.tlp-size-card--long img {
  height: auto !important;
  object-fit: contain !important;
  object-position: center !important;
  aspect-ratio: auto !important;
}
.tlp-size-card--mini img {
  width: min(100%, 505px) !important;
  max-width: 100% !important;
}
.tlp-size-card--half img {
  width: min(100%, 713px) !important;
  max-width: 100% !important;
}
.tlp-size-card--long img {
  width: min(100%, 968px) !important;
  max-width: 100% !important;
}

/* ===== 2026-05-12 微調整 v9 ===== */
/* トレーラーハウスサイズ：再送画像を同一キャンバス幅で表示し、画像内の比率をそのまま見せる */
.tlp-size-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  align-items: start !important;
}
.tlp-size-card img,
.tlp-size-card--mini img,
.tlp-size-card--half img,
.tlp-size-card--long img {
  display: block !important;
  width: 100% !important;
  max-width: 100% !important;
  height: auto !important;
  aspect-ratio: auto !important;
  object-fit: contain !important;
  object-position: center center !important;
  transform: none !important;
}

@media (min-width: 921px) {
  .tlp-size-card figcaption {
    min-height: 3.2em !important;
    display: grid !important;
    place-items: end center !important;
  }
  .tlp-size-card img,
  .tlp-size-card--mini img,
  .tlp-size-card--half img,
  .tlp-size-card--long img {
    width: 100% !important;
  }
}

@media (max-width: 920px) {
  .tlp-size-card img,
  .tlp-size-card--mini img,
  .tlp-size-card--half img,
  .tlp-size-card--long img {
    width: min(760px, 100%) !important;
    max-width: 100% !important;
    margin-inline: auto !important;
  }
}

/* ===== 2026-05-12 校正後修正 v10 ===== */
/* キービジュアル：限定30台バッジを配置PDFに合わせて追加 */
.tlp-hero {
  overflow: visible !important;
}
.tlp-hero__limited {
  position: absolute;
  z-index: 30;
  width: clamp(128px, 15vw, 218px);
  left: clamp(54%, 62vw, 66%);
  bottom: clamp(-74px, -5.4vw, -42px);
  transform: translateX(-50%);
  filter: drop-shadow(0 14px 22px rgba(0,0,0,.18));
  pointer-events: none;
}
.tlp-overview {
  position: relative;
  z-index: 2;
}

/* トレーラーハウスサイズ比較は削除し、ハーフ・ロングバナーのみ残す */
.tlp-harflong {
  background: #fff;
  padding: clamp(72px, 8vw, 116px) 0 clamp(82px, 9vw, 128px);
}
.tlp-harflong__link {
  display: block;
  width: min(1080px, 100%);
  margin-inline: auto;
  text-decoration: none;
  border-radius: 0;
  overflow: hidden;
  box-shadow: none;
  transition: opacity .18s ease;
}
.tlp-harflong__link:hover {
  opacity: .94;
}
.tlp-harflong__link img {
  width: 100%;
  height: auto;
  display: block;
}

/* SP版：法的区分表の「種別」列を横スクロール時に固定 */
@media (max-width: 640px) {
  .tlp-table-wrap {
    position: relative;
  }
  .tlp-compare-table thead .tlp-th-kind,
  .tlp-compare-table tbody th {
    position: sticky;
    left: 0;
    box-shadow: 8px 0 0 rgba(255,255,255,.86);
  }
  .tlp-compare-table thead .tlp-th-kind {
    z-index: 8;
  }
  .tlp-compare-table tbody th {
    z-index: 7;
  }
}

/* フッター：会社名の前にWork Boxロゴを追加 */
.tlp-contact__workbox-logo {
  display: block;
  width: min(420px, 86vw);
  margin: clamp(30px, 4vw, 46px) 0 18px;
  padding: 14px 18px;
  background: #fff;
  text-decoration: none;
}
.tlp-contact__workbox-logo img {
  width: 100%;
  height: auto;
}
.tlp-contact__company {
  margin-top: 0 !important;
}

@media (max-width: 920px) {
  .tlp-hero__limited {
    width: clamp(118px, 22vw, 176px);
    left: 68%;
    bottom: -38px;
  }
}

@media (max-width: 640px) {
  .tlp-hero__limited {
    width: min(132px, 34vw);
    left: 72%;
    bottom: -34px;
  }
  .tlp-harflong {
    padding: 58px 0 76px;
  }
  .tlp-contact__workbox-logo {
    width: min(340px, 100%);
    margin-inline: auto;
  }
}

/* ===== 2026-05-13 微調整 v11 ===== */
/* Header: use Work Box logo with transparent background and smaller visual weight */
.tlp-header__brand {
  display: inline-flex;
  align-items: center;
  text-decoration: none;
  max-width: min(300px, 42vw);
}
.tlp-header__brand img {
  display: block;
  width: clamp(210px, 24vw, 300px);
  height: auto;
  object-fit: contain;
  background: transparent !important;
}

/* Hero note copy and limited badge adjustments */
.tlp-hero__note {
  font-size: 11px;
  color: rgba(0,0,0,.62);
}
.tlp-hero__limited {
  width: clamp(188px, 21vw, 320px) !important;
  left: clamp(56%, 64vw, 67%) !important;
  bottom: clamp(-92px, -6.8vw, -54px) !important;
}

/* Disaster link in blue */
.tlp-dtrace-link,
.tlp-dtrace-link:visited {
  color: #2f79d4 !important;
  border-bottom-color: currentColor !important;
}

/* Footer logo: transparent background and slightly smaller */
.tlp-contact__workbox-logo {
  width: min(336px, 72vw) !important;
  padding: 0 !important;
  background: transparent !important;
}
.tlp-contact__company {
  font-size: clamp(15px, 1.4vw, 18px) !important;
}

@media (max-width: 920px) {
  .tlp-header__brand {
    max-width: min(240px, 45vw);
  }
  .tlp-header__brand img {
    width: min(240px, 45vw);
  }
  .tlp-hero__limited {
    width: clamp(160px, 26vw, 240px) !important;
    left: 66% !important;
    bottom: -42px !important;
  }
}

@media (max-width: 640px) {
  .tlp-header__inner {
    min-height: 68px;
  }
  .tlp-header__brand {
    max-width: min(180px, 48vw);
  }
  .tlp-header__brand img {
    width: min(180px, 48vw);
  }

  /* Keep the note away from the larger limited badge on mobile */
  .tlp-hero__visual {
    position: relative;
  }
  .tlp-hero__note {
    position: absolute !important;
    left: 6px;
    right: auto;
    bottom: 22px;
    width: min(45vw, 180px);
    margin: 0 !important;
    text-align: left !important;
    font-size: 10px;
    line-height: 1.55;
    z-index: 4;
  }
  .tlp-hero__limited {
    width: min(180px, 42vw) !important;
    left: auto !important;
    right: 8px;
    bottom: -26px !important;
    transform: none !important;
  }

  .tlp-contact__workbox-logo {
    margin-inline: auto !important;
    width: min(280px, 78vw) !important;
    text-align: center;
  }
  .tlp-contact__company {
    text-align: center;
  }
}

/* ===== 2026-05-13 微調整 v12 ===== */
/* Header: revert left brand to text */
.tlp-header__brand {
  max-width: none !important;
  display: inline-flex;
  align-items: center;
  text-decoration: none;
  font-family: "Oswald", "Noto Sans JP", sans-serif !important;
  font-weight: 700 !important;
  font-size: clamp(22px, 2vw, 30px) !important;
  letter-spacing: .01em !important;
  line-height: 1 !important;
}
.tlp-header__brand img { display: none !important; }

/* Hero: replacement limited badge tuned for desktop balance */
.tlp-hero__limited {
  width: clamp(160px, 17vw, 250px) !important;
  left: clamp(57%, 64vw, 66%) !important;
  bottom: clamp(-82px, -5.8vw, -48px) !important;
}

/* Legal comparison table: inline footnote markers */
.tlp-cell-note {
  display: inline-block;
  margin-left: .18em;
  font-size: .62em;
  line-height: 1;
  vertical-align: super;
  color: currentColor;
}

/* Footer: add thin white line above company name */
.tlp-contact__company {
  width: min(420px, 86vw);
  padding-top: 16px;
  margin-top: 16px !important;
  border-top: 1px solid rgba(255,255,255,.9);
}

@media (max-width: 920px) {
  .tlp-hero__limited {
    width: clamp(146px, 22vw, 210px) !important;
    left: 66% !important;
    bottom: -38px !important;
  }
}

@media (max-width: 640px) {
  .tlp-header__brand {
    font-size: 18px !important;
  }
  .tlp-hero__limited {
    width: min(154px, 38vw) !important;
    right: 10px;
    left: auto !important;
    bottom: -20px !important;
  }
  .tlp-contact__company {
    width: min(300px, 84vw);
    margin-inline: auto;
  }
}

/* ===== 2026-05-13 微調整 v13 ===== */
@media (max-width: 640px) {
  .tlp-contact__company {
    text-align: center !important;
    margin-inline: auto !important;
  }
}

/* ===== 2026-05-13 微調整 v14 ===== */
/* Footer white line and company name closer together */
.tlp-contact__company {
  padding-top: 10px !important;
  margin-top: 8px !important;
}

@media (max-width: 640px) {
  /* Footer mobile: align Work Box logo and company name to the left */
  .tlp-contact__workbox-logo {
    margin-inline: 0 !important;
    text-align: left !important;
  }
  .tlp-contact__company {
    text-align: left !important;
    margin-inline: 0 !important;
  }
}

/* ===== 2026-05-13 SP表示調整 v18 ===== */
/* PC表示は現状維持。スマホ時のみ、ヘッダー・キービジュアル・比較表を調整 */
@media (max-width: 640px) {
  .tlp-header__inner {
    gap: 12px !important;
  }
  .tlp-header__brand {
    font-size: 16px !important;
    line-height: 1.05 !important;
    flex: 0 1 auto !important;
  }
  .tlp-header__contact {
    flex: 0 0 auto !important;
    min-width: 148px !important;
    width: 148px !important;
    min-height: 38px !important;
    padding: 7px 12px !important;
    gap: 8px !important;
    white-space: nowrap !important;
  }
  .tlp-header__contact span {
    white-space: nowrap !important;
    word-break: keep-all !important;
    overflow-wrap: normal !important;
    line-height: 1 !important;
  }
  .tlp-header__contact img {
    flex: 0 0 auto !important;
  }

  .tlp-hero__lead {
    font-size: clamp(23px, 6.2vw, 28px) !important;
    line-height: 1.78 !important;
    letter-spacing: .015em !important;
  }
  .tlp-hero__lead span {
    display: block !important;
    white-space: nowrap !important;
    word-break: keep-all !important;
    overflow-wrap: normal !important;
  }

  .tlp-compare-table {
    min-width: 680px !important;
    table-layout: fixed !important;
  }
  .tlp-compare-table thead .tlp-th-kind,
  .tlp-compare-table tbody th {
    width: 118px !important;
    min-width: 118px !important;
    max-width: 118px !important;
    padding-left: 8px !important;
    padding-right: 8px !important;
    font-size: 13px !important;
    line-height: 1.55 !important;
    white-space: normal !important;
    word-break: keep-all !important;
  }
  .tlp-compare-table thead th:not(.tlp-th-kind),
  .tlp-compare-table td {
    width: 185px !important;
  }
  .tlp-compare-table th,
  .tlp-compare-table td {
    padding: 16px 10px !important;
  }
}

@media (max-width: 380px) {
  .tlp-header__contact {
    width: 140px !important;
    min-width: 140px !important;
    font-size: 11px !important;
  }
  .tlp-hero__lead {
    font-size: 23px !important;
  }
  .tlp-compare-table thead .tlp-th-kind,
  .tlp-compare-table tbody th {
    width: 108px !important;
    min-width: 108px !important;
    max-width: 108px !important;
    font-size: 12px !important;
  }
}

/* ===== 2026-05-13 微調整 v19 ===== */
.tlp-usecase__title-mobile { display: none; }

@media (max-width: 640px) {
  .tlp-usecase__title {
    font-size: clamp(24px, 6.6vw, 34px) !important;
    line-height: 1.62 !important;
    letter-spacing: .02em !important;
    text-wrap: balance;
  }
  .tlp-usecase__title-desktop { display: none; }
  .tlp-usecase__title-mobile { display: inline; }
}
