/* ツールチップ関連スタイル - tooltips.css */

/* ツールチップ */
.info-icon {
  display: inline-block;
  width: 16px;
  height: 16px;
  background-color: #FF9800;
  color: white;
  font-size: 11px;
  font-weight: bold;
  text-align: center;
  line-height: 16px;
  border-radius: 50%;
  margin-left: 5px;
  cursor: help;
}

.tooltip {
  position: relative;
  display: inline-block;
}

/* ツールチップ - 下方向に表示するように修正 */
.tooltip .tooltip-text {
  visibility: hidden;
  width: 220px;
  background-color: #555;
  color: #fff;
  text-align: center;
  border-radius: 6px;
  padding: 5px;
  position: absolute;
  z-index: 1;
  top: 125%;
  left: 50%;
  margin-left: -110px;
  opacity: 0;
  transition: opacity 0.3s;
  font-weight: normal;
  font-size: 11px;
}

.tooltip .tooltip-text::after {
  content: "";
  position: absolute;
  bottom: 100%;
  left: 50%;
  margin-left: -5px;
  border-width: 5px;
  border-style: solid;
  border-color: transparent transparent #555 transparent;
}

.tooltip:hover .tooltip-text {
  visibility: visible;
  opacity: 1;
}

/* カスタムツールチップ（上向き表示） */
.tooltip-up .tooltip-text {
  top: auto;
  bottom: 125%;
  margin-bottom: 5px;
}

.tooltip-up .tooltip-text::after {
  top: 100%;
  bottom: auto;
  border-color: #555 transparent transparent transparent;
}

/* カスタムツールチップ（右向き表示） */
.tooltip-right .tooltip-text {
  top: 50%;
  left: 125%;
  margin-left: 5px;
  margin-top: -15px;
  width: 180px;
}

.tooltip-right .tooltip-text::after {
  top: 50%;
  right: 100%;
  left: auto;
  margin-top: -5px;
  margin-left: 0;
  border-color: transparent #555 transparent transparent;
}

/* カスタムツールチップ（左向き表示） */
.tooltip-left .tooltip-text {
  top: 50%;
  right: 125%;
  margin-right: 5px;
  margin-top: -15px;
  margin-left: 0;
  width: 180px;
}

.tooltip-left .tooltip-text::after {
  top: 50%;
  left: 100%;
  right: auto;
  margin-top: -5px;
  margin-right: 0;
  border-color: transparent transparent transparent #555;
}

/* 大きなツールチップ */
.tooltip-large .tooltip-text {
  width: 300px;
  margin-left: -150px;
  font-size: 12px;
  padding: 10px;
  line-height: 1.4;
}

/* 小さなツールチップ */
.tooltip-small .tooltip-text {
  width: 150px;
  margin-left: -75px;
  font-size: 10px;
  padding: 3px;
}

/* 警告ツールチップ */
.tooltip-warning .tooltip-text {
  background-color: #ff9800;
}

.tooltip-warning .tooltip-text::after {
  border-color: transparent transparent #ff9800 transparent;
}

.tooltip-warning.tooltip-up .tooltip-text::after {
  border-color: #ff9800 transparent transparent transparent;
}

.tooltip-warning.tooltip-right .tooltip-text::after {
  border-color: transparent #ff9800 transparent transparent;
}

.tooltip-warning.tooltip-left .tooltip-text::after {
  border-color: transparent transparent transparent #ff9800;
}

/* エラーツールチップ */
.tooltip-error .tooltip-text {
  background-color: #f44336;
}

.tooltip-error .tooltip-text::after {
  border-color: transparent transparent #f44336 transparent;
}

.tooltip-error.tooltip-up .tooltip-text::after {
  border-color: #f44336 transparent transparent transparent;
}

.tooltip-error.tooltip-right .tooltip-text::after {
  border-color: transparent #f44336 transparent transparent;
}

.tooltip-error.tooltip-left .tooltip-text::after {
  border-color: transparent transparent transparent #f44336;
}

/* 成功ツールチップ */
.tooltip-success .tooltip-text {
  background-color: #4caf50;
}

.tooltip-success .tooltip-text::after {
  border-color: transparent transparent #4caf50 transparent;
}

.tooltip-success.tooltip-up .tooltip-text::after {
  border-color: #4caf50 transparent transparent transparent;
}

.tooltip-success.tooltip-right .tooltip-text::after {
  border-color: transparent #4caf50 transparent transparent;
}

.tooltip-success.tooltip-left .tooltip-text::after {
  border-color: transparent transparent transparent #4caf50;
}

/* スマホビュー調整 */
@media screen and (max-width: 500px) {
  .tooltip .tooltip-text {
    width: 180px;
    margin-left: -90px;
    font-size: 10px;
  }
  
  .tooltip-large .tooltip-text {
    width: 200px;
    margin-left: -100px;
    font-size: 11px;
  }
  
  .tooltip-right .tooltip-text,
  .tooltip-left .tooltip-text {
    width: 150px;
  }
  
  /* スマホではツールチップをタップで表示 */
  .tooltip {
    cursor: pointer;
  }
  
  /* タッチデバイス用のツールチップ表示制御 */
  .tooltip.active .tooltip-text {
    visibility: visible;
    opacity: 1;
  }
}