/* =============================================
   FISHBOWL — Playful, round, bubbly, squishy
   Everything is soft, rounded, pastel
   ============================================= */
*{margin:0;padding:0;box-sizing:border-box}
:root{
  --bg:#0c1a2a;--card:#112236;--border:rgba(255,255,255,.06);
  --aqua:#00d4aa;--aqua2:#00b4d8;--coral:#ff6b6b;--sand:#fbbf24;
  --text:#e0f0ff;--text2:#7aa4c8;--text3:#3d6080;
  --r:20px;--rs:12px;
  --display:'Fredoka',sans-serif;--body:'Nunito',sans-serif;
}
html{scroll-behavior:smooth}
body{font-family:var(--body);background:var(--bg);color:var(--text);min-height:100vh;overflow-x:hidden;-webkit-font-smoothing:antialiased}

/* BG canvas for bubbles */
#bgCanvas{position:fixed;inset:0;z-index:0;pointer-events:none}

.page{position:relative;z-index:10;max-width:460px;margin:0 auto;padding:20px 16px 60px}

/* === HEADER === */
.top{text-align:center;padding:24px 0 16px}
.title{
  font-family:var(--display);font-size:clamp(2.2rem,8vw,3rem);
  font-weight:700;color:var(--aqua);line-height:1.1;
  display:flex;flex-wrap:wrap;justify-content:center;gap:4px 12px;
}
.word{display:inline-flex;align-items:center}
.fish{font-size:.8em;display:inline-block;animation:fishWiggle 2s ease-in-out infinite}
.fish.flip{animation:fishWiggle 2s ease-in-out .5s infinite;transform:scaleX(-1)}
@keyframes fishWiggle{0%,100%{transform:translateY(0) rotate(0)}25%{transform:translateY(-3px) rotate(5deg)}75%{transform:translateY(2px) rotate(-3deg)}}
.flip{animation:fishWiggleFlip 2s ease-in-out .5s infinite}
@keyframes fishWiggleFlip{0%,100%{transform:scaleX(-1) translateY(0)}25%{transform:scaleX(-1) translateY(-3px) rotate(5deg)}75%{transform:scaleX(-1) translateY(2px) rotate(-3deg)}}
.t{
  display:inline-block;opacity:0;
  animation:tPop .5s cubic-bezier(.2,.8,.3,1.2) calc(var(--i)*.08s+.3s) forwards;
}
@keyframes tPop{from{opacity:0;transform:scale(0) translateY(15px)}to{opacity:1;transform:none}}
.subtitle{font-size:1rem;color:var(--text2);margin-top:8px;font-weight:300}

/* === BOWL === */
.bowl-container{display:flex;flex-direction:column;align-items:center;margin:20px 0}
.bowl{
  position:relative;width:280px;height:200px;
  border-radius:0 0 140px 140px;
  border:4px solid rgba(0,180,216,.25);
  border-top:none;
  background:linear-gradient(180deg,rgba(0,180,216,.04),rgba(0,212,170,.06));
  overflow:hidden;
  animation:bowlWobble 6s ease-in-out infinite;
}
@keyframes bowlWobble{0%,100%{transform:rotate(0)}50%{transform:rotate(.3deg)}}
/* Water surface */
.water{position:absolute;top:0;left:0;right:0;height:30px;overflow:hidden}
.wave{
  position:absolute;width:200%;height:100%;top:0;left:-50%;
  background:repeating-linear-gradient(90deg,transparent,rgba(0,212,170,.08) 25%,transparent 50%);
  animation:waveFlow 4s linear infinite;
}
.wave2{animation-duration:6s;animation-direction:reverse;opacity:.5}
@keyframes waveFlow{to{transform:translateX(25%)}}

/* Swimming fish */
.fish-tank{position:absolute;inset:20px 10px 10px}
.swim-fish{
  position:absolute;font-size:20px;
  animation:swimAcross linear infinite;
  opacity:0;
}
@keyframes swimAcross{
  0%{transform:translateX(-30px) translateY(0);opacity:0}
  5%{opacity:.9}
  50%{transform:translateX(200px) translateY(15px) scaleX(-1);opacity:.9}
  95%{opacity:.9}
  100%{transform:translateX(430px) translateY(-5px);opacity:0}
}

/* Net */
.net{
  position:absolute;top:-10px;left:50%;transform:translateX(-50%);
  width:40px;color:var(--sand);z-index:5;
}
.net.net-drop{animation:netDrop 1.5s ease-in-out forwards}
@keyframes netDrop{
  0%{transform:translateX(-50%) translateY(0)}
  40%{transform:translateX(-50%) translateY(120px)}
  60%{transform:translateX(-50%) translateY(120px)}
  100%{transform:translateX(-50%) translateY(0)}
}

/* Bowl stats */
.bowl-stats{
  display:flex;align-items:baseline;gap:8px;margin-top:12px;
  font-family:var(--display);font-size:.9rem;color:var(--text2);
}
.bs-num{font-size:1.6rem;font-weight:700;color:var(--aqua)}
.bs-label{font-size:.85rem}
.bs-sep{opacity:.3}
.bs-status{color:var(--aqua);font-weight:600}
.bs-status.closed{color:var(--coral)}

/* === CARD === */
.card{
  background:var(--card);border:1px solid var(--border);
  border-radius:var(--r);padding:28px 24px;margin-top:8px;
}
.card-title{
  font-family:var(--display);font-size:1.1rem;font-weight:600;
  color:var(--aqua);margin-bottom:20px;
}

