/** Shopify CDN: Minification failed

Line 164:13 Expected identifier but found whitespace
Line 164:14 Unexpected "1px"

**/
/* =========================================
   Base
   ========================================= */
:root {
  --th-bg: #faf7f3;
  /*--th-bg: #f4f4f4;*/
  --th-bg-alt: #fffaf3;
  --th-bg-accent: #f2ebe0;
  --th-text: #1f1f1f;
  --th-text-muted: #6a645a;
  --th-border: #e1d9cd;
  --th-primary: #94613d;
  --th-primary-soft: #f0e0d4;
  --th-radius-lg: 1.5rem;
  --th-radius-md: 1rem;
  --th-radius-sm: 0.5rem;
  --th-shadow-soft: 0 14px 40px rgba(0, 0, 0, 0.06);
}

*,
*::before,
*::after {
  box-sizing: border-box;
}

html {
  font-size: 16px;
}

body {
  margin: 0;
  font-family: system-ui, -apple-system, BlinkMacSystemFont, "SF Pro Text",
    "Segoe UI", sans-serif;
  color: var(--th-text);
  background-color: var(--th-bg);
  line-height: 1.6;
}

/* =========================================
   Layout helpers
   ========================================= */
.th-container {
  width: 100%;
  max-width: 1120px;
  padding-inline: 1.5rem;
  margin-inline: auto;
}

.th-section {
  padding: 3.5rem 0;
  background-color: var(--th-bg);
}

.th-section--light {
  background-color: #ffffff;
}

.th-section--accent {
  background-color: var(--th-bg-accent);
}

.th-section--narrow {
  padding-block: 2.5rem;
}

.th-section__header {
  margin-bottom: 2rem;
}

.th-section__header--tabs {
  display: flex;
  flex-direction: column;
  gap: 1rem;
  align-items: flex-start;
}

.th-section__title {
  margin: 0 0 0.25rem;
  font-size: 1.5rem;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.th-section__subtitle {
  margin: 0;
  color: var(--th-text-muted);
  font-size: 0.95rem;
}

.th-section__footer {
  margin-top: 2rem;
}

/* Product detail – metafield rich text size normalization */
.th-product-block__body {
  font-size: 0.95rem;      /* 他テキストと近いサイズ */
  line-height: 1.7;
}

/* metafield_tag が出力する要素対策 */
.th-product-block__body p,
.th-product-block__body ul,
.th-product-block__body ol,
.th-product-block__body li {
  font-size: inherit;
  line-height: inherit;
}

/* 念のため見出し系も抑制 */
.th-product-block__body h1,
.th-product-block__body h2,
.th-product-block__body h3 {
  font-size: 1rem;
  margin-top: 1.2em;
}


/* =========================================
   Header ヘッダー
   ========================================= */
/* 親メニューの基本 */
/*.th-nav__item {
  position: relative;
}
*/
/* メガメニュー全体の背景を確実に文字全体に適用 */
/*.th-mega-menu--with-bg {
  background-color: #fff;    
  padding: 1.5rem 2rem;
}*/

.th-mega-menu--with-bg {
  background-color: #fff;
}

/* メガメニュー本体（デフォルトは非表示） */
/*.th-mega-menu {
  display: none;
  position: absolute;
  left: 0;
  right: 0;
  top: 100%;
  padding: 24px 32px;
  background: #fff;
  border-top: 1px solid #eee;
  box-shadow: 0 8px 24px rgba(0,0,0,0.06);
  z-index: 20;
}*/

/*.th-mega-menu {
  display: none;
  position: absolute;
  left: 0;
  right: 0;
  top: 100%;
  padding: 1.5rem 2rem;
  background-color: #fff; /* 背景をしっかり指定 */
  border-top: 1px solid #eee;
  box-shadow: 0 8px 24px rgba(0,0,0,0.06);
  z-index: 20;
}*/
/*
.th-mega-menu.is-open {
  display: block;
}
*/
/* 内側レイアウト（横並びの列） */
/*.th-mega-menu__inner {
  max-width: 1200px;
  margin: 0 auto;
  display: flex;
  flex-wrap: wrap;
  gap: 32px;
}
*/
/* 内側カラムが背景からはみ出さないようブロック化 */
/*.th-mega-menu__inner {
  display: flex;
  gap: 2rem;
}
*/

/*.th-mega-menu__inner {
  max-width: 1200px;
  margin: 0 auto;
  display: flex;
  flex-wrap: wrap;
  gap: 32px;
}*/

/*.th-mega-menu__column {
  display: block;
}
*/

/*.th-mega-menu__column {
  display: block;
  min-width: 180px;
}*/
/*
.th-mega-menu__heading {
  display: block;
  font-weight: 600;
  margin-bottom: 8px;
}

.th-mega-menu__list {
  list-style: none;
  margin: 0;
  padding: 0;
}

.th-mega-menu__item + .th-mega-menu__item {
  margin-top: 4px;
}
*/
/*
.th-header {
  position: sticky;
  top: 0;
  z-index: 10;
  background-color: rgba(250, 247, 243, 0.92);
  backdrop-filter: blur(12px);
  border-bottom: 1px solid rgba(225, 217, 205, 0.7);
}

.th-header__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding-block: 0.8rem;
  gap: 1rem;
  position: relative; 
}
*/
/* ロゴ */
/*.th-logo {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  text-decoration: none;
  color: inherit;
}
*/
/*.th-logo__mark {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2.2rem;
  height: 2.2rem;
  border-radius: 999px;
  border: 1px solid var(--th-border);
  background-color: #ffffff;
  font-size: 1.3rem;
}
*/
.th-logo__mark--small {
  width: 1.8rem;
  height: 1.8rem;
  font-size: 1.1rem;
}
/*
.th-logo__text {
  font-size: 1rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}
*/
.th-logo__text--small {
  font-size: 0.85rem;
}

/* 検索フォーム（PC 表示） */
/*.th-header__search {
  display: none;          
  align-items: center;
  gap: 0.4rem;
  max-width: 260px;
  flex: 0 0 auto;
}
*/
/*.th-header__search-input {
  flex: 1 1 auto;
  min-width: 0;
  padding: 0.45rem 0.9rem;
  border-radius: 999px;
  border: 1px solid rgba(225, 217, 205, 0.9);
  font-size: 0.85rem;
  background-color: #ffffff;
}*/

