/**
 * V2 shell — `design/menu.html` (Tailwind extend + inline nav styles) is the source for the
 * drawer, profile strip inside it, and `.v2-nav` (colors, borders, scrollbar thumb, type).
 * `--v2-menu-*` mirrors those literals. Remaining `--v2-*` tokens cover app bar / main until
 * aligned to the same mock. No stich.css; do not use stitch_viqtorina design packs as reference.
 */

:root {
  --v2-surface: #f8f9fa;
  --v2-surface-dim: #d9dadb;
  --v2-surface-container-lowest: #ffffff;
  --v2-surface-container-low: #f3f4f5;
  --v2-surface-container: #edeeef;
  --v2-surface-variant: #e1e3e4;
  --v2-on-surface: #191c1d;
  --v2-on-surface-variant: #424753;
  --v2-outline: #727784;
  --v2-outline-variant: #c2c6d5;
  --v2-primary: #004492;
  --v2-on-primary: #ffffff;
  --v2-primary-container: #005bbf;
  --v2-on-primary-container: #c8d8ff;
  --v2-primary-fixed: #d7e2ff;
  --v2-secondary-container: #dbe3f1;
  --v2-on-secondary-container: #5d6571;
  --v2-error: #ba1a1a;
  --v2-on-error: #ffffff;
  --v2-elevation-1: 0 4px 12px rgba(0, 0, 0, 0.05);
  --v2-radius-md: 0.75rem;
  --v2-radius-full: 9999px;
  --v2-font-display: "Be Vietnam Pro", system-ui, -apple-system, "Segoe UI", sans-serif;
  --v2-font-label: "Inter", system-ui, -apple-system, "Segoe UI", sans-serif;
  --v2-touch-min: 44px;
  --v2-appbar-h: 64px;
  --v2-drawer-w: 300px;
  --v2-content-offset: 320px;

  /* design/menu.html — drawer + .v2-nav (Tailwind theme.extend + .nav-section-header + scrollbar) */
  --v2-menu-drawer-title: #005bbf;
  --v2-menu-on-surface: #191c1d;
  --v2-menu-on-surface-variant: #414754;
  --v2-menu-outline-muted: #727785;
  --v2-menu-outline-variant: #c1c6d6;
  --v2-menu-surface-variant: #e1e3e4;
  --v2-menu-active-bg: #1a73e8;
  --v2-menu-active-fg: #ffffff;
}

*,
*::before,
*::after {
  box-sizing: border-box;
}

html {
  overflow-x: hidden;
}

body.v2-body {
  margin: 0;
  font-family: var(--v2-font-display);
  font-size: 16px;
  line-height: 24px;
  font-weight: 400;
  color: var(--v2-on-surface);
  background: var(--v2-surface);
  min-height: 100vh;
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
}

body.v2-body a {
  color: var(--v2-primary);
}

body.v2-body a:hover {
  color: var(--v2-primary-container);
}

/* Anchor-styled .btn-primary must not inherit link blue (Google login etc.) */
body.v2-body a.btn.btn-primary,
body.v2-body a.btn.btn-primary:link,
body.v2-body a.btn.btn-primary:visited {
  color: #ffffff;
}

body.v2-body a.btn.btn-primary:hover,
body.v2-body a.btn.btn-primary:focus,
body.v2-body a.btn.btn-primary:active {
  color: #ffffff;
}

body.v2-body .v2-drawer .v2-nav a,
body.v2-body .v2-drawer .v2-nav a:link,
body.v2-body .v2-drawer .v2-nav a:visited {
  color: #000;
}

body.v2-body .v2-drawer .v2-nav a:hover {
  color: #000;
}

body.v2-body .v2-drawer .v2-nav a.v2-nav__link--active,
body.v2-body .v2-drawer .v2-nav a.v2-nav__link--active:link,
body.v2-body .v2-drawer .v2-nav a.v2-nav__link--active:visited,
body.v2-body .v2-drawer .v2-nav a.v2-nav__link--active:hover {
  color: #fff;
}

body.v2-body .v2-offcanvas-body .v2-nav a,
body.v2-body .v2-offcanvas-body .v2-nav a:link,
body.v2-body .v2-offcanvas-body .v2-nav a:visited {
  color: #000;
}

body.v2-body .v2-offcanvas-body .v2-nav a:hover {
  color: #000;
}

body.v2-body .v2-offcanvas-body .v2-nav a.v2-nav__link--active,
body.v2-body .v2-offcanvas-body .v2-nav a.v2-nav__link--active:link,
body.v2-body .v2-offcanvas-body .v2-nav a.v2-nav__link--active:visited,
body.v2-body .v2-offcanvas-body .v2-nav a.v2-nav__link--active:hover {
  color: #000;
}

body.v2-body .v2-nav a,
body.v2-body .v2-nav a:link,
body.v2-body .v2-nav a:visited {
  color: var(--v2-menu-on-surface-variant);
}

body.v2-body .v2-nav a:hover {
  color: var(--v2-menu-on-surface-variant);
}

body.v2-body .v2-nav a.v2-nav__link--active,
body.v2-body .v2-nav a.v2-nav__link--active:link,
body.v2-body .v2-nav a.v2-nav__link--active:visited,
body.v2-body .v2-nav a.v2-nav__link--active:hover {
  color: var(--v2-menu-active-fg);
}

.material-symbols-outlined {
  font-family: "Material Symbols Outlined", sans-serif;
  font-weight: normal;
  font-style: normal;
  font-size: 1.5rem;
  line-height: 1;
  letter-spacing: normal;
  text-transform: none;
  display: inline-block;
  white-space: nowrap;
  direction: ltr;
  font-feature-settings: "liga";
  -webkit-font-smoothing: antialiased;
  font-variation-settings: "FILL" 0, "wght" 400, "GRAD" 0, "opsz" 24;
}

/* Scrollbar (menu.html .custom-scrollbar thumb #c1c6d6) */
.v2-drawer,
.v2-offcanvas-body {
  scrollbar-width: thin;
  scrollbar-color: var(--v2-menu-outline-variant) transparent;
}

.v2-drawer::-webkit-scrollbar,
.v2-offcanvas-body::-webkit-scrollbar {
  width: 6px;
}

.v2-drawer::-webkit-scrollbar-thumb,
.v2-offcanvas-body::-webkit-scrollbar-thumb {
  background: var(--v2-menu-outline-variant);
  border-radius: 10px;
}

/* --- Desktop drawer (menu.html aside) --- */
.v2-drawer {
  display: none;
  position: fixed;
  left: 0;
  top: 0;
  bottom: 0;
  width: var(--v2-drawer-w);
  z-index: 1040;
  flex-direction: column;
  background: var(--v2-surface-container-low);
  border-right: 1px solid var(--v2-menu-outline-variant);
  border-top-right-radius: var(--v2-radius-md);
  border-bottom-right-radius: var(--v2-radius-md);
  box-shadow: var(--v2-elevation-1);
  overflow-y: auto;
}

@media (min-width: 992px) {
  .v2-drawer {
    display: flex;
  }
}

.v2-drawer__inner {
  padding: 20px 24px 12px;
  display: flex;
  flex-direction: column;
  align-items: stretch;
  min-height: 100%;
}

.v2-drawer__brand {
  display: flex;
  justify-content: center;
  align-items: center;
  margin: 0 0 20px;
  padding: 0;
  line-height: 0;
  width: 100%;
}

.v2-drawer__logo {
  display: block;
  height: 56px;
  width: auto;
  max-width: 100%;
  object-fit: contain;
}

.v2-profile-card {
  display: flex;
  align-items: center;
  gap: 16px;
  width: 100%;
  padding: 8px 16px;
  margin-bottom: 20px;
  background: var(--v2-surface-container-lowest);
  border-radius: var(--v2-radius-md);
  box-shadow: var(--v2-elevation-1);
}

.v2-profile-card__avatar {
  width: 48px;
  height: 48px;
  border-radius: var(--v2-radius-full);
  overflow: hidden;
  flex-shrink: 0;
  background: var(--v2-menu-active-bg);
  display: flex;
  align-items: center;
  justify-content: center;
}

.v2-profile-card__avatar img,
.v2-profile-card__avatar .viq-topbar-avatar,
.v2-profile-card__avatar .viq-topbar-avatar-placeholder {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border: none;
}

.v2-profile-card__text {
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 8px;
}

/* Drawer profile + nav: design/menu.html — label-md/sm = Inter; section = Be Vietnam Pro 11px uppercase; weights per request = 1000; nav text #000 */
.v2-drawer .v2-profile-card__name {
  font-family: var(--v2-font-label);
  font-size: 14px;
  font-weight: 1000;
  line-height: 20px;
  letter-spacing: 0.01em;
  color: #191c1d;
  margin: 0;
}

.v2-drawer .v2-profile-card .viq-rail-profile-meta {
  font-family: var(--v2-font-label);
  font-size: 12px;
  font-weight: 1000;
  line-height: 16px;
  color: #414754;
  margin: 0;
}

.v2-drawer .v2-nav__section {
  padding: 8px 16px 4px 16px;
  font-family: var(--v2-font-display);
  font-size: 11px;
  font-weight: 1000;
  line-height: 16px;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: #000;
}

.v2-drawer .v2-nav__link {
  margin: 1px 16px;
  padding: 8px 16px;
  font-family: var(--v2-font-label);
  font-size: 14px;
  font-weight: 1000;
  line-height: 20px;
  letter-spacing: 0.01em;
  color: #000;
}

.v2-drawer .v2-nav__label {
  font-family: var(--v2-font-label);
  font-weight: 1000;
  color: #000;
}

.v2-drawer .v2-nav__link .material-symbols-outlined {
  font-family: "Material Symbols Outlined", sans-serif;
  font-weight: normal;
  color: #000;
}

.v2-drawer .v2-nav__link:hover:not(.v2-nav__link--active) {
  color: #000;
}

.v2-offcanvas-body .v2-nav__link:hover {
  color: #000;
}

.v2-drawer .v2-nav__link .badge {
  font-family: var(--v2-font-label);
  font-weight: 1000;
}

.v2-drawer .v2-nav__link--active,
.v2-drawer .v2-nav__link--active .v2-nav__label {
  font-weight: 1000;
  color: #fff;
}

.v2-drawer .v2-nav__link--active .material-symbols-outlined {
  color: #fff;
}

.v2-offcanvas-body .v2-nav__section {
  font-family: var(--v2-font-display);
  font-size: 11px;
  font-weight: 1000;
  line-height: 16px;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: #000;
}

.v2-offcanvas-body .v2-nav__link,
.v2-offcanvas-body .v2-nav__label {
  font-family: var(--v2-font-label);
  font-size: 14px;
  font-weight: 1000;
  line-height: 20px;
  letter-spacing: 0.01em;
  color: #000;
}

.v2-offcanvas-body .v2-nav__link .material-symbols-outlined {
  font-family: "Material Symbols Outlined", sans-serif;
  font-weight: normal;
  color: #000;
}

.v2-offcanvas-body .v2-nav__link--active,
.v2-offcanvas-body .v2-nav__link--active .v2-nav__label {
  color: #000;
  font-weight: 1000;
}

/* V1-style level progress in profile card; hover = native title (pts to next level) */
.v2-profile-card .player-stats-progress {
  width: 100%;
  margin-top: 2px;
  cursor: help;
}

.v2-profile-card .player-stats-progress-bar {
  height: 6px;
  border-radius: var(--v2-radius-full);
  background: var(--v2-surface-variant);
  overflow: hidden;
}

.v2-profile-card .player-stats-progress-fill {
  height: 100%;
  min-width: 0;
  border-radius: inherit;
  background: #1a73e8;
  transition: width 0.35s ease;
}

/* --- Nav (menu.html nav links) --- */
.v2-nav {
  display: flex;
  flex-direction: column;
  width: 100%;
  gap: 4px;
  padding-bottom: 40px;
}

.v2-drawer .v2-nav {
  padding-bottom: 20px;
}

.v2-nav__section {
  padding: 16px 16px 8px 16px;
  font-family: var(--v2-font-display);
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--v2-menu-outline-muted);
}

.v2-nav__link {
  display: flex;
  align-items: center;
  gap: 16px;
  margin: 4px 16px;
  padding: 8px 16px;
  border-radius: var(--v2-radius-full);
  text-decoration: none;
  color: var(--v2-menu-on-surface-variant);
  font-family: var(--v2-font-label);
  font-size: 14px;
  font-weight: 500;
  line-height: 20px;
  letter-spacing: 0.01em;
  transition: background 0.2s ease, color 0.2s ease;
  border: none;
  background: transparent;
  cursor: pointer;
}

.v2-nav__link:hover {
  background: var(--v2-menu-surface-variant);
  color: var(--v2-menu-on-surface-variant);
}

.v2-nav__link--active {
  background: var(--v2-menu-active-bg);
  color: var(--v2-menu-active-fg);
  font-weight: 700;
}

.v2-nav__link--active .v2-nav__label {
  color: inherit;
  font-weight: 700;
}

.v2-nav__link--active .material-symbols-outlined {
  color: inherit;
}

.v2-nav__link .material-symbols-outlined {
  font-size: 24px;
  flex-shrink: 0;
  color: inherit;
}

.v2-nav__label {
  flex: 1;
  min-width: 0;
}

.v2-nav__leading {
  display: flex;
  align-items: center;
  gap: 16px;
  min-width: 0;
}

.v2-nav__link--row {
  justify-content: space-between;
}

.v2-nav__link .badge {
  flex-shrink: 0;
  margin-right: 0.5rem;
  font-size: 10px;
  padding: 2px 6px;
  border-radius: var(--v2-radius-full);
  background: var(--v2-error) !important;
  color: var(--v2-on-error) !important;
}

.v2-nav__link--row .badge {
  margin-left: 0;
}

/* --- Top app bar (menu.html header) --- */
.v2-appbar {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  height: var(--v2-appbar-h);
  z-index: 1030;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding: 8px 24px;
  background: var(--v2-surface);
  box-shadow: var(--v2-elevation-1);
}

@media (min-width: 992px) {
  .v2-appbar {
    padding-left: var(--v2-content-offset);
  }
}

.v2-appbar__start,
.v2-appbar__end {
  display: flex;
  align-items: center;
  gap: 12px;
  min-width: 0;
}

.v2-appbar__menu-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  padding: 8px;
  border: none;
  background: transparent;
  color: var(--v2-on-surface-variant);
  border-radius: var(--v2-radius-full);
  cursor: pointer;
  transition: background 0.2s ease;
}

.v2-appbar__menu-btn:hover {
  background: var(--v2-surface-variant);
}

@media (min-width: 992px) {
  .v2-appbar__menu-btn {
    display: none;
  }
}

.v2-appbar__home-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  padding: 8px;
  border: none;
  background: transparent;
  color: var(--v2-on-surface-variant);
  border-radius: var(--v2-radius-full);
  text-decoration: none;
  cursor: pointer;
  transition: background 0.2s ease, color 0.2s ease;
}

.v2-appbar__home-btn:hover {
  background: var(--v2-surface-variant);
  color: var(--v2-on-surface-variant);
}

.v2-appbar__brand {
  display: flex;
  align-items: center;
  gap: 8px;
  text-decoration: none;
  color: inherit;
}

.v2-appbar__brand-logo {
  height: 40px;
  width: auto;
  object-fit: contain;
}

.v2-appbar__brand-text {
  display: none;
  font-family: var(--v2-font-display);
  font-size: 20px;
  font-weight: 700;
  line-height: 28px;
  letter-spacing: -0.02em;
  color: var(--v2-primary-container);
}

@media (min-width: 768px) {
  .v2-appbar__brand-text {
    display: block;
  }
}

/* menu.html header: brand title next to home (md+) */
.v2-appbar__brand-text--header {
  display: none;
}

@media (min-width: 768px) {
  .v2-appbar__brand-text--header {
    display: block;
  }
}

.v2-appbar__search {
  flex: 1;
  max-width: 36rem;
  padding: 0 24px;
  display: none;
}

@media (min-width: 768px) {
  .v2-appbar__search {
    display: block;
  }
}

.v2-appbar__search-wrap {
  position: relative;
  display: flex;
  align-items: center;
  width: 100%;
}

.v2-appbar__search-wrap .material-symbols-outlined {
  position: absolute;
  left: 12px;
  font-size: 1.25rem;
  color: var(--v2-outline);
  pointer-events: none;
}

.v2-appbar__search-input {
  width: 100%;
  border: none;
  border-radius: var(--v2-radius-full);
  padding: 8px 16px 8px 44px;
  font-family: var(--v2-font-display);
  font-size: 16px;
  line-height: 24px;
  background: var(--v2-surface-container-low);
  color: var(--v2-on-surface);
}

.v2-appbar__search-input::placeholder {
  color: var(--v2-outline-variant);
}

.v2-appbar__search-input:focus {
  outline: 2px solid color-mix(in srgb, var(--v2-primary-container) 22%, transparent);
  outline-offset: 0;
}

.v2-appbar__icon-btn {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  padding: 8px;
  border: none;
  background: transparent;
  color: var(--v2-on-surface-variant);
  border-radius: var(--v2-radius-full);
  text-decoration: none;
  cursor: pointer;
  transition: background 0.2s ease;
}

.v2-appbar__icon-btn:hover {
  background: var(--v2-surface-variant);
}

.v2-appbar__icon-btn .badge {
  position: absolute;
  top: 0;
  right: 0;
  transform: translate(20%, -10%);
  font-size: 0.65rem;
}

.v2-appbar__points {
  display: flex;
  align-items: center;
  min-width: 0;
}

.v2-appbar__points .player-stats {
  flex-direction: row;
  align-items: center;
  gap: 8px;
  padding: 4px 16px;
  background: var(--v2-secondary-container);
  color: var(--v2-on-secondary-container);
  border-radius: var(--v2-radius-full);
}

.v2-appbar__points .player-stats-info {
  display: none;
}

.v2-appbar__points .player-stats-points {
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: 6px;
}

.v2-appbar__points .player-stats-points-value,
.v2-appbar__points .player-stats-points-label {
  font-family: var(--v2-font-label);
  font-size: 14px;
  font-weight: 700;
  line-height: 20px;
  color: inherit;
}

.v2-appbar__points .material-symbols-outlined {
  font-size: 18px;
  color: var(--v2-primary-container);
}

.v2-appbar__notif-btn {
  display: inline-flex;
}

.v2-appbar__avatar-wrap {
  display: inline-flex;
  width: 32px;
  height: 32px;
  margin-left: 4px;
  padding: 0;
  border: 1px solid var(--v2-outline-variant);
  border-radius: var(--v2-radius-full);
  overflow: hidden;
  background: transparent;
  text-decoration: none;
  flex-shrink: 0;
}

.v2-appbar__avatar-wrap .viq-topbar-avatar,
.v2-appbar__avatar-wrap .viq-topbar-avatar-placeholder {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border: none;
}

.v2-appbar__avatar-btn {
  width: 32px;
  height: 32px;
  padding: 0;
  border: 1px solid var(--v2-outline-variant);
  border-radius: var(--v2-radius-full);
  overflow: hidden;
  background: transparent;
  margin-left: 4px;
}

