/* ========================================
   ORDER SUIT PAGE – FULL CONTENT STYLES
   /order-suit/ 固定ページ専用
======================================== */

/* ---- HERO ---- */
.os-hero {
  position: relative;
  background:
    linear-gradient(rgba(10, 10, 10, 0.78), rgba(10, 10, 10, 0.78)),
    url('https://tsp2022.com/wp-content/uploads/2026/05/tsp2022-fitting-house-model.jpg')
    center 25% / cover no-repeat;
  padding: clamp(80px, 15vw, 140px) 0 clamp(60px, 10vw, 100px);
  text-align: center;
  overflow: hidden;
}
.os-hero::after {
  content: 'ORDER SUIT';
  position: absolute;
  bottom: -16px;
  left: 50%;
  transform: translateX(-50%);
  font-family: 'Montserrat', sans-serif;
  font-size: clamp(52px, 14vw, 140px);
  font-weight: 800;
  letter-spacing: 0.15em;
  color: rgba(255, 255, 255, 0.03);
  white-space: nowrap;
  pointer-events: none;
  user-select: none;
}
.os-hero__inner {
  position: relative;
  z-index: 1;
  max-width: 900px;
  margin: 0 auto;
  padding: 0 clamp(20px, 5vw, 48px);
}
.os-eyebrow {
  display: inline-block;
  font-family: 'Montserrat', sans-serif;
  font-size: 10px;
  font-weight: 400;
  letter-spacing: 0.55em;
  color: #c9a24a;
  text-transform: uppercase;
  margin-bottom: 24px;
}
.os-hero__logo { margin-bottom: 20px; }
.os-hero__logo-img {
  width: clamp(160px, 26vw, 280px);
  height: auto;
  display: block;
  margin: 0 auto;
}
.os-hero__title {
  font-family: 'Noto Sans JP', sans-serif;
  font-size: clamp(22px, 4.5vw, 40px);
  font-weight: 300;
  color: #ece8e1;
  line-height: 1.7;
  letter-spacing: 0.1em;
  margin: 0 0 28px;
}
.os-hero__lead {
  font-family: 'Noto Sans JP', sans-serif;
  font-size: clamp(13px, 1.8vw, 15px);
  font-weight: 300;
  color: #b8b2aa;
  line-height: 2.5;
  margin: 0 auto 40px;
  max-width: 460px;
}
.os-hero__cta-row {
  display: flex;
  max-width: 460px;
  margin: 0 auto 36px;
  border: 1px solid rgba(255, 255, 255, 0.09);
}
.os-hero__cta-item {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 7px;
  padding: 18px 8px;
  text-decoration: none;
  transition: background 0.4s ease;
  min-width: 0;
}
.os-hero__cta-item + .os-hero__cta-item { border-left: 1px solid rgba(255, 255, 255, 0.09); }
.os-hero__cta-item:hover { background: rgba(255, 255, 255, 0.03); }
.os-hero__cta-icon { width: 15px; height: 15px; flex-shrink: 0; display: block; }
.os-hero__cta-label {
  font-family: 'Montserrat', sans-serif;
  font-size: 8px;
  letter-spacing: 0.42em;
  color: #c9a24a;
  text-transform: uppercase;
  white-space: nowrap;
}
.os-hero__cta-value {
  font-family: 'Noto Sans JP', sans-serif;
  font-size: 11px;
  font-weight: 300;
  color: #c5c0b8;
  letter-spacing: 0.04em;
  white-space: nowrap;
}
.os-hero__cta-item--tel .os-hero__cta-value {
  font-family: 'Montserrat', sans-serif;
  font-size: 11px;
  font-weight: 200;
  letter-spacing: 0.1em;
}
.os-hero__store {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-wrap: wrap;
  margin-top: 36px;
  padding-top: 28px;
  border-top: 1px solid rgba(255, 255, 255, 0.06);
}
.os-hero__store-item {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 5px;
  padding: 0 clamp(14px, 3vw, 28px);
}
.os-hero__store-sep {
  width: 1px;
  height: 28px;
  background: rgba(255, 255, 255, 0.1);
  flex-shrink: 0;
}
.os-hero__store-label {
  font-family: 'Montserrat', sans-serif;
  font-size: 8px;
  letter-spacing: 0.45em;
  color: #c9a24a;
  text-transform: uppercase;
}
.os-hero__store-val {
  font-family: 'Noto Sans JP', sans-serif;
  font-size: 12px;
  font-weight: 300;
  color: #9e9890;
  letter-spacing: 0.04em;
  line-height: 1.7;
  text-align: center;
}

