/* /src/css/nav/fortune/fortune_detail.css */

.fortune-detail{
  padding: 26px 0 70px;
}

.fortune-detail__inner{
  width: min(1240px, 92vw);
  margin: 0 auto;
}

/* ===== ヒーロー帯 ===== */
.fortune-detail__hero{
  display: grid;
  grid-template-columns: 1fr minmax(320px, 520px) 1fr;
  align-items: start;
  gap: 18px;
  margin-bottom: 18px;
}

.fortune-detail__heroBack{
  display: flex;
  align-items: flex-start;
  justify-content: flex-start;
  padding-top: 8px;
}

.fortune-detail__heroCenter{
  text-align: center;
  padding: 0 8px;
}

.fortune-detail__heroMeta{
  display: inline-flex;
  gap: 8px;
  flex-wrap: wrap;
  justify-content: flex-end;
  align-items: flex-start;
  padding-top: 8px;
}

.fortune-detail__back{
  display: inline-flex;
  align-items: center;
  text-decoration: none;
  font-weight: 900;
  color: rgba(28,28,34,.82);
  padding: 12px 16px;
  border-radius: 999px;
  background: rgba(255,255,255,.58);
  border: 1px solid rgba(28,28,34,.10);
  box-shadow: 0 12px 26px rgba(0,0,0,.08);
  white-space: nowrap;
}

.fortune-detail__back:hover{
  filter: brightness(1.02);
}

.fortune-chip{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 10px 12px;
  border-radius: 999px;
  font-weight: 900;
  font-size: 12px;
  color: rgba(28,28,34,.78);
  background: rgba(255,255,255,.58);
  border: 1px solid rgba(28,28,34,.10);
  white-space: nowrap;
}

.fortune-detail__kicker{
  margin: 0 0 10px;
  font-size: 12px;
  font-weight: 900;
  letter-spacing: .10em;
  color: rgba(28,28,34,.58);
}

.fortune-detail__title{
  margin: 0;
  font-weight: 900;
  letter-spacing: .02em;
  line-height: 1.08;
  font-size: clamp(30px, 3.8vw, 52px);
  color: rgba(0,0,0,.94);
  position: relative;
}

.fortune-detail__title::after{
  content:"";
  display:block;
  width: 96px;
  height: 5px;
  margin: 12px auto 0;
  border-radius: 999px;
  background: rgba(123,87,255,.40);
  box-shadow: 0 10px 24px rgba(123,87,255,.18);
}

.fortune-detail__lead{
  margin: 14px 0 0;
  font-weight: 900;
  line-height: 1.8;
  color: rgba(28,28,34,.68);
  font-size: clamp(14px, 1.5vw, 17px);
}

/* ===== フラッシュ ===== */
.fortune-detail__flash{
  width: min(960px, 100%);
  margin: 0 auto 14px;
  padding: 14px 16px;
  border-radius: 18px;
  font-weight: 900;
  line-height: 1.7;
  border: 1px solid rgba(28,28,34,.10);
  box-shadow: 0 14px 34px rgba(0,0,0,.08);
  background: rgba(255,255,255,.70);
  color: rgba(28,28,34,.82);
}

.fortune-detail__flash.is-success{
  background: rgba(237,255,245,.82);
  border-color: rgba(33,160,90,.22);
  color: rgba(24,110,63,.92);
}

.fortune-detail__flash.is-error{
  background: rgba(255,244,244,.88);
  border-color: rgba(214,86,86,.22);
  color: rgba(163,44,44,.92);
}

.fortune-detail__flash.is-info{
  background: rgba(245,246,255,.88);
  border-color: rgba(123,87,255,.18);
  color: rgba(72,60,130,.92);
}

/* ===== 共通の小見出し ===== */
.fortune-detail__eyebrow{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 7px 12px;
  border-radius: 999px;
  background: rgba(123,87,255,.12);
  border: 1px solid rgba(123,87,255,.18);
  color: rgba(91,65,180,.92);
  font-size: 11px;
  font-weight: 900;
  letter-spacing: .12em;
}

