/* Kitudep Nicknames — front-end widgets. Uses theme tokens with safe fallbacks. */
:root {
  --kitu-accent: var(--accent, #9D00FF);
  --kitu-soft: var(--accent-soft, #f3e3ff);
  --kitu-ink: #2b2333;
  --kitu-muted: #8b8195;
  --kitu-line: #efe6f3;
  --kitu-card: #fcf9fc;
}

/* ---- Generator tool ---- */
.kitu-tool {
  background: #fff;
  border: 1px solid var(--kitu-line);
  border-radius: 24px;
  padding: 22px;
  box-shadow: 0 24px 60px -28px rgba(120, 60, 140, .28);
}
.kitu-tool__title { margin: 0 0 14px; font-size: 22px; font-weight: 800; }
.kitu-tool__bar { display: flex; gap: 10px; flex-wrap: wrap; }
.kitu-tool__input {
  flex: 1; min-width: 200px; font: 600 18px/1.2 inherit; padding: 15px 17px;
  border: 1.5px solid var(--kitu-line); border-radius: 14px; outline: none;
  color: var(--kitu-ink); background: var(--kitu-card);
}
.kitu-tool__input:focus { border-color: var(--kitu-accent); background: #fff; }
.kitu-tool__clear {
  padding: 0 20px; border: 1.5px solid var(--kitu-line); background: #fff;
  border-radius: 14px; font-weight: 600; color: #8b8195; cursor: pointer; font: inherit; font-size: 15px;
}
.kitu-tool__clear:hover { border-color: var(--kitu-accent); color: var(--kitu-accent); }
.kitu-tool__filters { display: flex; gap: 8px; flex-wrap: wrap; margin: 16px 0 4px; }
.kitu-chip {
  padding: 9px 16px; border: 1.5px solid var(--kitu-line); border-radius: 999px;
  font-weight: 600; font-size: 14px; cursor: pointer; font-family: inherit;
  color: #6b6376; background: #fff;
}
.kitu-chip.is-active { color: #fff; background: var(--kitu-accent); border-color: transparent; box-shadow: 0 8px 18px -8px var(--kitu-accent); }
.kitu-chip--api { border-style: dashed; }
.kitu-chip--api.is-active { border-style: solid; }
.kitu-loading { grid-column: 1 / -1; padding: 22px 6px; text-align: center; color: #a99fb3; font-size: 14px; font-weight: 600; }
.kitu-tool__meta { display: flex; align-items: center; justify-content: space-between; margin: 14px 2px 12px; }
.kitu-tool__count { font-size: 13px; font-weight: 600; color: #a99fb3; }
.kitu-tool__hint { font-size: 12px; color: #c9bfd2; }
.kitu-tool__results { padding-right: 2px; }
.kitu-tool__names, .kitu-tool__kaomoji { margin-top: 22px; padding-top: 18px; border-top: 1px solid var(--kitu-line); }
.kitu-tool__kaomoji-count { font-size: 12px; font-weight: 600; color: #a99fb3; }
.kitu-toast { position: fixed; left: 50%; bottom: 26px; transform: translateX(-50%) translateY(20px); background: #2b2333; color: #fff; font-weight: 700; font-size: 14px; padding: 12px 20px; border-radius: 12px; box-shadow: 0 14px 40px -12px rgba(0,0,0,.45); opacity: 0; pointer-events: none; transition: opacity .2s, transform .2s; z-index: 9999; max-width: 90vw; }
.kitu-toast.is-show { opacity: 1; transform: translateX(-50%) translateY(0); }
.kitu-tool__names-head { display: flex; align-items: baseline; justify-content: space-between; gap: 10px; flex-wrap: wrap; margin-bottom: 12px; }
.kitu-tool__names-title { font-size: 15px; font-weight: 800; color: var(--kitu-ink); }
.kitu-tool__names-count { font-size: 12px; font-weight: 600; color: #a99fb3; }
.kitu-tool__phrases-wrap { margin-top: 22px; }
.kitu-tool__phrases-title { font-size: 13px; font-weight: 700; color: #a99fb3; margin-bottom: 10px; text-transform: uppercase; letter-spacing: .04em; }
.kitu-tool__phrases { display: flex; gap: 8px; flex-wrap: wrap; }
.kitu-phrase {
  padding: 8px 14px; border: 1px solid var(--kitu-line); background: #fff; border-radius: 999px;
  font-weight: 600; font-size: 13.5px; color: #6b6376; cursor: pointer; font-family: inherit;
}
.kitu-phrase:hover { border-color: var(--kitu-accent); color: var(--kitu-accent); background: var(--kitu-soft); }

/* ---- Card grid (results / lists / top) ---- */
.kitu-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(min(100%, 232px), 1fr)); gap: 10px; }
.kitu-grid > * { min-width: 0; }
.kitu-grid--ranked { grid-template-columns: repeat(auto-fill, minmax(min(100%, 260px), 1fr)); }
.kitu-card {
  display: flex; align-items: center; gap: 10px; padding: 12px 14px; min-width: 0;
  border: 1px solid #f0eaf4; border-radius: 14px; background: var(--kitu-card);
}
.kitu-card:hover { border-color: var(--kitu-accent); background: #fff; }
.kitu-card__rank {
  font-size: 12px; font-weight: 800; color: #fff; background: var(--kitu-accent);
  width: 26px; height: 26px; border-radius: 8px; display: flex; align-items: center;
  justify-content: center; flex-shrink: 0;
}
.kitu-card__body { flex: 1; min-width: 0; display: flex; flex-direction: column; }
.kitu-card__text { font-size: 17px; color: var(--kitu-ink); word-break: break-word; line-height: 1.4; }
.kitu-card__sub { font-size: 11px; color: #a99fb3; margin-top: 2px; }
.kitu-copy {
  flex-shrink: 0; padding: 6px 13px; border-radius: 10px; font-weight: 700; font-size: 13px;
  cursor: pointer; font-family: inherit; min-width: 54px;
  border: 1.5px solid var(--kitu-accent); background: #fff; color: var(--kitu-accent);
}
.kitu-copy.is-copied { border-color: #16b083; background: #16b083; color: #fff; }

/* ---- Emoji / kaomoji grids ---- */
.kitu-emoji { display: flex; flex-wrap: wrap; gap: 8px; margin: 8px 0; }
.kitu-emoji__item {
  border: 1px solid var(--kitu-line); background: #fff; border-radius: 12px;
  padding: 8px 12px; font-size: 20px; cursor: pointer; line-height: 1; min-width: 44px;
}
.kitu-emoji__item:hover { border-color: var(--kitu-accent); background: var(--kitu-soft); }
.kitu-emoji--kaomoji .kitu-emoji__item { font-size: 15px; }

/* ---- Contribute nickname (in tool) ---- */
.kitu-tool__contribute { margin-top: 16px; padding: 16px; border: 1px dashed var(--kitu-line); border-radius: 14px; background: var(--kitu-card); }
.kitu-contribute__title { font-size: 14px; font-weight: 700; color: #6b6376; margin-bottom: 10px; }
.kitu-tool__contribute .kitu-add { margin: 0; }

/* ---- Contribute form / vote ---- */
.kitu-add { display: flex; gap: 8px; flex-wrap: wrap; align-items: center; margin: 12px 0; }
.kitu-add__input { flex: 1; min-width: 200px; padding: 12px 14px; border: 1.5px solid var(--kitu-line); border-radius: 12px; font: inherit; }
.kitu-add__input:focus { outline: none; border-color: var(--kitu-accent); }
.kitu-add__btn { padding: 12px 20px; border: none; border-radius: 12px; background: var(--kitu-accent); color: #fff; font-weight: 700; cursor: pointer; font-family: inherit; }
.kitu-add__msg { color: #16b083; font-weight: 600; }
.kitu-vote__title { font-size: 19px; font-weight: 800; margin: 0 0 12px; }

/* ---- Bootstrap-class shim (legacy inline content; no Bootstrap loaded) ---- */
.form-group { margin-bottom: 12px; }
.form-control {
  display: block; width: 100%; padding: 11px 14px; font: inherit; font-size: 16px;
  color: var(--kitu-ink); background: #fff; border: 1.5px solid var(--kitu-line);
  border-radius: 12px; box-sizing: border-box;
}
.form-control:focus { outline: none; border-color: var(--kitu-accent); }
.btn {
  display: inline-block; padding: 10px 18px; font: inherit; font-weight: 700; font-size: 15px;
  line-height: 1.2; text-align: center; cursor: pointer; border: 1.5px solid transparent;
  border-radius: 12px; text-decoration: none; background: #efe6f3; color: var(--kitu-ink);
}
.btn:hover { filter: brightness(.97); }
.btn-primary, .btn-pink { background: var(--kitu-accent); color: #fff; }
.btn-secondary { background: #6b6376; color: #fff; }
.btn-outline { background: #fff; border-color: var(--kitu-accent); color: var(--kitu-accent); }
.btn-copy { background: #fff; border-color: var(--kitu-accent); color: var(--kitu-accent); }
.btn-block { display: block; width: 100%; }
.btn.is-copied, .btn-copy.is-copied { background: #16b083; border-color: #16b083; color: #fff; }
.row { display: flex; flex-wrap: wrap; gap: 12px; }

@media (max-width: 600px) {
  .kitu-grid, .kitu-grid--ranked { grid-template-columns: 1fr; gap: 8px; }
  .kitu-tool { padding: 12px; border-radius: 16px; box-shadow: none; }
  .kitu-tool__results { padding-right: 0; }
  .kitu-tool__filters { margin: 12px 0 4px; gap: 6px; }
  .kitu-chip { padding: 8px 13px; font-size: 13.5px; }
  .kitu-card__text { font-size: 16px; }
  .kitu-card { padding: 10px 11px; gap: 8px; }
  .kitu-copy { min-width: 46px; padding: 6px 10px; }
  .kitu-emoji__item { padding: 7px 10px; font-size: 18px; min-width: 40px; }
}