.v2-appbar__avatar-btn .viq-topbar-avatar,
.v2-appbar__avatar-btn .viq-topbar-avatar-placeholder {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border: none;
}

/* --- Main content --- */
.v2-main {
  padding-top: var(--v2-appbar-h);
  min-height: 100vh;
  min-width: 0;
  background: var(--v2-surface);
}

@media (min-width: 992px) {
  .v2-main {
    margin-left: var(--v2-drawer-w);
  }
}

.v2-main__body {
  padding: 1rem 1rem 2rem;
}

@media (min-width: 768px) {
  .v2-main__body {
    padding-left: 1.5rem;
    padding-right: 1.5rem;
  }
}

/* --- Offcanvas (mobile drawer) --- */
.v2-offcanvas.offcanvas-start {
  background: var(--v2-surface-container-low);
  width: min(100%, 320px);
  border-right: 1px solid var(--v2-menu-outline-variant);
}

@media (min-width: 992px) {
  .v2-offcanvas {
    display: none !important;
  }
}

.v2-offcanvas .offcanvas-header {
  border-bottom-color: var(--v2-menu-outline-variant);
}

.v2-offcanvas .offcanvas-title {
  font-family: var(--v2-font-display);
  font-size: 20px;
  font-weight: 600;
  line-height: 28px;
  color: var(--v2-menu-drawer-title);
  letter-spacing: -0.02em;
}

.v2-offcanvas-body {
  flex: 1;
  overflow-y: auto;
  padding: 0;
}

/* --- V2 Home content (design/main.html) — shell unchanged --- */
.v2-home-wrap {
  max-width: 1400px;
  margin: 0 auto;
}

.v2-home-section {
  margin-bottom: 2.5rem;
}

.v2-home-muted {
  color: var(--v2-on-surface-variant);
}

.v2-home-label-sm {
  font-family: var(--v2-font-label);
  font-size: 12px;
  font-weight: 600;
  line-height: 16px;
}

.v2-home-label-md {
  font-family: var(--v2-font-label);
  font-size: 14px;
  font-weight: 500;
  line-height: 20px;
  letter-spacing: 0.01em;
}

.v2-home-headline-sm {
  font-family: var(--v2-font-display);
  font-size: 20px;
  font-weight: 600;
  line-height: 28px;
  letter-spacing: -0.01em;
  color: var(--v2-on-surface);
  margin: 0;
}

.v2-home-h2h-alert {
  background: var(--v2-secondary-container);
  color: var(--v2-on-secondary-container);
  border: 1px solid var(--v2-outline-variant);
  border-radius: 1.5rem;
  padding: 1rem 1.25rem;
  box-shadow: var(--v2-elevation-1);
}

.v2-home-h2h-alert__inner {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}

@media (min-width: 768px) {
  .v2-home-h2h-alert__inner {
    flex-direction: row;
    align-items: center;
    justify-content: space-between;
  }
}

.v2-home-h2h-alert__title {
  font-family: var(--v2-font-display);
  font-size: 18px;
  font-weight: 600;
  line-height: 1.3;
  margin: 0 0 0.25rem;
}

.v2-home-h2h-alert__text {
  font-size: 14px;
  line-height: 1.45;
  opacity: 0.95;
}

.v2-home-h2h-alert__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
}

.v2-home-h2h-alert__form {
  margin: 0;
}

.v2-home-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 44px;
  padding: 0.5rem 1rem;
  border-radius: 0.75rem;
  font-family: var(--v2-font-label);
  font-size: 14px;
  font-weight: 600;
  border: none;
  cursor: pointer;
  text-decoration: none;
}

.v2-home-btn--primary {
  background: var(--v2-primary-container);
  color: #fff;
}

.v2-home-btn--outline {
  background: transparent;
  color: var(--v2-on-secondary-container);
  border: 1px solid var(--v2-outline-variant);
}

.v2-home-hero {
  position: relative;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: 1.5rem;
  padding: 1.5rem;
  background: var(--v2-surface-container-lowest);
  border: 1px solid var(--v2-outline-variant);
  border-radius: 1.5rem;
  box-shadow: var(--v2-elevation-1);
}

@media (min-width: 768px) {
  .v2-home-hero {
    flex-direction: row;
    align-items: center;
    gap: 2rem;
    padding: 2rem 2.5rem;
  }
}

.v2-home-hero__glow {
  position: absolute;
  top: 0;
  right: 0;
  width: 16rem;
  height: 16rem;
  margin: -6rem -6rem 0 0;
  border-radius: 50%;
  background: color-mix(in srgb, var(--v2-primary-container) 8%, transparent);
  pointer-events: none;
}

.v2-home-hero__main {
  position: relative;
  z-index: 1;
  text-align: center;
}

@media (min-width: 768px) {
  .v2-home-hero__main {
    text-align: left;
  }
}

.v2-home-badge {
  display: inline-block;
  padding: 0.25rem 1rem;
  margin-bottom: 0.75rem;
  background: var(--v2-primary-container);
  color: #fff;
  font-family: var(--v2-font-label);
  font-size: 12px;
  font-weight: 600;
  line-height: 16px;
  border-radius: var(--v2-radius-full);
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.v2-home-hero__title {
  font-family: var(--v2-font-display);
  font-size: clamp(1.5rem, 2.5vw, 2rem);
  font-weight: 700;
  line-height: 1.25;
  margin: 0 0 0.5rem;
  color: var(--v2-on-surface);
}

.v2-home-hero__lead {
  font-family: var(--v2-font-display);
  font-size: 1.125rem;
  line-height: 1.55;
  color: var(--v2-on-surface-variant);
  margin: 0;
  max-width: 36rem;
}

.v2-home-hero__lead-strong {
  color: var(--v2-primary-container);
}

.v2-home-hero-progress {
  margin-top: 1.25rem;
  width: 100%;
  max-width: 28rem;
}

.v2-home-hero-progress__labels {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 0.25rem;
}

.v2-home-primary-strong {
  color: var(--v2-primary-container);
  font-weight: 700;
}

.v2-home-hero-progress__track {
  height: 12px;
  width: 100%;
  border-radius: var(--v2-radius-full);
  background: #e1e3e4;
  overflow: hidden;
}

.v2-home-hero-progress-fill {
  height: 100%;
  border-radius: var(--v2-radius-full);
  background: var(--v2-primary-container);
  transition: width 1s ease;
}

.v2-home-hero__stats {
  position: relative;
  z-index: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 1.5rem;
  flex-shrink: 0;
}

@media (min-width: 768px) {
  .v2-home-hero__stats {
    margin-left: auto;
  }
}

.v2-home-stat-tile {
  text-align: center;
}

.v2-home-stat-tile__icon {
  width: 5rem;
  height: 5rem;
  margin: 0 auto 0.5rem;
  border-radius: 1rem;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: var(--v2-elevation-1);
}

.v2-home-stat-tile__icon .material-symbols-outlined {
  font-size: 40px;
}

.v2-home-stat-tile__icon--tertiary {
  background: #ffdbcb;
  color: #9d4300;
}

.v2-home-stat-tile__icon--secondary {
  background: #dbe3f1;
  color: #575f6b;
}

.v2-home-stat-tile__label {
  font-family: var(--v2-font-label);
  font-size: 14px;
  font-weight: 700;
  line-height: 20px;
  margin: 0;
  color: var(--v2-on-surface);
}

.v2-home-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 2.5rem;
}

@media (min-width: 992px) {
  .v2-home-grid {
    grid-template-columns: minmax(0, 2fr) minmax(0, 1fr);
    align-items: start;
  }
}

.v2-home-block-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  margin-bottom: 1.5rem;
}

.v2-home-block-head__title {
  display: flex;
  align-items: center;
  gap: 0.5rem;
}

.v2-home-block-head__icon {
  font-size: 24px;
  color: var(--v2-primary-container);
}

.v2-home-block-head__muted {
  font-family: var(--v2-font-label);
  font-size: 14px;
  color: var(--v2-primary-container);
  font-weight: 500;
  cursor: default;
  opacity: 0.75;
}

.v2-home-quiz-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1.5rem;
  margin-bottom: 1.5rem;
}

@media (min-width: 768px) {
  .v2-home-quiz-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

.v2-home-quiz-card {
  background: var(--v2-surface-container-lowest);
  border: 1px solid var(--v2-outline-variant);
  border-radius: 1.5rem;
  overflow: hidden;
  box-shadow: var(--v2-elevation-1);
  transition: box-shadow 0.25s ease;
}

.v2-home-quiz-card:hover {
  box-shadow: 0 6px 16px rgba(0, 0, 0, 0.08);
}

.v2-home-quiz-card__media {
  height: 12rem;
  overflow: hidden;
}

.v2-home-quiz-card__img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.45s ease;
}

.v2-home-quiz-card:hover .v2-home-quiz-card__img {
  transform: scale(1.05);
}

.v2-home-quiz-card__body {
  padding: 1.5rem;
}

.v2-home-quiz-card__meta {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 0.5rem;
}

.v2-home-chip {
  display: inline-block;
  padding: 0.125rem 0.5rem;
  border-radius: 0.375rem;
  font-family: var(--v2-font-label);
  font-size: 12px;
  font-weight: 600;
  line-height: 16px;
}

.v2-home-chip--primary {
  background: #d8e2ff;
  color: #004493;
}

.v2-home-chip--tertiary {
  background: #ffdbcb;
  color: #783100;
}

.v2-home-quiz-card__title {
  font-family: var(--v2-font-display);
  font-size: 20px;
  font-weight: 600;
  line-height: 1.35;
  margin: 0 0 0.25rem;
  color: var(--v2-on-surface);
}

.v2-home-quiz-card__desc {
  font-size: 16px;
  line-height: 1.5;
  color: var(--v2-on-surface-variant);
  margin: 0 0 1rem;
}

.v2-home-quiz-cta {
  display: flex;
  width: 100%;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  min-height: 44px;
  padding: 0.5rem 1rem;
  border-radius: 0.75rem;
  font-family: var(--v2-font-label);
  font-size: 14px;
  font-weight: 700;
  border: none;
  cursor: default;
}

.v2-home-quiz-cta--primary {
  background: var(--v2-primary-container);
  color: #fff;
}

.v2-home-quiz-cta--secondary {
  background: #e7e8e9;
  color: var(--v2-on-surface-variant);
}

.v2-home-quiz-cta--static {
  pointer-events: none;
  opacity: 1;
}

.v2-home-quiz-cta .material-symbols-outlined {
  font-size: 18px;
}

.v2-home-action-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1.5rem;
}

@media (min-width: 768px) {
  .v2-home-action-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

.v2-home-action-duel {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding: 1.25rem 1.5rem;
  background: var(--v2-surface-container-lowest);
  border: 1px solid color-mix(in srgb, var(--v2-primary-container) 22%, var(--v2-outline-variant));
  border-radius: 1.5rem;
  text-decoration: none;
  color: var(--v2-on-surface);
  box-shadow: var(--v2-elevation-1);
  transition: background 0.2s ease, color 0.2s ease, border-color 0.2s ease;
  min-height: 44px;
}

.v2-home-action-duel:hover {
  background: var(--v2-primary-container);
  color: #fff;
  border-color: var(--v2-primary-container);
}

.v2-home-action-duel__row {
  display: flex;
  align-items: center;
  gap: 1rem;
  min-width: 0;
}

.v2-home-action-duel__icon-wrap {
  width: 3.5rem;
  height: 3.5rem;
  border-radius: 1rem;
  background: color-mix(in srgb, var(--v2-primary-container) 10%, transparent);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  transition: background 0.2s ease;
}

.v2-home-action-duel__icon-wrap .material-symbols-outlined {
  font-size: 32px;
  color: var(--v2-primary-container);
  transition: color 0.2s ease;
}

.v2-home-action-duel__title {
  font-family: var(--v2-font-display);
  font-size: 20px;
  font-weight: 600;
  line-height: 1.25;
  margin: 0 0 0.125rem;
}

.v2-home-action-duel__sub {
  font-family: var(--v2-font-label);
  font-size: 14px;
  line-height: 1.35;
  margin: 0;
  color: var(--v2-on-surface-variant);
  transition: color 0.2s ease;
}

.v2-home-action-duel__chev {
  flex-shrink: 0;
  color: var(--v2-on-surface-variant);
  transition: color 0.2s ease;
}

.v2-home-action-duel:hover .v2-home-action-duel__sub {
  color: rgba(255, 255, 255, 0.85);
}

.v2-home-action-duel:hover .v2-home-action-duel__icon-wrap {
  background: rgba(255, 255, 255, 0.2);
}

.v2-home-action-duel:hover .v2-home-action-duel__icon-wrap .material-symbols-outlined {
  color: #fff;
}

.v2-home-action-duel:hover .v2-home-action-duel__chev {
  color: #fff;
}

.v2-home-action-daily {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding: 1.25rem 1.5rem;
  background: var(--v2-surface-container-lowest);
  border: 1px solid color-mix(in srgb, var(--v2-primary-container) 22%, var(--v2-outline-variant));
  border-radius: 1.5rem;
  text-decoration: none;
  color: var(--v2-on-surface);
  box-shadow: var(--v2-elevation-1);
  transition: background 0.2s ease, color 0.2s ease, border-color 0.2s ease;
  min-height: 44px;
}

.v2-home-action-daily:hover {
  background: var(--v2-primary-container);
  color: #fff;
  border-color: var(--v2-primary-container);
}

.v2-home-action-daily:hover .v2-home-action-daily__title,
.v2-home-action-duel:hover .v2-home-action-duel__title {
  color: #fff;
}

.v2-home-action-daily:hover .v2-home-action-daily__sub {
  color: rgba(255, 255, 255, 0.85);
}

.v2-home-action-daily:hover .v2-home-action-daily__icon-wrap {
  background: rgba(255, 255, 255, 0.2);
}

.v2-home-action-daily:hover .v2-home-action-daily__icon-wrap .material-symbols-outlined {
  color: #fff;
}

.v2-home-action-daily__row {
  display: flex;
  align-items: center;
  gap: 1rem;
  min-width: 0;
}

.v2-home-action-daily__icon-wrap {
  width: 3.5rem;
  height: 3.5rem;
  border-radius: 1rem;
  background: color-mix(in srgb, var(--v2-primary-container) 10%, transparent);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  transition: background 0.2s ease;
}

.v2-home-action-daily__icon-wrap .material-symbols-outlined {
  font-size: 32px;
  color: var(--v2-primary-container);
  transition: color 0.2s ease;
}

.v2-home-action-daily__title {
  font-family: var(--v2-font-display);
  font-size: 20px;
  font-weight: 600;
  line-height: 1.25;
  margin: 0 0 0.125rem;
}

.v2-home-action-daily__sub {
  font-family: var(--v2-font-label);
  font-size: 14px;
  line-height: 1.35;
  margin: 0;
  color: var(--v2-on-surface-variant);
  transition: color 0.2s ease;
}

.v2-home-action-daily__chev {
  flex-shrink: 0;
  color: var(--v2-on-surface-variant);
  transition: color 0.2s ease;
}

.v2-home-action-daily:hover .v2-home-action-daily__chev {
  color: #fff;
}

body.v2-body a.v2-home-action-daily,
body.v2-body a.v2-home-action-duel {
  color: var(--v2-on-surface);
}

body.v2-body a.v2-home-action-daily:hover,
body.v2-body a.v2-home-action-duel:hover {
  color: #fff;
}

body.v2-body a.v2-home-action-daily:hover .v2-home-action-daily__title,
body.v2-body a.v2-home-action-duel:hover .v2-home-action-duel__title,
body.v2-body a.v2-home-action-daily:hover .v2-home-action-daily__sub,
body.v2-body a.v2-home-action-duel:hover .v2-home-action-duel__sub,
body.v2-body a.v2-home-action-daily:hover .v2-home-action-daily__chev,
body.v2-body a.v2-home-action-duel:hover .v2-home-action-duel__chev {
  color: #fff;
}

body.v2-body a.v2-home-action-daily:hover .v2-home-action-daily__sub,
body.v2-body a.v2-home-action-duel:hover .v2-home-action-duel__sub {
  color: rgba(255, 255, 255, 0.85);
}

body.v2-body a.v2-home-action-daily:hover .v2-home-action-daily__icon-wrap .material-symbols-outlined,
body.v2-body a.v2-home-action-duel:hover .v2-home-action-duel__icon-wrap .material-symbols-outlined {
  color: #fff;
}

.v2-home-lb {
  background: var(--v2-surface-container-lowest);
  border: 1px solid var(--v2-outline-variant);
  border-radius: 1.5rem;
  overflow: hidden;
  box-shadow: var(--v2-elevation-1);
}

.v2-home-lb__banner {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 0.75rem;
  padding: 0.75rem 1rem;
  border-bottom: 1px solid var(--v2-outline-variant);
  background: var(--v2-surface-container-low);
}

.v2-home-lb__banner-title {
  font-family: var(--v2-font-label);
  font-size: 14px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--v2-on-surface-variant);
}

.v2-home-lb__banner-meta {
  font-family: var(--v2-font-label);
  font-size: 12px;
  font-weight: 600;
  color: var(--v2-primary-container);
  white-space: nowrap;
}

.v2-home-lb__list {
  border-top: none;
}

.v2-home-lb__empty {
  padding: 1.25rem 1rem;
  margin: 0;
}

.v2-home-lb-row {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  padding: 0.75rem 1rem;
  border-top: 1px solid var(--v2-outline-variant);
}

.v2-home-lb-row:first-child {
  border-top: none;
}

.v2-home-lb-row--top1 {
  background: color-mix(in srgb, #ffdbcb 14%, var(--v2-surface-container-lowest));
}

.v2-home-lb-row--self {
  background: color-mix(in srgb, var(--v2-primary-container) 7%, transparent);
}

.v2-home-lb-rank {
  width: 2rem;
  flex-shrink: 0;
  text-align: center;
  font-family: var(--v2-font-display);
  font-size: 20px;
  font-weight: 600;
  line-height: 1.2;
  color: var(--v2-on-surface-variant);
}

.v2-home-lb-rank--gold {
  color: #c9a000;
}

.v2-home-lb-rank--silver {
  color: #9aa0a6;
}

.v2-home-lb-rank--bronze {
  color: #b87333;
}

.v2-home-lb-avatar-wrap {
  width: 3rem;
  height: 3rem;
  flex-shrink: 0;
  border-radius: 50%;
  overflow: hidden;
  border: 2px solid var(--v2-outline-variant);
}

.v2-home-lb-avatar-wrap--rank-1 {
  border-color: #c9a000;
}

.v2-home-lb-avatar-wrap--rank-2 {
  border-color: #9aa0a6;
}

.v2-home-lb-avatar-wrap--rank-3 {
  border-color: #b87333;
}

.v2-home-lb-avatar {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.v2-home-lb-avatar-fallback {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100%;
  font-family: var(--v2-font-label);
  font-size: 14px;
  font-weight: 700;
  color: #fff;
  background: linear-gradient(135deg, var(--v2-primary-container), var(--v2-primary));
}

.v2-home-lb-info {
  flex: 1;
  min-width: 0;
}

.v2-home-lb-name {
  margin: 0;
  font-family: var(--v2-font-label);
  font-size: 14px;
  font-weight: 700;
  line-height: 1.3;
}

.v2-home-lb-name a {
  color: inherit;
  text-decoration: none;
}

.v2-home-lb-name a:hover {
  color: var(--v2-primary-container);
}

.v2-home-lb-sub {
  margin: 0.125rem 0 0;
  font-family: var(--v2-font-label);
  font-size: 12px;
  line-height: 1.3;
  color: var(--v2-on-surface-variant);
}

.v2-home-lb-trend {
  flex-shrink: 0;
  font-size: 20px;
  color: var(--v2-on-surface-variant);
  opacity: 0.7;
}

.v2-home-lb__footer {
  padding: 1.25rem 1rem;
  text-align: center;
  background: var(--v2-surface-container-low);
  border-top: 1px solid var(--v2-outline-variant);
}

.v2-home-lb__footer-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 44px;
  padding: 0.5rem 1.25rem;
  border-radius: var(--v2-radius-full);
  font-family: var(--v2-font-label);
  font-size: 14px;
  font-weight: 700;
  color: var(--v2-primary-container);
  text-decoration: none;
  transition: background 0.15s ease;
}

.v2-home-lb__footer-btn:hover {
  background: color-mix(in srgb, var(--v2-primary-container) 10%, transparent);
  color: var(--v2-primary-container);
}

.v2-home-mission {
  position: relative;
  margin-top: 1.5rem;
  padding: 1.25rem 1.5rem;
  background: #191c1d;
  color: #fff;
  border-radius: 1.5rem;
  overflow: hidden;
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.15);
}

