*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
body{background:var(--egg-surface,#141420);color:var(--egg-text,#e8eaed)}

main{
  max-width:720px;
  margin:0 auto;
  padding:60px 16px 80px;
}

.hero{text-align:center;padding:32px 0 24px}
.hero-title{
  font-size:2rem;
  font-weight:800;
  background:linear-gradient(135deg,#ec4899,#f472b6,#fb7185);
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
  background-clip:text;
}
.hero-sub{
  margin-top:8px;
  font-size:.95rem;
  opacity:.7;
}

.picker{
  display:grid;
  grid-template-columns:1fr auto 1fr;
  align-items:center;
  gap:12px;
  padding:24px 4px 8px;
}
.slot{display:flex;flex-direction:column;align-items:center;gap:8px}
.slot-label{font-size:.78rem;opacity:.6;font-weight:600}
.slot-btn{
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:6px;
  width:100%;
  padding:24px 8px;
  border:2px solid rgba(236,72,153,.3);
  border-radius:18px;
  background:rgba(236,72,153,.06);
  cursor:pointer;
  font-family:inherit;
  color:inherit;
  transition:all .2s ease;
}
.slot-btn:hover,.slot-btn:focus-visible{
  background:rgba(236,72,153,.16);
  border-color:rgba(236,72,153,.6);
  transform:translateY(-2px);
  box-shadow:0 4px 16px rgba(236,72,153,.2);
}
.slot-btn:focus-visible{outline:2px solid #ec4899;outline-offset:2px}
.slot-btn.filled{border-style:solid}
.slot-emoji{font-size:2.6rem;line-height:1}
.slot-name{font-size:.92rem;font-weight:600;min-height:1.2em}
.heart{
  font-size:1.8rem;
  color:#ec4899;
  animation:pulse 1.4s ease-in-out infinite;
}
@keyframes pulse{0%,100%{transform:scale(1);opacity:.7}50%{transform:scale(1.15);opacity:1}}

.picker-modal{
  position:fixed;inset:0;z-index:9000;
  align-items:flex-end;justify-content:center;
}
.picker-modal:not([hidden]){display:flex}
.modal-backdrop{
  position:absolute;inset:0;
  background:rgba(0,0,0,.6);
  backdrop-filter:blur(4px);
}
.modal-panel{
  position:relative;
  width:100%;max-width:560px;
  max-height:85vh;
  background:#1a1a2e;
  border-radius:20px 20px 0 0;
  padding:20px 16px 32px;
  overflow-y:auto;
  animation:slideUp .3s cubic-bezier(.2,.9,.3,1.2);
}
@media(min-width:560px){
  .picker-modal{align-items:center}
  .modal-panel{border-radius:20px;max-height:80vh}
}
@keyframes slideUp{from{transform:translateY(40px);opacity:0}to{transform:translateY(0);opacity:1}}
.modal-header{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:4px 8px 16px;
}
.modal-title{font-size:1.05rem;font-weight:700}
.modal-close{
  background:none;border:none;color:inherit;
  font-size:1.8rem;cursor:pointer;
  width:36px;height:36px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-family:inherit;line-height:1;
}
.modal-close:hover{background:rgba(255,255,255,.08)}
.modal-close:focus-visible{outline:2px solid #ec4899;outline-offset:2px}

.sign-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:10px;
}
@media(min-width:520px){
  .sign-grid{grid-template-columns:repeat(4,1fr)}
}
.sign-card{
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:4px;
  padding:14px 6px;
  border:1px solid rgba(236,72,153,.25);
  border-radius:12px;
  background:rgba(236,72,153,.06);
  cursor:pointer;
  font-family:inherit;
  color:inherit;
  transition:all .2s ease;
}
.sign-card:hover,.sign-card:focus-visible{
  background:rgba(236,72,153,.18);
  border-color:rgba(236,72,153,.5);
  transform:translateY(-2px);
}
.sign-card:focus-visible{outline:2px solid #ec4899;outline-offset:2px}
.sign-card.disabled{opacity:.3;cursor:not-allowed}
.sign-card.disabled:hover{transform:none;background:rgba(236,72,153,.06)}
.sign-card .sign-emoji{font-size:1.8rem}
.sign-card .sign-name{font-size:.78rem;font-weight:600}
.sign-card .sign-date{font-size:.66rem;opacity:.5}

.result-panel{
  margin-top:24px;
  padding:24px 16px;
  border-radius:20px;
  background:linear-gradient(180deg,rgba(236,72,153,.08),rgba(236,72,153,.02));
  border:1px solid rgba(236,72,153,.18);
  animation:fadeIn .4s ease;
  text-align:center;
}
@keyframes fadeIn{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}

.score-ring{
  position:relative;
  width:160px;height:160px;
  margin:0 auto 8px;
}
.score-ring svg{width:100%;height:100%;transform:rotate(-90deg)}
.ring-bg{fill:none;stroke:rgba(236,72,153,.15);stroke-width:8}
.ring-fg{
  fill:none;
  stroke:url(#ring-gradient);
  stroke:#ec4899;
  stroke-width:8;
  stroke-linecap:round;
  stroke-dasharray:326.7;
  stroke-dashoffset:326.7;
  transition:stroke-dashoffset 1s cubic-bezier(.2,.8,.2,1);
}
.score-text{
  position:absolute;
  inset:0;
  display:flex;
  align-items:center;
  justify-content:center;
  gap:2px;
  font-weight:800;
}
.score-num{font-size:3rem}
.score-suffix{font-size:1.2rem;opacity:.7;margin-top:8px}

.stars{
  display:flex;
  justify-content:center;
  gap:4px;
  font-size:1.4rem;
  margin:8px 0;
  letter-spacing:2px;
}
.star-on{color:#fbbf24}
.star-off{color:rgba(255,255,255,.18)}

.tier-title{
  font-size:1.4rem;
  font-weight:700;
  margin:8px 0 4px;
}
.result-summary{
  font-size:.95rem;
  line-height:1.6;
  opacity:.85;
  padding:0 8px;
  margin-bottom:20px;
  word-break:keep-all;
}

.detail-grid{
  display:grid;
  grid-template-columns:1fr;
  gap:12px;
  margin-top:8px;
  text-align:left;
}
@media(min-width:520px){
  .detail-grid{grid-template-columns:1fr 1fr}
}
.detail-card{
  padding:14px 16px;
  border-radius:14px;
  background:rgba(255,255,255,.03);
  border:1px solid rgba(255,255,255,.06);
}
.detail-icon{font-size:1.2rem;margin-bottom:4px}
.detail-title{font-size:.85rem;font-weight:700;margin-bottom:6px;opacity:.85}
.detail-strength,.detail-challenge{
  font-size:.85rem;line-height:1.55;opacity:.8;
  word-break:keep-all;
}

.action-row{
  display:flex;
  gap:10px;
  margin-top:20px;
  justify-content:center;
}
.action-btn{
  padding:10px 22px;
  border-radius:24px;
  font-size:.88rem;
  font-weight:600;
  cursor:pointer;
  font-family:inherit;
  transition:all .2s ease;
  border:1px solid transparent;
}
.action-btn.share{
  background:#ec4899;
  color:#fff;
  border-color:#ec4899;
}
.action-btn.share:hover{background:#db2777;border-color:#db2777}
.action-btn.reset{
  background:transparent;
  color:inherit;
  border-color:rgba(255,255,255,.2);
}
.action-btn.reset:hover{background:rgba(255,255,255,.06)}
.action-btn:focus-visible{outline:2px solid #ec4899;outline-offset:2px}

.sr-only{
  position:absolute;width:1px;height:1px;
  padding:0;margin:-1px;overflow:hidden;
  clip:rect(0,0,0,0);border:0;
}
