/* ===== すべて #etkApp 配下のみ適用 ===== */
#etkApp{
  --etk-paper:#FFFEF9;
  --etk-ink:#2D4059;
  --etk-coral:#FF8A7A;
  --etk-coral-dark:#d96a5c;
  --etk-sun:#FFD25E;
  --etk-leaf:#8BC34A;
  --etk-line:#E4DECF;
  /* プリント位置（Tシャツ写真に合わせて調整） */
  --etk-print-top:22%;
  --etk-print-width:46%;

  font-family:"Hiragino Maru Gothic ProN","HGMaruGothicMPRO","BIZ UDGothic","Yu Gothic","Meiryo",sans-serif;
  color:var(--etk-ink);
  max-width:1060px;
  margin:0 auto;
  display:grid;
  grid-template-columns:1.15fr .85fr;
  column-gap:32px;
  align-items:start;
  line-height:1.5;
}
#etkApp .etk-col{
  display:flex;
  flex-direction:column;
  gap:18px;
}
#etkApp .etk-dl-field{margin-top:0;}
#etkApp *,
#etkApp *::before,
#etkApp *::after{box-sizing:border-box;margin:0;padding:0;}

/* ----- プレビュー ----- */
#etkApp .etk-stage{
  width:100%;
}
#etkApp .etk-stage-shirt{
  position:relative;
}
#etkApp .etk-shirt-img{
  display:block;
  width:100%;
  height:auto;
  user-select:none;
  -webkit-user-drag:none;
}
#etkApp .etk-img-missing{
  display:none;
  width:100%;
  aspect-ratio:6/7;
  border:3px dashed var(--etk-line);
  border-radius:18px;
  background:#fff;
  color:#8a97aa;
  font-size:.85rem;
  text-align:center;
  align-content:center;
  padding:20px;
  word-break:break-all;
}
#etkApp .etk-stage.etk-no-img .etk-shirt-img{display:none;}
#etkApp .etk-stage.etk-no-img .etk-img-missing{display:grid;}

#etkApp .etk-print{
  position:absolute;
  top:var(--etk-print-top);
  left:50%;
  transform:translateX(-50%);
  width:var(--etk-print-width);
  pointer-events:none;
}
#etkApp .etk-print svg{display:block;width:100%;height:auto;}

/* ----- Tシャツ下部の設定情報パネル ----- */
#etkApp .etk-info{
  background:var(--etk-paper);
  border:2px solid var(--etk-line);
  border-radius:16px;
  padding:12px 18px;
  font-size:1.4rem;
  /* font-size:.86rem; */
}
#etkApp .etk-info-row{
  display:flex;
  align-items:center;
  gap:10px;
  padding:7px 0;
  border-bottom:1px dashed var(--etk-line);
}
#etkApp .etk-info-row:last-child{border-bottom:none;}
#etkApp .etk-info-label{
  flex:none;
  width:8.5em;
  color:#8a97aa;
  font-weight:700;
  letter-spacing:.04em;
}
#etkApp .etk-info-dot{
  flex:none;
  width:15px;height:15px;
  border-radius:50%;
  border:2px solid #C9CFD8;
  display:inline-block;
}
#etkApp .etk-info-value{
  color:var(--etk-ink);
  word-break:break-all;
}

/* ----- 操作パネル ----- */
#etkApp .etk-panel{
  background:var(--etk-paper);
  border:2px solid var(--etk-line);
  border-radius:22px;
  padding:26px 24px 28px;
  box-shadow:0 6px 0 rgba(45,64,89,.06);
}
#etkApp .etk-field{margin-bottom:26px;}
#etkApp .etk-field:last-child{margin-bottom:0;}
#etkApp .etk-label{
  display:flex;align-items:center;gap:8px;
  font-weight:700;
  font-size:1.5rem;
  /* font-size:.95rem; */
  margin-bottom:12px;
  letter-spacing:.06em;
}
#etkApp .etk-badge{
  width:12px;height:12px;
  border-radius:50% 46% 52% 48%;
  display:inline-block;flex:none;
}
#etkApp .etk-badge--1{background:var(--etk-coral);}
#etkApp .etk-badge--2{background:var(--etk-sun);}
#etkApp .etk-badge--3{background:var(--etk-leaf);}