/* Search ボタン */
/*.th-header__search-btn {
  padding: 0.45rem 0.9rem;
  border-radius: 999px;
  border: 1px solid var(--th-border);
  background-color: #ffffff;
  font-size: 0.8rem;
  cursor: pointer;
  white-space: nowrap;
}

.th-header__search-btn:hover {
  background-color: var(--th-primary-soft);
  border-color: var(--th-primary-soft);
}*/

/* ナビ（SP デフォルトはドロワー） */
/*.th-nav {
  position: absolute;
  left: 0;
  right: 0;
  top: 100%;
  background-color: var(--th-bg);
  border-bottom: 1px solid rgba(225, 217, 205, 0.9);
  padding: 0.75rem 1.5rem 1rem;
  display: none;
}*/

/*.th-nav.is-open {
  display: block;
}*/

/*.th-nav__list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column; 
  gap: 0.75rem;
  font-size: 0.9rem;
}

.th-nav__list a {
  text-decoration: none;
  color: var(--th-text-muted);
}

.th-nav__list a:hover {
  color: var(--th-text);
}
*/
/* メニューリンク共通 */
/*.th-nav__link {
  text-decoration: none;
  color: var(--th-text-muted);
  font-size: 0.9rem;
}
*/
.th-logo__mark--small {
  width: 1.8rem;
  height: 1.8rem;
  font-size: 1.1rem;
}

.th-logo__text--small {
  font-size: 0.85rem;
}

/*.th-header__cta {
  display: none;
  font-size: 0.85rem;
  padding: 0.4rem 0.9rem;
  border-radius: 999px;
  border: 1px solid var(--th-border);
  text-decoration: none;
  color: var(--th-text);
  background-color: #ffffff;
}*/

/* ドロップダウン用ボタンもリンクと同じ見た目にリセット */
/*button.th-nav__link {
  background: none;
  border: 0;
  padding: 0;
  margin: 0;
  font: inherit;
  color: var(--th-text-muted);
  cursor: pointer;
}*/

/* ホバー時の色（HOME と同じ） */
/*.th-nav__link:hover,
button.th-nav__link:hover {
  color: var(--th-text);
}
*/

/* ハンバーガーボタン */
/*.th-menu-toggle {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2.2rem;
  height: 2.2rem;
  border-radius: 999px;
  border: 1px solid var(--th-border);
  background-color: #ffffff;
  cursor: pointer;
  padding: 0;
}
*/
/*.th-menu-toggle__icon {
  display: inline-flex;
  flex-direction: column;
  gap: 4px;
}
*/
.th-menu-toggle__icon span {
  display: block;
  width: 16px;
  height: 2px;
  border-radius: 999px;
  background-color: var(--th-text);
  transition: transform 0.18s ease, opacity 0.18s ease;
}

/* 開いたときの × 風アニメーション */
/*.th-menu-toggle[aria-expanded="true"] .th-menu-toggle__icon span:nth-child(1) {
  transform: translateY(6px) rotate(45deg);
}
.th-menu-toggle[aria-expanded="true"] .th-menu-toggle__icon span:nth-child(2) {
  opacity: 0;
}
.th-menu-toggle[aria-expanded="true"] .th-menu-toggle__icon span:nth-child(3) {
  transform: translateY(-6px) rotate(-45deg);
}
*/
/*.th-header__cta {
  display: none;
  font-size: 0.85rem;
  padding: 0.4rem 0.9rem;
  border-radius: 999px;
  border: 1px solid var(--th-border);
  text-decoration: none;
  color: var(--th-text);
  background-color: #ffffff;
}*/

/* =========================================
   Hero
   ========================================= */
.th-hero {
  padding-top: 2.4rem;
  padding-bottom: 3.5rem;
  background-color: var(--th-bg);
}

.th-hero__inner {
  display: flex;
  flex-direction: column;
  gap: 2.5rem;
}

.th-hero__content {
  max-width: 34rem;
}

.th-eyebrow {
  font-size: 0.75rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--th-text-muted);
  margin: 0 0 0.75rem;
}

.th-hero__title {
  margin: 0 0 1rem;
  font-size: 2rem;
  line-height: 1.1;
}

.th-hero__text {
  margin: 0 0 1.5rem;
  color: var(--th-text-muted);
  font-size: 0.98rem;
}

.th-hero__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
}

.th-hero__media {
  flex: 1 1 50%;
  display: flex;
  align-items: stretch;
}

.th-hero__image-wrapper {
  position: relative;
  width: 100%;
  /* 好きなアスペクト比に調整可（ここでは 4:3） */
  padding-top: 75%;
  overflow: hidden;
  border-radius: 8px; /* 不要なら削除 */
}

.th-hero__image {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  /* object-fit / object-position / transform は inline style で上書き */
  transition: transform 0.3s ease, object-position 0.3s ease;
}

.th-hero__image-placeholder {
  width: 100%;
  aspect-ratio: 4 / 3;
  border-radius: var(--th-radius-lg);
  border: 1px dashed var(--th-border);
  background-color: #ffffff;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--th-text-muted);
  font-size: 0.9rem;
}

/* =========================================
   Buttons & links
   ========================================= */
.th-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.7rem 1.4rem;
  border-radius: 999px;
  border: 1px solid transparent;
  font-size: 0.9rem;
  text-decoration: none;
  cursor: pointer;
  transition: transform 120ms ease, box-shadow 120ms ease,
    background-color 120ms ease, border-color 120ms ease;
}

.th-btn--primary {
  background-color: var(--th-primary);
  color: #ffffff;
  box-shadow: var(--th-shadow-soft);
}

.th-btn--primary:hover {
  transform: translateY(-1px);
  box-shadow: 0 18px 40px rgba(0, 0, 0, 0.12);
}

.th-btn--ghost {
  background-color: #ffffff;
  color: var(--th-text);
  border-color: var(--th-border);
}

.th-btn--ghost:hover {
  background-color: var(--th-primary-soft);
  border-color: var(--th-primary-soft);
}

.th-link {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  font-size: 0.9rem;
  text-decoration: none;
  color: var(--th-primary);
  position: relative;
}

.th-link::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: -0.1rem;
  width: 100%;
  height: 1px;
  background-color: rgba(148, 97, 61, 0.5);
}

/* =========================================
   Grid
   ========================================= */
.th-grid {
  display: grid;
  gap: 1.5rem;
}

.th-grid--categories {
  grid-template-columns: repeat(auto-fit, minmax(210px, 1fr));
}

.th-grid--products {
  grid-template-columns: repeat(auto-fit, minmax(230px, 1fr));
}

