/* Local Dive 無料1分診断 (Stage 3)
 * 右上 FAB → 2 問質問 → 5 つの DX パックから 1 つを推奨。
 */

/* ============================================================
 * Step 1: FAB (ヘッダー直下、業種ごとに「赤」のトンマナを変えて配置)
 *   - ベースは温かみのある赤グラデ + パルス (元の v9 の意匠を踏襲)
 *   - data-industry で業種ごとに赤の系統を切替
 * ============================================================ */
#ld-qd-fab{
  position: fixed;
  top: 110px;
  right: 18px;
  z-index: 9998;
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 13px 20px 13px 24px;
  border: none;
  border-radius: 999px;
  cursor: pointer;
  font-family: 'Noto Sans JP', sans-serif;
  font-weight: 700;
  font-size: 14px;
  letter-spacing: 0.04em;
  color: #fff;
  /* 既定: warm red (元の v9 を継承) */
  background: linear-gradient(135deg, #ff7a8e 0%, #ff5e3a 50%, #ffa05a 100%);
  box-shadow:
    0 12px 28px rgba(255, 94, 58, 0.36),
    0 4px 8px rgba(255, 94, 58, 0.20),
    inset 0 1px 0 rgba(255, 255, 255, 0.30);
  white-space: nowrap;
  text-decoration: none;
  transition: transform 0.25s ease, box-shadow 0.25s ease;
  animation: ld-qd-pulse 3.2s ease-in-out infinite;
}
#ld-qd-fab:hover{
  transform: translateY(-2px) scale(1.03);
  box-shadow:
    0 18px 36px rgba(255, 94, 58, 0.46),
    0 6px 12px rgba(255, 94, 58, 0.28),
    inset 0 1px 0 rgba(255, 255, 255, 0.40);
}
#ld-qd-fab .ld-qd-fab-spark{
  display: inline-block;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: #fff;
  box-shadow: 0 0 10px rgba(255, 255, 255, 0.9);
  animation: ld-qd-spark 1.8s ease-in-out infinite;
}
#ld-qd-fab .ld-qd-fab-sub{
  display: block;
  font-size: 9.5px;
  font-weight: 500;
  letter-spacing: 0.18em;
  color: rgba(255, 255, 255, 0.86);
  margin-top: 2px;
}
@keyframes ld-qd-pulse{
  0%, 100% { box-shadow: 0 12px 28px rgba(255, 94, 58, 0.30), 0 4px 8px rgba(255, 94, 58, 0.16), inset 0 1px 0 rgba(255, 255, 255, 0.30); }
  50%      { box-shadow: 0 14px 36px rgba(255, 94, 58, 0.50), 0 6px 12px rgba(255, 94, 58, 0.28), inset 0 1px 0 rgba(255, 255, 255, 0.40); }
}
@keyframes ld-qd-spark{
  0%, 100% { opacity: 0.6; transform: scale(0.8); }
  50%      { opacity: 1.0; transform: scale(1.2); }
}

/* ============================================================
 * 業種別 赤トンマナ override
 *   redA = 主色, redB = 中継, redC = 影 (最暗) で 3-stop グラデ
 * ============================================================ */
/* 旅館: 漆器の朱 */
body[data-industry="ryokan"] #ld-qd-fab{
  background: linear-gradient(135deg, #d6383b 0%, #b32023 55%, #8c1416 100%);
  box-shadow: 0 12px 28px rgba(180,32,35,0.40), 0 4px 8px rgba(180,32,35,0.22), inset 0 1px 0 rgba(255,255,255,0.22);
}
body[data-industry="ryokan"] #ld-qd-fab:hover{
  box-shadow: 0 18px 36px rgba(180,32,35,0.52), 0 6px 12px rgba(180,32,35,0.32), inset 0 1px 0 rgba(255,255,255,0.32);
}

/* 酒造: 重厚な紅 + 金 */
body[data-industry="sake"] #ld-qd-fab{
  background: linear-gradient(135deg, #c2362f 0%, #931f1c 55%, #5a0e0e 100%);
  box-shadow: 0 12px 28px rgba(146,30,28,0.40), 0 4px 8px rgba(146,30,28,0.24), inset 0 1px 0 rgba(217,174,92,0.30);
}
body[data-industry="sake"] #ld-qd-fab:hover{
  box-shadow: 0 18px 36px rgba(146,30,28,0.55), 0 6px 12px rgba(146,30,28,0.32), inset 0 1px 0 rgba(217,174,92,0.40);
}