#etkApp .etk-text-input{
  width:100%;
  font:inherit;
  font-size:1.5rem;
  /* font-size:1.05rem; */
  padding:12px 14px;
  border:2px solid var(--etk-line);
  border-radius:14px;
  background:#fff;
  color:var(--etk-ink);
  letter-spacing:.04em;
}
#etkApp .etk-text-input:focus{
  outline:3px solid var(--etk-sun);
  outline-offset:2px;
  border-color:var(--etk-sun);
}
#etkApp .etk-hint{
  margin-top:8px;
  font-size:1.3rem;
  /* font-size:.78rem; */
  color:#8a97aa;}

#etkApp .etk-swatches{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(44px,1fr));
  gap:10px;
}
#etkApp .etk-swatch{
  appearance:none;border:none;cursor:pointer;
  width:44px;height:44px;
  border-radius:46% 54% 50% 50% / 52% 48% 52% 48%;
  border:3px solid rgba(45,64,89,.14);
  transition:transform .12s ease;
  position:relative;
  font:inherit;
}
#etkApp .etk-swatch:hover{transform:scale(1.1) rotate(-4deg);}
#etkApp .etk-swatch:focus-visible{outline:3px solid var(--etk-coral);outline-offset:2px;}
#etkApp .etk-swatch[aria-pressed="true"]{
  border-color:var(--etk-ink);
  box-shadow:0 0 0 3px var(--etk-paper), 0 0 0 6px var(--etk-sun);
}
#etkApp .etk-swatch[aria-pressed="true"]::after{
  content:"✓";
  position:absolute;inset:0;
  display:grid;place-items:center;
  font-weight:700;font-size:1.05rem;
}
#etkApp .etk-swatch--light::after{color:var(--etk-ink);}
#etkApp .etk-swatch--dark::after{color:#fff;}

/* ----- スウォッチのアコーディオン（15色目以降） ----- */
#etkApp .etk-more-box{
  max-height:0;
  overflow:hidden;
  margin-top:0;
  transition:max-height .3s ease, margin-top .3s ease;
}
#etkApp .etk-more-box.etk-open{
  margin-top:10px;
}
#etkApp .etk-more-btn{
  appearance:none;cursor:pointer;
  width:100%;
  margin-top:12px;
  padding:9px;
  border:2px dashed var(--etk-line);
  border-radius:12px;
  background:#fff;
  color:#6b7a90;
  font:inherit;
  font-size:1.3rem;
  /* font-size:.85rem; */
  font-weight:700;
  letter-spacing:.05em;
  transition:background .15s ease;
}
#etkApp .etk-more-btn:hover{background:#FFF8E6;}
#etkApp .etk-more-btn:focus-visible{
  outline:3px solid var(--etk-sun);
  outline-offset:2px;
}
#etkApp .etk-more-btn .etk-more-caret{
  display:inline-block;
  margin-left:6px;
  font-size:.75rem;
  transition:transform .25s ease;
}
#etkApp .etk-more-btn[aria-expanded="true"] .etk-more-caret{
  transform:rotate(180deg);
}