/* Fields */
.field{margin-bottom:18px}
.field label{
  display:block;font-size:.8rem;font-weight:600;
  color:var(--text2);margin-bottom:6px;
}
.field input{
  width:100%;padding:12px 14px;
  background:rgba(0,0,0,.2);border:2px solid var(--border);
  border-radius:var(--rs);color:var(--text);
  font-family:var(--body);font-size:.95rem;outline:none;
  transition:border-color .3s,box-shadow .3s;
}
.field input::placeholder{color:var(--text3)}
.field input:focus{border-color:var(--aqua);box-shadow:0 0 16px rgba(0,212,170,.1)}

/* Pick */
.pick{display:flex;gap:16px;margin-top:6px}
.pick-opt{
  display:flex;align-items:center;gap:8px;cursor:pointer;
  font-size:.9rem;color:var(--text2);transition:color .2s;
}
.pick-opt:hover{color:var(--text)}
.pick-opt input{display:none}
.pick-dot{
  width:16px;height:16px;border:2px solid var(--text3);
  border-radius:50%;position:relative;transition:all .3s;
}
.pick-opt input:checked~.pick-dot{
  border-color:var(--aqua);
  box-shadow:0 0 8px rgba(0,212,170,.2);
}
.pick-opt input:checked~.pick-dot::after{
  content:'';position:absolute;top:2px;left:2px;width:8px;height:8px;
  background:var(--aqua);border-radius:50%;
  animation:dotPop .3s cubic-bezier(.34,1.56,.64,1);
}
@keyframes dotPop{from{transform:scale(0)}to{transform:scale(1)}}
.pick-opt input:checked~span:last-child{color:var(--text);font-weight:600}

/* Drop button */
.drop-btn{
  width:100%;padding:14px;margin-top:10px;
  background:linear-gradient(135deg,var(--aqua),var(--aqua2));
  border:none;border-radius:var(--rs);
  color:#0a1628;font-family:var(--display);
  font-size:1.1rem;font-weight:700;cursor:pointer;
  transition:all .3s;position:relative;overflow:hidden;
}
.drop-btn::after{
  content:'';position:absolute;top:50%;left:50%;
  width:0;height:0;background:rgba(255,255,255,.2);
  border-radius:50%;transform:translate(-50%,-50%);
  transition:width .5s,height .5s;
}
.drop-btn:hover::after{width:300px;height:200px}
.drop-btn:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,212,170,.2)}
.drop-btn:active{transform:scale(.97)}
.drop-btn:disabled{opacity:.4;cursor:not-allowed;transform:none!important}
.drop-text{position:relative;z-index:1}

.error{font-size:.85rem;color:var(--coral);padding:8px 0}
.error:not(.hidden){animation:shake .3s ease-out}
@keyframes shake{0%,100%{transform:translateX(0)}25%{transform:translateX(-5px)}75%{transform:translateX(5px)}}

/* === IN BOWL === */
.in-bowl{text-align:center;padding:16px 0}
.splash{font-size:2rem;margin-bottom:8px;animation:splashPop .6s cubic-bezier(.34,1.56,.64,1)}
@keyframes splashPop{from{transform:scale(0) rotate(-20deg);opacity:0}to{transform:scale(1) rotate(0);opacity:1}}
.in-name{
  font-family:var(--display);font-size:1.6rem;font-weight:700;
  color:var(--aqua);margin-bottom:8px;
}
.in-sub{color:var(--text2);font-size:.9rem}

/* === CLOSED === */
.closed{text-align:center;padding:20px 0}
.closed-icon{font-size:2rem;display:block;margin-bottom:8px}
.closed p{color:var(--text2);font-size:.9rem}

/* === WINNER === */
.winner-card{margin-top:20px}
.winner-bowl{
  position:relative;text-align:center;
  padding:36px 24px;
  background:var(--card);border:2px solid var(--sand);
  border-radius:var(--r);overflow:hidden;
  animation:winnerGlow 3s ease-in-out infinite;
}
@keyframes winnerGlow{
  0%,100%{box-shadow:0 0 20px rgba(251,191,36,.1)}
  50%{box-shadow:0 0 40px rgba(251,191,36,.2)}
}
.winner-label{
  font-family:var(--display);font-size:.85rem;font-weight:600;
  color:var(--sand);margin-bottom:12px;
}
.winner-fish{font-size:3rem;margin-bottom:8px;animation:fishWiggle 1.5s ease-in-out infinite}
.winner-name{
  font-family:var(--display);font-size:1.8rem;font-weight:700;
  color:var(--aqua);margin-bottom:8px;min-height:1.4em;
}
.winner-name::after{content:'|';animation:blink .6s step-end infinite;font-weight:300}
@keyframes blink{0%,100%{opacity:1}50%{opacity:0}}
.winner-contact{font-size:.9rem;color:var(--text2)}
.winner-splash{
  position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(circle at 50% 30%,rgba(0,212,170,.08),transparent 60%);
}

/* Footer */
.foot{text-align:center;padding:24px 0 0}
.foot a{
  font-size:1.2rem;color:var(--text3);text-decoration:none;
  opacity:.3;transition:opacity .3s;
}
.foot a:hover{opacity:.8}

/* Confetti */
.confetti-container{position:fixed;inset:0;z-index:9999;pointer-events:none;overflow:hidden}
.confetti-p{position:absolute;top:-20px;animation:cfall linear forwards}
@keyframes cfall{0%{transform:translateY(0) rotate(0);opacity:1}80%{opacity:.8}100%{transform:translateY(100vh) rotate(720deg);opacity:0}}
.hidden{display:none!important}
@media(max-width:480px){.page{padding:12px 10px 40px}.bowl{width:220px;height:160px;border-radius:0 0 110px 110px}}