.th-grid--stories {
  grid-template-columns: repeat(auto-fit, minmax(230px, 1fr));
}

/* =========================================
   Cards
   ========================================= */
.th-card {
  background-color: #ffffff;
  border-radius: var(--th-radius-md);
  border: 1px solid rgba(225, 217, 205, 0.6);
  overflow: hidden;
  height: 100%;
  display: flex;
  flex-direction: column;
}

.th-card__link {
  color: inherit;
  text-decoration: none;
  display: flex;
  flex-direction: column;
  height: 100%;
}

.th-card__media {
  width: 100%;
  aspect-ratio: 4 / 3;
  overflow: hidden;
}

.th-card__media--placeholder {
  background-image: linear-gradient(
    135deg,
    rgba(242, 235, 224, 0.85),
    rgba(250, 247, 243, 1)
  );
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.85rem;
  color: var(--th-text-muted);
}

.th-card__body {
  padding: 1rem 1rem 1.15rem;
}

.th-card__eyebrow {
  margin: 0 0 0.25rem;
  font-size: 0.75rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--th-text-muted);
}

.th-card__title {
  margin: 0 0 0.45rem;
  font-size: 1rem;
}

.th-card__text {
  margin: 0;
  font-size: 0.9rem;
  color: var(--th-text-muted);
}

.th-card__text--small {
  font-size: 0.85rem;
}

.th-card__price {
  margin: 0 0 0.4rem;
  font-size: 0.95rem;
}

.th-card--product .th-card__body {
  padding-top: 0.9rem;
}

.th-card--story .th-card__body {
  padding-top: 0.9rem;
}

/* ============================
   Story Cards – Image Fix
============================ */
.th-card--story .th-card__media {
  width: 100%;
  aspect-ratio: 4 / 3; /* 必要に応じて比率変更可 */
  overflow: hidden;
  border-radius: var(--th-radius-md);
  background: #f5f5f5;
  position: relative;
}

.th-card--story .th-card__media img.th-card__image {
  width: 100%;
  height: 100%;
  object-fit: cover; /* 枠いっぱいに、はみ出しなし */
  object-position: center;
  display: block;
}


/* =========================================
   Featured (Gold Thread)
   ========================================= */
.th-featured {
  display: flex;
  flex-direction: column;
  gap: 2rem;
}

.th-featured__text {
  margin: 0 0 1.5rem;
  font-size: 0.95rem;
  color: var(--th-text-muted);
}

.th-featured__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
}

.th-featured__image-placeholder {
  width: 100%;
  aspect-ratio: 4 / 3;
  border-radius: var(--th-radius-lg);
  border: 1px dashed var(--th-border);
  background-color: #ffffff;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--th-text-muted);
  font-size: 0.9rem;
}

/* Featured story image container */
.th-featured__media {
  width: 100%;
  max-width: 520px; /* お好みで調整 */
  margin-left: auto;
  margin-right: auto;
}

.th-featured__media-inner {
  position: relative;
  width: 100%;
  padding-top: 75%; /* アスペクト比 4:3。縦長にしたければ 125% などに変更 */
  overflow: hidden;
  border-radius: 16px; /* 角丸が不要なら削除 */
}

/* 画像とプレースホルダーを枠の中にフィットさせる */
.th-featured__image,
.th-featured__image-placeholder {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
}

/* アップロード画像は枠内でトリミングして表示 */
.th-featured__image {
  display: block;
  object-fit: cover; /* 「枠いっぱい＋はみ出し部分はトリミング」 */
}

/* プレースホルダー表示用 */
.th-featured__image-placeholder {
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.9rem;
  background-color: #f3f3f3; /* お好みで */
}

/* =========================================
   Split section (Craftsmanship)
   ========================================= */
.th-section--split {
  background-color: #ffffff;
}

.th-split {
  display: flex;
  flex-direction: column;
  gap: 2rem;
}

.th-split__text {
  margin: 0 0 1rem;
  font-size: 0.95rem;
  color: var(--th-text-muted);
}

.th-split__image-placeholder {
  width: 100%;
  aspect-ratio: 4 / 3;
  border-radius: var(--th-radius-lg);
  border: 1px dashed var(--th-border);
  background-color: var(--th-bg);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--th-text-muted);
  font-size: 0.9rem;
}

.th-split__image-wrapper {
  overflow: hidden;
  border-radius: var(--th-radius-lg);
}

.th-split__image {
  width: 100%;
  height: 100%;
  object-fit: cover;
}


/* =========================================
   Pills (New / Best Sellers)
   ========================================= */
.th-pill-group {
  display: inline-flex;
  padding: 0.2rem;
  border-radius: 999px;
  background-color: #ffffff;
  border: 1px solid rgba(225, 217, 205, 0.8);
  gap: 0.2rem;
}

.th-pill {
  border: 0;
  padding: 0.35rem 0.9rem;
  border-radius: 999px;
  background-color: transparent;
  font-size: 0.8rem;
  cursor: pointer;
}

.th-pill--active {
  background-color: var(--th-primary);
  color: #ffffff;
}

/* =========================================
   About
   ========================================= */
.th-about__text {
  margin: 0 0 1rem;
  color: var(--th-text-muted);
  font-size: 0.95rem;
}

/* =========================================
   Newsletter
   ========================================= */
.th-newsletter {
  display: flex;
  flex-direction: column;
  gap: 1.3rem;
}

.th-newsletter__form {
  display: flex;
  flex-direction: column;
  gap: 0.8rem;
}

.th-field {
  display: flex;
  flex-direction: column;
  gap: 0.35rem;
  font-size: 0.85rem;
}

.th-field__label {
  color: var(--th-text-muted);
}

.th-field input[type="email"] {
  padding: 0.6rem 0.75rem;
  border-radius: 999px;
  border: 1px solid rgba(225, 217, 205, 0.9);
  font-size: 0.9rem;
}

/* =========================================
   Footer
   ========================================= */
/*.th-footer {
  padding: 2.5rem 0 2rem;
  background-color: #15110d;
  color: #f2ebe3;
}
*/
/*.th-footer__inner {
  display: flex;
  flex-direction: column;
  gap: 2.5rem;
}*/

/*.th-footer__brand {
  max-width: 18rem;
}*/

/*.th-footer__copy {
  font-size: 0.85rem;
  color: #c9c0b3;
}*/

/*.th-footer__columns {
  display: grid;
  gap: 1.5rem;
  grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
}*/

/*.th-footer__heading {
  margin: 0 0 0.6rem;
  font-size: 0.85rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
}*/

