
.haruki-import { max-width: 1080px; margin: 0 auto; padding: 1rem 1rem 3rem; }
.hp-title { font-size: 1.5rem; font-weight: 800; margin: 0 0 .35rem; }
.hp-intro { font-size: .85rem; color: var(--text-soft); margin: 0 0 1rem; max-width: 60ch; }
.hp-gate, .hp-error, .hp-warn, .hp-loading { font-size: .9rem; }
.hp-error { color: #c0392b; }
.hp-warn { color: #b7791f; }
.hp-gate a, .hp-result-head a { color: var(--accent); }
.hp-form {
  display: flex; flex-wrap: wrap; align-items: flex-end; gap: .75rem;
  padding: 1rem; border-radius: 12px; background: var(--surface);
  box-shadow: 0 1px 4px color-mix(in oklab, var(--ink) 12%, transparent);
}
.hp-field { display: flex; flex-direction: column; gap: .25rem; }
.hp-field > span { font-size: .72rem; color: var(--muted); }
.hp-region, .hp-sekai-id {
  font: inherit; padding: .45rem .6rem; border-radius: 8px;
  border: 1px solid color-mix(in oklab, var(--ink) 18%, transparent);
  background: var(--surface-2); color: var(--text);
}
.hp-sekai-id { min-width: 16rem; }
.hp-btn {
  font: inherit; font-weight: 700; cursor: pointer;
  padding: .5rem .9rem; border-radius: 8px;
  border: 1px solid color-mix(in oklab, var(--ink) 18%, transparent);
  background: var(--surface-2); color: var(--text);
}
.hp-btn:hover:not(:disabled) { background: color-mix(in oklab, var(--accent) 12%, var(--surface-2)); }
.hp-btn:disabled { opacity: .5; cursor: default; }
.hp-primary { background: var(--accent); color: #fff; border-color: transparent; }
.hp-primary:hover:not(:disabled) { filter: brightness(1.05); }
.hp-linked-head { font-size: .9rem; flex-basis: 100%; margin: 0 0 .25rem; }
.hp-linked-ok { color: #2e7d32; font-weight: 700; font-size: .75rem; margin-left: .4rem; }
.hp-linked-actions { display: flex; gap: .6rem; flex-basis: 100%; }
.hp-btn.hp-danger { background: transparent; color: #c0392b; border-color: color-mix(in oklab, #c0392b 40%, transparent); }
.hp-btn.hp-danger:hover:not(:disabled) { background: color-mix(in oklab, #c0392b 10%, var(--surface-2)); }
.hp-check {
  flex-basis: 100%;
  display: flex; gap: .5rem; align-items: flex-start;
  font-size: .75rem; color: var(--text-soft); max-width: 56ch; cursor: pointer;
}
.hp-check input { margin-top: .15rem; flex: 0 0 auto; }
.hp-admin { display: inline-flex; align-items: center; gap: .5rem; margin-left: auto; }
.hp-admin-tag {
  font-size: .65rem; font-weight: 800; letter-spacing: .04em; text-transform: uppercase;
  padding: .15rem .4rem; border-radius: 5px; color: #fff;
  background: color-mix(in oklab, var(--accent) 70%, #000);
}
.hp-token-block {
  margin-top: 1rem; padding: 1rem; border-radius: 12px;
  background: color-mix(in oklab, var(--accent) 8%, var(--surface));
  border: 1px solid color-mix(in oklab, var(--accent) 30%, transparent);
}
.hp-token-help { margin: 0 0 .5rem; font-size: .85rem; }
.hp-token-row { display: flex; align-items: center; gap: .5rem; flex-wrap: wrap; }
.hp-token {
  font-family: ui-monospace, Menlo, Consolas, monospace; font-size: 1.4rem; font-weight: 700;
  letter-spacing: .03em; padding: .4rem .7rem; border-radius: 8px;
  background: var(--surface-2); color: var(--accent); user-select: all;
}
.hp-token-note { margin: .5rem 0 .75rem; font-size: .75rem; color: var(--text-soft); }
.hp-status { min-height: 1.2rem; margin: .6rem 0; font-size: .85rem; }
.hp-status-ok { color: #2e7d32; }
.hp-status-error { color: #c0392b; }
.hp-status-info { color: var(--text-soft); }
.haruki-public-section { margin-top: 1.75rem; }
.haruki-public-title { font-size: 1.1rem; font-weight: 800; margin: 0 0 .75rem; }
.hp-visibility {
  margin: .75rem 0; padding: .75rem 1rem; border-radius: 12px;
  background: var(--surface); border: 1px solid color-mix(in oklab, var(--ink) 12%, transparent);
}
.hp-visibility-head { font-size: .82rem; font-weight: 700; margin: 0 0 .5rem; }
.hp-visibility-note { font-size: .72rem; color: var(--text-soft); font-weight: 400; }
.hp-visibility-grid { display: flex; flex-wrap: wrap; gap: .5rem .9rem; }
.hp-visibility-item {
  display: inline-flex; align-items: center; gap: .35rem;
  font-size: .8rem; color: var(--text); cursor: pointer;
}
.hp-visibility-item input { margin: 0; }
.hp-result { margin-top: 1.25rem; }
.hp-result-head {
  font-size: .85rem; color: var(--text-soft); margin: 0 0 .5rem;
  display: flex; align-items: center; justify-content: space-between; gap: .5rem; flex-wrap: wrap;
}
.hp-devtools { display: inline-flex; gap: .4rem; }
.hp-btn.hp-mini { font-size: .68rem; padding: .2rem .5rem; font-weight: 600; }
.hp-card-root {
  display: grid; gap: 1rem; padding: 1rem; border-radius: 14px;
  background: var(--surface);
  box-shadow: 0 1px 6px color-mix(in oklab, var(--ink) 14%, transparent);
}
.hp-section { min-width: 0; }
.hp-h2 { font-size: .95rem; font-weight: 800; margin: 0 0 .5rem; }
.hp-note { font-size: .7rem; font-weight: 500; color: var(--muted); }
.hp-beta {
  position: relative; display: inline-block;
  font-size: .68rem; font-weight: 800; letter-spacing: .01em;
  color: var(--accent, #39c5bb); cursor: help; margin: 0 .1rem;
}
.hp-beta::after {
  content: attr(data-tip);
  position: absolute; left: 0; top: calc(100% + 6px); z-index: 40;
  width: max-content; max-width: min(78vw, 280px);
  padding: .45rem .6rem; border-radius: 8px;
  background: var(--card, #1c1f26); color: var(--ink, #e6e6e6);
  border: 1px solid color-mix(in srgb, var(--ink, #888) 20%, transparent);
  box-shadow: 0 6px 22px rgba(0, 0, 0, .25);
  font-size: .72rem; font-weight: 500; line-height: 1.5; white-space: normal;
  opacity: 0; transform: translateY(-3px); pointer-events: none;
  transition: opacity .12s ease, transform .12s ease;
}
.hp-beta:hover::after, .hp-beta:focus::after, .hp-beta:focus-visible::after {
  opacity: 1; transform: translateY(0);
}
.hp-header { display: flex; gap: 1rem; align-items: center; }
.hp-avatar {
  width: 84px; height: 84px; flex: 0 0 auto; border-radius: 16px; overflow: hidden;
  background: var(--surface-2);
}
.hp-avatar-img { width: 100%; height: 100%; object-fit: cover; display: block; }
.hp-name { font-size: 1.35rem; font-weight: 800; margin: 0; }
.hp-rank { font-size: .85rem; color: var(--accent); font-weight: 700; }
.hp-word { margin: .35rem 0; font-size: .85rem; color: var(--text); }
.hp-meta { display: flex; flex-wrap: wrap; gap: .5rem; align-items: center; }
.hp-twitter { font-size: .8rem; color: var(--accent); }
.hp-meta-pill {
  font-size: .68rem; color: var(--text-soft);
  padding: .12rem .4rem; border-radius: 5px; background: var(--surface-2);
}
.hp-cards { display: grid; grid-template-columns: repeat(5, 1fr); gap: .6rem; }
@media (max-width: 620px) { .hp-cards { grid-template-columns: repeat(5, 1fr); gap: .35rem; } }
.hp-card { min-width: 0; }
.hp-card-crop {
  position: relative; aspect-ratio: 312 / 512; overflow: hidden; border-radius: 10px;
  background: var(--surface-2);
}
.hp-card-img { width: 100%; height: 100%; object-fit: cover; display: block; }
.hp-card-missing { display: grid; place-items: center; height: 100%; font-size: .7rem; color: var(--muted); }
.hp-card-attr { position: absolute; top: 3px; left: 3px; width: 22px; height: 22px; line-height: 0; }
.hp-card-attr img { width: 100%; height: 100%; display: block; }
.hp-card-ribbon {
  position: absolute; top: 10px; right: -23px; transform: rotate(45deg);
  width: 92px; text-align: center; font-size: .5rem; font-weight: 800;
  letter-spacing: .02em; color: #fff; padding: 2px 0; line-height: 1;
  box-shadow: 0 1px 2px rgba(0,0,0,.3);
}
.hp-card-ribbon.is-leader { background: #e8588a; }
.hp-card-ribbon.is-sub { background: #3bb38a; }
.hp-card-foot {
  position: absolute; left: 0; right: 0; bottom: 0; padding: 6px 4px 3px;
  display: flex; flex-direction: column; gap: 1px;
  background: linear-gradient(transparent, rgba(0,0,0,.6));
}
.hp-card-level { font-size: .62rem; font-weight: 800; color: #fff; text-shadow: 0 1px 2px rgba(0,0,0,.7); }
.hp-card-stars { display: flex; line-height: 0; }
.hp-card-stars .rarity-star { width: 12px; height: 12px; }
.hp-card-master {
  position: absolute; bottom: 4px; right: 4px; width: 20px; height: 20px;
  display: grid; place-items: center; font-size: .66rem; font-weight: 800; color: #fff;
}
.hp-card-master::before {
  content: ''; position: absolute; inset: 0; z-index: -1; transform: rotate(45deg);
  background: color-mix(in oklab, var(--ink) 72%, transparent); border-radius: 4px;
  border: 1px solid rgba(255,255,255,.6);
}
.hp-deck .hp-h2 { display: inline-flex; align-items: center; }
.hp-deck-talent { display: inline-flex; align-items: center; gap: .25rem; font-size: .85rem; font-weight: 800; color: var(--accent); margin-left: .6rem; }
.hp-deck-mic {
  display: inline-block; width: 1.15em; height: 1.15em; background: var(--accent);
  -webkit-mask: url(/img/cp-widgets/icon_deckPower_wh.png) center/contain no-repeat;
  mask: url(/img/cp-widgets/icon_deckPower_wh.png) center/contain no-repeat;
}
.hp-cpcard-carousel { position: relative; }
.hp-cpcard-track {
  display: flex; overflow-x: auto; scroll-snap-type: x mandatory;
  gap: 0; scrollbar-width: none; -webkit-overflow-scrolling: touch;
  border-radius: 10px;
}
.hp-cpcard-track::-webkit-scrollbar { display: none; }
.hp-cpcard-item { flex: 0 0 100%; scroll-snap-align: center; margin: 0; min-width: 0; }
.hp-cpcard-canvas {
  width: 100%; height: auto; aspect-ratio: 1830 / 813; display: block;
  border-radius: 10px; background: var(--surface-2);
}
.hp-cpcard-diag { font-size: .68rem; color: #b7791f; margin-top: .3rem; word-break: break-word; padding: 0 .5rem; }
.hp-carousel-nav {
  position: absolute; top: calc(50% - 1.2rem); transform: translateY(-50%);
  width: 2.4rem; height: 2.4rem; border-radius: 50%; cursor: pointer;
  display: grid; place-items: center; font-size: 1.5rem; line-height: 1;
  border: none; color: #fff; background: color-mix(in oklab, var(--ink) 55%, transparent);
  backdrop-filter: blur(2px); transition: background .15s;
}
.hp-carousel-nav:hover { background: color-mix(in oklab, var(--ink) 70%, transparent); }
.hp-carousel-prev { left: .5rem; }
.hp-carousel-next { right: .5rem; }
.hp-carousel-dots { display: flex; justify-content: center; gap: .4rem; margin-top: .5rem; }
.hp-carousel-dot {
  width: .55rem; height: .55rem; border-radius: 50%; cursor: pointer; padding: 0;
  border: none; background: color-mix(in oklab, var(--ink) 22%, transparent); transition: background .15s, transform .15s;
}
.hp-carousel-dot.is-active { background: var(--accent); transform: scale(1.2); }
.hp-showall {
  font: inherit; font-size: .72rem; font-weight: 700; cursor: pointer;
  margin-left: .5rem; padding: .2rem .65rem; border-radius: 999px; vertical-align: middle;
  border: 1px solid color-mix(in oklab, var(--accent) 40%, transparent);
  background: transparent; color: var(--accent);
}
.hp-showall:hover { background: color-mix(in oklab, var(--accent) 12%, transparent); }
.hp-cpcard-carousel.is-expanded .hp-cpcard-track {
  flex-direction: column; overflow-x: visible; scroll-snap-type: none; gap: 1rem;
}
.hp-cpcard-carousel.is-expanded .hp-carousel-nav,
.hp-cpcard-carousel.is-expanded .hp-carousel-dots { display: none; }
.hp-honor-row { display: flex; flex-wrap: wrap; gap: .4rem; align-items: center; }
.hp-honor-item { line-height: 0; }
.hp-honor-canvas { height: 40px; width: auto; display: block; border-radius: 4px; }
.hp-honor-fallback { display: none; }
.hp-honor-item--fallback .hp-honor-canvas { display: none; }
.hp-honor-item--fallback .hp-honor-fallback { display: inline-block; line-height: 1.4; }
.hp-honor {
  font-size: .72rem; padding: .15rem .45rem; border-radius: 5px;
  background: var(--surface-2); color: var(--text-soft);
}
.hp-clear-table { width: 100%; border-collapse: collapse; font-size: .8rem; }
.hp-clear-table th, .hp-clear-table td {
  padding: .3rem .4rem; text-align: center;
  border-bottom: 1px solid color-mix(in oklab, var(--ink) 8%, transparent);
}
.hp-clear-table thead th { font-size: .68rem; color: var(--muted); text-transform: uppercase; }
.hp-clear-row { text-align: left !important; font-weight: 700; white-space: nowrap; }
.hp-stats { display: grid; grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)); gap: .75rem; }
.hp-stat-card { padding: .75rem; border-radius: 10px; background: var(--surface-2); }
.hp-stat-cap { font-size: .68rem; color: var(--muted); text-transform: uppercase; font-weight: 700; }
.hp-stat-char { width: 40px; height: 40px; border-radius: 50%; object-fit: cover; object-position: top center; float: right; }
.hp-stat-val { font-size: .9rem; font-weight: 700; margin-top: .2rem; }
.hp-stat-sub { font-size: .72rem; color: var(--text-soft); }
.hp-power-total { font-size: 1.3rem; font-weight: 800; color: var(--accent); }
.hp-power-breakdown { list-style: none; margin: .4rem 0 0; padding: 0; font-size: .72rem; }
.hp-power-breakdown li { display: flex; justify-content: space-between; gap: .5rem; padding: .1rem 0; }
.hp-power-breakdown span { color: var(--text-soft); }
.hp-char-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(56px, 1fr)); gap: .5rem; }
.hp-char { display: flex; flex-direction: column; align-items: center; gap: .15rem; }
.hp-char-icon {
  width: 44px; height: 44px; border-radius: 50%; object-fit: cover; object-position: top center;
  background: var(--surface-2);
}
.hp-char-rank { font-size: .72rem; font-weight: 700; }