.v2-home-mission__content {
  position: relative;
  z-index: 1;
}

.v2-home-mission__kicker {
  font-family: var(--v2-font-label);
  font-size: 14px;
  font-weight: 700;
  color: #ffdbcb;
  margin: 0 0 0.25rem;
}

.v2-home-mission__title {
  font-family: var(--v2-font-display);
  font-size: 20px;
  font-weight: 600;
  line-height: 1.35;
  margin: 0 0 0.75rem;
}

.v2-home-mission__reward {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  color: #fff;
}

.v2-home-mission__reward .material-symbols-outlined {
  color: #d8e2ff;
}

.v2-home-mission__deco {
  position: absolute;
  bottom: -1rem;
  right: -1rem;
  font-size: 120px;
  color: rgba(255, 255, 255, 0.06);
  transform: rotate(12deg);
  pointer-events: none;
}

/* Guest home — design/main-page/main-not-auth.html */
.v2-home-na-welcome {
  position: relative;
  overflow: hidden;
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 1rem;
  padding: 1.5rem;
  background: var(--v2-surface-container-lowest);
  border: 1px solid var(--v2-outline-variant);
  border-radius: 1.5rem;
  box-shadow: var(--v2-elevation-1);
}

@media (min-width: 992px) {
  .v2-home-na-welcome {
    padding: 2rem 2.5rem;
  }
}

.v2-home-na-welcome__glow {
  position: absolute;
  top: 0;
  right: 0;
  width: 16rem;
  height: 16rem;
  margin: -6rem -6rem 0 0;
  border-radius: 50%;
  background: color-mix(in srgb, var(--v2-primary-container) 8%, transparent);
  pointer-events: none;
}

.v2-home-na-welcome__inner {
  position: relative;
  z-index: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.75rem;
  max-width: 36rem;
}

.v2-home-na-welcome__title {
  font-family: var(--v2-font-display);
  font-size: clamp(1.5rem, 2.8vw, 2rem);
  font-weight: 700;
  line-height: 1.25;
  margin: 0;
  color: var(--v2-on-surface);
}

.v2-home-na-welcome__lead {
  font-family: var(--v2-font-display);
  font-size: 1.125rem;
  line-height: 1.55;
  margin: 0;
  color: var(--v2-on-surface-variant);
}

.v2-home-na-google {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 1rem;
  margin-top: 0.5rem;
  padding: 1rem 2.5rem;
  min-height: 44px;
  background: var(--v2-surface-container-lowest);
  border: 2px solid var(--v2-outline-variant);
  border-radius: 1rem;
  box-shadow: var(--v2-elevation-1);
  font-family: var(--v2-font-display);
  font-size: 20px;
  font-weight: 700;
  line-height: 1.25;
  color: var(--v2-on-surface);
  text-decoration: none;
  transition: background 0.2s ease, border-color 0.2s ease;
}

.v2-home-na-google:hover {
  background: var(--v2-surface-container);
  color: var(--v2-on-surface);
}

.v2-home-na-google__mark {
  width: 2rem;
  height: 2rem;
  flex-shrink: 0;
}

.v2-home-na-benefits {
  position: relative;
  margin-top: 1.5rem;
  padding: 1.25rem 1.5rem;
  background: var(--v2-primary-container);
  color: #fff;
  border-radius: 1.5rem;
  overflow: hidden;
  box-shadow: 0 8px 24px color-mix(in srgb, var(--v2-primary-container) 35%, transparent);
}

.v2-home-na-benefits__content {
  position: relative;
  z-index: 1;
}

.v2-home-na-benefits__kicker {
  font-family: var(--v2-font-label);
  font-size: 14px;
  font-weight: 700;
  color: #d8e2ff;
  margin: 0 0 0.75rem;
}

.v2-home-na-benefits__list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}

.v2-home-na-benefits__item {
  display: flex;
  align-items: center;
  gap: 0.5rem;
}

.v2-home-na-benefits__check {
  font-size: 22px;
  color: #d8e2ff;
  flex-shrink: 0;
}

.v2-home-na-benefits__text {
  font-family: var(--v2-font-label);
  font-size: 14px;
  font-weight: 500;
  line-height: 1.35;
}

.v2-home-na-benefits__deco {
  position: absolute;
  bottom: -1rem;
  right: -1rem;
  font-size: 120px;
  color: rgba(255, 255, 255, 0.08);
  transform: rotate(12deg);
  pointer-events: none;
}

.v2-home-quiz-cta--link {
  text-decoration: none;
  cursor: pointer;
  box-sizing: border-box;
}

.v2-home-quiz-cta--link.v2-home-quiz-cta--primary:hover {
  filter: brightness(0.95);
}

.v2-home-quiz-cta--link.v2-home-quiz-cta--secondary:hover {
  background: var(--v2-outline-variant);
}

body.v2-body a.v2-home-quiz-cta--link.v2-home-quiz-cta--primary,
body.v2-body a.v2-home-quiz-cta--link.v2-home-quiz-cta--primary:hover {
  color: #fff;
}

body.v2-body a.v2-home-quiz-cta--link.v2-home-quiz-cta--secondary {
  color: var(--v2-on-surface-variant);
}

body.v2-body a.v2-home-quiz-cta--link.v2-home-quiz-cta--secondary:hover {
  color: var(--v2-on-surface-variant);
}

body.v2-body a.v2-home-na-google,
body.v2-body a.v2-home-na-google:hover {
  color: var(--v2-on-surface);
}

/* --- V2 Profile (design/profile.html) --- */
.v2-profile-wrap {
  max-width: 1400px;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  gap: 1.5rem;
}

.v2-profile-passport {
  position: relative;
  overflow: hidden;
  border-radius: 0.75rem;
  padding: 1.5rem;
  border: 1px solid color-mix(in srgb, var(--v2-outline-variant) 55%, transparent);
  box-shadow: var(--v2-elevation-1);
  background: var(--v2-surface);
}

@media (min-width: 992px) {
  .v2-profile-passport {
    padding: 2rem 2.5rem;
  }
}

.v2-profile-passport--texture {
  background-color: var(--v2-surface);
  background-image: radial-gradient(circle at 2px 2px, rgba(0, 91, 191, 0.05) 1px, transparent 0);
  background-size: 24px 24px;
}

.v2-profile-passport__toolbar {
  position: absolute;
  top: 0;
  right: 0;
  padding: 1.5rem;
  display: flex;
  align-items: center;
  gap: 0.5rem;
}

.v2-profile-passport__toolbar--end {
  justify-content: flex-end;
}

.v2-profile-passport__toolbar-label {
  font-family: var(--v2-font-label);
  font-size: 12px;
  font-weight: 500;
  line-height: 16px;
  color: #575f6b;
}

.v2-profile-switch {
  position: relative;
  display: inline-flex;
  align-items: center;
  cursor: pointer;
}

.v2-profile-switch:has(.v2-profile-switch__input:disabled) {
  cursor: not-allowed;
  opacity: 0.65;
}

.v2-profile-switch__input {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

.v2-profile-switch__input:focus-visible + .v2-profile-switch__track {
  outline: 2px solid var(--v2-primary-container);
  outline-offset: 2px;
}

.v2-profile-switch__track {
  width: 2.75rem;
  height: 1.5rem;
  border-radius: var(--v2-radius-full);
  background: #d1d5db;
  position: relative;
  transition: background-color 0.2s ease;
}

.v2-profile-switch__input:checked + .v2-profile-switch__track {
  background: var(--v2-primary-container);
}

.v2-profile-switch__track::after {
  content: "";
  position: absolute;
  top: 2px;
  left: 2px;
  width: 1.25rem;
  height: 1.25rem;
  border-radius: 50%;
  background: #fff;
  border: 1px solid #d1d5db;
  transition: transform 0.2s ease;
}

.v2-profile-switch__input:checked + .v2-profile-switch__track::after {
  transform: translateX(calc(2.75rem - 1.25rem - 4px));
}

/* Own profile: preview როგორც სტუმელი — დამალე რედაქტირება */
.v2-profile-wrap--public-preview .v2-profile-owner-only {
  display: none !important;
}

.v2-profile-challenge-btn--toolbar {
  min-height: 2.25rem;
  padding: 0.25rem 0.625rem;
  gap: 0.25rem;
  font-size: 12px;
  line-height: 1.2;
  border-radius: 0.5rem;
}

.v2-profile-challenge-btn--toolbar .material-symbols-outlined {
  font-size: 18px;
}

.v2-profile-passport__main {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 2rem;
  padding-top: 2.5rem;
}

@media (min-width: 768px) {
  .v2-profile-passport__main {
    flex-direction: row;
    align-items: flex-start;
    padding-top: 0;
  }
}

.v2-profile-passport__avatar-block {
  position: relative;
  flex-shrink: 0;
}

.v2-profile-passport__avatar-frame {
  width: 8rem;
  height: 8rem;
  border-radius: 0.75rem;
  overflow: hidden;
  background: #fff;
  box-shadow:
    0 0 15px rgba(26, 115, 232, 0.5),
    inset 0 0 5px rgba(26, 115, 232, 0.3);
  border: 3px solid #1a73e8;
}

@media (min-width: 992px) {
  .v2-profile-passport__avatar-frame {
    width: 10rem;
    height: 10rem;
  }
}

.v2-profile-passport__avatar-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.v2-profile-passport__avatar-fallback {
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 2.5rem;
  font-weight: 700;
  color: #fff;
  background: linear-gradient(135deg, var(--v2-primary-container), var(--v2-primary));
}

.v2-profile-passport__badge-pro {
  position: absolute;
  bottom: -0.75rem;
  left: 50%;
  transform: translateX(-50%);
  padding: 0.125rem 1rem;
  border-radius: var(--v2-radius-full);
  background: var(--v2-primary-container);
  color: var(--v2-on-primary-container);
  font-family: var(--v2-font-label);
  font-size: 12px;
  font-weight: 600;
  line-height: 16px;
  white-space: nowrap;
  box-shadow: var(--v2-elevation-1);
}

.v2-profile-passport__detail {
  flex: 1;
  width: 100%;
  text-align: center;
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}

@media (min-width: 768px) {
  .v2-profile-passport__detail {
    text-align: left;
  }
}

.v2-profile-passport__name-block {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  flex-wrap: wrap;
}

@media (min-width: 768px) {
  .v2-profile-passport__name-block {
    justify-content: flex-start;
  }
}

.v2-profile-passport__name {
  font-family: var(--v2-font-display);
  font-size: clamp(1.75rem, 3vw, 2rem);
  font-weight: 700;
  line-height: 1.25;
  margin: 0;
  color: var(--v2-primary-container);
}

.v2-profile-icon-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 44px;
  min-height: 44px;
  padding: 0;
  border: 1px solid var(--v2-outline-variant);
  border-radius: 0.5rem;
  background: var(--v2-surface-container-lowest);
  color: var(--v2-on-surface-variant);
  cursor: pointer;
}

.v2-profile-icon-btn:hover {
  background: var(--v2-surface-container);
}

.v2-profile-challenge-btn {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  min-height: 44px;
  padding: 0.5rem 1rem;
  border-radius: 0.5rem;
  border: none;
  background: #ffc107;
  color: #191c1d;
  font-family: var(--v2-font-label);
  font-size: 14px;
  font-weight: 600;
  cursor: pointer;
}

.v2-profile-challenge-btn:disabled {
  opacity: 0.7;
}

.v2-profile-passport__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  justify-content: center;
}

@media (min-width: 768px) {
  .v2-profile-passport__actions {
    justify-content: flex-start;
  }
}

.v2-profile-text-btn {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  min-height: 44px;
  padding: 0.25rem 0.75rem;
  border: none;
  background: transparent;
  color: var(--v2-primary-container);
  font-family: var(--v2-font-label);
  font-size: 14px;
  font-weight: 500;
  cursor: pointer;
  border-radius: 0.5rem;
}

.v2-profile-text-btn:hover {
  background: color-mix(in srgb, var(--v2-primary-container) 8%, transparent);
}

.v2-profile-edit-name {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  align-items: center;
  justify-content: center;
}

@media (min-width: 768px) {
  .v2-profile-edit-name {
    justify-content: flex-start;
  }
}

.v2-profile-edit-name__input {
  flex: 1;
  min-width: 12rem;
  max-width: 24rem;
  padding: 0.5rem 0.75rem;
  border: 1px solid var(--v2-outline-variant);
  border-radius: 0.5rem;
  font-size: 15px;
}

.v2-profile-pill-btn {
  min-height: 44px;
  padding: 0.5rem 1rem;
  border-radius: var(--v2-radius-full);
  font-family: var(--v2-font-label);
  font-size: 14px;
  font-weight: 600;
  border: none;
  cursor: pointer;
}

.v2-profile-pill-btn--primary {
  background: var(--v2-primary-container);
  color: #fff;
}

.v2-profile-pill-btn--outline {
  background: transparent;
  color: var(--v2-on-surface-variant);
  border: 1px solid var(--v2-outline-variant);
}

.v2-profile-alert {
  margin: 0;
  font-size: 14px;
}

.v2-profile-alert--error {
  color: var(--v2-error);
}

.v2-profile-alert--ok {
  color: #198754;
}

.v2-profile-passport__tagline {
  font-family: var(--v2-font-display);
  font-size: 20px;
  font-weight: 600;
  line-height: 1.35;
  margin: 0;
  color: var(--v2-on-surface-variant);
}

.v2-profile-passport__level {
  margin: 0;
  font-size: 15px;
  font-weight: 500;
  color: var(--v2-on-surface-variant);
}

.v2-profile-passport__progress {
  max-width: 32rem;
  margin: 0 auto;
  width: 100%;
}

@media (min-width: 768px) {
  .v2-profile-passport__progress {
    margin: 0;
  }
}

.v2-profile-passport__progress-head {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  gap: 0.5rem;
  margin-bottom: 0.25rem;
}

.v2-profile-passport__progress-label {
  font-family: var(--v2-font-label);
  font-size: 14px;
  font-weight: 500;
  color: #575f6b;
}

.v2-profile-passport__progress-xp {
  font-family: var(--v2-font-label);
  font-size: 12px;
  font-weight: 700;
  color: var(--v2-primary-container);
}

.v2-profile-passport__progress-track {
  height: 12px;
  width: 100%;
  border-radius: var(--v2-radius-full);
  background: #e7e8e9;
  overflow: hidden;
}

.v2-profile-passport__progress-fill {
  height: 100%;
  border-radius: var(--v2-radius-full);
  background: var(--v2-primary-container);
}

.v2-profile-passport__hint {
  display: flex;
  align-items: flex-start;
  gap: 0.25rem;
  margin: 0.5rem 0 0;
  font-family: var(--v2-font-label);
  font-size: 12px;
  line-height: 1.35;
  color: #783100;
}

.v2-profile-passport__hint-icon {
  font-size: 16px;
  flex-shrink: 0;
  margin-top: 1px;
}

.v2-profile-grid-top {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1.5rem;
}

@media (min-width: 1280px) {
  .v2-profile-grid-top {
    grid-template-columns: minmax(0, 4fr) minmax(0, 8fr);
    align-items: stretch;
  }
}

.v2-profile-wrap .v2-profile-card {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: 0;
  width: 100%;
  margin-bottom: 0;
  background: var(--v2-surface);
  border-radius: 0.75rem;
  padding: 1.5rem;
  border: 1px solid color-mix(in srgb, var(--v2-outline-variant) 55%, transparent);
  box-shadow: var(--v2-elevation-1);
}

.v2-profile-wrap .v2-profile-card__title {
  font-family: var(--v2-font-display);
  font-size: 20px;
  font-weight: 600;
  line-height: 1.35;
  margin: 0 0 1.25rem;
  color: var(--v2-on-surface);
}

.v2-profile-wrap .v2-profile-card__title--primary {
  color: var(--v2-primary-container);
}

.v2-profile-radar-card {
  display: flex;
  flex-direction: column;
  min-height: 400px;
}

.v2-profile-radar-body {
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
}

.v2-profile-radar-svg-wrap {
  width: 100%;
  max-width: 22rem;
  margin: 0 auto;
}

.v2-profile-radar-svg {
  width: 100%;
  height: auto;
  display: block;
  filter: drop-shadow(0 4px 12px rgba(0, 0, 0, 0.08));
  color: color-mix(in srgb, var(--v2-outline-variant) 35%, transparent);
}

.v2-profile-radar-svg__ring {
  color: color-mix(in srgb, var(--v2-outline-variant) 25%, transparent);
}

.v2-profile-radar-svg__axis {
  color: color-mix(in srgb, var(--v2-outline-variant) 35%, transparent);
}

.v2-profile-radar-svg__lbl {
  font-size: 10px;
  font-weight: 700;
  fill: #575f6b;
}

.v2-profile-radar-svg__lbl--primary {
  fill: var(--v2-primary-container);
}

.v2-profile-chart-canvas-wrap {
  position: relative;
  width: 100%;
  max-width: 22rem;
  margin: 0 auto;
  aspect-ratio: 1;
}

.v2-profile-stats-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1.5rem;
}