/*.th-footer__column ul {
  list-style: none;
  padding: 0;
  margin: 0;
  font-size: 0.85rem;
}*/

/*.th-footer__column a {
  text-decoration: none;
  color: #d6cec3;
}

.th-footer__column a:hover {
  color: #ffffff;
}*/

/*.th-footer__column li + li {
  margin-top: 0.3rem;
}*/

/*.th-footer__bottom {
  border-top: 1px solid rgba(255, 255, 255, 0.08);
  padding-top: 1rem;
  margin-top: 0.5rem;
  font-size: 0.8rem;
  color: #a99f91;
}*/

/* =========================================
   Responsive Header
   ========================================= */
@media (min-width: 720px) {
  /*.th-header__inner {
    padding-block: 0.8rem;
  }
  */
  /* ナビはヘッダー内で横並び */
  /*.th-nav {
    position: static;
    display: block !important;
    padding: 0;
    border-bottom: none;
    background-color: transparent;
  }*/

  /* ナビ（SP デフォルトはドロワー） */
    /*.th-nav {
      position: absolute;
      left: 0;
      right: 0;
      top: 100%;
      background-color: #ffffff; 
      border-bottom: 1px solid rgba(225, 217, 205, 0.9);
      padding: 0.75rem 1.5rem 1rem;
      display: none;
    }
    */
    /*.th-nav.is-open {
      display: block;
    }*/


  /*.th-nav__list {
    flex-direction: row;
    align-items: center;
    gap: 1.5rem;
  }*/

  /* 検索フォームを表示 */
  /*.th-header__search {
    display: flex;
  }*/

  /* PC ではハンバーガーを隠す */
  /*.th-menu-toggle {
    display: none;
  }
  */
  /*.th-header__cta {
    display: inline-flex;
  }*/

  .th-hero__inner {
    flex-direction: row;
    align-items: center;
    gap: 3rem;
  }

  .th-hero__title {
    font-size: 2.4rem;
  }

  .th-featured {
    flex-direction: row;
    align-items: center;
    gap: 3rem;
  }

  .th-split {
    flex-direction: row;
    align-items: center;
    gap: 3rem;
  }

  .th-newsletter {
    flex-direction: row;
    align-items: center;
    justify-content: space-between;
  }

  .th-newsletter__form {
    flex-direction: row;
    align-items: flex-end;
  }

  .th-newsletter__form .th-btn {
    white-space: nowrap;
  }
}

@media (min-width: 960px) {
  .th-section {
    padding: 4rem 0;
  }

  .th-hero {
    padding-bottom: 4.2rem;
  }

  .th-section__header--tabs {
    flex-direction: row;
    align-items: center;
    justify-content: space-between;
  }

  /*.th-footer__inner {
    flex-direction: row;
    align-items: flex-start;
    justify-content: space-between;
  }*/
}

/* =========================================
   Base (トップページと同じトークン)
   ========================================= */
/*
:root {
  --th-bg: #faf7f3;
  --th-bg-alt: #fffaf3;
  --th-bg-accent: #f2ebe0;
  --th-text: #1f1f1f;
  --th-text-muted: #6a645a;
  --th-border: #e1d9cd;
  --th-primary: #94613d;
  --th-primary-soft: #f0e0d4;
  --th-radius-lg: 1.5rem;
  --th-radius-md: 1rem;
  --th-radius-sm: 0.5rem;
  --th-shadow-soft: 0 14px 40px rgba(0, 0, 0, 0.06);
}

*,
*::before,
*::after {
  box-sizing: border-box;
}

html {
  font-size: 16px;
}

body {
  margin: 0;
  font-family: system-ui, -apple-system, BlinkMacSystemFont, "SF Pro Text",
    "Segoe UI", sans-serif;
  color: var(--th-text);
  background-color: var(--th-bg);
  line-height: 1.6;
}
*/
/* =========================================
   Layout helpers
   ========================================= */
.th-container {
  width: 100%;
  max-width: 1120px;
  padding-inline: 1.5rem;
  margin-inline: auto;
}

.th-section {
  padding: 3.5rem 0;
}

.th-section--light {
  background-color: #ffffff;
}

.th-section__header {
  margin-bottom: 2rem;
}

.th-section__title {
  margin: 0 0 0.25rem;
  font-size: 1.4rem;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.th-section__subtitle {
  margin: 0;
  color: var(--th-text-muted);
  font-size: 0.95rem;
}




/* =========================================
   Breadcrumb
   ========================================= */
.th-breadcrumb {
  padding-top: 1.1rem;
  padding-bottom: 0.4rem;
  font-size: 0.8rem;
}

.th-breadcrumb ol {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-wrap: wrap;
  gap: 0.4rem;
  color: var(--th-text-muted);
}

.th-breadcrumb a {
  text-decoration: none;
  color: inherit;
}

.th-breadcrumb li::after {
  content: "/";
  margin-left: 0.4rem;
}

.th-breadcrumb li:last-child::after {
  content: "";
  margin: 0;
}

/* =========================================
   Typography helpers
   ========================================= */
.th-eyebrow {
  font-size: 0.75rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--th-text-muted);
  margin: 0 0 0.75rem;
}

/* =========================================
   Buttons & links
   ========================================= */
.th-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.75rem 1.5rem;
  border-radius: 999px;
  border: 1px solid transparent;
  font-size: 0.9rem;
  text-decoration: none;
  cursor: pointer;
  transition: transform 120ms ease, box-shadow 120ms ease,
    background-color 120ms ease, border-color 120ms ease;
}

.th-btn--primary {
  background-color: var(--th-primary);
  color: #ffffff;
  box-shadow: var(--th-shadow-soft);
}

.th-btn--primary:hover {
  transform: translateY(-1px);
  box-shadow: 0 18px 40px rgba(0, 0, 0, 0.12);
}

.th-link {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  font-size: 0.9rem;
  text-decoration: none;
  color: var(--th-primary);
  position: relative;
}

.th-link::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: -0.1rem;
  width: 100%;
  height: 1px;
  background-color: rgba(148, 97, 61, 0.5);
}

/* =========================================
   Product top layout
   ========================================= */
.th-product {
  padding-top: 1.5rem;
  padding-bottom: 2.5rem;
  display: grid;
  grid-template-columns: minmax(0, 1.1fr) minmax(0, 1fr);
  gap: 2.5rem;
}

.th-product__gallery {
  display: flex;
  flex-direction: column;
  gap: 0.9rem;
}

