:root {
	--bg: #0b0f14;
	--panel: #111923;
	--muted: #8ba2b1;
	--text: #e8f0f7;
	--brand: #5ad1ff;
	--accent: #ff5a7a;
	--chip: #1b2633;
	--chip-on: #0f141b;
	--good: #60d394;
	--warn: #ffd97d;
	--bad: #ff6b6b;
	--radius: 18px;
	--shadow: 0 6px 20px rgba(0, 0, 0, .35);
}

* {
	box-sizing: border-box
}

body {
  overflow: hidden;
	margin: 0;
	background: radial-gradient(1200px 1200px at 80% -10%, rgba(90, 209, 255, .08), transparent), var(--bg);
	color: var(--text);
	font: 500 15px/1.5 Inter, system-ui, Segoe UI, Roboto, Helvetica, Arial
}

header {
	position: sticky;
	top: 0;
	z-index: 10;
	background: linear-gradient(180deg, rgba(11, 15, 20, .9), rgba(11, 15, 20, .6) 60%, transparent);
	backdrop-filter: blur(8px)
}

.wrap {
	margin: 0 auto;
	padding: 18px
}

h1 {
	font-size: clamp(20px, 3vw, 28px);
	letter-spacing: .5px;
	margin: 0 0 10px
}

.toolbar {
	display: grid;
	grid-template-columns: auto 1fr auto auto;
	gap: 10px;
	align-items: center
}

.search {
	display: flex;
	align-items: center;
	background: var(--panel);
	border-radius: 999px;
	padding: 8px 14px;
	border: 1px solid #1e2a36
}

.search input {
	flex: 1;
	background: transparent;
	border: 0;
	color: var(--text);
	outline: none;
	font-size: 15px
}

.filters {
	display: flex;
	gap: 8px;
	flex-wrap: wrap
}

.actions {
	display: flex;
	gap: 8px;
	flex-wrap: wrap
}

select,
button {
	background: var(--panel);
	border: 1px solid #1e2a36;
	color: var(--text);
	padding: 8px 12px;
	border-radius: 999px
}

button {
	cursor: pointer;
	transition: transform .08s ease
}

button:active {
	transform: translateY(1px)
}

.digilist {
    overflow: overlay;
    height: 85vh;
    padding: 10px;
}
main {
	display: grid;
  grid-template-columns: 2fr 1fr;
	gap: 18px;
	align-items: start
}

.grid {
	display: grid;
	grid-template-columns: repeat(9, 1fr);
	gap: 8px;
	margin-top: 14px
}