@media (min-width: 576px) {
  .v2-profile-stats-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

.v2-profile-stat-card {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  min-height: 8.5rem;
  padding: 1.5rem;
  background: var(--v2-surface);
  border-radius: 0.75rem;
  border: 1px solid color-mix(in srgb, var(--v2-outline-variant) 55%, transparent);
  box-shadow: var(--v2-elevation-1);
  transition: box-shadow 0.2s ease;
}

.v2-profile-stat-card:hover {
  box-shadow: 0 6px 16px rgba(0, 0, 0, 0.08);
}

.v2-profile-stat-card__head {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 0.5rem;
}

.v2-profile-stat-card__icon {
  font-size: 24px;
  color: var(--v2-primary-container);
  background: #d8e2ff;
  padding: 0.5rem;
  border-radius: 0.5rem;
}

.v2-profile-stat-card__delta {
  font-family: var(--v2-font-label);
  font-size: 12px;
  font-weight: 600;
  color: #783100;
  text-align: right;
}

.v2-profile-stat-card__body {
  margin-top: 1rem;
}

.v2-profile-stat-card__label {
  font-family: var(--v2-font-label);
  font-size: 14px;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: #575f6b;
  margin: 0 0 0.25rem;
}

.v2-profile-stat-card__value {
  font-family: var(--v2-font-display);
  font-size: clamp(2rem, 4vw, 3rem);
  font-weight: 700;
  line-height: 1.1;
  letter-spacing: -0.02em;
  margin: 0;
  color: var(--v2-on-surface);
}

.v2-profile-grid-bottom {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1.5rem;
}

@media (min-width: 1280px) {
  .v2-profile-grid-bottom {
    grid-template-columns: minmax(0, 7fr) minmax(0, 5fr);
    align-items: start;
  }
}

/* Medals + duels: same card chrome as .v2-profile-stat-card (shadow + hover lift) */
.v2-profile-wrap .v2-profile-card.v2-profile-medals,
.v2-profile-wrap .v2-profile-card.v2-profile-duels {
  background: var(--v2-surface);
  border-radius: 0.75rem;
  padding: 1.5rem;
  border: 1px solid color-mix(in srgb, var(--v2-outline-variant) 55%, transparent);
  box-shadow: var(--v2-elevation-1);
  transition: box-shadow 0.2s ease;
}

.v2-profile-wrap .v2-profile-card.v2-profile-medals:hover,
.v2-profile-wrap .v2-profile-card.v2-profile-duels:hover {
  box-shadow: 0 6px 16px rgba(0, 0, 0, 0.08);
}

.v2-profile-medals__head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 1.5rem;
}

.v2-profile-medals__title {
  margin: 0;
  font-family: var(--v2-font-display);
  font-size: 20px;
  font-weight: 600;
  line-height: 28px;
  color: var(--v2-primary);
}

.v2-profile-medals__all-link {
  font-family: var(--v2-font-label);
  font-size: 14px;
  font-weight: 500;
  line-height: 20px;
  letter-spacing: 0.01em;
  color: var(--v2-primary);
  text-decoration: none;
}

.v2-profile-medals__all-link:hover {
  text-decoration: underline;
}

body.v2-body a.v2-profile-medals__all-link,
body.v2-body a.v2-profile-medals__all-link:hover {
  color: var(--v2-primary);
}

.v2-profile-medals__grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 1rem;
}

@media (min-width: 576px) {
  .v2-profile-medals__grid {
    grid-template-columns: repeat(6, minmax(0, 1fr));
  }
}

.v2-profile-medal-item {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.25rem;
}

.v2-profile-medal-item__icon {
  width: 3rem;
  height: 3rem;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  background: #d8e2ff;
  box-shadow: 0 1px 2px rgba(0, 0, 0, 0.05);
}

.v2-profile-medal-item__glyph {
  font-size: 20px;
  color: var(--v2-primary);
}

.v2-profile-medal-item__label {
  font-size: 10px;
  font-weight: 700;
  text-align: center;
  color: #575f6b;
  line-height: 1.2;
}

.v2-profile-medal-item--locked {
  opacity: 0.4;
  filter: grayscale(1);
}

.v2-profile-medal-item__icon--locked {
  background: #e1e3e4;
  box-shadow: inset 0 1px 3px rgba(0, 0, 0, 0.08);
}

.v2-profile-medal-item__glyph--muted {
  font-size: 20px;
  color: #575f6b;
}

.v2-profile-duels__heading {
  margin: 0 0 1.5rem;
  font-family: var(--v2-font-display);
  font-size: 20px;
  font-weight: 600;
  line-height: 28px;
  color: var(--v2-primary);
}

.v2-profile-duels__list {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}

.v2-profile-duel-row {
  display: flex;
  align-items: center;
  gap: 1rem;
  padding: 0.5rem;
  border-radius: 0.5rem;
  border: 1px solid rgba(193, 198, 214, 0.05);
  transition: background-color 0.15s ease, color 0.15s ease;
}

.v2-profile-duel-row:hover {
  background: #edeeef;
}

.v2-profile-duel-row__ava {
  width: 2.5rem;
  height: 2.5rem;
  border-radius: 50%;
  object-fit: cover;
  border: 1px solid rgba(0, 91, 191, 0.2);
  flex-shrink: 0;
}

.v2-profile-duel-row__info {
  flex: 1;
  min-width: 0;
}

.v2-profile-duel-row__name {
  margin: 0;
  font-family: var(--v2-font-label);
  font-size: 14px;
  font-weight: 700;
  line-height: 20px;
  letter-spacing: 0.01em;
  color: var(--v2-on-surface);
}

.v2-profile-duel-row__meta {
  margin: 0;
  font-family: var(--v2-font-label);
  font-size: 12px;
  font-weight: 600;
  line-height: 16px;
  color: #575f6b;
}

.v2-profile-duel-row__score {
  text-align: right;
  padding: 0 1rem;
  flex-shrink: 0;
}

.v2-profile-duel-row__nums {
  margin: 0;
  font-family: var(--v2-font-label);
  font-size: 14px;
  font-weight: 700;
  line-height: 20px;
  letter-spacing: 0.01em;
  color: #575f6b;
}

.v2-profile-duel-row__nums--win {
  color: var(--v2-primary);
}

.v2-profile-duel-row__nums--lose {
  color: #575f6b;
}

.v2-profile-duel-row__outcome {
  margin: 0;
  font-size: 10px;
  font-weight: 800;
  line-height: 1.2;
}

.v2-profile-duel-row__outcome--win {
  color: #1a73e8;
}

.v2-profile-duel-row__outcome--lose {
  color: var(--v2-error);
}

.v2-profile-duel-row__btn {
  flex-shrink: 0;
  padding: 0.25rem 0.5rem;
  border-radius: 0.25rem;
  border: 1px solid var(--v2-primary);
  background: transparent;
  color: var(--v2-primary);
  font-family: var(--v2-font-label);
  font-size: 12px;
  font-weight: 600;
  line-height: 16px;
  cursor: pointer;
  min-height: 32px;
  transition: background-color 0.15s ease, color 0.15s ease, border-color 0.15s ease;
}

.v2-profile-duel-row__btn:hover {
  background: var(--v2-primary);
  color: #fff;
  border-color: var(--v2-primary);
}

.v2-profile-categories {
  margin-top: 0;
}

.v2-profile-chart-bar-wrap {
  position: relative;
  width: 100%;
  min-height: 400px;
}

/* --- Daily Quiz start (design/daily-quiz/start.html) — page canvas only; shell is V2 layout --- */
.v2-dq-start {
  --v2-dq-tertiary: #9d4300;
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: min(calc(100dvh - var(--v2-appbar-h) - 3rem), calc(100vh - var(--v2-appbar-h) - 3rem));
  overflow: hidden;
  padding: 0 0 2rem;
}

.v2-dq-start__blob {
  position: absolute;
  border-radius: 50%;
  pointer-events: none;
  filter: blur(100px);
}

.v2-dq-start__blob--tr {
  top: 25%;
  right: -5rem;
  width: 24rem;
  height: 24rem;
  background: color-mix(in srgb, var(--v2-primary) 10%, transparent);
}

.v2-dq-start__blob--bl {
  bottom: 25%;
  left: -5rem;
  width: 20rem;
  height: 20rem;
  filter: blur(80px);
  background: color-mix(in srgb, var(--v2-dq-tertiary) 10%, transparent);
}

.v2-dq-start__frame {
  position: relative;
  z-index: 1;
  width: 100%;
  max-width: 42rem;
  padding-left: 1.5rem;
  padding-right: 1.5rem;
}

.v2-dq-start__card {
  background: var(--v2-surface-container-lowest);
  border-radius: 2rem;
  border: 1px solid color-mix(in srgb, var(--v2-outline-variant) 20%, transparent);
  box-shadow: 0 10px 15px -3px rgba(0, 0, 0, 0.08), 0 4px 6px -4px rgba(0, 0, 0, 0.06);
  overflow: hidden;
}

.v2-dq-start__hero {
  position: relative;
  height: 16rem;
  width: 100%;
}

.v2-dq-start__hero-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.v2-dq-start__hero-gradient {
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, #fff 0%, rgba(255, 255, 255, 0.4) 45%, transparent 100%);
  pointer-events: none;
}

.v2-dq-start__hero-caption {
  position: absolute;
  bottom: 1.5rem;
  left: 2rem;
  display: flex;
  align-items: center;
  gap: 1rem;
}

.v2-dq-start__hero-icon {
  width: 4rem;
  height: 4rem;
  border-radius: 1rem;
  background: var(--v2-primary);
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 10px 15px -3px rgba(0, 0, 0, 0.12), 0 4px 6px -4px rgba(0, 0, 0, 0.08);
  transform: rotate(-3deg);
}

.v2-dq-start__hero-icon-glyph {
  font-size: 32px;
  color: #fff;
  font-variation-settings: "FILL" 1, "wght" 400, "GRAD" 0, "opsz" 24;
}

.v2-dq-start__hero-title {
  margin: 0;
  font-family: var(--v2-font-display);
  font-size: clamp(1.75rem, 4vw, 2rem);
  font-weight: 700;
  line-height: 1.25;
  color: var(--v2-on-surface);
}

.v2-dq-start__hero-meta {
  margin: 0;
  font-family: var(--v2-font-label);
  font-size: 14px;
  font-weight: 700;
  line-height: 20px;
  letter-spacing: 0.01em;
  color: var(--v2-primary);
}

.v2-dq-start__body {
  padding: 2rem;
  display: flex;
  flex-direction: column;
  gap: 2rem;
}

.v2-dq-start__alert {
  padding: 0.75rem 1rem;
  border-radius: 0.75rem;
  border: 1px solid color-mix(in srgb, var(--v2-error) 35%, transparent);
  background: color-mix(in srgb, var(--v2-error) 8%, var(--v2-surface-container-lowest));
  color: var(--v2-on-surface);
  font-family: var(--v2-font-label);
  font-size: 14px;
  line-height: 20px;
}

.v2-dq-start__block {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}

.v2-dq-start__lead {
  margin: 0;
  font-family: var(--v2-font-display);
  font-size: 16px;
  line-height: 24px;
  font-weight: 400;
  color: var(--v2-on-surface-variant);
}

.v2-dq-start__rules {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1rem;
  padding-top: 1rem;
}

