.fortune-dialog{
  background:rgba(15,23,42,.42);
  backdrop-filter:blur(16px);
}
.fortune-shell{
  max-width:820px;
  border-radius:28px;
  padding:24px;
  display:grid;
  gap:18px;
  background:
    radial-gradient(circle at top right, rgba(199,164,106,.14), transparent 28%),
    linear-gradient(180deg, rgba(255,255,255,.98), rgba(248,250,252,.95));
  border:1px solid rgba(148,163,184,.18);
  box-shadow:0 30px 70px rgba(15,23,42,.22);
}
.fortune-head{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:14px;
  padding-bottom:10px;
  border-bottom:1px solid rgba(148,163,184,.14);
}
.fortune-title{
  font-size:20px;
  font-weight:700;
  letter-spacing:-.03em;
  line-height:1.24;
  color:#0f172a;
}
.fortune-date{
  font-size:12px;
  color:#64748b;
  margin-top:6px;
}
.fortune-close{
  border:1px solid rgba(15,23,42,.12);
  background:rgba(255,255,255,.92);
  color:#0f172a;
  border-radius:999px;
  width:34px;
  height:34px;
  cursor:pointer;
  box-shadow:0 8px 16px rgba(15,23,42,.08);
}
.fortune-admin-test-btn{
  border:1px solid rgba(148,163,184,.16);
  background:rgba(255,255,255,.68);
  color:#94a3b8;
  border-radius:999px;
  padding:4px 8px;
  font-size:10px;
  font-weight:600;
  cursor:pointer;
  margin-left:2px;
  box-shadow:none;
  opacity:.42;
  transition:opacity .18s ease, background .18s ease, color .18s ease, border-color .18s ease;
}
.fortune-head:hover .fortune-admin-test-btn,
.fortune-admin-test-btn:focus-visible{opacity:.92;}
.fortune-admin-test-btn:hover{background:#f8fafc;color:#64748b;border-color:rgba(148,163,184,.24);}
.fortune-body{
  position:relative;
  min-height:180px;
  display:grid;
  gap:14px;
}
.fortune-loading{
  padding:16px;
  border-radius:14px;
  border:1px dashed rgba(148,163,184,.24);
  background:#f8fafc;
  color:#64748b;
  font-size:13px;
  text-align:center;
}
.fortune-error{
  padding:12px;
  border-radius:12px;
  background:#fef2f2;
  border:1px solid rgba(239,68,68,.2);
  color:#991b1b;
  font-size:13px;
}
.fortune-reveal-stage{
  display:none;
  align-items:center;
  justify-content:center;
  min-height:300px;
  padding:20px 0 12px;
  perspective:1200px;
  isolation:isolate;
}
.fortune-reveal-stage::before{
  content:"";
  position:absolute;
  inset:24px 8% 10px;
  border-radius:34px;
  background:
    radial-gradient(circle at 50% 24%, rgba(232,190,113,.18), transparent 34%),
    radial-gradient(circle at 50% 100%, rgba(15,23,42,.12), transparent 48%);
  filter:blur(18px);
  z-index:0;
  pointer-events:none;
}
.fortune-reveal-card{
  width:min(90%, 372px);
  aspect-ratio:1.68 / 1;
  border-radius:24px;
  background:
    linear-gradient(160deg, rgba(255,255,255,.14), rgba(255,255,255,.02)),
    radial-gradient(circle at 18% 10%, rgba(244,214,147,.26), transparent 34%),
    radial-gradient(circle at 82% 18%, rgba(255,255,255,.08), transparent 28%),
    linear-gradient(135deg, #12213f 0%, #1b2c52 42%, #26354a 100%);
  border:1px solid rgba(244,214,147,.24);
  box-shadow:
    0 24px 48px rgba(15,23,42,.22),
    0 10px 26px rgba(15,23,42,.12),
    inset 0 1px 0 rgba(255,255,255,.14);
  display:flex;
  align-items:center;
  justify-content:center;
  position:relative;
  overflow:hidden;
  transform-style:preserve-3d;
  z-index:1;
}
.fortune-reveal-card::before,
.fortune-reveal-card::after{
  content:"";
  position:absolute;
  inset:0;
  border-radius:inherit;
  pointer-events:none;
}
.fortune-reveal-card::before{
  inset:auto 12% -16px 12%;
  height:34px;
  border-radius:999px;
  background:radial-gradient(circle, rgba(15,23,42,.3), transparent 70%);
  filter:blur(12px);
  opacity:.75;
  z-index:-1;
}
.fortune-reveal-card::after{
  inset:12px;
  border:1px solid rgba(255,255,255,.08);
}
.fortune-reveal-copy{
  position:absolute;
  inset:0;
  z-index:2;
  pointer-events:none;
  display:flex;
  flex-direction:column;
  justify-content:space-between;
  padding:18px 18px 16px;
}
.fortune-reveal-brand{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:8px 12px;
  border-radius:999px;
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.14);
  backdrop-filter:blur(10px);
  box-shadow:0 10px 24px rgba(15,23,42,.14);
}
.fortune-reveal-brand-logo{
  width:16px;
  height:16px;
  filter:brightness(0) invert(1);
  opacity:.95;
  flex:0 0 auto;
}
.fortune-reveal-brand-text{
  color:rgba(255,255,255,.9);
  font-size:11px;
  font-weight:700;
  letter-spacing:.22em;
  text-transform:uppercase;
  line-height:1;
}
.fortune-reveal-stage.is-running .fortune-reveal-card{
  animation:fortuneFloat 1800ms ease-in-out infinite, fortuneTiltLoop 2200ms cubic-bezier(.42,0,.2,1) infinite;
}
.fortune-reveal-stage.is-running .fortune-reveal-copy{
  animation:fortuneCopyPulse 1400ms ease-in-out infinite alternate;
}
.fortune-reveal-stage.is-unlocking .fortune-reveal-card{
  animation:fortuneUnlock 520ms cubic-bezier(.17,.84,.44,1) forwards;
}
.fortune-reveal-stage.is-unlocking .fortune-reveal-copy{
  animation:none;
}
.fortune-reveal-glow{
  position:absolute;
  inset:-22% -35%;
  background:linear-gradient(110deg, transparent 24%, rgba(255,255,255,.05) 38%, rgba(255,255,255,.18) 50%, rgba(255,255,255,.05) 62%, transparent 76%);
  transform:translateX(-72%);
  opacity:.8;
  pointer-events:none;
}
.fortune-reveal-stage.is-running .fortune-reveal-glow{
  animation:fortuneGlint 1400ms linear infinite;
}
.fortune-reveal-mark{
  display:flex;
  align-items:center;
  gap:10px;
  color:#fff;
  font-size:15px;
  line-height:1.55;
  font-weight:800;
  letter-spacing:.04em;
  text-shadow:0 10px 22px rgba(15,23,42,.36);
  max-width:220px;
}
.fortune-reveal-mark::before{
  content:"";
  width:36px;
  height:1px;
  border-radius:999px;
  background:linear-gradient(90deg, rgba(244,214,147,.18), rgba(244,214,147,.92));
  flex:none;
}
.fortune-reveal-watermark{
  color:rgba(244,214,147,.68);
  font-size:11px;
  font-weight:700;
  letter-spacing:.32em;
  text-transform:uppercase;
  opacity:.86;
}
.fortune-card{
  padding:24px;
  border-radius:22px;
  background:
    radial-gradient(circle at top right, rgba(199,164,106,.13), transparent 26%),
    linear-gradient(180deg, #fffdfa 0%, #f8fafc 100%);
  border:1px solid rgba(148,163,184,.16);
  box-shadow:0 18px 36px rgba(15,23,42,.08);
}
.fortune-card.is-reveal-in{
  animation:fortuneCardEnter 360ms cubic-bezier(.17,.84,.44,1);
}
.fortune-stars{
  display:inline-flex;
  align-items:center;
  gap:10px;
  font-size:17px;
  letter-spacing:.06em;
  color:#a16207;
  margin-bottom:16px;
  font-weight:800;
  line-height:1;
  text-shadow:0 1px 0 rgba(255,255,255,.65);
}
.fortune-summary{
  max-width:32ch;
  font-size:19px;
  font-weight:650;
  color:#0f172a;
  margin-bottom:20px;
  line-height:1.72;
  letter-spacing:-.02em;
}
.fortune-section{
  margin-top:16px;
  padding-top:16px;
  border-top:1px solid rgba(148,163,184,.16);
}
.fortune-label{
  font-size:10px;
  letter-spacing:.14em;
  color:#8a7b65;
  margin-bottom:12px;
  font-weight:700;
}
.fortune-text{
  font-size:14px;
  line-height:1.92;
  color:#0f172a;
}
.fortune-v3-lines{display:grid;gap:8px;}
.fortune-v3-panel{
  border-radius:18px;
  padding:16px;
  background:rgba(255,255,255,.72);
  border:1px solid rgba(148,163,184,.14);
}
.fortune-v3-line{
  display:block;
  padding:11px 14px;
  border-radius:12px;
  border:1px solid rgba(148,163,184,.14);
  background:#fff;
  color:#334155;
}
.fortune-meta{
  margin-top:18px;
  margin-bottom:0;
  display:flex;
  flex-wrap:wrap;
  gap:6px;
  font-size:10px;
  color:#94a3b8;
}
.fortune-meta span{
  padding:5px 9px;
  border-radius:999px;
  border:1px solid rgba(199,164,106,.18);
  background:rgba(255,253,248,.72);
  color:#9a7a45;
  font-weight:600;
  letter-spacing:.02em;
}
.fortune-explain{
  margin-top:16px;
  padding-top:16px;
  border-top:1px solid rgba(148,163,184,.16);
  display:grid;
  gap:12px;
}
.fortune-explain-toggle{
  border:none;
  background:#fff;
  border:1px solid rgba(148,163,184,.18);
  color:#0f172a;
  font-size:14px;
  font-weight:700;
  line-height:1.4;
  border-radius:999px;
  padding:10px 16px;
  display:inline-flex;
  align-items:center;
  gap:6px;
  width:fit-content;
  max-width:100%;
  text-align:left;
  cursor:pointer;
  box-shadow:0 8px 16px rgba(15,23,42,.06);
}
.fortune-explain-toggle[aria-expanded="true"]{background:#fffdf8;}
.fortune-explain-body{
  display:grid;
  gap:10px;
  padding:14px 16px;
  border-radius:16px;
  border:1px solid rgba(148,163,184,.14);
  background:rgba(255,255,255,.78);
  font-size:13px;
  line-height:1.72;
  color:#0f172a;
}
.fortune-explain-title{
  font-weight:700;
  font-size:17px;
  line-height:1.4;
  margin:0;
}
.fortune-explain-desc,
.fortune-explain-how{
  color:#64748b;
  line-height:1.75;
  margin:0;
}
.fortune-task{
  display:grid;
  gap:10px;
  margin-top:8px;
  padding:14px 16px;
  border:1px solid #b7efcf;
  border-radius:16px;
  background:linear-gradient(180deg,#f4fff8,#eefcf5);
  box-shadow:0 8px 20px rgba(34,197,94,.08);
}
.fortune-task-head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
}
.fortune-task-kicker{
  font-size:11px;
  line-height:1;
  letter-spacing:.16em;
  text-transform:uppercase;
  font-weight:900;
  color:#16a34a;
  margin-bottom:0;
}
.fortune-task-mini{
  font-size:11px;
  line-height:1.55;
  color:#15803d;
  font-weight:600;
  text-align:right;
}
.fortune-task .fortune-label{
  color:#166534;
  font-weight:700;
}
.fortune-task .fortune-text{
  color:#14532d;
  font-size:14px;
  line-height:1.88;
}
.fortune-task-toggle{
  border:1px solid #bbf7d0;
  background:#fff;
  border-radius:999px;
  padding:12px 16px;
  font-size:13px;
  font-weight:800;
  color:#166534;
  cursor:pointer;
  text-align:center;
  box-shadow:0 8px 18px rgba(34,197,94,.08);
  transition:transform .18s ease, box-shadow .18s ease, border-color .18s ease, background .18s ease, color .18s ease;
}
.fortune-task-toggle:hover{
  transform:translateY(-1px);
  box-shadow:0 12px 22px rgba(34,197,94,.12);
}
.fortune-task-toggle[aria-pressed="true"]{
  background:linear-gradient(180deg,#16a34a,#15803d);
  border-color:#15803d;
  color:#f0fdf4;
  box-shadow:0 10px 22px rgba(22,163,74,.2);
}
.fortune-task-streak{
  font-size:12px;
  color:#15803d;
  font-weight:700;
}
.fortune-task-feedback{
  margin-top:2px;
  font-size:11px;
  line-height:1.75;
  color:#166534;
  padding:10px 12px;
  border-radius:12px;
  background:rgba(255,255,255,.72);
  border:1px solid rgba(22,163,74,.16);
}
@keyframes fortuneTiltLoop{
  0%{transform:translateY(0) rotateZ(0deg) rotateX(0deg) scale(1);}
  45%{transform:translateY(-4px) rotateZ(-1.6deg) rotateX(3.5deg) scale(1.012);}
  100%{transform:translateY(0) rotateZ(1.4deg) rotateX(-2.4deg) scale(1);}
}
@keyframes fortuneCopyPulse{
  from{opacity:.92;transform:translateY(0);}
  to{opacity:1;transform:translateY(-2px);}
}
@media (max-width:560px){
  .fortune-title{font-size:18px;}
  .fortune-stars{font-size:16px;gap:8px;}
  .fortune-summary{font-size:18px;max-width:none;line-height:1.7;}
  .fortune-reveal-mark{font-size:14px;}
}
@media (prefers-reduced-motion: reduce){
  .fortune-reveal-stage.is-running .fortune-reveal-card,
  .fortune-reveal-stage.is-running .fortune-reveal-copy,
  .fortune-reveal-stage.is-running .fortune-reveal-glow,
  .fortune-reveal-stage.is-unlocking .fortune-reveal-card,
  .fortune-reveal-stage.is-unlocking .fortune-reveal-copy,
  .fortune-card.is-reveal-in{
    animation:none !important;
  }
}