.card {
	position: relative;
	background: linear-gradient(180deg, #0f1721, #0d141d);
	border: 1px solid #1e2a36;
	border-radius: var(--radius);
	overflow: hidden;
	box-shadow: var(--shadow);
	cursor: pointer;
	transition: transform .15s ease, box-shadow .2s ease
}

.card:hover {
	transform: translateY(-2px)
}

.card .thumb {
	aspect-ratio: 1/1;
	background: #0a0f15;
	display: grid;
	place-items: center
}

.card img {
	width: 100px;
	height: 100px;
	object-fit: contain;
	transform: scale(1.3)
}

.badge {
	position: absolute;
	top: 4px;
	left: 4px;
	background: var(--chip);
	border: 1px solid #233140;
	color: #d8e7f3;
	padding: 2px 6px;
	border-radius: 999px;
	font-size: 10px
}

.title {
	padding: 4px 6px;
	border-top: 1px solid #1e2a36;
	display: flex;
	justify-content: space-between;
	gap: 4px;
	align-items: center
}

.title h3 {
	margin: 0;
	font-size: 12px;
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis
}

.title .sub {
	color: var(--muted);
	font-size: 10px
}

/* Aside constrained to viewport height */
.panel {
	background: linear-gradient(180deg, #0e1720, #0c1219);
	border: 1px solid #1e2a36;
	border-radius: var(--radius);
	box-shadow: var(--shadow);
	padding: 12px;
	display: flex;
	flex-direction: column;
	overflow: hidden;
    height: 85vh;
}

.panel-scroll {
	overflow: auto;
	padding-right: 6px
}

.hero {
	display: grid;
	grid-template-columns: 88px 1fr;
	gap: 10px;
	align-items: center
}

.hero img {
	width: 88px;
	height: 88px;
	object-fit: contain;
	border-radius: 10px;
	border: 1px solid #1e2a36
}

.chips {
	display: flex;
	flex-wrap: wrap;
	gap: 6px
}

.chip {
	background: var(--chip);
	border: 1px solid #233140;
	color: #d8e7f3;
	padding: 4px 8px;
	border-radius: 999px;
	font-size: 12px
}

/* Two-column block */
.section2 {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 10px;
}

.section1 {
	background: #0e1720;
	border: 1px solid #1e2a36;
	border-radius: 12px;
	padding: 10px;
	overflow: hidden
}

.section {
	margin-top: 12px
}

.section h4 {
	margin: 0 0 6px;
	color: #b9d7e7;
	letter-spacing: .3px;
	font-size: 13px
}

.section-head {
	display: flex;
	justify-content: space-between;
	align-items: center
}

.toggle20 {
	display: flex;
	align-items: center;
	gap: 6px;
	font-size: 12px;
	color: #cfe7f5
}

.kv {}

.kv div {
	display: flex;
	justify-content: space-around;
	background: var(--chip-on);
	border: 1px solid #1e2a36;
	border-radius: 10px;
	padding: 6px 8px
}

.kv .k {
	width: 36%;
	color: #a9becc;
	font-size: 12px
}

.kv .v {
	width: 63%;
	font-weight: 600
}

.resists {
	padding: 5px;
	display: grid;
	grid-template-columns: repeat(7, 1fr);
	gap: 6px
}

.resists.elem {
	padding: 5px;
	grid-template-columns: repeat(6, 1fr)
}

.resists .r {
	background: var(--chip-on);
	border: 1px solid #1e2a36;
	border-radius: 10px;
	padding: 6px;
	text-align: center
}

.r .lab {
	font-size: 11px;
	color: #a9becc;
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 4px;
}

.r .val {
	font-weight: 700
}

.r[data-v="2x"] {
	outline: 2px solid var(--bad)
}

.r[data-v="1.5x"] {
	outline: 2px solid var(--warn)
}

.r[data-v="0.5x"] {
	outline: 2px solid #7fb7ff
}

.r[data-v="0x"] {
	outline: 2px solid var(--good)
}

.stats {}

.stat {
	background: var(--chip-on);
	border: 1px solid #1e2a36;
	border-radius: 10px;
	padding: 6px
}

.stat .row {
	display: flex;
	justify-content: space-between;
	font-size: 13px
}

.bar {
	height: 8px;
	background: #0a0f15;
	border: 1px solid #1e2a36;
	border-radius: 999px;
	overflow: hidden;
	margin-top: 6px
}

.bar>i {
	display: block;
	height: 100%;
	width: 0;
	background: linear-gradient(90deg, var(--brand), #8ef)
}

/* Evo grids with images (max 6 each + placeholders) */
.evo-wrap {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 10px
}

.evo-col {
	background: #0f141b;
	border: 1px solid #1e2a36;
	border-radius: 10px;
	padding: 8px
}

.evo-title {
	font-size: 12px;
	color: #a9becc;
	margin: 0 0 6px
}

.evo-grid {
	display: grid;
}

.evo-card,
.evo-slot {
	background: #0a0f15;
	border: 1px solid #1e2a36;
	border-radius: 10px;
	overflow: hidden;
	text-align: center;
	height: 125px;
}

.evo-slot img {
	width: 100%;
	height: 100%;
	object-fit: contain
}

.evo-card .img {
	width: 100%;
	display: flex;
	align-items: center;
	justify-content: center
}

.evo-card img {
	width: 100px;
	height: 100px;
	object-fit: contain
}

.evo-card .label {
	font-size: 11px;
	padding: 4px 4px;
	color: #d8e7f3;
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
	border-top: 1px solid #1e2a36
}

/* NEW: highlight states */
.card.needs-evo {
	outline: 2px solid var(--warn);
}

.card.collected {
	outline: 2px solid var(--good);
	filter: grayscale(100%);
}

.muted {
	color: var(--muted)
}

.empty {
	opacity: .7
}

footer {
	opacity: .6;
	text-align: center;
	padding: 30px 0
}

@media (max-width: 1400px) {
	.grid {
		grid-template-columns: repeat(7, 1fr);
	}
}

@media (max-width: 1000px) {
	.grid {
		grid-template-columns: repeat(5, 1fr);
	}

	main {
		grid-template-columns: 1fr
	}

	.panel {
		position: static;
		max-height: none
	}
}

.toggle {
	border: 1px solid #1e2a36;
	background: var(--panel);
	border-radius: 999px;
	padding: 6px 12px;
	cursor: pointer;
	transition: background 0.2s, color 0.2s;
}

.toggle.active {
	background: var(--brand);
	color: #000;
	font-weight: 600;
}

.evo-grid .collected img {
	filter: grayscale(100%) brightness(0.8);
	border: 2px solid #4caf50;
	border-radius: 10px;
}

/* Icon button + screen-reader text */
.icon-btn {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	padding: 8px 10px;
	border: 1px solid rgba(255, 255, 255, .15);
	background: transparent;
	color: inherit;
	border-radius: 8px;
	cursor: pointer;
}

.icon-btn:hover {
	background: rgba(255, 255, 255, .06);
}

.sr-only {
	position: absolute;
	left: -9999px;
	width: 1px;
	height: 1px;
	overflow: hidden;
}

/* Modal */
.modal {
	position: fixed;
	inset: 0;
	display: none;
}

.modal[open] {
	display: block;
}

.modal-backdrop {
	position: absolute;
	inset: 0;
	background: rgba(0, 0, 0, .5);
	backdrop-filter: blur(2px);
}

.modal-dialog {
	position: absolute;
	inset: 0;
	margin: auto;
	max-width: 1100px;
	width: calc(100% - 32px);
	max-height: 80vh;
	overflow: auto;
	background: #111;
	color: #fff;
	border: 1px solid rgba(255, 255, 255, .15);
	border-radius: 12px;
	box-shadow: 0 10px 30px rgba(0, 0, 0, .5);
	padding: 18px 20px;
}

.modal-title {
	margin: 0 0 8px;
	font-size: 18px;
}

.modal-body {
	font-size: 14px;
	line-height: 1.5;
}

.modal-body ul {
	margin: 8px 0 0 18px;
}

.modal-body li {
	margin: 6px 0;
}

.modal-close {
	position: absolute;
	top: 6px;
	right: 8px;
	font-size: 24px;
	line-height: 1;
	background: none;
	border: 0;
	color: inherit;
	cursor: pointer;
}

@media (prefers-color-scheme: light) {
	.modal-dialog {
		background: #fff;
		color: #111;
		border-color: rgba(0, 0, 0, .12);
	}
}