/* ===== 入り口カード ===== */
.fortune-detail__entryCard{
  position: relative;
  margin: 0 auto;
  width: min(960px, 100%);
  background: rgba(255,255,255,.62);
  border: 1px solid rgba(255,255,255,.78);
  border-radius: 28px;
  padding: 24px 20px 22px;
  box-shadow: 0 26px 70px rgba(0,0,0,.16);
  backdrop-filter: blur(16px);
  overflow: hidden;
}

.fortune-detail__entryDecor{
  position: absolute;
  inset: -20% -10% auto auto;
  width: 320px;
  height: 320px;
  border-radius: 999px;
  background:
    radial-gradient(circle,
      rgba(255, 195, 113, .26) 0%,
      rgba(255, 167, 214, .18) 34%,
      rgba(123, 87, 255, .14) 58%,
      rgba(123, 87, 255, 0) 76%);
  filter: blur(12px);
  pointer-events: none;
}

.fortune-detail__entryHead{
  position: relative;
  text-align: center;
  margin-bottom: 18px;
  display: grid;
  justify-items: center;
  gap: 10px;
}

.fortune-detail__entryTitle{
  margin: 0;
  font-weight: 900;
  letter-spacing: .02em;
  color: rgba(28,28,34,.92);
  font-size: clamp(24px, 2.7vw, 34px);
  line-height: 1.25;
}

.fortune-detail__entryLead{
  margin: 0 auto;
  max-width: 38em;
  font-weight: 900;
  line-height: 1.9;
  color: rgba(28,28,34,.68);
  font-size: clamp(14px, 1.4vw, 16px);
}

.fortune-detail__entryTypeBox{
  margin: 0 auto;
  width: fit-content;
  display: grid;
  gap: 6px;
  justify-items: center;
  padding: 18px 24px;
  border-radius: 22px;
  background: rgba(123,87,255,.10);
  border: 1px solid rgba(123,87,255,.18);
  box-shadow: 0 16px 34px rgba(123,87,255,.10);
}

.fortune-detail__entryTypeLabel{
  font-size: 12px;
  font-weight: 900;
  letter-spacing: .04em;
  color: rgba(28,28,34,.58);
}

.fortune-detail__entryTypeValue{
  font-size: clamp(24px, 3vw, 30px);
  font-weight: 900;
  letter-spacing: .12em;
  color: #7b57ff;
}

.fortune-detail__currentTypePill{
  margin: 0 auto 6px;
  width: fit-content;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 10px 14px;
  border-radius: 999px;
  background: rgba(255,255,255,.72);
  border: 1px solid rgba(28,28,34,.08);
  box-shadow: 0 10px 22px rgba(0,0,0,.06);
}

.fortune-detail__currentTypePillLabel{
  font-size: 12px;
  font-weight: 900;
  color: rgba(28,28,34,.58);
}

.fortune-detail__currentTypePillValue{
  font-size: 14px;
  font-weight: 900;
  letter-spacing: .08em;
  color: #7b57ff;
}

.fortune-detail__entryForm{
  margin-top: 18px;
}

.fortune-detail__entryActions{
  margin-top: 18px;
  display: flex;
  justify-content: center;
  gap: 10px;
  flex-wrap: wrap;
}

.fortune-detail__mainBtn{
  min-width: 168px;
}

.fortune-detail__entryNote{
  margin: 14px 0 0;
  text-align: center;
  font-size: 12px;
  font-weight: 900;
  color: rgba(28,28,34,.62);
  line-height: 1.8;
}

.fortune-detail__emptyState{
  display: grid;
  justify-items: center;
  gap: 8px;
  padding: 4px 0 2px;
}

.fortune-detail__emptyLead{
  margin: 0;
  text-align: center;
  font-weight: 900;
  color: rgba(28,28,34,.86);
  font-size: 16px;
}

.fortune-detail__emptySub{
  margin: 0;
  text-align: center;
  max-width: 34em;
  font-weight: 900;
  line-height: 1.9;
  color: rgba(28,28,34,.66);
  font-size: 14px;
}

/* ===== タイプ選択 ===== */
.fortune-detail__pickForm{
  display: grid;
  gap: 14px;
}

.fortune-detail__pickForm--compact{
  margin-top: 10px;
}

.fortune-detail__pickHead{
  text-align: center;
}