/* ----- フォント選択（プルダウン） ----- */
#etkApp .etk-font-dd{position:relative;}
#etkApp .etk-font-dd-btn{
  appearance:none;cursor:pointer;
  width:100%;
  display:flex;align-items:center;gap:12px;
  border:2px solid var(--etk-line);
  border-radius:14px;
  background:#fff;
  color:var(--etk-ink);
  padding:10px 14px;
  text-align:left;
  font:inherit;
}
#etkApp .etk-font-dd-btn:focus-visible{
  outline:3px solid var(--etk-sun);
  outline-offset:2px;
  border-color:var(--etk-sun);
}
#etkApp .etk-font-dd-btn .etk-font-sample{
  font-size:1.5rem;
  /* font-size:1.25rem; */
  font-weight:bold;
  line-height:1.2;
}
#etkApp .etk-font-dd-btn .etk-font-name{
  font-size:.78rem;color:#8a97aa;
  font-family:"Hiragino Maru Gothic ProN","HGMaruGothicMPRO","BIZ UDGothic","Yu Gothic","Meiryo",sans-serif;
}
#etkApp .etk-font-dd-caret{
  margin-left:auto;
  font-size:.8rem;color:#8a97aa;
  transition:transform .15s ease;
}
#etkApp .etk-font-dd.etk-open .etk-font-dd-caret{transform:rotate(180deg);}

#etkApp .etk-font-dd-list{
  position:absolute;
  top:calc(100% + 6px);left:0;right:0;
  z-index:9999;
  display:none;
  background:#fff;
  border:2px solid var(--etk-line);
  border-radius:14px;
  box-shadow:0 10px 24px rgba(45,64,89,.16);
  max-height:300px;
  overflow-y:auto;
  padding:6px;
  list-style:none;
}
#etkApp .etk-font-dd.etk-open .etk-font-dd-list{display:block;}
#etkApp .etk-font-dd-item{
  appearance:none;cursor:pointer;
  width:100%;
  display:flex;align-items:center;gap:12px;
  border:none;border-radius:10px;
  background:transparent;
  color:var(--etk-ink);
  padding:9px 12px;
  text-align:left;
  font:inherit;
}
#etkApp .etk-font-dd-item:hover,
#etkApp .etk-font-dd-item:focus-visible{
  background:#FFF3D6;
  outline:none;
}
#etkApp .etk-font-dd-item .etk-font-sample{
  font-size:1.2rem;
  font-weight:bold;
  line-height:1.2;
}
#etkApp .etk-font-dd-item .etk-font-name{
  font-size:.74rem;color:#8a97aa;
  font-family:"Hiragino Maru Gothic ProN","HGMaruGothicMPRO","BIZ UDGothic","Yu Gothic","Meiryo",sans-serif;
}
#etkApp .etk-font-dd-item[aria-selected="true"]{
  background:#FFF8E6;
}
#etkApp .etk-font-dd-item[aria-selected="true"]::after{
  content:"✓";
  margin-left:auto;
  font-weight:700;
  color:var(--etk-coral);
}

/* ----- サイズ調整スライダー ----- */
#etkApp .etk-slider-row{
  display:flex;align-items:center;gap:14px;
}
#etkApp .etk-slider{
  -webkit-appearance:none;
  appearance:none;
  flex:1;
  height:10px;
  border-radius:8px;
  background:var(--etk-line);
  outline:none;
  cursor:pointer;
  margin:0;
}
#etkApp .etk-slider:focus-visible{
  outline:3px solid var(--etk-sun);
  outline-offset:4px;
}
#etkApp .etk-slider::-webkit-slider-thumb{
  -webkit-appearance:none;
  appearance:none;
  width:24px;height:24px;
  border-radius:50%;
  background:var(--etk-coral);
  border:3px solid #fff;
  box-shadow:0 2px 4px rgba(45,64,89,.3);
  cursor:grab;
}
#etkApp .etk-slider::-webkit-slider-thumb:active{cursor:grabbing;}
#etkApp .etk-slider::-moz-range-thumb{
  width:18px;height:18px;
  border-radius:50%;
  background:var(--etk-coral);
  border:3px solid #fff;
  box-shadow:0 2px 4px rgba(45,64,89,.3);
  cursor:grab;
}
#etkApp .etk-slider-val{
  flex:none;
  min-width:56px;
  text-align:center;
  font-weight:700;
  font-size:.85rem;
  background:#fff;
  border:2px solid var(--etk-line);
  border-radius:10px;
  padding:5px 6px;
}
#etkApp .etk-slider-ends{
  display:flex;justify-content:space-between;
  margin-top:6px;
  font-size:1.3rem;
  /* font-size:.72rem; */
  color:#8a97aa;
}

