/* =========================================================
   Kaitori WebPush Alert - Layout & Style
========================================================= */

.kaitori-alert-box{
  max-width: 900px;
  margin: 24px auto;
  padding: 18px;
  border: 1px solid #e6e6e6;
  border-radius: 14px;
  background: #fff;
}

.kaitori-alert-grid{
  display: grid;
  grid-template-columns: 1.25fr 1fr;
  grid-template-areas:
    "left  right"
    "info  right";
  column-gap: 18px;
  row-gap: 10px;
  align-items: start;
}

.kaitori-alert-left{ grid-area: left; }
.kaitori-alert-right{ grid-area: right; }
.kaitori-alert-info{ grid-area: info; }

.kaitori-alert-label{
  font-size: 17px;
  color: #000;
  margin-bottom: 6px;
  text-align: center;
}

.kaitori-alert-input{
  width: 100%;
  height: 48px;
  border-radius: 12px;
  border: 1px solid #f0b4b4;
  padding: 0 14px;
  box-sizing: border-box;

  text-align: center;
  font-weight: 800;
  color: #c00;
  font-size: 28px;
}

.kaitori-alert-actions{
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 8px;
  align-items: center;
}

.kaitori-main-btn{
  grid-column: 1 / -1;
  width: 100%;
  height: 48px;
  border: none;
  border-radius: 12px;
  background: #c00; /* 統一感 */
  color: #fff;
  font-size: 16px;
  font-weight: 700;
  cursor: pointer;
}
.kaitori-main-btn:disabled{
  opacity: .55;
  cursor: not-allowed;
}

[data-kaitori-quick]{
  grid-column: 1 / -1;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 8px;
}
[data-kaitori-quick] button,
.kaitori-quick-btn{
  width: 100%;
  height: 40px;
  padding: 0 10px;
  border-radius: 12px;
  border: 1px solid #d8d8d8;
  background: #fff;
  cursor: pointer;
  font-size: 14px;
}
[data-kaitori-quick] button:hover,
.kaitori-quick-btn:hover{
  background: #f3f3f3;
}

.kaitori-alert-sub-actions{
  grid-column: 1 / -1;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
}

.kaitori-sub-btn{
  width: 100%;
  height: 40px;
  padding: 0 10px;
  border-radius: 12px;
  border: 1px solid #d8d8d8;
  background: #fff;
  cursor: pointer;
  font-size: 14px;
}
.kaitori-sub-btn:hover{
  background: #f3f3f3;
}

/* 「この端末の登録一覧」は黒 */
.kaitori-sub-btn-black{
  background: #000;
  color: #fff;
  border-color: #000;
}
.kaitori-sub-btn-black:hover{
  opacity: .9;
}

.kaitori-alert-info{
  display: flex;
  align-items: baseline;
  justify-content: center;
  gap: 14px;
  flex-wrap: wrap; /* メッセージは次行 */
}

.kaitori-current{
  display: inline-flex;
  align-items: baseline;
  gap: 6px;
  white-space: nowrap;
}

.kaitori-current .label{
  font-size: 14px;
  color: #333;
}

.kaitori-current .value,
.kaitori-current .yen{
  font-size: 18px;
  font-weight: 800;
  color: #000;
}

.kaitori-delta{
  display: inline-flex;
  align-items: baseline;
  color: #1d4ed8;
  font-weight: 700;
  white-space: nowrap;
}

.kaitori-msg{
  flex-basis: 100%;
  margin-top: 6px;
  font-size: 17px;
  text-align: center;
  white-space: pre-line;
}

@media (max-width: 768px){
  .kaitori-alert-grid{
    grid-template-columns: 1fr;
    grid-template-areas:
      "left"
      "info"
      "right";
  }

  .kaitori-main-btn{
    height: 54px;
    font-size: 18px;
  }

  [data-kaitori-quick]{
    grid-template-columns: 1fr 1fr;
  }
  [data-kaitori-quick] button:last-child{
    grid-column: 1 / -1;
  }

  .kaitori-alert-sub-actions{
    grid-template-columns: 1fr 1fr;
  }
}

@media (min-width: 769px){
  .kaitori-alert-input{
    font-size: 50px;
    height: 56px;
  }
}