.fortune-detail__pickTitle{
  margin: 0;
  font-size: 18px;
  font-weight: 900;
  color: rgba(28,28,34,.90);
}

.fortune-detail__pickLead{
  margin: 8px auto 0;
  max-width: 36em;
  font-size: 14px;
  font-weight: 900;
  line-height: 1.8;
  color: rgba(28,28,34,.66);
}

.fortune-detail__typeGrid{
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
}

.fortune-detail__typeOption{
  display: block;
  cursor: pointer;
}

.fortune-detail__typeInput{
  position: absolute;
  opacity: 0;
  pointer-events: none;
}

.fortune-detail__typeCard{
  display: grid;
  justify-items: center;
  gap: 8px;
  min-height: 104px;
  padding: 18px 14px;
  border-radius: 20px;
  border: 1px solid rgba(28,28,34,.10);
  background:
    linear-gradient(180deg, rgba(255,255,255,.86), rgba(255,255,255,.72));
  box-shadow: 0 12px 24px rgba(0,0,0,.05);
  transition: transform .16s ease, border-color .16s ease, box-shadow .16s ease, background .16s ease;
}

.fortune-detail__typeOption:hover .fortune-detail__typeCard{
  transform: translateY(-2px);
  border-color: rgba(123,87,255,.30);
  box-shadow: 0 18px 34px rgba(0,0,0,.09);
}

.fortune-detail__typeInput:focus-visible + .fortune-detail__typeCard{
  outline: 3px solid rgba(123,87,255,.28);
  outline-offset: 4px;
}

.fortune-detail__typeInput:checked + .fortune-detail__typeCard{
  border-color: rgba(123,87,255,.50);
  background:
    linear-gradient(180deg, rgba(246,241,255,.98), rgba(238,230,255,.90));
  box-shadow: 0 18px 34px rgba(123,87,255,.16);
}

.fortune-detail__typeCode{
  font-size: 18px;
  font-weight: 900;
  letter-spacing: .08em;
  color: rgba(28,28,34,.92);
}

.fortune-detail__typeSub{
  text-align: center;
  font-size: 12px;
  font-weight: 900;
  line-height: 1.6;
  color: rgba(28,28,34,.58);
}

/* ===== 結果カード ===== */
.fortune-detail__card{
  position: relative;
  margin: 0 auto;
  width: min(1120px, 100%);
  background: rgba(255,255,255,.66);
  border: 1px solid rgba(255,255,255,.78);
  border-radius: 30px;
  padding: 26px 28px 24px;
  box-shadow: 0 26px 70px rgba(0,0,0,.16);
  backdrop-filter: blur(16px);
}

.fortune-detail__resultHead{
  text-align: center;
  padding: 0 0 18px;
  border-bottom: 1px solid rgba(28,28,34,.08);
  margin-bottom: 24px;
}

.fortune-detail__resultTitle{
  margin: 0;
  font-weight: 900;
  letter-spacing: .02em;
  color: rgba(28,28,34,.92);
  font-size: 20px;
}

.fortune-detail__resultLayout{
  display: grid;
  grid-template-columns: minmax(0, 1.02fr) minmax(320px, .98fr);
  grid-template-areas:
    "intro visual"
    "body visual";
  align-items: start;
  gap: 6px 28px;
}

.fortune-detail__resultIntro{
  grid-area: intro;
  display: grid;
  align-content: start;
  gap: 0;
}

.fortune-detail__resultMetaRow{
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}

.fortune-detail__resultBody{
  grid-area: body;
  display: grid;
  align-content: start;
  gap: 18px;
}

.fortune-detail__resultTypeBox{
  margin: 0;
  width: fit-content;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 10px 14px;
  border-radius: 999px;
  background: rgba(123,87,255,.10);
  border: 1px solid rgba(123,87,255,.18);
  box-shadow: 0 8px 20px rgba(123,87,255,.06);
}

.fortune-detail__resultTypeLabel{
  font-size: 12px;
  font-weight: 900;
  letter-spacing: .02em;
  color: rgba(28,28,34,.60);
  line-height: 1;
}

.fortune-detail__resultTypeValue{
  font-size: 14px;
  font-weight: 900;
  letter-spacing: .08em;
  color: #7b57ff;
  line-height: 1;
}

