:root {
  --layout-max: 1920px;
  --bg: #0b1028;
  --bg-soft: #18204f;
  --panel: #26326f;
  --ink: #f3f7ff;
  --ink-soft: #c9d8ff;
  --ink-dim: #9caedc;
  --accent-a: #7aa7ff;
  --accent-b: #a97bff;
  --accent-c: #9cd5ff;
  --line: rgba(138, 165, 247, 0.42);
  --line-soft: rgba(120, 145, 228, 0.32);
}

* {
  box-sizing: border-box;
}

html,
body {
  margin: 0;
  min-height: 100%;
}

body {
  font-family: "Sora", sans-serif;
  color: var(--ink);
  background:
    radial-gradient(circle at 12% 12%, color-mix(in srgb, var(--accent-b) 24%, transparent), transparent 36%),
    radial-gradient(circle at 88% 8%, color-mix(in srgb, var(--accent-a) 22%, transparent), transparent 34%),
    linear-gradient(150deg, #060816, var(--bg) 46%, #0f1435 100%);
  padding: 0.92rem;
  text-rendering: optimizeLegibility;
}

.page-shell {
  width: min(100%, calc(var(--layout-max) + 88px));
  max-width: calc(var(--layout-max) + 88px);
  margin: 0 auto;
  display: grid;
  grid-template-columns: 64px minmax(0, 1fr);
  gap: 0.72rem;
  align-items: start;
}

.page-main {
  min-width: 0;
}

.game-icon-rail {
  position: sticky;
  top: 0.66rem;
  border: 1px solid var(--line);
  border-radius: 0.92rem;
  background: linear-gradient(148deg, color-mix(in srgb, var(--bg-soft) 86%, #172056), color-mix(in srgb, var(--panel) 66%, #1d2a63));
  box-shadow: inset 0 1px 0 rgba(210, 234, 255, 0.12), 0 14px 30px rgba(5, 8, 22, 0.34);
  padding: 0.38rem;
  display: grid;
  gap: 0.34rem;
  z-index: 35;
}

.game-icon-btn {
  width: 100%;
  aspect-ratio: 1 / 1;
  border-radius: 0.68rem;
  border: 1px solid rgba(112, 138, 223, 0.58);
  background: rgba(27, 41, 96, 0.62);
  color: #e8f5ff;
  text-decoration: none;
  display: grid;
  place-items: center;
}

.game-icon-btn .material-symbols-outlined {
  font-size: 1.25rem;
}

.game-icon-btn.active {
  border-color: color-mix(in srgb, var(--accent-c) 72%, transparent);
  background: linear-gradient(132deg, color-mix(in srgb, var(--accent-a) 35%, transparent), color-mix(in srgb, var(--accent-b) 28%, transparent));
  box-shadow: inset 0 0 0 1px rgba(204, 236, 255, 0.42);
}

.game-icon-btn.inactive {
  opacity: 0.62;
}

.game-icon-btn[aria-disabled="true"] {
  pointer-events: none;
}

.scene-glow {
  position: fixed;
  width: 34vw;
  height: 34vw;
  max-width: 420px;
  max-height: 420px;
  border-radius: 50%;
  filter: blur(28px);
  pointer-events: none;
  z-index: -1;
}

.scene-glow-left {
  left: -12vw;
  top: 32vh;
  background: color-mix(in srgb, var(--accent-b) 24%, transparent);
}

.scene-glow-right {
  right: -10vw;
  top: 6vh;
  background: color-mix(in srgb, var(--accent-a) 22%, transparent);
}

.material-symbols-outlined {
  font-size: 1rem;
  line-height: 1;
  vertical-align: middle;
}

h1,
h2,
h3,
h4 {
  margin: 0;
  font-family: "Space Grotesk", sans-serif;
}

p {
  margin: 0;
}

.top-navbar,
.panel,
.hub-layout {
  width: min(100%, var(--layout-max));
  max-width: var(--layout-max);
  margin-left: auto;
  margin-right: auto;
}

.top-navbar {
  border: 1px solid var(--line);
  border-radius: 1rem;
  background:
    radial-gradient(circle at 15% 12%, color-mix(in srgb, var(--accent-b) 20%, transparent), transparent 44%),
    radial-gradient(circle at 85% 12%, color-mix(in srgb, var(--accent-a) 19%, transparent), transparent 44%),
    linear-gradient(130deg, color-mix(in srgb, var(--bg-soft) 84%, #1a2254), color-mix(in srgb, var(--panel) 70%, #1d2a64));
  box-shadow: inset 0 1px 0 rgba(220, 238, 255, 0.16), 0 16px 36px rgba(4, 7, 20, 0.42);
  padding: 0.68rem 0.86rem;
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: 0.72rem;
  position: sticky;
  top: 0.6rem;
  z-index: 30;
}

.brand-link {
  text-decoration: none;
  color: #f4fbff;
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
}

.brand-link .material-symbols-outlined {
  font-size: 1.12rem;
  border-radius: 0.54rem;
  border: 1px solid color-mix(in srgb, var(--accent-c) 62%, transparent);
  background: color-mix(in srgb, var(--accent-a) 26%, transparent);
  padding: 0.2rem;
}

.brand-link strong {
  display: block;
  line-height: 1.1;
  font-size: 0.92rem;
}

.brand-link small {
  display: block;
  margin-top: 0.04rem;
  color: #d2e3ff;
  font-size: 0.68rem;
  letter-spacing: 0.07em;
  text-transform: uppercase;
}

.top-nav-tabs {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  gap: 0.38rem;
}

.nav-tab {
  border: 1px solid rgba(128, 152, 231, 0.52);
  border-radius: 999px;
  background: rgba(30, 47, 114, 0.48);
  color: #ebf3ff;
  padding: 0.36rem 0.74rem;
  cursor: pointer;
  font-family: inherit;
  font-size: 0.74rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

.nav-tab.active {
  border-color: color-mix(in srgb, var(--accent-c) 72%, #d5f1ff);
  background: linear-gradient(122deg, color-mix(in srgb, var(--accent-a) 30%, transparent), color-mix(in srgb, var(--accent-b) 24%, transparent));
  box-shadow: inset 0 0 0 1px rgba(203, 236, 255, 0.42);
}

.patch-wrap {
  display: flex;
  justify-content: flex-end;
}

.patch-pill {
  border-radius: 999px;
  border: 1px solid color-mix(in srgb, var(--accent-c) 66%, transparent);
  background: color-mix(in srgb, var(--accent-a) 22%, transparent);
  color: #eef9ff;
  padding: 0.26rem 0.62rem;
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.07em;
  text-transform: uppercase;
}

.panel {
  border: 1px solid var(--line-soft);
  border-radius: 1rem;
  background: linear-gradient(160deg, color-mix(in srgb, var(--panel) 82%, #20307a), color-mix(in srgb, var(--bg-soft) 78%, #17245f));
  box-shadow: inset 0 1px 0 rgba(204, 229, 255, 0.12), 0 14px 32px rgba(5, 9, 25, 0.36);
  padding: 0.9rem;
  margin-top: 0.76rem;
}

.hero-panel {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(290px, 440px);
  gap: 0.84rem;
  align-items: start;
}

.eyebrow {
  text-transform: uppercase;
  letter-spacing: 0.12em;
  font-size: 0.72rem;
  color: var(--ink-soft);
}

h1 {
  margin-top: 0.24rem;
  font-size: clamp(1.72rem, 4.2vw, 2.7rem);
}

.intro {
  margin-top: 0.44rem;
  color: var(--ink-soft);
  line-height: 1.58;
  font-size: 0.92rem;
  max-width: 76ch;
}

.current-game-chip {
  margin-top: 0.5rem;
  display: inline-flex;
  align-items: center;
  gap: 0.26rem;
  border-radius: 999px;
  border: 1px solid color-mix(in srgb, var(--accent-c) 64%, transparent);
  background: color-mix(in srgb, var(--accent-a) 24%, transparent);
  color: #ecf6ff;
  font-weight: 700;
  letter-spacing: 0.04em;
  font-size: 0.72rem;
  text-transform: uppercase;
  padding: 0.24rem 0.56rem;
}

.hero-snapshot {
  border: 1px solid rgba(118, 142, 222, 0.52);
  border-radius: 0.84rem;
  background: rgba(22, 33, 85, 0.54);
  padding: 0.62rem;
}

.snapshot-name {
  font-size: 1.02rem;
  font-weight: 700;
}

.snapshot-subtitle {
  margin-top: 0.24rem;
  color: var(--ink-soft);
  line-height: 1.5;
  font-size: 0.86rem;
}

.snapshot-stats {
  margin-top: 0.58rem;
  display: grid;
  gap: 0.42rem;
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.snapshot-stats article {
  border: 1px solid rgba(112, 137, 223, 0.6);
  border-radius: 0.66rem;
  background: linear-gradient(165deg, color-mix(in srgb, var(--panel) 70%, #2a3a8c), color-mix(in srgb, var(--bg-soft) 72%, #223579));
  padding: 0.46rem;
}

.snapshot-stats p {
  color: var(--ink-dim);
  font-size: 0.72rem;
}

.snapshot-stats strong {
  font-size: 0.98rem;
}

.status-line {
  margin-top: 0.52rem;
  color: var(--ink-soft);
  font-size: 0.82rem;
}

.subbar-panel {
  margin-top: 0.7rem;
}

.sub-nav {
  display: grid;
  gap: 0.42rem;
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.tab-btn {
  border: 1px solid rgba(127, 151, 231, 0.52);
  border-radius: 0.72rem;
  background: linear-gradient(155deg, color-mix(in srgb, var(--panel) 74%, #20347e), color-mix(in srgb, var(--bg-soft) 72%, #1a2d75));
  color: #edf4ff;
  padding: 0.54rem 0.58rem;
  cursor: pointer;
  font-family: inherit;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.3rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  font-size: 0.76rem;
  font-weight: 700;
}

.tab-btn.active {
  border-color: color-mix(in srgb, var(--accent-c) 74%, #c6ebff);
  box-shadow: inset 0 0 0 1px rgba(190, 236, 255, 0.46);
  background: linear-gradient(145deg, color-mix(in srgb, var(--accent-a) 30%, var(--panel)), color-mix(in srgb, var(--accent-b) 26%, var(--bg-soft)));
}

.hub-layout {
  display: grid;
  gap: 0.72rem;
  grid-template-columns: minmax(0, 1fr);
}

.content-panel {
  min-height: 600px;
}

.panel-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.55rem;
  margin-bottom: 0.62rem;
}

.planner-head-meta {
  display: inline-flex;
  align-items: center;
  gap: 0.52rem;
}

.planner-mini-link {
  display: inline-flex;
  align-items: center;
  gap: 0.24rem;
  text-decoration: none;
  color: #eef7ff;
  border: 1px solid rgba(157, 197, 255, 0.6);
  border-radius: 999px;
  background: linear-gradient(112deg, rgba(83, 108, 213, 0.86), rgba(77, 166, 255, 0.86));
  padding: 0.34rem 0.58rem;
  font-size: 0.74rem;
  font-weight: 700;
  letter-spacing: 0.04em;
}

.planner-mini-link .material-symbols-outlined {
  font-size: 0.9rem;
}

.panel h2 {
  font-size: 1.05rem;
  display: inline-flex;
  align-items: center;
  gap: 0.32rem;
}

.panel-controls {
  display: flex;
  gap: 0.45rem;
  align-items: end;
}

label {
  display: grid;
  gap: 0.22rem;
  font-size: 0.74rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--ink-soft);
}

input,
select {
  border: 1px solid rgba(106, 129, 211, 0.65);
  border-radius: 0.62rem;
  background: linear-gradient(155deg, color-mix(in srgb, var(--panel) 82%, #22327d), color-mix(in srgb, var(--bg-soft) 82%, #1c2c6f));
  color: #eef5ff;
  padding: 0.52rem 0.6rem;
  font-family: inherit;
}

input:focus,
select:focus {
  outline: 2px solid color-mix(in srgb, var(--accent-a) 52%, transparent);
  border-color: var(--accent-a);
}

.guide-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: 0.72rem;
}

.guide-grid {
  display: grid;
  gap: 0.48rem;
  grid-template-columns: repeat(auto-fill, minmax(190px, 1fr));
  align-content: start;
}

.guide-card {
  position: relative;
  border: 1px solid rgba(107, 130, 212, 0.62);
  border-radius: 0.72rem;
  padding: 0.46rem;
  background: linear-gradient(160deg, color-mix(in srgb, var(--panel) 78%, #2d3f93), color-mix(in srgb, var(--bg-soft) 76%, #243483));
  text-decoration: none;
  color: inherit;
}

.guide-card.selected {
  border-color: color-mix(in srgb, var(--accent-c) 78%, #d2f2ff);
  box-shadow: inset 0 0 0 1px rgba(188, 233, 255, 0.48);
}

.guide-card-indicator {
  position: absolute;
  top: 0.38rem;
  right: 0.38rem;
  width: 0.56rem;
  height: 0.56rem;
  border-radius: 999px;
  background: var(--unit-accent, var(--accent-c));
  box-shadow: 0 0 0 2px rgba(12, 18, 47, 0.7);
}

.guide-card.base-form {
  background: linear-gradient(160deg, color-mix(in srgb, var(--panel) 78%, #2d3f93), color-mix(in srgb, var(--accent-a) 16%, #243483));
}

.guide-card.alt-form {
  background: linear-gradient(160deg, color-mix(in srgb, var(--panel) 78%, #2d3f93), color-mix(in srgb, var(--accent-b) 22%, #243483));
}

.guide-card img {
  width: 100%;
  aspect-ratio: 1 / 1;
  object-fit: cover;
  border-radius: 0.56rem;
  border: 1px solid rgba(146, 173, 255, 0.66);
  background: rgba(22, 34, 86, 0.76);
}

.guide-card.rarity-5 img {
  border-color: rgba(255, 215, 122, 0.92);
  background: linear-gradient(150deg, rgba(94, 66, 26, 0.86), rgba(203, 149, 52, 0.78));
}

.guide-card.rarity-4 img {
  border-color: rgba(207, 162, 255, 0.92);
  background: linear-gradient(150deg, rgba(68, 42, 116, 0.86), rgba(144, 89, 222, 0.78));
}

.guide-card strong {
  display: block;
  margin-top: 0.34rem;
  font-size: 0.87rem;
  color: #f4f8ff;
}

.guide-card small {
  display: block;
  margin-top: 0.1rem;
  color: #deebff;
  font-size: 0.72rem;
}

.guide-form-badge {
  display: inline-flex;
  margin-top: 0.24rem;
  border: 1px solid rgba(150, 176, 249, 0.54);
  border-radius: 999px;
  background: rgba(28, 43, 104, 0.64);
  color: #e9f4ff;
  font-size: 0.64rem;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  padding: 0.14rem 0.42rem;
}

.guide-detail {
  display: none;
}

.guide-detail-splash {
  width: 100%;
  border-radius: 0.66rem;
  border: 1px solid rgba(140, 168, 250, 0.6);
  max-height: 176px;
  object-fit: cover;
}

.guide-detail-head {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: 0.5rem;
  margin-top: 0.5rem;
  align-items: center;
}

.guide-detail-icon {
  width: 3rem;
  height: 3rem;
  border-radius: 0.66rem;
  border: 1px solid rgba(150, 182, 255, 0.72);
  object-fit: cover;
}

#guideDetailMeta {
  margin-top: 0.14rem;
  color: #d4e4ff;
  font-size: 0.78rem;
}

.guide-detail-updated {
  margin-top: 0.12rem;
  color: #b8cbf7;
  font-size: 0.68rem;
  letter-spacing: 0.05em;
  text-transform: uppercase;
}

.guide-detail-description {
  margin-top: 0.44rem;
  line-height: 1.56;
  color: #e6efff;
  font-size: 0.91rem;
}

.build-slots {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.34rem;
}

.build-slot {
  border: 1px solid rgba(116, 142, 227, 0.55);
  border-radius: 0.56rem;
  background: rgba(24, 37, 93, 0.58);
  padding: 0.38rem;
}

.build-slot p {
  display: inline-flex;
  align-items: center;
  gap: 0.22rem;
  color: #b7cdf6;
  font-size: 0.64rem;
  letter-spacing: 0.07em;
  text-transform: uppercase;
}

.slot-icon-img {
  width: 0.92rem;
  height: 0.92rem;
  display: inline-block;
  flex-shrink: 0;
}

.build-slot strong {
  margin-top: 0.12rem;
  display: block;
  color: #f3f9ff;
  font-size: 0.74rem;
  line-height: 1.32;
}

.guide-detail h4 {
  margin-top: 0.52rem;
  margin-bottom: 0.26rem;
  font-size: 0.78rem;
  color: var(--accent-c);
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.guide-detail h5 {
  margin: 0 0 0.24rem;
  font-size: 0.7rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: #cae0ff;
}

.gear-grid {
  display: grid;
  gap: 0.38rem;
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.gear-grid section {
  border: 1px solid rgba(111, 137, 222, 0.5);
  border-radius: 0.58rem;
  background: rgba(20, 31, 82, 0.56);
  padding: 0.34rem;
}

.gear-list {
  gap: 0.22rem;
}

.gear-item {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: 0.32rem;
  align-items: center;
}

.gear-item img {
  width: 1.12rem;
  height: 1.12rem;
  border-radius: 0.34rem;
  border: 1px solid rgba(133, 161, 244, 0.68);
  object-fit: cover;
}

.gear-item span {
  font-size: 0.75rem;
  line-height: 1.35;
}

.detail-list {
  margin: 0;
  padding: 0;
  list-style: none;
  display: grid;
  gap: 0.24rem;
}

.detail-list li {
  font-size: 0.84rem;
  color: #dfebff;
  line-height: 1.4;
}

.tag-row {
  display: flex;
  gap: 0.3rem;
  flex-wrap: wrap;
}

.pros-cons-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.44rem;
}

.guide-source-row {
  margin-top: 0.4rem;
  display: flex;
  flex-wrap: wrap;
  gap: 0.42rem;
}

.guide-source-link {
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  border: 1px solid rgba(154, 188, 250, 0.66);
  border-radius: 999px;
  background: color-mix(in srgb, var(--accent-a) 26%, transparent);
  color: #edf7ff;
  font-size: 0.73rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  padding: 0.24rem 0.56rem;
}

.tag {
  border: 1px solid color-mix(in srgb, var(--accent-a) 52%, transparent);
  background: color-mix(in srgb, var(--accent-a) 26%, transparent);
  color: #e8f6ff;
  border-radius: 999px;
  padding: 0.18rem 0.48rem;
  font-size: 0.66rem;
  text-transform: uppercase;
  letter-spacing: 0.06em;
}

.empty-state {
  border: 1px dashed rgba(122, 146, 231, 0.62);
  border-radius: 0.72rem;
  background: rgba(16, 24, 63, 0.48);
  color: #cfe0ff;
  padding: 0.72rem;
  font-size: 0.86rem;
}

.hidden {
  display: none;
}

.tier-patch {
  color: var(--ink-soft);
  font-size: 0.8rem;
}

.tier-board {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 0.58rem;
}

.tier-column {
  border: 1px solid rgba(106, 130, 212, 0.6);
  border-radius: 0.74rem;
  background: linear-gradient(160deg, color-mix(in srgb, var(--panel) 72%, #2f438f), color-mix(in srgb, var(--bg-soft) 72%, #22357f));
  padding: 0.5rem;
  display: grid;
  gap: 0.35rem;
}

.tier-column h3 {
  font-size: 0.92rem;
  color: var(--accent-c);
}

.tier-item {
  border: 1px solid rgba(126, 149, 230, 0.58);
  border-radius: 0.62rem;
  background: rgba(24, 35, 88, 0.62);
  padding: 0.42rem;
  display: grid;
  gap: 0.18rem;
}

.tier-item-head {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: 0.4rem;
  align-items: center;
}

.tier-item-head img {
  width: 2rem;
  height: 2rem;
  border-radius: 0.5rem;
  border: 1px solid rgba(140, 168, 252, 0.66);
  object-fit: cover;
}

.tier-item strong {
  font-size: 0.84rem;
}

.tier-item small {
  color: var(--ink-dim);
  font-size: 0.7rem;
}

.tier-item p {
  color: #d8e7ff;
  font-size: 0.78rem;
  line-height: 1.48;
}

.tier-icon-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0.42rem;
}

.tier-icon-item {
  border: 1px solid rgba(126, 149, 230, 0.58);
  border-radius: 0.6rem;
  background: rgba(24, 35, 88, 0.64);
  padding: 0.35rem;
  display: grid;
  gap: 0.2rem;
  cursor: pointer;
  color: #e7f1ff;
  font-family: inherit;
  font-weight: 600;
  transition: transform 0.16s ease, border-color 0.16s ease;
}

.tier-icon-item:hover {
  transform: translateY(-1px);
  border-color: rgba(158, 184, 255, 0.85);
}

.tier-icon-item img {
  width: 100%;
  aspect-ratio: 1 / 1;
  object-fit: cover;
  border-radius: 0.5rem;
  border: 1px solid rgba(140, 168, 252, 0.72);
}

.tier-icon-item small {
  font-size: 0.68rem;
  line-height: 1.2;
  text-align: center;
}

.tier-limit-note {
  color: var(--ink-dim);
  font-size: 0.72rem;
  margin-top: 0.12rem;
}

.planner-shell {
  display: grid;
  gap: 0.95rem;
}

.btn {
  border: 0;
  border-radius: 0.64rem;
  background: linear-gradient(112deg, var(--accent-b), var(--accent-a));
  color: #fff;
  font-family: inherit;
  font-weight: 700;
  padding: 0.56rem 0.72rem;
  cursor: pointer;
}

.btn.small {
  padding: 0.48rem 0.68rem;
  font-size: 0.84rem;
}

.btn.alt {
  background: linear-gradient(112deg, #2f9fff, #5dd1ff);
}

.btn.google-btn {
  background: linear-gradient(110deg, #ffffff, #dfe9ff);
  color: #24377d;
  border: 1px solid rgba(140, 168, 252, 0.64);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.28rem;
}

.btn.ghost {
  background: linear-gradient(112deg, rgba(95, 118, 212, 0.5), rgba(78, 98, 186, 0.5));
  border: 1px solid rgba(151, 186, 255, 0.52);
}

.planner-grid {
  max-width: 1400px;
  width: 100%;
  margin: 0;
  display: grid;
  gap: 0.95rem;
  grid-template-columns: minmax(0, 390px) minmax(0, 1fr);
  grid-template-areas:
    "auth add"
    "plans snapshot";
  align-items: start;
}

.planner-card {
  border: 1px solid rgba(114, 135, 219, 0.42);
  border-radius: 1rem;
  background: linear-gradient(165deg, rgba(25, 36, 93, 0.95), rgba(18, 29, 76, 0.95));
  box-shadow: inset 0 1px 0 rgba(205, 232, 255, 0.12), 0 14px 30px rgba(5, 10, 28, 0.28);
  padding: 0.95rem;
  display: grid;
  gap: 0.6rem;
}

.planner-auth-card {
  grid-area: auth;
  align-content: start;
}

.planner-auth-state {
  color: #dbe7ff;
  font-size: 0.88rem;
  line-height: 1.45;
}

.planner-auth-actions {
  display: grid;
  gap: 0.72rem;
}

.planner-auth-form {
  display: grid;
  gap: 0.42rem;
  border: 1px solid rgba(97, 120, 212, 0.62);
  border-radius: 0.8rem;
  padding: 0.62rem;
  background: linear-gradient(170deg, rgba(35, 48, 119, 0.72), rgba(29, 40, 102, 0.72));
}

.planner-card h2 {
  font-size: 1.02rem;
  display: inline-flex;
  align-items: center;
  gap: 0.32rem;
  margin: 0;
}

.planner-card h3 {
  font-size: 0.96rem;
  margin: 0;
}

.selected-line {
  border-radius: 0.64rem;
  border: 1px solid rgba(109, 133, 221, 0.62);
  background: rgba(28, 40, 104, 0.58);
  color: #dce8ff;
  padding: 0.5rem 0.55rem;
  font-size: 0.82rem;
}

.planner-add-card {
  grid-area: add;
  align-content: start;
}

.planner-add-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.72rem;
}

.planner-add-form {
  border: 1px solid rgba(99, 123, 214, 0.65);
  border-radius: 0.86rem;
  background: linear-gradient(165deg, rgba(36, 49, 122, 0.76), rgba(27, 38, 97, 0.76));
  padding: 0.7rem;
  display: grid;
  gap: 0.45rem;
}

.planner-lightcone-grid {
  border: 1px solid rgba(93, 116, 205, 0.62);
  border-radius: 0.72rem;
  background: rgba(19, 30, 78, 0.55);
  padding: 0.46rem;
  min-height: 4rem;
}

.planner-unit-grid {
  border: 1px solid rgba(93, 116, 205, 0.62);
  border-radius: 0.72rem;
  background: rgba(19, 30, 78, 0.55);
  padding: 0.46rem;
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(155px, 1fr));
  gap: 0.42rem;
  max-height: 16rem;
  overflow: auto;
}

.planner-unit-card {
  border: 1px solid rgba(100, 123, 214, 0.62);
  border-radius: 0.62rem;
  background: linear-gradient(160deg, rgba(39, 53, 128, 0.8), rgba(29, 42, 103, 0.8));
  color: #edf3ff;
  font-family: inherit;
  padding: 0.42rem;
  text-align: left;
  display: flex;
  align-items: center;
  gap: 0.42rem;
  cursor: pointer;
}

.planner-unit-card.rarity-5 {
  border-color: rgba(255, 215, 122, 0.62);
  background: linear-gradient(160deg, rgba(111, 77, 31, 0.72), rgba(67, 48, 17, 0.8));
}

.planner-unit-card.rarity-4 {
  border-color: rgba(206, 160, 255, 0.62);
  background: linear-gradient(160deg, rgba(78, 50, 132, 0.74), rgba(46, 33, 89, 0.82));
}

.planner-unit-card.selected {
  border-color: rgba(150, 212, 255, 0.9);
  box-shadow: inset 0 0 0 1px rgba(176, 227, 255, 0.6);
  background: linear-gradient(152deg, rgba(68, 84, 188, 0.95), rgba(44, 66, 154, 0.92));
}

.planner-unit-icon {
  width: 2.08rem;
  height: 2.08rem;
  border-radius: 0.52rem;
  border: 1px solid rgba(145, 180, 255, 0.7);
  object-fit: cover;
  flex-shrink: 0;
}

.planner-unit-text {
  display: grid;
  gap: 0.13rem;
  min-width: 0;
}

.planner-unit-text strong {
  font-size: 0.78rem;
  line-height: 1.2;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.planner-unit-text small {
  font-size: 0.66rem;
  color: #c6d6ff;
  text-transform: uppercase;
  letter-spacing: 0.06em;
}

.planner-control-split {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.48rem;
}

.planner-add-card .btn {
  margin-top: 0.12rem;
}

.planner-plans-card {
  grid-area: plans;
  align-content: start;
}

.plan-list {
  display: grid;
  gap: 0.52rem;
}

.plan-chip {
  border: 1px solid rgba(101, 126, 219, 0.7);
  border-radius: 0.8rem;
  background: linear-gradient(160deg, rgba(41, 55, 133, 0.84), rgba(30, 43, 108, 0.84));
  padding: 0.6rem;
  display: grid;
  gap: 0.34rem;
  cursor: pointer;
}

.plan-chip.snapshot-selected {
  border-color: rgba(180, 226, 255, 0.95);
  box-shadow: inset 0 0 0 1px rgba(183, 230, 255, 0.54);
}

.plan-chip.paused {
  opacity: 0.68;
}

.plan-chip-head {
  display: flex;
  justify-content: space-between;
  gap: 0.5rem;
  align-items: center;
}

.plan-chip-head-left {
  display: inline-flex;
  align-items: center;
  gap: 0.42rem;
  min-width: 0;
}

.plan-chip-icon {
  width: 1.75rem;
  height: 1.75rem;
  border-radius: 0.52rem;
  border: 1px solid rgba(145, 181, 255, 0.72);
  object-fit: cover;
  flex-shrink: 0;
}

.plan-chip-icon-fallback {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 1rem;
  color: #e9f4ff;
  background: linear-gradient(140deg, rgba(71, 95, 188, 0.86), rgba(55, 74, 152, 0.86));
}

.plan-name {
  font-size: 0.9rem;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.plan-type,
.plan-level {
  color: #c5d1ff;
  font-size: 0.8rem;
  line-height: 1.4;
}

.remove-plan {
  border: 0;
  border-radius: 999px;
  width: 1.5rem;
  height: 1.5rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  color: #fff;
  background: linear-gradient(120deg, #ff5ea5, #de4385);
}

.plan-selector-label {
  display: grid;
  gap: 0.23rem;
  font-size: 0.66rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: #bac9ff;
}

.plan-selector {
  border: 1px solid rgba(88, 111, 198, 0.82);
  border-radius: 0.52rem;
  background: #232f74;
  color: #f3f6ff;
  padding: 0.42rem 0.46rem;
}

.planner-snapshot-card {
  grid-area: snapshot;
  display: grid;
  align-content: start;
  gap: 0.72rem;
}

.snapshot-selector-label {
  display: grid;
  gap: 0.24rem;
  font-size: 0.7rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: #c8d7ff;
}

.planner-snapshot-focus {
  border: 1px solid rgba(118, 144, 230, 0.66);
  border-radius: 0.88rem;
  background: linear-gradient(160deg, rgba(38, 54, 130, 0.78), rgba(27, 40, 102, 0.78));
  padding: 0.58rem 0.64rem;
  display: flex;
  align-items: center;
  gap: 0.58rem;
}

.planner-snapshot-icon {
  width: 3rem;
  height: 3rem;
  border-radius: 0.65rem;
  border: 1px solid rgba(165, 201, 255, 0.74);
  object-fit: cover;
  flex-shrink: 0;
}

.planner-snapshot-text {
  min-width: 0;
  display: grid;
  gap: 0.18rem;
}

.planner-snapshot-text strong {
  font-size: 1rem;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.planner-snapshot-text small {
  color: #c6d7ff;
  font-size: 0.74rem;
  text-transform: uppercase;
  letter-spacing: 0.07em;
}

.planner-total-stats {
  margin-top: 0;
}

.materials-wrap {
  border: 1px solid rgba(106, 130, 212, 0.52);
  border-radius: 0.74rem;
  overflow: auto;
}

.planner-materials-wrap {
  max-height: 740px;
  background: rgba(20, 29, 75, 0.72);
}

table {
  width: 100%;
  border-collapse: collapse;
  min-width: 650px;
}

th,
td {
  padding: 0.53rem 0.62rem;
  border-bottom: 1px solid rgba(90, 112, 197, 0.4);
  text-align: left;
  font-size: 0.84rem;
}

th {
  color: var(--ink-soft);
  font-size: 0.7rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  border-bottom: 1px solid rgba(105, 129, 216, 0.65);
}

.material-name {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: 0.38rem;
  align-items: center;
}

.material-name > div {
  min-width: 0;
  display: grid;
  gap: 0.12rem;
}

.material-name span {
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.material-name img {
  width: 1.65rem;
  height: 1.65rem;
  border-radius: 0.44rem;
  border: 1px solid rgba(136, 164, 248, 0.65);
  object-fit: cover;
}

.material-meta {
  color: #afc0f3;
  font-size: 0.66rem;
  text-transform: uppercase;
  letter-spacing: 0.07em;
}

.owned-input {
  width: 86px;
  padding: 0.32rem 0.45rem;
}

.missing-good {
  color: #8ef2bb;
}

.missing-bad {
  color: #ffb7d6;
}

.maps-shell {
  display: grid;
  gap: 0.66rem;
}

.maps-frame {
  width: 100%;
  min-height: 540px;
  border: 1px solid rgba(104, 128, 212, 0.62);
  border-radius: 0.82rem;
  background: #0a0f29;
}

.maps-meta {
  border: 1px solid rgba(103, 128, 212, 0.52);
  border-radius: 0.76rem;
  background: rgba(20, 30, 76, 0.58);
  padding: 0.62rem;
  display: grid;
  gap: 0.36rem;
}

.maps-meta h3 {
  font-size: 0.93rem;
}

.maps-meta p {
  color: var(--ink-soft);
  font-size: 0.86rem;
}

.maps-world-list {
  display: grid;
  gap: 0.32rem;
}

.world-card {
  border: 1px solid rgba(108, 132, 217, 0.55);
  border-radius: 0.64rem;
  background: rgba(27, 39, 96, 0.68);
  padding: 0.42rem;
}

.world-card strong {
  font-size: 0.8rem;
}

.world-card p {
  margin-top: 0.12rem;
  font-size: 0.79rem;
}

.maps-tips {
  display: grid;
  gap: 0.24rem;
}

.tip {
  font-size: 0.82rem;
  color: #d5e5ff;
}

@media (max-width: 1120px) {
  .hero-panel {
    grid-template-columns: minmax(0, 1fr);
  }

  .planner-grid {
    grid-template-columns: minmax(0, 1fr);
    grid-template-areas:
      "auth"
      "add"
      "plans"
      "snapshot";
  }

  .planner-add-grid {
    grid-template-columns: minmax(0, 1fr);
  }

  .guide-layout {
    grid-template-columns: minmax(0, 1fr);
  }

  .pros-cons-grid {
    grid-template-columns: minmax(0, 1fr);
  }

  .gear-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 860px) {
  body {
    padding: 0.7rem;
  }

  .page-shell {
    grid-template-columns: minmax(0, 1fr);
    gap: 0.56rem;
  }

  .game-icon-rail {
    position: static;
    display: flex;
    gap: 0.34rem;
    overflow-x: auto;
    padding: 0.34rem;
  }

  .game-icon-btn {
    width: 2.5rem;
    min-width: 2.5rem;
    aspect-ratio: 1 / 1;
  }

  .top-navbar {
    grid-template-columns: 1fr;
    gap: 0.58rem;
    top: 0.45rem;
  }

  .top-nav-tabs {
    justify-content: flex-start;
  }

  .patch-wrap {
    justify-content: flex-start;
  }

  .sub-nav {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .panel-head {
    flex-direction: column;
    align-items: flex-start;
  }

  .panel-controls {
    width: 100%;
    flex-direction: column;
    align-items: stretch;
  }

  .planner-grid {
    grid-template-columns: minmax(0, 1fr);
  }

  .planner-control-split {
    grid-template-columns: minmax(0, 1fr);
  }

  .planner-add-grid {
    grid-template-columns: minmax(0, 1fr);
  }

  .gear-grid {
    grid-template-columns: minmax(0, 1fr);
  }

  .maps-frame {
    min-height: 380px;
  }
}