/*.th-product__media-main {
  border-radius: var(--th-radius-lg);
  overflow: hidden;
  border: 1px solid var(--th-border);
  background-color: #ffffff;
}*/

/* --- Product Main Image: Fix height to 404px --- */
/*.th-product__media-main {
  width: 100%;
  height: 404px;              
  overflow: hidden;           
  border-radius: 8px;         
}

.th-product__media-main img.th-product__media-image {
  width: 100%;
  height: 100%;
  object-fit: cover;          
  object-position: center;    
}*/

/* --- Product Main: メイン画像コンテナ（前回指定していなければ追加） --- */
.th-product__media-main {
  width: 100%;
  height: 404px;        /* 高さ固定 */
  overflow: hidden;     /* はみ出し防止 */
  border-radius: 8px;
  position: relative;
}

/* メイン画像を切り替え用にレイヤー化 */
.th-product__media-item {
  display: none;
  width: 100%;
  height: 100%;
}

.th-product__media-item--active {
  display: block;
}

.th-product__media-main img.th-product__media-image {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
}

/* --- サムネイルまわり --- */
/*.th-product__media-thumbs {
  display: flex;
  gap: 0.75rem;
  margin-top: 1rem;
  flex-wrap: wrap;
}*/

.th-product__media-thumbs {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(70px, 1fr));
  gap: 0.6rem;
  margin-top: 1rem;
}

/*.th-thumb {
  padding: 0;
  border: none;
  background: transparent;
  cursor: pointer;
}*/

.th-thumb {
  padding: 0.25rem;
  border-radius: var(--th-radius-sm);
  border: 1px solid var(--th-border);
  background-color: #ffffff;
  cursor: pointer;
  overflow: hidden; 
  display: block;
}

/*.th-thumb__img {
  display: block;
  width: 80px;
  height: 80px;
  object-fit: cover;     
  object-position: center;
  border-radius: 4px;
  overflow: hidden;
}*/

.th-thumb__img {
  display: block;
  width: 100%;          /* 枠の幅にフィット */
  aspect-ratio: 1 / 1;  /* 正方形でトリミング */
  object-fit: cover;    /* 枠いっぱい＋はみ出し部分カット */
  border-radius: calc(var(--th-radius-sm) - 2px);
}

/* アクティブなサムネイルの見た目（必要に応じて調整） */
/*.th-thumb--active .th-thumb__img {
  outline: 2px solid #333;
}*/
.th-thumb--active {
  border-color: var(--th-primary);
  box-shadow: 0 0 0 1px rgba(148, 97, 61, 0.3);
}

.th-thumb--active .th-thumb__img {
  outline: 2px solid rgba(148, 97, 61, 0.8);
}

.th-product__media-placeholder {
  width: 100%;
  aspect-ratio: 4 / 3;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--th-text-muted);
  font-size: 0.9rem;
}

/*.th-product__media-thumbs {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(70px, 1fr));
  gap: 0.6rem;
}*/

/*.th-thumb {
  border-radius: var(--th-radius-sm);
  border: 1px solid var(--th-border);
  background-color: #ffffff;
  padding: 0.4rem;
  font-size: 0.7rem;
  color: var(--th-text-muted);
  cursor: pointer;
}*/

/*.th-thumb--active {
  border-color: var(--th-primary);
  box-shadow: 0 0 0 1px rgba(148, 97, 61, 0.3);
}*/

/* =========================================
   Product image lightbox
   ========================================= */
.th-lightbox {
  position: fixed;
  inset: 0;
  display: none;
  align-items: center;
  justify-content: center;
  z-index: 999;
}

.th-lightbox.is-open {
  display: flex;
}

.th-lightbox__backdrop {
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.6);
}

.th-lightbox__content {
  position: relative;
  max-width: 90vw;
  max-height: 90vh;
  padding: 0.5rem;
}

.th-lightbox__image {
  display: block;
  max-width: 100%;
  max-height: 90vh;
  object-fit: contain;
  border-radius: 8px;
  background-color: #000;
}

.th-lightbox__close {
  position: absolute;
  top: 0.2rem;
  right: 0.4rem;
  border: 0;
  background: transparent;
  color: #ffffff;
  font-size: 1.8rem;
  line-height: 1;
  cursor: pointer;
}

/* Summary / buy box */
.th-product__summary {
  padding: 1.2rem 1.2rem 1.4rem;
  border-radius: var(--th-radius-lg);
  border: 1px solid rgba(225, 217, 205, 0.9);
  background-color: #ffffff;
}

.th-product__title {
  margin: 0 0 0.4rem;
  font-size: 1.5rem;
  line-height: 1.3;
}

.th-product__meta {
  margin: 0 0 1rem;
  color: var(--th-text-muted);
  font-size: 0.9rem;
}

.th-product__price-row {
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  gap: 0.5rem;
  margin-bottom: 0.8rem;
}

.th-product__price {
  margin: 0;
  font-size: 1.35rem;
}

.th-product__tax-note {
  margin: 0;
  font-size: 0.8rem;
  color: var(--th-text-muted);
}

.th-product__highlights {
  list-style: none;
  padding-left: 0;
  margin: 0 0 1.2rem;
  font-size: 0.9rem;
  color: var(--th-text-muted);
}

.th-product__highlights li {
  position: relative;
  padding-left: 1rem;
}

.th-product__highlights li + li {
  margin-top: 0.3rem;
}

.th-product__highlights li::before {
  content: "•";
  position: absolute;
  left: 0;
  top: 0;
}

/* Form */
.th-product__form {
  border-top: 1px solid var(--th-border);
  padding-top: 1rem;
  margin-top: 0.4rem;
}

.th-products__group--hidden {
  display: none;
}

.th-products__group--active {
  display: block;
}


.th-field {
  display: flex;
  flex-direction: column;
  gap: 0.35rem;
  font-size: 0.85rem;
  margin-bottom: 0.8rem;
}

.th-field--inline {
  flex-direction: row;
  align-items: center;
  justify-content: space-between;
}

.th-field__label {
  color: var(--th-text-muted);
}

.th-field select,
.th-field input[type="number"] {
  padding: 0.4rem 0.6rem;
  border-radius: 999px;
  border: 1px solid rgba(225, 217, 205, 0.9);
  font-size: 0.86rem;
  min-width: 7rem;
}

.th-product__add {
  width: 100%;
  margin-top: 0.4rem;
}

.th-product__note {
  margin: 0.6rem 0 0;
  font-size: 0.8rem;
  color: var(--th-text-muted);
}