.fortune-detail__rankBlock{
  display: grid;
  gap: 8px;
  justify-content: center;
  align-items: center;
}

.fortune-detail__rankLabel{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: fit-content;
  padding: 7px 12px;
  border-radius: 999px;
  background: rgba(123,87,255,.10);
  border: 1px solid rgba(123,87,255,.18);
  color: rgba(91,65,180,.92);
  font-size: 11px;
  font-weight: 900;
  letter-spacing: .12em;
}

.fortune-detail__rankLabel--top{
  margin: 0;
}

.fortune-detail__visual{
  grid-area: visual;
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  align-self: stretch;
  min-height: 100%;
  padding: 22px 18px;
  overflow: hidden;
}

.fortune-detail__rankImage{
  width: 100%;
  display: grid;
  justify-items: center;
  margin: 0;
  position: relative;
}

.fortune-detail__rankImageEl{
  width: min(420px, 100%);
  height: auto;
  display: block;
  user-select: none;
  pointer-events: none;
  position: relative;
  z-index: 1;
  animation: fortuneFloatIn .55s ease;
}

.fortune-detail__rank{
  margin: 0;
  text-align: center;
  font-family: "IBM Plex Sans JP", system-ui, -apple-system, "Noto Sans JP", "Segoe UI", Roboto, Arial, sans-serif;
  font-weight: 900;
  letter-spacing: .08em;
  line-height: 1.05;
  font-size: clamp(56px, 6vw, 84px);
  background: linear-gradient(90deg, #ff4b6e 0%, #b24cff 48%, #4a63ff 100%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  text-shadow: 0 10px 24px rgba(123, 87, 255, .08);
}

@keyframes fortuneFloatIn {
  0%{
    opacity: 0;
    transform: translateY(10px) scale(.94);
  }
  100%{
    opacity: 1;
    transform: translateY(0) scale(1);
  }
}

.fortune-detail__badge{
  margin: 0;
  width: fit-content;
  max-width: 100%;
  text-align: center;
  font-weight: 900;
  color: rgba(28,28,34,.82);
  background: rgba(255,255,255,.68);
  border: 1px solid rgba(28,28,34,.10);
  border-radius: 999px;
  padding: 10px 14px;
}

.fortune-detail__msgCard{
  margin-top: 0;
  border-radius: 22px;
  background: rgba(255,255,255,.80);
  border: 1px solid rgba(28,28,34,.08);
  padding: 20px 20px;
  box-shadow: 0 14px 34px rgba(0,0,0,.08);
}

.fortune-detail__msg{
  margin: 0;
  text-align: left;
  font-weight: 900;
  line-height: 1.95;
  color: rgba(28,28,34,.86);
  font-size: clamp(15px, 1.5vw, 19px);
}

.fortune-detail__resultNote{
  margin: 0;
  text-align: left;
  font-weight: 800;
  line-height: 1.8;
  color: rgba(28,28,34,.68);
}

.fortune-detail__resultNote strong{
  color: #7b57ff;
}

/* ===== ボタン ===== */
.fortune-detail__actions{
  margin-top: 2px;
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: 10px;
  flex-wrap: wrap;
}

.fortune-detail__actionForm{
  display: inline-flex;
}

.fortune-detail__actions .btn{
  width: auto;
}

.fortune-detail__actions .btn.btn-ghost{
  min-width: 150px;
  justify-content: center;
}

.fortune-detail__actions .fortune-detail__mainBtn{
  min-width: auto;
}

.fortune-detail__retryBtn{
  min-width: 148px;
}

/* ===== 別タイプ ===== */
.fortune-detail__changeType{
  margin-top: 22px;
  border-radius: 22px;
  background: rgba(255,255,255,.58);
  border: 1px solid rgba(123,87,255,.18);
  box-shadow: 0 16px 34px rgba(123,87,255,.08);
  overflow: hidden;
}

.fortune-detail__changeTypeSummary{
  list-style: none;
  cursor: pointer;
  padding: 16px 18px;
  font-weight: 900;
  color: rgba(82,57,173,.96);
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  background: linear-gradient(135deg, rgba(123,87,255,.16), rgba(214,203,255,.42));
  border-bottom: 1px solid rgba(123,87,255,.16);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.72);
}