#etkApp .etk-dl{
  width:100%;
  font:inherit;
  font-weight:700;
  font-size:1.4rem;
  /* font-size:1rem; */
  letter-spacing:.08em;
  padding:14px;
  border:none;border-radius:16px;
  background:var(--etk-coral);
  color:#fff;cursor:pointer;
  box-shadow:0 5px 0 var(--etk-coral-dark);
  transition:transform .1s ease, box-shadow .1s ease;
}
#etkApp .etk-dl:hover{transform:translateY(2px);box-shadow:0 3px 0 var(--etk-coral-dark);}
#etkApp .etk-dl:active{transform:translateY(5px);box-shadow:0 0 0 var(--etk-coral-dark);}
#etkApp .etk-dl:focus-visible{outline:3px solid var(--etk-ink);outline-offset:3px;}

@media (max-width:820px){
  #etkApp{
    display:flex;
    flex-direction:column;
    gap:26px;
  }
  /* 左右カラムの枠を透過させ、中身を直接の並び替え対象にする */
  #etkApp .etk-col{display:contents;}
  /* スマホでの表示順：プレビュー → 操作パネル → 設定情報 → ダウンロード */
  #etkApp .etk-stage{order:0;}
  #etkApp .etk-panel{
    order:1;
    /*追記*/
    margin: 0 auto;
    width: 95%;
  }
  #etkApp #etk-info{
    order:2;
    /*追記*/
    margin: 0 auto;
    width: 95%;
  }
  #etkApp .etk-dl-field{
    order:3;
    /*追記*/
    margin: 0 auto;
    width: 80%;
  }
}

/*
================================================================
 クラスTシャツ ロゴジェネレーター｜つかい方ガイド（利用者向け）
================================================================
■ 使い方
  このブロックを、ロゴアプリ（#etkApp）のすぐ下に貼り付けてください。
  単体でも動作します（JavaScriptは不要・表示のみ）。

■ 干渉対策
  ・CSSはすべて #etkGuide 配下のみに適用
  ・クラスは etkg- プレフィックスで他と衝突しません
================================================================
*/
#etkGuide{
  --etkg-paper:#FFFEF9;
  --etkg-ink:#2D4059;
  --etkg-coral:#FF8A7A;
  --etkg-sun:#FFD25E;
  --etkg-line:#E4DECF;
  --etkg-head:#FFF3D6;

  font-family:"Hiragino Maru Gothic ProN","HGMaruGothicMPRO","BIZ UDGothic","Yu Gothic","Meiryo",sans-serif;
  color:var(--etkg-ink);
  max-width:1060px;
  margin:32px auto 0;
  line-height:1.6;
  width: 95%;
}
#etkGuide *,
#etkGuide *::before,
#etkGuide *::after{box-sizing:border-box;margin:0;padding:0;}

#etkGuide .etkg-head{
  display:flex;
  align-items:center;
  gap:10px;
  margin-bottom:16px;
  padding-left: 10px;
}
#etkGuide .etkg-head .etkg-mark{
  width:16px;height:16px;flex:none;
  border-radius:50% 46% 52% 48%;
  background:var(--etkg-coral);
}
#etkGuide .etkg-head h2{
  font-size:1.4rem;
  /* font-size:1.15rem; */
  letter-spacing:.06em;
}
#etkGuide .etkg-lead{
  font-size:1.4rem;
  /* font-size:.9rem; */
  color:#6b7a90;
  margin-bottom:18px;
}

