:root {
  color-scheme: light;
  --bg: #fff7df;
  --bg-2: #ffe8ee;
  --ink: #332521;
  --ink-soft: #5f4a43;
  --muted: #8a7067;
  --panel: rgba(255, 255, 255, 0.74);
  --panel-strong: rgba(255, 255, 255, 0.92);
  --glass: rgba(255, 255, 255, 0.54);
  --line: rgba(88, 56, 36, 0.14);
  --line-strong: rgba(88, 56, 36, 0.22);
  --accent: #ffb23f;
  --accent-2: #ff6f9a;
  --accent-3: #72d7cf;
  --accent-4: #b7df6a;
  --violet: #a99af2;
  --danger: #dd5d5d;
  --shadow: 0 24px 80px rgba(120, 70, 32, 0.18);
  --shadow-strong: 0 30px 110px rgba(128, 66, 51, 0.28);
  --radius: 28px;
  font-family: "Hiragino Maru Gothic ProN", "Yu Gothic", "Meiryo", system-ui, sans-serif;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; min-height: 100%; }
body {
  margin: 0;
  min-height: 100%;
  color: var(--ink);
  background:
    radial-gradient(circle at 15% 6%, rgba(255, 204, 91, 0.46) 0 18%, transparent 34%),
    radial-gradient(circle at 83% 4%, rgba(255, 108, 154, 0.34) 0 18%, transparent 36%),
    linear-gradient(135deg, #fff7df 0%, #ffe8ee 48%, #e5fcf8 100%);
  overflow-x: hidden;
}
body::selection { background: rgba(255, 127, 155, 0.32); }
button, input, select, textarea { font: inherit; }
button, a { -webkit-tap-highlight-color: transparent; }
button { cursor: pointer; }
button:disabled { cursor: not-allowed; opacity: 0.48; }

a { color: inherit; text-decoration: none; }

button:focus-visible,
a:focus-visible,
.input:focus-visible,
.select:focus-visible,
.share-box:focus-visible {
  outline: 3px solid rgba(255, 111, 154, 0.65);
  outline-offset: 2px;
}
.character-card:has(input:focus-visible) {
  outline: 3px solid rgba(255, 111, 154, 0.65);
  outline-offset: 2px;
}

.ambient { position: fixed; inset: 0; z-index: -1; overflow: hidden; pointer-events: none; }
.orb { position: absolute; border-radius: 999px; filter: blur(8px); opacity: 0.82; animation: floaty 12s ease-in-out infinite alternate; }
.orb-a { width: 420px; height: 420px; right: -110px; top: -120px; background: repeating-conic-gradient(from 8deg, rgba(255, 178, 63, 0.8) 0 8deg, rgba(255,255,255,0) 8deg 19deg), radial-gradient(circle, #fff0a8, transparent 62%); }
.orb-b { width: 360px; height: 360px; left: -140px; top: 320px; background: radial-gradient(circle, rgba(114, 215, 207, 0.72), transparent 62%); animation-delay: -4s; }
.orb-c { width: 340px; height: 340px; right: 14%; bottom: -150px; background: radial-gradient(circle, rgba(255, 111, 154, 0.58), transparent 62%); animation-delay: -7s; }
.mesh { position: absolute; width: 260px; height: 260px; border: 1px solid rgba(255,255,255,0.54); border-radius: 46px; transform: rotate(18deg); opacity: 0.4; background: linear-gradient(135deg, rgba(255,255,255,0.3), transparent); }
.mesh-a { left: 9%; top: 150px; }
.mesh-b { right: 8%; top: 520px; transform: rotate(-23deg); }
.grain { position: absolute; inset: -20%; opacity: 0.09; background-image: radial-gradient(circle, rgba(40, 30, 24, 0.8) 0 1px, transparent 1px); background-size: 18px 18px; animation: grain 8s steps(2, end) infinite; }

@keyframes floaty { from { transform: translate3d(0, 0, 0) scale(1); } to { transform: translate3d(28px, -18px, 0) scale(1.04); } }
@keyframes grain { 0%,100% { transform: translate(0,0); } 50% { transform: translate(-24px, 16px); } }
@keyframes rise { from { opacity: 0; transform: translateY(18px) scale(0.98); } to { opacity: 1; transform: translateY(0) scale(1); } }
@keyframes pop { 0% { transform: scale(0.96); } 50% { transform: scale(1.03); } 100% { transform: scale(1); } }
@keyframes shimmer { from { transform: translateX(-120%) rotate(18deg); } to { transform: translateX(140%) rotate(18deg); } }
@keyframes pulse { 0%,100% { transform: scale(1); opacity: 0.7; } 50% { transform: scale(1.08); opacity: 1; } }

.site-hero { max-width: 1220px; margin: 0 auto; padding: 22px 20px 20px; }
.topbar {
  display: flex; align-items: center; justify-content: space-between; gap: 16px;
  padding: 12px 14px; border: 1px solid rgba(255,255,255,0.76); border-radius: 999px;
  background: rgba(255,255,255,0.42); backdrop-filter: blur(18px); box-shadow: 0 12px 40px rgba(120,70,32,0.09);
}
.brand { display: inline-flex; align-items: center; gap: 10px; font-weight: 950; letter-spacing: 0.04em; }
.brand__mark { width: 38px; height: 38px; display: grid; place-items: center; border-radius: 15px; background: #fff; box-shadow: 0 8px 20px rgba(120,70,32,0.12); }
.hero-grid { display: grid; grid-template-columns: minmax(0, 1.1fr) minmax(320px, 0.9fr); gap: clamp(24px, 5vw, 70px); align-items: center; padding: clamp(36px, 7vw, 80px) 0 38px; }
.hero-copy { animation: rise 0.66s ease both; }
.eyebrow { margin: 0 0 12px; color: #b36830; font-weight: 950; letter-spacing: 0.13em; text-transform: uppercase; }
h1 { margin: 0; font-size: clamp(44px, 8vw, 84px); line-height: 1.02; letter-spacing: -0.035em; }
.lead { max-width: 760px; margin: 22px 0 0; color: var(--ink-soft); line-height: 1.9; font-weight: 650; font-size: clamp(15px, 2vw, 18px); }
.hero-actions { display: flex; flex-wrap: wrap; gap: 12px; margin-top: 28px; }
.hero-card { position: relative; min-height: 420px; border-radius: 46px; border: 1px solid rgba(255,255,255,0.8); background: linear-gradient(145deg, rgba(255,255,255,0.8), rgba(255,255,255,0.36)); box-shadow: var(--shadow-strong); overflow: hidden; transform-style: preserve-3d; animation: rise 0.78s ease 0.08s both; }
.hero-card::before { content: ""; position: absolute; inset: 0; background: linear-gradient(120deg, transparent 0 35%, rgba(255,255,255,0.46) 44%, transparent 55%); animation: shimmer 5.5s ease-in-out infinite; }
.hero-card__glow { position: absolute; width: 280px; height: 280px; border-radius: 999px; background: radial-gradient(circle, rgba(255,178,63,0.58), transparent 66%); top: -80px; right: -80px; animation: pulse 4.2s ease-in-out infinite; }
.hero-card__badge { position: absolute; left: 26px; bottom: 26px; border-radius: 999px; padding: 12px 16px; background: var(--ink); color: #fff; font-weight: 950; box-shadow: 0 16px 38px rgba(51,37,33,0.18); }
.mini-sort-card { position: absolute; display: grid; place-items: center; width: 164px; height: 108px; border-radius: 28px; color: #fff; font-weight: 950; font-size: 24px; letter-spacing: 0.04em; box-shadow: 0 20px 60px rgba(75, 47, 34, 0.18); transform: rotate(var(--r)); animation: floatCard 5.6s ease-in-out infinite alternate; }
.mini-sort-card--one { --r: -8deg; left: 44px; top: 52px; background: linear-gradient(135deg, #ffb23f, #ff6f9a); }
.mini-sort-card--two { --r: 7deg; right: 42px; top: 88px; background: linear-gradient(135deg, #72d7cf, #78c96d); animation-delay: -1.4s; }
.mini-sort-card--three { --r: -2deg; left: 122px; top: 168px; background: linear-gradient(135deg, #a99af2, #ff89b4); animation-delay: -2.3s; }
.mini-sort-card--four { --r: 9deg; right: 84px; bottom: 86px; background: linear-gradient(135deg, #ff9f69, #ffcf68); animation-delay: -3.2s; }
.mini-sort-card--five { --r: -10deg; left: 54px; bottom: 112px; background: linear-gradient(135deg, #68c8ff, #8be1d2); animation-delay: -4s; }
@keyframes floatCard { from { transform: translateY(0) rotate(var(--r)); } to { transform: translateY(-14px) rotate(calc(var(--r) * -0.6)); } }

.app { max-width: 1220px; margin: 0 auto 34px; padding: 0 20px; }
.panel { background: var(--panel); backdrop-filter: blur(24px); border: 1px solid rgba(255,255,255,0.78); border-radius: var(--radius); box-shadow: var(--shadow); padding: clamp(18px, 3vw, 34px); animation: rise 0.42s ease both; }
.panel + .panel { margin-top: 18px; }
.panel--hero { overflow: hidden; position: relative; }
.panel--hero::after { content: ""; position: absolute; right: -120px; top: -120px; width: 340px; height: 340px; border-radius: 999px; background: radial-gradient(circle, rgba(255, 178, 63, 0.28), transparent 68%); pointer-events: none; }
.toolbar { display: flex; flex-wrap: wrap; align-items: center; justify-content: space-between; gap: 14px; margin-bottom: 18px; }
.toolbar__left, .toolbar__right { display: flex; flex-wrap: wrap; align-items: center; gap: 10px; }
h2, h3 { margin: 0; line-height: 1.32; letter-spacing: -0.02em; }
h2 { font-size: clamp(28px, 5vw, 46px); }
h3 { font-size: clamp(20px, 3vw, 28px); }
.helper { margin: 10px 0 0; color: var(--muted); line-height: 1.8; font-weight: 650; }

.btn { position: relative; overflow: hidden; display: inline-flex; align-items: center; justify-content: center; gap: 8px; border: 0; border-radius: 999px; min-height: 46px; padding: 12px 18px; background: #fff; color: var(--ink); font-weight: 950; box-shadow: 0 12px 28px rgba(88,62,39,0.11); transition: transform 0.16s ease, box-shadow 0.16s ease, filter 0.16s ease; }
.btn::after { content: ""; position: absolute; inset: 0; background: linear-gradient(120deg, transparent 0 30%, rgba(255,255,255,0.46) 45%, transparent 62%); transform: translateX(-120%); transition: transform 0.36s ease; }
.btn:hover:not(:disabled) { transform: translateY(-2px); box-shadow: 0 16px 34px rgba(88,62,39,0.17); }
.btn:hover:not(:disabled)::after { transform: translateX(120%); }
.btn:active:not(:disabled) { transform: translateY(0); }
.btn--primary { color: #fff; background: linear-gradient(135deg, #ffb23f, #ff6f9a); }
.btn--mint { color: #fff; background: linear-gradient(135deg, #72d7cf, #78c96d); }
.btn--violet { color: #fff; background: linear-gradient(135deg, #a99af2, #ff89b4); }
.btn--glass { background: rgba(255,255,255,0.58); border: 1px solid rgba(255,255,255,0.7); }
.btn--ghost { background: rgba(255,255,255,0.62); }
.btn--danger { background: #fff0f0; color: var(--danger); }
.btn--wide { min-width: 180px; }
.pill { display: inline-flex; align-items: center; gap: 7px; border: 1px solid var(--line); border-radius: 999px; padding: 8px 12px; color: var(--muted); background: rgba(255,255,255,0.62); font-size: 13px; font-weight: 900; }
.pill strong { color: var(--ink); }

.metrics { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 12px; margin: 18px 0 22px; }
.metric { border: 1px solid var(--line); border-radius: 22px; padding: 15px; background: rgba(255,255,255,0.58); }
.metric strong { display: block; font-size: 28px; line-height: 1; }
.metric span { display: block; margin-top: 7px; color: var(--muted); font-size: 12px; font-weight: 850; }

.group-tabs { display: flex; gap: 8px; overflow-x: auto; padding: 3px 2px 14px; margin: 0 0 10px; scrollbar-width: thin; }
.group-tabs button { flex: 0 0 auto; border: 1px solid var(--line); border-radius: 999px; background: rgba(255,255,255,0.62); padding: 9px 14px; color: var(--muted); font-weight: 950; transition: transform 0.16s ease, background 0.16s ease; }
.group-tabs button:hover { transform: translateY(-1px); }
.group-tabs button.is-active { background: var(--ink); color: #fff; border-color: transparent; }

.search-row { display: grid; grid-template-columns: 1fr auto; gap: 12px; margin-bottom: 16px; }
.input, .select, .share-box { width: 100%; border: 1px solid var(--line); border-radius: 17px; background: rgba(255,255,255,0.72); color: var(--ink); padding: 0 14px; outline: none; box-shadow: inset 0 1px 0 rgba(255,255,255,0.6); }
.input, .select { min-height: 48px; }
.input:focus, .select:focus, .share-box:focus { border-color: rgba(255, 111, 154, 0.5); box-shadow: 0 0 0 4px rgba(255,111,154,0.12); }

.character-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)); gap: 12px; }
.character-card { position: relative; display: flex; align-items: center; gap: 12px; min-height: 86px; border: 1px solid var(--line); border-radius: 24px; padding: 12px; background: rgba(255,255,255,0.62); overflow: hidden; transition: transform 0.16s ease, border-color 0.16s ease, box-shadow 0.16s ease, background 0.16s ease; }
.character-card::before { content: ""; position: absolute; inset: 0; background: linear-gradient(120deg, transparent, rgba(255,255,255,0.38), transparent); transform: translateX(-130%); transition: transform 0.34s ease; }
.character-card:hover { transform: translateY(-3px); box-shadow: 0 18px 42px rgba(88,62,39,0.12); }
.character-card:hover::before { transform: translateX(130%); }
.character-card input { position: absolute; inset: 0; opacity: 0; cursor: pointer; }
.character-card:has(input:checked) { background: rgba(255, 249, 232, 0.92); border-color: rgba(255, 111, 154, 0.48); box-shadow: 0 16px 40px rgba(255,111,154,0.16); }
.avatar { position: relative; width: 54px; height: 54px; border-radius: 20px; display: grid; place-items: center; flex: 0 0 auto; color: #fff; font-weight: 950; letter-spacing: -0.06em; box-shadow: 0 10px 22px rgba(88,62,39,0.14); }
.avatar::after { content: ""; position: absolute; inset: 4px; border-radius: 16px; border: 1px solid rgba(255,255,255,0.42); }
.character-card__body { display: grid; gap: 4px; min-width: 0; }
.character-card strong { font-size: 18px; }
.character-card small { color: var(--muted); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; font-weight: 750; }
.custom-form { display: grid; grid-template-columns: minmax(120px, 1fr) minmax(120px, 190px) auto; gap: 10px; margin-top: 16px; }

.sort-stage { display: grid; gap: 20px; }
.sort-head { display: grid; grid-template-columns: 1fr auto; gap: 16px; align-items: center; }
.progress-card { min-width: 230px; border-radius: 26px; border: 1px solid var(--line); padding: 14px; background: rgba(255,255,255,0.62); }
.progress-number { display: flex; align-items: baseline; justify-content: space-between; gap: 10px; color: var(--muted); font-size: 13px; font-weight: 900; }
.progress-number strong { color: var(--ink); font-size: 28px; }
.progress-bar { overflow: hidden; height: 12px; margin-top: 10px; border-radius: 999px; background: rgba(255,255,255,0.86); border: 1px solid var(--line); }
.progress-bar > span { display: block; height: 100%; width: 0%; border-radius: inherit; background: linear-gradient(90deg, #ffb23f, #ff6f9a, #72d7cf, #b7df6a); transition: width 0.24s ease; }
.tie-actions { display: flex; flex-wrap: wrap; justify-content: center; gap: 10px; }
.current-stack { display: flex; gap: 8px; flex-wrap: wrap; color: var(--muted); font-size: 13px; font-weight: 850; }
.current-stack span { border: 1px solid var(--line); border-radius: 999px; padding: 6px 10px; background: rgba(255,255,255,0.6); }

.result-hero { display: grid; grid-template-columns: minmax(0, 1fr) minmax(260px, 0.42fr); gap: 18px; align-items: stretch; }
.podium { display: grid; grid-template-columns: repeat(3, 1fr); gap: 12px; align-items: end; }
.podium-card { position: relative; min-height: 210px; border-radius: 28px; padding: 18px; border: 1px solid rgba(255,255,255,0.78); background: linear-gradient(145deg, rgba(255,255,255,0.86), rgba(255,255,255,0.48)); box-shadow: 0 18px 50px rgba(88,62,39,0.13); overflow: hidden; animation: pop 0.42s ease both; }
.podium-card:nth-child(1) { min-height: 260px; }
.podium-card::before { content: ""; position: absolute; width: 180px; height: 180px; border-radius: 999px; background: var(--card-bg); opacity: 0.22; right: -70px; top: -72px; }
.podium-rank { position: relative; display: inline-grid; place-items: center; width: 52px; height: 52px; border-radius: 18px; color: #fff; background: var(--card-bg); font-weight: 950; font-size: 20px; }
.podium-name { position: relative; display: block; margin-top: 46px; font-size: clamp(22px, 3vw, 34px); font-weight: 950; line-height: 1.18; }
.podium-meta { position: relative; display: block; margin-top: 8px; color: var(--muted); font-size: 13px; font-weight: 850; }
.result-side { border: 1px solid var(--line); border-radius: 28px; padding: 18px; background: rgba(255,255,255,0.58); }
.result-side strong { display: block; font-size: 42px; line-height: 1; }
.result-side span { display: block; margin-top: 8px; color: var(--muted); font-weight: 850; line-height: 1.6; }
.result-actions { display: flex; flex-wrap: wrap; gap: 10px; margin-top: 20px; }
.result-list { display: grid; gap: 10px; margin-top: 18px; }
.result-item { display: grid; grid-template-columns: 84px 1fr auto; gap: 14px; align-items: center; border: 1px solid var(--line); border-radius: 22px; padding: 14px 16px; background: rgba(255,255,255,0.68); transition: transform 0.16s ease, box-shadow 0.16s ease; }
.result-item:hover { transform: translateY(-2px); box-shadow: 0 14px 34px rgba(88,62,39,0.1); }
.rank { display: inline-grid; place-items: center; min-height: 50px; border-radius: 18px; color: #fff; background: linear-gradient(135deg, #ffb23f, #ff6f9a); font-weight: 950; font-size: 18px; }
.result-names { display: flex; flex-wrap: wrap; gap: 8px; align-items: center; font-weight: 950; font-size: 20px; }
.name-chip { display: inline-flex; align-items: center; border-radius: 999px; padding: 7px 12px; background: rgba(255,255,255,0.88); border: 1px solid var(--line); }
.result-meta { color: var(--muted); font-size: 13px; font-weight: 850; }
.stats-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(170px, 1fr)); gap: 10px; margin-top: 16px; }
.stat-card { position: relative; overflow: hidden; border: 1px solid var(--line); border-radius: 22px; padding: 16px; background: rgba(255,255,255,0.62); }
.stat-card::before { content: ""; position: absolute; inset: auto -20px -40px auto; width: 110px; height: 110px; border-radius: 999px; background: var(--card-bg); opacity: 0.16; }
.stat-card strong { position: relative; font-size: 32px; }
.stat-card span { position: relative; display: block; color: var(--muted); font-size: 13px; font-weight: 850; margin-top: 5px; }
.share-box { min-height: 130px; padding: 14px; resize: vertical; line-height: 1.7; }

.feature-strip { max-width: 1220px; margin: 0 auto 48px; padding: 0 20px; display: grid; grid-template-columns: repeat(4, 1fr); gap: 12px; }
.feature-strip article { border: 1px solid rgba(255,255,255,0.76); border-radius: 24px; padding: 18px; background: rgba(255,255,255,0.48); backdrop-filter: blur(18px); box-shadow: 0 12px 40px rgba(120,70,32,0.08); }
.feature-strip strong { display: block; font-size: 19px; }
.feature-strip span { display: block; margin-top: 8px; color: var(--muted); line-height: 1.7; font-weight: 650; }
.footer { max-width: 1220px; margin: 0 auto 36px; padding: 0 20px; color: var(--muted); font-size: 13px; line-height: 1.8; }
.toast { position: fixed; left: 50%; bottom: 24px; z-index: 30; transform: translateX(-50%) translateY(20px); opacity: 0; pointer-events: none; border-radius: 999px; padding: 11px 17px; background: var(--ink); color: #fff; box-shadow: var(--shadow); transition: opacity 0.2s ease, transform 0.2s ease; font-weight: 850; }
.toast.is-visible { opacity: 1; transform: translateX(-50%) translateY(0); }
.confetti { position: fixed; top: -12px; width: 9px; height: 14px; border-radius: 3px; background: var(--card-bg); pointer-events: none; animation: fall var(--d) linear forwards; z-index: 50; }
@keyframes fall { to { transform: translate3d(var(--x), 110vh, 0) rotate(720deg); opacity: 0.2; } }

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation-duration: 0.001ms !important; animation-iteration-count: 1 !important; scroll-behavior: auto !important; transition-duration: 0.001ms !important; }
}
@media (max-width: 1020px) {
  .hero-grid { grid-template-columns: 1fr; }
  .hero-card { min-height: 340px; }
  .mini-sort-card--one { left: 6%; top: 44px; }
  .mini-sort-card--two { right: 8%; top: 52px; }
  .mini-sort-card--three { left: calc(50% - 82px); top: 120px; }
  .mini-sort-card--four { right: 22%; bottom: 56px; }
  .mini-sort-card--five { left: 18%; bottom: 48px; }
  .result-hero { grid-template-columns: 1fr; }
  .feature-strip { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 720px) {
  .site-hero { padding-top: 14px; }
  .topbar { border-radius: 24px; }
  h1 { font-size: clamp(40px, 13vw, 64px); }
  .hero-card { min-height: 300px; }
  .mini-sort-card { width: 108px; height: 74px; border-radius: 20px; font-size: 17px; }
  .mini-sort-card--one { left: 14px; top: 26px; }
  .mini-sort-card--two { right: 14px; top: 48px; }
  .mini-sort-card--three { left: calc(50% - 54px); top: 116px; }
  .mini-sort-card--four { right: 26px; bottom: 66px; }
  .mini-sort-card--five { left: 22px; bottom: 52px; }
  .metrics { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .search-row, .custom-form { grid-template-columns: 1fr; }
  .sort-head { grid-template-columns: 1fr; }
  .progress-card { min-width: 0; }
  .podium { grid-template-columns: 1fr; }
  .podium-card, .podium-card:nth-child(1) { min-height: 190px; }
  .result-item { grid-template-columns: 64px 1fr; }
  .result-meta { grid-column: 2; }
  .feature-strip { grid-template-columns: 1fr; }
}

/* 5択配置式ソート */
.sort-panel { position: relative; overflow: hidden; }
.sort-panel::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background:
    radial-gradient(circle at 14% 12%, rgba(255, 178, 63, 0.18), transparent 32%),
    radial-gradient(circle at 88% 18%, rgba(114, 215, 207, 0.18), transparent 30%);
}
.sort-panel > * { position: relative; }
.placement-zone { display: grid; gap: 24px; }
.pool-shell {
  position: relative;
  border: 2px dashed rgba(138, 112, 103, 0.24);
  border-radius: 34px;
  padding: 26px clamp(16px, 3vw, 28px) 30px;
  background: rgba(255,255,255,0.34);
  min-height: 210px;
  overflow: hidden;
}
.pool-shell::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image: linear-gradient(90deg, rgba(255,255,255,0.32) 1px, transparent 1px), linear-gradient(rgba(255,255,255,0.28) 1px, transparent 1px);
  background-size: 38px 38px;
  opacity: 0.35;
  pointer-events: none;
}
.zone-label { position: relative; color: var(--ink-soft); font-size: 14px; font-weight: 950; letter-spacing: 0.02em; margin-bottom: 20px; }
.retire-note { position: relative; margin-top: 18px; color: var(--muted); font-size: 12px; font-weight: 850; text-align: right; }
.candidate-pool { position: relative; display: grid; grid-template-columns: repeat(5, minmax(0, 1fr)); gap: clamp(10px, 1.8vw, 16px); align-items: stretch; }
.candidate-card {
  position: relative;
  display: grid;
  gap: 12px;
  min-height: 176px;
  border: 1px solid rgba(255,255,255,0.82);
  border-radius: 28px;
  padding: 16px;
  text-align: left;
  background: rgba(255,255,255,0.78);
  color: inherit;
  box-shadow: 0 18px 42px rgba(88,62,39,0.13);
  overflow: hidden;
  animation: rise 0.36s ease both;
  animation-delay: calc(var(--i) * 52ms);
  transition: transform 0.18s ease, box-shadow 0.18s ease, opacity 0.18s ease, filter 0.18s ease;
  cursor: grab;
  user-select: none;
  -webkit-user-select: none;
  will-change: transform;
}

.candidate-card::before {
  content: "";
  position: absolute;
  width: 150px;
  height: 150px;
  border-radius: 999px;
  right: -58px;
  top: -64px;
  background: var(--card-bg);
  opacity: 0.22;
}
.candidate-card::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(120deg, transparent 0 28%, rgba(255,255,255,0.55) 46%, transparent 62%);
  transform: translateX(-132%);
  transition: transform 0.5s ease;
}
.candidate-card:hover { transform: translateY(-6px) rotate(-0.3deg); box-shadow: 0 28px 70px rgba(88,62,39,0.18); }
.candidate-card:active, .candidate-card.is-grabbed { cursor: grabbing; transform: translateY(-14px) rotate(-2.2deg) scale(1.055); box-shadow: 0 38px 96px rgba(88,62,39,0.30); filter: saturate(1.12); z-index: 20; }
.candidate-card:hover::after { transform: translateX(132%); }
.candidate-card.is-placed { display: none; }
.candidate-card.is-placed:hover { transform: none; }
.candidate-card__badge { position: relative; z-index: 1; width: 38px; height: 38px; display: grid; place-items: center; border-radius: 14px; background: rgba(255,255,255,0.78); border: 1px solid var(--line); color: var(--muted); font-weight: 950; }
.candidate-card__avatar { position: relative; z-index: 1; width: 72px; height: 72px; border-radius: 26px; display: grid; place-items: center; color: #fff; background: var(--card-bg); box-shadow: 0 16px 34px rgba(88,62,39,0.17); font-weight: 950; font-size: 25px; letter-spacing: -0.06em; }
.candidate-card__body { position: relative; z-index: 1; display: grid; gap: 8px; }
.candidate-card__body strong { font-size: clamp(20px, 2.4vw, 28px); line-height: 1.16; }
.candidate-card__body small { color: var(--muted); font-weight: 850; line-height: 1.5; }
.rank-board { display: grid; grid-template-columns: 16px repeat(5, minmax(0, 1fr) 16px); column-gap: 4px; row-gap: 12px; padding: 12px clamp(4px, 2vw, 42px) 0; align-items: stretch; }
.rank-insert-gap {
  position: relative;
  min-height: 168px;
  border-radius: 999px;
  background: transparent;
  transition: background 0.16s ease, transform 0.16s ease;
}
.rank-insert-gap span {
  position: absolute;
  left: 50%;
  top: 18px;
  bottom: 16px;
  width: 5px;
  transform: translateX(-50%) scaleY(0.18);
  border-radius: 999px;
  background: linear-gradient(180deg, #ffb23f, #ff6f9a, #72d7cf);
  opacity: 0;
  box-shadow: 0 12px 28px rgba(255,111,154,0.26);
  transition: opacity 0.16s ease, transform 0.16s ease;
}
.is-dragging-card .rank-insert-gap span { opacity: 0.28; transform: translateX(-50%) scaleY(0.72); }
.rank-insert-gap.is-insertover { background: rgba(255,111,154,0.10); transform: scaleX(1.22); }
.rank-insert-gap.is-insertover span { opacity: 1; transform: translateX(-50%) scaleY(1); }
.rank-slot {
  position: relative;
  min-height: 168px;
  display: grid;
  align-content: center;
  justify-items: center;
  gap: 10px;
  border-radius: 26px;
  border: 2px dashed rgba(138, 112, 103, 0.28);
  background: rgba(255,255,255,0.44);
  color: var(--muted);
  padding: 18px 12px 16px;
  transition: transform 0.16s ease, box-shadow 0.16s ease, border-color 0.16s ease, background 0.16s ease;
}
.rank-slot:hover, .rank-slot.is-dragover { transform: translateY(-4px); border-color: rgba(255,111,154,0.55); box-shadow: 0 18px 42px rgba(88,62,39,0.12); background: rgba(255,255,255,0.68); }
.rank-slot.is-dragover { transform: translateY(-7px) scale(1.015); border-color: rgba(255,111,154,0.82); background: rgba(255,255,255,0.78); }
.is-dragging-card .rank-slot { border-color: rgba(255,111,154,0.42); background: rgba(255,255,255,0.62); }
.is-dragging-card .rank-slot::after { content: "ここにドロップ"; position: absolute; right: 14px; bottom: 12px; color: rgba(95,74,67,0.42); font-size: 11px; font-weight: 950; letter-spacing: 0.04em; }
.drag-ghost { position: fixed; top: -1000px; left: -1000px; z-index: 9999; pointer-events: none; transform: rotate(-3deg) scale(1.04); opacity: 0.94; box-shadow: 0 32px 90px rgba(88,62,39,0.28); cursor: grabbing; }

.rank-slot__badge { position: absolute; top: -16px; left: 50%; transform: translateX(-50%); min-width: 58px; height: 34px; display: inline-grid; place-items: center; padding: 0 12px; border-radius: 999px; color: #fff; background: var(--card-bg); font-weight: 950; box-shadow: 0 10px 24px rgba(88,62,39,0.14); }
.rank-slot__empty { color: rgba(95,74,67,0.46); font-weight: 950; }
.rank-slot.is-filled { border-style: solid; border-color: rgba(255,255,255,0.78); background: rgba(255,255,255,0.86); box-shadow: 0 22px 52px rgba(88,62,39,0.13); }
.rank-slot.is-filled::before { content: ""; position: absolute; inset: auto -24px -46px auto; width: 138px; height: 138px; border-radius: 999px; background: var(--card-bg); opacity: 0.18; }
.rank-slot__avatar { position: relative; width: 58px; height: 58px; display: grid; place-items: center; border-radius: 20px; color: #fff; background: var(--card-bg); font-weight: 950; font-size: 21px; box-shadow: 0 12px 26px rgba(88,62,39,0.16); }
.rank-slot__name { position: relative; color: var(--ink); font-size: clamp(18px, 2.4vw, 25px); font-weight: 950; line-height: 1.18; text-align: center; }
.rank-slot__hint { position: relative; color: var(--muted); font-size: 11px; font-weight: 850; }

@media (max-width: 1020px) {
  .candidate-pool { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .rank-board { grid-template-columns: 1fr; }
  .rank-insert-gap { min-height: 18px; }
  .rank-insert-gap span { left: 12px; right: 12px; top: 50%; bottom: auto; width: auto; height: 5px; transform: translateY(-50%) scaleX(0.18); }
  .is-dragging-card .rank-insert-gap span { transform: translateY(-50%) scaleX(0.72); }
  .rank-insert-gap.is-insertover span { transform: translateY(-50%) scaleX(1); }
}
@media (max-width: 720px) {
  .candidate-pool, .rank-board { grid-template-columns: 1fr; }
  .pool-shell { padding: 20px 14px 22px; }
  .rank-slot { min-height: 126px; }
}

/* Sort screen should feel stable while cards move between slots. */
.sort-panel,
.sort-panel .candidate-card,
.sort-panel .rank-slot.is-filled {
  animation: none;
}
.sort-panel .candidate-card.is-placed {
  pointer-events: auto;
}


.candidate-pool__empty { grid-column: 1 / -1; margin: 0; padding: 36px 20px; text-align: center; color: rgba(95,74,67,0.56); font-weight: 950; }
.candidate-card[hidden], .candidate-card.is-placed { display: none !important; }