.fortune-detail__changeTypeSummary:hover{
  filter: brightness(1.02);
}

.fortune-detail__changeTypeSummary::-webkit-details-marker{
  display: none;
}

.fortune-detail__changeTypeSummary::after{
  content: "＋";
  font-size: 16px;
  line-height: 1;
  color: rgba(123,87,255,.92);
}

.fortune-detail__changeType[open] .fortune-detail__changeTypeSummary::after{
  content: "−";
}

.fortune-detail__changeTypeBody{
  padding: 14px 18px 18px;
}

.fortune-detail__changeTypeHead{
  text-align: center;
  margin-bottom: 10px;
}

.fortune-detail__changeTypeTitle{
  margin: 0;
  font-size: 16px;
  font-weight: 900;
  color: rgba(28,28,34,.88);
}

.fortune-detail__changeTypeLead{
  margin: 8px auto 0;
  max-width: 34em;
  font-size: 13px;
  font-weight: 900;
  line-height: 1.8;
  color: rgba(28,28,34,.64);
}

.fortune-detail__note{
  margin: 12px 0 0;
  text-align: center;
  font-size: 12px;
  font-weight: 900;
  color: rgba(28,28,34,.62);
}

/* ===== 他のみくじ導線 ===== */
.fortune-other{
  margin: 26px auto 0;
  width: min(1120px, 100%);
  padding-top: 16px;
  border-top: 1px solid rgba(28,28,34,.08);
}

.fortune-other__head{
  text-align: center;
  margin-bottom: 10px;
}

.fortune-other__title{
  margin: 0;
  font-size: 14px;
  font-weight: 900;
  color: rgba(28,28,34,.86);
}

.fortune-other__sub{
  margin: 6px 0 0;
  font-size: 12px;
  font-weight: 900;
  color: rgba(28,28,34,.62);
}

.fortune-other__grid{
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}

.fortune-other__card{
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  padding: 12px 12px;
  border-radius: 16px;
  border: 1px solid rgba(28,28,34,.12);
  background: rgba(255,255,255,.55);
  font-weight: 900;
  text-decoration: none;
  color: rgba(28,28,34,.86);
  transition: transform .16s ease, filter .16s ease, box-shadow .16s ease;
}

.fortune-other__card:hover{
  transform: translateY(-1px);
  filter: brightness(1.02);
  box-shadow: 0 12px 22px rgba(0,0,0,.07);
}

.fortune-other__cardText{
  display: inline-block;
}

.fortune-other__cardHint{
  font-size: 12px;
  color: rgba(28,28,34,.60);
  padding: 6px 10px;
  border-radius: 999px;
  background: rgba(255,255,255,.60);
  border: 1px solid rgba(28,28,34,.10);
}

.fortune-other__card.is-current{
  opacity: .60;
  pointer-events: none;
  border-style: dashed;
}

/* ===== PC微調整 ===== */
@media (min-width: 921px){
  .fortune-detail__resultLayout{
    gap: 0 28px;
  }

  .fortune-detail__resultBody{
    margin-top: -28px;
  }
}

