:root{
  --pink: #f66399;
  --black: #000;
  --right: #f2f2f2;
  --white: #fff;
}

.funlab, .funlab *{ box-sizing: border-box; }
.funlab{
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial;
  color: var(--black);
}

.funlab__header{ margin-bottom: 12px; }
.funlab__title{ font-weight: 1000; letter-spacing: .8px; font-size: 20px; }
.funlab__subtitle{ font-size: 13px; opacity: .85; }

.funlab__grid{
  display:grid;
  grid-template-columns: 420px 1fr;
  gap: 16px;
}
@media (max-width: 980px){
  .funlab__grid{ grid-template-columns: 1fr; }
}

/* LEFT MODULE */
.funlab__panel{
  background: var(--pink);
  border: 2px solid var(--black);
  border-radius: 14px;
  padding: 14px;
  overflow:hidden;
}

.funlab__labelRow{
  display:flex;
  align-items:center;
  justify-content: space-between;
  gap: 10px;
}
.funlab__label{ font-weight: 900; font-size: 12px; }

.funlab__tiny{
  border: 2px solid var(--black);
  background: var(--white);
  color: var(--black);
  border-radius: 10px;
  padding: 8px 10px;
  font-weight: 900;
  cursor: pointer;
  white-space: nowrap;
}
.funlab__tiny:hover{ filter: brightness(0.98); }
.funlab__tiny--wide{ width: 100%; text-align: center; }
.funlab__tiny--danger{ background: #fff; }

/* STATUS STRIP */
.funlab__status{
  margin-top: 10px;
  border: 2px solid var(--black);
  border-radius: 12px;
  background: rgba(255,255,255,.86);
  padding: 10px 12px;
  display:flex;
  align-items:center;
  justify-content: space-between;
  gap: 10px;
}
.funlab__statusTag{
  font-weight: 1000;
  font-size: 11px;
  letter-spacing: .8px;
  opacity: .8;
}
.funlab__statusMsg{
  font-weight: 1000;
  font-size: 12px;
}

/* BIG BUTTON */
.funlab__button{
  width: 100%;
  border: 2px solid var(--black);
  border-radius: 16px;
  padding: 16px 14px;
  margin-top: 12px;
  cursor: pointer;
  background: linear-gradient(180deg, #ffffff, #f7f7f7);
  box-shadow: 0 10px 0 rgba(0,0,0,.25);
  transform: translateY(0);
  transition: transform .08s ease, box-shadow .08s ease, filter .15s ease;
  position: relative;
  overflow:hidden;
}
.funlab__button:active{
  transform: translateY(6px);
  box-shadow: 0 4px 0 rgba(0,0,0,.25);
}
.funlab__button::before{
  content:"";
  position:absolute;
  inset:-30% -30%;
  background: radial-gradient(circle at 30% 30%, rgba(0,0,0,.08), transparent 55%),
              radial-gradient(circle at 70% 70%, rgba(0,0,0,.06), transparent 55%);
  opacity: .6;
}
.funlab__buttonTop{
  display:block;
  font-weight: 1000;
  font-size: 18px;
  letter-spacing: 1px;
  position: relative;
  z-index: 1;
}
.funlab__buttonBottom{
  display:block;
  font-weight: 1000;
  font-size: 28px;
  letter-spacing: 1.2px;
  position: relative;
  z-index: 1;
}

/* Controls card */
.funlab__controlsCard{
  margin-top: 12px;
  border: 2px solid var(--black);
  border-radius: 14px;
  background: rgba(255,255,255,.88);
  padding: 12px;
}
.funlab__controlsGrid{
  display:grid;
  grid-template-columns: 1fr;
  gap: 12px;
}
.funlab__control--full{ width: 100%; }
.funlab__controlLabel{
  font-size: 12px;
  font-weight: 1000;
  margin-bottom: 6px;
  display:flex;
  align-items:baseline;
  gap: 8px;
}
.funlab__controlHint{
  font-weight: 900;
  font-size: 11px;
  opacity: .75;
}

/* Segmented rows */
.funlab__segRow{
  margin-top: 8px;
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 6px;
}
.funlab__segBtn{
  border: 2px solid var(--black);
  background: #fff;
  color: #000;
  border-radius: 10px;
  padding: 8px 8px;
  font-weight: 1000;
  cursor: pointer;
  font-size: 12px;
}
.funlab__segBtn:hover{ filter: brightness(0.98); }
.funlab__segBtn.is-active{
  background:#000;
  color:#fff;
}

/* Fortune mode buttons */
.funlab__modes{
  display:grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 6px;
}
.funlab__modeBtn{
  border: 2px solid var(--black);
  background: #fff;
  color: #000;
  border-radius: 10px;
  padding: 8px 8px;
  font-weight: 1000;
  cursor: pointer;
  font-size: 12px;
}
.funlab__modeBtn:hover{ filter: brightness(0.98); }
.funlab__modeBtn.is-active{
  background: #000;
  color: #fff;
}

/* Chaos slider */
.funlab__range{ width: 100%; accent-color: #000; }

/* Stats */
.funlab__stats{
  margin-top: 12px;
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
}
.funlab__stat{
  border: 2px solid var(--black);
  border-radius: 14px;
  background: var(--white);
  padding: 10px 12px;
}
.funlab__statK{ font-size: 12px; font-weight: 900; opacity: .85; }
.funlab__statV{
  font-size: 22px;
  font-weight: 1000;
  letter-spacing: .3px;
  margin-top: 2px;
}

/* RIGHT MODULE */
.funlab__stage{
  background: var(--right);
  border: 2px solid var(--black);
  border-radius: 14px;
  min-height: 520px;
  position: relative;
  overflow:hidden;
}

/* Ritual mode */
.funlab.is-ritual .funlab__stage{ background: #eaeaea; }
.funlab.is-ritual .funlab__bg{ filter: saturate(1.0) contrast(1.0) brightness(0.97); }
.funlab.is-ritual .funlab__fortune--stage{
  background: rgba(255,255,255,.92);
  box-shadow: 0 6px 0 rgba(0,0,0,.12), 0 0 14px rgba(246,99,153,.16);
}

/* Layers */
.funlab__bg{
  position:absolute; inset:0; z-index:0;
  filter: saturate(1.15) contrast(1.05);
}
.funlab__particles{
  position:absolute; inset:0; z-index:1;
  width:100%; height:100%;
  pointer-events:none;
}
.funlab__petArea{
  position:absolute; inset:0; z-index:2;
  display:flex; flex-direction:column;
  align-items:center; justify-content:center;
  gap: 12px; padding: 16px;
}

/* =========================
   FACE-ONLY PET + SOFT CIRCLE
   ========================= */

.funlab__pet{
  width: 260px;
  height: 260px;
  position: relative;
  z-index: 3;
  animation: funlabFloat calc(2.8s + (1 - var(--funlab-chaos, .45)) * 1.4s) ease-in-out infinite;
}
@keyframes funlabFloat{
  0%,100%{ transform: translateY(0); }
  50%{ transform: translateY(-12px); }
}

/* gentle glow "aura" behind everything */
.funlab__petHalo{
  position:absolute;
  inset: 14%;
  border-radius: 999px;
  background:
    radial-gradient(circle at 40% 35%, rgba(255,47,210,.22), transparent 62%),
    radial-gradient(circle at 70% 70%, rgba(0,246,255,.18), transparent 64%),
    radial-gradient(circle at 50% 50%, rgba(255,255,255,.12), transparent 66%);
  filter: blur(calc(12px + var(--funlab-chaos, .45) * 8px));
  opacity: .95;
}

/* soft circle/ring around him (subtle, not a body) */
.funlab__petRing{
  position:absolute;
  inset: 22%;
  border-radius: 999px;
  background:
    radial-gradient(circle at 50% 50%, rgba(255,255,255,0) 58%, rgba(255,255,255,.22) 60%, rgba(255,255,255,0) 68%),
    radial-gradient(circle at 30% 30%, rgba(246,99,153,.20), transparent 60%),
    radial-gradient(circle at 70% 70%, rgba(0,246,255,.16), transparent 62%);
  filter: blur(0.2px);
  opacity: .9;
  mix-blend-mode: normal;
}

/* Face container centered */
.funlab__petFaceOnly{
  position:absolute;
  inset:0;
  display:flex;
  align-items:center;
  justify-content:center;
}

/* Eyes: BIGGER + FARTHER APART */
.funlab__petEyeOnly{
  position:absolute;
  width: 22px;
  height: 30px;
  border-radius: 999px;
  background: rgba(20,20,20,.92);
  top: 108px;
  animation: funlabBlink calc(4.3s + (1 - var(--funlab-chaos, .45)) * 1.5s) infinite;
  box-shadow:
    0 0 10px rgba(255,255,255,.10),
    0 0 18px rgba(246,99,153,.10);
}
.funlab__petEyeOnly--l{ left: 86px; }
.funlab__petEyeOnly--r{ right: 86px; }

@keyframes funlabBlink{
  0%, 92%, 100% { transform: scaleY(1); }
  94% { transform: scaleY(0.12); }
  96% { transform: scaleY(1); }
}
.funlab__petEyeOnly::after{
  content:"";
  position:absolute;
  width: 8px;
  height: 8px;
  border-radius: 999px;
  background: rgba(255,255,255,.94);
  top: 5px;
  left: 6px;
}

/* Bunny nose: just the tiny dot */
.funlab__petBunnyNose{
  position:absolute;
  top: 146px;
  left: 50%;
  transform: translateX(-50%);
  width: 14px;
  height: 10px;
}
.funlab__petNoseDot{
  position:absolute;
  left: 50%;
  top: 1px;
  transform: translateX(-50%);
  width: 7px;
  height: 6px;
  border-radius: 999px;
  background: rgba(20,20,20,.84);
  opacity: .92;
}

/* Little mouth (small curved smile) */
.funlab__petMouthOnly{
  position:absolute;
  top: 160px;
  left: 50%;
  transform: translateX(-50%);
  width: 22px;
  height: 12px;
}
.funlab__petMouthOnly::after{
  content:"";
  position:absolute;
  inset:0;
  border: 2px solid rgba(20,20,20,.72);
  border-top: none;
  border-left: none;
  border-right: none;
  border-radius: 0 0 18px 18px;
}

/* Shadow */
.funlab__petShadow{
  position:absolute;
  z-index: 1;
  bottom: 20px;
  left: 50%;
  transform: translateX(-50%);
  width: 150px;
  height: 24px;
  background: rgba(0,0,0,.14);
  filter: blur(12px);
  border-radius: 999px;
  opacity: .55;
}

/* Reaction states */
.funlab__pet.is-bop{ animation: funlabBop .5s ease; }
@keyframes funlabBop{
  0%{ transform: scale(1) translateY(0); }
  40%{ transform: scale(1.06) translateY(-10px); }
  100%{ transform: scale(1) translateY(0); }
}
.funlab__pet.is-wiggle{ animation: funlabWiggle .55s ease; }
@keyframes funlabWiggle{
  0%{ transform: rotate(0deg); }
  25%{ transform: rotate(-4deg); }
  50%{ transform: rotate(4deg); }
  75%{ transform: rotate(-2deg); }
  100%{ transform: rotate(0deg); }
}
.funlab__pet.is-glowBoost .funlab__petHalo{
  filter: blur(calc(18px + var(--funlab-chaos, .45) * 12px));
  opacity: 1;
}
.funlab__pet.is-glowBoost .funlab__petRing{
  opacity: 1;
}

/* Fortune */
.funlab__fortune--stage{
  margin-top: 6px;
  max-width: 560px;
  text-align: center;
  font-size: 18px;
  font-weight: 1000;
  line-height: 1.35;
  letter-spacing: .2px;
  padding: 12px 16px;
  border-radius: 14px;
  background: rgba(255,255,255,.86);
  border: 2px solid var(--black);
  box-shadow: 0 6px 0 rgba(0,0,0,.15), 0 0 18px rgba(246,99,153,.22);
}
.funlab__fortune--stage.is-pop{ animation: funlabFortunePop .35s ease; }
@keyframes funlabFortunePop{
  0%{ transform: translateY(8px); opacity: 0; }
  100%{ transform: translateY(0); opacity: 1; }
}

.funlab__hint{
  font-size: 12px;
  font-weight: 900;
  opacity: .75;
  user-select:none;
}

/* Toast */
.funlab__toast{
  position:absolute;
  z-index: 4;
  bottom: 14px;
  left: 14px;
  right: 14px;
  border: 2px solid var(--black);
  border-radius: 14px;
  background: rgba(255,255,255,.9);
  padding: 10px 12px;
  font-weight: 900;
  font-size: 12px;
  opacity: 0;
  transform: translateY(10px);
  transition: opacity .2s ease, transform .2s ease;
  pointer-events:none;
}
.funlab__toast.is-on{
  opacity: 1;
  transform: translateY(0);
}