/* 茶舗: 茜赤 + 茶 (落ち着いた赤茶) */
body[data-industry="tea"] #ld-qd-fab{
  background: linear-gradient(135deg, #b94d4a 0%, #8c2f30 55%, #5a1f20 100%);
  box-shadow: 0 12px 28px rgba(140,47,48,0.36), 0 4px 8px rgba(140,47,48,0.22), inset 0 1px 0 rgba(255,255,255,0.18);
}
body[data-industry="tea"] #ld-qd-fab:hover{
  box-shadow: 0 18px 36px rgba(140,47,48,0.50), 0 6px 12px rgba(140,47,48,0.30), inset 0 1px 0 rgba(255,255,255,0.28);
}

/* 和菓子: 桜紅 (やや桃色寄りの赤) */
body[data-industry="wagashi"] #ld-qd-fab{
  background: linear-gradient(135deg, #e36084 0%, #c0395a 55%, #8a1c3a 100%);
  box-shadow: 0 12px 28px rgba(192,57,90,0.40), 0 4px 8px rgba(192,57,90,0.22), inset 0 1px 0 rgba(255,255,255,0.30);
}
body[data-industry="wagashi"] #ld-qd-fab:hover{
  box-shadow: 0 18px 36px rgba(192,57,90,0.52), 0 6px 12px rgba(192,57,90,0.32), inset 0 1px 0 rgba(255,255,255,0.40);
}

/* 陶芸: 釉薬の赤茶 */
body[data-industry="tougei"] #ld-qd-fab{
  background: linear-gradient(135deg, #d05933 0%, #a13a20 55%, #6e2613 100%);
  box-shadow: 0 12px 28px rgba(161,58,32,0.42), 0 4px 8px rgba(161,58,32,0.24), inset 0 1px 0 rgba(255,255,255,0.22);
}
body[data-industry="tougei"] #ld-qd-fab:hover{
  box-shadow: 0 18px 36px rgba(161,58,32,0.55), 0 6px 12px rgba(161,58,32,0.32), inset 0 1px 0 rgba(255,255,255,0.32);
}

/* 納豆: 大豆煮汁の暖赤 */
body[data-industry="nattou"] #ld-qd-fab{
  background: linear-gradient(135deg, #c44a36 0%, #983222 55%, #6c1f10 100%);
  box-shadow: 0 12px 28px rgba(152,50,34,0.40), 0 4px 8px rgba(152,50,34,0.24), inset 0 1px 0 rgba(255,255,255,0.22);
}
body[data-industry="nattou"] #ld-qd-fab:hover{
  box-shadow: 0 18px 36px rgba(152,50,34,0.52), 0 6px 12px rgba(152,50,34,0.30), inset 0 1px 0 rgba(255,255,255,0.32);
}

/* 観光農園: 苺紅 */
body[data-industry="agritourism"] #ld-qd-fab{
  background: linear-gradient(135deg, #ec3e4d 0%, #c8222d 55%, #8e1418 100%);
  box-shadow: 0 12px 28px rgba(200,34,45,0.42), 0 4px 8px rgba(200,34,45,0.24), inset 0 1px 0 rgba(255,255,255,0.30);
}
body[data-industry="agritourism"] #ld-qd-fab:hover{
  box-shadow: 0 18px 36px rgba(200,34,45,0.55), 0 6px 12px rgba(200,34,45,0.32), inset 0 1px 0 rgba(255,255,255,0.40);
}

/* mobile: smaller FAB */
@media (max-width: 760px){
  #ld-qd-fab{
    top: 76px;
    right: 12px;
    padding: 10px 14px 10px 18px;
    font-size: 12.5px;
  }
  #ld-qd-fab .ld-qd-fab-sub{ font-size: 8.5px; }
}

/* agritourism は header が上部に padding で高めに配置されるためさらに下げる */
body[data-industry="agritourism"] #ld-qd-fab{ top: 130px; }
@media (max-width: 760px){
  body[data-industry="agritourism"] #ld-qd-fab{ top: 86px; }
}

/* ============================================================
 * Step 2: モーダル
 * ============================================================ */
#ld-qd-modal{
  position: fixed;
  inset: 0;
  z-index: 10000;
  display: none;
  align-items: center;
  justify-content: center;
  padding: 24px;
  background: rgba(20, 18, 14, 0.72);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
}
#ld-qd-modal.--open{ display: flex; }

#ld-qd-modal .ld-qd-panel{
  width: min(560px, 100%);
  max-height: 92vh;
  overflow-y: auto;
  background: #fffaf2;
  border-radius: 26px;
  padding: 32px 30px 28px;
  box-shadow: 0 36px 80px rgba(0, 0, 0, 0.32);
  position: relative;
  font-family: 'Noto Sans JP', sans-serif;
  color: #2a1f12;
  line-height: 1.65;
}