/* ---- FV CTA BAR ---- */
.os-cta-bar {
  background: #0d0d0d;
  border-top: 1px solid #1a1a1a;
  border-bottom: 1px solid #1a1a1a;
}
.os-cta-bar__inner {
  max-width: 960px;
  margin: 0 auto;
  display: flex;
  align-items: stretch;
}
.os-cta-bar__item {
  flex: 1;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 10px;
  padding: clamp(28px, 4.5vw, 44px) clamp(16px, 2.5vw, 24px);
  text-decoration: none;
  text-align: center;
  transition: background 0.4s ease;
}
.os-cta-bar__item:hover { background: rgba(255, 255, 255, 0.018); }
.os-cta-bar__div {
  width: 1px;
  background: #1a1a1a;
  flex-shrink: 0;
  align-self: stretch;
}
.os-cta-bar__cat {
  display: block;
  font-family: 'Montserrat', sans-serif;
  font-size: 9px;
  font-weight: 300;
  letter-spacing: 0.42em;
  color: #606060;
  text-transform: uppercase;
}
.os-cta-bar__title {
  display: block;
  font-family: 'Noto Sans JP', sans-serif;
  font-size: clamp(13px, 2vw, 15px);
  font-weight: 300;
  color: #8e8e8e;
  letter-spacing: 0.06em;
  line-height: 1.4;
  transition: color 0.35s ease;
}
.os-cta-bar__item--line .os-cta-bar__title { color: #a8a8a8; }
.os-cta-bar__item--tel .os-cta-bar__title {
  font-family: 'Montserrat', sans-serif;
  font-size: clamp(13px, 2vw, 15px);
  font-weight: 200;
  letter-spacing: 0.2em;
}
.os-cta-bar__item:hover .os-cta-bar__title { color: #e4e4e4; }

/* ---- SHARED UTILITIES ---- */
.os-section-en {
  display: block;
  font-family: 'Montserrat', sans-serif;
  font-size: 10px;
  font-weight: 400;
  letter-spacing: 0.55em;
  color: #b8945a;
  text-transform: uppercase;
  margin-bottom: 16px;
}

/* ---- DEFINITION ---- */
.os-def {
  background: #f7f6f3;
  padding: clamp(60px, 10vw, 100px) 0;
}
.os-def__inner {
  max-width: 900px;
  margin: 0 auto;
  padding: 0 clamp(20px, 5vw, 48px);
}
.os-def__heading {
  font-family: 'Noto Sans JP', sans-serif;
  font-size: clamp(22px, 4vw, 34px);
  font-weight: 300;
  color: #1a1a1a;
  letter-spacing: 0.06em;
  line-height: 1.5;
  margin: 0 0 40px;
}
.os-def__quote {
  border-left: 2px solid #b8945a;
  padding: 28px 32px;
  background: #edecea;
  margin-bottom: 56px;
}
.os-def__quote p {
  font-family: 'Noto Sans JP', sans-serif;
  font-size: clamp(15px, 2.2vw, 17px);
  font-weight: 300;
  color: #3a3a3a;
  line-height: 2.1;
  margin: 0;
}
.os-compare {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1px;
  background: #dedad4;
}
.os-compare__col {
  background: #f7f6f3;
  padding: clamp(28px, 4vw, 44px) clamp(20px, 3vw, 36px);
}
.os-compare__col--order { background: #1a1a1a; }
.os-compare__badge {
  display: inline-block;
  font-family: 'Montserrat', sans-serif;
  font-size: 9px;
  letter-spacing: 0.5em;
  text-transform: uppercase;
  color: #b8945a;
  margin-bottom: 14px;
}
.os-compare__col:not(.os-compare__col--order) .os-compare__badge { color: #9a9590; }
.os-compare__name {
  font-family: 'Noto Sans JP', sans-serif;
  font-size: clamp(16px, 2.5vw, 20px);
  font-weight: 500;
  color: #e8e4de;
  margin: 0 0 24px;
}
.os-compare__col:not(.os-compare__col--order) .os-compare__name { color: #1a1a1a; }
.os-compare__list { list-style: none; margin: 0; padding: 0; }
.os-compare__list li {
  font-family: 'Noto Sans JP', sans-serif;
  font-size: 13px;
  font-weight: 300;
  color: #6a6a6a;
  line-height: 1.7;
  padding: 10px 0;
  border-bottom: 1px solid #e4e0da;
  display: flex;
  gap: 10px;
  align-items: flex-start;
}
.os-compare__col--order .os-compare__list li { color: #a8a49e; border-bottom-color: #2a2a2a; }
.os-compare__list li::before {
  content: '—';
  font-family: 'Montserrat', sans-serif;
  color: #c8c4be;
  flex-shrink: 0;
  line-height: 1.7;
}
.os-compare__col--order .os-compare__list li::before { color: #b8945a; }

/* ---- ATELIER STRIP ---- */
.os-atelier { background: #0a0a0a; overflow: hidden; }
.os-atelier__fig { margin: 0; overflow: hidden; line-height: 0; }
.os-atelier__fig img {
  width: 100%;
  height: auto;
  max-height: 72vh;
  object-fit: cover;
  display: block;
  filter: brightness(0.82);
  transition: transform 1s ease;
}
.os-atelier__fig:hover img { transform: scale(1.02); }
.os-atelier__cap {
  max-width: 900px;
  margin: 0 auto;
  padding: 28px clamp(20px, 5vw, 48px);
  display: flex;
  align-items: baseline;
  gap: 28px;
  border-bottom: 1px solid #1a1a1a;
}
.os-atelier__cap .os-section-en { margin: 0; white-space: nowrap; }
.os-atelier__cap p {
  font-family: 'Noto Sans JP', sans-serif;
  font-size: 13px;
  font-weight: 300;
  color: #9a9a9a;
  line-height: 1.9;
  margin: 0;
}

/* ---- SCENE — occasions ---- */
.os-scene {
  background: #f4f3f0;
  padding: clamp(60px, 10vw, 100px) 0;
  border-top: 1px solid #e8e4de;
}
.os-scene__inner {
  max-width: 1100px;
  margin: 0 auto;
  padding: 0 clamp(20px, 5vw, 48px);
  display: grid;
  grid-template-columns: 1fr 2fr;
  gap: clamp(40px, 7vw, 88px);
  align-items: start;
}
.os-scene__intro {
  position: sticky;
  top: clamp(40px, 6vw, 80px);
}
.os-scene__heading {
  font-family: 'Noto Sans JP', sans-serif;
  font-size: clamp(22px, 3.8vw, 36px);
  font-weight: 300;
  color: #1a1a1a;
  line-height: 1.7;
  letter-spacing: 0.06em;
  margin: 0 0 20px;
}
.os-scene__note {
  font-family: 'Noto Sans JP', sans-serif;
  font-size: 13px;
  font-weight: 300;
  color: #8a8a8a;
  line-height: 2.4;
  margin: 0;
}
.os-scene__list { list-style: none; margin: 0; padding: 0; }
.os-scene__item {
  border-top: 1px solid #e0ded8;
  padding: clamp(24px, 4vw, 40px) 0;
}
.os-scene__item:last-child { border-bottom: 1px solid #e0ded8; }
.os-scene__num {
  display: block;
  font-family: 'Montserrat', sans-serif;
  font-size: 9px;
  font-weight: 300;
  letter-spacing: 0.5em;
  color: #b8945a;
  text-transform: uppercase;
  margin-bottom: 10px;
}
.os-scene__title {
  display: block;
  font-family: 'Noto Sans JP', sans-serif;
  font-size: clamp(16px, 2.4vw, 20px);
  font-weight: 300;
  color: #1e1e1e;
  letter-spacing: 0.06em;
  margin-bottom: 14px;
  line-height: 1.6;
}
.os-scene__item-fig {
  margin: 0 0 16px;
  overflow: hidden;
  line-height: 0;
}
.os-scene__item-fig img {
  width: 100%;
  aspect-ratio: 16 / 9;
  object-fit: cover;
  display: block;
  filter: brightness(0.78);
  transition: transform 0.9s ease, filter 0.4s ease;
}
.os-scene__item:hover .os-scene__item-fig img {
  transform: scale(1.02);
  filter: brightness(0.9);
}
.os-scene__body {
  font-family: 'Noto Sans JP', sans-serif;
  font-size: 13px;
  font-weight: 300;
  color: #6a6a6a;
  line-height: 2.3;
  margin: 0;
}

/* ---- HOUSE MODEL ---- */
.os-house {
  background: #0f0f0f;
  padding: clamp(60px, 10vw, 100px) 0;
}
.os-house__inner {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 clamp(20px, 5vw, 48px);
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(32px, 6vw, 88px);
  align-items: start;
}
.os-house__heading {
  font-family: 'Noto Sans JP', sans-serif;
  font-size: clamp(22px, 3.8vw, 36px);
  font-weight: 300;
  color: #f5f5f5;
  line-height: 1.7;
  letter-spacing: 0.06em;
  margin: 0 0 28px;
}
.os-house__body {
  font-family: 'Noto Sans JP', sans-serif;
  font-size: 14px;
  font-weight: 300;
  color: #aaaaaa;
  line-height: 2.4;
  margin: 0 0 32px;
}
.os-house__list { list-style: none; padding: 0; margin: 0 0 40px; }
.os-house__list li {
  font-family: 'Noto Sans JP', sans-serif;
  font-size: 13px;
  font-weight: 300;
  color: #bbb;
  line-height: 1.8;
  padding: 11px 0;
  border-bottom: 1px solid #1e1e1e;
  display: flex;
  gap: 12px;
  align-items: flex-start;
}
.os-house__list li::before {
  content: '—';
  font-family: 'Montserrat', sans-serif;
  color: #b8945a;
  flex-shrink: 0;
  line-height: 1.8;
}
.os-house__images { display: grid; grid-template-rows: auto auto; gap: 6px; }
.os-house__fig { margin: 0; overflow: hidden; line-height: 0; }
.os-house__fig img {
  width: 100%;
  height: auto;
  display: block;
  transition: transform 0.9s ease;
  filter: brightness(0.93);
}
.os-house__fig:hover img { transform: scale(1.03); filter: brightness(1); }

/* ---- FITTING STRIP ---- */
.os-fitting {
  background: #0a0a0a;
  padding: clamp(48px, 7vw, 72px) 0;
  border-top: 1px solid #1a1a1a;
}
.os-fitting__inner {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 clamp(20px, 5vw, 48px);
  display: grid;
  grid-template-columns: 1fr 1.6fr;
  gap: clamp(24px, 5vw, 72px);
  align-items: center;
}
.os-fitting__heading {
  font-family: 'Noto Sans JP', sans-serif;
  font-size: clamp(19px, 3vw, 28px);
  font-weight: 300;
  color: #f0f0f0;
  line-height: 1.7;
  letter-spacing: 0.06em;
  margin: 0 0 20px;
}
.os-fitting__note {
  font-family: 'Noto Sans JP', sans-serif;
  font-size: 13px;
  font-weight: 300;
  color: #9a9a9a;
  line-height: 2.2;
  margin: 0;
}
.os-fitting__fig { margin: 0; overflow: hidden; line-height: 0; }
.os-fitting__fig img {
  width: 100%;
  height: auto;
  display: block;
  filter: brightness(0.88);
}

/* ---- FABRIC ---- */
.os-fabric {
  background: #111111;
  padding: clamp(60px, 10vw, 100px) 0;
}
.os-fabric__inner {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 clamp(20px, 5vw, 48px);
  display: grid;
  grid-template-columns: 1.4fr 1fr;
  gap: clamp(32px, 5vw, 72px);
  align-items: center;
}
.os-fabric__main-fig { margin: 0 0 10px; overflow: hidden; line-height: 0; }
.os-fabric__main-fig img {
  width: 100%;
  height: auto;
  display: block;
  transition: transform 0.9s ease;
}
.os-fabric__main-fig:hover img { transform: scale(1.02); }
.os-fabric__figcap {
  font-family: 'Montserrat', sans-serif;
  font-size: 10px;
  letter-spacing: 0.4em;
  color: #4a4a4a;
  text-transform: uppercase;
  line-height: 1;
}
.os-fabric__heading {
  font-family: 'Noto Sans JP', sans-serif;
  font-size: clamp(20px, 3.5vw, 32px);
  font-weight: 300;
  color: #f5f5f5;
  line-height: 1.6;
  letter-spacing: 0.06em;
  margin: 0 0 24px;
}
.os-fabric__body {
  font-family: 'Noto Sans JP', sans-serif;
  font-size: 14px;
  font-weight: 300;
  color: #aaaaaa;
  line-height: 2.2;
  margin: 0 0 32px;
}
.os-fabric__sub-fig { margin: 0; overflow: hidden; line-height: 0; }
.os-fabric__sub-fig img {
  width: 100%;
  height: auto;
  display: block;
  filter: brightness(0.85);
  transition: filter 0.4s ease;
}
.os-fabric__sub-fig:hover img { filter: brightness(0.95); }

/* ---- PRICE ---- */
.os-price {
  background: #0a0a0a;
  padding: clamp(60px, 10vw, 100px) 0;
  border-top: 1px solid #161616;
}
.os-price__inner {
  max-width: 960px;
  margin: 0 auto;
  padding: 0 clamp(20px, 5vw, 48px);
}
.os-price__head { margin-bottom: clamp(44px, 7vw, 68px); }
.os-price__heading {
  font-family: 'Noto Sans JP', sans-serif;
  font-size: clamp(22px, 4vw, 34px);
  font-weight: 300;
  color: #f5f5f5;
  letter-spacing: 0.06em;
  line-height: 1.5;
  margin: 0 0 12px;
}
.os-price__sub {
  font-family: 'Noto Sans JP', sans-serif;
  font-size: 13px;
  font-weight: 300;
  color: #8a8a8a;
  line-height: 2.2;
  margin: 0;
}
.os-price__grades { list-style: none; margin: 0 0 40px; padding: 0; }
.os-price__grade {
  display: grid;
  grid-template-columns: clamp(100px, 13vw, 148px) 1fr 2fr;
  gap: clamp(16px, 3vw, 36px);
  padding: clamp(28px, 4.5vw, 44px) 0;
  border-top: 1px solid #1a1a1a;
  align-items: start;
}
.os-price__grade:last-child { border-bottom: 1px solid #1a1a1a; }
.os-price__grade-fig {
  margin: 0;
  overflow: hidden;
  line-height: 0;
  align-self: start;
}
.os-price__grade-fig img {
  width: 100%;
  aspect-ratio: 1 / 1;
  object-fit: cover;
  display: block;
  filter: brightness(0.76);
  transition: filter 0.6s ease;
}
.os-price__grade:hover .os-price__grade-fig img { filter: brightness(0.88); }
.os-price__grade-label {
  display: block;
  font-family: 'Montserrat', sans-serif;
  font-size: 9px;
  font-weight: 300;
  letter-spacing: 0.5em;
  color: #b8945a;
  text-transform: uppercase;
  margin-bottom: 10px;
}
.os-price__amount {
  display: block;
  font-family: 'Montserrat', sans-serif;
  font-size: clamp(20px, 3.2vw, 30px);
  font-weight: 300;
  color: #ede9e3;
  letter-spacing: 0.04em;
  line-height: 1.2;
  margin-bottom: 10px;
}
.os-price__amount-tax {
  display: block;
  font-family: 'Noto Sans JP', sans-serif;
  font-size: 10px;
  font-weight: 300;
  color: #575757;
  letter-spacing: 0.06em;
  line-height: 1.8;
}
.os-price__mills {
  font-family: 'Montserrat', sans-serif;
  font-size: clamp(10px, 1.5vw, 12px);
  font-weight: 300;
  color: #787878;
  letter-spacing: 0.2em;
  margin: 0 0 12px;
  text-transform: uppercase;
}
.os-price__grade-note {
  font-family: 'Noto Sans JP', sans-serif;
  font-size: 13px;
  font-weight: 300;
  color: #8a8a8a;
  line-height: 2.2;
  margin: 0;
}
.os-price__disclaimer {
  font-family: 'Noto Sans JP', sans-serif;
  font-size: 12px;
  font-weight: 300;
  color: #5a5a5a;
  line-height: 2.2;
  padding-top: 24px;
  border-top: 1px solid #1e1e1e;
}

/* ---- PRICE: STOCK FABRIC ---- */
.os-price__stock {
  margin-top: 64px;
  padding-top: 56px;
  border-top: 1px solid #1e1e1e;
}
.os-price__stock-fig {
  margin: 0 0 44px;
  overflow: hidden;
  line-height: 0;
}
.os-price__stock-fig img {
  width: 100%;
  aspect-ratio: 21 / 9;
  object-fit: cover;
  display: block;
  filter: brightness(0.68);
  transition: filter 0.6s ease;
}
.os-price__stock-fig:hover img { filter: brightness(0.78); }
.os-price__stock-head { margin-bottom: 36px; }
.os-price__stock-badge {
  display: inline-block;
  font-family: 'Montserrat', sans-serif;
  font-size: 9px;
  letter-spacing: 0.5em;
  color: #b8945a;
  text-transform: uppercase;
  margin-bottom: 14px;
}
.os-price__stock-heading {
  font-family: 'Montserrat', sans-serif;
  font-size: clamp(15px, 2.2vw, 20px);
  font-weight: 300;
  color: #b8b2a8;
  letter-spacing: 0.32em;
  text-transform: uppercase;
  margin: 0 0 14px;
}
.os-price__stock-note {
  font-family: 'Noto Sans JP', sans-serif;
  font-size: 13px;
  font-weight: 300;
  color: #8a8a8a;
  line-height: 2.3;
  margin: 0;
}
.os-price__stock-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1px;
  background: #1e1e1e;
}
.os-price__stock-item {
  background: #0a0a0a;
  padding: clamp(28px, 4vw, 44px) clamp(22px, 3.5vw, 40px);
  position: relative;
  overflow: hidden;
}
.os-price__stock-item::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 1px;
  background: linear-gradient(90deg, #b8945a 0%, transparent 60%);
}
.os-price__stock-mills {
  display: block;
  font-family: 'Montserrat', sans-serif;
  font-size: 10px;
  font-weight: 300;
  letter-spacing: 0.25em;
  color: #606060;
  text-transform: uppercase;
  margin-bottom: 18px;
}
.os-price__stock-price {
  display: block;
  font-family: 'Montserrat', sans-serif;
  font-size: clamp(26px, 4vw, 38px);
  font-weight: 300;
  color: #ede9e3;
  letter-spacing: 0.04em;
  line-height: 1.1;
  margin-bottom: 10px;
}
.os-price__stock-tax {
  display: block;
  font-family: 'Noto Sans JP', sans-serif;
  font-size: 10px;
  font-weight: 300;
  color: #575757;
  letter-spacing: 0.06em;
  line-height: 1.8;
  margin-bottom: 20px;
}
.os-price__stock-ref {
  display: block;
  font-family: 'Montserrat', sans-serif;
  font-size: 9px;
  font-weight: 300;
  letter-spacing: 0.2em;
  color: #383838;
  text-transform: uppercase;
  margin-bottom: 8px;
}
.os-price__stock-avail {
  display: block;
  font-family: 'Noto Sans JP', sans-serif;
  font-size: 11px;
  font-weight: 300;
  color: #b8945a;
  letter-spacing: 0.1em;
}

/* ---- SPECS ---- */
.os-specs {
  background: #f7f6f3;
  padding: clamp(60px, 10vw, 100px) 0;
  border-top: 1px solid #e8e4de;
}
.os-specs__inner {
  max-width: 960px;
  margin: 0 auto;
  padding: 0 clamp(20px, 5vw, 48px);
}
.os-specs__head { margin-bottom: clamp(40px, 6vw, 56px); }
.os-specs__heading {
  font-family: 'Noto Sans JP', sans-serif;
  font-size: clamp(22px, 4vw, 34px);
  font-weight: 300;
  color: #1a1a1a;
  letter-spacing: 0.06em;
  margin: 0 0 12px;
  line-height: 1.5;
}
.os-specs__note {
  font-family: 'Noto Sans JP', sans-serif;
  font-size: 13px;
  font-weight: 300;
  color: #8a8a8a;
  line-height: 2;
  margin: 0;
}
.os-specs__grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 1px;
  background: #dedad4;
}
.os-specs__item {
  background: #f7f6f3;
  padding: clamp(22px, 3.2vw, 34px) clamp(20px, 3vw, 32px);
}
.os-specs__item-fig {
  margin: 0 0 14px;
  overflow: hidden;
  line-height: 0;
}
.os-specs__item-fig img {
  width: 100%;
  aspect-ratio: 4 / 3;
  object-fit: cover;
  display: block;
  filter: brightness(0.82);
  transition: filter 0.4s ease, transform 0.7s ease;
}
.os-specs__item:hover .os-specs__item-fig img {
  filter: brightness(0.94);
  transform: scale(1.04);
}
.os-specs__item-en {
  display: block;
  font-family: 'Montserrat', sans-serif;
  font-size: 9px;
  font-weight: 300;
  letter-spacing: 0.5em;
  color: #b8945a;
  text-transform: uppercase;
  margin-bottom: 5px;
}
.os-specs__item-ja {
  display: block;
  font-family: 'Noto Sans JP', sans-serif;
  font-size: clamp(14px, 2vw, 16px);
  font-weight: 300;
  color: #1e1e1e;
  letter-spacing: 0.06em;
  margin-bottom: 10px;
}
.os-specs__item-vals {
  font-family: 'Noto Sans JP', sans-serif;
  font-size: 12px;
  font-weight: 300;
  color: #7a7a7a;
  line-height: 2;
  margin: 0;
}

/* ---- DETAILS GALLERY ---- */
.os-gallery {
  background: #0a0a0a;
  padding: clamp(60px, 10vw, 100px) 0;
}
.os-gallery__inner {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 clamp(20px, 5vw, 48px);
}
.os-gallery__head { margin-bottom: clamp(32px, 5vw, 52px); }
.os-gallery__heading {
  font-family: 'Noto Sans JP', sans-serif;
  font-size: clamp(22px, 4vw, 34px);
  font-weight: 300;
  color: #f5f5f5;
  letter-spacing: 0.06em;
  line-height: 1.5;
  margin: 0;
}
.os-gallery__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 4px;
}
.os-gallery__item { margin: 0; overflow: hidden; position: relative; line-height: 0; }
.os-gallery__item img {
  width: 100%;
  aspect-ratio: 3 / 4;
  object-fit: cover;
  display: block;
  transition: transform 0.9s ease, filter 0.4s ease;
  filter: brightness(0.88);
}
.os-gallery__item:hover img { transform: scale(1.04); filter: brightness(1); }
.os-gallery__cap {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  padding: 40px 18px 18px;
  background: linear-gradient(transparent, rgba(0, 0, 0, 0.72));
  line-height: 1.4;
}
.os-gallery__cap-en {
  display: block;
  font-family: 'Montserrat', sans-serif;
  font-size: 9px;
  letter-spacing: 0.45em;
  color: #b8945a;
  text-transform: uppercase;
  margin-bottom: 4px;
}
.os-gallery__cap-ja {
  display: block;
  font-family: 'Noto Sans JP', sans-serif;
  font-size: 12px;
  font-weight: 300;
  color: #ddd;
}

/* ---- ORDER TUXEDO ---- */
.os-tuxedo {
  background: #0f0f0f;
  padding: clamp(60px, 10vw, 100px) 0;
}
.os-tuxedo__inner {
  max-width: 1100px;
  margin: 0 auto;
  padding: 0 clamp(20px, 5vw, 48px);
}
.os-tuxedo__head {
  max-width: 640px;
  margin: 0 auto clamp(48px, 7vw, 72px);
  text-align: center;
}
.os-tuxedo__heading {
  font-family: 'Noto Sans JP', sans-serif;
  font-size: clamp(24px, 4.5vw, 40px);
  font-weight: 300;
  color: #ece8e1;
  letter-spacing: 0.08em;
  line-height: 1.65;
  margin: 0 0 24px;
}
.os-tuxedo__subtext {
  font-family: 'Noto Sans JP', sans-serif;
  font-size: 14px;
  font-weight: 300;
  color: #aaaaaa;
  line-height: 2.3;
  margin: 0;
}
.os-tuxedo__gallery {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 6px;
  margin-bottom: clamp(44px, 6vw, 68px);
}
.os-tuxedo__gallery-fig { margin: 0; overflow: hidden; position: relative; line-height: 0; }
.os-tuxedo__gallery-fig img {
  width: 100%;
  aspect-ratio: 2 / 3;
  object-fit: cover;
  display: block;
  filter: brightness(0.75);
  transition: filter 0.6s ease, transform 0.9s ease;
}
.os-tuxedo__gallery-fig:hover img { filter: brightness(0.92); transform: scale(1.025); }
.os-tuxedo__gallery-cap {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  padding: 60px 22px 22px;
  background: linear-gradient(transparent, rgba(0, 0, 0, 0.65));
  line-height: 1.5;
}
.os-tuxedo__gallery-en {
  display: block;
  font-family: 'Montserrat', sans-serif;
  font-size: 9px;
  letter-spacing: 0.5em;
  color: #c9a24a;
  text-transform: uppercase;
  margin-bottom: 5px;
}
.os-tuxedo__gallery-ja {
  display: block;
  font-family: 'Noto Sans JP', sans-serif;
  font-size: 13px;
  font-weight: 300;
  color: #e4e0d8;
}

/* ---- FAQ ---- */
.os-faq {
  background: #f4f3f0;
  padding: clamp(60px, 10vw, 100px) 0;
  border-top: 1px solid #e8e4de;
}
.os-faq__inner {
  max-width: 760px;
  margin: 0 auto;
  padding: 0 clamp(20px, 5vw, 48px);
}
.os-faq__head { margin-bottom: clamp(40px, 6vw, 56px); }
.os-faq__heading {
  font-family: 'Noto Sans JP', sans-serif;
  font-size: clamp(20px, 3.5vw, 28px);
  font-weight: 300;
  color: #1a1a1a;
  letter-spacing: 0.08em;
  line-height: 1.7;
  margin: 0;
}
.os-faq__list { list-style: none; margin: 0; padding: 0; }
.os-faq__item {
  border-top: 1px solid #e0ded8;
  padding: clamp(24px, 4vw, 36px) 0;
}
.os-faq__item:last-child { border-bottom: 1px solid #e0ded8; }
.os-faq__q {
  font-family: 'Noto Sans JP', sans-serif;
  font-size: clamp(14px, 2vw, 15px);
  font-weight: 300;
  color: #2a2a2a;
  line-height: 1.7;
  letter-spacing: 0.04em;
  margin: 0 0 14px;
  display: flex;
  gap: 14px;
  align-items: flex-start;
}
.os-faq__q::before {
  content: 'Q';
  font-family: 'Montserrat', sans-serif;
  font-size: 10px;
  font-weight: 400;
  letter-spacing: 0.1em;
  color: #b8945a;
  flex-shrink: 0;
  line-height: 2;
}
.os-faq__a {
  font-family: 'Noto Sans JP', sans-serif;
  font-size: 13px;
  font-weight: 300;
  color: #6a6a6a;
  line-height: 2.3;
  margin: 0;
  padding-left: 24px;
}

/* ---- WELCOME / ATMOSPHERE ---- */
.os-welcome {
  background: #0d0d0d;
  padding: clamp(72px, 12vw, 120px) 0;
}
.os-welcome__inner {
  max-width: 1160px;
  margin: 0 auto;
  padding: 0 clamp(20px, 5vw, 60px);
  display: grid;
  grid-template-columns: 5fr 4fr;
  gap: clamp(48px, 7vw, 88px);
  align-items: center;
}
@media (max-width: 768px) {
  .os-welcome__inner {
    grid-template-columns: 1fr;
    gap: clamp(32px, 6vw, 48px);
  }
}
.os-welcome__fig { margin: 0; }
.os-welcome__fig img {
  width: 100%;
  aspect-ratio: 3 / 4;
  object-fit: cover;
  display: block;
  filter: brightness(0.84) saturate(0.78);
}
@media (max-width: 768px) {
  .os-welcome__fig img { aspect-ratio: 4 / 3; }
}
.os-welcome__heading {
  font-family: 'Noto Sans JP', sans-serif;
  font-size: clamp(24px, 3.8vw, 38px);
  font-weight: 200;
  color: #e8e4de;
  letter-spacing: 0.14em;
  line-height: 1.75;
  margin: 0 0 clamp(18px, 3vw, 28px);
}
.os-welcome__body {
  font-family: 'Noto Sans JP', sans-serif;
  font-size: 13px;
  font-weight: 300;
  color: #787878;
  line-height: 2.3;
  margin: 0 0 clamp(32px, 5vw, 48px);
}
.os-welcome__list {
  list-style: none;
  margin: 0;
  padding: 0;
}
.os-welcome__list-item {
  display: grid;
  grid-template-columns: 72px 1fr;
  gap: 16px;
  padding: 14px 0;
  border-top: 1px solid #1c1c1c;
  align-items: baseline;
}
.os-welcome__list-item:last-child { border-bottom: 1px solid #1c1c1c; }
.os-welcome__list-en {
  font-family: 'Montserrat', sans-serif;
  font-size: 8px;
  font-weight: 300;
  letter-spacing: 0.38em;
  color: #b8945a;
  text-transform: uppercase;
  line-height: 1.6;
}
.os-welcome__list-ja {
  font-family: 'Noto Sans JP', sans-serif;
  font-size: 13px;
  font-weight: 300;
  color: #8a8a8a;
  line-height: 1.75;
}

/* ---- CONTACT ---- */
.os-contact {
  background: #ffffff;
  padding: clamp(64px, 10vw, 100px) 0;
  border-top: 1px solid #e8e4de;
}
.os-contact__inner {
  max-width: 760px;
  margin: 0 auto;
  padding: 0 clamp(20px, 5vw, 48px);
}
.os-contact__head { margin-bottom: clamp(40px, 7vw, 60px); }
.os-contact__heading {
  font-family: 'Noto Sans JP', sans-serif;
  font-size: clamp(18px, 3vw, 26px);
  font-weight: 300;
  color: #1a1a1a;
  letter-spacing: 0.1em;
  line-height: 1.7;
  margin: 0 0 10px;
}
.os-contact__sub {
  font-family: 'Noto Sans JP', sans-serif;
  font-size: 13px;
  font-weight: 300;
  color: #8a8a8a;
  line-height: 2;
  margin: 0;
}
.os-contact__list { list-style: none; margin: 0; padding: 0; }
.os-contact__row { border-top: 1px solid #e8e4de; }
.os-contact__row:last-child { border-bottom: 1px solid #e8e4de; }
.os-contact__link {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
  padding: clamp(24px, 4vw, 36px) 0;
  text-decoration: none;
}
.os-contact__link-left { flex: 1; min-width: 0; }
.os-contact__link-cat {
  display: block;
  font-family: 'Montserrat', sans-serif;
  font-size: 9px;
  font-weight: 300;
  letter-spacing: 0.5em;
  color: #b8945a;
  text-transform: uppercase;
  margin-bottom: 10px;
}
.os-contact__link-title {
  display: block;
  font-family: 'Noto Sans JP', sans-serif;
  font-size: clamp(19px, 3vw, 26px);
  font-weight: 300;
  color: #2a2a2a;
  letter-spacing: 0.06em;
  margin-bottom: 10px;
  transition: color 0.35s ease;
}
.os-contact__row--line .os-contact__link-title { color: #1a1a1a; }
.os-contact__row:hover .os-contact__link-title { color: #000000; }
.os-contact__link-desc {
  display: block;
  font-family: 'Noto Sans JP', sans-serif;
  font-size: 13px;
  font-weight: 300;
  color: #8a8a8a;
  line-height: 1.9;
}
.os-contact__link-note {
  display: block;
  font-size: 12px;
  color: #b8945a;
  margin-top: 6px;
  letter-spacing: 0.04em;
}
.os-contact__link-arrow {
  font-family: 'Montserrat', sans-serif;
  font-size: 13px;
  color: #cccccc;
  flex-shrink: 0;
  transition: color 0.35s ease, transform 0.35s ease;
  line-height: 1;
}
.os-contact__row:hover .os-contact__link-arrow { color: #888; transform: translateX(5px); }
.os-contact__tel-num {
  display: block;
  font-family: 'Montserrat', sans-serif;
  font-size: clamp(22px, 4.5vw, 32px);
  font-weight: 200;
  letter-spacing: 0.2em;
  color: #2a2a2a;
  margin-bottom: 8px;
  transition: color 0.35s ease;
}
.os-contact__row:hover .os-contact__tel-num { color: #000000; }
.os-contact__hours {
  font-family: 'Noto Sans JP', sans-serif;
  font-size: 12px;
  font-weight: 300;
  color: #9a9a9a;
  line-height: 1.8;
}

/* ---- CONTACT: Store Info + Map ---- */
.os-contact__store-block {
  margin-bottom: clamp(44px, 7vw, 64px);
  padding-bottom: clamp(44px, 7vw, 64px);
  border-bottom: 1px solid #e8e4de;
}
.os-contact__store-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  border: 1px solid #e8e4de;
  margin: 0;
  padding: 0;
}
@media (max-width: 480px) {
  .os-contact__store-grid { grid-template-columns: 1fr; }
}
.os-contact__store-cell {
  padding: clamp(18px, 3vw, 26px) clamp(16px, 3vw, 28px);
  border-right: 1px solid #e8e4de;
}
.os-contact__store-cell:last-child { border-right: none; }
@media (max-width: 480px) {
  .os-contact__store-cell { border-right: none; border-bottom: 1px solid #e8e4de; }
  .os-contact__store-cell:last-child { border-bottom: none; }
}
.os-contact__store-label {
  display: block;
  font-family: 'Montserrat', sans-serif;
  font-size: 8px;
  font-weight: 300;
  letter-spacing: 0.4em;
  color: #b8945a;
  text-transform: uppercase;
  margin-bottom: 10px;
}
.os-contact__store-val {
  display: block;
  font-family: 'Noto Sans JP', sans-serif;
  font-size: 13px;
  font-weight: 300;
  color: #2a2a2a;
  line-height: 1.9;
  margin: 0;
}
.os-contact__store-note {
  display: block;
  font-size: 11px;
  color: #9a9a9a;
  margin-top: 4px;
  letter-spacing: 0.04em;
}
.os-contact__map-wrap {
  position: relative;
  width: 100%;
  height: clamp(240px, 38vw, 380px);
  overflow: hidden;
  border: 1px solid #e8e4de;
  border-top: none;
}
.os-contact__map-wrap iframe {
  position: absolute;
  top: 0; left: 0;
  width: 100%; height: 100%;
  border: 0;
  display: block;
  filter: saturate(0.75) contrast(0.88) brightness(1.02);
}

/* ---- PRICE accent image ---- */
.os-price__accent {
  margin: 0 0 56px;
  overflow: hidden;
  line-height: 0;
}
.os-price__accent img {
  width: 100%;
  aspect-ratio: 16 / 5;
  object-fit: cover;
  display: block;
  filter: brightness(0.64);
  transition: filter 0.8s ease;
}
.os-price__accent:hover img { filter: brightness(0.74); }

/* ---- SPECS accent image ---- */
.os-specs__accent {
  max-width: 540px;
  margin: 0 auto 48px;
  overflow: hidden;
  line-height: 0;
}
.os-specs__accent img {
  width: 100%;
  aspect-ratio: 16 / 7;
  object-fit: cover;
  display: block;
  filter: brightness(0.86);
  transition: filter 0.5s ease;
}
.os-specs__accent:hover img { filter: brightness(0.94); }

/* ---- POPULAR MORE ---- */
.popularMore { text-align: center; margin-top: 40px; padding-top: 4px; }

/* ---- MOST POPULAR ---- */
#suitPopular .popular-list {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 20px 16px;
  list-style: none;
  margin: 0;
  padding: 0;
}
#suitPopular .popular-link { display: block; text-decoration: none; }
#suitPopular .popular-thumb { aspect-ratio: 4 / 3; overflow: hidden; margin-bottom: 12px; }
#suitPopular .popular-thumb img,
#suitPopular .popular-thumb .wpp-thumbnail {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform 0.6s ease;
}
#suitPopular .popular-link:hover .popular-thumb img,
#suitPopular .popular-link:hover .wpp-thumbnail { transform: scale(1.04); }

/* ---- SEO CONTENT (WordPress本文) ---- */
/* .os-seo-content__inner の中のみに適用。他ページ・他セクション影響なし */

.os-seo-content {
  background: #f7f6f3;
  padding: clamp(60px, 10vw, 100px) 0;
  border-top: 1px solid #e8e4de;
  border-bottom: 1px solid #e8e4de;
}
.os-seo-content__inner {
  max-width: 720px;
  margin: 0 auto;
  padding: 0 clamp(20px, 5vw, 48px);
}

/* 段落 */
.os-seo-content__inner p {
  font-family: 'Noto Sans JP', sans-serif;
  font-size: clamp(14px, 2vw, 15px);
  font-weight: 300;
  color: #3a3a3a;
  line-height: 2.3;
  margin: 0 0 clamp(16px, 2.5vw, 20px);
}

/* h2：底面ラインで区切り、ゴールドアクセント */
.os-seo-content__inner h2 {
  font-family: 'Noto Sans JP', sans-serif;
  font-size: clamp(18px, 3vw, 24px);
  font-weight: 300;
  color: #1a1a1a;
  letter-spacing: 0.08em;
  line-height: 1.7;
  margin: clamp(48px, 7vw, 68px) 0 clamp(16px, 2.5vw, 22px);
  padding-bottom: 16px;
  border-bottom: 1px solid #e0ded8;
  position: relative;
}
.os-seo-content__inner h2::after {
  content: '';
  position: absolute;
  bottom: -1px;
  left: 0;
  width: 32px;
  height: 1px;
  background: #b8945a;
}
.os-seo-content__inner h2:first-child { margin-top: 0; }

/* h3：左ボーダーで控えめに格調 */
.os-seo-content__inner h3 {
  font-family: 'Noto Sans JP', sans-serif;
  font-size: clamp(15px, 2.2vw, 17px);
  font-weight: 300;
  color: #2a2a2a;
  letter-spacing: 0.06em;
  line-height: 1.8;
  margin: clamp(32px, 5vw, 44px) 0 clamp(10px, 1.8vw, 14px);
  padding-left: 13px;
  border-left: 2px solid #b8945a;
}

/* h4 */
.os-seo-content__inner h4 {
  font-family: 'Noto Sans JP', sans-serif;
  font-size: clamp(13px, 1.8vw, 14px);
  font-weight: 400;
  color: #2a2a2a;
  letter-spacing: 0.06em;
  line-height: 1.8;
  margin: clamp(20px, 3.5vw, 28px) 0 clamp(8px, 1.5vw, 10px);
}

/* リスト：LP共通の — スタイルで統一 */
.os-seo-content__inner ul,
.os-seo-content__inner ol {
  list-style: none;
  margin: 0 0 clamp(20px, 3vw, 28px);
  padding: 0;
}
.os-seo-content__inner ul li,
.os-seo-content__inner ol li {
  font-family: 'Noto Sans JP', sans-serif;
  font-size: clamp(13px, 1.8vw, 14px);
  font-weight: 300;
  color: #5a5a5a;
  line-height: 1.9;
  padding: 10px 0;
  border-bottom: 1px solid #ebe8e3;
  display: flex;
  gap: 10px;
  align-items: flex-start;
}
.os-seo-content__inner ul li:first-child,
.os-seo-content__inner ol li:first-child { border-top: 1px solid #ebe8e3; }
.os-seo-content__inner ul li::before {
  content: '—';
  font-family: 'Montserrat', sans-serif;
  font-size: 11px;
  color: #b8945a;
  flex-shrink: 0;
  line-height: 1.9;
}

/* ol：連番 */
.os-seo-content__inner ol { counter-reset: os-seo-ol; }
.os-seo-content__inner ol li::before {
  counter-increment: os-seo-ol;
  content: counter(os-seo-ol, decimal-leading-zero);
  font-family: 'Montserrat', sans-serif;
  font-size: 11px;
  font-weight: 300;
  letter-spacing: 0.1em;
  color: #b8945a;
  flex-shrink: 0;
  line-height: 1.95;
}

/* リンク：内部リンク（自然なアンダーライン） */
.os-seo-content__inner a {
  color: #b8945a;
  text-decoration: none;
  border-bottom: 1px solid rgba(184, 148, 90, 0.35);
  transition: color 0.3s ease, border-color 0.3s ease;
}
.os-seo-content__inner a:hover {
  color: #9a7a56;
  border-bottom-color: #9a7a56;
}
/* 外部リンク：落ち着いたグレー */
.os-seo-content__inner a[href^="http"]:not([href*="tsp2022.com"]) {
  color: #8a8a8a;
  border-bottom-color: rgba(138, 138, 138, 0.3);
}
.os-seo-content__inner a[href^="http"]:not([href*="tsp2022.com"]):hover {
  color: #5a5a5a;
  border-bottom-color: rgba(90, 90, 90, 0.5);
}

/* インライン装飾 */
.os-seo-content__inner strong {
  font-weight: 400;
  color: #1e1e1e;
}
.os-seo-content__inner em {
  font-style: italic;
  color: #4a4a4a;
}

/* 引用ブロック */
.os-seo-content__inner blockquote {
  border-left: 2px solid #b8945a;
  padding: clamp(20px, 3.5vw, 28px) clamp(18px, 3vw, 28px);
  background: #edecea;
  margin: clamp(24px, 4vw, 36px) 0;
}
.os-seo-content__inner blockquote p {
  color: #3a3a3a;
  margin: 0;
  line-height: 2.1;
}


/* ---- MOBILE ---- */
@media (max-width: 768px) {
  .os-hero__lead br { display: none; }
  .os-hero__cta-row { flex-direction: column; max-width: 260px; }
  .os-hero__cta-item + .os-hero__cta-item {
    border-left: none;
    border-top: 1px solid rgba(255, 255, 255, 0.09);
  }
  .os-hero__cta-item { flex-direction: row; justify-content: center; gap: 10px; padding: 16px 20px; }
  .os-hero__store { flex-direction: column; gap: 14px; align-items: center; }
  .os-hero__store-sep { display: none; }
  .os-hero__store-item { padding: 0; }

  .os-compare { grid-template-columns: 1fr; }
  .os-compare__col--order { order: -1; }
  .os-def__quote { padding: 24px 20px; }

  .os-atelier__cap { flex-direction: column; gap: 8px; }

  .os-scene__inner { grid-template-columns: 1fr; gap: clamp(28px, 5vw, 40px); }
  .os-scene__intro { position: static; }
  .os-scene__item-fig img { aspect-ratio: 4 / 3; }

  .os-house__inner { grid-template-columns: 1fr; }
  .os-house__images { grid-template-columns: 1fr 1fr; grid-template-rows: auto; }

  .os-fitting__inner { grid-template-columns: 1fr; }
  .os-fitting__fig { order: -1; }

  .os-fabric__inner { grid-template-columns: 1fr; }

  .os-price__grade {
    grid-template-columns: 72px 1fr;
    grid-template-rows: auto auto;
    gap: 12px 14px;
  }
  .os-price__grade-fig { grid-row: 1; grid-column: 1; }
  .os-price__grade-left { grid-row: 1; grid-column: 2; }
  .os-price__grade-right { grid-row: 2; grid-column: 1 / -1; }
  .os-price__grade-fig img { aspect-ratio: 1 / 1; }
  .os-price__stock-grid { grid-template-columns: 1fr; }
  .os-price__stock-fig img { aspect-ratio: 16 / 9; }

  .os-specs__grid { grid-template-columns: 1fr; }

  .os-gallery__grid { grid-template-columns: 1fr; gap: 4px; }
  .os-gallery__item img { aspect-ratio: 4 / 3; }

  .os-tuxedo__gallery { grid-template-columns: 1fr; gap: 4px; }

  #suitPopular .popular-list { grid-template-columns: repeat(2, 1fr); gap: 16px 12px; }

  .os-cta-bar__inner { flex-direction: column; }
  .os-cta-bar__div { height: 1px; width: auto; align-self: unset; }
  .os-cta-bar__item {
    flex-direction: row;
    justify-content: space-between;
    text-align: left;
    padding: 20px clamp(20px, 5vw, 32px);
    min-height: 60px;
    gap: 16px;
  }
  .os-cta-bar__item::after {
    content: '→';
    font-family: 'Montserrat', sans-serif;
    font-size: 11px;
    color: #505050;
    flex-shrink: 0;
    transition: color 0.35s ease;
  }
  .os-cta-bar__item:hover::after { color: #999; }
  .os-cta-bar__cat { letter-spacing: 0.38em; }

  .os-seo-content { padding: clamp(44px, 8vw, 60px) 0; }
  .os-seo-content__inner h2 { font-size: clamp(17px, 4.5vw, 20px); }
  .os-seo-content__inner h3 { font-size: 14px; }
  .os-seo-content__inner p { line-height: 2.1; }
}