#etkGuide .etkg-card{
  background:var(--etkg-paper);
  border:2px solid var(--etkg-line);
  border-radius:18px;
  overflow:hidden;
  box-shadow:0 6px 0 rgba(45,64,89,.06);
}
#etkGuide table{
  width:100%;
  border-collapse:collapse;
  font-size:.9rem;
}
#etkGuide caption{
  caption-side:top;
  text-align:left;
  padding:14px 18px 0;
  font-size:1.4rem;
  /* font-size:.78rem; */
  color:#8a97aa;
  display: flex;
}
#etkGuide thead th{
  background:var(--etkg-head);
  color:var(--etkg-ink);
  font-weight:700;
  text-align:left;
  padding:12px 18px;
  letter-spacing:.04em;
  border-bottom:2px solid var(--etkg-line);
}
#etkGuide tbody th{
  font-weight:700;
  text-align:left;
  white-space:nowrap;
  padding:13px 18px;
  vertical-align:top;
  border-bottom:1px dashed var(--etkg-line);
}
#etkGuide tbody td{
  padding:13px 18px;
  vertical-align:top;
  color:#4a5a70;
  border-bottom:1px dashed var(--etkg-line);
  font-size: 1.4rem;
  text-align: left;
}
#etkGuide tbody tr:last-child th,
#etkGuide tbody tr:last-child td{border-bottom:none;}
#etkGuide tbody tr:nth-child(even) th,
#etkGuide tbody tr:nth-child(even) td{
  background:rgba(255,243,214,.32);
}

/* アイコン（丸） */
#etkGuide .etkg-ico{
  display:inline-flex;align-items:center;justify-content:center;
  width:45px;
  height:45px;
  flex:none;
  border-radius:50% 46% 52% 48%;
  background:var(--etkg-sun);
  font-size:3.0rem;
  /* font-size:.95rem; */
  margin-right:10px;
  vertical-align:-6px;
}
#etkGuide .etkg-name{
  display:inline;
  font-size: 1.4rem;
}

#etkGuide .etkg-note{
  margin-top:14px;
  font-size:1.3rem;
  /* font-size:.8rem; */
  color:#8a97aa;
  padding-left:2px;
}

/* スマホ：表をカード型に積み替え */
@media (max-width:600px){
  #etkGuide thead{display:none;}
  #etkGuide table,
  #etkGuide tbody,
  #etkGuide tbody tr,
  #etkGuide tbody th,
  #etkGuide tbody td{display:block;width:100%;}
  #etkGuide tbody tr{
    padding:6px 0;
    border-bottom:1px dashed var(--etkg-line);
  }
  #etkGuide tbody tr:last-child{border-bottom:none;}
  #etkGuide tbody th{
    border-bottom:none;
    padding-bottom:2px;
    white-space:normal;
  }
  #etkGuide tbody td{
    border-bottom:none;
    padding-top:0;
    padding-left:54px;
  }
  #etkGuide tbody tr:nth-child(even) th,
  #etkGuide tbody tr:nth-child(even) td{background:transparent;}
}

/*
================================================================
 Tシャツ紹介ブロック（見出し＋画像＋説明文）
================================================================
■ 使い方
  このブロックを、既存ページの好きな場所に貼り付けてください。
  ロゴジェネレーター（#etkApp）とは独立していて、単体で動きます。

■ レイアウト
  ・PC ：見出しが上、その下の左に画像・右に説明文
  ・スマホ：見出し → 画像 → 説明文 の縦1列

■ 画像の差し替え
  <img class="etki-img" src="..."> の src を実際のwebpパスに
  書き換えてください（現在は仮のパスを設定しています）。

■ 干渉対策
  ・CSSはすべて #etkIntro 配下のみに適用
  ・クラスは etki- プレフィックスで他と衝突しません
  ・JavaScriptは使用していません（表示のみ）
================================================================
*/
#etkIntro{
  --etki-paper:#FFFEF9;
  --etki-ink:#2D4059;
  --etki-sub:#6b7a90;
  --etki-coral:#FF8A7A;
  --etki-line:#E4DECF;
  --etki-head:#FFF3D6;

  font-family:"Hiragino Maru Gothic ProN","HGMaruGothicMPRO","BIZ UDGothic","Yu Gothic","Meiryo",sans-serif;
  color:var(--etki-ink);
  max-width:1060px;
  margin:32px auto 0;
  line-height:1.7;
}
#etkIntro *,
#etkIntro *::before,
#etkIntro *::after{box-sizing:border-box;margin:0;padding:0;}