#ld-qd-modal .ld-qd-close{
  position: absolute;
  top: 14px;
  right: 16px;
  background: transparent;
  border: 0;
  font-size: 24px;
  color: #999;
  cursor: pointer;
  padding: 4px 10px;
  border-radius: 8px;
}
#ld-qd-modal .ld-qd-close:hover{ background: rgba(0,0,0,.05); color: #333; }

#ld-qd-modal .ld-qd-title{
  font-family: 'Cormorant Garamond', 'Shippori Mincho', serif;
  font-size: 24px;
  font-weight: 500;
  letter-spacing: 0.06em;
  color: #ff5e3a;
  margin: 0 0 4px;
}
#ld-qd-modal .ld-qd-sub{
  font-size: 12.5px;
  color: #888;
  letter-spacing: 0.04em;
  margin: 0 0 18px;
}

#ld-qd-modal .ld-qd-step-indicator{
  display: flex;
  gap: 6px;
  margin-bottom: 22px;
}
#ld-qd-modal .ld-qd-step-dot{
  flex: 1;
  height: 4px;
  border-radius: 999px;
  background: #f0e1d0;
}
#ld-qd-modal .ld-qd-step-dot.--active{
  background: linear-gradient(90deg, #ff7a8e, #ff5e3a);
}

#ld-qd-modal .ld-qd-question{
  font-size: 16.5px;
  font-weight: 700;
  margin: 0 0 18px;
  color: #2a1f12;
  line-height: 1.55;
}

#ld-qd-modal .ld-qd-options{
  display: flex;
  flex-direction: column;
  gap: 10px;
}
#ld-qd-modal .ld-qd-option{
  text-align: left;
  padding: 14px 18px;
  border: 1.5px solid #f0d8c0;
  border-radius: 14px;
  background: #fff;
  cursor: pointer;
  font-size: 14.5px;
  color: #2a1f12;
  transition: all 0.2s ease;
  font-family: inherit;
  line-height: 1.5;
}
#ld-qd-modal .ld-qd-option:hover{
  border-color: #ff7a8e;
  background: #fff5f2;
  transform: translateX(2px);
}

/* result */
#ld-qd-modal .ld-qd-result-card{
  background: linear-gradient(135deg, #fff3e8 0%, #ffe2da 60%, #fce0ff 100%);
  border-radius: 20px;
  padding: 22px 22px 20px;
  margin-bottom: 16px;
  border: 1.5px solid #ffd0b8;
}
#ld-qd-modal .ld-qd-result-eyebrow{
  font-size: 11px;
  letter-spacing: 0.18em;
  color: #ff5e3a;
  margin: 0 0 6px;
  font-weight: 700;
}
#ld-qd-modal .ld-qd-result-name{
  font-size: 20px;
  font-weight: 700;
  margin: 0 0 8px;
  color: #2a1f12;
}
#ld-qd-modal .ld-qd-result-desc{
  font-size: 13.5px;
  color: #4a3a2c;
  margin: 0;
}

#ld-qd-modal .ld-qd-cta{
  display: block;
  width: 100%;
  padding: 14px;
  border: 0;
  border-radius: 14px;
  background: linear-gradient(135deg, #ff7a8e 0%, #ff5e3a 60%, #ffa05a 100%);
  color: #fff;
  font-family: inherit;
  font-weight: 700;
  font-size: 15px;
  letter-spacing: 0.04em;
  cursor: pointer;
  text-align: center;
  text-decoration: none;
  box-shadow: 0 8px 22px rgba(255, 94, 58, 0.30);
  transition: transform 0.2s ease, box-shadow 0.2s ease;
}
#ld-qd-modal .ld-qd-cta:hover{
  transform: translateY(-1px);
  box-shadow: 0 12px 28px rgba(255, 94, 58, 0.40);
}

#ld-qd-modal .ld-qd-restart{
  display: block;
  width: 100%;
  margin-top: 10px;
  padding: 10px;
  border: 0;
  background: transparent;
  color: #888;
  font-size: 12.5px;
  cursor: pointer;
  font-family: inherit;
}
#ld-qd-modal .ld-qd-restart:hover{ color: #ff5e3a; text-decoration: underline; }

@media (max-width: 760px){
  #ld-qd-modal .ld-qd-panel{ padding: 24px 20px 20px; border-radius: 20px; }
  #ld-qd-modal .ld-qd-title{ font-size: 20px; }
  #ld-qd-modal .ld-qd-question{ font-size: 15px; }
  #ld-qd-modal .ld-qd-option{ font-size: 13.5px; padding: 12px 14px; }
}