/* ===== レスポンシブ ===== */
@media (min-width: 720px){
  .fortune-other__grid{
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

@media (max-width: 920px){
  .fortune-detail__hero{
    grid-template-columns: 1fr;
    justify-items: center;
    gap: 12px;
    margin-bottom: 16px;
  }

  .fortune-detail__heroBack,
  .fortune-detail__heroMeta{
    width: 100%;
    justify-content: center;
    padding-top: 0;
  }

  .fortune-detail__heroCenter{
    order: -1;
  }

  .fortune-detail__title{
    font-size: clamp(34px, 9vw, 56px);
  }

  .fortune-detail__card{
    padding: 22px 20px;
  }

  .fortune-detail__resultLayout{
    grid-template-columns: 1fr;
    grid-template-areas:
      "intro"
      "visual"
      "body";
    gap: 18px;
  }

  .fortune-detail__resultIntro,
  .fortune-detail__resultBody{
    justify-items: center;
    text-align: center;
  }

  .fortune-detail__resultMetaRow{
    justify-content: center;
  }

  .fortune-detail__resultTypeBox{
    margin: 0;
  }

  .fortune-detail__rank,
  .fortune-detail__msg,
  .fortune-detail__resultNote{
    text-align: center;
  }

  .fortune-detail__rankLabel,
  .fortune-detail__badge{
    margin-left: auto;
    margin-right: auto;
  }

  .fortune-detail__actions{
    display: grid;
    gap: 12px;
    justify-items: center;
  }

  .fortune-detail__visual{
    padding: 16px 12px 8px;
  }

  .fortune-detail__typeGrid{
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 640px){
  .fortune-detail{
    padding: 20px 0 56px;
  }

  .fortune-detail__inner{
    width: min(94vw, 1240px);
  }

  .fortune-detail__entryCard,
  .fortune-detail__card,
  .fortune-other,
  .fortune-detail__flash{
    width: 100%;
  }

  .fortune-detail__entryCard,
  .fortune-detail__card{
    border-radius: 22px;
    padding: 18px 14px 18px;
  }

  .fortune-detail__resultHead{
    margin-bottom: 18px;
    padding-bottom: 14px;
  }

  .fortune-detail__resultMetaRow{
    gap: 8px;
    justify-content: center;
  }

  .fortune-detail__resultTypeBox{
    padding: 9px 12px;
    gap: 8px;
  }

  .fortune-detail__resultTypeLabel{
    font-size: 11px;
  }

  .fortune-detail__resultTypeValue{
    font-size: 13px;
  }

  .fortune-detail__visual{
    padding: 12px 8px 6px;
  }

  .fortune-detail__rankImageEl{
    width: min(300px, 90%);
  }

  .fortune-detail__rank{
    font-size: clamp(44px, 12vw, 66px);
  }

  .fortune-detail__msg{
    font-size: 15px;
    line-height: 1.9;
  }

  .fortune-detail__actions .btn,
  .fortune-detail__entryActions .btn{
    width: 100%;
  }

  .fortune-detail__actionForm{
    width: 100%;
  }

  .fortune-detail__mainBtn{
    min-width: 0;
  }

  .fortune-detail__retryBtn{
    min-width: 0;
  }

  .fortune-detail__typeGrid{
    grid-template-columns: 1fr;
  }

  .fortune-detail__typeCard{
    min-height: 92px;
  }
}

@media (prefers-reduced-motion: reduce){
  .fortune-detail__rankImageEl{
    animation: none !important;
  }

  .fortune-other__card,
  .fortune-detail__typeCard{
    transition: none !important;
  }

  .fortune-other__card:hover,
  .fortune-detail__typeOption:hover .fortune-detail__typeCard{
    transform: none !important;
  }
}

/* ===== 結果シェア ===== */
.result-share{
  margin-top: 18px;
  padding: 16px;
  border-radius: 24px;
  background:
    radial-gradient(circle at top left, rgb(var(--share-accent-rgb, 123 87 255) / .16), transparent 42%),
    linear-gradient(180deg, rgba(255,255,255,.86), rgba(255,255,255,.74));
  border: 1px solid rgb(var(--share-accent-rgb, 123 87 255) / .16);
  box-shadow: 0 16px 34px rgba(0,0,0,.06);
}

.result-share__top{
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 18px;
  align-items: center;
}

.result-share__preview{
  display: flex;
  align-items: center;
  gap: 14px;
  min-width: 0;
}

.result-share__thumb{
  width: 88px;
  height: 88px;
  flex: 0 0 auto;
  border-radius: 22px;
  overflow: hidden;
  background: rgba(255,255,255,.90);
  border: 1px solid rgba(28,28,34,.08);
  display: grid;
  place-items: center;
}

.result-share__thumb img{
  width: 100%;
  height: 100%;
  object-fit: contain;
  display: block;
}

.result-share__thumbFallback{
  width: 100%;
  height: 100%;
  display: grid;
  place-items: center;
  font-size: 20px;
  font-weight: 900;
  letter-spacing: .08em;
  color: rgba(28,28,34,.82);
  background: linear-gradient(135deg, rgba(123,87,255,.12), rgba(47,73,255,.10));
}

.result-share__meta{
  min-width: 0;
}

.result-share__eyebrow{
  margin: 0;
  font-size: 11px;
  font-weight: 900;
  letter-spacing: .08em;
  color: rgb(var(--share-accent-rgb, 123 87 255) / .94);
}

.result-share__title{
  margin: 8px 0 0;
  font-size: clamp(20px, 3vw, 28px);
  line-height: 1.2;
  font-weight: 900;
  color: rgba(28,28,34,.96);
}

.result-share__character{
  margin: 6px 0 0;
  font-weight: 900;
  color: rgba(28,28,34,.80);
}

.result-share__quote{
  margin: 10px 0 0;
  padding: 10px 12px;
  border-radius: 14px;
  background: rgba(255,255,255,.74);
  border: 1px solid rgb(var(--share-accent-rgb, 123 87 255) / .14);
  box-shadow: 0 8px 18px rgba(0,0,0,.04);
  line-height: 1.8;
  font-weight: 900;
  font-size: 13px;
  color: rgba(28,28,34,.84);
}

.result-share__actions{
  display: grid;
  gap: 10px;
  justify-items: end;
  align-content: center;
}

.result-share__actionLabel{
  margin: 0;
  font-size: 12px;
  font-weight: 900;
  letter-spacing: .08em;
  color: rgba(28,28,34,.72);
}

.result-share__buttons{
  display: grid;
  grid-template-columns: repeat(4, 72px);
  gap: 12px;
  align-items: center;
  justify-content: end;
}

.share-pill{
  appearance: none;
  border: 0;
  cursor: pointer;
  text-decoration: none;
  width: 72px;
  height: 72px;
  padding: 0;
  border-radius: 20px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: rgba(255,255,255,.92);
  border: 1px solid rgba(28,28,34,.08);
  box-shadow: 0 12px 24px rgba(0,0,0,.07);
  transition: transform .2s ease, box-shadow .2s ease, filter .2s ease;
}

.share-pill:hover{
  transform: translateY(-3px);
  box-shadow: 0 18px 30px rgba(0,0,0,.10);
  filter: brightness(1.02);
}

.share-pill:active{
  transform: translateY(-1px);
}

.share-pill__icon{
  width: 32px;
  height: 32px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: rgba(28,28,34,.92);
  line-height: 0;
  flex: 0 0 auto;
}

.share-pill__icon svg{
  width: 100%;
  height: 100%;
  display: block;
  fill: currentColor;
}

.share-pill--x .share-pill__icon{
  color: #111;
}

.share-pill--facebook .share-pill__icon{
  color: #1877f2;
}

.share-pill--line .share-pill__icon{
  color: #06c755;
}

.share-pill--copy .share-pill__icon{
  color: #000;
}

.result-share__status{
  min-height: 22px;
  margin: 10px 4px 0;
  font-size: 12px;
  font-weight: 900;
  color: rgb(var(--share-accent-rgb, 123 87 255) / .96);
  opacity: 0;
  transform: translateY(4px);
  transition: opacity .18s ease, transform .18s ease;
}

.result-share__status.is-visible{
  opacity: 1;
  transform: translateY(0);
}

@media (max-width: 1100px){
  .result-share__actions{
    justify-items: start;
  }

  .result-share__buttons{
    justify-content: start;
  }
}

@media (max-width: 900px){
  .result-share__top{
    grid-template-columns: 1fr;
  }
}

@media (max-width: 640px){
  .result-share{
    padding: 16px 12px;
    border-radius: 18px;
  }

  .result-share__top{
    gap: 14px;
  }

  .result-share__preview{
    flex-direction: column;
    align-items: flex-start;
    gap: 12px;
  }

  .result-share__actions{
    width: 100%;
    justify-items: start;
  }

  .result-share__actionLabel{
    font-size: 11px;
  }

  .result-share__thumb{
    width: 72px;
    height: 72px;
    border-radius: 18px;
  }

  .result-share__buttons{
    width: 100%;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 10px;
  }

  .share-pill{
    width: 100%;
    height: 64px;
    border-radius: 18px;
  }

  .share-pill__icon{
    width: 28px;
    height: 28px;
  }
}