/* カード全体 */
#etkIntro .etki-card{
  background:var(--etki-paper);
  border:2px solid var(--etki-line);
  border-radius:20px;
  overflow:hidden;
  box-shadow:0 6px 0 rgba(45,64,89,.06);
}

/* 見出し（上・横幅いっぱい） */
#etkIntro .etki-head{
  display:flex;align-items:center;gap:10px;
  background:var(--etki-head);
  border-bottom:2px solid var(--etki-line);
  padding:16px 22px;
}
#etkIntro .etki-head .etki-mark{
  width:16px;height:16px;flex:none;
  border-radius:50% 46% 52% 48%;
  background:var(--etki-coral);
}
#etkIntro .etki-head h2{
  font-size:1.4rem;
  letter-spacing:.06em;
}

/* 本体（画像＋説明文） */
#etkIntro .etki-body{
  display:grid;
  grid-template-columns:1fr 1fr; /* PC：左に画像・右に説明文 */
  gap:24px;
  padding:22px;
  align-items:start;
}

/* 画像（左） */
#etkIntro .etki-figure{margin:0;}
#etkIntro .etki-img{
  display:block;
  width:100%;
  height:auto;
  border-radius:14px;
  background:#fff;
  border:1px solid var(--etki-line);
}
#etkIntro .etki-cap{
  margin-top:8px;
  font-size:1.4rem;
  color:var(--etki-sub);
  text-align:center;
}

/* 説明文（右） */
#etkIntro .etki-desc h3{
  font-size:1.4rem;
  margin-bottom:10px;
  letter-spacing:.04em;
}
#etkIntro .etki-desc p{
  font-size:1.4rem;
  color:#4a5a70;
  margin-bottom:12px;
}
#etkIntro .etki-desc p:last-child{margin-bottom:0;}
#etkIntro .etki-list{
  list-style:none;
  margin:0 0 4px;
  padding:0;
}
#etkIntro .etki-list li{
  position:relative;
  padding-left:24px;
  font-size:1.4rem;
  color:#4a5a70;
  margin-bottom:8px;
  border-bottom: 1px dotted;
  padding-bottom: 7px;
}
#etkIntro .etki-list li::before{
  content:"";
  position:absolute;left:2px;top:.45em;
  width:11px;height:11px;
  border-radius:50% 46% 52% 48%;
  background:var(--etki-coral);
}

/* 「Tシャツ詳細へ」ボタン */
#etkIntro .etki-btn{
  display:inline-flex;
  align-items:center;
  gap:8px;
  margin-top:16px;
  padding:13px 26px;
  background:var(--etki-coral);
  color:#fff;
  font-size:1.4rem;
  font-weight:700;
  letter-spacing:.06em;
  text-decoration:none;
  border-radius:14px;
  box-shadow:0 4px 0 #d96a5c;
  transition:transform .1s ease, box-shadow .1s ease;
  width: 100%;
}
#etkIntro .etki-btn:hover{
  transform:translateY(2px);
  box-shadow:0 2px 0 #d96a5c;
}
#etkIntro .etki-btn:active{
  transform:translateY(4px);
  box-shadow:0 0 0 #d96a5c;
}
#etkIntro .etki-btn:focus-visible{
  outline:3px solid var(--etki-ink);
  outline-offset:3px;
}
#etkIntro .etki-btn .etki-btn-arrow{
  font-size:1.1em;
  line-height:1;
}


/* スマホ：見出し → 画像 → 説明文 の1列 */
@media (max-width:720px){
  #etkIntro .etki-body{
    grid-template-columns:1fr;
    gap:18px;
  }
}