.th-product__reassurance {
  margin-top: 1.2rem;
  padding-top: 0.8rem;
  border-top: 1px dashed var(--th-border);
  font-size: 0.8rem;
  color: var(--th-text-muted);
}


.th-product__reassurance p {
  margin: 0;
}

.th-product__reassurance p + p {
  margin-top: 0.25rem;
}

/* =========================================
   Product detail layout (下部)
   ========================================= */
.th-product-layout {
  display: grid;
  grid-template-columns: minmax(0, 1.6fr) minmax(0, 1fr);
  gap: 2.2rem;
}

.th-product__body {
  display: flex;
  flex-direction: column;
  gap: 1.8rem;
}

.th-product__side {
  display: flex;
  flex-direction: column;
  gap: 1.4rem;
}

.th-product-block {
  padding: 1.3rem 1.3rem 1.5rem;
  border-radius: var(--th-radius-md);
  border: 1px solid rgba(225, 217, 205, 0.9);
  background-color: #ffffff;
}

.th-product-block--table {
  padding: 1.3rem;
}

.th-product-block__title {
  margin: 0 0 0.6rem;
  font-size: 1.05rem;
}

.th-product-block__subtitle {
  margin: 0 0 0.4rem;
  font-size: 0.9rem;
  color: var(--th-text-muted);
}

.th-product-block p {
  margin: 0 0 0.7rem;
  font-size: 0.92rem;
  color: var(--th-text);
}

.th-product-block p:last-child {
  margin-bottom: 0;
}

/* Two-column layout inside block */
.th-product-two-col {
  display: grid;
  gap: 1.2rem;
}

.th-list {
  padding-left: 1.1rem;
  margin: 0;
  font-size: 0.9rem;
  color: var(--th-text-muted);
}

.th-list li + li {
  margin-top: 0.3rem;
}

.th-list--compact {
  padding-left: 1rem;
}

/* =========================================
   Artisan block
   ========================================= */
.th-artisan {
  display: grid;
  grid-template-columns: minmax(0, 1.1fr) minmax(0, 1.3fr);
  gap: 1.3rem;
  align-items: center;
}

.th-artisan__image-placeholder {
  width: 100%;
  aspect-ratio: 4 / 3;
  border-radius: var(--th-radius-md);
  border: 1px dashed var(--th-border);
  background-color: var(--th-bg-alt);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.85rem;
  color: var(--th-text-muted);
}

.th-artisan__media{
  width: 100%;
  overflow: hidden;          /* はみ出し防止 */
  border-radius: var(--th-radius-md);
}

.th-artisan__image{
  display: block;            /* 画像下の謎の隙間防止 */
  width: 100%;
  max-width: 100%;
  height: 100%;
  max-height: 100%;
  object-fit: cover;         /* 枠に合わせてトリミングして収める */
  object-position: center;
}

.th-artisan__media-link,
.th-artisan__subheading-link {
  text-decoration: none;
  color: inherit;
  display: inline-block;
}

.th-artisan__media-link { display: block; }


/* =========================================
   Tables
   ========================================= */
.th-spec-table,
.th-compare-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.88rem;
}

.th-spec-table th,
.th-spec-table td {
  padding: 0.45rem 0.2rem;
  text-align: left;
}

.th-spec-table th {
  width: 35%;
  color: var(--th-text-muted);
  font-weight: 500;
}

.th-spec-table tr + tr th,
.th-spec-table tr + tr td {
  border-top: 1px solid rgba(225, 217, 205, 0.8);
}

/* Comparison table */
.th-table-scroll {
  overflow-x: auto;
}

.th-compare-table th,
.th-compare-table td {
  padding: 0.6rem 0.6rem;
  border-bottom: 1px solid rgba(225, 217, 205, 0.8);
  text-align: left;
  white-space: nowrap;
}

.th-compare-table thead th {
  font-size: 0.8rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--th-text-muted);
}

.th-compare-table tbody th {
  font-weight: 500;
  white-space: normal;
}

/* Compare table : 商品ページ */
.th-compare-table .th-compare-link {
  color: inherit;          /* 周囲の文字色を継承 */
  text-decoration: none;   /* 下線を消す */
  font-weight: inherit;    /* 太さを揃える */
  display: inline-block;
}

/* ホバー時のみ、さりげなく変化させたい場合（任意） */
.th-compare-table .th-compare-link:hover {
  text-decoration: underline;
  opacity: 0.8;
}

/* =========================================
   Category products の商品カード画像調整
   ========================================= */

/* 画像枠：一定の比率を保ちつつ、枠内で完結させる */
.th-grid--products .th-card__media {
  position: relative;
  /* 枠の縦横比：お好みで 4/3 や 1/1 に調整可能 */
  aspect-ratio: 4 / 3;
  overflow: hidden;
}

/* 画像：枠内に全体が収まるように表示 */
.th-grid--products .th-card__image {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: contain; /* ここがポイント：画像全体を表示 */
  display: block;
}


/* =========================================
   Card grid (for recommended products)
   ========================================= */
.th-grid {
  display: grid;
  gap: 1.5rem;
}

.th-grid--products {
  grid-template-columns: repeat(auto-fit, minmax(230px, 1fr));
}

.th-recommend .th-grid--products{
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 1.25rem; /* 既存のgapに合わせて調整OK */
}

