/* InfluencerPit – Dog Icon Mascot (appears on active empty field) */

.ip-field{ position:relative; }

.ip-label-row{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
}

.ip-help-dogicon{
  position:relative;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:52px;
  height:52px;
  margin-left:10px;
  vertical-align:middle;
  cursor:pointer;
  user-select:none;
  border-radius:14px;
  transform-origin:50% 80%;
  opacity:0;
  transform: translateY(4px) scale(0.96);
  pointer-events:none;
  transition: opacity .18s ease, transform .18s ease;
}

.ip-field.ip-mascot-active .ip-help-dogicon{
  opacity:1;
  transform: translateY(0) scale(1);
  pointer-events:auto;
}

.ip-dogicon-svg{ width:48px; height:48px; display:block; }

.ip-help-dogicon::after{
  content: attr(data-ip-mascot-tip);
  position:absolute;
  left:60px;
  top:12px;
  white-space:nowrap;
  font-size:13px;
  padding:7px 10px;
  border-radius:12px;
  background:#fff;
  border:1px solid #e9e9e9;
  box-shadow:0 8px 24px rgba(0,0,0,0.12);
  opacity:0;
  transform:translateY(4px);
  pointer-events:none;
  transition: opacity .18s ease, transform .18s ease;
  z-index:2;
}

.ip-field.ip-mascot-active .ip-help-dogicon:hover::after,
.ip-field.ip-mascot-active .ip-help-dogicon:focus::after{
  opacity:1;
  transform:translateY(0);
}

.ip-help-dogicon:focus{
  outline:2px solid #5BBB7B;
  outline-offset:3px;
}

/* Tail wag */
.ip-dogicon-tail{ transform-origin: 0px 0px; animation: ip-icon-wag 1.15s ease-in-out infinite; }

.ip-field.ip-mascot-active .ip-help-dogicon:hover .ip-dogicon-tail,
.ip-field.ip-mascot-active .ip-help-dogicon:focus .ip-dogicon-tail{ animation-duration: 0.75s; }

@keyframes ip-icon-wag{
  0%, 100% { transform: translate(98px,90px) rotate(18deg); }
  50% { transform: translate(98px,90px) rotate(-22deg); }
}

/* Blink */
.ip-dogicon-eyes{ transform-origin: 64px 50px; animation: ip-icon-blink 4.4s infinite; }
@keyframes ip-icon-blink{
  0%, 92%, 100% { transform: scaleY(1); }
  94% { transform: scaleY(0.12); }
  96% { transform: scaleY(1); }
}

/* Help modal */
.ip-modal{ position:fixed; inset:0; z-index:99999; display:none; }
.ip-modal.is-open{ display:block; }
.ip-modal__backdrop{ position:absolute; inset:0; background:rgba(0,0,0,0.55); }
.ip-modal__panel{
  position:relative;
  width:min(520px, 92vw);
  margin:12vh auto;
  background:#fff;
  border-radius:14px;
  padding:18px 18px 16px;
  box-shadow:0 10px 40px rgba(0,0,0,0.25);
}
.ip-modal__close{
  position:absolute; top:10px; right:10px;
  width:36px; height:36px;
  border-radius:10px; border:1px solid #e5e5e5;
  background:#fff; font-size:20px; cursor:pointer;
}
.ip-modal__title{ margin:0 0 6px; font-size:18px; }
.ip-modal__img{ display:block; width:100%; max-height:280px; object-fit:contain; border-radius:12px; margin:10px 0; background: rgba(0,0,0,0.03); }
.ip-modal__text{ margin:0; font-size:14px; }

/* Celebration */
.ip-celebrate{ position:fixed; inset:0; z-index:100000; display:none; }
.ip-celebrate.is-open{ display:block; }
.ip-celebrate::before{ content:""; position:absolute; inset:0; background:rgba(0,0,0,0.55); }

.ip-celebrate__panel{
  position:relative;
  width:min(420px, 92vw);
  margin:18vh auto;
  background:#fff;
  border-radius:18px;
  padding:22px 18px;
  text-align:center;
  box-shadow:0 12px 40px rgba(0,0,0,0.28);
}
.ip-celebrate__dog{ font-size:40px; margin-bottom:6px; }
.ip-celebrate__btn{
  margin-top:12px;
  padding:10px 14px;
  border-radius:12px;
  border:1px solid #5BBB7B;
  background:#5BBB7B;
  color:#fff;
  cursor:pointer;
}

/* Confetti */
.ip-confetti{ pointer-events:none; position:absolute; inset:0; overflow:hidden; }
.ip-confetti span{
  position:absolute; top:-10px;
  width:8px; height:14px;
  background:#5BBB7B;
  opacity:0.9;
  animation: ip-confetti-fall 1.8s linear infinite;
}
.ip-confetti span:nth-child(1){ left:5%; animation-delay:.05s; background:#5BBB7B;}
.ip-confetti span:nth-child(2){ left:15%; animation-delay:.1s; background:#111;}
.ip-confetti span:nth-child(3){ left:25%; animation-delay:.2s; background:#FFD166;}
.ip-confetti span:nth-child(4){ left:35%; animation-delay:.15s; background:#EF476F;}
.ip-confetti span:nth-child(5){ left:45%; animation-delay:.05s; background:#118AB2;}
.ip-confetti span:nth-child(6){ left:55%; animation-delay:.12s; background:#06D6A0;}
.ip-confetti span:nth-child(7){ left:65%; animation-delay:.18s; background:#5BBB7B;}
.ip-confetti span:nth-child(8){ left:75%; animation-delay:.22s; background:#111;}
.ip-confetti span:nth-child(9){ left:85%; animation-delay:.08s; background:#FFD166;}
.ip-confetti span:nth-child(10){ left:95%; animation-delay:.16s; background:#EF476F;}

@keyframes ip-confetti-fall{ to{ transform: translateY(110vh) rotate(360deg); } }

/* Demo wrapper */
.ip-demo-wrap{
  max-width:760px; margin:24px auto; padding:18px;
  border:1px solid #eee; border-radius:14px; background:#fff;
}
.ip-demo-title{ margin:0 0 6px; }
.ip-demo-subtitle{ margin:0 0 14px; opacity:0.85; }
.ip-demo-form .ip-field{ margin:16px 0; }
.ip-demo-form label{ font-weight:600; margin-bottom:6px; }
.ip-demo-form input, .ip-demo-form textarea{
  width:100%; padding:10px 12px;
  border:1px solid #ddd; border-radius:10px;
  font-size:14px; box-sizing:border-box;
}