@media (min-width: 768px) {
  .v2-dq-start__rules {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

.v2-dq-start__rule {
  display: flex;
  align-items: flex-start;
  gap: 0.75rem;
  padding: 1rem;
  border-radius: 1rem;
  background: var(--v2-surface-container-low);
  border: 1px solid color-mix(in srgb, var(--v2-outline-variant) 30%, transparent);
}

.v2-dq-start__rule-icon {
  font-size: 24px;
  flex-shrink: 0;
  font-variation-settings: "FILL" 0, "wght" 400, "GRAD" 0, "opsz" 24;
}

.v2-dq-start__rule-icon--primary {
  color: var(--v2-primary);
}

.v2-dq-start__rule-icon--tertiary {
  color: var(--v2-dq-tertiary);
}

.v2-dq-start__rule-icon--error {
  color: var(--v2-error);
}

.v2-dq-start__rule-title {
  margin: 0;
  font-family: var(--v2-font-label);
  font-size: 14px;
  font-weight: 700;
  line-height: 20px;
  letter-spacing: 0.01em;
  color: var(--v2-on-surface);
}

.v2-dq-start__rule-desc {
  margin: 0;
  font-size: 12px;
  line-height: 16px;
  color: var(--v2-outline);
}

.v2-dq-start__footer {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding-top: 1.5rem;
  border-top: 1px solid color-mix(in srgb, var(--v2-outline-variant) 20%, transparent);
}

.v2-dq-start__status {
  display: flex;
  flex-direction: column;
  gap: 0.125rem;
}

.v2-dq-start__status-label {
  font-size: 12px;
  line-height: 16px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--v2-outline);
}

.v2-dq-start__status-value {
  display: inline-flex;
  align-items: center;
  gap: 0.25rem;
  font-family: var(--v2-font-label);
  font-size: 14px;
  font-weight: 500;
  line-height: 20px;
  letter-spacing: 0.01em;
  color: var(--v2-on-surface);
}

.v2-dq-start__status-dot {
  width: 0.5rem;
  height: 0.5rem;
  border-radius: 50%;
  background: var(--v2-primary);
  flex-shrink: 0;
  animation: v2-dq-start-pulse 2s ease-in-out infinite;
}

.v2-dq-start__status-dot--muted {
  background: var(--v2-outline-variant);
  animation: none;
}

@keyframes v2-dq-start-pulse {
  0%,
  100% {
    opacity: 1;
  }

  50% {
    opacity: 0.35;
  }
}

.v2-dq-start__cta-wrap {
  flex-shrink: 0;
}

.v2-dq-start__cta-form {
  margin: 0;
  display: inline-block;
}

.v2-dq-start__cta {
  position: relative;
  overflow: hidden;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.75rem;
  min-height: 44px;
  padding: 1rem 2.5rem;
  border: none;
  border-radius: 1rem;
  background: var(--v2-primary);
  color: var(--v2-on-primary);
  font-family: var(--v2-font-display);
  font-size: 20px;
  font-weight: 600;
  line-height: 28px;
  text-decoration: none;
  cursor: pointer;
  box-shadow: 0 10px 15px -3px color-mix(in srgb, var(--v2-primary) 20%, transparent),
    0 4px 6px -4px color-mix(in srgb, var(--v2-primary) 15%, transparent);
  transition: transform 0.15s ease, background-color 0.15s ease, box-shadow 0.15s ease;
}

.v2-dq-start__cta:hover {
  background: var(--v2-primary-container);
  color: var(--v2-on-primary);
  transform: scale(1.05);
}

.v2-dq-start__cta:active {
  transform: scale(0.95);
}

.v2-dq-start__cta-play {
  font-size: 24px;
  font-variation-settings: "FILL" 1, "wght" 400, "GRAD" 0, "opsz" 24;
}

.v2-dq-start__social {
  margin-top: 2rem;
  display: flex;
  justify-content: center;
  align-items: center;
  flex-wrap: wrap;
  gap: 1rem;
}

.v2-dq-start__avatars {
  display: flex;
  align-items: center;
}

.v2-dq-start__avatar {
  width: 2.5rem;
  height: 2.5rem;
  border-radius: 50%;
  object-fit: cover;
  border: 2px solid #fff;
  margin-left: -0.75rem;
  box-sizing: content-box;
}

.v2-dq-start__avatar:first-child {
  margin-left: 0;
}

.v2-dq-start__avatar--more {
  display: flex;
  align-items: center;
  justify-content: center;
  background: #dbe3f1;
  color: #141c26;
  font-size: 10px;
  font-weight: 700;
  font-family: var(--v2-font-label);
}

.v2-dq-start__social-text {
  margin: 0;
  align-self: center;
  font-family: var(--v2-font-label);
  font-size: 14px;
  font-weight: 500;
  line-height: 20px;
  letter-spacing: 0.01em;
  color: var(--v2-on-surface-variant);
}

.v2-dq-start__ripple {
  position: absolute;
  background: rgba(255, 255, 255, 0.3);
  border-radius: 50%;
  transform: scale(0);
  pointer-events: none;
}

.v2-dq-start__ripple--animate {
  animation: v2-dq-start-ripple 0.6s linear forwards;
}

@keyframes v2-dq-start-ripple {
  to {
    transform: scale(4);
    opacity: 0;
  }
}

/* --- Daily Quiz question (design/daily-quiz/quiz.html) --- */
.v2-dq-quiz {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  min-height: min(calc(100dvh - var(--v2-appbar-h) - 3rem), calc(100vh - var(--v2-appbar-h) - 3rem));
  padding: 0 0 2rem;
}

.v2-dq-quiz__frame {
  width: 100%;
  max-width: 56rem;
  padding: 0 1rem;
}

@media (min-width: 992px) {
  .v2-dq-quiz__frame {
    padding: 0 2.5rem;
  }
}

.v2-dq-quiz__progress {
  margin-bottom: 3rem;
}

.v2-dq-quiz__progress-head {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  gap: 1rem;
  margin-bottom: 1rem;
}

.v2-dq-quiz__progress-label {
  font-family: var(--v2-font-display);
  font-size: 20px;
  font-weight: 600;
  line-height: 28px;
  color: var(--v2-on-surface-variant);
}

.v2-dq-quiz__progress-badge {
  font-family: var(--v2-font-label);
  font-size: 14px;
  font-weight: 700;
  line-height: 20px;
  letter-spacing: 0.01em;
  color: var(--v2-primary);
}

.v2-dq-quiz__progress-track {
  height: 0.75rem;
  width: 100%;
  border-radius: var(--v2-radius-full);
  overflow: hidden;
  background: #e7e8e9;
}

.v2-dq-quiz__progress-fill {
  height: 100%;
  border-radius: var(--v2-radius-full);
  background: var(--v2-primary);
  box-shadow: 0 0 12px rgba(0, 91, 191, 0.3);
  transition: width 0.5s ease;
}

.v2-dq-quiz__card {
  background: var(--v2-surface-container-lowest);
  border-radius: 2rem;
  border: 1px solid color-mix(in srgb, var(--v2-outline-variant) 100%, transparent);
  padding: 2.5rem;
  box-shadow: 0 1px 2px rgba(0, 0, 0, 0.05);
  margin-bottom: 2rem;
}

@media (max-width: 767.98px) {
  .v2-dq-quiz__card {
    padding: 1.5rem;
  }
}

.v2-dq-quiz__form {
  margin: 0;
  width: 100%;
}

.v2-dq-quiz__head {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 2rem;
}

@media (min-width: 768px) {
  .v2-dq-quiz__head {
    flex-direction: row;
    align-items: flex-start;
    justify-content: space-between;
  }
}

.v2-dq-quiz__head-main {
  flex: 1;
  min-width: 0;
}

.v2-dq-quiz__chip {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.25rem 0.75rem;
  margin-bottom: 1.5rem;
  border-radius: var(--v2-radius-full);
  background: #dbe3f1;
  color: #141c26;
}

.v2-dq-quiz__chip-icon {
  font-size: 16px;
  font-variation-settings: "FILL" 0, "wght" 400, "GRAD" 0, "opsz" 24;
}

.v2-dq-quiz__chip-text {
  font-family: var(--v2-font-label);
  font-size: 12px;
  font-weight: 600;
  line-height: 16px;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.v2-dq-quiz__question {
  margin: 0;
  font-family: var(--v2-font-display);
  font-size: clamp(1.25rem, 3vw, 1.5rem);
  font-weight: 600;
  line-height: 1.35;
  color: var(--v2-on-surface);
}

.v2-dq-quiz__timer {
  position: relative;
  flex-shrink: 0;
  width: 6rem;
  height: 6rem;
}

.v2-dq-quiz__timer-svg {
  width: 100%;
  height: 100%;
  transform: rotate(-90deg);
  color: var(--v2-primary);
}

.v2-dq-quiz__timer-bg {
  stroke: #e7e8e9;
}

.v2-dq-quiz__timer-arc {
  stroke: currentColor;
  stroke-linecap: round;
  transition: stroke-dashoffset 1s linear;
}

.v2-dq-quiz__timer-num {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--v2-font-display);
  font-size: 20px;
  font-weight: 600;
  line-height: 28px;
  color: var(--v2-primary);
}

.v2-dq-quiz__answers {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1rem;
  margin-top: 3rem;
}

@media (min-width: 768px) {
  .v2-dq-quiz__answers {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

.v2-dq-quiz__opt {
  display: flex;
  align-items: center;
  padding: 1.5rem;
  border-radius: 1rem;
  gap: 0;
  text-align: left;
  transition: transform 0.15s ease, background-color 0.2s ease, box-shadow 0.2s ease, border-color 0.2s ease;
}

.v2-dq-quiz__opt--pick {
  cursor: pointer;
  border: 1px solid transparent;
  background: var(--v2-surface-container);
  color: var(--v2-on-surface-variant);
  position: relative;
}

.v2-dq-quiz__opt--pick:hover {
  background: #e7e8e9;
}

.v2-dq-quiz__opt--pick:active {
  transform: scale(0.98);
}

.v2-dq-quiz__opt--pick:has(.v2-dq-quiz__radio:checked) {
  outline: 2px solid var(--v2-primary);
  outline-offset: 2px;
  background: color-mix(in srgb, var(--v2-primary) 6%, var(--v2-surface-container-lowest));
}

.v2-dq-quiz__radio {
  position: absolute;
  opacity: 0;
  width: 0;
  height: 0;
  pointer-events: none;
}

.v2-dq-quiz__opt-letter {
  flex-shrink: 0;
  width: 2rem;
  height: 2rem;
  margin-right: 1rem;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--v2-font-display);
  font-size: 14px;
  font-weight: 700;
  background: var(--v2-outline-variant);
  color: #fff;
  transition: background-color 0.2s ease;
}

.v2-dq-quiz__opt--pick:hover .v2-dq-quiz__opt-letter {
  background: var(--v2-outline);
}

.v2-dq-quiz__opt-text {
  flex: 1;
  font-family: var(--v2-font-display);
  font-size: 18px;
  line-height: 28px;
  font-weight: 400;
  color: inherit;
}

.v2-dq-quiz__opt-check {
  margin-left: auto;
  font-size: 24px;
  color: #fff;
  font-variation-settings: "FILL" 1, "wght" 400, "GRAD" 0, "opsz" 24;
}

.v2-dq-quiz__opt--correct {
  background: #22c55e;
  color: #fff;
  border: 1px solid transparent;
  box-shadow: 0 10px 15px -3px rgba(34, 197, 94, 0.25), 0 0 0 4px #dcfce7;
}

.v2-dq-quiz__opt--correct .v2-dq-quiz__opt-letter {
  background: rgba(255, 255, 255, 0.2);
  color: #fff;
}

.v2-dq-quiz__opt--correct .v2-dq-quiz__opt-text {
  color: #fff;
}

.v2-dq-quiz__opt--wrong {
  background: color-mix(in srgb, var(--v2-error) 12%, var(--v2-surface-container-lowest));
  border: 2px solid var(--v2-error);
  color: var(--v2-on-surface);
}

.v2-dq-quiz__opt--wrong .v2-dq-quiz__opt-letter {
  background: var(--v2-error);
  color: #fff;
}

.v2-dq-quiz__opt--neutral {
  background: var(--v2-surface-container);
  color: var(--v2-on-surface-variant);
  opacity: 0.85;
}

.v2-dq-quiz__opt--neutral .v2-dq-quiz__opt-letter {
  background: var(--v2-outline-variant);
  color: #fff;
}

.v2-dq-quiz__feedback {
  margin-top: 2.5rem;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.75rem;
  padding: 1rem 2rem;
  border-radius: 1rem;
  box-shadow: 0 1px 2px rgba(0, 0, 0, 0.05);
}

.v2-dq-quiz__feedback--ok {
  background: #f0fdf4;
  border: 1px solid #bbf7d0;
  color: #14532d;
}

.v2-dq-quiz__feedback--bad {
  background: #fef2f2;
  border: 1px solid #fecaca;
  color: #7f1d1d;
}

.v2-dq-quiz__feedback--warn {
  background: #fffbeb;
  border: 1px solid #fde68a;
  color: #78350f;
}

.v2-dq-quiz__feedback-icon {
  font-size: 24px;
  flex-shrink: 0;
  font-variation-settings: "FILL" 1, "wght" 400, "GRAD" 0, "opsz" 24;
}

.v2-dq-quiz__feedback--ok .v2-dq-quiz__feedback-icon {
  color: #22c55e;
}

.v2-dq-quiz__feedback--bad .v2-dq-quiz__feedback-icon {
  color: var(--v2-error);
}

.v2-dq-quiz__feedback--warn .v2-dq-quiz__feedback-icon {
  color: #d97706;
}

.v2-dq-quiz__feedback-text {
  margin: 0;
  font-family: var(--v2-font-display);
  font-size: 20px;
  font-weight: 700;
  line-height: 28px;
}

.v2-dq-quiz__actions {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 1.5rem;
}

.v2-dq-quiz__next {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.75rem;
  min-height: 44px;
  padding: 1rem 3rem;
  border: none;
  border-radius: 1rem;
  background: var(--v2-primary);
  color: #fff !important;
  font-family: var(--v2-font-display);
  font-size: 20px;
  font-weight: 600;
  line-height: 28px;
  text-decoration: none;
  cursor: pointer;
  box-shadow: 0 20px 25px -5px rgba(0, 0, 0, 0.12), 0 8px 10px -6px rgba(0, 0, 0, 0.08);
  transition: transform 0.15s ease, box-shadow 0.2s ease, background-color 0.15s ease;
}

.v2-dq-quiz__next:hover {
  background: var(--v2-primary-container);
  color: #fff !important;
  box-shadow: 0 25px 50px -12px rgba(0, 0, 0, 0.18);
}

.v2-dq-quiz__next:active {
  transform: scale(0.97);
}

.v2-dq-quiz__next:disabled {
  opacity: 0.45;
  cursor: not-allowed;
  transform: none;
  box-shadow: none;
}

.v2-dq-quiz__next .material-symbols-outlined {
  font-size: 24px;
}

.v2-dq-quiz__protest {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.5rem 0.75rem;
  min-height: 44px;
  border: none;
  background: transparent;
  font-family: var(--v2-font-label);
  font-size: 14px;
  font-weight: 500;
  line-height: 20px;
  letter-spacing: 0.01em;
  color: var(--v2-outline);
  cursor: pointer;
  transition: color 0.15s ease;
}

.v2-dq-quiz__protest:hover {
  color: var(--v2-error);
}

.v2-dq-quiz__protest .material-symbols-outlined {
  font-size: 20px;
}

/* --- Daily Quiz results (design/daily-quiz/result.html) --- */
.v2-dq-res {
  padding: 2.5rem 0 3rem;
  background: var(--v2-surface);
}

.v2-dq-res__frame {
  max-width: 56rem;
  margin: 0 auto;
  padding: 0 1rem;
}

@media (min-width: 992px) {
  .v2-dq-res__frame {
    padding: 0 2.5rem;
  }
}

@keyframes v2-dq-res-fade-up {
  from {
    transform: translateY(20px);
    opacity: 0;
  }

  to {
    transform: translateY(0);
    opacity: 1;
  }
}

.v2-dq-res__anim {
  opacity: 0;
  animation: v2-dq-res-fade-up 0.6s ease-out forwards;
}

.v2-dq-res__anim--0 {
  animation-delay: 0s;
}

.v2-dq-res__anim--1 {
  animation-delay: 0.1s;
}

.v2-dq-res__anim--2 {
  animation-delay: 0.2s;
}

.v2-dq-res__anim--3 {
  animation-delay: 0.3s;
}

.v2-dq-res__anim--4 {
  animation-delay: 0.4s;
}

.v2-dq-res__hero {
  text-align: center;
  margin-bottom: 2.5rem;
}

.v2-dq-res__hero-title {
  margin: 0 0 0.75rem;
  font-family: var(--v2-font-display);
  font-size: clamp(2.25rem, 5vw, 3rem);
  font-weight: 700;
  line-height: 1.15;
  letter-spacing: -0.02em;
  color: var(--v2-primary);
}

.v2-dq-res__hero-lead {
  margin: 0;
  font-family: var(--v2-font-display);
  font-size: 20px;
  font-weight: 600;
  line-height: 28px;
  color: var(--v2-on-surface-variant);
}

.v2-dq-res__card {
  border-radius: 1.5rem;
  margin-bottom: 1.5rem;
}

.v2-dq-res__card--score {
  background: var(--v2-surface-container-lowest);
  box-shadow: 0 12px 32px rgba(26, 115, 232, 0.1);
  padding: 2.5rem;
  display: flex;
  flex-direction: column;
  align-items: center;
}

@media (max-width: 767.98px) {
  .v2-dq-res__card--score {
    padding: 1.5rem;
  }
}

.v2-dq-res__score-row {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 2rem;
  width: 100%;
}

@media (min-width: 768px) {
  .v2-dq-res__score-row {
    flex-direction: row;
    align-items: center;
    justify-content: center;
  }
}

.v2-dq-res__gauge-wrap {
  position: relative;
  width: 12rem;
  height: 12rem;
  flex-shrink: 0;
}

.v2-dq-res__gauge {
  --gauge-pct: 0%;
  width: 100%;
  height: 100%;
  border-radius: 50%;
  background: radial-gradient(closest-side, #fff 79%, transparent 80% 100%),
    conic-gradient(var(--v2-primary) var(--gauge-pct), #dbe3f1 0);
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background 0.9s ease-out, transform 0.5s ease;
  transform: scale(1);
}

.v2-dq-res__gauge:hover {
  transform: scale(1.05);
}

.v2-dq-res__gauge-inner {
  width: 85%;
  height: 85%;
  border-radius: 50%;
  background: #fff;
  box-shadow: inset 0 2px 8px rgba(0, 0, 0, 0.06);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
}

.v2-dq-res__gauge-ratio {
  font-family: var(--v2-font-display);
  font-size: clamp(2rem, 4vw, 3rem);
  font-weight: 700;
  line-height: 1.1;
  letter-spacing: -0.02em;
  color: var(--v2-on-surface);
}

.v2-dq-res__gauge-label {
  font-family: var(--v2-font-label);
  font-size: 14px;
  font-weight: 500;
  line-height: 20px;
  color: var(--v2-outline);
}

.v2-dq-res__score-copy {
  flex: 1;
  text-align: center;
  min-width: 0;
}

@media (min-width: 768px) {
  .v2-dq-res__score-copy {
    text-align: left;
  }
}

.v2-dq-res__points-pill {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  padding: 0.35rem 1.25rem;
  margin-bottom: 1rem;
  border-radius: var(--v2-radius-full);
  background: var(--v2-primary-container);
  color: var(--v2-on-primary-container);
  animation: v2-dq-res-bounce-once 0.8s ease-out 0.5s both;
}

@keyframes v2-dq-res-bounce-once {
  0%,
  100% {
    transform: translateY(0);
  }

  40% {
    transform: translateY(-6px);
  }

  55% {
    transform: translateY(2px);
  }

  70% {
    transform: translateY(-2px);
  }
}

.v2-dq-res__points-icon {
  font-size: 22px;
  font-variation-settings: "FILL" 1, "wght" 400, "GRAD" 0, "opsz" 24;
}

.v2-dq-res__points-text {
  font-family: var(--v2-font-display);
  font-size: 20px;
  font-weight: 600;
  line-height: 28px;
}

.v2-dq-res__tier {
  margin: 0 0 0.5rem;
  font-family: var(--v2-font-display);
  font-size: 1.5rem;
  font-weight: 600;
  line-height: 2rem;
  color: var(--v2-on-surface);
}

.v2-dq-res__tier-sub {
  margin: 0;
  font-family: var(--v2-font-display);
  font-size: 18px;
  line-height: 28px;
  font-weight: 400;
  color: var(--v2-on-surface-variant);
}

.v2-dq-res__stats {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1rem;
  width: 100%;
  margin-top: 2.5rem;
  padding-top: 2.5rem;
  border-top: 1px solid color-mix(in srgb, var(--v2-outline-variant) 30%, transparent);
}

@media (max-width: 575.98px) {
  .v2-dq-res__stats {
    grid-template-columns: 1fr;
  }
}

.v2-dq-res__stat {
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 1rem;
  border-radius: 0.75rem;
  background: var(--v2-surface-container-low);
  text-align: center;
}

.v2-dq-res__stat-icon {
  font-size: 24px;
  margin-bottom: 0.25rem;
  font-variation-settings: "FILL" 0, "wght" 400, "GRAD" 0, "opsz" 24;
}

.v2-dq-res__stat-icon--primary {
  color: var(--v2-primary);
}

.v2-dq-res__stat-icon--fire {
  color: #be5a1c;
  font-variation-settings: "FILL" 1, "wght" 400, "GRAD" 0, "opsz" 24;
}

.v2-dq-res__stat-icon--tint {
  color: #005bc0;
}

.v2-dq-res__stat-label {
  font-family: var(--v2-font-label);
  font-size: 14px;
  font-weight: 500;
  line-height: 20px;
  color: var(--v2-outline);
}

.v2-dq-res__stat-value {
  font-family: var(--v2-font-display);
  font-size: 20px;
  font-weight: 600;
  line-height: 28px;
  color: var(--v2-on-surface);
}

.v2-dq-res__card--master {
  background: var(--v2-surface-container-lowest);
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.05);
  padding: 2.5rem;
  margin-bottom: 1.5rem;
}

@media (max-width: 767.98px) {
  .v2-dq-res__card--master {
    padding: 1.5rem;
  }
}

.v2-dq-res__master-top {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  justify-content: space-between;
  gap: 1.25rem;
  margin-bottom: 1.5rem;
}

@media (min-width: 768px) {
  .v2-dq-res__master-top {
    flex-direction: row;
    align-items: center;
  }
}

.v2-dq-res__master-left {
  display: flex;
  align-items: center;
  gap: 1rem;
}

.v2-dq-res__master-icon {
  width: 3rem;
  height: 3rem;
  border-radius: 0.75rem;
  background: var(--v2-primary-container);
  color: var(--v2-on-primary-container);
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.1);
}

.v2-dq-res__master-icon .material-symbols-outlined {
  font-size: 28px;
}

.v2-dq-res__master-title {
  margin: 0 0 0.35rem;
  font-family: var(--v2-font-display);
  font-size: 20px;
  font-weight: 600;
  line-height: 28px;
  color: var(--v2-on-surface);
}

.v2-dq-res__master-rank-row {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.35rem;
}

.v2-dq-res__rank-badge {
  display: inline-block;
  padding: 0.125rem 0.5rem;
  border-radius: 0.25rem;
  background: var(--v2-primary);
  color: #fff;
  font-size: 10px;
  font-weight: 700;
  line-height: 1.2;
  text-transform: uppercase;
  letter-spacing: 0.06em;
}

.v2-dq-res__rank-label {
  font-family: var(--v2-font-label);
  font-size: 14px;
  font-weight: 500;
  line-height: 20px;
  color: var(--v2-on-surface-variant);
}

.v2-dq-res__master-next {
  text-align: left;
  width: 100%;
}

@media (min-width: 768px) {
  .v2-dq-res__master-next {
    width: auto;
    text-align: right;
  }
}

.v2-dq-res__master-next-label {
  margin: 0 0 0.25rem;
  font-family: var(--v2-font-label);
  font-size: 14px;
  font-weight: 500;
  line-height: 20px;
  color: var(--v2-outline);
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.v2-dq-res__master-next-value {
  margin: 0;
  font-family: var(--v2-font-display);
  font-size: 20px;
  font-weight: 600;
  line-height: 28px;
  color: var(--v2-primary);
}

.v2-dq-res__rank-track-wrap {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}

.v2-dq-res__rank-track {
  height: 1rem;
  width: 100%;
  border-radius: var(--v2-radius-full);
  overflow: hidden;
  background: var(--v2-secondary-container);
}

.v2-dq-res__rank-fill {
  height: 100%;
  border-radius: var(--v2-radius-full);
  background: var(--v2-primary);
  position: relative;
  overflow: hidden;
  transition: width 1s ease-out;
}

.v2-dq-res__rank-fill-shine {
  position: absolute;
  inset: 0;
  background: rgba(255, 255, 255, 0.2);
  animation: v2-dq-res-rank-pulse 2s ease-in-out infinite;
}

@keyframes v2-dq-res-rank-pulse {
  0%,
  100% {
    opacity: 0.35;
  }

  50% {
    opacity: 0.9;
  }
}

.v2-dq-res__rank-foot {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  justify-content: space-between;
  gap: 0.5rem;
}

@media (min-width: 576px) {
  .v2-dq-res__rank-foot {
    flex-direction: row;
    align-items: center;
  }
}

.v2-dq-res__rank-foot-left {
  font-family: var(--v2-font-label);
  font-size: 14px;
  font-weight: 500;
  line-height: 20px;
  color: var(--v2-on-surface-variant);
}

.v2-dq-res__rank-foot-right {
  font-family: var(--v2-font-label);
  font-size: 14px;
  font-weight: 700;
  line-height: 20px;
  color: var(--v2-primary);
  white-space: nowrap;
}

.v2-dq-res__teasers {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1.5rem;
  margin-bottom: 1.5rem;
}

@media (min-width: 768px) {
  .v2-dq-res__teasers {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

.v2-dq-res__teaser {
  display: flex;
  align-items: center;
  gap: 1rem;
  padding: 1.25rem;
  border-radius: 1.5rem;
  background: var(--v2-surface-container-lowest);
  box-shadow: var(--v2-elevation-1);
  border: 1px solid color-mix(in srgb, var(--v2-outline-variant) 10%, transparent);
  text-decoration: none;
  color: inherit;
  transition: transform 0.15s ease, box-shadow 0.2s ease;
}

.v2-dq-res__teaser:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 16px rgba(0, 0, 0, 0.08);
  color: inherit;
}

.v2-dq-res__teaser-icon {
  width: 4rem;
  height: 4rem;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.v2-dq-res__teaser-icon .material-symbols-outlined {
  font-size: 28px;
}

.v2-dq-res__teaser-icon--amber {
  background: #ffb691;
  color: #341100;
}

.v2-dq-res__teaser-icon--blue {
  background: #dbe3f1;
  color: #141c26;
}

.v2-dq-res__teaser-label {
  margin: 0 0 0.25rem;
  font-family: var(--v2-font-label);
  font-size: 14px;
  font-weight: 500;
  line-height: 20px;
  color: var(--v2-outline);
}

.v2-dq-res__teaser-value {
  margin: 0;
  font-family: var(--v2-font-display);
  font-size: 20px;
  font-weight: 600;
  line-height: 28px;
  color: var(--v2-on-surface);
}

.v2-dq-res__actions {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 1rem;
  padding-top: 2.5rem;
  padding-bottom: 1.5rem;
}

@media (min-width: 768px) {
  .v2-dq-res__actions {
    flex-direction: row;
  }
}

.v2-dq-res__cta {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.75rem;
  min-width: min(100%, 15rem);
  min-height: 44px;
  padding: 0.875rem 2rem;
  border-radius: 0.75rem;
  font-family: var(--v2-font-display);
  font-size: 18px;
  font-weight: 700;
  line-height: 1.4;
  text-decoration: none;
  cursor: pointer;
  transition: transform 0.15s ease, box-shadow 0.2s ease, background-color 0.15s ease;
}

@media (min-width: 768px) {
  .v2-dq-res__cta {
    min-width: 15rem;
  }
}

.v2-dq-res__cta .material-symbols-outlined {
  font-size: 24px;
}

.v2-dq-res__cta--primary {
  background: var(--v2-primary);
  color: #fff !important;
  box-shadow: 0 10px 15px -3px rgba(0, 0, 0, 0.12);
}

.v2-dq-res__cta--primary:hover {
  color: #fff !important;
  box-shadow: 0 20px 25px -5px rgba(0, 0, 0, 0.15);
  transform: translateY(-2px);
}

.v2-dq-res__cta--primary:active {
  transform: scale(0.97) translateY(0);
}

.v2-dq-res__cta--secondary {
  background: var(--v2-secondary-container);
  color: var(--v2-primary) !important;
}

.v2-dq-res__cta--secondary:hover {
  background: color-mix(in srgb, var(--v2-secondary-container) 80%, var(--v2-surface));
  color: var(--v2-primary) !important;
}

.v2-dq-res__cta--secondary:active {
  transform: scale(0.97);
}

.v2-dq-res__back-daily {
  margin: 0;
  text-align: center;
  font-family: var(--v2-font-label);
  font-size: 14px;
}

.v2-dq-res__back-daily a {
  color: var(--v2-primary);
  font-weight: 600;
}

/* =============================================================================
   Notifications V2 — pixel-aligned to design/notifications.html (Tailwind).
   ============================================================================= */
.scrollbar-hide::-webkit-scrollbar {
  display: none;
}

.scrollbar-hide {
  -ms-overflow-style: none;
  scrollbar-width: none;
}

.v2-notif-page {
  --v2-notif-primary-fixed: #d7e2ff;
  --v2-notif-inv-surface: #2e3132;
  --v2-notif-inv-on-surface: #f0f1f2;
  --v2-notif-duel-icon-bg: #fff4e6;
  --v2-notif-duel-icon-fg: #ff9800;
  width: 100%;
  max-width: 64rem;
  margin-left: auto;
  margin-right: auto;
  padding: 1.5rem 1rem 2rem;
}

@media (min-width: 1024px) {
  .v2-notif-page {
    padding: 2.5rem 1.5rem 2.5rem;
  }
}

.v2-notif-page__header {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  justify-content: space-between;
  gap: 1rem;
  margin-bottom: 2rem;
}

@media (min-width: 576px) {
  .v2-notif-page__header {
    flex-direction: row;
    align-items: center;
  }
}

.v2-notif-page__title {
  margin: 0 0 0.25rem;
  font-family: var(--v2-font-display);
  font-size: 1.875rem;
  font-weight: 900;
  line-height: 2.25rem;
  letter-spacing: -0.02em;
  color: var(--v2-on-surface);
}

.v2-notif-page__subtitle {
  margin: 0;
  font-family: var(--v2-font-label);
  font-size: 0.875rem;
  line-height: 1.25rem;
  font-weight: 400;
  color: var(--v2-on-secondary-container);
}

.v2-notif-page__header-actions {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.5rem;
}

.v2-notif-page__markall-form {
  margin: 0;
}

.v2-notif-page__btn-markall {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  padding: 0.625rem 1rem;
  min-height: var(--v2-touch-min);
  border-radius: 0.75rem;
  border: 1px solid var(--v2-notif-primary-fixed);
  background: #ffffff;
  color: var(--v2-primary);
  font-family: var(--v2-font-label);
  font-size: 0.875rem;
  font-weight: 700;
  line-height: 1.25;
  box-shadow: 0 1px 2px rgba(0, 0, 0, 0.06);
  cursor: pointer;
  transition: background-color 0.15s ease, color 0.15s ease;
}

.v2-notif-page__btn-markall:hover:not(:disabled) {
  background: color-mix(in srgb, var(--v2-notif-primary-fixed) 10%, #ffffff);
}

.v2-notif-page__btn-markall:disabled {
  opacity: 0.45;
  cursor: not-allowed;
}

.v2-notif-page__btn-markall-icon {
  font-size: 1.25rem;
}

.v2-notif-page__btn-settings {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: var(--v2-touch-min);
  height: var(--v2-touch-min);
  padding: 0.625rem;
  border: none;
  border-radius: 0.75rem;
  background: #e7e8e9;
  color: var(--v2-on-secondary-container);
  text-decoration: none;
  cursor: pointer;
  transition: background-color 0.15s ease;
}

.v2-notif-page__btn-settings:hover {
  background: color-mix(in srgb, var(--v2-secondary-container) 50%, #e7e8e9);
  color: var(--v2-on-secondary-container);
}

.v2-notif-page__tabs {
  display: flex;
  gap: 0.5rem;
  overflow-x: auto;
  margin-bottom: 1.5rem;
  padding-bottom: 0.5rem;
}

.v2-notif-page__tab {
  flex-shrink: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.5rem 1.25rem;
  border-radius: var(--v2-radius-full);
  border: 1px solid color-mix(in srgb, var(--v2-outline-variant) 30%, transparent);
  background: #ffffff;
  color: var(--v2-on-secondary-container);
  font-family: var(--v2-font-label);
  font-size: 0.875rem;
  font-weight: 500;
  line-height: 1.25;
  text-decoration: none;
  white-space: nowrap;
  transition: background-color 0.15s ease, color 0.15s ease, box-shadow 0.15s ease;
}

.v2-notif-page__tab:hover {
  background: color-mix(in srgb, var(--v2-secondary-container) 30%, #ffffff);
  color: var(--v2-on-secondary-container);
}

.v2-notif-page__tab--active {
  background: var(--v2-primary);
  color: #ffffff;
  border-color: var(--v2-primary);
  font-weight: 700;
  box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.12);
}

body.v2-body .v2-notif-page__tab--active,
body.v2-body .v2-notif-page__tab--active:link,
body.v2-body .v2-notif-page__tab--active:visited {
  color: #ffffff;
}

body.v2-body .v2-notif-page__tab--active:hover {
  color: #ffffff;
}

.v2-notif-page__empty {
  margin: 0;
  font-size: 0.875rem;
  color: var(--v2-on-secondary-container);
}

.v2-notif-page__list {
  display: grid;
  gap: 1rem;
}

.v2-notif-card {
  position: relative;
  display: flex;
  gap: 1rem;
  width: 100%;
  text-align: left;
  cursor: pointer;
  border-radius: 1rem;
  padding: 1.25rem;
  transition: box-shadow 0.2s ease, transform 0.2s ease, opacity 0.2s ease;
  -webkit-tap-highlight-color: transparent;
}

.v2-notif-card:focus-visible {
  outline: 2px solid var(--v2-primary-container);
  outline-offset: 2px;
}

.v2-notif-card--unread {
  overflow: hidden;
  background: #ffffff;
  border: none;
  border-left: 4px solid var(--v2-primary);
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.05);
}

.v2-notif-card--unread:hover {
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.08);
  transform: translateY(-2px);
}

.v2-notif-card--read {
  background: rgba(255, 255, 255, 0.7);
  border: 1px solid color-mix(in srgb, var(--v2-outline-variant) 30%, transparent);
  opacity: 0.8;
}

.v2-notif-card__icon-wrap {
  width: 3rem;
  height: 3rem;
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 0.75rem;
}

.v2-notif-card__icon-wrap--levelup {
  background: var(--v2-notif-primary-fixed);
  color: var(--v2-primary);
}

.v2-notif-card__icon-wrap--invitation {
  background: var(--v2-notif-duel-icon-bg);
  color: var(--v2-notif-duel-icon-fg);
}

.v2-notif-card__icon-wrap--matchresult {
  background: var(--v2-notif-primary-fixed);
  color: var(--v2-primary);
}

.v2-notif-card__icon-wrap--tribe {
  background: color-mix(in srgb, var(--v2-secondary-container) 50%, #ffffff);
  color: var(--v2-on-secondary-container);
}

.v2-notif-card__icon-wrap--system {
  background: var(--v2-notif-inv-surface);
  color: var(--v2-notif-inv-on-surface);
}

.v2-notif-card__icon-wrap--default {
  background: #e7e8e9;
  color: var(--v2-on-secondary-container);
}

.v2-notif-card--read .v2-notif-card__icon-wrap--levelup,
.v2-notif-card--read .v2-notif-card__icon-wrap--invitation,
.v2-notif-card--read .v2-notif-card__icon-wrap--matchresult,
.v2-notif-card--read .v2-notif-card__icon-wrap--tribe {
  background: color-mix(in srgb, var(--v2-secondary-container) 50%, #ffffff);
  color: var(--v2-on-secondary-container);
}

.v2-notif-card--read .v2-notif-card__icon-wrap--system {
  background: color-mix(in srgb, var(--v2-notif-inv-surface) 88%, #ffffff);
  color: var(--v2-notif-inv-on-surface);
}

.v2-notif-card__ms {
  font-size: 1.5rem;
}

.v2-notif-card__ms--fill {
  font-variation-settings: "FILL" 1, "wght" 400, "GRAD" 0, "opsz" 24;
}

.v2-notif-card__body {
  flex: 1;
  min-width: 0;
  display: flex;
  flex-direction: column;
}

.v2-notif-card__head {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 0.5rem;
  margin-bottom: 0.25rem;
}

.v2-notif-card__title {
  margin: 0;
  padding-right: 1rem;
  font-family: var(--v2-font-display);
  font-size: 1rem;
  line-height: 1.35;
  color: var(--v2-on-surface);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.v2-notif-card--unread .v2-notif-card__title {
  font-weight: 700;
}

.v2-notif-card--read .v2-notif-card__title {
  font-weight: 500;
}

.v2-notif-card__dot {
  width: 0.625rem;
  height: 0.625rem;
  flex-shrink: 0;
  margin-top: 0.35rem;
  border-radius: 50%;
  background: var(--v2-primary);
}

.v2-notif-card__text {
  margin: 0 0 1rem;
  font-family: var(--v2-font-display);
  font-size: 0.875rem;
  line-height: 1.45;
  font-weight: 400;
  color: var(--v2-on-secondary-container);
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.v2-notif-card__footer-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
  margin-top: 0;
}

.v2-notif-card__cta {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.5rem 1.5rem;
  min-height: 2.25rem;
  border-radius: 0.75rem;
  background: var(--v2-primary);
  color: #ffffff !important;
  font-family: var(--v2-font-label);
  font-size: 0.875rem;
  font-weight: 700;
  line-height: 1.25;
  text-decoration: none;
  box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.12);
  transition: transform 0.12s ease;
}

.v2-notif-card__cta:hover {
  color: #ffffff !important;
  transform: scale(1.05);
}

.v2-notif-card__cta:active {
  transform: scale(0.95);
}

.v2-notif-card__time {
  font-family: var(--v2-font-label);
  font-size: 0.75rem;
  line-height: 1rem;
  color: var(--v2-outline);
  flex-shrink: 0;
}

.v2-notif-card__time--block {
  display: block;
  margin-top: 0.75rem;
}

.v2-notif-page__pager {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 1rem;
  margin-top: 1.5rem;
}

.v2-notif-page__pager-link {
  font-family: var(--v2-font-label);
  font-size: 0.875rem;
  font-weight: 600;
  color: var(--v2-primary);
  text-decoration: none;
  padding: 0.5rem 0.75rem;
  border-radius: 0.5rem;
}

.v2-notif-page__pager-link:hover:not(.v2-notif-page__pager-link--disabled) {
  background: color-mix(in srgb, var(--v2-notif-primary-fixed) 22%, transparent);
}

.v2-notif-page__pager-link--disabled {
  color: var(--v2-outline);
  pointer-events: none;
  opacity: 0.5;
}

.v2-notif-page__pager-current {
  font-family: var(--v2-font-label);
  font-size: 0.875rem;
  font-weight: 700;
  color: var(--v2-on-surface);
  min-width: 2rem;
  text-align: center;
}

/* =============================================================================
   Challenges V2 — design/h2h.html
   ============================================================================= */
.v2-h2h-page {
  width: 100%;
  max-width: 72rem;
  margin-left: auto;
  margin-right: auto;
  padding: 1rem 1rem 2.5rem;
}

@media (min-width: 768px) {
  .v2-h2h-page {
    padding: 1.25rem 1.5rem 3rem;
  }
}

.v2-h2h-page__header {
  display: flex;
  flex-direction: column;
  gap: 1rem;
  margin-bottom: 2rem;
}

@media (min-width: 768px) {
  .v2-h2h-page__header {
    flex-direction: row;
    align-items: center;
    justify-content: space-between;
  }
}

.v2-h2h-page__title {
  margin: 0;
  font-family: var(--v2-font-display);
  font-size: clamp(1.5rem, 4vw, 1.875rem);
  font-weight: 900;
  line-height: 1.2;
  color: var(--v2-on-surface);
}

.v2-h2h-page__lead {
  margin: 0.25rem 0 0;
  font-size: 0.875rem;
  line-height: 1.45;
  color: var(--v2-on-surface-variant);
}

.v2-h2h-page__cta-new {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  min-height: var(--v2-touch-min);
  padding: 0.75rem 1.5rem;
  border-radius: 1rem;
  background: var(--v2-primary);
  color: #ffffff !important;
  font-family: var(--v2-font-label);
  font-size: 0.9375rem;
  font-weight: 700;
  text-decoration: none;
  box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.12);
  transition: box-shadow 0.2s ease, transform 0.15s ease;
}

.v2-h2h-page__cta-new:hover {
  color: #ffffff !important;
  box-shadow: 0 10px 15px -3px rgba(0, 0, 0, 0.15);
}

body.v2-body .v2-h2h-page__cta-new,
body.v2-body .v2-h2h-page__cta-new:link,
body.v2-body .v2-h2h-page__cta-new:visited,
body.v2-body .v2-h2h-page__cta-new:hover {
  color: #ffffff !important;
}

.v2-h2h-page__alert {
  margin-bottom: 1rem;
}

.v2-h2h-page__grid {
  display: grid;
  gap: 1.5rem;
}

@media (min-width: 1280px) {
  .v2-h2h-page__grid {
    grid-template-columns: minmax(0, 2fr) minmax(0, 1fr);
    align-items: start;
  }
}

.v2-h2h-section-head {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  margin-bottom: 1rem;
}

.v2-h2h-section-head--history {
  margin-top: 0.5rem;
}

.v2-h2h-section-head__bar {
  width: 0.5rem;
  height: 2rem;
  border-radius: var(--v2-radius-full);
  flex-shrink: 0;
}

.v2-h2h-section-head__bar--primary {
  background: var(--v2-primary-container);
}

.v2-h2h-section-head__bar--secondary {
  background: var(--v2-secondary-container);
}

.v2-h2h-section-head__bar--muted {
  background: color-mix(in srgb, var(--v2-on-surface-variant) 30%, transparent);
}

.v2-h2h-section-head__title {
  margin: 0;
  font-family: var(--v2-font-display);
  font-size: 1.25rem;
  font-weight: 700;
  line-height: 1.3;
  color: var(--v2-on-surface);
}

.v2-h2h-empty {
  margin: 0;
  font-size: 0.875rem;
  color: var(--v2-on-secondary-container);
}

.v2-h2h-active-grid {
  display: grid;
  gap: 1rem;
}

@media (min-width: 768px) {
  .v2-h2h-active-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

.v2-h2h-active-card {
  position: relative;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  gap: 1rem;
  padding: 1.5rem;
  border-radius: 2rem;
  background: var(--v2-surface-container-lowest);
  border: 1px solid color-mix(in srgb, var(--v2-outline-variant) 30%, transparent);
  box-shadow: 0 1px 2px rgba(0, 0, 0, 0.06);
}

.v2-h2h-active-card__top {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
}

.v2-h2h-active-card__who {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  min-width: 0;
}

.v2-h2h-avatar-link {
  flex-shrink: 0;
  text-decoration: none;
}

.v2-h2h-avatar {
  display: block;
  border-radius: 50%;
  object-fit: cover;
}

.v2-h2h-avatar--lg {
  width: 3rem;
  height: 3rem;
}

.v2-h2h-avatar--pending {
  width: 2.5rem;
  height: 2.5rem;
  opacity: 0.65;
  filter: grayscale(0.35);
}

.v2-h2h-avatar--sm {
  width: 2rem;
  height: 2rem;
}

.v2-h2h-avatar-fallback {
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  background: var(--v2-primary);
  color: #fff;
  font-weight: 700;
}

.v2-h2h-avatar-fallback--lg {
  width: 3rem;
  height: 3rem;
  font-size: 1rem;
}

.v2-h2h-avatar-fallback--pending {
  width: 2.5rem;
  height: 2.5rem;
  font-size: 0.875rem;
  opacity: 0.75;
}

.v2-h2h-avatar-fallback--sm {
  width: 2rem;
  height: 2rem;
  font-size: 0.75rem;
}

.v2-h2h-active-card__name {
  margin: 0;
  font-size: 1rem;
  font-weight: 700;
  color: var(--v2-on-surface);
}

.v2-h2h-active-card__meta {
  margin: 0.125rem 0 0;
  font-size: 0.75rem;
  color: var(--v2-on-surface-variant);
}

.v2-h2h-active-card__progress-wrap {
  padding: 0.75rem;
  border-radius: 0.75rem;
  background: color-mix(in srgb, var(--v2-primary-fixed) 30%, transparent);
}

.v2-h2h-active-card__progress-labels {
  display: flex;
  justify-content: space-between;
  font-size: 0.625rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  margin-bottom: 0.25rem;
  color: var(--v2-on-surface);
}

.v2-h2h-active-card__progress-track {
  height: 0.375rem;
  border-radius: var(--v2-radius-full);
  background: var(--v2-surface-container-high);
  overflow: hidden;
}

.v2-h2h-active-card__progress-fill {
  height: 100%;
  border-radius: var(--v2-radius-full);
  background: var(--v2-primary);
  transition: width 0.25s ease;
}

.v2-h2h-active-card__btn {
  display: flex;
  width: 100%;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  min-height: var(--v2-touch-min);
  padding: 0.75rem 1rem;
  border: none;
  border-radius: 0.75rem;
  background: var(--v2-primary-container);
  color: var(--v2-on-primary-container) !important;
  font-family: var(--v2-font-label);
  font-size: 0.875rem;
  font-weight: 700;
  text-decoration: none;
  cursor: pointer;
  transition: filter 0.15s ease;
}

.v2-h2h-active-card__btn:hover {
  filter: brightness(1.08);
  color: var(--v2-on-primary-container) !important;
}

body.v2-body a.v2-h2h-active-card__btn,
body.v2-body a.v2-h2h-active-card__btn:link,
body.v2-body a.v2-h2h-active-card__btn:visited,
body.v2-body a.v2-h2h-active-card__btn:hover {
  color: var(--v2-on-primary-container) !important;
}

.v2-h2h-active-card__btn--waiting {
  background: color-mix(in srgb, var(--v2-primary-container) 25%, var(--v2-surface-container));
  color: var(--v2-on-surface) !important;
}

body.v2-body a.v2-h2h-active-card__btn--waiting,
body.v2-body a.v2-h2h-active-card__btn--waiting:hover {
  color: var(--v2-on-surface) !important;
}

.v2-h2h-pending-list {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}

.v2-h2h-pending-card {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
  padding: 1rem;
  border-radius: 1rem;
  background: var(--v2-surface-container-lowest);
  border: 1px solid color-mix(in srgb, var(--v2-outline-variant) 20%, transparent);
}

@media (min-width: 768px) {
  .v2-h2h-pending-card {
    flex-direction: row;
    align-items: center;
    justify-content: space-between;
  }
}

.v2-h2h-pending-card__main {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  min-width: 0;
}

.v2-h2h-pending-card__avatar-wrap {
  position: relative;
  flex-shrink: 0;
}

.v2-h2h-pending-card__avatar-link {
  display: block;
}

.v2-h2h-pending-card__name {
  margin: 0;
  font-size: 0.875rem;
  font-weight: 700;
  color: var(--v2-on-surface);
}

.v2-h2h-pending-card__sub {
  margin: 0.125rem 0 0;
  font-size: 0.625rem;
  color: var(--v2-on-surface-variant);
}

.v2-h2h-pending-card__type {
  margin: 0.125rem 0 0;
  font-size: 0.6875rem;
  color: var(--v2-on-secondary-container);
}

.v2-h2h-pending-card__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
}

.v2-h2h-pending-card__btn {
  padding: 0.375rem 0.75rem;
  border-radius: 0.5rem;
  font-size: 0.75rem;
  font-weight: 600;
  border: none;
  cursor: pointer;
}

.v2-h2h-pending-card__btn--accept {
  background: var(--v2-primary);
  color: #fff;
}

.v2-h2h-pending-card__btn--decline {
  background: transparent;
  color: var(--v2-error);
  border: 1px solid color-mix(in srgb, var(--v2-error) 35%, transparent);
}

.v2-h2h-pending-card__row-end {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.5rem;
}

.v2-h2h-pending-badge {
  font-size: 0.625rem;
  font-weight: 700;
  padding: 0.25rem 0.75rem;
  border-radius: var(--v2-radius-full);
  background: var(--v2-surface-container);
  color: var(--v2-on-surface-variant);
}

.v2-h2h-pending-card__link-cancel {
  font-size: 0.75rem;
  font-weight: 600;
  color: var(--v2-primary);
  background: none;
  border: none;
  cursor: pointer;
  text-decoration: underline;
  padding: 0;
}

.v2-h2h-history {
  margin-top: 1.5rem;
}

.v2-h2h-table-wrap {
  overflow-x: auto;
  border-radius: 2rem;
  background: var(--v2-surface-container-lowest);
  border: 1px solid color-mix(in srgb, var(--v2-outline-variant) 30%, transparent);
  box-shadow: 0 1px 2px rgba(0, 0, 0, 0.06);
}

.v2-h2h-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.875rem;
  text-align: left;
}

.v2-h2h-table thead tr {
  background: color-mix(in srgb, var(--v2-surface-container-low) 50%, transparent);
}

.v2-h2h-table th {
  padding: 1rem 1.5rem;
  font-family: var(--v2-font-label);
  font-size: 0.75rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--v2-on-surface-variant);
}

.v2-h2h-table__th-action {
  text-align: right;
}

.v2-h2h-table tbody tr {
  border-top: 1px solid color-mix(in srgb, var(--v2-outline-variant) 10%, transparent);
}

.v2-h2h-table tbody tr:hover {
  background: color-mix(in srgb, var(--v2-surface-container-low) 55%, transparent);
}

.v2-h2h-table td {
  padding: 1rem 1.5rem;
  vertical-align: middle;
}

.v2-h2h-table__player {
  display: flex;
  align-items: center;
  gap: 0.75rem;
}

.v2-h2h-table__avatar-link {
  flex-shrink: 0;
}

.v2-h2h-table__name {
  font-weight: 700;
  color: var(--v2-on-surface);
}

.v2-h2h-table__muted {
  color: var(--v2-on-surface-variant);
}

.v2-h2h-table__score {
  font-weight: 900;
  font-variant-numeric: tabular-nums;
}

.v2-h2h-table__action {
  text-align: right;
}

.v2-h2h-table__link {
  font-weight: 700;
  color: var(--v2-primary) !important;
  text-decoration: none;
}

.v2-h2h-table__link:hover {
  text-decoration: underline;
  color: var(--v2-primary) !important;
}

.v2-h2h-chip {
  display: inline-block;
  padding: 0.125rem 0.5rem;
  border-radius: 0.25rem;
  font-size: 0.625rem;
  font-weight: 700;
  background: color-mix(in srgb, var(--v2-primary-fixed) 50%, transparent);
  color: var(--v2-primary);
}

.v2-h2h-result {
  display: inline-block;
  padding: 0.25rem 0.75rem;
  border-radius: var(--v2-radius-full);
  font-size: 0.625rem;
  font-weight: 700;
}

.v2-h2h-result--win {
  background: #dcfce7;
  color: #166534;
}

.v2-h2h-result--loss {
  background: color-mix(in srgb, var(--v2-error) 18%, transparent);
  color: var(--v2-error);
}

.v2-h2h-result--draw {
  background: var(--v2-surface-container);
  color: var(--v2-on-surface-variant);
}

.v2-h2h-pager {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 1rem;
  margin-top: 1rem;
}

.v2-h2h-pager__link {
  font-size: 0.875rem;
  font-weight: 600;
  color: var(--v2-primary) !important;
  text-decoration: none;
  padding: 0.5rem 0.75rem;
  border-radius: 0.5rem;
}

.v2-h2h-pager__link:hover:not(.v2-h2h-pager__link--disabled) {
  background: color-mix(in srgb, var(--v2-primary-fixed) 22%, transparent);
}

.v2-h2h-pager__link--disabled {
  opacity: 0.45;
  pointer-events: none;
  color: var(--v2-outline) !important;
}

.v2-h2h-pager__meta {
  font-size: 0.875rem;
  font-weight: 600;
  color: var(--v2-on-surface);
}

/* --- H2H game lobby V2 --- */
.v2-h2h-idx {
  padding: 2rem 0 2.5rem;
  background: var(--v2-surface);
}

.v2-h2h-idx__frame {
  max-width: 28rem;
  margin: 0 auto;
}

.v2-h2h-idx__head {
  text-align: center;
  margin-bottom: 1.5rem;
}

.v2-h2h-idx__title {
  font-size: clamp(1.75rem, 4vw, 2.25rem);
}

.v2-h2h-idx__card {
  margin-top: 0.5rem;
}

.v2-h2h-idx__actions {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
  margin-top: 0.25rem;
}

.v2-h2h-idx__wait {
  margin: 0;
  text-align: center;
  font-size: 0.875rem;
  color: var(--v2-on-surface-variant);
}

.v2-h2h-idx__link-secondary {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.35rem;
  min-height: 44px;
  font-family: var(--v2-font-label);
  font-size: 14px;
  font-weight: 600;
  color: var(--v2-primary) !important;
  text-decoration: none;
  border-radius: 0.75rem;
}

.v2-h2h-idx__link-secondary:hover {
  background: color-mix(in srgb, var(--v2-primary) 8%, transparent);
}

/* --- H2H results duel (V2; pairs with v2-dq-res) --- */
.v2-h2h-res__duel-caption {
  margin: 0 0 1rem;
  text-align: center;
  font-family: var(--v2-font-label);
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--v2-outline);
}

.v2-h2h-res__duel {
  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
  width: 100%;
  margin-bottom: 2rem;
}

.v2-h2h-res__duel-side {
  flex: 1;
  min-width: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
}

.v2-h2h-res__vs {
  flex-shrink: 0;
  font-family: var(--v2-font-display);
  font-size: 1.25rem;
  font-weight: 800;
  color: var(--v2-outline-variant);
}

.v2-h2h-res__avatar {
  width: 5rem;
  height: 5rem;
  border-radius: 50%;
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--v2-surface-container-high);
  border: 3px solid transparent;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.08);
}

.v2-h2h-res__avatar--highlight {
  border-color: var(--v2-primary);
}

.v2-h2h-res__avatar img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.v2-h2h-res__avatar-fallback {
  font-family: var(--v2-font-display);
  font-size: 1.5rem;
  font-weight: 700;
  color: var(--v2-on-primary-container);
  background: var(--v2-primary-container);
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
}

.v2-h2h-res__duel-name {
  margin: 0.75rem 0 0.25rem;
  font-family: var(--v2-font-label);
  font-size: 14px;
  font-weight: 600;
  color: var(--v2-on-surface-variant);
  max-width: 100%;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.v2-h2h-res__duel-score {
  margin: 0;
  font-family: var(--v2-font-display);
  font-size: clamp(1.5rem, 4vw, 2rem);
  font-weight: 700;
  color: var(--v2-on-surface);
}

.v2-h2h-res__duel-score--win {
  color: var(--v2-primary);
}

.v2-h2h-res__duel-score--muted {
  color: var(--v2-outline);
}

.v2-h2h-res__duel-tag {
  margin-top: 0.35rem;
  display: inline-block;
  padding: 0.125rem 0.5rem;
  border-radius: 999px;
  background: var(--v2-secondary-container);
  color: var(--v2-on-secondary-container);
  font-size: 0.625rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

/* --- Rating hub V2 (design/rating/rating.html) --- */
.v2-rating-hub {
  padding: 2rem 0 3rem;
  background: var(--v2-surface);
}

.v2-rating-hub__inner {
  max-width: 87.5rem;
  margin: 0 auto;
  padding: 0 1rem;
}

@media (min-width: 992px) {
  .v2-rating-hub__inner {
    padding: 0 2.5rem;
  }
}

.v2-rating-hub__title {
  margin: 0 0 2.5rem;
  font-family: var(--v2-font-display);
  font-size: clamp(1.75rem, 4vw, 2rem);
  font-weight: 700;
  line-height: 1.25;
  color: var(--v2-on-surface);
}

.v2-rating-hub__grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 2rem;
}

@media (min-width: 992px) {
  .v2-rating-hub__grid {
    grid-template-columns: repeat(12, minmax(0, 1fr));
  }

  .v2-rating-hub__card {
    grid-column: span 6;
  }
}

.v2-rating-hub__card {
  background: var(--v2-surface-container-lowest);
  border: 1px solid var(--v2-outline-variant);
  border-radius: 1.5rem;
  overflow: hidden;
  box-shadow: 0 1px 2px rgba(0, 0, 0, 0.06);
  display: flex;
  flex-direction: column;
}

.v2-rating-hub__card-head {
  padding: 1.5rem;
  border-bottom: 1px solid var(--v2-outline-variant);
  display: flex;
  flex-direction: column;
  gap: 1rem;
}

.v2-rating-hub__card-head--row {
  flex-direction: row;
  align-items: center;
  gap: 1rem;
}

.v2-rating-hub__card-title {
  margin: 0;
  font-family: var(--v2-font-display);
  font-size: 1.25rem;
  font-weight: 600;
  line-height: 28px;
  color: var(--v2-on-surface);
}

.v2-rating-hub__card-title--tight {
  flex: 1;
}

.v2-rating-hub__pills {
  display: flex;
  flex-wrap: wrap;
  gap: 0.25rem;
  padding: 0.25rem;
  border-radius: 999px;
  background: var(--v2-surface-container-low);
}

.v2-rating-hub__pill {
  flex: 1 1 auto;
  min-height: 44px;
  padding: 0.375rem 0.75rem;
  border: none;
  border-radius: 999px;
  background: transparent;
  font-family: var(--v2-font-label);
  font-size: 14px;
  font-weight: 500;
  color: var(--v2-on-surface-variant);
  cursor: pointer;
  transition: background 0.15s ease, color 0.15s ease, box-shadow 0.15s ease;
}

.v2-rating-hub__pill:hover:not(:disabled) {
  background: color-mix(in srgb, var(--v2-surface-variant) 35%, transparent);
}

.v2-rating-hub__pill--active {
  background: #fff;
  color: var(--v2-primary);
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.08);
}

.v2-rating-hub__pill--ghost:disabled {
  opacity: 0.55;
  cursor: not-allowed;
}

.v2-rating-hub__thead {
  display: grid;
  grid-template-columns: minmax(2rem, 1fr) minmax(0, 7fr) minmax(0, 4fr);
  column-gap: 0.75rem;
  padding: 0.75rem 1.5rem;
  font-family: var(--v2-font-label);
  font-size: 12px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--v2-outline);
}

.v2-rating-hub__th--pts {
  text-align: right;
}

.v2-rating-hub__tbody--hidden {
  display: none !important;
}

.v2-rating-hub__row {
  display: grid;
  grid-template-columns: minmax(2rem, 1fr) minmax(0, 7fr) minmax(0, 4fr);
  column-gap: 0.75rem;
  align-items: center;
  padding: 0.75rem 1.5rem;
  border-top: 1px solid color-mix(in srgb, var(--v2-outline-variant) 50%, transparent);
}

.v2-rating-hub__row--stripe {
  background: var(--v2-surface-container-low);
}

.v2-rating-hub__row--gold .v2-rating-hub__rank--top {
  font-weight: 800;
  color: #9d4300;
}

.v2-rating-hub__row--me {
  background: color-mix(in srgb, var(--v2-primary-fixed) 22%, #fff);
}

.v2-rating-hub__rank {
  font-family: var(--v2-font-label);
  font-weight: 600;
  font-size: 14px;
  color: var(--v2-on-surface-variant);
}

.v2-rating-hub__player {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  min-width: 0;
}

.v2-rating-hub__avatar-wrap {
  flex-shrink: 0;
  width: 2.5rem;
  height: 2.5rem;
  border-radius: 50%;
  overflow: hidden;
  background: var(--v2-secondary-container);
}

.v2-rating-hub__avatar {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.v2-rating-hub__avatar-fallback {
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 700;
  font-size: 0.875rem;
  background: var(--v2-primary-container);
  color: var(--v2-on-primary-container);
}

.v2-rating-hub__name {
  font-family: var(--v2-font-label);
  font-size: 14px;
  font-weight: 500;
  color: inherit;
  text-decoration: none;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.v2-rating-hub__name:hover {
  color: var(--v2-primary);
}

.v2-rating-hub__name--me {
  font-weight: 700;
  color: var(--v2-primary);
}

.v2-rating-hub__name-static {
  font-family: var(--v2-font-label);
  font-size: 14px;
  font-weight: 500;
  color: var(--v2-on-surface);
}

.v2-rating-hub__pts {
  text-align: right;
  font-family: var(--v2-font-label);
  font-size: 14px;
  font-weight: 600;
  color: var(--v2-on-surface);
}

.v2-rating-hub__pts--me {
  font-weight: 700;
  color: var(--v2-primary);
}

.v2-rating-hub__empty {
  margin: 0;
  padding: 1.5rem;
  text-align: center;
  color: var(--v2-on-surface-variant);
  font-size: 14px;
}

.v2-rating-hub__foot-link {
  margin: 0;
  padding: 0.75rem 1.5rem 1rem;
  text-align: center;
}

.v2-rating-hub__foot-link a {
  font-size: 14px;
  font-weight: 600;
  color: var(--v2-primary) !important;
  text-decoration: none;
}

.v2-rating-hub__foot-link a:hover {
  text-decoration: underline;
}

.v2-rating-hub__tribe-icon {
  width: 2.5rem;
  height: 2.5rem;
  border-radius: 0.5rem;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  color: #fff;
}

.v2-rating-hub__tribe-icon .material-symbols-outlined {
  font-size: 22px;
}

.v2-rating-hub__tribe-icon--0 {
  background: #9d4300;
  border: 2px solid #ffdbcb;
}

.v2-rating-hub__tribe-icon--1 {
  background: #575f6b;
}

.v2-rating-hub__tribe-icon--2 {
  background: var(--v2-primary);
}

.v2-rating-hub__tribe-icon--3 {
  background: var(--v2-primary-container);
}

.v2-rating-hub__card--special .v2-rating-hub__card-head {
  border-bottom: 1px solid var(--v2-outline-variant);
}

.v2-rating-hub__spec-icon {
  width: 2.5rem;
  height: 2.5rem;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  color: #fff;
}

.v2-rating-hub__spec-icon--primary {
  background: var(--v2-primary-container);
}

.v2-rating-hub__spec-icon--tertiary {
  background: #be5a1c;
}

.v2-rating-hub__spec-icon .material-symbols-outlined {
  font-size: 22px;
}

.v2-rating-hub__card-footer {
  padding: 0.75rem 1rem;
  border-top: 1px solid var(--v2-outline-variant);
}

.v2-rating-hub__see-all {
  display: block;
  width: 100%;
  padding: 0.5rem;
  text-align: center;
  font-family: var(--v2-font-display);
  font-size: 15px;
  font-weight: 700;
  color: var(--v2-primary) !important;
  text-decoration: none;
  border-radius: 0.75rem;
  transition: background 0.15s ease;
}

.v2-rating-hub__see-all:hover {
  background: color-mix(in srgb, var(--v2-primary-container) 12%, transparent);
}

/* Tribes V2 — design/tribe/tribe-list.html + my-tribe.html (tokens align with :root) */
.v2-tribe-browse,
.v2-tribe-create,
.v2-tribe-my {
  max-width: 72rem;
  margin: 0 auto;
  padding: 0 1rem 2rem;
}

@media (min-width: 768px) {
  .v2-tribe-browse,
  .v2-tribe-create,
  .v2-tribe-my {
    padding-left: 1.5rem;
    padding-right: 1.5rem;
  }
}

.v2-tribe-browse__head {
  display: flex;
  flex-direction: column;
  gap: 1rem;
  margin-bottom: 2rem;
}

@media (min-width: 640px) {
  .v2-tribe-browse__head {
    flex-direction: row;
    flex-wrap: wrap;
    align-items: flex-start;
    justify-content: space-between;
  }
}

.v2-tribe-browse__title {
  margin: 0 0 0.5rem;
  font-family: var(--v2-font-display);
  font-size: clamp(1.5rem, 4vw, 1.875rem);
  font-weight: 800;
  color: var(--v2-on-surface);
  letter-spacing: -0.02em;
}

.v2-tribe-browse__lead {
  margin: 0;
  font-family: var(--v2-font-label);
  font-size: 0.875rem;
  color: var(--v2-on-surface-variant);
  max-width: 36rem;
}

.v2-tribe-browse__head-actions {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.75rem;
}

.v2-tribe-browse__link-rating {
  font-family: var(--v2-font-label);
  font-size: 0.875rem;
  font-weight: 600;
  color: var(--v2-primary);
  text-decoration: none;
}

.v2-tribe-browse__link-rating:hover {
  text-decoration: underline;
}

.v2-tribe-browse__cta-create {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  min-height: var(--v2-touch-min);
  padding: 0.625rem 1.25rem;
  border-radius: var(--v2-radius-md);
  font-family: var(--v2-font-display);
  font-size: 0.9375rem;
  font-weight: 700;
  color: var(--v2-on-primary);
  background: var(--v2-primary);
  text-decoration: none;
  box-shadow: 0 4px 14px color-mix(in srgb, var(--v2-primary) 28%, transparent);
  border: none;
  cursor: pointer;
  transition: transform 0.12s ease, box-shadow 0.12s ease;
}

.v2-tribe-browse__cta-create:hover {
  color: var(--v2-on-primary);
  transform: scale(1.02);
}

.v2-tribe-browse__cta-create--disabled {
  opacity: 0.55;
  cursor: not-allowed;
  transform: none;
  box-shadow: none;
}

.v2-tribe-browse__alert {
  padding: 0.75rem 1rem;
  border-radius: var(--v2-radius-md);
  margin-bottom: 1rem;
  font-size: 0.875rem;
}

.v2-tribe-browse__alert--error {
  background: color-mix(in srgb, var(--v2-error) 12%, #fff);
  color: var(--v2-error);
}

.v2-tribe-browse__alert--ok {
  background: color-mix(in srgb, #1b8736 14%, #fff);
  color: #0d4f1f;
}

.v2-tribe-browse__toolbar {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
  align-items: stretch;
  padding: 1rem;
  margin-bottom: 1.5rem;
  background: var(--v2-surface-container-lowest);
  border-radius: 1rem;
  box-shadow: var(--v2-elevation-1);
  border: 1px solid var(--v2-outline-variant);
}

.v2-tribe-browse__search {
  position: relative;
  flex: 1 1 12rem;
  min-width: 0;
}

.v2-tribe-browse__search-icon {
  position: absolute;
  left: 0.875rem;
  top: 50%;
  transform: translateY(-50%);
  font-size: 1.25rem;
  color: var(--v2-outline);
  pointer-events: none;
}

.v2-tribe-browse__search-input {
  width: 100%;
  min-height: var(--v2-touch-min);
  padding: 0.625rem 0.875rem 0.625rem 2.75rem;
  border: none;
  border-radius: var(--v2-radius-md);
  background: var(--v2-surface-container-low);
  font-family: var(--v2-font-label);
  font-size: 0.875rem;
  color: var(--v2-on-surface);
}

.v2-tribe-browse__search-input:focus {
  outline: 2px solid var(--v2-primary-container);
  outline-offset: 0;
}

.v2-tribe-browse__filter-btn {
  min-height: var(--v2-touch-min);
  padding: 0 1.25rem;
  border: none;
  border-radius: var(--v2-radius-md);
  font-family: var(--v2-font-label);
  font-weight: 600;
  font-size: 0.875rem;
  color: var(--v2-on-secondary-container);
  background: var(--v2-secondary-container);
  cursor: pointer;
}

.v2-tribe-browse__filter-btn:hover {
  filter: brightness(0.97);
}

.v2-tribe-browse__grid {
  display: grid;
  gap: 1rem;
  grid-template-columns: 1fr;
}

@media (min-width: 640px) {
  .v2-tribe-browse__grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (min-width: 1024px) {
  .v2-tribe-browse__grid {
    grid-template-columns: repeat(3, 1fr);
  }
}

.v2-tribe-browse__card {
  display: flex;
  flex-direction: column;
  padding: 1.25rem;
  background: var(--v2-surface-container-lowest);
  border-radius: 1rem;
  border: 1px solid var(--v2-outline-variant);
  box-shadow: var(--v2-elevation-1);
  transition: box-shadow 0.15s ease;
}

.v2-tribe-browse__card:hover:not(.v2-tribe-browse__card--muted) {
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.08);
}

.v2-tribe-browse__card--muted {
  opacity: 0.72;
}

.v2-tribe-browse__card-top {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 0.5rem;
  margin-bottom: 0.75rem;
}

.v2-tribe-browse__emblem {
  width: 4rem;
  height: 4rem;
  border-radius: 0.75rem;
  background: var(--v2-secondary-container);
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  flex-shrink: 0;
}

.v2-tribe-browse__emblem img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.v2-tribe-browse__emblem .material-symbols-outlined {
  font-size: 2rem;
  color: var(--v2-primary);
}

.v2-tribe-browse__badge {
  font-family: var(--v2-font-label);
  font-size: 0.6875rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  padding: 0.25rem 0.5rem;
  border-radius: 9999px;
  background: var(--v2-primary-fixed);
  color: var(--v2-primary);
}

.v2-tribe-browse__card-name {
  margin: 0 0 0.375rem;
  font-family: var(--v2-font-display);
  font-size: 1.125rem;
  font-weight: 700;
  color: var(--v2-on-surface);
}

.v2-tribe-browse__card-desc {
  margin: 0 0 1rem;
  font-size: 0.8125rem;
  line-height: 1.45;
  color: var(--v2-on-surface-variant);
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.v2-tribe-browse__stats {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem 1rem;
  margin-bottom: 1rem;
  font-family: var(--v2-font-label);
  font-size: 0.8125rem;
  color: var(--v2-on-surface-variant);
}

.v2-tribe-browse__stat {
  display: inline-flex;
  align-items: center;
  gap: 0.25rem;
}

.v2-tribe-browse__stat .material-symbols-outlined {
  font-size: 1.125rem;
  color: var(--v2-outline);
}

.v2-tribe-browse__card-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  margin-top: auto;
}

.v2-tribe-browse__btn-secondary {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: var(--v2-touch-min);
  padding: 0 1rem;
  border-radius: var(--v2-radius-md);
  font-family: var(--v2-font-label);
  font-weight: 600;
  font-size: 0.875rem;
  color: var(--v2-on-surface);
  background: var(--v2-surface-container);
  border: 1px solid var(--v2-outline-variant);
  text-decoration: none;
  cursor: pointer;
}

.v2-tribe-browse__btn-secondary:hover {
  background: var(--v2-surface-variant);
  color: var(--v2-on-surface);
}

.v2-tribe-browse__join-form {
  margin: 0;
  flex: 1 1 auto;
}

.v2-tribe-browse__btn-join {
  display: flex;
  width: 100%;
  min-height: var(--v2-touch-min);
  align-items: center;
  justify-content: center;
  gap: 0.375rem;
  border: none;
  border-radius: var(--v2-radius-md);
  font-family: var(--v2-font-display);
  font-weight: 700;
  font-size: 0.875rem;
  color: var(--v2-on-primary);
  background: var(--v2-primary);
  cursor: pointer;
}

.v2-tribe-browse__btn-join:hover:not(:disabled) {
  filter: brightness(1.05);
}

.v2-tribe-browse__btn-join--disabled {
  opacity: 0.55;
  cursor: not-allowed;
}

.v2-tribe-browse__empty {
  text-align: center;
  padding: 2rem 1rem;
  color: var(--v2-on-surface-variant);
  font-size: 0.9375rem;
}

.v2-tribe-browse__pager {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
  justify-content: center;
  margin-top: 1.5rem;
}

.v2-tribe-browse__page-link {
  min-height: var(--v2-touch-min);
  padding: 0 1.25rem;
  display: inline-flex;
  align-items: center;
  border-radius: var(--v2-radius-md);
  font-weight: 600;
  font-size: 0.875rem;
  color: var(--v2-primary);
  background: var(--v2-surface-container-lowest);
  border: 1px solid var(--v2-outline-variant);
  text-decoration: none;
}

.v2-tribe-browse__page-link:hover {
  background: var(--v2-surface-container-low);
  color: var(--v2-primary);
}

/* Create V2 */
.v2-tribe-create__head {
  margin-bottom: 1.5rem;
}

.v2-tribe-create__title {
  margin: 0 0 0.5rem;
  font-family: var(--v2-font-display);
  font-size: clamp(1.5rem, 4vw, 1.875rem);
  font-weight: 800;
  color: var(--v2-on-surface);
}

.v2-tribe-create__lead {
  margin: 0 0 0.75rem;
  font-size: 0.875rem;
  color: var(--v2-on-surface-variant);
}

.v2-tribe-create__back {
  font-size: 0.875rem;
  font-weight: 600;
  text-decoration: none;
}

.v2-tribe-create__card {
  max-width: 32rem;
  padding: 1.5rem;
  background: var(--v2-surface-container-lowest);
  border-radius: 1rem;
  border: 1px solid var(--v2-outline-variant);
  box-shadow: var(--v2-elevation-1);
}

.v2-tribe-create__validation {
  margin-bottom: 1rem;
  font-size: 0.875rem;
  color: var(--v2-error);
}

.v2-tribe-create__field {
  margin-bottom: 1.25rem;
}

.v2-tribe-create__label {
  display: block;
  margin-bottom: 0.375rem;
  font-family: var(--v2-font-label);
  font-size: 0.8125rem;
  font-weight: 600;
  color: var(--v2-on-surface-variant);
}

.v2-tribe-create__input,
.v2-tribe-create__textarea {
  width: 100%;
  min-height: var(--v2-touch-min);
  padding: 0.625rem 0.875rem;
  border: 1px solid var(--v2-outline-variant);
  border-radius: var(--v2-radius-md);
  font-family: var(--v2-font-label);
  font-size: 0.9375rem;
  background: var(--v2-surface-container-low);
  color: var(--v2-on-surface);
}

.v2-tribe-create__textarea {
  min-height: 6rem;
  resize: vertical;
}

.v2-tribe-create__err {
  display: block;
  margin-top: 0.25rem;
  font-size: 0.75rem;
  color: var(--v2-error);
}

.v2-tribe-create__submit {
  width: 100%;
  min-height: var(--v2-touch-min);
  border: none;
  border-radius: var(--v2-radius-md);
  font-family: var(--v2-font-display);
  font-weight: 700;
  font-size: 1rem;
  color: var(--v2-on-primary);
  background: var(--v2-primary);
  cursor: pointer;
}

.v2-tribe-create__submit:hover {
  filter: brightness(1.05);
}

/* My tribe V2 */
.v2-tribe-my__alert {
  padding: 0.75rem 1rem;
  border-radius: var(--v2-radius-md);
  margin-bottom: 1rem;
  font-size: 0.875rem;
}

.v2-tribe-my__alert--error {
  background: color-mix(in srgb, var(--v2-error) 12%, #fff);
  color: var(--v2-error);
}

.v2-tribe-my__alert--ok {
  background: color-mix(in srgb, #1b8736 14%, #fff);
  color: #0d4f1f;
}

.v2-tribe-my__panel {
  padding: 1.25rem;
  border-radius: 1rem;
  margin-bottom: 1rem;
  border: 1px solid var(--v2-outline-variant);
}

.v2-tribe-my__panel--warn {
  background: color-mix(in srgb, #9d4300 10%, #fff);
  border-color: color-mix(in srgb, #9d4300 25%, var(--v2-outline-variant));
}

.v2-tribe-my__panel--info {
  background: var(--v2-surface-container-low);
}

.v2-tribe-my__panel-title {
  margin: 0 0 0.5rem;
  font-size: 1.125rem;
  font-weight: 700;
}

.v2-tribe-my__panel-text {
  margin: 0 0 1rem;
  font-size: 0.875rem;
  color: var(--v2-on-surface-variant);
}

.v2-tribe-my__row {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
}

.v2-tribe-my__inline-form {
  display: inline-flex;
  margin: 0;
}

.v2-tribe-my__btn-primary {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: var(--v2-touch-min);
  padding: 0 1.25rem;
  border-radius: var(--v2-radius-md);
  font-weight: 700;
  font-size: 0.875rem;
  color: var(--v2-on-primary);
  background: var(--v2-primary);
  border: none;
  text-decoration: none;
  cursor: pointer;
}

.v2-tribe-my__btn-secondary {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: var(--v2-touch-min);
  padding: 0 1.25rem;
  border-radius: var(--v2-radius-md);
  font-weight: 600;
  font-size: 0.875rem;
  color: var(--v2-on-surface);
  background: var(--v2-surface-container-lowest);
  border: 1px solid var(--v2-outline-variant);
  text-decoration: none;
  cursor: pointer;
  gap: 0.375rem;
}

.v2-tribe-my__btn-danger {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: var(--v2-touch-min);
  padding: 0 1rem;
  border-radius: var(--v2-radius-md);
  font-weight: 600;
  font-size: 0.875rem;
  color: var(--v2-on-error);
  background: var(--v2-error);
  border: none;
  cursor: pointer;
}

.v2-tribe-my__btn-ghost {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: var(--v2-touch-min);
  padding: 0 0.875rem;
  border-radius: var(--v2-radius-md);
  font-weight: 600;
  font-size: 0.8125rem;
  color: var(--v2-primary);
  background: transparent;
  border: 1px solid transparent;
  text-decoration: none;
}

.v2-tribe-my__btn-ghost:hover {
  background: color-mix(in srgb, var(--v2-primary-fixed) 35%, transparent);
}

.v2-tribe-my__hero {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 1.25rem;
  padding: 1.5rem;
  margin-bottom: 1.5rem;
  background: var(--v2-surface-container-lowest);
  border-radius: 1.5rem;
  border: 1px solid var(--v2-outline-variant);
  box-shadow: var(--v2-elevation-1);
  overflow: hidden;
}

@media (min-width: 768px) {
  .v2-tribe-my__hero {
    flex-direction: row;
    align-items: flex-start;
    padding: 2rem;
  }
}

.v2-tribe-my__hero-emblem {
  width: 7.5rem;
  height: 7.5rem;
  border-radius: 1rem;
  background: var(--v2-secondary-container);
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  flex-shrink: 0;
}

.v2-tribe-my__hero-emblem img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.v2-tribe-my__hero-icon {
  font-size: 3.5rem !important;
  color: var(--v2-primary);
}

.v2-tribe-my__hero-main {
  flex: 1;
  min-width: 0;
  text-align: center;
}

@media (min-width: 768px) {
  .v2-tribe-my__hero-main {
    text-align: left;
  }
}

.v2-tribe-my__hero-title {
  margin: 0 0 0.5rem;
  font-family: var(--v2-font-display);
  font-size: clamp(1.375rem, 3vw, 1.75rem);
  font-weight: 800;
  color: var(--v2-on-surface);
}

.v2-tribe-my__hero-desc {
  margin: 0 0 1rem;
  font-size: 0.9375rem;
  color: var(--v2-on-surface-variant);
}

.v2-tribe-my__chips {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  justify-content: center;
  margin-bottom: 1rem;
}

@media (min-width: 768px) {
  .v2-tribe-my__chips {
    justify-content: flex-start;
  }
}

.v2-tribe-my__chip {
  display: inline-flex;
  align-items: center;
  gap: 0.25rem;
  padding: 0.375rem 0.75rem;
  border-radius: 9999px;
  font-family: var(--v2-font-label);
  font-size: 0.8125rem;
  font-weight: 600;
  background: var(--v2-surface-container-low);
  color: var(--v2-on-surface-variant);
}

.v2-tribe-my__chip .material-symbols-outlined {
  font-size: 1.125rem;
}

.v2-tribe-my__hero-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  justify-content: center;
}

@media (min-width: 768px) {
  .v2-tribe-my__hero-actions {
    justify-content: flex-start;
  }
}

.v2-tribe-my__layout {
  display: grid;
  gap: 1.25rem;
  grid-template-columns: 1fr;
}

@media (min-width: 992px) {
  .v2-tribe-my__layout {
    grid-template-columns: 1fr 280px;
    align-items: start;
  }
}

.v2-tribe-my__section {
  padding: 1.25rem;
  background: var(--v2-surface-container-lowest);
  border-radius: 1rem;
  border: 1px solid var(--v2-outline-variant);
  margin-bottom: 1rem;
}

.v2-tribe-my__section-title {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  margin: 0 0 1rem;
  font-family: var(--v2-font-display);
  font-size: 1.0625rem;
  font-weight: 700;
  color: var(--v2-on-surface);
}

.v2-tribe-my__section-title .material-symbols-outlined {
  font-size: 1.25rem;
  color: var(--v2-primary);
}

.v2-tribe-my__member-list {
  list-style: none;
  margin: 0;
  padding: 0;
}

.v2-tribe-my__member {
  display: grid;
  grid-template-columns: auto 1fr auto;
  gap: 0.75rem;
  align-items: center;
  padding: 0.625rem 0;
  border-bottom: 1px solid var(--v2-outline-variant);
}

.v2-tribe-my__member:last-child {
  border-bottom: none;
}

.v2-tribe-my__member-avatar {
  width: 2.5rem;
  height: 2.5rem;
  border-radius: 50%;
  overflow: hidden;
  background: var(--v2-secondary-container);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.v2-tribe-my__member-avatar img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.v2-tribe-my__member-avatar .material-symbols-outlined {
  font-size: 1.25rem;
  color: var(--v2-on-surface-variant);
}

.v2-tribe-my__member-info {
  min-width: 0;
}

.v2-tribe-my__member-name {
  display: block;
  font-weight: 600;
  font-size: 0.9375rem;
  color: var(--v2-on-surface);
  text-decoration: none;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.v2-tribe-my__member-name:hover {
  color: var(--v2-primary);
}

.v2-tribe-my__member-role {
  display: block;
  font-size: 0.75rem;
  color: var(--v2-on-surface-variant);
}

.v2-tribe-my__member-role--admin {
  color: var(--v2-primary);
  font-weight: 600;
}

.v2-tribe-my__member-pts {
  font-family: var(--v2-font-label);
  font-weight: 700;
  font-size: 0.875rem;
  color: var(--v2-on-surface);
}

.v2-tribe-my__muted {
  margin: 0;
  font-size: 0.875rem;
  color: var(--v2-on-surface-variant);
}

.v2-tribe-my__request-list {
  list-style: none;
  margin: 0;
  padding: 0;
}

.v2-tribe-my__request {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.75rem;
  padding: 0.75rem 0;
  border-bottom: 1px solid var(--v2-outline-variant);
}

.v2-tribe-my__request:last-child {
  border-bottom: none;
}

.v2-tribe-my__request-name {
  flex: 1 1 8rem;
  font-weight: 600;
  font-size: 0.875rem;
}

.v2-tribe-my__request-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
}

.v2-tribe-my__btn-small {
  min-height: 2.5rem;
  padding: 0 0.75rem;
  border: none;
  border-radius: 0.5rem;
  font-size: 0.8125rem;
  font-weight: 600;
  cursor: pointer;
}

.v2-tribe-my__btn-small--ok {
  color: #fff;
  background: #1b6b2a;
}

.v2-tribe-my__btn-small--no {
  color: var(--v2-on-surface);
  background: var(--v2-surface-variant);
}

.v2-tribe-my__aside-card {
  padding: 1.25rem;
  background: var(--v2-surface-container-lowest);
  border-radius: 1rem;
  border: 1px dashed var(--v2-outline-variant);
}

.v2-tribe-my__aside-title {
  margin: 0 0 0.5rem;
  font-size: 1rem;
  font-weight: 700;
}