/* タブレット */
@media (max-width: 990px){
  .th-recommend .th-grid--products{
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

/* スマホ */
@media (max-width: 560px){
  .th-recommend .th-grid--products{
    grid-template-columns: 1fr;
  }
}

.th-card {
  background-color: #ffffff;
  border-radius: var(--th-radius-md);
  border: 1px solid rgba(225, 217, 205, 0.6);
  overflow: hidden;
  display: flex;
  flex-direction: column;
}

.th-card__link {
  color: inherit;
  text-decoration: none;
  display: flex;
  flex-direction: column;
  height: 100%;
}

.th-card__media {
  width: 100%;
  aspect-ratio: 4 / 3;
}

.th-card__media--placeholder {
  background-image: linear-gradient(
    135deg,
    rgba(242, 235, 224, 0.85),
    rgba(250, 247, 243, 1)
  );
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.85rem;
  color: var(--th-text-muted);
}

.th-card__body {
  padding: 1rem 1rem 1.15rem;
}

.th-card__eyebrow {
  margin: 0 0 0.25rem;
  font-size: 0.75rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--th-text-muted);
}

.th-card__title {
  margin: 0 0 0.45rem;
  font-size: 1rem;
}

.th-card__price {
  margin: 0 0 0.4rem;
  font-size: 0.95rem;
}

.th-card__text {
  margin: 0;
  font-size: 0.88rem;
  color: var(--th-text-muted);
}

.th-card__text--small {
  font-size: 0.84rem;
}

/* =========================================
   Footer (トップページと共通)
   ========================================= */
/*.th-footer {
  padding: 2.5rem 0 2rem;
  background-color: #15110d;
  color: #f2ebe3;
}*/

/*.th-footer__inner {
  display: flex;
  flex-direction: column;
  gap: 2.5rem;
}*/

/*.th-footer__brand {
  max-width: 18rem;
}*/

/*.th-footer__copy {
  font-size: 0.85rem;
  color: #c9c0b3;
}*/

/*.th-footer__columns {
  display: grid;
  gap: 1.5rem;
  grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
}*/

/*.th-footer__heading {
  margin: 0 0 0.6rem;
  font-size: 0.85rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
}*/

/*.th-footer__column ul {
  list-style: none;
  padding: 0;
  margin: 0;
  font-size: 0.85rem;
}*/

/*.th-footer__column a {
  text-decoration: none;
  color: #d6cec3;
}

.th-footer__column a:hover {
  color: #ffffff;
}*/

/*.th-footer__column li + li {
  margin-top: 0.3rem;
}*/

/*.th-footer__bottom {
  border-top: 1px solid rgba(255, 255, 255, 0.08);
  padding-top: 1rem;
  margin-top: 0.5rem;
  font-size: 0.8rem;
  color: #a99f91;
}*/

/* =========================================
   Responsive
   ========================================= */
@media (min-width: 720px) {
  /*.th-nav {
    display: block;
  }*/

  /*.th-header__cta {
    display: inline-flex;
  }*/

  .th-product {
    align-items: flex-start;
  }

  .th-product-two-col {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 719.98px) {
  .th-product {
    grid-template-columns: minmax(0, 1fr);
  }

  .th-product__summary {
    padding: 1rem 1rem 1.3rem;
  }

  .th-field--inline {
    flex-direction: column;
    align-items: flex-start;
    gap: 0.3rem;
  }

  .th-product-layout {
    grid-template-columns: minmax(0, 1fr);
  }

  .th-artisan {
    grid-template-columns: minmax(0, 1fr);
  }
}

/*@media (min-width: 960px) {
  .th-footer__inner {
    flex-direction: row;
    align-items: flex-start;
    justify-content: space-between;
  }
}*/


/* ============================================================
   CATEGORY PAGE
   ============================================================ */

/* ---------- CATEGORY HERO (タイトル + 説明 + サブカテゴリ) ---------- */

.th-category-hero {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: 2rem;
  align-items: center;
}

.th-category-hero__content {
  display: flex;
  flex-direction: column;
  gap: 1.2rem;
}

.th-category-hero__title {
  margin: 0;
  font-size: 2rem;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.th-category-hero__intro {
  margin: 0;
  color: var(--th-text-muted);
  font-size: 1rem;
  line-height: 1.7;
  max-width: 42rem;
}

.th-category-subnav {
  display: flex;
  flex-wrap: wrap;
  gap: 0.4rem;
  margin-top: 0.4rem;
}

.th-category-subnav .th-pill {
  cursor: pointer;
  background-color: #ffffff;
  border: 1px solid var(--th-border);
}

.th-category-subnav .th-pill--active {
  background-color: var(--th-primary);
  color: #ffffff;
  border-color: var(--th-primary);
}

/* ---------- CATEGORY HERO IMAGE ---------- */

/* Category hero : dynamic height */
.th-category-hero__media {
  max-height: var(--hero-max-height, 360px);
  overflow: hidden;
  border-radius: var(--th-radius-lg);
}

.th-category-hero__image {
  width: 100%;
  height: 100%;
  max-height: var(--hero-max-height, 360px);
  object-fit: cover;
  object-position: center;
  display: block;
}

.th-category-hero__image-placeholder {
  width: 100%;
  aspect-ratio: 4 / 3;
  border-radius: var(--th-radius-lg);
  border: 1px dashed var(--th-border);
  background-color: #ffffff;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--th-text-muted);
  font-size: 0.9rem;
}

/* ---------- FAQ block (カテゴリ用バージョン) ---------- */

.th-faq {
  padding: 0.9rem 0;
  border-bottom: 1px solid rgba(225, 217, 205, 0.7);
}

.th-faq:first-of-type {
  border-top: 1px solid rgba(225, 217, 205, 0.7);
}

.th-faq__summary {
  cursor: pointer;
  font-size: 1rem;
  font-weight: 500;
  color: var(--th-text);
  list-style: none;
}

.th-faq__summary::-webkit-details-marker {
  display: none;
}

.th-faq__summary::after {
  content: "+";
  float: right;
  color: var(--th-text-muted);
}

details[open] .th-faq__summary::after {
  content: "–";
}

.th-faq__content {
  margin-top: 0.6rem;
  color: var(--th-text-muted);
  font-size: 0.9rem;
  line-height: 1.6;
}

/* ---------- RESPONSIVE LAYOUT ---------- */

@media (min-width: 720px) {
  .th-category-hero {
    grid-template-columns: minmax(0, 1.2fr) minmax(0, 1fr);
    gap: 3rem;
  }

  .th-category-hero__title {
    font-size: 2.4rem;
  }

  .th-category-hero__intro {
    font-size: 1.05rem;
  }
}

@media (min-width: 960px) {
  .th-category-hero {
    grid-template-columns: minmax(0, 1fr) minmax(0, 0.9fr);
  }
}

/* ============================================================
   GOLD THREAD LP
   ============================================================ */

/* ---------- HERO ---------- */
.gt-hero {
  background-color: #fffaf3;
  padding: 4rem 0;
}

.gt-hero__inner {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: 2.5rem;
  align-items: center;
}

.gt-hero__title {
  margin: 0;
  font-size: 2.4rem;
  letter-spacing: 0.03em;
  text-transform: uppercase;
}

.gt-hero__lead {
  color: var(--th-text-muted);
  max-width: 38rem;
  line-height: 1.7;
}

.gt-hero__actions {
  margin-top: 1.2rem;
}

.gt-hero__image-placeholder {
  width: 100%;
  aspect-ratio: 4 / 3;
  border-radius: var(--th-radius-lg);
  border: 1px dashed var(--th-border);
  background-color: #ffffff;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--th-text-muted);
}

/* ---------- CONTENT BLOCK ---------- */
.gt-block {
  max-width: 760px;
  margin-inline: auto;
  text-align: left;
}

.gt-block__title {
  margin: 0 0 1rem;
  font-size: 1.6rem;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.gt-block__text {
  margin: 0 0 1rem;
  color: var(--th-text-muted);
  line-height: 1.7;
}

.gt-ul {
  padding-left: 1.2rem;
  color: var(--th-text-muted);
  line-height: 1.6;
}

.gt-ul li + li {
  margin-top: 0.4rem;
}

/* ---------- PROCESS ---------- */
.gt-process__grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 1.6rem;
  margin-top: 1.2rem;
}

.gt-step__media-placeholder {
  width: 100%;
  aspect-ratio: 4 / 3;
  border-radius: var(--th-radius-md);
  border: 1px dashed var(--th-border);
  background-color: #ffffff;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--th-text-muted);
  font-size: 1.3rem;
}

.gt-step__title {
  margin: 0.8rem 0 0.4rem;
  font-size: 1rem;
}

.gt-step__text {
  margin: 0;
  color: var(--th-text-muted);
  font-size: 0.9rem;
}

/* ---------- ARTISAN ---------- */
.gt-artisan {
  display: grid;
  gap: 2rem;
  grid-template-columns: minmax(0, 1fr);
}

.gt-artisan__image-placeholder {
  width: 100%;
  aspect-ratio: 4 / 3;
  border: 1px dashed var(--th-border);
  background-color: var(--th-bg-alt);
  border-radius: var(--th-radius-md);
  display: flex;
  align-items: center;
  justify-content: center;
}

.gt-artisan__title {
  margin: 0 0 0.3rem;
  font-size: 1.4rem;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.gt-artisan__subtitle {
  margin: 0 0 1rem;
  color: var(--th-text-muted);
  font-size: 0.9rem;
}

/* ---------- CTA ---------- */
.gt-cta {
  text-align: center;
  background-color: #fffaf3;
}

.gt-cta__inner {
  display: flex;
  flex-direction: column;
  gap: 1rem;
  align-items: center;
}

.gt-cta__title {
  margin: 0;
  font-size: 1.6rem;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

/* ---------- RESPONSIVE ---------- */
@media (min-width: 720px) {
  .gt-hero__inner {
    grid-template-columns: minmax(0, 1.1fr) minmax(0, 1fr);
  }
  .gt-artisan {
    grid-template-columns: minmax(0, 1.1fr) minmax(0, 1fr);
  }
}

/* =========================================
   Gold Thread page
   ========================================= */

.gt-hero {
  background: var(--th-bg-alt);
}

.gt-hero__inner {
  display: grid;
  grid-template-columns: minmax(0, 1.2fr) minmax(0, 1fr);
  gap: 2.5rem;
  align-items: center;
}

.gt-hero__title {
  font-size: 2.5rem;
  line-height: 1.2;
  margin-bottom: 1rem;
}

.gt-hero__lead {
  font-size: 1rem;
  line-height: 1.7;
  color: var(--th-text-muted);
  margin-bottom: 1.5rem;
}

.gt-hero__actions {
  display: flex;
  gap: 1rem;
  flex-wrap: wrap;
}

.gt-hero__media {
  position: relative;
}

.gt-hero__image,
.gt-artisan__image {
  width: 100%;
  height: 100%;
  max-height: 420px;
  object-fit: cover;
  border-radius: var(--th-radius-lg);
  display: block;
}

.gt-hero__image-placeholder,
.gt-step__media-placeholder,
.gt-artisan__image-placeholder {
  border-radius: var(--th-radius-lg);
  border: 1px dashed var(--th-border);
  padding: 2.5rem 1.5rem;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--th-text-muted);
  text-align: center;
}

/* Generic block */

.gt-block {
  max-width: 52rem;
  margin: 0 auto;
  text-align: left;
}

.gt-block__title {
  font-size: 1.75rem;
  margin-bottom: 1rem;
}

.gt-block__text {
  font-size: 1rem;
  line-height: 1.8;
  color: var(--th-text-muted);
  margin-bottom: 1rem;
}

/* Process */

.gt-process__grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 1.5rem;
}

.gt-step {
  background: #ffffff;
  border-radius: var(--th-radius-md);
  padding: 1.25rem;
  box-shadow: var(--th-shadow-soft);
}

.gt-step__media {
  margin-bottom: 1rem;
}

.gt-step__image {
  width: 100%;
  height: 180px;
  object-fit: cover;
  border-radius: var(--th-radius-md);
  display: block;
}

.gt-step__media-placeholder {
  height: 180px;
}

.gt-step__title {
  font-size: 1.05rem;
  margin-bottom: 0.5rem;
}

.gt-step__text {
  font-size: 0.95rem;
  line-height: 1.7;
  color: var(--th-text-muted);
}

/* Lists */

.gt-ul {
  list-style: none;
  padding: 0;
  margin: 1rem 0 0;
}

.gt-ul li {
  position: relative;
  padding-left: 1.4rem;
  margin-bottom: 0.5rem;
  font-size: 0.98rem;
}

.gt-ul li::before {
  content: "";
  position: absolute;
  left: 0.4rem;
  top: 0.7rem;
  width: 6px;
  height: 6px;
  border-radius: 999px;
  background: var(--th-primary);
}

/* Artisan */

.gt-artisan {
  display: grid;
  grid-template-columns: minmax(0, 1.1fr) minmax(0, 1fr);
  gap: 2.5rem;
  align-items: center;
}

.gt-artisan__subtitle {
  font-size: 0.95rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--th-text-muted);
  margin-bottom: 0.75rem;
}

.gt-artisan__text {
  font-size: 0.98rem;
  line-height: 1.8;
  color: var(--th-text-muted);
  margin-bottom: 1rem;
}

/* CTA */

.gt-cta {
  text-align: center;
}

.gt-cta__inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 1.25rem;
}

.gt-cta__title {
  font-size: 1.75rem;
}

/* Responsive */

@media (max-width: 960px) {
  .gt-hero__inner,
  .gt-artisan {
    grid-template-columns: minmax(0, 1fr);
  }

  .gt-hero__media {
    order: -1;
  }

  .gt-process__grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 600px) {
  .gt-hero__title {
    font-size: 2rem;
  }

  .gt-process__grid {
    grid-template-columns: minmax(0, 1fr);
  }

  .gt-step__image,
  .gt-step__media-placeholder {
    height: 200px;
  }
}
