:root {
  --ink: #0f172a;
  --muted: #64748b;
  --line: rgba(148, 163, 184, 0.28);
  --glass: rgba(255, 255, 255, 0.68);
  --glass-strong: rgba(255, 255, 255, 0.82);
  --blue: #2563eb;
  --cyan: #0891b2;
  --rose: #e11d48;
  --green: #10b981;
  --green-dark: #047857;
  --shadow: 0 24px 90px rgba(15, 23, 42, 0.22);
  --flag-width: 22px;
  --flag-height: 16px;
  --page-gutter: clamp(10px, 2.2vw, 28px);
  --section-width: min(1160px, calc(100% - var(--page-gutter) - var(--page-gutter)));
  --radius-ios: 16px;
  --radius-icon: min(22.37%, 12px);
  --radius-control: min(22.37%, 10px);
  --radius-label: clamp(5px, 0.5em, 12px);
  --radius-flag: min(22.37%, 6px);
}

*,
*::before,
*::after {
  box-sizing: border-box;
}

html {
  scroll-behavior: auto;
  scrollbar-width: thin;
  scrollbar-color: rgba(16, 185, 129, 0.8) rgba(15, 23, 42, 0.12);
  -webkit-text-size-adjust: 100%;
  text-size-adjust: 100%;
  overflow-x: hidden;
}

img,
svg,
video,
canvas {
  max-width: 100%;
}

::-webkit-scrollbar {
  width: 10px;
  height: 10px;
}

::-webkit-scrollbar-track {
  background: rgba(15, 23, 42, 0.08);
  border-radius: 999px;
}

::-webkit-scrollbar-thumb {
  border: 2px solid rgba(246, 249, 252, 0.9);
  border-radius: 999px;
  background: linear-gradient(180deg, var(--green), var(--green-dark));
}

::-webkit-scrollbar-thumb:hover {
  background: linear-gradient(180deg, #34d399, var(--green-dark));
}

@media (max-width: 768px) and (orientation: portrait) {
  html {
    scrollbar-color: rgba(16, 185, 129, 0.86) rgba(7, 17, 31, 0.22);
  }

  ::-webkit-scrollbar {
    width: 6px;
    height: 6px;
  }

  ::-webkit-scrollbar-track {
    background: rgba(7, 17, 31, 0.22);
  }

  ::-webkit-scrollbar-thumb {
    border: 0;
  }
}

body {
  margin: 0;
  font-family: Inter, "Microsoft YaHei", "PingFang SC", system-ui, sans-serif;
  color: var(--ink);
  background: #f6f9fc;
  overflow-x: hidden;
  touch-action: pan-y;
}

body.region-blocked {
  overflow: hidden;
}

body.region-blocked .topbar,
body.region-blocked main,
body.region-blocked .mini-chat,
body.region-blocked .ai-launcher,
body.region-blocked .scroll-dock {
  display: none;
}

[data-admin-hidden="true"] {
  display: none !important;
}

[hidden] {
  display: none !important;
}

.hero-text,
.chat-stream .bubble p,
.mini-stream .bubble p,
.api-panel > div:first-child p:not(.eyebrow),
.api-cards article p,
.tool-card.ad-card > p {
  white-space: pre-line;
}

.region-legal-notice {
  display: none;
  min-height: 100svh;
  padding: 24px;
  place-items: center;
  color: #fff;
  background:
    linear-gradient(135deg, rgba(15, 23, 42, 0.96), rgba(30, 41, 59, 0.94)),
    radial-gradient(circle at 50% 0%, rgba(37, 99, 235, 0.22), transparent 40%);
}

.region-legal-notice.show {
  display: grid;
}

.region-legal-card {
  width: min(560px, 100%);
  padding: 28px;
  border: 1px solid rgba(255, 255, 255, 0.18);
  border-radius: var(--radius-ios);
  background: rgba(15, 23, 42, 0.58);
  box-shadow: 0 22px 70px rgba(0, 0, 0, 0.32);
  text-align: center;
}

.region-legal-card h1 {
  margin: 0 0 12px;
  font-size: clamp(26px, 5vw, 42px);
  line-height: 1.1;
}

.region-legal-card p {
  margin: 0;
  color: rgba(255, 255, 255, 0.78);
  font-size: 16px;
  line-height: 1.7;
}

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

button,
input,
select,
textarea {
  font: inherit;
  min-width: 0;
}

button,
[role="button"],
a[href] {
  cursor: pointer;
  touch-action: manipulation;
  -webkit-tap-highlight-color: transparent;
}

button,
button *,
[role="button"],
[role="button"] * {
  user-select: text;
  -webkit-user-select: text;
}

button:not(:disabled).instant-click-active,
[role="button"]:not([aria-disabled="true"]).instant-click-active,
a[href].instant-click-active {
  opacity: 0.96;
  transition: none !important;
}

input,
textarea,
select,
[contenteditable="true"] {
  user-select: text;
  -webkit-user-select: text;
}

#aiQuery,
#miniQuery {
  user-select: text !important;
  -webkit-user-select: text !important;
  caret-color: #fff;
}

#aiQuery::selection,
#miniQuery::selection {
  color: #fff;
  background: rgba(37, 99, 235, 0.78);
}

button:focus-visible,
a:focus-visible,
input:focus-visible {
  outline: 3px solid rgba(16, 185, 129, 0.34);
  outline-offset: 2px;
}

.topbar {
  position: fixed;
  top: 16px;
  left: 50%;
  z-index: 40;
  width: var(--section-width);
  transform: translateX(-50%);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 20px;
  padding: 12px 14px;
  border: 1px solid rgba(255, 255, 255, 0.62);
  border-radius: var(--radius-ios);
  background: rgba(255, 255, 255, 0.72);
  backdrop-filter: blur(22px);
  box-shadow: 0 12px 40px rgba(15, 23, 42, 0.12);
  transition: transform 220ms ease, opacity 160ms ease;
}

.brand,
.nav-links,
.nav-actions,
.filter-row,
.quick-prompts,
.action-pair,
.metrics,
.scene-buttons {
  display: flex;
  align-items: center;
}

.brand {
  gap: 10px;
  font-weight: 900;
}

.brand-mark {
  display: grid;
  width: 36px;
  height: 36px;
  place-items: center;
  border-radius: var(--radius-ios);
  color: #fff;
  background: linear-gradient(135deg, var(--blue), var(--cyan));
}

.nav-links {
  gap: clamp(12px, 2vw, 22px);
  color: #334155;
  font-size: 14px;
  font-weight: 700;
}

.nav-links a,
.nav-cta,
.theme-text,
.tool-link,
.start-chat {
  min-width: 0;
  overflow: hidden;
  white-space: nowrap;
}

.nav-cta {
  display: inline-grid;
  place-items: center;
  border: 0;
  padding: 10px 16px;
  border-radius: var(--radius-ios);
  color: #fff;
  background: linear-gradient(135deg, var(--green), var(--green-dark));
  font-size: 14px;
  font-weight: 800;
  cursor: pointer;
}

.nav-actions {
  gap: 8px;
}

.mobile-menu-toggle,
.mobile-menu-panel,
.group-more-btn {
  display: none;
}

.language-switcher {
  position: relative;
}

.language-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  width: clamp(92px, 10vw, 118px);
  min-width: 92px;
  height: 39px;
  padding: 0 12px;
  border: 1px solid rgba(15, 23, 42, 0.16);
  border-radius: var(--radius-ios);
  color: var(--ink);
  background: rgba(255, 255, 255, 0.82);
  box-shadow: 0 8px 24px rgba(15, 23, 42, 0.08);
  cursor: pointer;
  font-size: 13px;
  font-weight: 900;
}

.language-text {
  min-width: 0;
  max-width: 74px;
  overflow: hidden;
  white-space: nowrap;
}

.language-flag {
  display: inline-flex;
  width: var(--flag-width);
  min-width: var(--flag-width);
  height: var(--flag-height);
  align-items: center;
  justify-content: center;
  line-height: 1;
}

.language-flag .country-flag {
  width: var(--flag-width);
  height: var(--flag-height);
}

.language-menu {
  position: absolute;
  top: calc(100% + 10px);
  right: 0;
  z-index: 55;
  display: grid;
  gap: 6px;
  width: 220px;
  max-height: min(620px, calc(100vh - 96px));
  overflow-x: hidden;
  overflow-y: auto;
  padding: 8px;
  border: 1px solid rgba(255, 255, 255, 0.36);
  border-radius: var(--radius-ios);
  background: rgba(255, 255, 255, 0.94);
  box-shadow: 0 18px 48px rgba(15, 23, 42, 0.16);
  opacity: 0;
  transform: translateY(8px) scale(0.98);
  pointer-events: none;
  transition: opacity 160ms ease, transform 160ms ease;
}

.language-switcher.open .language-menu {
  opacity: 1;
  transform: translateY(0) scale(1);
  pointer-events: auto;
}

.language-option {
  display: grid;
  grid-template-columns: 28px minmax(0, 1fr) auto;
  align-items: center;
  gap: 8px;
  min-height: 40px;
  padding: 0 8px;
  border: 1px solid transparent;
  border-radius: var(--radius-ios);
  color: var(--ink);
  background: transparent;
  cursor: pointer;
  font-size: 13px;
  font-weight: 900;
  text-align: left;
}

.language-option-label,
.model-menu-category-label {
  min-width: 0;
  overflow: hidden;
  white-space: nowrap;
}

.language-option:hover,
.language-option.active {
  border-color: rgba(16, 185, 129, 0.26);
  background: rgba(16, 185, 129, 0.1);
}

.language-option:disabled,
.language-option[aria-disabled="true"] {
  cursor: not-allowed;
  opacity: 0.52;
}

.language-option:disabled:hover,
.language-option[aria-disabled="true"]:hover {
  border-color: transparent;
  background: transparent;
}

.language-option small {
  color: var(--muted);
  font-size: 11px;
  font-weight: 800;
}

.register-trigger {
  color: var(--ink);
  background: rgba(255, 255, 255, 0.86);
}

body.user-logged-in .login-trigger,
body.user-logged-in .register-trigger,
.nav-actions .login-trigger[hidden],
.nav-actions .register-trigger[hidden] {
  display: none !important;
}

body:not(.user-logged-in) .user-menu {
  display: none !important;
}

.user-menu {
  position: relative;
}

.user-menu[hidden] {
  display: none !important;
}

.user-menu-btn {
  display: inline-flex;
  align-items: center;
  gap: 9px;
  height: 43px;
  max-width: 198px;
  padding: 0 11px 0 8px;
  border: 1px solid rgba(16, 185, 129, 0.26);
  border-radius: var(--radius-ios);
  color: var(--ink);
  background: rgba(255, 255, 255, 0.88);
  box-shadow: 0 10px 26px rgba(15, 23, 42, 0.1);
  cursor: pointer;
  text-align: left;
}

.user-avatar-small {
  display: inline-grid;
  flex: 0 0 auto;
  width: 30px;
  height: 30px;
  place-items: center;
  border-radius: var(--radius-ios);
  color: #fff;
  background: linear-gradient(135deg, var(--green), var(--blue));
  font-size: 13px;
  font-weight: 1000;
}

.generated-user-avatar {
  position: relative;
  display: inline-grid;
  place-items: center;
  overflow: hidden;
  color: #fff;
  background:
    radial-gradient(circle at 18% 14%, rgba(255, 255, 255, 0.92) 0 10%, transparent 23%),
    radial-gradient(circle at 82% 12%, var(--avatar-c) 0 15%, transparent 33%),
    radial-gradient(circle at 18% 86%, rgba(255, 255, 255, 0.3) 0 16%, transparent 34%),
    linear-gradient(145deg, var(--avatar-a), var(--avatar-b));
  box-shadow:
    inset 0 0 0 1px rgba(255, 255, 255, 0.58),
    inset 0 -5px 12px rgba(15, 23, 42, 0.11),
    0 8px 18px rgba(15, 23, 42, 0.13);
}

.generated-user-avatar svg {
  display: block;
  width: 100%;
  height: 100%;
}

.user-menu-copy {
  display: grid;
  min-width: 0;
  line-height: 1.15;
}

.user-menu-copy strong,
.user-menu-copy small {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.user-menu-copy strong {
  font-size: 13px;
  font-weight: 1000;
}

.user-menu-copy small {
  color: var(--muted);
  font-size: 11px;
  font-weight: 800;
}

.user-panel {
  position: absolute;
  top: calc(100% + 10px);
  right: 0;
  z-index: 70;
  width: min(340px, calc(100vw - 28px));
  opacity: 0;
  transform: translateY(8px) scale(0.98);
  pointer-events: none;
  transition: opacity 160ms ease, transform 160ms ease;
}

.user-menu.open .user-panel {
  opacity: 1;
  transform: translateY(0) scale(1);
  pointer-events: auto;
}

.user-panel-card {
  padding: 16px;
  border: 1px solid rgba(255, 255, 255, 0.36);
  border-radius: var(--radius-ios);
  color: #fff;
  background: rgba(15, 23, 42, 0.92);
  box-shadow: 0 20px 54px rgba(15, 23, 42, 0.28);
  backdrop-filter: blur(22px);
}

.user-panel-card h3 {
  margin: 4px 0 6px;
  font-size: 22px;
  line-height: 1.2;
}

.user-panel-head {
  display: flex;
  align-items: center;
  gap: 12px;
}

.user-panel-avatar {
  flex: 0 0 56px;
  width: 56px;
  height: 56px;
  border-radius: var(--radius-ios);
}

.user-panel-subtitle,
.user-identity {
  color: rgba(255, 255, 255, 0.7);
  line-height: 1.55;
}

.user-identity {
  display: grid;
  gap: 4px;
  margin-top: 12px;
  padding: 11px;
  border-radius: var(--radius-ios);
  background: rgba(255, 255, 255, 0.1);
  font-size: 13px;
}

.user-identity span,
.user-identity strong {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.user-stats {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 8px;
  margin-top: 12px;
}

.user-stats div {
  padding: 10px;
  border-radius: var(--radius-ios);
  background: rgba(255, 255, 255, 0.1);
}

.user-stats span,
.user-stats strong {
  display: block;
}

.user-stats span {
  color: rgba(255, 255, 255, 0.62);
  font-size: 11px;
  font-weight: 900;
}

.user-stats strong {
  margin-top: 5px;
  font-size: 15px;
}

.user-panel-actions {
  display: grid;
  grid-template-columns: 1fr 1fr;
  grid-auto-rows: minmax(40px, auto);
  gap: 8px;
  margin-top: 12px;
}

.user-panel-actions button,
.user-panel-actions a {
  display: grid;
  min-height: 40px;
  place-items: center;
  min-width: 0;
  border: 0;
  border-radius: var(--radius-control);
  color: #fff;
  background: linear-gradient(135deg, rgba(16, 185, 129, 0.9), rgba(4, 120, 87, 0.9));
  cursor: pointer;
  font-size: 13px;
  font-weight: 900;
}

.user-panel-actions [data-user-logout] {
  grid-column: 1 / -1;
  color: #fecaca;
  background: rgba(239, 68, 68, 0.16);
}

.user-system-page {
  width: var(--section-width);
  display: grid;
  gap: 14px;
  margin: 0 auto 36px;
}

.user-system-head {
  display: flex;
  gap: 16px;
  align-items: center;
  justify-content: space-between;
  padding: 20px;
  border: 1px solid rgba(8, 145, 178, 0.16);
  border-radius: var(--radius-ios);
  background:
    linear-gradient(135deg, rgba(224, 242, 254, 0.78), rgba(236, 253, 245, 0.86)),
    rgba(255, 255, 255, 0.8);
}

.user-system-head h2 {
  margin: 4px 0 8px;
  color: #0369a1;
  font-size: clamp(30px, 5vw, 50px);
  line-height: 1.08;
}

.user-system-head p:not(.eyebrow) {
  max-width: 720px;
  margin: 0;
  color: var(--muted);
  line-height: 1.7;
}

.user-system-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  justify-content: flex-end;
}

.user-system-recharge,
.user-system-api-key {
  min-height: 44px;
  padding: 0 18px;
  border: 0;
  border-radius: var(--radius-control);
  color: #fff;
  background: linear-gradient(135deg, var(--green), var(--green-dark));
  cursor: pointer;
  font-weight: 900;
}

.user-system-api-key {
  background: linear-gradient(135deg, var(--blue), var(--cyan));
}

.user-system-stats,
.user-system-grid {
  display: grid;
  gap: 6px;
}

.user-system-stats {
  grid-template-columns: repeat(6, minmax(0, 1fr));
}

.user-system-stats article,
.user-system-grid section,
.user-api-key-section {
  border: 1px solid var(--line);
  border-radius: var(--radius-ios);
  background: rgba(255, 255, 255, 0.88);
  box-shadow: 0 14px 38px rgba(15, 23, 42, 0.07);
}

.user-system-stats article {
  display: grid;
  gap: 5px;
  padding: 12px;
  border-color: rgba(148, 163, 184, 0.22);
  transition: border-color 0.16s ease, box-shadow 0.16s ease, transform 0.16s ease, background 0.16s ease;
}

.user-system-stats article:hover,
.user-system-grid section:hover {
  border-color: rgba(14, 165, 233, 0.5);
  background: linear-gradient(135deg, rgba(224, 242, 254, 0.88), rgba(236, 253, 245, 0.92));
  box-shadow: 0 10px 28px rgba(8, 145, 178, 0.14);
  transform: translateY(-1px);
}

.user-system-stats span,
.user-system-row span,
.user-system-row small {
  min-width: 0;
  overflow: hidden;
  color: var(--muted);
  text-overflow: ellipsis;
  white-space: nowrap;
}

.user-system-stats strong {
  min-width: 0;
  overflow-wrap: anywhere;
  font-size: 18px;
}

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

.user-system-grid section {
  padding: 14px;
  border-color: rgba(148, 163, 184, 0.22);
  transition: border-color 0.16s ease, box-shadow 0.16s ease, transform 0.16s ease, background 0.16s ease;
}

.user-system-grid h3,
.user-api-key-section h3 {
  margin: 0 0 10px;
  font-size: 18px;
}

.user-system-row,
.user-system-empty {
  display: grid;
  gap: 4px;
  padding: 10px 0;
  border-top: 1px solid rgba(15, 23, 42, 0.08);
}

.user-system-row:first-of-type {
  border-top: 0;
}

.user-system-row strong {
  min-width: 0;
  overflow-wrap: anywhere;
}

.user-system-row small,
.user-system-empty {
  font-size: 12px;
}

.user-system-toggle {
  display: flex;
  gap: 10px;
  align-items: center;
  padding: 10px 0;
  border-top: 1px solid rgba(15, 23, 42, 0.08);
  cursor: pointer;
}

.user-system-toggle input {
  width: 18px;
  height: 18px;
  flex: 0 0 auto;
  accent-color: var(--green);
}

.user-system-toggle span {
  display: grid;
  gap: 3px;
  min-width: 0;
}

.user-system-toggle strong {
  font-size: 15px;
}

.user-system-toggle small {
  color: var(--muted);
  line-height: 1.5;
}

.user-api-key-card {
  display: grid;
  gap: 10px;
  padding-top: 10px;
  border-top: 1px solid rgba(15, 23, 42, 0.08);
}

.user-api-key-list {
  display: grid;
  gap: 10px;
  margin-top: 10px;
}

.user-api-key-item,
.user-api-key-empty {
  display: grid;
  gap: 10px;
  padding: 12px;
  border: 1px solid rgba(59, 130, 246, 0.18);
  border-radius: 12px;
  background: linear-gradient(135deg, rgba(248, 250, 252, 0.94), rgba(239, 246, 255, 0.86));
  box-shadow: 0 10px 26px rgba(15, 23, 42, 0.05);
}

.user-api-key-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 12px;
  align-items: center;
}

.user-api-key-main {
  display: grid;
  min-width: 0;
  gap: 4px;
}

.user-api-key-main span {
  position: relative;
  display: block;
  width: fit-content;
  max-width: 100%;
  padding: 6px 8px;
  border-radius: 8px;
  border: 1px solid rgba(37, 99, 235, 0.12);
  background: rgba(219, 234, 254, 0.72);
  min-width: 0;
  color: #3b5b86;
  font: 800 12px/1.4 ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
  overflow-wrap: anywhere;
  cursor: pointer;
}

.user-api-key-main span.copied {
  border-color: rgba(16, 185, 129, 0.32);
  color: #047857;
  background: rgba(209, 250, 229, 0.9);
}

.user-api-key-main span.copied::after {
  content: attr(data-copy-tip);
  margin-left: 8px;
  color: #059669;
  font: 900 12px/1.4 Inter, "Microsoft YaHei", sans-serif;
}

.user-api-key-main small {
  display: flex;
  flex-wrap: nowrap;
  gap: 8px;
  min-width: 0;
  overflow: hidden;
  white-space: nowrap;
  color: var(--muted);
  font-size: 12px;
  font-weight: 800;
  line-height: 1.45;
}

.user-api-key-main small span {
  width: auto;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  overflow-wrap: normal;
}

.user-api-key-item-head {
  display: flex;
  gap: 8px;
  align-items: center;
  justify-content: space-between;
}

.user-api-key-item-head span {
  min-width: 0;
  color: var(--muted);
  font: 800 12px/1.4 ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
  overflow-wrap: anywhere;
}

.user-api-key-section {
  padding: 16px;
  border-color: rgba(14, 165, 233, 0.18);
  border-radius: 22px;
  background:
    linear-gradient(135deg, rgba(224, 242, 254, 0.72), rgba(236, 253, 245, 0.68)),
    rgba(255, 255, 255, 0.58);
}

.user-api-key-section-head {
  display: flex;
  gap: 10px;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 10px;
  width: 100%;
  max-width: 100%;
  white-space: nowrap;
}

.user-api-key-section-head h3 {
  margin: 0;
}

.user-api-key-section-head button {
  flex: 0 0 auto;
  margin-left: auto;
  min-height: 38px;
  width: auto;
  max-width: 100%;
  padding: 0 16px;
  border: 1px solid rgba(37, 99, 235, 0.24);
  border-radius: var(--radius-control);
  color: #fff;
  background: linear-gradient(135deg, #2563eb, #14b8a6);
  box-shadow: 0 10px 22px rgba(37, 99, 235, 0.22);
  cursor: pointer;
  font-weight: 1000;
  white-space: nowrap;
}

.user-api-key-usage {
  display: grid;
  gap: 10px;
  margin-top: 12px;
  padding-top: 12px;
  border-top: 1px solid rgba(15, 23, 42, 0.08);
}

.user-api-key-usage-panel {
  display: grid;
  gap: 10px;
  padding: 12px;
  border: 1px solid rgba(20, 184, 166, 0.2);
  border-radius: 12px;
  background: rgba(240, 253, 250, 0.78);
}

.user-api-key-usage-stats {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 8px;
}

.user-api-key-usage-stats span {
  display: grid;
  gap: 3px;
  padding: 10px;
  border-radius: 10px;
  background: rgba(255, 255, 255, 0.72);
}

.user-api-key-usage-stats small,
.user-api-key-usage-record small {
  color: var(--muted);
  font-size: 12px;
  font-weight: 800;
}

.user-api-key-usage-records {
  display: grid;
  gap: 6px;
}

.user-api-key-usage-record {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto auto;
  gap: 8px;
  align-items: center;
  padding: 8px 0;
  border-top: 1px solid rgba(15, 23, 42, 0.08);
}

.user-api-key-usage-record strong {
  min-width: 0;
  overflow-wrap: anywhere;
}

.user-api-key-card label {
  display: grid;
  gap: 6px;
}

.user-api-key-settings-panel {
  display: grid;
  gap: 10px;
  padding-top: 10px;
  border-top: 1px solid rgba(15, 23, 42, 0.08);
}

.user-api-key-settings-panel[hidden] {
  display: none;
}

.user-api-key-settings-panel label {
  display: grid;
  gap: 6px;
}

.user-api-key-limits {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
}

.user-api-key-card label span,
.user-api-key-settings-panel label span,
.user-api-key-card small {
  color: var(--muted);
  font-size: 12px;
  font-weight: 800;
  line-height: 1.5;
}

.user-api-key-card input,
.user-api-key-settings-panel input {
  width: 100%;
  min-width: 0;
  min-height: 40px;
  padding: 0 10px;
  border: 1px solid rgba(15, 23, 42, 0.12);
  border-radius: 10px;
  color: var(--ink);
  background: rgba(248, 250, 252, 0.92);
  font: 800 13px/1.4 ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
}

.user-api-key-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
  justify-content: flex-end;
}

.user-api-key-actions button {
  min-height: 38px;
  width: auto;
  max-width: 100%;
  padding: 0 14px;
  border: 0;
  border-radius: var(--radius-control);
  color: #fff;
  background: linear-gradient(135deg, #2563eb, #0ea5e9);
  cursor: pointer;
  font-weight: 1000;
}

.user-api-key-actions button.copied {
  background: linear-gradient(135deg, #10b981, #059669);
}

.user-api-key-actions button.danger {
  background: linear-gradient(135deg, #ef4444, #9f1239);
}

@media (max-width: 900px) {
  .user-system-head {
    align-items: stretch;
    flex-direction: column;
  }

  .user-system-stats,
  .user-system-grid,
  .user-api-key-limits {
    grid-template-columns: 1fr;
  }

  .user-system-actions {
    justify-content: stretch;
  }

  .user-system-actions button {
    flex: 1 1 140px;
  }

  .user-api-key-item-head {
    align-items: flex-start;
    flex-direction: column;
  }

  .user-api-key-row {
    grid-template-columns: 1fr;
  }

  .user-api-key-main small {
    display: grid;
    gap: 2px;
    overflow: visible;
    white-space: normal;
  }

  .user-api-key-main small span {
    white-space: normal;
    overflow-wrap: anywhere;
  }

  .user-api-key-usage-stats,
  .user-api-key-usage-record {
    grid-template-columns: 1fr;
  }

  .user-api-key-actions {
    justify-content: flex-start;
  }
}

.theme-toggle {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  min-width: 82px;
  height: 39px;
  justify-content: center;
  padding: 0 12px;
  border: 1px solid rgba(15, 23, 42, 0.16);
  border-radius: var(--radius-ios);
  color: var(--ink);
  background: rgba(255, 255, 255, 0.82);
  cursor: pointer;
  font-weight: 900;
  box-shadow: 0 8px 24px rgba(15, 23, 42, 0.08);
}

.theme-symbol {
  position: relative;
  width: 18px;
  height: 18px;
  border-radius: var(--radius-ios);
  background: var(--ink);
  box-shadow: inset -6px -2px 0 #fff;
}

body.night-theme .theme-symbol {
  background: #facc15;
  box-shadow: 0 0 0 4px rgba(250, 204, 21, 0.2);
}

.theme-text {
  font-size: 13px;
}

body.night-theme .theme-toggle {
  color: #f8fafc;
  border-color: rgba(250, 204, 21, 0.28);
  background: rgba(15, 23, 42, 0.78);
}

body.night-theme .language-btn {
  color: #f8fafc;
  border-color: rgba(148, 163, 184, 0.22);
  background: rgba(15, 23, 42, 0.78);
}

body.night-theme .user-menu-btn {
  color: #f8fafc;
  border-color: rgba(16, 185, 129, 0.28);
  background: rgba(15, 23, 42, 0.78);
}

body.night-theme .user-menu-copy small {
  color: #a8b5c7;
}

body.night-theme .language-menu {
  border-color: rgba(148, 163, 184, 0.24);
  background: rgba(15, 23, 42, 0.94);
}

body.night-theme .language-option {
  color: #e5edf7;
}

body.night-theme .language-option small {
  color: #a8b5c7;
}

main {
  overflow: visible;
}

body:not(.page-ai-tools) #aiToolsPage,
body:not(.page-api) #api,
body:not(.page-user-system) #userSystem {
  display: none;
}

body.page-ai-tools .hero,
body.page-ai-tools .metrics,
body.page-ai-tools #directory,
body.page-ai-tools #toolGrid,
body.page-ai-tools #scenes,
body.page-ai-tools #siteFooter,
body.page-ai-tools #api,
body.page-api .hero,
body.page-api .metrics,
body.page-api #directory,
body.page-api #toolGrid,
body.page-api #scenes,
body.page-api #siteFooter,
body.page-api #aiToolsPage,
body.page-user-system .hero,
body.page-user-system .metrics,
body.page-user-system #directory,
body.page-user-system #toolGrid,
body.page-user-system #scenes,
body.page-user-system #api,
body.page-user-system #siteFooter,
body.page-user-system #aiToolsPage {
  display: none !important;
}

body.page-ai-tools .mini-chat,
body.page-ai-tools .ai-launcher,
body.page-api .mini-chat,
body.page-api .ai-launcher,
body.page-user-system .mini-chat,
body.page-user-system .ai-launcher {
  display: none !important;
}

body.page-ai-tools main,
body.page-api main,
body.page-user-system main {
  min-height: 100vh;
  padding-top: 120px;
}

.site-footer {
  width: var(--section-width);
  margin: 30px auto 24px;
  padding: 14px 18px;
  border: 1px solid var(--line);
  border-radius: var(--radius-ios);
  background: rgba(255, 255, 255, 0.9);
}

.site-footer-inner {
  display: flex;
  flex-wrap: wrap;
  gap: 10px 18px;
  align-items: center;
  justify-content: center;
}

.site-footer-item {
  display: inline-flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: baseline;
  justify-content: center;
  margin: 0;
  color: var(--muted);
  font-size: 13px;
  text-align: center;
}

.site-footer-item > span {
  color: #475569;
  font-weight: 800;
}

.site-footer-item > strong {
  color: var(--ink);
  font-weight: 900;
  letter-spacing: 0.1px;
}

body.night-theme .site-footer {
  border-color: rgba(148, 163, 184, 0.18);
  background: rgba(15, 23, 42, 0.82);
}

body.night-theme .site-footer-item > span {
  color: #a8b5c7;
}

body.night-theme .site-footer-item > strong {
  color: #e5edf7;
}



body.night-theme {
  color: #e5edf7;
  background: #07111f;
}

body.night-theme .topbar,
body.night-theme .metrics,
body.night-theme .section-head,
body.night-theme .tool-grid,
body.night-theme .tool-card,
body.night-theme .featured,
body.night-theme .scenes,
body.night-theme .api-panel,
body.night-theme .login-panel {
  color: #e5edf7;
  border-color: rgba(148, 163, 184, 0.18);
  background: rgba(15, 23, 42, 0.82);
}

body.night-theme .nav-links,
body.night-theme .tool-card p,
body.night-theme .metrics span,
body.night-theme .api-panel p,
body.night-theme .login-panel p:not(.eyebrow) {
  color: #a8b5c7;
}

body.night-theme .section-head,
body.night-theme .tool-grid {
  border: 1px solid rgba(148, 163, 184, 0.14);
  border-radius: var(--radius-ios);
  box-shadow: 0 18px 46px rgba(0, 0, 0, 0.18);
}

body.night-theme .section-head {
  padding: 18px;
  margin-bottom: 14px;
}

body.night-theme .tool-grid {
  padding: 16px;
}

body.night-theme .ad-card {
  border-color: rgba(56, 189, 248, 0.28);
  background:
    linear-gradient(135deg, rgba(15, 23, 42, 0.92), rgba(6, 78, 59, 0.72)),
    #0f172a;
}

body.night-theme .ad-badge,
body.night-theme .ad-tag {
  color: #bae6fd;
  background: rgba(14, 165, 233, 0.18);
}

body.night-theme .section-head h2,
body.night-theme .featured h2,
body.night-theme .scenes h2,
body.night-theme .api-panel h2 {
  color: #e5edf7;
}

body.night-theme .filter,
body.night-theme .scene-buttons button,
body.night-theme .api-cards article,
body.night-theme .feature-strip article {
  color: #e5edf7;
  border-color: rgba(148, 163, 184, 0.2);
  background: rgba(15, 23, 42, 0.78);
}

body.night-theme .tag {
  color: #cbd5e1;
  background: rgba(148, 163, 184, 0.14);
}

body.night-theme .empty-state {
  color: #a8b5c7;
  border-color: rgba(148, 163, 184, 0.24);
  background: rgba(15, 23, 42, 0.78);
}

body.night-theme .hero-bg::after {
  background:
    radial-gradient(circle at 30% 28%, rgba(255, 255, 255, 0.14), transparent 28%),
    linear-gradient(to bottom, transparent 0 66%, #07111f 100%);
}

body.site-style-tech {
  --green: #10b981;
  --green-dark: #047857;
  --blue: #2563eb;
  --cyan: #0891b2;
}

body.site-style-gemini {
  --green: #34a853;
  --green-dark: #188038;
  --blue: #4285f4;
  --cyan: #1a73e8;
  color: #202124;
  background: #f8fbff;
}

body.site-style-chatgpt {
  --green: #10a37f;
  --green-dark: #08775f;
  --blue: #111827;
  --cyan: #10a37f;
  color: #202123;
  background: #f7f7f2;
}

body.site-style-gemini .topbar,
body.site-style-chatgpt .topbar {
  border-color: rgba(15, 23, 42, 0.08);
  background: rgba(255, 255, 255, 0.86);
  box-shadow: 0 12px 34px rgba(60, 64, 67, 0.13);
}

body.site-style-gemini .hero-bg {
  background:
    linear-gradient(115deg, rgba(66, 133, 244, 0.16), transparent 28%),
    linear-gradient(245deg, rgba(52, 168, 83, 0.14), transparent 30%),
    linear-gradient(180deg, #ffffff 0%, #eef5ff 55%, #f8fbff 100%);
  animation: none;
}

body.site-style-gemini .hero-bg::after {
  background:
    linear-gradient(rgba(66, 133, 244, 0.08) 1px, transparent 1px),
    linear-gradient(90deg, rgba(66, 133, 244, 0.08) 1px, transparent 1px),
    linear-gradient(to bottom, transparent 0 68%, #f8fbff 100%);
  background-size: 46px 46px, 46px 46px, auto;
}

body.site-style-chatgpt .hero-bg {
  background:
    linear-gradient(140deg, rgba(16, 163, 127, 0.1), transparent 36%),
    linear-gradient(180deg, #f7f7f2 0%, #ffffff 56%, #f7f7f2 100%);
  animation: none;
}

body.site-style-chatgpt .hero-bg::after {
  background:
    linear-gradient(rgba(32, 33, 35, 0.045) 1px, transparent 1px),
    linear-gradient(90deg, rgba(32, 33, 35, 0.045) 1px, transparent 1px),
    linear-gradient(to bottom, transparent 0 70%, #f7f7f2 100%);
  background-size: 52px 52px, 52px 52px, auto;
}

body.site-style-gemini .tech-field,
body.site-style-chatgpt .tech-field {
  opacity: 0.18;
}

body.site-style-gemini .hero-content,
body.site-style-chatgpt .hero-content {
  color: #202124;
}

body.site-style-chatgpt .hero-content {
  color: #202123;
}

body.site-style-gemini .eyebrow {
  color: #1a73e8;
}

body.site-style-chatgpt .eyebrow {
  color: #10a37f;
}

body.site-style-gemini .hero-text,
body.site-style-chatgpt .hero-text {
  color: #5f6368;
}

body.site-style-chatgpt .hero-text {
  color: #565869;
}

body.site-style-gemini .model-bar,
body.site-style-gemini .chat-stream,
body.site-style-gemini .quick-prompts button {
  color: #202124;
  border-color: rgba(66, 133, 244, 0.18);
  background: rgba(255, 255, 255, 0.76);
  box-shadow: 0 16px 44px rgba(60, 64, 67, 0.12);
}

body.site-style-chatgpt .model-bar,
body.site-style-chatgpt .chat-stream,
body.site-style-chatgpt .quick-prompts button {
  color: #202123;
  border-color: rgba(32, 33, 35, 0.1);
  background: rgba(255, 255, 255, 0.86);
  box-shadow: 0 14px 36px rgba(32, 33, 35, 0.1);
}

body.site-style-gemini .model-pill,
body.site-style-gemini .more-model-btn,
body.site-style-gemini .chat-model-btn,
body.site-style-gemini .model-version-btn,
body.site-style-gemini .composer-input-shell {
  color: #202124;
  border-color: rgba(66, 133, 244, 0.18);
  background: rgba(255, 255, 255, 0.84);
}

body.site-style-chatgpt .model-pill,
body.site-style-chatgpt .more-model-btn,
body.site-style-chatgpt .chat-model-btn,
body.site-style-chatgpt .model-version-btn,
body.site-style-chatgpt .composer-input-shell {
  color: #202123;
  border-color: rgba(32, 33, 35, 0.12);
  background: rgba(255, 255, 255, 0.9);
}

body.site-style-gemini .chat-model-label,
body.site-style-gemini .model-version-label,
body.site-style-gemini #aiQuery::placeholder {
  color: #5f6368;
}

body.site-style-chatgpt .chat-model-label,
body.site-style-chatgpt .model-version-label,
body.site-style-chatgpt #aiQuery::placeholder {
  color: #6e6e80;
}

body.site-style-gemini #aiQuery,
body.site-style-chatgpt #aiQuery {
  color: #202124;
}

body.site-style-chatgpt #aiQuery {
  color: #202123;
}

body.site-style-gemini .search-chat-box,
body.site-style-chatgpt .search-chat-box,
body.site-style-gemini.chat-mode .search-chat-box,
body.site-style-chatgpt.chat-mode .search-chat-box {
  border-color: rgba(15, 23, 42, 0.08);
  background: rgba(255, 255, 255, 0.86);
}

body.site-style-gemini .solid-btn {
  color: #fff;
  background: linear-gradient(135deg, #4285f4, #34a853);
}

body.site-style-gemini .ghost-btn {
  color: #1a73e8;
  border-color: rgba(66, 133, 244, 0.22);
  background: #fff;
}

body.site-style-chatgpt .solid-btn {
  color: #fff;
  background: #10a37f;
}

body.site-style-chatgpt .ghost-btn {
  color: #202123;
  border-color: rgba(32, 33, 35, 0.18);
  background: #fff;
}

body.site-style-gemini .attach-btn,
body.site-style-chatgpt .attach-btn {
  color: #202124;
}

body.site-style-chatgpt .attach-btn {
  color: #202123;
}

body.site-style-gemini .attachment-chip,
body.site-style-chatgpt .attachment-chip {
  border-color: rgba(15, 23, 42, 0.12);
  background: #fff;
}

body.site-style-gemini .metrics,
body.site-style-gemini .tool-card,
body.site-style-gemini .featured,
body.site-style-gemini .scenes,
body.site-style-gemini .api-panel {
  border-color: rgba(66, 133, 244, 0.12);
  box-shadow: 0 10px 28px rgba(60, 64, 67, 0.08);
}

body.site-style-chatgpt .metrics,
body.site-style-chatgpt .tool-card,
body.site-style-chatgpt .featured,
body.site-style-chatgpt .scenes,
body.site-style-chatgpt .api-panel {
  border-color: rgba(32, 33, 35, 0.1);
  box-shadow: 0 8px 24px rgba(32, 33, 35, 0.07);
}

.hero {
  position: relative;
  min-height: 100vh;
  display: grid;
  place-items: center;
  padding: 112px 18px clamp(238px, 30vh, 292px);
  isolation: isolate;
}

.hero-bg {
  position: absolute;
  inset: 0;
  z-index: -2;
  background:
    linear-gradient(135deg, rgba(2, 6, 23, 0.78), rgba(8, 47, 73, 0.48) 45%, rgba(6, 78, 59, 0.34)),
    url("https://images.unsplash.com/photo-1639322537228-f710d846310a?auto=format&fit=crop&w=1800&q=85") center/cover;
  animation: none;
}

.hero-bg::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: -1;
  background:
    linear-gradient(rgba(255, 255, 255, 0.035) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255, 255, 255, 0.035) 1px, transparent 1px),
    radial-gradient(circle at 28% 25%, rgba(34, 211, 238, 0.22), transparent 28%),
    radial-gradient(circle at 72% 34%, rgba(16, 185, 129, 0.2), transparent 24%),
    linear-gradient(to bottom, transparent 0 66%, #f6f9fc 100%);
  background-size: 44px 44px, 44px 44px, auto, auto, auto;
}

.tech-field {
  position: absolute;
  inset: 0;
  z-index: -1;
  overflow: hidden;
  pointer-events: none;
}

.tech-field span {
  display: none;
}

.hero-content {
  width: min(1040px, 100%);
  margin: 0 auto;
  text-align: center;
  color: #fff;
  transform: translateY(clamp(-12px, -2vh, -4px));
  transition: opacity 260ms ease, transform 340ms cubic-bezier(0.22, 1, 0.36, 1);
}

.eyebrow {
  margin: 0 0 12px;
  color: #67e8f9;
  font-size: 13px;
  font-weight: 900;
  letter-spacing: 0;
  text-transform: uppercase;
}

h1,
h2,
h3,
p {
  margin-top: 0;
}

h1 {
  width: min(920px, 100%);
  margin: 0 auto 20px;
  font-size: clamp(42px, 7vw, 82px);
  line-height: 1;
  letter-spacing: 0;
}

.hero-text {
  width: min(780px, 100%);
  margin: 0 auto;
  color: rgba(255, 255, 255, 0.86);
  font-size: 18px;
  line-height: 1.78;
}

.hero-console {
  --hero-console-gap: 12px;
  --hero-expand-size: clamp(28px, 2.2vw, 34px);
  --hero-expand-gap: clamp(7px, 0.9vw, 10px);
  --hero-control-rail: calc(var(--hero-expand-size) + var(--hero-expand-gap));
  --hero-linked-width: calc(100% - var(--hero-control-rail));
  position: absolute;
  left: 50%;
  bottom: 38px;
  z-index: 50;
  width: min(calc(1040px + var(--hero-control-rail)), calc(100% - var(--page-gutter) - var(--page-gutter)));
  transform: translateX(-50%);
  display: grid;
  gap: var(--hero-console-gap);
  overflow: visible;
  pointer-events: none;
  opacity: 1;
  transition: none;
  max-height: calc(100vh - 132px);
}

body.chat-mode:not(.mini-mode) .hero-console {
  top: calc(var(--topbar-bottom, 78px) + var(--hero-console-gap));
  bottom: 38px;
  grid-template-rows: auto auto auto auto;
  max-height: none;
  align-content: end;
}

.hero:has(.more-models.open) .hero-console,
body.model-menu-open .hero-console {
  z-index: 2147483640;
}

.model-bar,
.search-chat-row,
.search-chat-box,
.chat-stream,
.quick-prompts {
  pointer-events: auto;
}

.model-bar,
.chat-stream,
.quick-prompts {
  width: var(--hero-linked-width);
  justify-self: start;
}

.chat-stream {
  visibility: hidden;
  display: grid;
  gap: 10px;
  max-height: 46vh;
  overflow: auto;
  padding: 14px;
  border: 1px solid rgba(255, 255, 255, 0.36);
  border-radius: var(--radius-ios);
  background: rgba(15, 23, 42, 0.36);
  backdrop-filter: blur(18px);
  box-shadow: var(--shadow);
  scrollbar-width: thin;
  scrollbar-color: rgba(16, 185, 129, 0.86) rgba(255, 255, 255, 0.08);
  opacity: 0;
  transform: translateY(16px) scale(0.98);
  pointer-events: none;
  transition: none;
}

body.chat-mode .chat-stream {
  visibility: visible;
  min-height: 0;
  max-height: var(--hero-chat-max-height, 46vh);
  height: auto;
  align-self: end;
  align-content: start;
  align-items: start;
  padding: 18px 18px 44px;
  opacity: 1;
  transform: translateY(0) scale(1);
  pointer-events: auto;
  transition: none;
  animation: none;
}

body.chat-mode .chat-stream:empty {
  display: none;
}

body.chat-mode.empty-chat-expanded .chat-stream:empty {
  display: grid;
  min-height: var(--hero-chat-max-height, 46vh);
  height: var(--hero-chat-max-height, 46vh);
  max-height: var(--hero-chat-max-height, 46vh);
}

@media (min-width: 769px) {
  body.desktop-chat-focus-mode.chat-mode:not(.mini-mode):not(.chat-fullscreen) .topbar {
    transform: translate(-50%, calc(-100% - 24px));
    opacity: 0;
    pointer-events: none;
    transition-duration: 320ms, 220ms;
    transition-timing-function: cubic-bezier(0.22, 1, 0.36, 1), ease;
  }

  body.desktop-chat-focus-mode.chat-mode:not(.mini-mode):not(.chat-fullscreen) .hero {
    min-height: 100vh;
    height: 100vh;
    padding: 0 18px;
    overflow: visible;
    place-items: stretch;
    pointer-events: none;
  }

  body.desktop-chat-focus-mode.chat-mode:not(.mini-mode):not(.chat-fullscreen) .hero-content {
    opacity: 0;
    transform: translateY(-28px) scale(0.985);
    pointer-events: none;
  }

  body.desktop-chat-focus-mode.chat-mode:not(.mini-mode):not(.chat-fullscreen) .hero-console {
    position: fixed;
    top: clamp(14px, 2.2vh, 24px);
    bottom: clamp(10px, 1.8vh, 18px);
    z-index: 80;
    grid-template-rows: minmax(0, 1fr) auto auto;
    align-content: stretch;
    max-height: none;
    pointer-events: none;
    animation: desktopChatFocusConsoleIn 360ms cubic-bezier(0.22, 1, 0.36, 1) both;
  }

  body.desktop-chat-focus-mode.chat-mode:not(.mini-mode):not(.chat-fullscreen) .quick-prompts,
  body.desktop-chat-focus-mode.chat-mode:not(.mini-mode):not(.chat-fullscreen) .fullscreen-utility-bar {
    display: none;
  }

  body.desktop-chat-focus-mode.chat-mode:not(.mini-mode):not(.chat-fullscreen) .model-bar {
    align-self: end;
    margin: 0;
  }

  body.desktop-chat-focus-mode.chat-mode:not(.mini-mode):not(.chat-fullscreen) .chat-stream {
    align-self: stretch;
    height: 100%;
    max-height: none;
    min-height: 0;
    margin: 0;
    opacity: 1;
    transform: translateY(0) scale(1);
    animation: none;
  }

  body.desktop-chat-focus-mode.chat-mode.empty-chat-expanded:not(.mini-mode):not(.chat-fullscreen) .chat-stream:empty {
    min-height: 0;
    height: 100%;
    max-height: none;
  }

  body.desktop-chat-focus-mode.chat-mode:not(.mini-mode):not(.chat-fullscreen) .search-chat-row {
    align-self: end;
    margin: 0;
    transform: none;
  }

  body.desktop-chat-focus-mode.chat-mode:not(.mini-mode):not(.chat-fullscreen) .search-chat-box {
    background: rgb(255, 255, 255);
    backdrop-filter: none;
  }

  @keyframes desktopChatFocusConsoleIn {
    from {
      opacity: 0.92;
      transform: translate(-50%, 14px) scale(0.985);
    }
    to {
      opacity: 1;
      transform: translate(-50%, 0) scale(1);
    }
  }

  @keyframes desktopChatFocusStreamIn {
    from {
      opacity: 0;
      transform: translateY(10px);
    }
    to {
      opacity: 1;
      transform: translateY(0);
    }
  }
}

.bubble {
  --ai-message-content-left: 44px;
  display: flex;
  align-items: flex-start;
  gap: 10px;
  min-width: 0;
  color: #fff;
  opacity: 1;
  transform: translateY(0) scale(1);
  animation: none;
}

.bubble.user {
  position: relative;
  justify-content: flex-end;
  z-index: 1;
}

.bubble.ai {
  position: relative;
  z-index: 1;
}

.bubble.user::before {
  content: "";
  position: absolute;
  top: -12px;
  right: -10px;
  bottom: -42px;
  width: min(86%, 720px);
  z-index: 0;
}

.bubble.user:hover,
.bubble.user:focus-within,
.bubble.ai:hover,
.bubble.ai:focus-within {
  z-index: 6;
}

.bubble.ai::before {
  content: "";
  position: absolute;
  top: -12px;
  left: -10px;
  bottom: -42px;
  width: min(86%, 720px);
  z-index: 0;
}

.bubble.user .user-avatar {
  position: relative;
  z-index: 1;
  order: 2;
}

.bubble.user .user-bubble-body {
  position: relative;
  z-index: 1;
  flex: 0 1 auto;
  display: grid;
  justify-items: end;
  width: fit-content;
  max-width: min(78%, 620px);
  min-width: 0;
}

.bubble p {
  flex: 0 1 auto;
  width: fit-content;
  max-width: min(78%, 620px);
  min-width: 0;
  margin: 0;
  padding: 12px 14px;
  border: 1px solid rgba(255, 255, 255, 0.28);
  border-radius: var(--radius-ios);
  background: rgba(255, 255, 255, 0.18);
  backdrop-filter: blur(14px);
  line-height: 1.62;
  box-shadow: 0 10px 34px rgba(15, 23, 42, 0.18);
  overflow-wrap: anywhere;
  word-break: break-word;
}

.chat-stream .bubble.ai p {
  max-width: min(72%, 560px, calc(100% - 58px));
}

.bubble.user p {
  background: rgba(16, 185, 129, 0.58);
}

.bubble.user .user-bubble-body > .bubble-text {
  max-width: 100%;
}

.bubble-actions {
  position: absolute;
  top: 100%;
  right: 4px;
  bottom: auto;
  z-index: 4;
  display: inline-flex;
  gap: 5px;
  padding: 6px 0 0;
  border: 0;
  border-radius: var(--radius-ios);
  background: transparent;
  box-shadow: none;
  backdrop-filter: none;
  opacity: 0;
  transform: translateY(-2px);
  pointer-events: none;
  transition: opacity 150ms ease, transform 150ms ease;
}

.bubble.user:hover .bubble-actions,
.bubble.user:focus-within .bubble-actions {
  opacity: 1;
  transform: translateY(0);
  pointer-events: auto;
}

.bubble.user.editing .bubble-actions {
  display: none;
}

.bubble.ai.has-actions {
  margin-bottom: 44px;
}

.bubble.ai .bubble-actions {
  left: 50px;
  right: auto;
}

.bubble.ai:hover .bubble-actions,
.bubble.ai:focus-within .bubble-actions {
  opacity: 1;
  transform: translateY(0);
  pointer-events: auto;
}

.bubble-action-btn {
  position: relative;
  display: inline-grid;
  place-items: center;
  width: 38px;
  height: 38px;
  border: 0;
  border-radius: var(--radius-ios);
  color: rgba(255, 255, 255, 0.78);
  background: rgba(15, 23, 42, 0.2);
  cursor: pointer;
  font-size: 0;
  box-shadow: 0 8px 20px rgba(15, 23, 42, 0.14);
  transition: color 140ms ease, background 140ms ease, opacity 140ms ease, transform 140ms ease;
}

.bubble-action-btn:hover,
.bubble-action-btn.copied,
.bubble-action-btn.active {
  color: #fff;
  background: rgba(15, 23, 42, 0.34);
  transform: translateY(-1px);
}

.bubble-action-btn.copied {
  color: #bbf7d0;
  background: rgba(16, 185, 129, 0.14);
}

.bubble-action-btn.active {
  color: #0f172a;
  background: rgba(255, 255, 255, 0.9);
}

.bubble-action-btn svg {
  width: 18px;
  height: 18px;
  fill: none;
  stroke: currentColor;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.copy-action::before,
.copy-action::after {
  content: "";
  position: absolute;
  width: 12px;
  height: 14px;
  border: 2px solid currentColor;
  border-radius: var(--radius-ios);
}

.copy-action::before {
  left: 10px;
  top: 9px;
  background: transparent;
  opacity: 0.55;
}

.copy-action::after {
  left: 14px;
  top: 13px;
  background: transparent;
}

.copy-action.copied::before {
  left: 11px;
  top: 12px;
  width: 16px;
  height: 9px;
  border: 0;
  border-left: 2px solid currentColor;
  border-bottom: 2px solid currentColor;
  border-radius: 0;
  opacity: 1;
  transform: rotate(-45deg);
}

.copy-action.copied::after {
  display: none;
}

.edit-action::before {
  content: "";
  position: absolute;
  width: 19px;
  height: 5px;
  border-radius: 999px;
  background: currentColor;
  transform: rotate(-42deg);
  box-shadow: none;
}

.edit-action::after {
  content: "";
  position: absolute;
  right: 9px;
  bottom: 9px;
  width: 12px;
  height: 3px;
  border-radius: 999px;
  background: currentColor;
  opacity: 0.5;
  transform: rotate(-10deg);
}

.bubble-edit-input {
  width: min(520px, 72vw);
  max-width: 100%;
  min-height: 86px;
  padding: 12px 13px;
  border: 1px solid rgba(255, 255, 255, 0.34);
  border-radius: var(--radius-ios);
  color: #fff;
  background: rgba(15, 23, 42, 0.42);
  box-shadow: 0 10px 28px rgba(15, 23, 42, 0.16);
  outline: none;
  resize: vertical;
  font: inherit;
  line-height: 1.58;
}

.bubble-edit-input:focus {
  border-color: rgba(16, 185, 129, 0.72);
  box-shadow: 0 0 0 3px rgba(16, 185, 129, 0.16), 0 10px 28px rgba(15, 23, 42, 0.18);
}

.bubble-edit-actions {
  display: inline-flex;
  justify-content: flex-end;
  gap: 8px;
  width: 100%;
  margin-top: 8px;
}

.bubble-edit-actions button {
  min-width: 62px;
  height: 34px;
  border: 1px solid rgba(255, 255, 255, 0.18);
  border-radius: 999px;
  color: #fff;
  background: rgba(255, 255, 255, 0.08);
  cursor: pointer;
  font-weight: 900;
  transition: background 140ms ease, border-color 140ms ease, transform 140ms ease;
}

.bubble-edit-actions button:hover {
  border-color: rgba(255, 255, 255, 0.32);
  background: rgba(255, 255, 255, 0.14);
}

.bubble-edit-done {
  border-color: rgba(255, 255, 255, 0.92) !important;
  color: #0f172a !important;
  background: rgba(255, 255, 255, 0.92) !important;
}

.bubble-edit-done:hover {
  background: #fff !important;
}

.api-fallback-note {
  display: block;
  margin-bottom: 8px;
  padding-bottom: 8px;
  border-bottom: 1px solid rgba(255, 255, 255, 0.22);
  color: #ffe8a3;
  font-weight: 850;
}

.quota-warning-title,
.quota-warning-text {
  display: block;
}

.quota-warning-title {
  margin-bottom: 6px;
  color: #fef3c7;
  font-weight: 1000;
}

.quota-warning-text {
  color: rgba(255, 255, 255, 0.9);
}

.quota-action-row {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 8px;
  margin-top: 12px;
  white-space: normal;
}

.quota-action-btn {
  display: inline-grid;
  place-items: center;
  min-width: 102px;
  min-height: 42px;
  padding: 0 16px;
  border: 0;
  border-radius: var(--radius-ios);
  color: #fff;
  cursor: pointer;
  font-weight: 900;
  line-height: 1;
  white-space: nowrap;
  box-shadow: 0 10px 24px rgba(15, 23, 42, 0.16);
  transition: transform 150ms ease, filter 150ms ease;
}

.quota-action-btn:hover {
  transform: translateY(-1px);
  filter: brightness(1.03);
}

.quota-action-btn.free {
  background: linear-gradient(135deg, #22c55e, #10b981);
}

.quota-action-btn.recharge {
  background: linear-gradient(135deg, #60a5fa, #2563eb);
}

.quota-action-btn.signin {
  background: linear-gradient(135deg, #f59e0b, #f97316);
}

.quota-action-btn.invite {
  background: linear-gradient(135deg, #8b5cf6, #7c3aed);
}

.quota-action-btn.login {
  background: linear-gradient(135deg, #14b8a6, #0f766e);
}

.quota-action-btn.register {
  background: linear-gradient(135deg, #fb7185, #e11d48);
}

.model-fallback-actions {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 8px;
  margin-top: 12px;
}

.model-fallback-btn {
  min-width: 88px;
  min-height: 38px;
  padding: 0 14px;
  border: 0;
  border-radius: var(--radius-icon);
  color: #fff;
  cursor: pointer;
  font-weight: 900;
}

.bubble-actions .bubble-action-btn {
  border-radius: var(--radius-icon) !important;
}

.model-fallback-btn.cancel {
  color: #334155;
  background: rgba(226, 232, 240, 0.95);
}

.model-fallback-btn.agree {
  background: linear-gradient(135deg, #22c55e, #10b981);
}

.model-fallback-btn:disabled {
  cursor: default;
  opacity: 0.62;
}

.quota-payment-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 34px;
  margin-top: 10px;
  padding: 0 12px;
  border-radius: var(--radius-ios);
  color: #0f172a !important;
  background: #fff;
  font-weight: 950;
  text-decoration: none;
}

.quota-payment-continue {
  min-width: 104px;
  background: linear-gradient(135deg, #38bdf8, #22c55e);
  box-shadow: 0 10px 24px rgba(14, 165, 233, 0.24);
}

.quota-payment-error {
  display: block;
  margin-top: 8px;
  color: rgba(255, 255, 255, 0.78);
  font-size: 12px;
  line-height: 1.5;
  word-break: break-word;
}

.mini-stream .quota-action-row {
  justify-content: flex-end;
  gap: 6px;
  margin-top: 9px;
}

.mini-stream .quota-action-btn {
  min-width: 78px;
  min-height: 32px;
  padding: 0 10px;
  font-size: 14px;
  line-height: 1.55;
}

.typing-dot {
  display: inline-block;
  width: 6px;
  height: 6px;
  margin: 0 2px;
  border-radius: var(--radius-ios);
  background: rgba(255, 255, 255, 0.84);
  animation: typingPulse 900ms ease-in-out infinite;
}

.typing-dot:nth-child(2) {
  animation-delay: 120ms;
}

.typing-dot:nth-child(3) {
  animation-delay: 240ms;
}

.avatar {
  flex: 0 0 34px;
  display: grid;
  width: 34px;
  height: 34px;
  place-items: center;
  border-radius: var(--radius-ios);
  color: var(--ink);
  background: rgba(255, 255, 255, 0.84);
  font-size: 12px;
  font-weight: 900;
}

.user-avatar {
  position: relative;
  flex: 0 0 36px;
  width: 36px;
  height: 36px;
  border-radius: var(--radius-ios);
  background: linear-gradient(145deg, #fef3c7, #f9a8d4 64%, #60a5fa);
  box-shadow: inset 0 -4px 0 rgba(15, 23, 42, 0.12);
}

.user-avatar.generated-user-avatar {
  padding: 0;
  border-radius: var(--radius-ios);
  background:
    radial-gradient(circle at 18% 14%, rgba(255, 255, 255, 0.92) 0 10%, transparent 23%),
    radial-gradient(circle at 82% 12%, var(--avatar-c) 0 15%, transparent 33%),
    radial-gradient(circle at 18% 86%, rgba(255, 255, 255, 0.3) 0 16%, transparent 34%),
    linear-gradient(145deg, var(--avatar-a), var(--avatar-b));
}

.user-avatar.user-panel-avatar {
  flex: 0 0 56px;
  width: 56px;
  height: 56px;
  border-radius: var(--radius-ios);
}

.user-avatar.generated-user-avatar::before,
.user-avatar.generated-user-avatar::after,
.user-avatar.generated-user-avatar .user-smile {
  display: none;
}

.user-avatar::before,
.user-avatar::after {
  content: "";
  position: absolute;
  top: 12px;
  width: 5px;
  height: 5px;
  border-radius: 50%;
  background: #0f172a;
}

.user-avatar::before {
  left: 10px;
}

.user-avatar::after {
  right: 10px;
}

.user-smile {
  position: absolute;
  left: 50%;
  bottom: 9px;
  width: 12px;
  height: 6px;
  transform: translateX(-50%);
  border-bottom: 2px solid #0f172a;
  border-radius: 0 0 12px 12px;
}

.model-bar {
  position: relative;
  z-index: 120;
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  align-items: center;
  justify-content: flex-start;
  gap: 8px;
  padding: 8px 10px;
  border: 1px solid rgba(255, 255, 255, 0.34);
  border-radius: var(--radius-ios);
  color: rgba(255, 255, 255, 0.86);
  background: rgba(15, 23, 42, 0.22);
  backdrop-filter: blur(16px);
  overflow: visible;
}

.model-bar:has(.more-models.open),
.search-chat-row:has(.chat-model-picker.open),
.search-chat-row:has(.model-version-picker.open) {
  position: relative;
  z-index: 2147483642;
  overflow: visible;
}

.model-bar > span {
  flex: 0 0 auto;
  min-width: 0;
  font-size: 16px;
  font-weight: 900;
  white-space: nowrap;
}

.model-switcher {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  justify-content: flex-start;
  gap: 8px;
  width: 100%;
  min-width: 0;
}

.model-pills {
  width: auto;
  max-width: none;
  display: flex;
  flex-wrap: nowrap;
  justify-content: flex-start;
  gap: 7px;
  min-width: 0;
  overflow: auto;
  scrollbar-width: none;
  scrollbar-color: rgba(16, 185, 129, 0.86) rgba(255, 255, 255, 0.08);
}

.model-pills::-webkit-scrollbar {
  display: none;
}

.model-pill {
  flex: 0 0 auto;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 7px;
  box-sizing: border-box;
  height: 36px;
  min-height: 36px;
  padding: 0 10px 0 6px;
  border: 1px solid rgba(255, 255, 255, 0.28);
  border-radius: var(--radius-ios);
  color: #fff;
  background: rgba(255, 255, 255, 0.12);
  cursor: pointer;
  font-size: 12px;
  font-weight: 900;
  line-height: 1;
  white-space: nowrap;
  transition: background 160ms ease, border-color 160ms ease, box-shadow 160ms ease;
}

.model-pill > .app-icon {
  flex: 0 0 auto;
  width: 26px;
  height: 26px;
  border-radius: var(--radius-ios);
  background: rgba(255, 255, 255, 0.92);
}

.app-icon {
  display: grid;
  place-items: center;
  border-radius: var(--radius-ios);
  border: 1px solid rgba(15, 23, 42, 0.1);
  color: transparent;
  background: rgba(255, 255, 255, 0.96);
  box-shadow: 0 6px 18px rgba(15, 23, 42, 0.12);
  overflow: hidden;
  position: relative;
  font-size: 0;
}

.app-icon img {
  grid-area: 1 / 1;
}

.app-icon img {
  z-index: 1;
  width: 74%;
  height: 74%;
  object-fit: contain;
  background: transparent;
}

.app-icon.icon-missing::before {
  content: "AI";
  color: #0f172a;
  font-size: 10px;
  font-weight: 1000;
}

.app-icon.custom-generated-icon {
  border: 0;
  color: #fff;
  background:
    radial-gradient(circle at 30% 22%, rgba(255, 255, 255, 0.48), transparent 28%),
    linear-gradient(135deg, var(--custom-icon-a, #22c55e), var(--custom-icon-b, #2563eb));
  box-shadow: 0 7px 18px rgba(15, 23, 42, 0.18);
  font-size: 12px;
  font-weight: 1000;
  letter-spacing: 0;
  text-transform: uppercase;
}

.app-icon.custom-generated-icon > span {
  line-height: 1;
}

.logo.app-icon.custom-generated-icon {
  font-size: 18px;
}

.brand-mark[data-ai-model-icon],
.avatar[data-ai-model-icon],
.mini-avatar[data-ai-model-icon],
.ai-launcher [data-ai-model-icon] {
  overflow: hidden;
  padding: 0;
  color: transparent;
}

.brand-mark[data-ai-model-icon] > .app-icon,
.avatar[data-ai-model-icon] > .app-icon,
.mini-avatar[data-ai-model-icon] > .app-icon,
.ai-launcher [data-ai-model-icon] > .app-icon {
  width: 100%;
  height: 100%;
}

.ai-avatar {
  overflow: hidden;
  padding: 0;
  border: 0;
  color: transparent;
  background: transparent;
  box-shadow: none;
}

.ai-avatar > .app-icon {
  flex: 0 0 auto;
  width: 100%;
  height: 100%;
  border-radius: inherit;
}

.model-pill .app-icon,
.more-model-option .app-icon,
.chat-model-option .app-icon,
.mini-model-option .app-icon {
  flex: 0 0 auto;
  width: 26px;
  height: 26px;
}

.model-pill .app-icon img,
.more-model-option .app-icon img,
.chat-model-btn .app-icon img,
.chat-model-option .app-icon img,
.mini-model-option .app-icon img,
.mini-avatar .app-icon img,
.ai-avatar .app-icon img,
.logo.app-icon img {
  width: 74%;
  height: 74%;
  object-fit: contain;
  background: transparent;
}

.app-icon.original-brand-icon,
.model-pill > .app-icon.original-brand-icon,
.more-model-option > .app-icon.original-brand-icon,
.chat-model-btn > .app-icon.original-brand-icon,
.chat-model-option > .app-icon.original-brand-icon,
.mini-model-option > .app-icon.original-brand-icon,
.mini-avatar .app-icon.original-brand-icon,
.ai-avatar > .app-icon.original-brand-icon,
.logo.app-icon.original-brand-icon {
  border: 0;
  background: transparent;
  box-shadow: none;
}

.app-icon.original-brand-icon img,
.model-pill .app-icon.original-brand-icon img,
.more-model-option .app-icon.original-brand-icon img,
.chat-model-btn .app-icon.original-brand-icon img,
.chat-model-option .app-icon.original-brand-icon img,
.mini-model-option .app-icon.original-brand-icon img,
.mini-avatar .app-icon.original-brand-icon img,
.ai-avatar .app-icon.original-brand-icon img,
.logo.app-icon.original-brand-icon img {
  width: 100%;
  height: 100%;
  object-fit: contain;
}

.model-pill.active {
  border-color: rgba(255, 255, 255, 0.28);
  background: linear-gradient(135deg, var(--green), var(--green-dark));
  box-shadow: 0 8px 22px rgba(16, 185, 129, 0.24);
}

.more-models {
  position: relative;
  z-index: 1;
  justify-self: end;
  min-width: max-content;
}

.more-models.open {
  z-index: 2147483643;
}

.more-model-btn {
  display: inline-grid;
  place-items: center;
  min-height: 36px;
  padding: 0 12px;
  border: 1px solid rgba(255, 255, 255, 0.3);
  border-radius: var(--radius-ios);
  color: #fff;
  background: rgba(15, 23, 42, 0.32);
  cursor: pointer;
  font-weight: 900;
}

.more-model-menu {
  position: absolute;
  right: 0;
  bottom: calc(100% + 8px);
  z-index: 2147483644;
  display: grid;
  grid-template-columns: repeat(2, minmax(120px, 1fr));
  gap: 8px;
  width: min(420px, 82vw);
  max-height: 340px;
  overflow: auto;
  padding: 10px;
  border: 1px solid rgba(255, 255, 255, 0.36);
  border-radius: var(--radius-ios);
  background: rgba(15, 23, 42, 0.82);
  backdrop-filter: blur(20px);
  box-shadow: var(--shadow);
  scrollbar-width: thin;
  scrollbar-color: rgba(16, 185, 129, 0.86) rgba(255, 255, 255, 0.08);
  opacity: 0;
  transform: translateY(10px) scale(0.98);
  pointer-events: none;
  transition: opacity 180ms ease, transform 180ms ease;
}

.more-model-menu::-webkit-scrollbar,
.model-menu-list::-webkit-scrollbar,
.chat-stream::-webkit-scrollbar,
.mini-stream::-webkit-scrollbar,
.model-version-menu::-webkit-scrollbar,
.model-version-menu-list::-webkit-scrollbar,
.chat-model-menu::-webkit-scrollbar,
.mini-model-menu::-webkit-scrollbar {
  width: 8px;
}

.more-model-menu::-webkit-scrollbar-track,
.model-menu-list::-webkit-scrollbar-track,
.chat-stream::-webkit-scrollbar-track,
.mini-stream::-webkit-scrollbar-track,
.model-version-menu::-webkit-scrollbar-track,
.model-version-menu-list::-webkit-scrollbar-track,
.chat-model-menu::-webkit-scrollbar-track,
.mini-model-menu::-webkit-scrollbar-track {
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.08);
}

.more-model-menu::-webkit-scrollbar-thumb,
.model-menu-list::-webkit-scrollbar-thumb,
.chat-stream::-webkit-scrollbar-thumb,
.mini-stream::-webkit-scrollbar-thumb,
.model-version-menu::-webkit-scrollbar-thumb,
.model-version-menu-list::-webkit-scrollbar-thumb,
.chat-model-menu::-webkit-scrollbar-thumb,
.mini-model-menu::-webkit-scrollbar-thumb {
  border: 2px solid rgba(15, 23, 42, 0.4);
  border-radius: 999px;
  background: linear-gradient(180deg, var(--green), var(--green-dark));
}

.more-models.open .more-model-menu,
.more-model-menu.model-menu-floating.open {
  opacity: 1;
  transform: translateY(0) scale(1);
  pointer-events: auto;
}

.more-model-menu.model-menu-floating {
  position: fixed;
  right: auto;
  bottom: auto;
  z-index: 2147483647;
  transform-origin: right bottom;
}

.more-model-option {
  display: flex;
  align-items: center;
  gap: 8px;
  min-height: 42px;
  padding: 0 8px;
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: var(--radius-ios);
  color: #fff;
  background: rgba(255, 255, 255, 0.08);
  cursor: pointer;
  font-size: 12px;
  font-weight: 900;
}

.more-model-option.active {
  border-color: rgba(16, 185, 129, 0.7);
  background: rgba(16, 185, 129, 0.24);
}

.more-model-option > .app-icon {
  width: 26px;
  height: 26px;
  border-radius: var(--radius-ios);
  background: rgba(255, 255, 255, 0.92);
}

.search-chat-row {
  position: relative;
  z-index: 130;
  display: grid;
  grid-template-columns: minmax(0, var(--hero-linked-width)) var(--hero-expand-size);
  align-items: center;
  gap: var(--hero-expand-gap);
  width: 100%;
  transition: transform 340ms cubic-bezier(0.22, 1, 0.36, 1);
}

.chat-side-controls {
  display: inline-grid;
  gap: 6px;
  align-self: center;
  align-content: center;
  justify-items: center;
  justify-self: center;
  padding: 2px 0;
  transform: none;
}

.search-chat-box {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: max-content max-content minmax(220px, 1fr) auto;
  align-items: stretch;
  gap: 10px;
  width: 100%;
  padding: 10px;
  border: 1px solid rgba(255, 255, 255, 0.5);
  border-radius: var(--radius-ios);
  background: rgba(255, 255, 255, 0.5);
  backdrop-filter: blur(24px);
  box-shadow: var(--shadow);
  transition: transform 280ms ease, background 280ms ease;
}

.search-chat-box :is(.chat-model-btn, .model-version-btn, .composer-input-shell, .solid-btn, .ghost-btn, .action-pair) {
  border-radius: var(--radius-ios) !important;
}

.composer-input-shell {
  display: grid;
  align-items: stretch;
  gap: 8px;
  width: 100%;
  min-width: 0;
  min-height: 58px;
  padding: 6px;
  border: 1px solid rgba(255, 255, 255, 0.52);
  border-radius: var(--radius-ios);
  color: #fff;
  background: rgba(15, 23, 42, 0.38);
  transition: background 160ms ease;
}

.composer-input-shell:focus-within {
  border-color: rgba(255, 255, 255, 0.52);
  box-shadow: none;
}

.composer-input-shell.has-attachments {
  align-content: start;
  gap: 9px;
}

.composer-input-shell.has-image-settings,
.composer-input-shell.has-video-settings {
  align-content: start;
  gap: 2px;
  grid-template-rows: minmax(0, 1fr) auto;
}

.composer-input-row {
  display: grid;
  grid-template-columns: 34px minmax(0, 1fr);
  align-items: center;
  gap: 5px;
  min-width: 0;
}

.image-generation-panel {
  position: relative;
  display: flex;
  align-self: end;
  align-items: center;
  justify-content: flex-start;
  flex-wrap: wrap;
  gap: 7px;
  width: fit-content;
  max-width: 100%;
  min-width: 0;
  margin-left: 0;
  padding: 0 2px 2px;
  box-sizing: border-box;
}

.image-generation-panel[hidden] {
  display: none;
}

.video-generation-panel {
  flex-wrap: nowrap;
  gap: 4px;
  width: 100%;
}

.image-generation-panel label {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  min-width: 0;
  color: rgba(255, 255, 255, 0.88);
  font-size: 12px;
  font-weight: 850;
  white-space: nowrap;
}

.video-generation-panel label {
  flex: 1 1 0;
  gap: 3px;
}

.image-generation-select {
  min-width: max-content;
  height: 28px;
  padding: 0 26px 0 10px;
  border: 1px solid rgba(255, 255, 255, 0.24);
  border-radius: 10px;
  color: #fff;
  background: rgba(15, 23, 42, 0.48) url("data:image/svg+xml,%3Csvg width='10' height='6' viewBox='0 0 10 6' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1L5 5L9 1' stroke='white' stroke-opacity='.9' stroke-width='1.6' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E") no-repeat right 12px center / 10px 6px;
  appearance: none;
  font: inherit;
  font-weight: 900;
  text-align: center;
  text-align-last: center;
  backdrop-filter: blur(18px) saturate(150%);
  cursor: pointer;
}

.video-generation-panel .video-generation-select {
  flex: 1 1 auto;
  width: 100%;
  min-width: 0;
  max-width: 100%;
  padding-right: 20px;
  padding-left: 7px;
  font-size: 11px;
}

.image-generation-select.open {
  border-color: rgba(255, 255, 255, 0.42);
  background-color: rgba(16, 185, 129, 0.72);
}

.image-generation-select.has-device-icon {
  display: inline-grid;
  grid-auto-flow: column;
  align-items: center;
  gap: 6px;
  padding-left: 9px;
}

.generation-device-icon {
  position: relative;
  display: inline-block;
  width: 13px;
  height: 17px;
  border: 2px solid currentColor;
  border-radius: 4px;
  opacity: 0.92;
}

.generation-device-icon::after {
  content: "";
  position: absolute;
  left: 50%;
  bottom: 1px;
  width: 3px;
  height: 3px;
  border-radius: 999px;
  background: currentColor;
  transform: translateX(-50%);
}

.generation-device-icon.monitor {
  width: 20px;
  height: 13px;
  border-radius: 3px;
}

.generation-device-icon.monitor::after {
  bottom: -6px;
  width: 10px;
  height: 2px;
  border-radius: 2px;
}

.generation-device-icon.square {
  width: 16px;
  height: 16px;
  border-radius: 4px;
}

.generation-device-icon.tablet-wide {
  width: 20px;
  height: 15px;
  border-radius: 5px;
}

.generation-device-icon.tablet {
  width: 15px;
  height: 20px;
  border-radius: 5px;
}

.generation-device-text {
  display: inline-flex;
  align-items: baseline;
  gap: 4px;
}

.generation-device-text small {
  color: rgba(255, 255, 255, 0.72);
  font-size: 10px;
  font-weight: 850;
}

.image-generation-select .generation-device-text small {
  display: none;
}

.image-generation-menu {
  position: absolute;
  z-index: 20;
  display: grid;
  min-width: 86px;
  padding: 6px;
  gap: 4px;
  border: 1px solid rgba(255, 255, 255, 0.26);
  border-radius: var(--radius-ios);
  background: rgba(15, 23, 42, 0.58);
  box-shadow: 0 16px 42px rgba(15, 23, 42, 0.22);
  backdrop-filter: blur(22px) saturate(160%);
  transform: translate(-50%, -100%);
}

.image-generation-menu[hidden] {
  display: none;
}

.image-generation-menu button {
  min-height: 28px;
  padding: 0 12px;
  border: 0;
  border-radius: 10px;
  color: #fff;
  background: transparent;
  font: inherit;
  font-weight: 900;
  text-align: center;
}

.image-generation-menu button.device-size-option {
  display: grid;
  grid-template-columns: 24px minmax(0, 1fr);
  align-items: center;
  gap: 8px;
  min-width: 128px;
  padding: 6px 10px;
  text-align: left;
}

.image-generation-menu button.device-size-option .generation-device-text {
  flex-direction: column;
  align-items: flex-start;
  gap: 1px;
}

.image-generation-menu button:hover,
.image-generation-menu button.active {
  background: linear-gradient(135deg, rgba(16, 185, 129, 0.58), rgba(4, 120, 87, 0.58));
  backdrop-filter: blur(18px) saturate(150%);
}

body.chat-mode .search-chat-row {
  transform: translateY(-2px);
}

body.chat-mode .search-chat-box {
  background: rgba(255, 255, 255, 0.62);
}

.chat-model-picker {
  position: relative;
  z-index: 1;
  min-width: 0;
  width: max-content;
  max-width: min(390px, 42vw);
}

.chat-model-picker.open {
  z-index: 2147483643;
}

.chat-model-btn {
  display: grid;
  align-items: center;
  align-content: center;
  justify-items: center;
  gap: 4px;
  width: max-content;
  max-width: min(390px, 42vw);
  min-height: 64px;
  height: 100%;
  padding: 9px 10px;
  border: 1px solid rgba(255, 255, 255, 0.34);
  border-radius: var(--radius-ios);
  color: #fff;
  background: rgba(15, 23, 42, 0.38);
  cursor: pointer;
  font-size: 13px;
  font-weight: 900;
  white-space: nowrap;
  transition: transform 160ms ease, border-color 160ms ease, background 160ms ease;
}

.chat-model-btn,
.model-version-btn {
  min-height: var(--composer-control-height, 64px);
}

.chat-model-label {
  color: rgba(255, 255, 255, 0.72);
  font-size: 12px;
  font-weight: 900;
  line-height: 1;
}

.chat-model-main {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-wrap: wrap;
  gap: 6px;
  min-width: 0;
  width: auto;
  max-width: 100%;
  row-gap: 4px;
  align-self: center;
}

.chat-model-main .model-option-name {
  min-width: 0;
  max-width: none;
  overflow: visible;
  text-align: center;
  white-space: normal;
  word-break: keep-all;
  overflow-wrap: anywhere;
}

.chat-model-btn:hover,
.chat-model-picker.open .chat-model-btn {
  transform: translateY(-1px);
  border-color: rgba(16, 185, 129, 0.7);
  background: linear-gradient(135deg, rgba(16, 185, 129, 0.72), rgba(4, 120, 87, 0.72));
}

.chat-model-btn > .app-icon {
  flex: 0 0 auto;
  width: 30px;
  height: 30px;
  border-radius: var(--radius-ios);
  background: rgba(255, 255, 255, 0.92);
}

.chat-model-btn .app-icon,
.mini-avatar .app-icon {
  flex: 0 0 auto;
  width: 30px;
  height: 30px;
}

.chat-model-btn .app-icon,
.chat-model-option .app-icon {
  width: 34px;
  height: 34px;
}

.mini-avatar .app-icon {
  width: 34px;
  height: 34px;
}

.model-version-picker {
  position: relative;
  z-index: 1;
  width: var(--model-version-width, max-content);
  min-width: 0;
  max-width: calc(100vw - 36px);
}

.model-version-picker.open {
  z-index: 2147483643;
}

.model-version-btn {
  position: relative;
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  align-content: center;
  align-items: center;
  justify-items: center;
  gap: 3px;
  width: 100%;
  height: 100%;
  padding: 9px 28px 9px 12px;
  border: 1px solid rgba(255, 255, 255, 0.34);
  border-radius: var(--radius-ios);
  color: #fff;
  background: rgba(15, 23, 42, 0.38);
  transition: transform 160ms ease, border-color 160ms ease, background 160ms ease;
  cursor: pointer;
  font-size: 13px;
  font-weight: 900;
  white-space: nowrap;
}

.model-version-btn::after {
  content: "";
  position: absolute;
  top: 50%;
  right: 11px;
  width: 7px;
  height: 7px;
  border-right: 2px solid currentColor;
  border-bottom: 2px solid currentColor;
  transform: translateY(-62%) rotate(45deg);
  opacity: 0.82;
}

.model-version-btn:hover,
.model-version-picker.open .model-version-btn {
  transform: translateY(-1px);
  border-color: rgba(16, 185, 129, 0.7);
  background: linear-gradient(135deg, rgba(16, 185, 129, 0.72), rgba(4, 120, 87, 0.72));
}

.model-version-label {
  min-width: 0;
  color: rgba(255, 255, 255, 0.72);
  font-size: 12px;
  font-weight: 900;
  line-height: 1;
  text-align: center;
  white-space: nowrap;
}

.model-version-name {
  min-width: 0;
  width: 100%;
  overflow: visible;
  text-overflow: clip;
  line-height: 1.12;
  white-space: normal;
  text-align: center;
}

.model-version-badges {
  display: inline-flex;
  align-items: center;
  justify-content: flex-start;
  gap: 4px;
  width: fit-content;
  min-width: 0;
  max-width: 100%;
  flex-wrap: wrap;
}

.model-version-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex: 0 0 max-content;
  width: max-content;
  min-width: max-content;
  min-inline-size: max-content;
  inline-size: max-content;
  max-width: none;
  height: auto;
  min-height: calc(1em + 0.64em);
  padding: 0.32em 0.72em;
  box-sizing: border-box;
  border-radius: var(--radius-ios);
  color: #fff;
  background: #0ea5e9;
  font-size: inherit;
  font-style: normal;
  font-weight: 950;
  line-height: 1.1;
  white-space: nowrap;
}

.model-version-badge.latest {
  background: #0284c7;
}

.model-version-badge.hot {
  background: #f97316;
}

.model-version-badge.strongCoding {
  background: #312e81;
}

.model-version-badge.coding {
  background: #4f46e5;
}

.model-version-badge.chat {
  background: #0891b2;
}

.model-version-badge.companion {
  background: #ec4899;
}

.model-version-badge.academic {
  background: #2563eb;
}

.model-version-badge.cognition {
  background: #9333ea;
}

.model-version-badge.stocks {
  background: #059669;
}

.model-version-badge.composing {
  background: #c2410c;
}

.model-version-badge.arranging {
  background: #7c2d12;
}

.model-version-badge.photoRestore {
  background: #be185d;
}

.model-version-badge.posterDesign {
  background: #a21caf;
}

.model-version-badge.value {
  background: #16a34a;
}

.model-version-badge.expensive {
  background: #dc2626;
}

.model-version-badge.budget {
  background: #0d9488;
}

.model-version-badge.promoPrice {
  background: #ea580c;
}

.model-version-badge.image {
  background: #db2777;
}

.model-version-badge.video {
  background: #7c3aed;
}

.model-version-badge.audio {
  background: #0d9488;
}

.model-version-badge.online {
  background: #2563eb;
}

.model-version-badge.music,
.model-version-badge.free {
  background: #16a34a;
}

.model-version-price {
  display: grid;
  align-items: start;
  justify-content: start;
  gap: 3px;
  max-width: 100%;
  min-height: 19px;
  padding: 4px 6px;
  border-radius: 7px;
  color: #fff;
  background: transparent;
  font-size: 10px;
  font-weight: 950;
  line-height: 1.25;
  overflow-wrap: anywhere;
  white-space: normal;
}

.model-version-price.selected {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 4px;
  justify-self: center;
  width: fit-content;
  margin-inline: auto;
  min-height: 0;
  padding: 0;
  border: 0;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
  text-align: center;
}

.model-version-price.selected .model-version-price-selected-label {
  display: inline-flex;
  align-items: center;
  min-height: 0;
  padding: 0;
  border-radius: 0;
  color: rgba(255, 255, 255, 0.78);
  background: transparent;
  font-size: 10px;
  font-weight: 1000;
  line-height: 1;
  text-shadow: none;
  white-space: nowrap;
}

.model-version-price.selected strong {
  color: currentColor;
  font-size: 10px;
  font-weight: 1000;
  line-height: 1;
  letter-spacing: 0;
  white-space: nowrap;
}

.model-version-price.option.support-layout {
  display: inline-grid;
  grid-template-columns: minmax(0, 1fr);
  gap: 4px;
  justify-content: flex-start;
  min-width: 0;
  width: 100%;
  max-width: 100%;
  padding: 0;
  background: transparent;
}

.model-version-main-prices {
  display: inline-flex;
  flex-wrap: wrap;
  gap: 4px;
  min-width: 0;
  width: 100%;
  max-width: 100%;
  white-space: normal;
}

.model-version-main-prices:has(.model-version-price-chip.currency) {
  align-items: center;
}

.model-version-main-prices.currency-row {
  display: grid;
  grid-template-columns: 42px minmax(0, 1fr);
  align-items: flex-start;
  column-gap: 4px;
}

.model-version-main-prices.currency-row > .model-version-price-chip.currency,
.model-version-main-prices.currency-row > .model-version-price-values {
  align-self: flex-start;
}

.model-version-price-values {
  display: inline-flex;
  flex-wrap: wrap;
  gap: 4px;
  min-width: 0;
  max-width: 100%;
}

.model-version-price-chip {
  flex: 0 0 auto;
  display: inline-flex;
  align-items: center;
  min-height: 20px;
  padding: 2px 6px;
  border-radius: 6px;
  font-size: 10px;
  font-style: normal;
  font-weight: 950;
  line-height: 1.25;
  overflow-wrap: anywhere;
  white-space: nowrap;
}

.model-version-price-chip.currency {
  justify-content: center;
  width: 42px;
  color: #e0f2fe;
  background: rgba(14, 165, 233, 0.42);
  text-shadow: 0 1px 2px rgba(15, 23, 42, 0.35);
}

.model-version-price-chip.currency.regional {
  color: var(--model-version-region-fg, #fff7ed);
  background: var(--model-version-region-bg, rgba(249, 115, 22, 0.5));
}

.model-version-price-chip.input {
  color: #fde68a;
  background: rgba(245, 158, 11, 0.2);
}

.model-version-price-chip.output {
  color: #a7f3d0;
  background: rgba(16, 185, 129, 0.18);
}

.model-version-price-chip.estimate {
  color: #fecaca;
  background: rgba(239, 68, 68, 0.18);
}

.model-version-price-chip.exchange {
  color: #bfdbfe;
  background: rgba(59, 130, 246, 0.18);
}

.model-version-price-chip.exchange-date {
  color: #dbeafe;
  background: rgba(96, 165, 250, 0.14);
}

.model-version-price-chip.region-tag {
  color: var(--model-version-region-fg, #ecfeff);
  background: var(--model-version-region-bg, rgba(6, 182, 212, 0.34));
}

.model-version-price-chip.rate,
.model-version-price-chip.unit,
.model-version-price-chip.rmb {
  color: #fed7aa;
  background: rgba(249, 115, 22, 0.15);
}

.model-version-price-chip.rmb.input {
  color: #fde68a;
  background: rgba(245, 158, 11, 0.2);
}

.model-version-price-chip.rmb.output {
  color: #a7f3d0;
  background: rgba(16, 185, 129, 0.18);
}

.model-version-price-line {
  display: inline-flex;
  align-items: center;
  justify-content: flex-start;
  flex-wrap: wrap;
  gap: 4px;
  min-width: 0;
}

.model-version-price-line em {
  display: inline-flex;
  align-items: center;
  min-height: 18px;
  padding: 1px 5px;
  border-radius: 6px;
  font-style: normal;
  white-space: nowrap;
}

.model-version-price-line .input {
  color: #92400e;
  background: rgba(245, 158, 11, 0.18);
}

.model-version-price-line .output {
  color: #0f766e;
  background: rgba(16, 185, 129, 0.14);
}

.model-version-price-line .estimate {
  color: #b91c1c;
  background: rgba(239, 68, 68, 0.12);
}

.model-version-price-line .exchange {
  color: #1d4ed8;
  background: rgba(59, 130, 246, 0.14);
}

.model-version-price-line .exchange-date {
  color: #1e3a8a;
  background: rgba(191, 219, 254, 0.55);
}

.model-version-price-line .region-tag {
  color: #ffe600;
  background: #de2910;
  text-shadow: 0 1px 2px rgba(15, 23, 42, 0.45);
}

.model-version-price-line .rate,
.model-version-price-line .unit {
  color: #7c2d12;
  background: rgba(249, 115, 22, 0.14);
}

.model-version-menu {
  position: fixed;
  left: 0;
  top: 0;
  z-index: 2147483647;
  display: grid;
  grid-template-columns: 1fr;
  justify-items: stretch;
  gap: 12px;
  width: min(var(--model-version-menu-width, max-content), calc(100vw - 36px));
  max-width: calc(100vw - 36px);
  max-height: var(--model-version-menu-max-height, min(360px, calc(100vh - 24px)));
  overflow: hidden;
  overscroll-behavior: contain;
  padding: 12px;
  border: 1px solid rgba(255, 255, 255, 0.36);
  border-radius: var(--radius-ios);
  color: #fff;
  background: rgba(15, 23, 42, 0.84);
  backdrop-filter: blur(20px);
  box-shadow: var(--shadow);
  opacity: 0;
  transform: translateY(10px) scale(0.98);
  transform-origin: left bottom;
  pointer-events: none;
  transition: opacity 180ms ease, transform 180ms ease;
  scrollbar-gutter: stable both-edges;
  scrollbar-width: thin;
  scrollbar-color: rgba(16, 185, 129, 0.86) rgba(255, 255, 255, 0.08);
}

.model-version-picker.open .model-version-menu,
.model-version-menu.open {
  opacity: 1;
  transform: translateY(0) scale(1);
  pointer-events: auto;
}

@media (min-width: 769px) {
  .model-version-menu {
    width: min(max(680px, var(--model-version-menu-width, 560px)), calc(100vw - 48px));
  }
}

:where(.more-model-menu, .chat-model-menu, .mini-model-menu, .model-version-menu, .language-menu, .user-panel, .fullscreen-user-panel, .fullscreen-settings-panel, .image-generation-menu, .attach-menu-panel, .mobile-menu-panel, .auth-modal, .custom-model-modal, .quota-modal, .site-notice-modal, .repo-connect-modal) {
  transition-duration: 0ms !important;
  will-change: opacity, transform;
}

:where(.model-pill, .more-model-btn, .chat-model-btn, .model-version-btn, .model-version-sort, .model-version-option, .chat-model-option, .more-model-option, .mini-model-option, .quick-prompts button, .scene-buttons button, .filter, .ghost-btn, .solid-btn, .expand-chat-btn, .fullscreen-chat-btn, .scroll-dock button) {
  transition-duration: 0ms !important;
}

.model-version-sortbar {
  position: sticky;
  top: -12px;
  z-index: 2;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  align-items: center;
  gap: 6px;
  width: calc(100% + 24px);
  margin: -12px -12px 0;
  padding: 10px 12px;
  box-sizing: border-box;
  border: 0;
  border-radius: 0;
  background: rgba(15, 23, 42, 0.84);
  backdrop-filter: blur(18px);
}

.model-version-sort {
  min-height: 34px;
  border: 1px solid rgba(255, 255, 255, 0.14);
  border-radius: var(--radius-ios);
  color: rgba(255, 255, 255, 0.84);
  background: rgba(255, 255, 255, 0.1);
  cursor: pointer;
  font-size: 13px;
  font-weight: 900;
}

.model-version-sort:hover,
.model-version-sort:focus-visible {
  border-color: rgba(56, 189, 248, 0.72);
  color: #fff;
  background: rgba(37, 99, 235, 0.34);
  box-shadow: 0 0 0 2px rgba(56, 189, 248, 0.18), 0 10px 22px rgba(2, 132, 199, 0.18);
  transform: translateY(-1px);
}

.model-version-sort.active {
  border-color: rgba(16, 185, 129, 0.74);
  color: #fff;
  background: linear-gradient(135deg, rgba(16, 185, 129, 0.72), rgba(5, 150, 105, 0.48));
}

.model-version-option {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  align-items: center;
  align-content: start;
  justify-content: stretch;
  flex: 0 0 auto;
  width: 100%;
  min-width: 0;
  max-width: 100%;
  column-gap: 4px;
  row-gap: 4px;
  height: auto;
  min-height: 0;
  padding: 10px 12px;
  box-sizing: border-box;
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: var(--radius-ios);
  color: #fff;
  background: rgba(255, 255, 255, 0.08);
  cursor: pointer;
  font-size: 14px;
  font-weight: 900;
  text-align: left;
  white-space: normal;
  transition: border-color 100ms ease, background 100ms ease, box-shadow 100ms ease, transform 100ms ease;
}

.model-version-option:not(:disabled):hover,
.model-version-option:not(:disabled):focus-visible {
  border-color: rgba(56, 189, 248, 0.78);
  background: linear-gradient(135deg, rgba(37, 99, 235, 0.42), rgba(14, 165, 233, 0.26));
  box-shadow: 0 0 0 2px rgba(56, 189, 248, 0.18), 0 12px 26px rgba(2, 132, 199, 0.2);
  transform: translateY(-1px);
}

.model-version-option-head {
  display: inline-flex;
  align-items: center;
  flex-wrap: wrap;
  column-gap: 8px;
  row-gap: 5px;
  min-width: 0;
  width: 100%;
  max-width: 100%;
}

.model-version-option .app-icon {
  flex: 0 0 auto;
  width: 24px;
  height: 24px;
}

.model-version-option-name {
  display: inline-flex;
  flex: 0 1 auto;
  min-width: 0;
  width: auto;
  max-width: calc(100% - 32px);
  align-self: center;
  justify-self: start;
  overflow: hidden;
  overflow-wrap: anywhere;
  text-overflow: ellipsis;
  line-height: 1.18;
  white-space: nowrap;
  word-break: normal;
  margin-right: 0;
}

.model-version-option-name.wrap {
  flex-basis: calc(100% - 32px);
  width: auto;
  overflow-wrap: anywhere;
  white-space: normal;
}

.model-version-option .model-version-badges {
  grid-column: auto;
  justify-self: start;
}

.model-version-option .model-version-price {
  grid-column: 1 / -1;
  justify-self: start;
}

.model-version-option.active {
  border-color: rgba(16, 185, 129, 0.7);
  background: linear-gradient(135deg, rgba(16, 185, 129, 0.48), rgba(4, 120, 87, 0.48));
}

.model-version-option.unavailable,
.model-version-option:disabled {
  cursor: not-allowed;
  opacity: 0.58;
  background: rgba(148, 163, 184, 0.14);
}

.model-version-unavailable-reason {
  display: block;
  grid-column: 1 / -1;
  width: 100%;
  color: rgba(255, 255, 255, 0.72);
  font-size: 12px;
  font-weight: 800;
  line-height: 1.25;
  overflow-wrap: anywhere;
}

.chat-model-menu {
  position: absolute;
  left: 0;
  top: auto;
  bottom: calc(100% + 8px);
  z-index: 2147483644;
  display: grid;
  grid-template-columns: repeat(2, minmax(150px, 1fr));
  gap: 10px;
  width: min(500px, 90vw);
  max-height: 400px;
  overflow: auto;
  padding: 12px;
  border: 1px solid rgba(255, 255, 255, 0.36);
  border-radius: var(--radius-ios);
  background: rgba(15, 23, 42, 0.84);
  backdrop-filter: blur(20px);
  box-shadow: var(--shadow);
  scrollbar-width: thin;
  scrollbar-color: rgba(16, 185, 129, 0.86) rgba(255, 255, 255, 0.08);
  opacity: 0;
  transform: translateY(10px) scale(0.98);
  pointer-events: none;
  transition: opacity 180ms ease, transform 180ms ease;
}

.chat-model-picker.open .chat-model-menu,
.chat-model-menu.open {
  opacity: 1;
  transform: translateY(0) scale(1);
  pointer-events: auto;
}

.chat-model-option {
  display: flex;
  align-items: center;
  gap: 10px;
  min-height: 48px;
  padding: 8px 10px;
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: var(--radius-ios);
  color: #fff;
  background: rgba(255, 255, 255, 0.08);
  cursor: pointer;
  font-size: 12px;
  font-weight: 900;
}

.chat-model-option.active {
  border-color: rgba(16, 185, 129, 0.7);
  background: linear-gradient(135deg, rgba(16, 185, 129, 0.48), rgba(4, 120, 87, 0.48));
}

.chat-model-option > .app-icon {
  width: 26px;
  height: 26px;
  border-radius: var(--radius-ios);
  background: rgba(255, 255, 255, 0.92);
}

#aiQuery {
  box-sizing: border-box;
  width: 100%;
  min-width: 0;
  min-height: 74px;
  height: auto;
  margin: 0;
  padding: var(--hero-input-padding-y, 12px) 10px;
  border: 0;
  border-radius: var(--radius-ios);
  outline: none;
  color: #fff;
  background: transparent;
  font-size: var(--hero-input-font-size, 16px);
  line-height: 1.55;
  overflow: hidden;
  resize: none;
  white-space: pre-wrap;
  justify-self: stretch;
}

#aiQuery.is-empty {
  text-align: left;
  white-space: normal;
}

#aiQuery:not(.is-empty) {
  --hero-input-font-size: 16px;
  --hero-input-padding-y: 12px;
  text-align: left;
}

@media (min-width: 769px) {
  body:not(.chat-fullscreen) #aiQuery,
  body:not(.chat-fullscreen) #aiQuery:not(.is-empty) {
    --hero-input-padding-y: 24px;
  }
}

#aiQuery::placeholder {
  color: rgba(255, 255, 255, 0.76);
  font-size: inherit;
}

#aiQuery.has-attachments::placeholder {
  color: transparent;
}

#aiQuery:focus {
  box-shadow: none;
}

.action-pair {
  gap: 8px;
  align-self: stretch;
}

.attach-btn {
  display: inline-grid;
  place-items: center;
  width: 34px;
  min-width: 34px;
  min-height: 42px;
  height: 42px;
  align-self: center;
  border: 0;
  border-radius: var(--radius-ios);
  color: #fff;
  background: transparent;
  cursor: pointer;
  transition: transform 160ms ease, color 160ms ease;
}

.attach-btn span {
  position: relative;
  display: block;
  width: 18px;
  height: 18px;
}

.attach-btn span::before,
.attach-btn span::after {
  content: "";
  position: absolute;
  left: 50%;
  top: 50%;
  border-radius: 999px;
  background: currentColor;
  transform: translate(-50%, -50%);
}

.attach-btn span::before {
  width: 18px;
  height: 2px;
}

.attach-btn span::after {
  width: 2px;
  height: 18px;
}

.attachment-tray {
  display: flex;
  align-items: flex-start;
  flex-wrap: wrap;
  gap: 7px;
  min-width: 0;
  max-height: 142px;
  overflow: auto;
  padding: 0 0 2px;
  color: rgba(255, 255, 255, 0.82);
  font-size: 12px;
}

.attachment-tray[hidden] {
  display: none;
}

.attachment-chip {
  --attachment-thumb-radius: var(--radius-ios);
  position: relative;
  display: inline-grid;
  width: 62px;
  height: 62px;
  place-items: center;
  overflow: hidden;
  padding: 0;
  border: 1px solid rgba(255, 255, 255, 0.28);
  border-radius: var(--attachment-thumb-radius);
  background: rgba(15, 23, 42, 0.42);
  clip-path: inset(0 round var(--attachment-thumb-radius));
}

.attachment-preview {
  position: relative;
  display: inline-grid;
  place-items: center;
  flex: 0 0 auto;
  width: 100%;
  height: 100%;
  overflow: hidden;
  border-radius: calc(var(--attachment-thumb-radius) - 1px);
  background: rgba(255, 255, 255, 0.12);
  clip-path: inset(0 round calc(var(--attachment-thumb-radius) - 1px));
}

.attachment-preview img {
  display: block;
  width: 100%;
  height: 100%;
  border-radius: inherit;
  clip-path: inherit;
  object-fit: cover;
}

.attachment-chip[data-attachment-kind="video"] .attachment-preview::after,
.bubble-attachment[data-attachment-kind="video"] .bubble-attachment-preview::after {
  content: "";
  position: absolute;
  left: 50%;
  top: 50%;
  width: 0;
  height: 0;
  border-top: 8px solid transparent;
  border-bottom: 8px solid transparent;
  border-left: 12px solid rgba(255, 255, 255, 0.92);
  filter: drop-shadow(0 2px 5px rgba(15, 23, 42, 0.45));
  transform: translate(-38%, -50%);
}

.attachment-file-icon {
  display: inline-grid;
  place-items: center;
  width: 100%;
  height: 100%;
  color: #d1fae5;
  background: rgba(16, 185, 129, 0.22);
  font-size: 10px;
  font-weight: 900;
  letter-spacing: 0;
}

.attachment-file-icon[data-kind="pdf"] {
  color: #fff;
  background: linear-gradient(135deg, #ef4444, #b91c1c);
}

.attachment-file-icon[data-kind="doc"],
.attachment-file-icon[data-kind="text"] {
  color: #fff;
  background: linear-gradient(135deg, #2563eb, #1d4ed8);
}

.attachment-file-icon[data-kind="sheet"] {
  color: #fff;
  background: linear-gradient(135deg, #16a34a, #15803d);
}

.attachment-file-icon[data-kind="slide"] {
  color: #fff;
  background: linear-gradient(135deg, #f97316, #c2410c);
}

.attachment-file-icon[data-kind="audio"],
.attachment-file-icon[data-kind="video"] {
  color: #fff;
  background: linear-gradient(135deg, #7c3aed, #4c1d95);
}

.repository-bubble {
  border-color: rgba(16, 185, 129, 0.44);
  background: rgba(6, 78, 59, 0.32);
}

.repository-preview {
  color: #ecfdf5;
  background:
    radial-gradient(circle at 28% 18%, rgba(255, 255, 255, 0.26), transparent 26%),
    linear-gradient(135deg, #0f172a, #047857);
  font-size: 12px;
  font-weight: 950;
  letter-spacing: -0.04em;
}

.repository-inline-badge {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  align-self: center;
  width: max-content;
  max-width: min(128px, 28vw);
  height: 34px;
  border: 1px solid rgba(22, 131, 255, 0.16);
  border-radius: var(--radius-ios);
  padding: 0 10px;
  color: #1683ff;
  background: #fff;
  box-shadow: 0 5px 14px rgba(15, 23, 42, 0.12);
  cursor: pointer;
  font-size: 16px;
  font-weight: 800;
  line-height: 1;
}

.repository-inline-badge span:first-child {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.repository-inline-badge[hidden] {
  display: none;
}

.repository-inline-badge:hover,
.repository-inline-badge:focus-visible {
  background: #fff;
  border-color: rgba(22, 131, 255, 0.36);
  outline: none;
}

.repository-inline-caret {
  color: currentColor;
  font-size: 14px;
  line-height: 1;
}

.repository-inline-mini {
  position: absolute;
  left: 36px;
  top: 50%;
  z-index: 2;
  height: 28px;
  max-width: 74px;
  padding: 0 7px;
  transform: translateY(-50%);
  font-size: 14px;
  border-radius: var(--radius-ios);
}

body.repository-connected #miniQuery {
  padding-left: 106px !important;
}

.attachment-copy {
  display: grid;
  gap: 2px;
  min-width: 0;
}

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

.attachment-chip small,
.attachment-note {
  color: rgba(255, 255, 255, 0.68);
}

.attachment-chip button {
  position: absolute;
  top: 4px;
  right: 4px;
  display: inline-grid;
  place-items: center;
  width: 19px;
  height: 19px;
  border: 0;
  border-radius: var(--radius-ios);
  color: #fff;
  background: rgba(15, 23, 42, 0.68);
  cursor: pointer;
  font-size: 0;
  line-height: 1;
  opacity: 0;
  transform: scale(0.86);
  pointer-events: none;
  transition: opacity 150ms ease, transform 150ms ease, background 150ms ease;
}

.attachment-chip:hover button,
.attachment-chip:focus-within button {
  opacity: 1;
  transform: scale(1);
  pointer-events: auto;
}

.attachment-chip button:hover,
.attachment-chip button:focus-visible {
  background: rgba(15, 23, 42, 0.86);
}

.attachment-chip button::before,
.attachment-chip button::after {
  content: "";
  position: absolute;
  left: 50%;
  top: 50%;
  width: 10px;
  height: 2px;
  border-radius: 999px;
  background: currentColor;
  transform-origin: center;
}

.attachment-chip button::before {
  transform: translate(-50%, -50%) rotate(45deg);
}

.attachment-chip button::after {
  transform: translate(-50%, -50%) rotate(-45deg);
}

.bubble-attachments {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  min-width: 0;
  max-width: 100%;
  margin-top: 8px;
}

.bubble-attachment {
  display: inline-grid;
  place-items: center;
  width: 54px;
  height: 54px;
  min-height: 54px;
  max-width: 54px;
  padding: 4px;
  border: 1px solid rgba(15, 23, 42, 0.12);
  border-radius: var(--radius-ios);
  background: rgba(255, 255, 255, 0.72);
}

.bubble-attachment:is(button) {
  appearance: none;
  font: inherit;
  cursor: zoom-in;
}

.bubble-attachment-preview {
  position: relative;
  display: inline-grid;
  place-items: center;
  width: 100%;
  height: 100%;
  overflow: hidden;
  border-radius: var(--radius-ios);
  background: rgba(15, 23, 42, 0.08);
}

.bubble-attachment-preview img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.bubble-attachment-preview video {
  display: block;
  width: 100%;
  max-height: min(62vh, 520px);
  border-radius: inherit;
}

.bubble-attachment-name {
  min-width: 0;
  overflow: hidden;
  color: #334155;
  font-size: 12px;
  font-weight: 800;
  line-height: 1.25;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.bubble.user .bubble-attachments {
  max-width: min(100%, 292px);
  justify-content: flex-end;
}

.bubble.user .bubble-attachment {
  width: 92px;
  height: 92px;
  max-width: 92px;
  min-height: 92px;
  padding: 0;
  border: 0;
  background: transparent;
}

.bubble-attachment[data-media-open="true"] {
  cursor: zoom-in;
}

.bubble.ai .ai-output-attachments {
  position: relative;
  z-index: 1;
  justify-content: flex-start;
}

.bubble.ai.has-media-only .ai-output-attachments {
  display: grid;
  gap: 8px;
  max-width: calc(100% - var(--ai-message-content-left));
  margin-left: var(--ai-message-content-left);
  margin-top: 0;
}

.bubble.ai.has-media-only {
  gap: 0;
  margin-bottom: 10px;
}

.bubble.ai.has-media-only::before {
  display: none;
}

.bubble.ai.has-video-countdown {
  margin-bottom: 34px;
}

.video-generation-countdown {
  position: absolute;
  top: calc(100% + 6px);
  left: var(--ai-message-content-left);
  z-index: 2;
  color: rgba(255, 255, 255, 0.82);
  font-size: 12px;
  font-weight: 800;
  line-height: 1.2;
  white-space: nowrap;
}

.video-generation-countdown strong {
  margin-left: 6px;
  color: #fff;
  font-variant-numeric: tabular-nums;
}

.bubble.ai .bubble-attachment.generated-image {
  width: min(320px, 100%);
  max-width: 100%;
  height: auto;
  min-height: 0;
  padding: 6px;
  gap: 6px;
  text-decoration: none;
}

.bubble.ai.has-media-only .bubble-attachment.generated-image {
  width: min(520px, 100%);
  padding: 0;
  border: 0;
  border-radius: 8px;
  background: transparent;
}

.bubble.ai .bubble-attachment.generated-image .bubble-attachment-preview {
  width: 100%;
  height: auto;
  min-height: 0;
  background: transparent;
}

.bubble.ai .bubble-attachment.generated-image img,
.bubble.ai .bubble-attachment.generated-image video {
  width: auto;
  max-width: 100%;
  height: auto;
  max-height: min(62vh, 520px);
  border-radius: inherit;
  object-fit: contain;
}

.chat-image-preview {
  position: fixed;
  inset: 0;
  z-index: 2147483656;
  display: grid;
  place-items: center;
  padding: clamp(14px, 3vw, 34px);
  background: rgba(2, 6, 23, 0.82);
  backdrop-filter: blur(18px);
}

.chat-image-preview[hidden] {
  display: none;
}

.chat-image-preview-card {
  position: relative;
  display: grid;
  place-items: center;
  max-width: 94vw;
  max-height: 92vh;
  margin: 0;
}

.chat-image-preview-card img {
  display: block;
  width: auto;
  max-width: 94vw;
  height: auto;
  max-height: 92vh;
  object-fit: contain;
  border-radius: 8px;
  box-shadow: 0 28px 90px rgba(0, 0, 0, 0.42);
}

.chat-image-preview-card button {
  position: absolute;
  right: 10px;
  top: 10px;
  display: inline-grid;
  width: 38px;
  height: 38px;
  place-items: center;
  border: 1px solid rgba(255, 255, 255, 0.34);
  border-radius: 999px;
  color: #fff;
  background: rgba(15, 23, 42, 0.66);
  cursor: pointer;
  font-size: 26px;
  line-height: 1;
}

body.chat-image-preview-open {
  overflow: hidden;
}

.image-result-model,
.image-repair-caption {
  color: rgba(51, 65, 85, 0.78);
  font-size: 11px;
  font-weight: 800;
  line-height: 1.3;
}

.generated-video-shell {
  position: relative;
  z-index: 1;
  display: grid;
  gap: 8px;
  width: fit-content;
  max-width: min(100%, 560px);
}

.generated-video-output {
  position: relative;
  display: block;
  width: min(100%, var(--generated-video-width, 292px));
  max-width: min(100%, 560px);
  aspect-ratio: var(--generated-video-ratio, 9 / 16);
  overflow: hidden;
  border-radius: 8px;
  background: #050505;
  cursor: pointer;
}

.generated-video-shell:not(.is-ready) .generated-video-actions,
.generated-video-output:not(.is-ready) {
  width: 0;
  height: 0;
  overflow: hidden;
}

.generated-video-output:not(.is-ready) video,
.generated-video-output:not(.is-ready) .generated-video-pause-btn {
  visibility: hidden;
}

.generated-video-output video {
  display: block;
  width: 100%;
  height: 100%;
  border-radius: 8px;
  background: #050505;
  object-fit: contain;
}

.generated-video-poster {
  position: absolute;
  inset: 0;
  z-index: 2;
  display: block;
  width: 100%;
  height: 100%;
  background: #050505;
  object-fit: contain;
  opacity: 0;
  pointer-events: none;
  transition: opacity 120ms ease;
}

.generated-video-output.is-ready:not(.is-playing) .generated-video-poster[src] {
  opacity: 1;
}

.generated-video-output.is-previewing .generated-video-poster {
  opacity: 0;
}

.generated-video-pause-btn {
  position: absolute;
  top: 50%;
  left: 50%;
  z-index: 4;
  display: grid;
  place-content: center;
  width: 38px;
  height: 38px;
  border: 1px solid rgba(255, 255, 255, 0.42);
  border-radius: 999px;
  background: rgba(15, 23, 42, 0.62);
  color: #fff;
  cursor: pointer;
  opacity: 0;
  pointer-events: none;
  transform: translate(-50%, -50%);
  transition: opacity 150ms ease, background 150ms ease;
}

.generated-video-output.is-ready:not(.is-playing) .generated-video-pause-btn {
  opacity: 1;
  pointer-events: auto;
}

.generated-video-output.is-ready.is-playing:hover .generated-video-pause-btn,
.generated-video-output.is-ready.is-playing .generated-video-pause-btn:focus-visible {
  opacity: 1;
  pointer-events: auto;
}

.generated-video-pause-btn:hover,
.generated-video-pause-btn:focus-visible {
  background: rgba(15, 23, 42, 0.82);
}

.generated-video-pause-btn::before {
  content: "";
  width: 0;
  height: 0;
  margin-left: 3px;
  border-top: 8px solid transparent;
  border-bottom: 8px solid transparent;
  border-left: 13px solid currentColor;
}

.generated-video-pause-btn::after {
  content: none;
}

.generated-video-output.is-playing .generated-video-pause-btn {
  grid-template-columns: repeat(2, auto);
  gap: 5px;
}

.generated-video-output.is-playing .generated-video-pause-btn::before,
.generated-video-output.is-playing .generated-video-pause-btn::after {
  content: "";
  width: 4px;
  height: 15px;
  margin-left: 0;
  border: 0;
  border-radius: 999px;
  background: currentColor;
}

.generated-output-actions {
  position: relative;
  z-index: 2;
  display: flex;
  gap: 6px;
  width: min(320px, 100%);
}

.generated-video-actions {
  justify-content: flex-end;
  width: 100%;
}

.bubble.ai.has-media-only .generated-output-actions {
  justify-content: flex-end;
  width: min(520px, 100%);
}

.bubble.ai.has-media-only .generated-video-actions {
  width: 100%;
}

.generated-output-actions button,
.generated-output-actions a {
  border: 1px solid rgba(15, 23, 42, 0.12);
  border-radius: 6px;
  background: rgba(255, 255, 255, 0.88);
  color: #0f766e;
  cursor: pointer;
  font-size: 12px;
  font-weight: 800;
  line-height: 1;
  padding: 8px 10px;
  text-decoration: none;
}

@media (max-width: 640px) {
  .generated-video-shell {
    width: min(100%, 520px);
  }

  .generated-video-actions {
    justify-content: flex-end;
  }
}

.mini-stream .bubble.ai.has-media-only .ai-output-attachments {
  max-width: calc(100% - 46px);
  margin-left: 46px;
}

.image-repair-work {
  display: grid;
  gap: 6px;
  margin-top: 8px;
  width: min(320px, 100%);
}

.image-repair-status {
  font-weight: 900;
}

.image-repair-grid {
  position: relative;
  display: grid;
  place-items: center;
  width: 100%;
  min-height: 180px;
  overflow: hidden;
  aspect-ratio: 1 / 1;
  border: 1px solid rgba(15, 23, 42, 0.12);
  border-radius: var(--radius-ios);
  background-image:
    linear-gradient(rgba(16, 185, 129, 0.24) 1px, transparent 1px),
    linear-gradient(90deg, rgba(16, 185, 129, 0.24) 1px, transparent 1px);
  background-size: 18px 18px;
}

.image-repair-grid img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  filter: saturate(0.7) contrast(0.92);
  opacity: 0.46;
}

.image-repair-scan {
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, transparent, rgba(16, 185, 129, 0.32), transparent);
  animation: image-repair-scan 1.45s ease-in-out infinite;
}

@keyframes image-repair-scan {
  0% {
    transform: translateY(-100%);
  }
  100% {
    transform: translateY(100%);
  }
}

.attach-btn:hover,
.attach-btn.has-files {
  transform: translateY(-1px);
  color: #bbf7d0;
  background: transparent;
}

.ghost-btn,
.solid-btn {
  display: inline-grid;
  place-items: center;
  min-width: 76px;
  min-height: 58px;
  height: 100%;
  border-radius: var(--radius-ios);
  cursor: pointer;
  font-weight: 900;
}

.ghost-btn {
  border: 1px solid rgba(15, 23, 42, 0.58);
  color: #fff;
  background: rgba(15, 23, 42, 0.72);
}

.solid-btn {
  border: 0;
  color: #fff;
  background: linear-gradient(135deg, var(--green), var(--green-dark));
}

.expand-chat-btn,
.fullscreen-chat-btn {
  --mini-control-icon-size: 13px;
  --mini-control-icon-stroke: 2px;
  position: relative;
  display: inline-grid;
  place-items: center;
  width: var(--hero-expand-size);
  height: var(--hero-expand-size);
  align-self: center;
  border: 1px solid rgba(255, 255, 255, 0.28);
  border-radius: var(--radius-ios);
  color: #fff;
  background: rgba(15, 23, 42, 0.78);
  backdrop-filter: blur(14px);
  cursor: pointer;
  font-size: 0;
  line-height: 1;
  transition: transform 160ms ease, background 160ms ease, border-color 160ms ease;
}

.expand-chat-btn > span,
.fullscreen-chat-btn > span {
  display: none;
}

.expand-chat-btn::before {
  content: "";
  position: absolute;
  left: 50%;
  top: 50%;
  box-sizing: border-box;
  width: var(--mini-control-icon-size);
  height: var(--mini-control-icon-size);
  border-top: var(--mini-control-icon-stroke) solid #fff;
  border-left: var(--mini-control-icon-stroke) solid #fff;
  border-radius: 2px 0 0 0;
  transform: translate(-50%, -54%) rotate(45deg);
  transform-origin: center;
}

.expand-chat-btn:hover,
.expand-chat-btn.active,
.fullscreen-chat-btn:hover,
.fullscreen-chat-btn.active {
  transform: scale(1.06);
  border-color: rgba(16, 185, 129, 0.62);
  background: rgba(16, 185, 129, 0.28);
}

.expand-chat-btn.active::before {
  transform: translate(-50%, -46%) rotate(225deg);
}

.fullscreen-chat-btn::before {
  content: "";
  position: absolute;
  left: 50%;
  top: 50%;
  display: block;
  width: var(--mini-control-icon-size);
  height: var(--mini-control-icon-size);
  transform: translate(-50%, -50%);
  transform-origin: center;
  background:
    linear-gradient(#fff, #fff) left top / calc(var(--mini-control-icon-size) * 0.54) var(--mini-control-icon-stroke) no-repeat,
    linear-gradient(#fff, #fff) left top / var(--mini-control-icon-stroke) calc(var(--mini-control-icon-size) * 0.54) no-repeat,
    linear-gradient(#fff, #fff) right top / calc(var(--mini-control-icon-size) * 0.54) var(--mini-control-icon-stroke) no-repeat,
    linear-gradient(#fff, #fff) right top / var(--mini-control-icon-stroke) calc(var(--mini-control-icon-size) * 0.54) no-repeat,
    linear-gradient(#fff, #fff) left bottom / calc(var(--mini-control-icon-size) * 0.54) var(--mini-control-icon-stroke) no-repeat,
    linear-gradient(#fff, #fff) left bottom / var(--mini-control-icon-stroke) calc(var(--mini-control-icon-size) * 0.54) no-repeat,
    linear-gradient(#fff, #fff) right bottom / calc(var(--mini-control-icon-size) * 0.54) var(--mini-control-icon-stroke) no-repeat,
    linear-gradient(#fff, #fff) right bottom / var(--mini-control-icon-stroke) calc(var(--mini-control-icon-size) * 0.54) no-repeat;
}

.fullscreen-chat-btn.active::before {
  width: var(--mini-control-icon-size);
  height: var(--mini-control-icon-size);
  transform: translate(-50%, -50%) rotate(45deg);
}

.fullscreen-utility-bar {
  position: absolute;
  top: 18px;
  right: 18px;
  z-index: 5;
  display: none;
  align-items: flex-start;
  gap: 10px;
}

.fullscreen-user-wrap,
.fullscreen-settings-wrap {
  position: relative;
}

.fullscreen-settings-wrap {
  display: inline-flex;
  align-items: flex-start;
  gap: 8px;
}

.fullscreen-avatar-btn,
.fullscreen-login-btn,
.fullscreen-settings-btn,
.fullscreen-close-btn {
  display: inline-grid;
  place-items: center;
  min-width: 82px;
  min-height: 39px;
  height: 39px;
  padding: 0 14px;
  border: 1px solid rgba(15, 23, 42, 0.16);
  border-radius: var(--radius-ios);
  color: var(--ink);
  background: rgba(255, 255, 255, 0.86);
  box-shadow: 0 8px 24px rgba(15, 23, 42, 0.08);
  cursor: pointer;
  font-weight: 900;
  transition: transform 160ms ease, box-shadow 160ms ease, border-color 160ms ease;
}

.fullscreen-avatar-btn:hover,
.fullscreen-login-btn:hover,
.fullscreen-settings-btn:hover,
.fullscreen-close-btn:hover,
.fullscreen-avatar-btn:focus-visible,
.fullscreen-login-btn:focus-visible,
.fullscreen-settings-btn:focus-visible,
.fullscreen-close-btn:focus-visible {
  transform: scale(1.04);
  border-color: rgba(15, 23, 42, 0.3);
  box-shadow: 0 14px 32px rgba(15, 23, 42, 0.15);
}

.fullscreen-avatar-btn {
  padding: 4px;
  min-width: 39px;
}

.fullscreen-avatar-btn .user-avatar-small {
  width: 30px;
  height: 30px;
}

.fullscreen-login-btn {
  min-width: 82px;
  font-size: 14px;
  border: 0;
  border-radius: var(--radius-ios);
  color: #fff;
  background: linear-gradient(135deg, var(--green), var(--green-dark));
  box-shadow: none;
}

.fullscreen-settings-btn {
  min-width: 82px;
  font-size: 13px;
}

.fullscreen-settings-btn > span {
  display: inline;
}

.fullscreen-close-btn {
  position: relative;
  width: 39px;
  min-width: 39px;
  padding: 0;
}

.fullscreen-close-btn::before,
.fullscreen-close-btn::after {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  width: 14px;
  height: 2px;
  border-radius: 999px;
  background: currentColor;
}

.fullscreen-close-btn::before {
  transform: translate(-50%, -50%) rotate(45deg);
}

.fullscreen-close-btn::after {
  transform: translate(-50%, -50%) rotate(-45deg);
}

.fullscreen-user-panel,
.fullscreen-settings-panel {
  position: absolute;
  top: calc(100% + 10px);
  right: 0;
  min-width: 238px;
  max-width: min(340px, calc(100vw - 24px));
  padding: 14px;
  border: 1px solid rgba(255, 255, 255, 0.32);
  border-radius: var(--radius-ios);
  color: #fff;
  background: rgba(15, 23, 42, 0.95);
  box-shadow: 0 20px 54px rgba(15, 23, 42, 0.3);
  backdrop-filter: blur(24px);
}

.fullscreen-user-panel {
  width: clamp(300px, 26vw, 420px);
  min-width: min(300px, calc(100vw - 24px));
  max-height: calc(100dvh - 92px);
  overflow-y: auto;
  overscroll-behavior: contain;
}

.fullscreen-user-panel[hidden],
.fullscreen-settings-panel[hidden] {
  display: none !important;
}

.fullscreen-user-panel .user-panel-card {
  padding: 0;
  border: 0;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
  backdrop-filter: none;
}

.fullscreen-user-panel .user-panel-head {
  display: grid;
  grid-template-columns: 56px minmax(0, 1fr);
  gap: 12px;
  align-items: center;
}

.fullscreen-user-panel .user-panel-card h3 {
  font-size: clamp(22px, 2.2vw, 32px);
}

.fullscreen-user-panel .user-stats,
.fullscreen-user-panel .user-panel-actions {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.fullscreen-user-panel .user-panel-actions [data-user-logout] {
  grid-column: 1 / -1;
}

.fullscreen-settings-panel h4 {
  margin: 0;
  font-size: 16px;
}

.fullscreen-setting-toggle {
  display: grid;
  grid-template-columns: 18px minmax(0, 1fr);
  align-items: center;
  gap: 10px;
  margin-top: 12px;
  font-size: 13px;
  font-weight: 800;
  cursor: pointer;
}

.fullscreen-setting-toggle input {
  width: 16px;
  height: 16px;
  margin: 0;
}

.fullscreen-primary-tabs,
.fullscreen-hot-tabs {
  display: none;
}

body.chat-fullscreen {
  overflow: hidden;
}

body.chat-fullscreen .hero {
  position: fixed;
  inset: 0;
  z-index: 2147483647;
  width: 100%;
  min-height: 100vh;
  min-height: 100dvh;
  height: 100vh;
  height: 100dvh;
  padding: 0;
  overflow: visible;
  isolation: isolate;
  pointer-events: none;
}

body.chat-fullscreen .hero > :not(.hero-console) {
  display: none;
}

body.chat-fullscreen main > :not(.hero) {
  display: none !important;
}

body.chat-fullscreen .topbar,
body.chat-fullscreen .scroll-dock,
body.chat-fullscreen .mini-chat,
body.chat-fullscreen .ai-launcher,
body.chat-fullscreen .language-menu,
body.chat-fullscreen .user-panel,
body.chat-fullscreen .country-hover-tip {
  display: none;
}

:where(.auth-modal, .custom-model-modal, .quota-modal, .site-notice-modal, .repo-connect-modal, .support-image-preview) {
  z-index: 2147483655 !important;
}

body.chat-fullscreen :where(.auth-modal.show, .custom-model-modal.show, .quota-modal.show, .site-notice-modal.show),
body.chat-fullscreen :where(.repo-connect-modal:not([hidden]), .support-image-preview:not([hidden])) {
  display: grid !important;
  z-index: 2147483655 !important;
}

body.chat-fullscreen.chat-mode:not(.mini-mode) .hero-console,
body.chat-fullscreen .hero-console {
  --fullscreen-hot-pill-gap: 8px;
  --fullscreen-hot-scroll-space: 14px;
  --fullscreen-edge-padding: 18px;
  --fullscreen-composer-width: min(100%, 84vw, 1120px);
  --fullscreen-hot-pill-height: max(54px, calc((100vh - 236px) / 10));
  --fullscreen-hot-pill-height: max(54px, calc((100dvh - 236px) / 10));
  --fullscreen-hot-icon-size: clamp(32px, calc(var(--fullscreen-hot-pill-height) - 28px), 48px);
  --fullscreen-hot-rank-size: clamp(32px, calc(var(--fullscreen-hot-pill-height) - 30px), 44px);
  position: fixed;
  inset: 0;
  left: 0;
  right: 0;
  top: 0;
  bottom: 0;
  z-index: 2147483647;
  width: auto;
  max-height: none;
  height: auto;
  padding: 18px;
  border: 0;
  border-radius: 0;
  background:
    radial-gradient(circle at 82% 10%, rgba(16, 185, 129, 0.2), transparent 28%),
    linear-gradient(135deg, rgba(2, 6, 23, 0.96), rgba(8, 47, 73, 0.9) 56%, rgba(6, 78, 59, 0.88));
  backdrop-filter: blur(26px);
  box-shadow: none;
  transform: none;
  grid-template-columns: fit-content(430px) minmax(0, 1fr);
  grid-template-rows: minmax(0, 1fr) auto;
  grid-template-areas:
    "models chat"
    "models composer";
  gap: 18px;
  align-content: stretch;
  pointer-events: auto;
}

body.chat-fullscreen .fullscreen-utility-bar {
  display: inline-flex;
}

body.chat-fullscreen .model-bar {
  grid-area: models;
  width: min(430px, 34vw);
  min-width: 260px;
  max-width: min(430px, 34vw);
  max-height: none;
  height: 100%;
  min-height: 0;
  justify-self: start;
  align-self: stretch;
  align-content: stretch;
  grid-template-columns: 1fr;
  grid-template-rows: auto auto auto minmax(0, 1fr);
  gap: 12px;
  padding: 16px;
  border-right: 1px solid rgba(255, 255, 255, 0.16);
  background: linear-gradient(180deg, rgba(15, 23, 42, 0.46), rgba(15, 23, 42, 0.2));
  overflow: hidden;
}

body.chat-fullscreen .model-bar > span {
  display: none;
  justify-self: center;
  position: relative;
  z-index: 2;
  width: 100%;
  padding: 2px 6px 10px;
  border-bottom: 1px solid rgba(255, 255, 255, 0.12);
  font-size: 17px;
  text-align: center;
  white-space: normal;
  line-height: 1.25;
}

body.chat-fullscreen .model-bar.hot-tab-all > span {
  display: block;
}

body.chat-fullscreen .model-switcher {
  grid-template-columns: 1fr;
  grid-template-rows: minmax(0, 1fr) auto;
  align-items: stretch;
  align-self: stretch;
  gap: 10px;
  height: 100%;
  max-height: 100%;
  min-height: 0;
  overflow: hidden;
}

body.chat-fullscreen .model-pills {
  counter-reset: hot-rank;
  flex-direction: column;
  align-content: stretch;
  width: 100%;
  max-width: 100%;
  height: 100%;
  max-height: 100%;
  min-height: 0;
  gap: var(--fullscreen-hot-pill-gap);
  overflow-x: hidden;
  overflow-y: auto;
  overscroll-behavior: contain;
  padding-right: 8px;
  scrollbar-gutter: stable both-edges;
  scrollbar-width: thin;
  scrollbar-color: rgba(16, 185, 129, 0.72) rgba(255, 255, 255, 0.08);
}

body.chat-fullscreen .fullscreen-primary-tabs,
body.chat-fullscreen .fullscreen-hot-tabs {
  display: grid;
  gap: 6px;
  width: 100%;
  order: -1;
}

body.chat-fullscreen .fullscreen-primary-tabs {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

body.chat-fullscreen .fullscreen-hot-tabs {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

body.chat-fullscreen .fullscreen-primary-tab,
body.chat-fullscreen .fullscreen-hot-tab {
  min-height: 34px;
  border: 1px solid rgba(255, 255, 255, 0.2);
  border-radius: var(--radius-ios);
  color: rgba(255, 255, 255, 0.88);
  background: rgba(15, 23, 42, 0.45);
  cursor: pointer;
  font-size: 12px;
  font-weight: 900;
}

body.chat-fullscreen .fullscreen-primary-tab {
  min-height: 40px;
  font-size: 14px;
}

body.chat-fullscreen .fullscreen-primary-tab.active,
body.chat-fullscreen .fullscreen-hot-tab.active {
  border-color: rgba(16, 185, 129, 0.72);
  color: #d1fae5;
  background: rgba(16, 185, 129, 0.28);
}

body.chat-fullscreen .model-pills::-webkit-scrollbar {
  width: 8px;
}

body.chat-fullscreen .model-pills::-webkit-scrollbar-track {
  background: rgba(255, 255, 255, 0.08);
  border-radius: var(--radius-ios);
}

body.chat-fullscreen .model-pills::-webkit-scrollbar-thumb {
  background: rgba(16, 185, 129, 0.72);
  border-radius: var(--radius-ios);
}

body.chat-fullscreen .model-pill {
  counter-increment: hot-rank;
  flex: 0 0 auto;
  width: 100%;
  min-width: 0;
  max-width: 100%;
  min-height: 54px;
  height: auto;
  justify-content: flex-start;
  gap: clamp(9px, 0.8vw, 13px);
  padding: 10px 14px 10px 10px;
  font-size: clamp(14px, calc(10px + 0.5vw), 16px);
  white-space: normal;
}

body.chat-fullscreen .model-pill::before {
  content: counter(hot-rank, decimal-leading-zero);
  flex: 0 0 auto;
  display: inline-grid;
  place-items: center;
  width: var(--fullscreen-hot-rank-size);
  height: var(--fullscreen-hot-rank-size);
  border-radius: var(--radius-ios);
  color: #bbf7d0;
  background: rgba(16, 185, 129, 0.14);
  font-size: clamp(12px, calc(8px + 0.35vw), 14px);
  font-weight: 1000;
}

body.chat-fullscreen .model-pill > .app-icon {
  width: var(--fullscreen-hot-icon-size);
  height: var(--fullscreen-hot-icon-size);
}

body.chat-fullscreen .model-pill .model-option-name {
  flex: 1 1 auto;
  justify-content: flex-start;
  text-align: left;
  line-height: 1.2;
  white-space: normal;
  overflow-wrap: normal;
  word-break: normal;
}

body.chat-fullscreen .model-pill .model-hot-badge {
  display: inline-flex;
  min-height: clamp(20px, calc(var(--fullscreen-hot-pill-height) - 48px), 26px);
  padding: 0 8px;
  font-size: clamp(11px, calc(8px + 0.3vw), 12px);
}

body.chat-fullscreen .more-models {
  width: 100%;
  min-width: 0;
  justify-self: start;
}

body.chat-fullscreen .more-model-btn {
  width: 100%;
  min-height: 44px;
  font-size: 14px;
}

body.chat-fullscreen .chat-stream {
  grid-area: chat;
  width: 100%;
  max-width: none;
  justify-self: stretch;
  display: grid;
  visibility: visible;
  min-height: 0;
  max-height: none;
  height: 100%;
  align-self: stretch;
  overflow-x: hidden;
  overflow-y: auto;
  overscroll-behavior: contain;
  padding: 14px 0 52px;
  border: 0;
  background: transparent;
  box-shadow: none;
  backdrop-filter: none;
  scrollbar-gutter: stable;
}

@media (min-width: 769px) {
  body.chat-fullscreen .chat-stream {
    grid-row: 1 / -1;
    width: calc(100% + var(--fullscreen-edge-padding, 18px));
    padding-right: var(--fullscreen-edge-padding, 18px);
    padding-bottom: calc(126px + var(--fullscreen-edge-padding, 18px));
  }
}

body.chat-fullscreen .bubble {
  --ai-message-content-left: calc(clamp(44px, 3.1vw, 54px) + clamp(12px, 1.1vw, 16px));
  width: min(100%, var(--fullscreen-composer-width));
  margin-inline: auto;
  gap: clamp(12px, 1.1vw, 16px);
}

body.chat-fullscreen .bubble p {
  max-width: 100%;
  padding: clamp(14px, 1vw, 18px) clamp(16px, 1.2vw, 22px);
  border-radius: var(--radius-ios);
  font-size: clamp(16px, 1.05vw, 19px);
  line-height: 1.68;
}

body.chat-fullscreen .bubble.user .user-bubble-body {
  max-width: 100%;
}

body.chat-fullscreen .hero,
body.chat-fullscreen .hero-bg,
body.chat-fullscreen .hero-console {
  border-radius: 0 !important;
}

body.chat-fullscreen .bubble.user .user-bubble-body > .bubble-text {
  max-width: 100%;
}

body.chat-fullscreen .bubble-edit-input {
  width: min(760px, 70vw);
  min-height: 116px;
  font-size: clamp(16px, 1.05vw, 19px);
}

body.chat-fullscreen .avatar,
body.chat-fullscreen .user-avatar {
  flex-basis: clamp(44px, 3.1vw, 54px);
  width: clamp(44px, 3.1vw, 54px);
  height: clamp(44px, 3.1vw, 54px);
  border-radius: var(--radius-ios);
}

body.chat-fullscreen .user-avatar.generated-user-avatar {
  border-radius: var(--radius-ios);
}

body.chat-fullscreen .user-avatar::before,
body.chat-fullscreen .user-avatar::after {
  top: 16px;
  width: 7px;
  height: 7px;
}

body.chat-fullscreen .user-avatar::before {
  left: 13px;
}

body.chat-fullscreen .user-avatar::after {
  right: 13px;
}

body.chat-fullscreen .user-smile {
  bottom: 11px;
  width: 16px;
  height: 8px;
}

body.chat-fullscreen .typing-dot {
  width: 8px;
  height: 8px;
}

body.chat-fullscreen .chat-stream:empty {
  display: grid;
}

body.chat-fullscreen .search-chat-row {
  grid-area: composer;
  width: var(--fullscreen-composer-width);
  grid-template-columns: minmax(0, 1fr) var(--hero-expand-size);
  justify-items: center;
  justify-self: center;
  align-self: end;
  transform: none;
}

body.chat-fullscreen .search-chat-box {
  grid-template-columns: max-content max-content minmax(0, 1fr);
  width: 100%;
  max-width: 100%;
  justify-self: stretch;
}

body.chat-fullscreen .search-chat-box,
body.chat-fullscreen .composer-input-shell {
  border-radius: var(--radius-ios);
}

body.chat-fullscreen .composer-input-row {
  grid-template-columns: 42px minmax(0, 1fr) max-content;
}

body.chat-fullscreen .chat-side-controls {
  transform: none;
  gap: 22px;
}

@media (min-width: 769px) {
  body.chat-fullscreen .search-chat-row {
    grid-template-columns: minmax(0, 1fr);
  }

  body.chat-fullscreen .chat-side-controls {
    position: absolute;
    top: 50%;
    right: 0;
    transform: translateY(-50%);
  }
}

body.chat-fullscreen .action-pair {
  display: none;
  grid-template-columns: minmax(116px, 168px);
}

body.chat-fullscreen .ghost-btn {
  display: none;
}

body.chat-fullscreen .solid-btn {
  min-width: 116px;
  padding: 0 clamp(18px, 1.7vw, 28px);
  font-size: clamp(18px, 1.45vw, 22px);
  line-height: 1;
  letter-spacing: 0;
  white-space: nowrap;
}

.model-version-btn > .model-version-badges {
  width: 100%;
  justify-content: center;
}

body.chat-fullscreen #sendBtn.send-inline-btn {
  align-self: stretch;
  width: auto;
  min-width: max-content;
  min-height: 52px;
  padding: 0 clamp(18px, 1.4vw, 24px);
}

body.chat-fullscreen #aiQuery {
  width: 100%;
  min-height: 72px;
  margin-left: 0;
  padding-left: 12px;
  padding-right: 12px;
  box-sizing: border-box;
}

body.chat-fullscreen .quick-prompts {
  display: none;
}

body.chat-fullscreen.fullscreen-conversation-view .chat-stream {
  display: grid;
}

body.chat-fullscreen.fullscreen-conversation-view .fullscreen-hot-tabs,
body.chat-fullscreen.fullscreen-conversation-view .model-switcher {
  display: none;
}

body.chat-fullscreen.fullscreen-conversation-view .model-bar {
  grid-template-rows: auto minmax(0, 1fr);
}

body.chat-fullscreen.fullscreen-conversation-view .model-bar > span {
  display: none;
}

.fullscreen-conversation-page {
  display: none;
}

body.chat-fullscreen.fullscreen-conversation-view .fullscreen-conversation-page {
  display: grid;
  grid-template-rows: auto auto minmax(0, 1fr);
  gap: 14px;
  width: 100%;
  max-width: 100%;
  height: 100%;
  justify-self: stretch;
  min-height: 0;
  color: #fff;
  overflow: hidden;
}

.fullscreen-conversation-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 12px;
  padding: 16px;
  border: 1px solid rgba(255, 255, 255, 0.16);
  border-radius: var(--radius-ios);
  background: rgba(255, 255, 255, 0.1);
  backdrop-filter: blur(18px);
}

.fullscreen-conversation-head div {
  display: grid;
  gap: 4px;
  flex: 1 1 160px;
  min-width: 0;
}

.fullscreen-conversation-head strong {
  font-size: 22px;
}

.fullscreen-conversation-head span {
  color: rgba(255, 255, 255, 0.68);
  font-size: 13px;
  font-weight: 800;
  overflow-wrap: anywhere;
}

.fullscreen-conversation-head button {
  flex: 0 0 auto;
  min-height: 42px;
  padding: 0 16px;
  border: 0;
  border-radius: var(--radius-ios);
  color: #fff;
  background: linear-gradient(135deg, var(--green), var(--green-dark));
  cursor: pointer;
  font-weight: 900;
}

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

.fullscreen-conversation-filters button {
  min-height: 34px;
  padding: 0 12px;
  border: 1px solid rgba(255, 255, 255, 0.18);
  border-radius: var(--radius-control);
  color: rgba(255, 255, 255, 0.82);
  background: rgba(15, 23, 42, 0.35);
  cursor: pointer;
  font-weight: 900;
}

.fullscreen-conversation-filters button.active {
  border-color: rgba(16, 185, 129, 0.72);
  color: #d1fae5;
  background: rgba(16, 185, 129, 0.24);
}

.fullscreen-conversation-list {
  display: grid;
  align-content: start;
  gap: 10px;
  width: 100%;
  max-width: 100%;
  height: 100%;
  max-height: 100%;
  min-height: 0;
  overflow-x: hidden;
  overflow-y: auto;
  overscroll-behavior: contain;
  padding-right: 0;
  scrollbar-gutter: auto;
  scrollbar-width: thin;
  scrollbar-color: rgba(16, 185, 129, 0.72) rgba(255, 255, 255, 0.08);
}

.fullscreen-conversation-item {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  gap: 12px;
  width: 100%;
  min-width: 0;
  max-width: 100%;
  min-height: 68px;
  padding: 12px 14px;
  border: 1px solid rgba(255, 255, 255, 0.16);
  border-radius: var(--radius-ios);
  color: #fff;
  background: rgba(255, 255, 255, 0.1);
  cursor: pointer;
  text-align: left;
}

.fullscreen-conversation-item.active,
.fullscreen-conversation-item:hover {
  border-color: rgba(16, 185, 129, 0.62);
  background: rgba(16, 185, 129, 0.18);
}

.fullscreen-conversation-main {
  display: grid;
  gap: 6px;
  min-width: 0;
}

.fullscreen-conversation-title-row {
  display: grid;
  grid-template-columns: 28px minmax(0, 1fr);
  align-items: center;
  gap: 8px;
  min-width: 0;
}

.fullscreen-conversation-rename {
  width: 28px;
  height: 28px;
  border: 1px solid rgba(255, 255, 255, 0.18);
  border-radius: var(--radius-ios);
  background: rgba(15, 23, 42, 0.34);
  cursor: pointer;
  position: relative;
}

.fullscreen-conversation-rename::before {
  content: "";
  position: absolute;
  left: 7px;
  top: 12px;
  width: 14px;
  height: 4px;
  border-radius: 999px;
  background: #d1fae5;
  transform: rotate(-35deg);
}

.fullscreen-conversation-rename::after {
  content: "";
  position: absolute;
  left: 17px;
  top: 8px;
  border-left: 5px solid #d1fae5;
  border-top: 3px solid transparent;
  border-bottom: 3px solid transparent;
  transform: rotate(-35deg);
}

.fullscreen-conversation-main strong {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  font-size: 16px;
}

.fullscreen-conversation-title-input {
  width: 100%;
  min-width: 0;
  height: 28px;
  padding: 0 8px;
  border: 1px solid rgba(94, 234, 212, 0.72);
  border-radius: 8px;
  color: #fff;
  background: rgba(15, 23, 42, 0.72);
  font: inherit;
  font-size: 16px;
  font-weight: 900;
  outline: 0;
}

.fullscreen-conversation-main small {
  color: rgba(255, 255, 255, 0.66);
  font-size: 12px;
  font-weight: 800;
}

.fullscreen-conversation-actions {
  display: inline-flex;
  flex-wrap: wrap;
  justify-content: end;
  gap: 6px;
  min-width: 0;
}

.fullscreen-conversation-actions span {
  display: inline-grid;
  place-items: center;
  min-height: 30px;
  padding: 0 10px;
  border-radius: var(--radius-ios);
  color: #d1fae5;
  background: rgba(15, 23, 42, 0.28);
  font-size: 12px;
  font-weight: 900;
}

.fullscreen-conversation-empty {
  display: grid;
  min-height: 180px;
  place-items: center;
  border: 1px dashed rgba(255, 255, 255, 0.2);
  border-radius: var(--radius-ios);
  color: rgba(255, 255, 255, 0.68);
  font-weight: 900;
}

.quick-prompts {
  justify-content: center;
  flex-wrap: wrap;
  gap: 8px;
}

.quick-prompts button,
.scene-buttons button {
  display: inline-grid;
  place-items: center;
  min-height: 38px;
  padding: 0 12px;
  border: 1px solid rgba(255, 255, 255, 0.34);
  border-radius: var(--radius-ios);
  color: #fff;
  background: rgba(15, 23, 42, 0.28);
  backdrop-filter: blur(14px);
  cursor: pointer;
  font-weight: 800;
}

.quick-prompts button:hover,
.scene-buttons button:hover,
.ghost-btn:hover,
.solid-btn:hover,
.tool-link:hover,
.start-chat:hover,
.favorite-btn:hover,
.nav-cta:hover {
  transform: translateY(-1px);
}

.metrics,
.section-head,
.tools-page,
.tool-grid,
.featured,
.scenes,
.api-panel {
  width: var(--section-width);
  margin-inline: auto;
}

.metrics {
  justify-content: space-between;
  gap: 14px;
  margin-top: 34px;
  margin-bottom: 64px;
  padding: 18px;
  border: 1px solid var(--line);
  border-radius: var(--radius-ios);
  background: #fff;
}

.metrics div {
  display: grid;
  gap: 4px;
}

.metrics strong {
  font-size: 28px;
}

.metrics span {
  color: var(--muted);
}

.section-head {
  display: flex;
  align-items: end;
  justify-content: space-between;
  gap: 22px;
  margin-bottom: 22px;
  scroll-margin-top: 108px;
}

.section-head h2,
.tools-page h2,
.featured h2,
.scenes h2,
.api-panel h2 {
  margin: 0;
  color: var(--ink);
  font-size: clamp(30px, 4vw, 46px);
  letter-spacing: 0;
}

.section-head .eyebrow,
.tools-page .eyebrow,
.featured .eyebrow,
.scenes .eyebrow,
.api-panel .eyebrow {
  color: var(--cyan);
}

.filter-row {
  flex-wrap: wrap;
  gap: 9px;
}

.filter {
  display: inline-grid;
  place-items: center;
  grid-auto-flow: column;
  gap: 7px;
  min-height: 52px;
  padding: 0 22px;
  border: 1px solid #dbe4ee;
  border-radius: var(--radius-ios);
  color: #334155;
  background: #fff;
  cursor: pointer;
  font-weight: 800;
}

.filter.active {
  color: #fff;
  border-color: transparent;
  background: var(--ink);
}

.filter.favorite-filter {
  position: relative;
  isolation: isolate;
  overflow: hidden;
  gap: 7px;
  padding-inline: 13px 15px;
  border-color: #f6d58b;
  color: #92400e;
  background: linear-gradient(180deg, #fffaf0 0%, #fff2c2 100%);
  box-shadow: 0 8px 18px rgba(245, 158, 11, 0.13);
}

.filter.favorite-filter::before,
.filter.favorite-filter::after {
  display: none;
}

.filter.favorite-filter.active {
  color: #78350f;
  border-color: #fbbf24;
  background: linear-gradient(180deg, #fde68a 0%, #fbbf24 100%);
  box-shadow: 0 10px 22px rgba(245, 158, 11, 0.2);
}

.favorite-filter-star,
.favorite-btn {
  --favorite-star-icon: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 64 64'%3E%3Cpath d='M32 6c2.5 0 4.6 1.6 5.5 4l4.4 12.1 12.8.4c2.5.1 4.7 1.7 5.5 4.1.8 2.4 0 5-2 6.5l-10 8.1 3.7 12.3c.7 2.4-.2 5-2.3 6.5s-4.8 1.6-6.9.2L32 53.1l-10.7 7.1c-2.1 1.4-4.9 1.3-6.9-.2s-3-4.1-2.3-6.5l3.7-12.3-10-8.1c-2-1.6-2.8-4.2-2-6.5.8-2.4 3-4 5.5-4.1l12.8-.4L26.5 10C27.4 7.6 29.5 6 32 6Z' fill='%23ffd95a' stroke='%2392400e' stroke-width='4' stroke-linejoin='round'/%3E%3Cpath d='M23 22c3.2-6.3 6.2-9.2 9-9.2' fill='none' stroke='%23fff7ad' stroke-width='5' stroke-linecap='round' opacity='.95'/%3E%3C/svg%3E");
}

.favorite-filter-star {
  position: relative;
  display: inline-grid;
  width: 24px;
  height: 24px;
  place-items: center;
  flex: 0 0 auto;
  border-radius: 999px;
  border: 1px solid #f6c453;
  color: #b45309;
  background: #fde68a;
  box-shadow: 0 3px 0 rgba(180, 83, 9, 0.12);
  font-size: 0;
  line-height: 1;
  transform: rotate(-7deg);
}

.favorite-filter-star::before {
  content: "";
  width: 20px;
  height: 20px;
  background: var(--favorite-star-icon) center / contain no-repeat;
}

.filter.favorite-filter:hover .favorite-filter-star,
.filter.favorite-filter.active .favorite-filter-star {
  color: #92400e;
  background: #fff7cc;
  transform: translateY(-1px) rotate(-7deg);
}

.filter-count {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 20px;
  height: 20px;
  padding: 0 6px;
  border-radius: 999px;
  color: inherit;
  background: rgba(15, 23, 42, 0.08);
  font-size: 11px;
  line-height: 1;
}

.filter.active .filter-count {
  background: rgba(255, 255, 255, 0.22);
}

.filter.favorite-filter .filter-count {
  color: #78350f;
  background: rgba(255, 255, 255, 0.54);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.6);
}

.filter.favorite-filter.active .filter-count {
  color: #fff;
  background: rgba(255, 255, 255, 0.22);
}

.tool-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 16px;
  margin-bottom: 74px;
}

.tools-page {
  display: grid;
  grid-template-columns: minmax(260px, 0.82fr) minmax(0, 1.18fr);
  gap: 22px;
  margin-bottom: 28px;
  padding: 28px;
  border: 1px solid var(--line);
  border-radius: var(--radius-ios);
  background: #fff;
  scroll-margin-top: 108px;
}

.ai-tools-page {
  grid-template-columns: 1fr;
  gap: 18px;
  padding: 0;
  border: 0;
  background: transparent;
}

.ai-tools-page .ai-tools-category-row {
  display: flex;
  width: 100%;
}

.ai-tools-grid {
  width: 100%;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  margin-bottom: 74px;
}

.ai-tools-card {
  min-height: 272px;
}

.ai-tools-actions {
  grid-template-columns: 1fr 1fr;
}

.tool-download.unavailable,
.tool-download.unavailable:hover {
  color: #64748b;
  background: #e2e8f0;
  cursor: not-allowed;
  opacity: 0.78;
  transform: none;
}

.tools-page-copy p:not(.eyebrow) {
  margin: 12px 0 0;
  color: var(--muted);
  line-height: 1.7;
}

.tools-page-actions,
.api-endpoint-list {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 18px;
}

.tools-page-actions a,
.api-endpoint-list span {
  display: inline-flex;
  min-height: 34px;
  align-items: center;
  padding: 0 12px;
  border: 1px solid rgba(8, 145, 178, 0.22);
  border-radius: var(--radius-ios);
  color: #0f766e;
  background: rgba(240, 253, 250, 0.88);
  font-size: 12px;
  font-weight: 950;
  text-decoration: none;
}

.tools-interface,
.api-workbench {
  display: grid;
  gap: 12px;
  min-width: 0;
  padding: 16px;
  border: 1px solid rgba(148, 163, 184, 0.22);
  border-radius: var(--radius-ios);
  background: linear-gradient(135deg, rgba(248, 250, 252, 0.98), rgba(236, 253, 245, 0.9));
}

.tools-interface-toolbar,
.api-workbench-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}

.api-model-page .api-workbench-head {
  display: grid;
  grid-template-columns: 1fr;
  align-items: center;
  justify-content: stretch;
  gap: 12px;
  padding: 24px 16px;
  border: 1px solid rgba(8, 145, 178, 0.16);
  border-radius: var(--radius-ios);
  background:
    linear-gradient(135deg, rgba(224, 242, 254, 0.78), rgba(236, 253, 245, 0.86)),
    #fff;
}

.tools-interface-toolbar span,
.api-workbench-head span {
  color: var(--cyan);
  font-size: 12px;
  font-weight: 1000;
}

.api-model-page .api-workbench-head span {
  width: 100%;
  color: var(--ink);
  font-size: 18px;
  text-align: center;
}

.api-model-page .api-workbench-head strong {
  display: block;
}

.api-model-page .api-workbench-head > strong {
  display: none;
}

.api-promo-copy {
  display: grid;
  grid-column: 1;
  grid-row: 1;
  justify-items: center;
  gap: 10px;
  max-width: 860px;
  margin: 0 auto;
  text-align: center;
}

.api-account-summary {
  display: grid;
  grid-column: 1;
  grid-row: 1;
  gap: 10px;
  justify-self: end;
  width: clamp(190px, 15vw, 210px);
  margin-right: 0;
  min-width: 0;
  padding: 12px;
  border: 1px solid rgba(148, 163, 184, 0.18);
  border-radius: 12px;
  color: var(--ink);
  background: #fff;
  box-shadow: 0 12px 30px rgba(8, 145, 178, 0.12);
}

.api-account-summary > span {
  width: auto;
  color: #0369a1;
  font-size: 14px;
  font-weight: 1000;
  text-align: center;
}

.api-account-balance {
  display: block;
  min-width: 0;
  padding: 8px;
  border-radius: 10px;
  color: #0f172a;
  background: rgba(224, 242, 254, 0.64);
  font-size: 13px;
  font-weight: 1000;
  line-height: 1.15;
  overflow-wrap: anywhere;
}

.api-account-metrics {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
}

.api-account-metrics div {
  min-width: 0;
  padding: 8px;
  border-radius: 10px;
  background: rgba(224, 242, 254, 0.64);
}

.api-account-balance small,
.api-account-balance strong,
.api-account-metrics small,
.api-account-metrics strong {
  display: block;
  min-width: 0;
  overflow-wrap: anywhere;
}

.api-account-balance small,
.api-account-metrics small {
  color: #64748b;
  font-size: 10px;
  font-weight: 900;
}

.api-account-balance strong,
.api-account-metrics strong {
  margin-top: 4px;
  color: #0f172a;
  font-size: 13px;
  font-weight: 1000;
  line-height: 1.15;
}

.api-account-recharge {
  display: grid;
  place-items: center;
  min-height: 38px;
  border: 0;
  border-radius: 12px;
  color: #fff;
  background: linear-gradient(135deg, rgba(16, 185, 129, 0.95), rgba(14, 165, 233, 0.95));
  cursor: pointer;
  font-size: 13px;
  font-weight: 1000;
}

.api-account-actions {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
}

.api-account-actions a {
  display: grid;
  place-items: center;
  min-height: 38px;
  border-radius: 12px;
  color: #fff;
  background: linear-gradient(135deg, rgba(16, 185, 129, 0.95), rgba(14, 165, 233, 0.95));
  font-size: 13px;
  font-weight: 1000;
  text-decoration: none;
}

.api-account-create {
  display: grid;
  place-items: center;
  min-height: 38px;
  border: 0;
  border-radius: 12px;
  color: #fff;
  background: linear-gradient(135deg, rgba(37, 99, 235, 0.95), rgba(14, 165, 233, 0.95));
  cursor: pointer;
  font-size: 13px;
  font-weight: 1000;
}

.api-model-page .api-promo-copy > span {
  width: auto;
  color: var(--ink);
  font-size: 50px;
  font-weight: 1000;
  line-height: 1.05;
}

.api-promo-copy strong {
  color: #0369a1;
  font-size: 30px;
  font-weight: 1000;
  line-height: 1.2;
}

.api-promo-copy .api-recharge-title {
  margin-bottom: -4px;
}

.api-promo-copy p {
  margin: 0;
  color: #475569;
  font-size: 15px;
  font-weight: 800;
  line-height: 1.6;
}

.api-model-search {
  display: grid;
  grid-template-columns: auto minmax(180px, 1fr) 38px;
  align-items: center;
  gap: 10px;
  width: min(100%, 540px);
  margin-top: 4px;
  padding: 8px 12px;
  border: 1px solid rgba(8, 145, 178, 0.22);
  border-radius: 14px;
  background: rgba(255, 255, 255, 0.88);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.8);
}

.api-model-page .api-model-search span {
  width: auto;
  color: #0369a1;
  font-size: 13px;
  line-height: 1;
  text-align: left;
}

.api-model-search input {
  width: 100%;
  min-height: 34px;
  border: 0;
  outline: 0;
  color: var(--ink);
  background: transparent;
  font: inherit;
  font-size: 14px;
  font-weight: 850;
}

.api-model-search-btn {
  position: relative;
  display: grid;
  place-items: center;
  width: 38px;
  height: 34px;
  border: 0;
  border-radius: 10px;
  background: linear-gradient(135deg, #0ea5e9, #10b981);
  box-shadow: 0 8px 18px rgba(14, 165, 233, 0.2);
  cursor: pointer;
}

.api-model-search-btn::before {
  content: "";
  width: 15px;
  height: 15px;
  border: 2px solid #fff;
  border-radius: 999px;
  box-sizing: border-box;
}

.api-model-search-btn::after {
  content: "";
  position: absolute;
  width: 8px;
  height: 2px;
  border-radius: 999px;
  background: #fff;
  transform: translate(7px, 7px) rotate(45deg);
}

.tools-interface-search,
.api-code-card {
  min-height: 46px;
  padding: 12px 14px;
  border: 1px solid rgba(148, 163, 184, 0.26);
  border-radius: var(--radius-ios);
  color: #64748b;
  background: #fff;
  font-weight: 900;
}

.tools-interface-grid,
.api-flow {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}

.tools-interface-grid article,
.api-flow article {
  min-height: 98px;
  padding: 13px;
  border: 1px solid rgba(148, 163, 184, 0.2);
  border-radius: var(--radius-ios);
  background: rgba(255, 255, 255, 0.78);
}

.tools-interface-grid span,
.api-flow b {
  display: inline-flex;
  min-height: 22px;
  align-items: center;
  padding: 0 8px;
  border-radius: 999px;
  color: #0369a1;
  background: #e0f2fe;
  font-size: 11px;
  font-weight: 1000;
}

.tools-interface-grid strong,
.api-flow span {
  display: block;
  margin-top: 10px;
  color: var(--ink);
  font-weight: 1000;
}

.tools-interface-grid p,
.api-code-card p {
  margin: 8px 0 0;
  color: var(--muted);
  font-size: 13px;
  line-height: 1.55;
}

.api-code-card code {
  display: block;
  margin-top: 8px;
  color: #0f172a;
  white-space: normal;
  overflow-wrap: anywhere;
}

.tools-interface-grid.top-tools-catalog {
  grid-template-columns: repeat(auto-fit, minmax(190px, 1fr));
  max-height: min(62vh, 640px);
  overflow: auto;
  padding-right: 4px;
}

.tools-showcase-card {
  display: grid;
  gap: 10px;
  min-height: 206px;
}

.tools-showcase-top {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  align-items: center;
  gap: 10px;
}

.tools-showcase-icon.app-icon {
  width: 38px;
  height: 38px;
}

.tools-interface-grid.top-tools-catalog .app-icon {
  min-height: 0;
  padding: 0;
  border-radius: var(--radius-ios);
  color: transparent;
  background: rgba(255, 255, 255, 0.96);
  font-size: 0;
}

.tools-showcase-top strong {
  display: block;
  color: var(--ink);
  font-weight: 1000;
  line-height: 1.2;
}

.tools-showcase-top p {
  display: flex;
  align-items: center;
  gap: 6px;
  margin: 4px 0 0;
  color: var(--muted);
  font-size: 12px;
}

.tools-interface-grid.top-tools-catalog .tools-showcase-top p > span,
.tools-interface-grid.top-tools-catalog .country-badge span,
.tools-interface-grid.top-tools-catalog .app-icon span {
  min-height: 0;
  padding: 0;
  border-radius: 0;
  color: inherit;
  background: transparent;
  font-size: inherit;
}

.tools-showcase-card > p {
  margin: 0;
  color: var(--muted);
  font-size: 12px;
  line-height: 1.5;
}

.tools-showcase-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.tools-showcase-tags span {
  display: inline-flex;
  min-height: 22px;
  align-items: center;
  padding: 0 7px;
  border-radius: 999px;
  color: #0f766e;
  background: rgba(240, 253, 250, 0.9);
  font-size: 11px;
  font-weight: 900;
}

.tools-showcase-card a {
  align-self: end;
  justify-self: start;
  color: #0f766e;
  font-size: 12px;
  font-weight: 950;
  text-decoration: none;
}

.api-panel.api-model-page {
  grid-template-columns: 1fr;
  align-items: stretch;
  justify-items: stretch;
  min-height: calc(100svh - 120px);
  margin-bottom: 0;
  padding: 0;
  border: 0;
  background: transparent;
}

.api-model-page > div:first-child {
  display: none;
}

.api-model-page .api-workbench {
  grid-template-rows: auto minmax(0, 1fr);
  width: 100%;
  min-height: calc(100svh - 120px);
  padding: 0;
  border: 0;
  background: transparent;
}

.api-model-page .api-flow,
.api-model-page .api-code-card,
.api-model-page .api-cards {
  display: none;
}

.api-model-market {
  overflow: hidden;
  display: grid;
  grid-template-columns: minmax(220px, 280px) minmax(0, 1fr);
  gap: 14px;
  min-height: 0;
  height: 100%;
  padding: 14px;
  border: 1px solid rgba(14, 165, 233, 0.18);
  border-radius: 22px;
  background:
    linear-gradient(135deg, rgba(224, 242, 254, 0.72), rgba(236, 253, 245, 0.68)),
    rgba(255, 255, 255, 0.58);
  box-shadow: 0 18px 50px rgba(15, 23, 42, 0.08);
  margin-bottom: 36px;
}

.api-provider-list,
.api-version-list {
  display: grid;
  align-content: start;
  gap: 10px;
  max-height: min(64vh, 640px);
  overflow: auto;
  padding-right: 4px;
  scrollbar-gutter: stable;
  scrollbar-width: thin;
  scrollbar-color: rgba(16, 185, 129, 0.76) rgba(8, 145, 178, 0.08);
}

.api-provider-list::-webkit-scrollbar,
.api-version-list::-webkit-scrollbar {
  width: 8px;
  height: 8px;
}

.api-provider-list::-webkit-scrollbar-track,
.api-version-list::-webkit-scrollbar-track {
  border-radius: 999px;
  background: rgba(8, 145, 178, 0.08);
}

.api-provider-list::-webkit-scrollbar-thumb,
.api-version-list::-webkit-scrollbar-thumb {
  border: 2px solid rgba(240, 253, 250, 0.95);
  border-radius: 999px;
  background: linear-gradient(180deg, #5eead4, #10b981);
}

.api-provider-list::-webkit-scrollbar-thumb:hover,
.api-version-list::-webkit-scrollbar-thumb:hover {
  background: linear-gradient(180deg, #99f6e4, #059669);
}

.api-model-page .api-provider-list,
.api-model-page .api-version-list {
  max-height: calc(100svh - 218px);
  min-height: 0;
}

.api-market-label {
  color: #0369a1;
  font-size: 20px;
  font-weight: 1000;
  line-height: 1.2;
}

.api-provider-list > .api-market-label {
  text-align: center;
}

.api-provider-item,
.api-version-group {
  border: 1px solid rgba(148, 163, 184, 0.22);
  border-radius: var(--radius-ios);
  background: rgba(255, 255, 255, 0.82);
}

.api-provider-item {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  align-items: center;
  gap: 10px;
  min-height: 62px;
  padding: 10px;
  width: 100%;
  color: inherit;
  font: inherit;
  text-align: left;
  cursor: pointer;
  transition: border-color 0.16s ease, box-shadow 0.16s ease, transform 0.16s ease, background 0.16s ease;
}

.api-provider-item:hover,
.api-provider-item:focus-visible {
  border-color: rgba(14, 165, 233, 0.5);
  background: linear-gradient(135deg, rgba(224, 242, 254, 0.88), rgba(236, 253, 245, 0.92));
  box-shadow: 0 10px 28px rgba(8, 145, 178, 0.14);
  outline: 0;
  transform: translateY(-1px);
}

.api-provider-item.active {
  border-color: rgba(14, 165, 233, 0.44);
  background: linear-gradient(135deg, rgba(224, 242, 254, 0.94), rgba(236, 253, 245, 0.9));
  box-shadow: inset 3px 0 0 #0ea5e9;
}

.api-provider-icon.app-icon {
  width: 34px;
  height: 34px;
}

.api-provider-copy {
  min-width: 0;
}

.api-provider-name-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  gap: 8px;
  min-width: 0;
}

.api-provider-item strong,
.api-provider-item em {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.api-provider-item strong {
  color: var(--ink);
  font-size: 13px;
  font-weight: 1000;
}

.api-provider-item em {
  color: var(--muted);
  font-size: 11px;
  font-weight: 900;
  font-style: normal;
}

.api-version-group {
  display: contents;
  border: 0;
  background: transparent;
}

.api-version-group h3 {
  margin: 0;
  color: var(--ink);
  font-size: 14px;
  font-weight: 1000;
}

.api-version-list-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.api-version-list-head .api-market-label {
  min-width: 0;
}

.api-version-list-head .api-version-sortbar {
  flex: 0 0 auto;
}

.api-version-sortbar {
  justify-self: end;
  display: inline-flex;
  flex-wrap: nowrap;
  justify-content: flex-end;
  gap: 8px;
  margin-left: auto;
}

.api-version-sort {
  min-height: 34px;
  padding: 0 13px;
  border: 1px solid rgba(8, 145, 178, 0.22);
  border-radius: 10px;
  color: #0f766e;
  background: #fff;
  cursor: pointer;
  font-size: 13px;
  font-weight: 1000;
  transition: border-color 0.16s ease, box-shadow 0.16s ease, transform 0.16s ease, background 0.16s ease;
}

.api-version-sort:hover,
.api-version-sort:focus-visible {
  border-color: rgba(14, 165, 233, 0.5);
  background: #fff;
  box-shadow: 0 8px 20px rgba(8, 145, 178, 0.14);
  outline: 0;
  transform: translateY(-1px);
}

.api-version-sort.active {
  color: #0369a1;
  border-color: rgba(14, 165, 233, 0.42);
  background: #fff;
  box-shadow: inset 0 -3px 0 #0ea5e9, 0 8px 20px rgba(8, 145, 178, 0.12);
}

.api-version-item {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: 10px;
  align-items: start;
  width: 100%;
  padding: 10px;
  border: 1px solid rgba(148, 163, 184, 0.18);
  border-radius: 12px;
  background: #fff;
  color: inherit;
  cursor: pointer;
  font: inherit;
  text-align: left;
  transition: border-color 0.16s ease, box-shadow 0.16s ease, transform 0.16s ease, background 0.16s ease;
}

.api-version-item:hover,
.api-version-item:focus-visible {
  border-color: rgba(14, 165, 233, 0.5);
  background: linear-gradient(135deg, rgba(224, 242, 254, 0.88), rgba(236, 253, 245, 0.92));
  box-shadow: 0 10px 28px rgba(8, 145, 178, 0.14);
  outline: 0;
  transform: translateY(-1px);
}

.api-version-item.active {
  border-color: rgba(14, 165, 233, 0.44);
  background: linear-gradient(135deg, rgba(224, 242, 254, 0.94), rgba(236, 253, 245, 0.9));
  box-shadow: inset 3px 0 0 #0ea5e9;
}

.api-version-summary {
  display: grid;
  gap: 5px;
  min-width: 0;
}

.api-version-name-row {
  display: flex;
  align-items: center;
  gap: 8px;
  min-width: 0;
  flex-wrap: wrap;
}

.api-version-icon {
  width: 26px;
  height: 26px;
  flex: 0 0 26px;
  border-radius: 8px;
}

.api-version-item strong,
.api-version-item code {
  display: block;
  overflow-wrap: anywhere;
}

.api-version-item strong {
  color: var(--ink);
  font-size: 16px;
  font-weight: 1000;
  line-height: 1.2;
}

.api-version-item code {
  color: #64748b;
  font-size: 12px;
  line-height: 1.2;
  margin-top: -1px;
}

.api-version-item .model-version-badges {
  margin-top: 0;
}

.api-version-item .model-version-price {
  justify-self: start;
  width: 100%;
}

.api-version-item .model-version-price.option.support-layout {
  color: var(--ink);
}

.api-version-item .model-version-price-chip.currency {
  color: #075985;
  background: #e0f2fe;
  text-shadow: none;
}

.api-version-item .model-version-price-chip.currency.regional,
.api-version-item .model-version-price-chip.region-tag {
  color: #ffe600;
  background: #de2910;
}

.api-version-item .model-version-price-chip.input,
.api-version-item .model-version-price-chip.rmb.input {
  color: #92400e;
  background: rgba(245, 158, 11, 0.18);
}

.api-version-item .model-version-price-chip.output,
.api-version-item .model-version-price-chip.rmb.output {
  color: #0f766e;
  background: rgba(16, 185, 129, 0.14);
}

.api-version-item .model-version-price-chip.estimate {
  color: #b91c1c;
  background: rgba(239, 68, 68, 0.12);
}

.api-version-item .model-version-price-chip.exchange,
.api-version-item .model-version-price-chip.exchange-date {
  color: #1d4ed8;
  background: rgba(59, 130, 246, 0.14);
}

.api-version-item .model-version-price-chip.rate,
.api-version-item .model-version-price-chip.unit,
.api-version-item .model-version-price-chip.rmb {
  color: #7c2d12;
  background: rgba(249, 115, 22, 0.14);
}

.api-version-price-pending {
  justify-self: start;
  color: #64748b;
  font-size: 12px;
  font-weight: 950;
}

.tool-card {
  display: grid;
  grid-template-rows: auto minmax(70px, 1fr) auto auto;
  gap: 14px;
  min-height: 286px;
  padding: 16px;
  border: 1px solid #dce5ee;
  border-radius: var(--radius-ios);
  background: #fff;
  box-shadow: 0 10px 30px rgba(15, 23, 42, 0.07);
  transition: transform 160ms ease, box-shadow 160ms ease, border-color 160ms ease;
}

.tool-card:hover {
  transform: translateY(-3px);
  border-color: rgba(37, 99, 235, 0.42);
  box-shadow: 0 18px 44px rgba(15, 23, 42, 0.13);
}

.ad-card {
  position: relative;
  overflow: hidden;
  border-color: rgba(56, 189, 248, 0.38);
  background:
    linear-gradient(135deg, rgba(239, 246, 255, 0.96), rgba(236, 253, 245, 0.92)),
    #fff;
}

.ad-card::after {
  content: "ADS";
  position: absolute;
  right: 12px;
  top: 10px;
  color: rgba(2, 132, 199, 0.18);
  font-size: 34px;
  font-weight: 1000;
  line-height: 1;
  pointer-events: none;
}

.ad-logo {
  width: 52px;
  height: 52px;
  color: #fff;
  background:
    radial-gradient(circle at 28% 18%, rgba(255, 255, 255, 0.86), transparent 24%),
    linear-gradient(135deg, #38bdf8, #10b981 58%, #f59e0b);
  border: 0;
  box-shadow: 0 12px 28px rgba(14, 165, 233, 0.24);
  font-size: 13px;
  font-weight: 1000;
  letter-spacing: 0;
}

.ad-badge {
  color: #075985;
  background: #e0f2fe;
}

.ad-tag {
  color: #075985;
  background: rgba(224, 242, 254, 0.86);
}

.ad-actions {
  grid-template-columns: 1fr 1fr;
}

.adsense-card {
  grid-template-rows: auto auto minmax(96px, 1fr);
}

.adsense-slot {
  width: 100%;
  min-height: 96px;
  border-radius: var(--radius-ios);
  background: rgba(255, 255, 255, 0.62);
}

.ad-promo-btn {
  background: linear-gradient(135deg, #fbbf24, #f59e0b);
}

.tool-top {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  min-width: 0;
}

.logo {
  flex: 0 0 auto;
  width: 46px;
  height: 46px;
}

.tool-title-row {
  display: flex;
  align-items: flex-start;
  gap: 8px;
  width: 100%;
}

.tool-title {
  flex: 1;
  min-width: 0;
}

.tool-name-group {
  display: flex;
  align-items: flex-start;
  flex-wrap: wrap;
  column-gap: 7px;
  row-gap: 4px;
  min-width: 0;
}

.tool-name-group h3 {
  min-width: 0;
  max-width: 100%;
  overflow-wrap: break-word;
  line-height: 1.16;
  white-space: normal;
}

.model-option-name {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.country-badge {
  align-self: center;
  flex: 0 0 auto;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 5px;
  min-width: var(--flag-width);
  min-height: var(--flag-height);
  padding: 0;
  border: 0;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
  line-height: 1;
}

.country-flag {
  position: relative;
  display: inline-grid;
  flex: 0 0 auto;
  width: var(--flag-width);
  height: var(--flag-height);
  place-items: center;
  overflow: hidden;
  border: 0;
  border-radius: var(--radius-ios);
  background: transparent;
  box-shadow: 0 2px 6px rgba(15, 23, 42, 0.12);
}

.country-flag img {
  display: block;
  width: 100%;
  height: 100%;
  border-radius: inherit;
  object-fit: cover;
}

.flag-emoji {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  height: 100%;
  font-size: var(--flag-height);
  line-height: var(--flag-height);
}

.flag-fallback {
  display: none;
  color: #334155;
  font-size: 8px;
  font-weight: 1000;
  line-height: 1;
}

.country-hover-tip {
  position: fixed;
  z-index: 2147483647;
  max-width: min(420px, calc(100vw - 24px));
  padding: 7px 9px;
  border-radius: var(--radius-ios);
  color: #fff;
  background: rgba(15, 23, 42, 0.94);
  box-shadow: 0 12px 30px rgba(15, 23, 42, 0.24);
  font-size: 12px;
  font-weight: 900;
  line-height: 1.25;
  white-space: normal;
  overflow-wrap: anywhere;
  text-align: center;
  opacity: 0;
  pointer-events: none;
  transform: translate(-50%, 4px) scale(0.96);
  transition: opacity 140ms ease, transform 140ms ease;
}

.country-hover-tip::after {
  content: "";
  position: absolute;
  left: 50%;
  top: calc(100% - 4px);
  width: 8px;
  height: 8px;
  background: rgba(15, 23, 42, 0.94);
  transform: translateX(-50%) rotate(45deg);
}

.country-hover-tip.show {
  opacity: 1;
  transform: translate(-50%, 0) scale(1);
}

.flag-missing .flag-fallback {
  display: inline;
}

.country-globe {
  border-radius: 50%;
  background:
    radial-gradient(circle at 50% 50%, rgba(255, 255, 255, 0.92) 0 18%, transparent 19%),
    linear-gradient(90deg, transparent 0 44%, rgba(255, 255, 255, 0.65) 44% 56%, transparent 56%),
    linear-gradient(180deg, transparent 0 44%, rgba(255, 255, 255, 0.65) 44% 56%, transparent 56%),
    radial-gradient(circle at 50% 50%, #38bdf8, #2563eb 72%);
}

.tool-country,
.model-country,
.chat-current-country {
  min-width: var(--flag-width);
  min-height: var(--flag-height);
  padding: 0;
}

.country-name {
  position: absolute;
  width: 1px;
  height: 1px;
  margin: -1px;
  padding: 0;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

.model-option-name {
  flex: 1 1 auto;
}

.model-pill .model-option-name {
  flex: 0 1 auto;
  display: inline-flex;
  align-items: center;
  line-height: 1;
}

.model-country,
.chat-current-country {
  margin-left: auto;
}

.model-pill .model-country,
.chat-model-main .chat-current-country {
  margin-left: 2px;
  align-self: center;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.chat-model-main .model-hot-badge,
.chat-model-main .chat-current-country {
  margin-left: 0;
}

body.night-theme .country-flag {
  box-shadow: 0 2px 7px rgba(0, 0, 0, 0.28);
}

.tool-card h3 {
  margin: 0;
  font-size: 18px;
}

.tool-card p {
  margin: 0;
  color: var(--muted);
  line-height: 1.58;
}

.tool-company {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  max-width: 100%;
  min-height: 24px;
  margin-top: 6px;
}

.tool-company > span:first-child {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.badge,
.tag {
  display: inline-flex;
  align-items: center;
  border-radius: var(--radius-ios);
  font-weight: 900;
}

.badge {
  flex: 0 0 auto;
  min-height: 22px;
  padding: 0 7px;
  color: #92400e;
  background: #fef3c7;
  font-size: 11px;
}

.model-hot-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex: 0 0 auto;
  min-height: 18px;
  padding: 0 5px;
  border-radius: var(--radius-ios);
  color: #92400e;
  background: #fef3c7;
  font-size: 10px;
  font-weight: 1000;
  line-height: 1;
}

.aggregate-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex: 0 0 auto;
  min-height: 18px;
  padding: 0 6px;
  border-radius: var(--radius-ios);
  color: #065f46;
  background: rgba(16, 185, 129, 0.16);
  border: 1px solid rgba(16, 185, 129, 0.28);
  font-size: 10px;
  font-weight: 1000;
  line-height: 1;
  white-space: nowrap;
}

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

.tag {
  min-height: 25px;
  padding: 0 8px;
  color: #475569;
  background: #eef5fb;
  font-size: 12px;
}

.tool-actions {
  align-self: end;
  display: grid;
  grid-template-columns: 1fr 1fr auto;
  gap: 8px;
}

.tool-link,
.start-chat,
.favorite-btn {
  display: grid;
  min-width: 0;
  place-items: center;
  min-height: 42px;
  border-radius: var(--radius-ios);
  cursor: pointer;
  font-weight: 900;
  white-space: nowrap;
  transition: transform 150ms ease, filter 150ms ease;
}

.tool-link {
  border: 0;
  color: #fff;
  background: linear-gradient(135deg, #38bdf8, #0284c7);
  text-decoration: none;
}

.tool-link::before {
  display: none;
}

.tool-link:hover {
  filter: brightness(1.03);
}

.start-chat {
  border: 0;
  color: #fff;
  background: linear-gradient(135deg, var(--green), var(--green-dark));
}

.favorite-btn {
  min-width: 42px;
  border: 1px solid #fde68a;
  color: #f59e0b;
  background: linear-gradient(145deg, #fff7ed, #fef3c7);
  font-size: 0;
  position: relative;
  overflow: hidden;
}

.favorite-btn.active {
  border-color: #fbbf24;
  background: linear-gradient(145deg, #fef08a, #f59e0b);
  box-shadow: 0 10px 24px rgba(245, 158, 11, 0.26);
}

.favorite-btn::before {
  content: "";
  position: absolute;
  left: 50%;
  top: 50%;
  width: 29px;
  height: 29px;
  background: var(--favorite-star-icon) center / contain no-repeat;
  transform: translate(-50%, -53%) rotate(-6deg);
  filter: drop-shadow(0 3px 0 rgba(146, 64, 14, 0.16));
}

.favorite-btn::after {
  content: "";
  position: absolute;
  left: 50%;
  top: 22px;
  width: 12px;
  height: 5px;
  transform: translateX(-50%);
  border-bottom: 2px solid #92400e;
  border-radius: 0 0 999px 999px;
  opacity: 0.7;
}

.favorite-btn.active::before {
  transform: translate(-50%, -53%) rotate(-6deg) scale(1.1);
}

.empty-state {
  grid-column: 1 / -1;
  padding: 34px;
  border: 1px dashed #bcccdc;
  border-radius: var(--radius-ios);
  background: #fff;
  color: var(--muted);
  text-align: center;
}

.featured,
.scenes,
.api-panel,
.login-panel {
  margin-bottom: 74px;
  padding: 28px;
  border: 1px solid var(--line);
  border-radius: var(--radius-ios);
  background: #fff;
}

.api-panel {
  display: grid;
  grid-template-columns: minmax(260px, 0.88fr) minmax(0, 1.12fr);
  align-items: center;
  gap: 24px;
}

.api-panel p:not(.eyebrow) {
  margin: 12px 0 0;
  color: var(--muted);
  line-height: 1.7;
}

.api-cards {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
}

.api-cards article {
  min-height: 152px;
  padding: 16px;
  border: 1px solid rgba(148, 163, 184, 0.22);
  border-radius: var(--radius-ios);
  background:
    linear-gradient(135deg, rgba(239, 246, 255, 0.96), rgba(240, 253, 250, 0.92)),
    #fff;
}

.api-cards span {
  display: inline-flex;
  min-height: 24px;
  align-items: center;
  padding: 0 8px;
  border-radius: 999px;
  color: #0369a1;
  background: #e0f2fe;
  font-size: 11px;
  font-weight: 1000;
}

.api-cards strong {
  display: block;
  margin-top: 12px;
  color: var(--ink);
  font-size: 17px;
}

.api-cards p {
  margin: 8px 0 0;
  color: var(--muted);
  font-size: 13px;
  line-height: 1.58;
}

body.night-theme .api-cards strong {
  color: #f8fafc;
}

.login-panel {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
  width: min(1160px, calc(100% - 28px));
  margin-inline: auto;
}

.login-panel p:not(.eyebrow) {
  margin: 12px 0 0;
  color: var(--muted);
  line-height: 1.7;
}

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

.login-actions button {
  min-height: 44px;
  padding: 0 18px;
  border: 0;
  border-radius: var(--radius-ios);
  color: #fff;
  background: linear-gradient(135deg, var(--green), var(--green-dark));
  cursor: pointer;
  font-weight: 900;
}

.login-actions button:first-child {
  color: var(--ink);
  background: #eef5fb;
}

.auth-modal {
  position: fixed;
  inset: 0;
  z-index: 100;
  display: grid;
  place-items: center;
  padding: 18px;
  background: rgba(2, 6, 23, 0.48);
  backdrop-filter: blur(12px);
  opacity: 0;
  pointer-events: none;
  transition: opacity 220ms ease;
}

.auth-modal.show {
  opacity: 1;
  pointer-events: auto;
}

.custom-model-modal {
  position: fixed;
  inset: 0;
  z-index: 2147483646;
  display: grid;
  place-items: center;
  padding: 18px;
  background: rgba(2, 6, 23, 0.5);
  backdrop-filter: blur(12px);
  opacity: 0;
  pointer-events: none;
  transition: opacity 220ms ease;
}

.custom-model-modal.show {
  opacity: 1;
  pointer-events: auto;
}

.quota-modal {
  position: fixed;
  inset: 0;
  z-index: 2147483647;
  display: grid;
  place-items: center;
  padding: clamp(10px, 3vw, 18px);
  overflow-y: auto;
  background: rgba(2, 6, 23, 0.52);
  backdrop-filter: blur(14px);
  opacity: 0;
  pointer-events: none;
  transition: opacity 220ms ease;
}

.quota-modal.show {
  opacity: 1;
  pointer-events: auto;
}

.site-notice-modal {
  position: fixed;
  inset: 0;
  z-index: 2147483647;
  display: grid;
  place-items: center;
  padding: 18px;
  background: transparent;
  backdrop-filter: none;
  opacity: 0;
  pointer-events: none;
  transition: opacity 220ms ease;
}

.site-notice-modal.show {
  opacity: 1;
  pointer-events: none;
}

.site-notice-card {
  position: relative;
  width: min(560px, 100%);
  padding: 24px 24px 28px;
  border: 1px solid rgba(255, 255, 255, 0.32);
  border-radius: var(--radius-ios);
  color: #fff;
  background: rgba(15, 23, 42, 0.82);
  backdrop-filter: blur(24px);
  box-shadow: var(--shadow);
  pointer-events: auto;
}

.site-notice-card h2 {
  margin: 6px 42px 10px 0;
  font-size: clamp(20px, 4vw, 28px);
  line-height: 1.2;
}

.site-notice-content {
  margin: 0;
  white-space: pre-wrap;
  line-height: 1.65;
}

.site-notice-content p {
  margin: 0 0 8px;
}

.site-notice-time {
  display: block;
  margin-top: 14px;
  color: rgba(226, 232, 240, 0.88);
  font-size: 12px;
  font-weight: 800;
}

.site-notice-media {
  display: grid;
  gap: 10px;
  margin-top: 12px;
}

.site-notice-media img,
.site-notice-media video {
  max-width: 100%;
  max-height: 320px;
  border-radius: var(--radius-ios);
  object-fit: contain;
  background: rgba(15, 23, 42, 0.42);
}

.site-notice-content a {
  color: #67e8f9;
  font-weight: 900;
}

.site-notice-content .site-notice-button,
.global-loading-notice .site-notice-button {
  display: inline-grid;
  width: max-content;
  max-width: 100%;
  min-height: 34px;
  margin-top: 10px;
  padding: 8px 14px;
  place-items: center;
  border-radius: var(--radius-ios);
  color: #052e2b;
  background: linear-gradient(135deg, #34d399, #22d3ee);
  text-decoration: none;
  white-space: normal;
  overflow-wrap: anywhere;
  box-shadow: 0 10px 24px rgba(14, 165, 233, 0.24);
}

.site-notice-mention {
  display: inline-block;
  padding: 1px 7px;
  border-radius: 999px;
  color: #d1fae5;
  background: rgba(16, 185, 129, 0.22);
  font-weight: 900;
}

.site-notice-countdown {
  position: relative;
  width: 100%;
  height: 6px;
  margin-top: 14px;
  overflow: hidden;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.12);
}

.site-notice-countdown span {
  display: block;
  width: 100%;
  height: 100%;
  transform-origin: left center;
  background: linear-gradient(90deg, #22d3ee, #34d399);
}

.site-notice-countdown.active span {
  animation: notice-countdown var(--notice-duration, 1s) linear forwards;
}

@keyframes notice-countdown {
  from {
    transform: scaleX(1);
  }
  to {
    transform: scaleX(0);
  }
}

.site-notice-close {
  position: absolute;
  top: 12px;
  right: 12px;
  width: 34px;
  height: 34px;
  border: 0;
  border-radius: var(--radius-ios);
  color: #fff;
  background: rgba(255, 255, 255, 0.12);
  cursor: pointer;
  font-size: 22px;
  line-height: 1;
}

.quota-card {
  position: relative;
  width: min(680px, calc(100vw - 20px));
  max-height: min(92vh, 760px);
  overflow-y: auto;
  padding: clamp(16px, 4vw, 24px);
  border: 1px solid rgba(255, 255, 255, 0.42);
  border-radius: var(--radius-ios);
  color: #fff;
  background: rgba(15, 23, 42, 0.78);
  backdrop-filter: blur(24px);
  box-shadow: var(--shadow);
  transform: translateY(18px) scale(0.97);
  transition: transform 260ms ease;
}

.quota-modal.show .quota-card {
  transform: translateY(0) scale(1);
}

.quota-modal.quota-recharge-page {
  place-items: center;
  padding: clamp(14px, 2.4vw, 28px);
  background:
    radial-gradient(circle at 18% 20%, rgba(20, 184, 166, 0.34), transparent 34%),
    radial-gradient(circle at 82% 12%, rgba(14, 165, 233, 0.28), transparent 32%),
    rgba(2, 6, 23, 0.68);
}

.quota-recharge-page .quota-card {
  display: grid;
  grid-template-areas:
    "eyebrow"
    "title"
    "copy"
    "preview"
    "actions";
  grid-template-columns: 1fr;
  grid-template-rows: auto auto auto minmax(0, 1fr) auto;
  gap: clamp(6px, 1vw, 10px);
  width: min(1240px, calc(100vw - 28px));
  min-height: min(650px, calc(100vh - 28px));
  max-height: none;
  padding: clamp(18px, 2.6vw, 32px);
  overflow: visible;
  background:
    linear-gradient(135deg, rgba(15, 23, 42, 0.92), rgba(30, 64, 107, 0.82)),
    rgba(15, 23, 42, 0.92);
}

.quota-recharge-page .quota-card .eyebrow {
  grid-area: eyebrow;
  align-self: end;
}

.quota-recharge-page .quota-card h2 {
  grid-area: title;
  margin: 0 48px 0 0;
  font-size: clamp(30px, 3vw, 35px);
  line-height: 1.08;
}

.quota-recharge-page .quota-card > p:not(.eyebrow) {
  grid-area: copy;
  align-self: start;
  max-width: none;
  white-space: nowrap;
}

.quota-recharge-page .quota-preview {
  display: grid;
  grid-area: preview;
  align-self: stretch;
  width: 100%;
  min-height: 0;
  margin: 0;
  padding: 0;
  overflow: visible;
  border: 0;
  border-radius: 0;
  background: transparent;
}

.quota-recharge-page .quota-modal-actions {
  grid-area: actions;
  margin-top: 2px;
  padding-top: 14px;
  border-top: 1px solid rgba(255, 255, 255, 0.14);
}

.quota-close {
  position: absolute;
  top: 12px;
  right: 12px;
  display: grid;
  place-items: center;
  width: 34px;
  height: 34px;
  border: 0;
  border-radius: var(--radius-ios);
  color: #fff;
  background: rgba(255, 255, 255, 0.12);
  cursor: pointer;
  font-size: 22px;
  line-height: 1;
}

.quota-card h2 {
  margin: 6px 42px 8px 0;
  font-size: clamp(22px, 4vw, 30px);
  line-height: 1.16;
}

.quota-card > p:not(.eyebrow) {
  margin: 0;
  color: rgba(255, 255, 255, 0.78);
  line-height: 1.7;
}

.quota-preview {
  display: grid;
  align-items: center;
  min-height: 108px;
  margin: 18px 0;
  padding: 12px;
  border: 1px dashed rgba(255, 255, 255, 0.35);
  border-radius: var(--radius-ios);
  color: rgba(255, 255, 255, 0.78);
  background:
    linear-gradient(135deg, rgba(16, 185, 129, 0.18), rgba(37, 99, 235, 0.18)),
    rgba(255, 255, 255, 0.08);
  font-weight: 950;
}

.quota-ad-window,
.quota-empty-products {
  display: grid;
  gap: 8px;
  width: 100%;
  text-align: left;
}

.quota-ad-badge {
  justify-self: start;
  padding: 3px 8px;
  border-radius: 999px;
  color: #d1fae5;
  background: rgba(16, 185, 129, 0.18);
  font-size: 12px;
  font-weight: 950;
}

.quota-ad-window strong {
  color: #fff;
  font-size: 18px;
}

.quota-ad-window p {
  margin: 0;
  color: rgba(255, 255, 255, 0.76);
}

.quota-ad-progress {
  overflow: hidden;
  height: 8px;
  border-radius: var(--radius-label);
  background: rgba(255, 255, 255, 0.14);
}

.quota-ad-progress span {
  display: block;
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(90deg, #22c55e, #60a5fa);
  transition: width 280ms ease;
}

.quota-product-groups {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  width: 100%;
  margin-bottom: 8px;
}

.quota-product-groups span {
  padding: 3px 8px;
  border-radius: 999px;
  color: rgba(255, 255, 255, 0.78);
  background: rgba(255, 255, 255, 0.1);
  font-size: 12px;
  font-weight: 900;
}

.quota-recharge-layout {
  display: grid;
  grid-template-columns: minmax(360px, 0.96fr) minmax(380px, 1.04fr);
  gap: 14px;
  align-items: stretch;
  width: 100%;
  height: 100%;
  min-height: 0;
}

.quota-recharge-left,
.quota-recharge-right {
  display: grid;
  gap: 12px;
  min-width: 0;
  min-height: 380px;
  align-content: start;
  padding: 14px;
  border: 1px solid rgba(255, 255, 255, 0.13);
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.06);
}

.quota-recharge-left {
  background: linear-gradient(180deg, rgba(45, 212, 191, 0.13), rgba(255, 255, 255, 0.05));
}

.quota-recharge-right {
  background: linear-gradient(180deg, rgba(14, 165, 233, 0.12), rgba(255, 255, 255, 0.05));
}

.quota-recharge-panel-head {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  align-items: end;
  min-width: 0;
}

.quota-recharge-panel-head strong {
  color: #fff;
  font-size: 20px;
  line-height: 1.15;
}

.quota-recharge-panel-head small {
  color: rgba(255, 255, 255, 0.62);
  font-size: 12px;
  font-weight: 850;
  text-align: right;
}

.quota-mode-tabs {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
  width: 100%;
  margin-bottom: 10px;
}

.quota-mode-tab {
  display: grid;
  gap: 3px;
  min-height: 62px;
  padding: 10px;
  border: 1px solid rgba(255, 255, 255, 0.16);
  border-radius: var(--radius-ios);
  color: #fff;
  background: rgba(255, 255, 255, 0.08);
  text-align: left;
  cursor: pointer;
}

.quota-mode-tab.active {
  border-color: rgba(94, 234, 212, 0.82);
  background: rgba(20, 184, 166, 0.2);
}

.quota-mode-tab span {
  font-size: 14px;
  font-weight: 950;
}

.quota-mode-tab small {
  color: rgba(255, 255, 255, 0.7);
  font-size: 11px;
  line-height: 1.25;
}

.quota-product-grid {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  width: 100%;
}

.quota-recharge-left .quota-product-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(104px, 1fr));
  gap: 8px;
  min-height: 116px;
  align-content: start;
}

.quota-product-card {
  display: grid;
  place-items: center;
  flex: 1 1 clamp(92px, 22%, 136px);
  width: auto;
  min-height: 48px;
  padding: 10px;
  border: 1px solid rgba(255, 255, 255, 0.18);
  border-radius: var(--radius-ios);
  color: #fff;
  background: rgba(255, 255, 255, 0.09);
  text-align: center;
}

.quota-product-card.active {
  border-color: rgba(94, 234, 212, 0.78);
  background: rgba(20, 184, 166, 0.18);
  box-shadow: 0 0 0 2px rgba(94, 234, 212, 0.12) inset;
}

.quota-product-card:disabled,
.quota-product-card.disabled {
  opacity: 0.42;
  cursor: not-allowed;
}

.quota-product-card span,
.quota-product-card small,
.quota-product-card em {
  color: rgba(255, 255, 255, 0.72);
  font-style: normal;
}

.quota-product-card strong {
  font-size: 18px;
  white-space: nowrap;
  overflow-wrap: normal;
}

.quota-product-card b {
  font-size: 20px;
  line-height: 1.2;
  white-space: nowrap;
}

.quota-recharge-left .quota-product-card {
  min-height: 54px;
  padding: 10px 8px;
}

.quota-recharge-right .quota-wallet-connect,
.quota-recharge-right .quota-payment-methods {
  margin-top: 0;
}

.quota-custom-amount {
  display: grid;
  gap: 8px;
  width: 100%;
  padding: 10px;
  border: 1px solid rgba(94, 234, 212, 0.26);
  border-radius: var(--radius-ios);
  background: rgba(20, 184, 166, 0.13);
}

.quota-custom-recharge {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
  width: 100%;
  padding: 0;
  border: 0;
  background: transparent;
}

.quota-custom-amount label,
.quota-custom-recharge label,
.quota-crypto-field {
  display: grid;
  gap: 5px;
  color: rgba(255, 255, 255, 0.74);
  font-size: 13px;
  font-weight: 850;
}

.quota-custom-amount input,
.quota-custom-recharge input {
  min-width: 0;
  height: 38px;
  padding: 0 10px;
  border: 1px solid rgba(255, 255, 255, 0.16);
  border-radius: 10px;
  color: #fff;
  background: rgba(255, 255, 255, 0.1);
}

.quota-crypto-select {
  position: relative;
  min-width: 0;
}

.quota-crypto-select summary {
  display: flex;
  align-items: center;
  gap: 10px;
  min-width: 0;
  height: 48px;
  padding: 0 12px;
  border: 1px solid rgba(255, 255, 255, 0.16);
  border-radius: 10px;
  color: #fff;
  background: rgba(255, 255, 255, 0.1);
  cursor: pointer;
  list-style: none;
}

.quota-crypto-select summary::-webkit-details-marker {
  display: none;
}

.quota-crypto-select summary::after {
  content: "";
  width: 7px;
  height: 7px;
  margin-left: auto;
  border-right: 2px solid rgba(255, 255, 255, 0.7);
  border-bottom: 2px solid rgba(255, 255, 255, 0.7);
  transform: rotate(45deg) translateY(-2px);
}

.quota-crypto-select[open] summary {
  border-color: rgba(94, 234, 212, 0.72);
  background: rgba(20, 184, 166, 0.18);
}

.quota-crypto-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex: 0 0 32px;
  width: 32px;
  height: 32px;
  overflow: visible;
}

.quota-crypto-icon img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: contain;
}

.quota-crypto-select summary strong,
.quota-crypto-select-menu strong {
  min-width: 0;
  font-size: 15px;
}

.quota-crypto-select summary small {
  overflow: hidden;
  min-width: 0;
  color: rgba(255, 255, 255, 0.62);
  text-overflow: ellipsis;
  white-space: nowrap;
}

.quota-crypto-select-menu {
  position: absolute;
  z-index: 4;
  top: calc(100% + 6px);
  left: 0;
  width: min(360px, calc(100vw - 32px));
  display: grid;
  gap: 6px;
  max-height: 320px;
  padding: 8px;
  overflow-y: auto;
  border: 1px solid rgba(94, 234, 212, 0.34);
  border-radius: 12px;
  background: rgba(15, 23, 42, 0.98);
  box-shadow: 0 18px 40px rgba(2, 6, 23, 0.34);
}

.quota-crypto-select-menu button {
  display: flex;
  align-items: center;
  gap: 10px;
  width: 100%;
  min-height: 52px;
  padding: 8px 10px;
  border: 1px solid transparent;
  border-radius: 10px;
  color: #fff;
  background: transparent;
  text-align: left;
}

.quota-crypto-field:nth-child(2) .quota-crypto-select-menu {
  right: 0;
  left: auto;
}

.quota-crypto-select-menu button.active,
.quota-crypto-select-menu button:hover {
  border-color: rgba(94, 234, 212, 0.34);
  background: rgba(20, 184, 166, 0.16);
}

.quota-crypto-select-menu span {
  display: grid;
  gap: 1px;
  min-width: 0;
}

.quota-crypto-select-menu small {
  color: rgba(255, 255, 255, 0.62);
}

.quota-custom-amount small,
.quota-custom-recharge small {
  grid-column: 1 / -1;
  color: rgba(255, 255, 255, 0.7);
}

.quota-crypto-methods {
  position: relative;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
  width: 100%;
}

.quota-crypto-methods > span {
  grid-column: 1 / -1;
  color: rgba(255, 255, 255, 0.74);
  font-size: 12px;
  font-weight: 950;
}

.quota-crypto-methods > button {
  display: grid;
  gap: 4px;
  min-height: 54px;
  padding: 10px;
  border: 1px solid rgba(255, 255, 255, 0.16);
  border-radius: var(--radius-ios);
  color: #fff;
  background: rgba(255, 255, 255, 0.08);
  text-align: left;
}

.quota-crypto-methods > button.active {
  border-color: rgba(94, 234, 212, 0.78);
  background: rgba(20, 184, 166, 0.2);
}

.quota-crypto-methods small,
.quota-crypto-address-hint {
  color: rgba(255, 255, 255, 0.68);
}

.quota-crypto-address-hint {
  width: 100%;
  font-size: 12px;
  font-weight: 850;
}

.quota-wallet-connect {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(128px, 1fr));
  gap: 8px;
  width: 100%;
  margin-top: 10px;
}

.quota-wallet-popover {
  position: absolute;
  z-index: 8;
  top: 50px;
  right: calc(50% + 8px);
  width: min(580px, calc(100vw - 96px));
  padding: 12px;
  border: 1px solid rgba(255, 255, 255, 0.22);
  border-radius: var(--radius-ios);
  background:
    linear-gradient(135deg, rgba(15, 23, 42, 0.94), rgba(30, 64, 107, 0.88)),
    rgba(15, 23, 42, 0.94);
  box-shadow: 0 22px 48px rgba(2, 6, 23, 0.38);
}

.quota-wallet-popover .quota-wallet-connect {
  grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
  max-height: 340px;
  margin-top: 0;
  overflow-y: auto;
}

.quota-wallet-connect > span {
  grid-column: 1 / -1;
  color: rgba(255, 255, 255, 0.74);
  font-size: 12px;
  font-weight: 950;
}

.quota-wallet-connect button {
  display: grid;
  grid-template-columns: 30px minmax(0, 1fr);
  align-items: center;
  gap: 4px;
  min-height: 52px;
  padding: 10px;
  border: 1px solid rgba(255, 255, 255, 0.16);
  border-radius: var(--radius-ios);
  color: #fff;
  background: rgba(255, 255, 255, 0.08);
  text-align: left;
}

.quota-wallet-icon {
  display: inline-grid;
  place-items: center;
  width: 26px;
  height: 26px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.96);
}

.quota-wallet-icon img {
  width: 20px;
  height: 20px;
  object-fit: contain;
}

.quota-wallet-connect button > span:not(.quota-wallet-icon) {
  display: grid;
  gap: 2px;
  min-width: 0;
}

.quota-wallet-connect strong {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.quota-wallet-connect button.active {
  border-color: rgba(94, 234, 212, 0.78);
  background: rgba(20, 184, 166, 0.2);
}

.quota-wallet-connect small {
  color: rgba(255, 255, 255, 0.68);
}

.quota-wallet-status {
  grid-column: 1 / -1;
  color: rgba(255, 255, 255, 0.78) !important;
  font-weight: 850;
}

.quota-payment-methods {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
  width: 100%;
  margin-top: 10px;
}

.quota-payment-methods > span {
  grid-column: 1 / -1;
  color: rgba(255, 255, 255, 0.74);
  font-size: 12px;
  font-weight: 950;
}

.quota-payment-method {
  display: grid;
  gap: 4px;
  min-height: 56px;
  padding: 10px;
  border: 1px solid rgba(255, 255, 255, 0.16);
  border-radius: var(--radius-ios);
  color: #fff;
  background: rgba(255, 255, 255, 0.08);
  text-align: left;
}

.quota-payment-method.active {
  border-color: rgba(94, 234, 212, 0.78);
  background: rgba(20, 184, 166, 0.18);
}

.quota-payment-method small {
  color: rgba(255, 255, 255, 0.68);
  font-size: 11px;
}

@media (max-width: 560px) {
  .quota-recharge-page .quota-card {
    display: grid;
    grid-template-areas:
      "eyebrow"
      "title"
      "copy"
      "preview"
      "actions";
    grid-template-columns: 1fr;
    min-height: 0;
    overflow-y: auto;
  }

  .quota-recharge-page .quota-preview {
    overflow: visible;
  }

  .quota-recharge-layout {
    grid-template-columns: 1fr;
  }

  .quota-recharge-left {
    padding: 14px;
  }

  .quota-recharge-left .quota-product-grid {
    grid-template-columns: repeat(auto-fit, minmax(104px, 1fr));
  }

  .quota-mode-tabs,
  .quota-custom-amount,
  .quota-custom-recharge,
  .quota-crypto-methods,
  .quota-payment-methods {
    grid-template-columns: 1fr;
  }

  .quota-product-card {
    flex-basis: calc(50% - 4px);
  }
}

.quota-modal-actions button:disabled {
  cursor: not-allowed;
  opacity: 0.58;
  transform: none;
  filter: none;
}

.quota-modal-actions {
  display: flex;
  justify-content: flex-end;
  flex-wrap: wrap;
  gap: 10px;
  align-items: center;
}

.quota-modal-actions button {
  min-height: 42px;
  padding: 0 18px;
  border-radius: var(--radius-ios);
  cursor: pointer;
  font-weight: 900;
  transition: transform 150ms ease, filter 150ms ease;
}

.quota-modal-actions button:hover {
  transform: translateY(-1px);
  filter: brightness(1.03);
}

.quota-primary {
  border: 0;
  color: #fff;
  background: linear-gradient(135deg, var(--green), var(--green-dark));
  box-shadow: 0 14px 34px rgba(4, 120, 87, 0.28);
}

.quota-secondary {
  min-width: 94px;
  border: 1px solid rgba(255, 255, 255, 0.18);
  color: #fff;
  background: rgba(255, 255, 255, 0.1);
}



.custom-model-card {
  position: relative;
  width: min(520px, 100%);
  padding: 24px;
  border: 1px solid rgba(255, 255, 255, 0.42);
  border-radius: var(--radius-ios);
  color: #fff;
  background: rgba(15, 23, 42, 0.72);
  backdrop-filter: blur(24px);
  box-shadow: var(--shadow);
  transform: translateY(18px) scale(0.97);
  transition: transform 260ms ease;
}

.custom-model-modal.show .custom-model-card {
  transform: translateY(0) scale(1);
}

.custom-model-close {
  position: absolute;
  top: 12px;
  right: 12px;
  display: grid;
  place-items: center;
  width: 34px;
  height: 34px;
  border: 0;
  border-radius: var(--radius-ios);
  color: #fff;
  background: rgba(255, 255, 255, 0.12);
  cursor: pointer;
  font-size: 22px;
  line-height: 1;
}

.custom-model-copy h2 {
  margin: 0 0 10px;
  font-size: 30px;
}

.custom-model-copy p:not(.eyebrow),
.custom-model-note {
  color: rgba(255, 255, 255, 0.72);
  line-height: 1.6;
}

.custom-model-form {
  display: grid;
  gap: 12px;
  margin-top: 18px;
}

.custom-model-form label {
  display: grid;
  gap: 6px;
  color: rgba(255, 255, 255, 0.82);
  font-size: 13px;
  font-weight: 900;
}

.custom-model-form input {
  min-height: 46px;
  padding: 0 13px;
  border: 1px solid rgba(255, 255, 255, 0.24);
  border-radius: var(--radius-ios);
  outline: 0;
  color: #fff;
  background: rgba(255, 255, 255, 0.1);
}

.custom-model-form input::placeholder {
  color: rgba(255, 255, 255, 0.48);
}

.custom-model-note {
  min-height: 22px;
  margin: 0;
  font-size: 13px;
  font-weight: 800;
}

.custom-model-note.error {
  color: #fecaca;
}

.custom-model-note.success {
  color: #bbf7d0;
}

.custom-model-save {
  display: grid;
  place-items: center;
  min-height: 48px;
  border: 0;
  border-radius: var(--radius-ios);
  color: #fff;
  background: linear-gradient(135deg, var(--green), var(--green-dark));
  cursor: pointer;
  font-weight: 900;
}

.auth-card {
  position: relative;
  width: min(460px, 100%);
  padding: 24px;
  border: 1px solid rgba(255, 255, 255, 0.42);
  border-radius: var(--radius-ios);
  color: #fff;
  background: rgba(15, 23, 42, 0.68);
  backdrop-filter: blur(24px);
  box-shadow: var(--shadow);
  transform: translateY(18px) scale(0.97);
  transition: transform 260ms ease;
}

.auth-modal.show .auth-card {
  transform: translateY(0) scale(1);
}

.auth-close {
  position: absolute;
  top: 12px;
  right: 12px;
  display: grid;
  place-items: center;
  width: 34px;
  height: 34px;
  border: 0;
  border-radius: var(--radius-ios);
  color: #fff;
  background: rgba(255, 255, 255, 0.12);
  cursor: pointer;
  font-size: 22px;
  line-height: 1;
}

.auth-copy h2 {
  margin: 0 0 10px;
  font-size: 30px;
}

.auth-copy p:not(.eyebrow),
.auth-note {
  margin: 0;
  color: rgba(255, 255, 255, 0.72);
  line-height: 1.6;
}

.auth-tabs {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
  margin: 18px 0;
  padding: 6px;
  border-radius: var(--radius-ios);
  background: rgba(255, 255, 255, 0.1);
}

.auth-tab {
  display: grid;
  place-items: center;
  min-height: 40px;
  border: 0;
  border-radius: var(--radius-ios);
  color: rgba(255, 255, 255, 0.72);
  background: transparent;
  cursor: pointer;
  font-weight: 900;
}

.auth-tab.active {
  color: #fff;
  background: linear-gradient(135deg, var(--green), var(--green-dark));
}

.auth-form {
  display: grid;
  gap: 12px;
}

.auth-form label {
  display: grid;
  gap: 6px;
  color: rgba(255, 255, 255, 0.82);
  font-size: 13px;
  font-weight: 900;
}

.auth-form input {
  min-height: 46px;
  padding: 0 13px;
  border: 1px solid rgba(255, 255, 255, 0.24);
  border-radius: var(--radius-ios);
  outline: 0;
  color: #fff;
  background: rgba(255, 255, 255, 0.1);
}

.auth-form input::placeholder {
  color: rgba(255, 255, 255, 0.48);
}

.auth-code-field[hidden] {
  display: none;
}

.auth-code-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 116px;
  gap: 8px;
}

.auth-code-btn {
  min-height: 46px;
  border: 0;
  border-radius: var(--radius-ios);
  background: rgba(16, 185, 129, 0.18);
  color: #fff;
  font-weight: 900;
  cursor: pointer;
}

.auth-code-btn:disabled {
  cursor: not-allowed;
  opacity: 0.56;
}

.auth-submit {
  display: grid;
  place-items: center;
  min-height: 48px;
  border: 0;
  border-radius: var(--radius-ios);
  color: #fff;
  background: linear-gradient(135deg, var(--green), var(--green-dark));
  cursor: pointer;
  font-weight: 900;
}

.auth-oauth {
  display: grid;
  gap: 10px;
  margin-top: 0;
}

.auth-oauth p {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
  gap: 10px;
  margin: 0;
  color: rgba(255, 255, 255, 0.62);
  font-size: 12px;
  font-weight: 900;
}

.auth-oauth p::before,
.auth-oauth p::after {
  content: "";
  height: 1px;
  background: rgba(255, 255, 255, 0.16);
}

.oauth-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: 10px;
}

.oauth-btn {
  display: inline-flex;
  width: 100%;
  min-width: 0;
  min-height: 48px;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 0 10px;
  border: 1px solid rgba(255, 255, 255, 0.18);
  border-radius: var(--radius-ios);
  color: #fff;
  background: rgba(255, 255, 255, 0.1);
  cursor: pointer;
  font-size: 13px;
  font-weight: 900;
  transition: transform 160ms ease, border-color 160ms ease, background 160ms ease;
}

.oauth-btn:hover {
  transform: translateY(-1px);
  border-color: rgba(255, 255, 255, 0.38);
  background: rgba(255, 255, 255, 0.16);
}

.oauth-btn span {
  display: inline-grid;
  flex: 0 0 auto;
  width: 24px;
  height: 24px;
  place-items: center;
  border-radius: var(--radius-ios);
  color: #111827;
  background: #fff;
  font-size: 11px;
  font-weight: 1000;
  padding: 4px;
}

.oauth-btn svg {
  display: block;
  width: 100%;
  height: 100%;
}

.oauth-btn.google span {
  background: #fff;
}

.oauth-btn.github span {
  background: #fff;
}

.oauth-btn.microsoft span {
  background: #fff;
}

.oauth-btn.apple span {
  background: #fff;
}

.account-preview {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 8px;
  margin-top: 16px;
}

.account-preview[hidden] {
  display: none;
}

.account-preview div {
  padding: 12px;
  border-radius: var(--radius-ios);
  background: rgba(255, 255, 255, 0.1);
}

.account-preview span,
.account-preview strong {
  display: block;
}

.account-preview span {
  color: rgba(255, 255, 255, 0.62);
  font-size: 12px;
}

.account-preview strong {
  margin-top: 6px;
  font-size: 15px;
}

.mini-chat {
  --mini-compact-height: 78px;
  --mini-bottom: 12px;
  --mini-expanded-height: clamp(220px, 34vh, 340px);
  position: fixed;
  left: 50%;
  top: auto;
  bottom: var(--mini-bottom);
  z-index: 70;
  display: grid;
  align-items: center;
  grid-template-columns: 54px 1fr;
  gap: 10px;
  width: min(760px, calc(100% - 92px));
  height: var(--mini-compact-height);
  overflow: visible;
  padding: 10px;
  border: 1px solid rgba(255, 255, 255, 0.22);
  border-radius: var(--radius-ios);
  background: rgba(15, 23, 42, 0.66);
  backdrop-filter: blur(24px);
  box-shadow: var(--shadow);
  opacity: 0;
  transform: translate(-50%, 34px) scale(0.86);
  transform-origin: center bottom;
  pointer-events: none;
  transition: opacity 260ms ease, transform 260ms ease, height 220ms ease;
  will-change: height, transform, opacity;
}

.mini-chat.model-open {
  z-index: 2147483640;
}

body.mini-mode .mini-chat {
  opacity: 1;
  transform: translate(-50%, 0) scale(1);
  pointer-events: auto;
  animation: none;
}

body.mini-mode .mini-chat:not(.compact) {
  top: auto;
  bottom: var(--mini-bottom);
  height: var(--mini-expanded-height);
  transform: translate(-50%, 0) scale(1);
  animation: none;
}

body.launcher-mode .mini-chat {
  opacity: 0;
  transform: translate(calc(50vw - 94px), 24px) scale(0.18);
  pointer-events: none;
}

.mini-controls {
  --mini-control-stack-height: 72px;
  position: absolute;
  right: -46px;
  bottom: calc((var(--mini-compact-height) - var(--mini-control-stack-height)) / 2);
  z-index: 2;
  display: grid;
  align-content: center;
  gap: 8px;
  height: var(--mini-control-stack-height);
}

.mini-close,
.mini-expand {
  --mini-control-icon-size: 12px;
  --mini-control-icon-stroke: 2px;
  position: relative;
  display: grid;
  width: 32px;
  height: 32px;
  place-items: center;
  border: 1px solid rgba(255, 255, 255, 0.28);
  border-radius: var(--radius-ios);
  color: #fff;
  background: rgba(15, 23, 42, 0.78);
  backdrop-filter: blur(14px);
  cursor: pointer;
  font-size: 0;
  line-height: 1;
  transition: transform 160ms ease, background 160ms ease, border-color 160ms ease;
}

.mini-close::before,
.mini-close::after,
.mini-expand::before,
.mini-expand::after {
  content: "";
  position: absolute;
  left: 50%;
  top: 50%;
  width: var(--mini-control-icon-size);
  height: var(--mini-control-icon-stroke);
  border-radius: 999px;
  background: #fff;
  transform-origin: center;
}

.mini-close::before {
  transform: translate(-50%, -50%) rotate(45deg);
}

.mini-close::after {
  transform: translate(-50%, -50%) rotate(-45deg);
}

.mini-expand::before {
  box-sizing: border-box;
  width: 11px;
  height: 11px;
  border-top: var(--mini-control-icon-stroke) solid #fff;
  border-left: var(--mini-control-icon-stroke) solid #fff;
  border-radius: 2px 0 0 0;
  background: transparent;
  transform: translate(-50%, -38%) rotate(45deg);
}

.mini-expand::after {
  display: none;
}

.mini-chat:not(.compact) .mini-expand::before {
  transform: translate(-50%, -62%) rotate(225deg);
}

.mini-close:hover,
.mini-expand:hover {
  transform: scale(1.06);
  border-color: rgba(16, 185, 129, 0.62);
  background: rgba(16, 185, 129, 0.28);
}

.mini-expand:disabled {
  opacity: 0.46;
  cursor: default;
}

.mini-expand:disabled:hover {
  transform: none;
  border-color: rgba(255, 255, 255, 0.28);
  background: rgba(15, 23, 42, 0.78);
}

.mini-model-menu {
  position: absolute;
  left: 0;
  bottom: calc(100% + 10px);
  z-index: 2147483644;
  display: grid;
  grid-template-columns: repeat(2, minmax(128px, 1fr));
  gap: 8px;
  width: min(420px, calc(100vw - 36px));
  max-height: min(320px, 42vh);
  overflow: auto;
  padding: 10px;
  border: 1px solid rgba(255, 255, 255, 0.24);
  border-radius: var(--radius-ios);
  background: rgba(15, 23, 42, 0.86);
  backdrop-filter: blur(22px);
  box-shadow: var(--shadow);
  opacity: 0;
  transform: translateY(10px) scale(0.98);
  pointer-events: none;
  transition: opacity 180ms ease, transform 180ms ease;
}

.mini-chat.model-open .mini-model-menu,
.mini-model-menu.open {
  opacity: 1;
  transform: translateY(0) scale(1);
  pointer-events: auto;
}

.mini-model-option {
  display: flex;
  align-items: center;
  gap: 8px;
  min-height: 42px;
  padding: 0 8px;
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: var(--radius-control);
  color: #fff;
  background: rgba(255, 255, 255, 0.08);
  cursor: pointer;
  font-size: 12px;
  font-weight: 900;
}

.mini-model-option.active {
  border-color: rgba(16, 185, 129, 0.7);
  background: linear-gradient(135deg, rgba(16, 185, 129, 0.48), rgba(4, 120, 87, 0.48));
}

.mini-model-version-option.unavailable,
.mini-model-version-option:disabled {
  cursor: not-allowed;
  opacity: 0.55;
}

.mini-model-version-option small {
  display: block;
  margin-top: 2px;
  font-size: 10px;
  font-weight: 800;
}

.mini-model-option > .app-icon {
  width: 26px;
  height: 26px;
  border-radius: var(--radius-icon);
  background: rgba(255, 255, 255, 0.92);
}

.more-model-menu,
.chat-model-menu,
.mini-model-menu {
  z-index: 2147483644;
  display: grid;
  grid-template-columns: 1fr;
  grid-template-rows: minmax(0, 1fr) auto;
  align-content: start;
  gap: 10px;
  width: min(430px, calc(100vw - 36px));
  height: auto;
  max-height: min(430px, 72vh);
  overflow: hidden;
  padding: 10px;
  border: 1px solid rgba(255, 255, 255, 0.36);
  border-radius: var(--radius-ios);
  background: rgba(15, 23, 42, 0.86);
  backdrop-filter: blur(20px);
  box-shadow: var(--shadow);
  scrollbar-width: thin;
  scrollbar-color: rgba(16, 185, 129, 0.86) rgba(255, 255, 255, 0.08);
}

.mini-model-menu {
  border-radius: var(--radius-icon);
}

.model-menu-list {
  display: grid;
  grid-template-columns: repeat(2, minmax(132px, 1fr));
  gap: 8px;
  min-height: 0;
  max-height: min(280px, 44vh);
  overflow: auto;
  padding-right: 1px;
  scrollbar-width: thin;
  scrollbar-color: rgba(16, 185, 129, 0.86) rgba(255, 255, 255, 0.08);
}

.model-version-menu-list {
  display: flex;
  flex-direction: column;
  gap: 12px;
  min-height: 0;
  max-height: calc(var(--model-version-menu-max-height, min(360px, calc(100vh - 24px))) - 56px);
  overflow-x: hidden;
  overflow-y: auto;
  overscroll-behavior: contain;
  padding-right: 4px;
  scrollbar-gutter: stable;
  scrollbar-width: thin;
  scrollbar-color: rgba(16, 185, 129, 0.86) rgba(255, 255, 255, 0.08);
}

@media (min-width: 769px) {
  .more-model-menu,
  .chat-model-menu,
  .mini-model-menu {
    width: min(660px, calc(100vw - 48px));
    max-height: min(620px, 78vh);
    padding: 14px;
  }

  .more-model-menu .model-menu-list,
  .chat-model-menu .model-menu-list,
  .mini-model-menu .model-menu-list {
    grid-template-columns: repeat(2, minmax(150px, 1fr));
    max-height: min(470px, 62vh);
    gap: 10px;
  }
}

.more-model-menu,
.chat-model-menu,
.mini-model-menu {
  overflow-x: hidden;
  overflow-y: hidden;
  scrollbar-gutter: stable both-edges;
}

.more-model-menu .model-menu-list,
.chat-model-menu .model-menu-list,
.mini-model-menu .model-menu-list {
  overflow-y: auto;
  padding-right: 6px;
}

.more-model-option,
.chat-model-option,
.mini-model-option {
  display: flex;
  align-items: center;
  gap: 10px;
  min-height: 48px;
  padding: 8px 10px;
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: var(--radius-control);
  color: #fff;
  background: rgba(255, 255, 255, 0.08);
  cursor: pointer;
  font-size: 14px;
  font-weight: 900;
}

.more-model-option.active,
.chat-model-option.active,
.mini-model-option.active {
  border-color: rgba(16, 185, 129, 0.7);
  background: linear-gradient(135deg, rgba(16, 185, 129, 0.48), rgba(4, 120, 87, 0.48));
}

.more-model-option > .app-icon,
.chat-model-option > .app-icon,
.mini-model-option > .app-icon {
  width: 26px;
  height: 26px;
  border-radius: var(--radius-icon);
  background: rgba(255, 255, 255, 0.92);
}

.chat-model-option > .app-icon {
  width: 34px;
  height: 34px;
}

.more-model-option > .app-icon.original-brand-icon,
.chat-model-option > .app-icon.original-brand-icon,
.mini-model-option > .app-icon.original-brand-icon {
  border: 0;
  background: transparent;
  box-shadow: none;
}

.model-pill > .app-icon.original-brand-icon,
.chat-model-btn > .app-icon.original-brand-icon,
.more-model-option > .app-icon.original-brand-icon,
.chat-model-option > .app-icon.original-brand-icon,
.mini-model-option > .app-icon.original-brand-icon,
.mini-avatar .app-icon.original-brand-icon,
.logo.app-icon.original-brand-icon {
  border: 0;
  background: transparent;
  box-shadow: none;
}

.app-icon.grok-brand-icon,
.model-pill > .app-icon.grok-brand-icon,
.chat-model-btn > .app-icon.grok-brand-icon,
.more-model-option > .app-icon.grok-brand-icon,
.chat-model-option > .app-icon.grok-brand-icon,
.mini-model-option > .app-icon.grok-brand-icon,
.mini-avatar .app-icon.grok-brand-icon,
.ai-avatar > .app-icon.grok-brand-icon,
.logo.app-icon.grok-brand-icon {
  border: 0;
  background: #050505;
  box-shadow: none;
}

.app-icon.grok-brand-icon img,
.model-pill .app-icon.grok-brand-icon img,
.chat-model-btn .app-icon.grok-brand-icon img,
.more-model-option .app-icon.grok-brand-icon img,
.chat-model-option .app-icon.grok-brand-icon img,
.mini-model-option .app-icon.grok-brand-icon img,
.mini-avatar .app-icon.grok-brand-icon img,
.ai-avatar .app-icon.grok-brand-icon img,
.logo.app-icon.grok-brand-icon img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: inherit;
}

.app-icon.white-backed-brand-icon,
.model-pill > .app-icon.white-backed-brand-icon,
.chat-model-btn > .app-icon.white-backed-brand-icon,
.more-model-option > .app-icon.white-backed-brand-icon,
.chat-model-option > .app-icon.white-backed-brand-icon,
.mini-model-option > .app-icon.white-backed-brand-icon,
.mini-avatar .app-icon.white-backed-brand-icon,
.ai-avatar > .app-icon.white-backed-brand-icon,
.logo.app-icon.white-backed-brand-icon {
  border: 0;
  background: rgba(255, 255, 255, 0.98);
  box-shadow: 0 6px 18px rgba(15, 23, 42, 0.1);
}

.app-icon.white-backed-brand-icon img,
.model-pill .app-icon.white-backed-brand-icon img,
.chat-model-btn .app-icon.white-backed-brand-icon img,
.more-model-option .app-icon.white-backed-brand-icon img,
.chat-model-option .app-icon.white-backed-brand-icon img,
.mini-model-option .app-icon.white-backed-brand-icon img,
.mini-avatar .app-icon.white-backed-brand-icon img,
.ai-avatar .app-icon.white-backed-brand-icon img,
.logo.app-icon.white-backed-brand-icon img {
  display: block;
  width: 76%;
  height: 76%;
  object-fit: contain;
  border-radius: 0;
}

.more-model-option .model-country,
.chat-model-option .model-country,
.mini-model-option .model-country {
  margin-left: auto;
  min-width: var(--flag-width);
  min-height: var(--flag-height);
}

.more-model-option .country-flag,
.chat-model-option .country-flag,
.mini-model-option .country-flag {
  width: var(--flag-width);
  height: var(--flag-height);
}

.country-badge .country-flag > img,
.model-pill .country-flag > img,
.more-model-option .country-flag > img,
.chat-model-btn .country-flag > img,
.chat-model-option .country-flag > img,
.mini-model-option .country-flag > img,
.tool-card .country-flag > img {
  display: block;
  width: 100%;
  height: 100%;
  border-radius: inherit;
  background: transparent;
  object-fit: cover;
}

.model-menu-categories {
  position: relative;
  z-index: 3;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: flex-start;
  gap: 6px;
  margin: 0 -2px -2px;
  padding: 10px 0 0;
  border-top: 1px solid rgba(255, 255, 255, 0.16);
  background: linear-gradient(180deg, rgba(15, 23, 42, 0), rgba(15, 23, 42, 0.9) 26%, rgba(15, 23, 42, 0.96));
  backdrop-filter: blur(14px);
}

.model-menu-category {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex: 0 0 auto;
  gap: 5px;
  min-height: 28px;
  padding: 0 9px;
  border: 1px solid rgba(255, 255, 255, 0.14);
  border-radius: var(--radius-control);
  color: rgba(255, 255, 255, 0.82);
  background: rgba(255, 255, 255, 0.08);
  cursor: pointer;
  font-size: 11px;
  font-weight: 900;
  line-height: 1;
  transition: border-color 0.16s ease, background 0.16s ease, color 0.16s ease;
}

.model-menu-category:hover,
.model-menu-category.active {
  border-color: rgba(16, 185, 129, 0.72);
  color: #fff;
  background: linear-gradient(135deg, rgba(16, 185, 129, 0.5), rgba(4, 120, 87, 0.42));
}

.model-menu-category.favorite-category {
  position: relative;
  isolation: isolate;
  overflow: hidden;
  gap: 6px;
  border-color: rgba(245, 158, 11, 0.36);
  color: #ffedd5;
  background:
    radial-gradient(circle at 20% 0%, rgba(255, 255, 255, 0.18), transparent 36%),
    linear-gradient(135deg, rgba(146, 64, 14, 0.58), rgba(245, 158, 11, 0.2));
}

.model-menu-category.favorite-category::before {
  display: none;
}

.model-favorite-star {
  position: relative;
  display: inline;
  width: auto;
  height: auto;
  flex: 0 0 auto;
  border-radius: 0;
  color: #fde68a;
  background: transparent;
  box-shadow: none;
  font-size: 12px;
  line-height: 1;
  transform: none;
}

.model-favorite-star::after {
  display: none;
}

.model-menu-category.favorite-category:hover,
.model-menu-category.favorite-category.active {
  border-color: rgba(251, 191, 36, 0.72);
  color: #fff;
  background:
    radial-gradient(circle at 20% 0%, rgba(255, 255, 255, 0.26), transparent 36%),
    linear-gradient(135deg, rgba(245, 158, 11, 0.72), rgba(180, 83, 9, 0.58));
}

.model-menu-category.favorite-category:hover .model-favorite-star,
.model-menu-category.favorite-category.active .model-favorite-star {
  transform: none;
}

.model-menu-category.custom-model-category {
  gap: 6px;
  border-color: rgba(56, 189, 248, 0.34);
  color: #dbeafe;
  background:
    radial-gradient(circle at 20% 0%, rgba(255, 255, 255, 0.16), transparent 36%),
    linear-gradient(135deg, rgba(14, 116, 144, 0.5), rgba(37, 99, 235, 0.24));
}

.model-menu-category.custom-model-category:hover {
  border-color: rgba(125, 211, 252, 0.78);
  color: #fff;
  background:
    radial-gradient(circle at 20% 0%, rgba(255, 255, 255, 0.24), transparent 36%),
    linear-gradient(135deg, rgba(14, 165, 233, 0.68), rgba(37, 99, 235, 0.5));
}

.custom-model-plus {
  display: inline-grid;
  place-items: center;
  width: 15px;
  height: 15px;
  border-radius: 50%;
  color: #0f172a;
  background: #bae6fd;
  font-size: 12px;
  line-height: 1;
}

.model-menu-category-count {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 17px;
  height: 17px;
  padding: 0 5px;
  border-radius: var(--radius-label);
  background: rgba(255, 255, 255, 0.14);
  font-size: 10px;
  line-height: 1;
}

.model-menu-category.active .model-menu-category-count {
  background: rgba(255, 255, 255, 0.24);
}

.model-menu-category.favorite-category .model-menu-category-count,
.model-menu-category.favorite-category.active .model-menu-category-count {
  min-width: auto;
  height: auto;
  padding: 0;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
}

.model-menu-empty {
  grid-column: 1 / -1;
  padding: 18px 10px;
  border: 1px dashed rgba(255, 255, 255, 0.2);
  border-radius: var(--radius-ios);
  color: rgba(255, 255, 255, 0.72);
  text-align: center;
  font-size: 12px;
  font-weight: 800;
}

.mini-chat:not(.compact) .mini-model-menu {
  left: 10px;
  bottom: 72px;
  transform-origin: left bottom;
}

.ai-launcher {
  position: fixed;
  right: calc(clamp(10px, 1.35vw, 20px) + clamp(5px, 0.7vw, 8px));
  bottom: 142px;
  z-index: 73;
  display: grid;
  width: clamp(34px, 3.2vw, 42px);
  height: clamp(34px, 3.2vw, 42px);
  place-items: center;
  border: 1px solid rgba(255, 255, 255, 0.34);
  border-radius: var(--radius-control);
  color: #fff;
  background:
    radial-gradient(circle at 32% 24%, rgba(255, 255, 255, 0.72), transparent 18%),
    linear-gradient(145deg, var(--green), var(--green-dark));
  box-shadow: 0 18px 42px rgba(16, 185, 129, 0.28);
  cursor: pointer;
  font-weight: 1000;
  opacity: 0;
  transform: translateY(16px) scale(0.82);
  pointer-events: none;
  transition: opacity 220ms ease, transform 220ms ease;
}

.ai-launcher::before,
.ai-launcher::after {
  content: "";
  position: absolute;
  top: 13px;
  width: 5px;
  height: 5px;
  border-radius: 50%;
  background: #fff;
}

.ai-launcher::before {
  left: 13px;
}

.ai-launcher::after {
  right: 13px;
}

.ai-launcher span {
  transform: translateY(6px);
  font-size: 11px;
  letter-spacing: 0;
}

body.launcher-mode .ai-launcher {
  opacity: 1;
  transform: translateY(0) scale(1);
  pointer-events: auto;
}

body.mini-mode .hero-console {
  opacity: 1;
  transform: translate(-50%, 0) scale(1);
  pointer-events: none;
  transition: none;
}

.mini-head {
  align-self: center;
  display: grid;
  align-items: center;
  justify-items: center;
  width: 54px;
  height: 54px;
  min-height: 54px;
  padding: 6px;
  border: 0;
  border-radius: var(--radius-ios);
  color: #fff;
  background: transparent;
  cursor: pointer;
  text-align: left;
}

.mini-avatar {
  display: grid;
  width: 38px;
  height: 38px;
  place-items: center;
  border-radius: var(--radius-ios);
  color: #fff;
  background: transparent;
  font-size: 12px;
  font-weight: 900;
}

.mini-avatar img {
  width: 34px;
  height: 34px;
  border-radius: var(--radius-ios);
  object-fit: cover;
}

.mini-body {
  align-self: center;
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  grid-template-rows: minmax(0, 1fr) auto;
  gap: 0;
  width: 100%;
  max-width: 100%;
  min-height: 0;
  min-width: 0;
  padding: 0;
  overflow: hidden;
}

.mini-chat.compact {
  grid-template-columns: 54px 1fr;
}

.mini-chat.compact .mini-head,
.mini-chat.compact .mini-body {
  align-self: center;
}

.mini-chat.compact .mini-body {
  height: 54px;
  align-content: center;
}

.mini-chat.compact .mini-stream {
  display: none;
}

.mini-chat:not(.compact) .mini-head {
  align-self: end;
}

.mini-chat:not(.compact) .mini-body {
  align-self: stretch;
  gap: 12px;
}

.mini-stream {
  display: none;
  gap: 10px;
  min-height: 0;
  min-width: 0;
  width: 100%;
  max-width: 100%;
  max-height: none;
  overflow-x: hidden;
  overflow-y: auto;
  overscroll-behavior: contain;
  margin-bottom: 0;
  padding: 0 4px 34px 0;
  scrollbar-width: auto;
  scrollbar-color: rgba(16, 185, 129, 0.86) rgba(255, 255, 255, 0.08);
}

.mini-chat:not(.compact) .mini-stream {
  display: grid;
}

.mini-stream .bubble {
  align-items: flex-start;
  gap: 8px;
  max-width: 100%;
}

.oauth-btn .oauth-icon {
  border-radius: var(--radius-icon);
}

.mini-stream .bubble p {
  max-width: min(100%, calc(100% - 56px));
  min-width: 0;
  padding: 10px 12px;
  font-size: 14px;
  line-height: 1.55;
  overflow-wrap: break-word;
  word-break: normal;
}

.mini-stream .bubble.user .user-bubble-body {
  max-width: min(100%, calc(100% - 56px));
  min-width: 0;
}

.mini-stream .bubble.user .user-bubble-body > .bubble-text {
  max-width: 100%;
}

.mini-stream .bubble-actions {
  right: 2px;
  top: 100%;
  bottom: auto;
  gap: 1px;
  padding: 3px 0 0;
}

.mini-stream .bubble.ai.has-actions {
  margin-bottom: 36px;
}

.mini-stream .bubble.ai .bubble-actions {
  left: 42px;
  right: auto;
}

.mini-stream .bubble-action-btn {
  width: 32px;
  height: 32px;
}

.mini-stream .bubble-edit-input {
  width: min(220px, 60vw);
  min-height: 66px;
  padding: 9px 10px;
  font-size: 12px;
}

.mini-stream .bubble-edit-actions button {
  min-width: 48px;
  height: 27px;
  font-size: 12px;
}

.mini-stream .avatar,
.mini-stream .user-avatar {
  width: 38px;
  height: 38px;
  flex: 0 0 38px;
}

.mini-stream .user-avatar::before,
.mini-stream .user-avatar::after {
  top: 13px;
}

.mini-stream .user-avatar::before {
  left: 11px;
}

.mini-stream .user-avatar::after {
  right: 11px;
}

.mini-input-row {
  align-self: end;
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 8px;
  width: 100%;
  min-width: 0;
  padding: 6px;
  border: 1px solid rgba(255, 255, 255, 0.42);
  border-radius: var(--radius-ios);
  background: rgba(255, 255, 255, 0.22);
  backdrop-filter: blur(18px);
}

.scroll-dock {
  position: fixed;
  right: clamp(10px, 1.35vw, 20px);
  bottom: clamp(12px, 1.5vw, 22px);
  z-index: 72;
  display: grid;
  gap: clamp(6px, 0.7vw, 10px);
  padding: clamp(5px, 0.7vw, 8px);
  border: 1px solid rgba(255, 255, 255, 0.24);
  border-radius: var(--radius-ios);
  background: rgba(15, 23, 42, 0.3);
  backdrop-filter: blur(20px);
  box-shadow: 0 18px 50px rgba(15, 23, 42, 0.16);
  opacity: 0;
  transform: translateY(12px) scale(0.92);
  pointer-events: none;
  transition: opacity 180ms ease, transform 180ms ease;
}

body.scroll-dock-visible .scroll-dock {
  opacity: 1;
  transform: translateY(0) scale(1);
  pointer-events: auto;
}

body.support-fullscreen-active {
  overflow: hidden;
}

body.support-fullscreen-active .mini-chat,
body.support-fullscreen-active .ai-launcher,
body.support-fullscreen-active .scroll-dock {
  display: none !important;
}

.support-widget {
  position: fixed;
  right: 20px;
  bottom: calc(214px + env(safe-area-inset-bottom, 0px));
  z-index: 2147483645;
  display: grid;
  justify-items: end;
  gap: 12px;
  font-family: inherit;
}

.support-widget-positioned {
  right: auto;
  bottom: auto;
}

.support-widget-dragging {
  touch-action: none;
  user-select: none;
}

.support-launcher {
  position: relative;
  display: grid;
  width: 50px;
  height: 50px;
  min-width: 50px;
  min-height: 50px;
  place-items: center;
  border: 1px solid rgba(14, 165, 233, 0.3);
  border-radius: var(--radius-ios);
  padding: 0;
  color: #fff;
  background: linear-gradient(145deg, #0ea5e9, #0284c7);
  box-shadow: 0 18px 42px rgba(14, 165, 233, 0.28);
  cursor: pointer;
  font-size: 0;
  font-weight: 900;
  line-height: 0;
  touch-action: manipulation;
}

.support-launcher::before,
.support-launcher::after {
  display: none;
}

.support-launcher-icon {
  display: grid;
  width: 32px;
  height: 32px;
  place-items: center;
  line-height: 1;
}

.support-launcher-icon svg {
  width: 32px;
  height: 32px;
  fill: none;
  stroke: currentColor;
  stroke-width: 2.35;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.support-launcher-icon img {
  width: 28px;
  height: 28px;
  object-fit: contain;
  border-radius: var(--radius-ios);
}

.support-launcher-custom {
  font-size: 20px;
  line-height: 1;
}

.support-launcher .support-launcher-text {
  position: absolute;
  width: 1px;
  height: 1px;
  margin: -1px;
  overflow: hidden;
  clip: rect(0 0 0 0);
  clip-path: inset(50%);
  white-space: nowrap;
  border: 0;
}

.support-panel {
  position: relative;
  display: none;
  width: min(360px, calc(100vw - 28px));
  overflow: hidden;
  border: 1px solid rgba(255, 255, 255, 0.22);
  border-radius: var(--radius-ios);
  background: rgba(15, 23, 42, 0.66);
  box-shadow: var(--shadow);
  backdrop-filter: blur(24px);
}

.support-widget.open .support-panel {
  display: grid;
}

.support-panel-head,
.support-form {
  display: flex;
  align-items: center;
}

.support-panel-head {
  justify-content: space-between;
  gap: 12px;
  padding: 14px 16px;
  color: #fff;
  border-bottom: 1px solid rgba(255, 255, 255, 0.14);
  background: rgba(255, 255, 255, 0.08);
}

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

.support-panel-head button {
  width: 32px;
  height: 32px;
  border: 1px solid rgba(255, 255, 255, 0.28);
  border-radius: var(--radius-ios);
  color: #fff;
  background: rgba(15, 23, 42, 0.78);
  backdrop-filter: blur(14px);
  cursor: pointer;
  font-size: 20px;
  font-weight: 900;
}

.support-messages {
  display: grid;
  align-content: start;
  gap: 9px;
  height: 310px;
  overflow: auto;
  overscroll-behavior: contain;
  padding: 14px;
  background: transparent;
}

.support-widget.fullscreen {
  inset: 0 !important;
  width: 100vw;
  height: 100svh;
  display: grid;
  place-items: center;
  padding: 32px;
  background: rgba(2, 6, 23, 0.72);
  backdrop-filter: blur(10px);
}

.support-widget.fullscreen .support-panel {
  width: min(760px, calc(100vw - 64px));
  height: min(720px, calc(100svh - 64px));
  max-height: none;
  border-radius: var(--radius-ios);
  display: grid;
  grid-template-rows: auto minmax(0, 1fr) auto;
}

.support-widget.fullscreen .support-messages {
  height: auto;
  min-height: 0;
  max-height: none;
}

.support-widget.fullscreen .support-launcher {
  display: none;
}

.support-widget.open.fullscreen {
  padding: 32px;
  place-items: center;
}

.support-widget.open.fullscreen .support-panel {
  width: min(760px, calc(100vw - 64px));
  height: min(720px, calc(100svh - 64px));
  max-height: none;
}

.support-bubble {
  display: grid;
  gap: 4px;
  max-width: 86%;
  padding: 10px 12px;
  border-radius: var(--radius-ios);
  border: 1px solid rgba(255, 255, 255, 0.22);
  color: #e2e8f0;
  background: rgba(255, 255, 255, 0.08);
  backdrop-filter: blur(10px);
  white-space: pre-wrap;
}

.support-bilingual,
.support-original,
.support-translated {
  display: grid;
  gap: 4px;
}

.support-original,
.support-translated {
  padding: 8px 9px;
  border-radius: var(--radius-ios);
  background: rgba(15, 23, 42, 0.18);
}

.support-translated {
  background: rgba(20, 184, 166, 0.16);
}

.support-original em,
.support-translated em {
  color: rgba(226, 232, 240, 0.72);
  font-size: 11px;
  font-style: normal;
  font-weight: 900;
}

.support-bubble.user {
  justify-self: end;
  color: #fff;
  border-color: rgba(16, 185, 129, 0.48);
  background: linear-gradient(135deg, rgba(16, 185, 129, 0.85), rgba(5, 150, 105, 0.82));
}

.support-bubble.admin,
.support-bubble.ai,
.support-bubble.system {
  justify-self: start;
}

.support-bubble.support-waiting {
  max-width: 92%;
  border-color: rgba(34, 211, 238, 0.34);
  background: rgba(14, 165, 233, 0.14);
}

.support-waiting-row {
  display: inline-flex;
  align-items: center;
  gap: 8px;
}

.support-waiting-dots {
  display: inline-flex;
  align-items: center;
  gap: 3px;
}

.support-waiting-dots i {
  width: 5px;
  height: 5px;
  border-radius: 999px;
  background: currentColor;
  opacity: 0.45;
  animation: support-waiting-pulse 1.1s ease-in-out infinite;
}

.support-waiting-dots i:nth-child(2) {
  animation-delay: 0.16s;
}

.support-waiting-dots i:nth-child(3) {
  animation-delay: 0.32s;
}

@keyframes support-waiting-pulse {
  0%,
  80%,
  100% {
    transform: translateY(0);
    opacity: 0.45;
  }

  40% {
    transform: translateY(-3px);
    opacity: 1;
  }
}

.support-bubble small {
  font-size: 11px;
  opacity: 0.72;
}

.support-bubble-attachments {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.support-bubble-attachments .support-attachment-chip {
  display: inline-grid;
  min-height: 22px;
  place-items: center;
  padding: 0 8px;
  border: 0;
  border-radius: 999px;
  color: #0f172a;
  background: rgba(226, 232, 240, 0.85);
  font-size: 11px;
  font-weight: 800;
  text-decoration: none;
}

.support-bubble-attachments .support-attachment-chip.button {
  width: max-content;
  max-width: 100%;
  color: #052e2b;
  background: linear-gradient(135deg, #34d399, #22d3ee);
  white-space: normal;
  overflow-wrap: anywhere;
}

.support-quick-replies {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  justify-self: start;
}

.support-quick-replies-title {
  width: 100%;
  color: rgba(226, 232, 240, 0.72);
  font-size: 12px;
  font-weight: 900;
}

.support-quick-replies button {
  width: max-content;
  max-width: 100%;
  min-height: 34px;
  padding: 7px 12px;
  border: 1px solid rgba(34, 211, 238, 0.32);
  border-radius: var(--radius-ios);
  color: #dffbff;
  background: rgba(14, 165, 233, 0.16);
  cursor: pointer;
  font-weight: 900;
  white-space: normal;
  overflow-wrap: anywhere;
  transition: transform 160ms ease, border-color 160ms ease, background 160ms ease;
}

.support-quick-replies button:hover,
.support-quick-replies button:focus-visible {
  border-color: rgba(34, 211, 238, 0.72);
  background: rgba(14, 165, 233, 0.28);
  transform: translateY(-1px);
}

.support-image-thumb {
  display: inline-grid;
  width: 92px;
  height: 68px;
  padding: 0;
  overflow: hidden;
  border: 1px solid rgba(226, 232, 240, 0.6);
  border-radius: var(--radius-ios);
  background: rgba(15, 23, 42, 0.32);
  cursor: zoom-in;
}

.support-video-thumb {
  width: 160px;
  max-width: 100%;
  height: 90px;
  border: 1px solid rgba(226, 232, 240, 0.6);
  border-radius: var(--radius-ios);
  background: rgba(15, 23, 42, 0.32);
}

.support-image-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.support-image-thumb.is-original {
  width: min(100%, var(--chat-original-max-width, 1024px));
  max-width: 100%;
  height: auto;
  cursor: default;
}

.support-image-thumb.is-original img {
  width: auto;
  max-width: 100%;
  height: auto;
  max-height: min(72vh, var(--chat-original-max-height, 1024px));
  object-fit: contain;
}

.support-form {
  display: block;
  padding: 10px;
  border-top: 1px solid rgba(255, 255, 255, 0.16);
  background: rgba(255, 255, 255, 0.06);
}

.support-input-shell {
  display: grid;
  gap: 6px;
  min-width: 0;
  min-height: 46px;
  padding: 6px;
  border: 1px solid rgba(255, 255, 255, 0.32);
  border-radius: var(--radius-ios);
  background: rgba(255, 255, 255, 0.12);
}

.support-input-row {
  display: grid;
  grid-template-columns: 36px minmax(0, 1fr) auto;
  align-items: center;
  gap: 5px;
  min-width: 0;
}

.support-attachment-list {
  display: flex;
  flex-wrap: wrap;
  gap: 7px;
  padding: 0;
}

.support-attachment-list[hidden] {
  display: none;
}

.support-selected-attachment {
  display: inline-grid;
  width: 54px;
  height: 44px;
  place-items: center;
  overflow: hidden;
  border: 1px solid rgba(34, 211, 238, 0.42);
  border-radius: var(--radius-ios);
  color: #fff;
  background: rgba(14, 165, 233, 0.16);
  cursor: zoom-in;
}

.support-selected-attachment img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.support-widget-attach {
  display: inline-grid;
  place-items: center;
  width: 36px;
  min-width: 36px;
  min-height: 38px;
  height: 38px;
  padding: 0;
  background: transparent;
}

.support-widget-attach span {
  position: relative;
  display: block;
  width: 18px;
  height: 18px;
}

.support-widget-attach span::before,
.support-widget-attach span::after {
  content: "";
  position: absolute;
  left: 50%;
  top: 50%;
  width: 18px;
  height: 2px;
  border-radius: 999px;
  background: currentColor;
  transform: translate(-50%, -50%);
}

.support-widget-attach span::after {
  transform: translate(-50%, -50%) rotate(90deg);
}

.support-form textarea {
  box-sizing: border-box;
  height: 38px;
  min-height: 38px;
  max-height: 110px;
  border: 0;
  border-radius: var(--radius-ios);
  padding: 9px 6px;
  resize: none;
  outline: none;
  color: #fff;
  background: transparent;
  font: inherit;
  line-height: 20px;
}

.support-form textarea::placeholder {
  color: rgba(226, 232, 240, 0.72);
}

.support-form button {
  width: auto;
  min-width: max-content;
  min-height: 38px;
  padding: 0 14px;
  border: 0;
  border-radius: var(--radius-ios);
  color: #fff;
  background: linear-gradient(135deg, var(--green), var(--green-dark));
  cursor: pointer;
  font-size: 14px;
  font-weight: 950;
}

.support-form .support-selected-attachment {
  width: 54px;
  min-width: 54px;
  min-height: 44px;
  padding: 0;
  border: 1px solid rgba(34, 211, 238, 0.42);
  background: rgba(14, 165, 233, 0.16);
}

.support-form .support-widget-attach {
  width: 42px;
  min-width: 42px;
  min-height: 42px;
  padding: 0;
  background: transparent;
}

.support-image-preview[hidden] {
  display: none;
}

.support-image-preview {
  position: fixed;
  inset: 0;
  z-index: 2147483647;
  display: grid;
  place-items: center;
  padding: 18px;
  background: transparent;
  pointer-events: none;
}

.support-image-preview-card {
  position: relative;
  display: grid;
  max-width: min(92vw, 920px);
  max-height: 84vh;
  margin: 0;
  pointer-events: auto;
}

.support-image-preview img {
  max-width: 100%;
  max-height: 84vh;
  object-fit: contain;
  border-radius: var(--radius-ios);
  background: rgba(15, 23, 42, 0.9);
  box-shadow: 0 18px 38px rgba(0, 0, 0, 0.32);
}

.support-image-preview figcaption {
  margin-top: 10px;
  padding: 10px 12px;
  border-radius: var(--radius-ios);
  color: #f8fafc;
  background: rgba(15, 23, 42, 0.82);
  line-height: 1.5;
  text-align: center;
}

.support-image-preview button {
  position: absolute;
  top: 8px;
  right: 8px;
  display: grid;
  width: 30px;
  height: 30px;
  place-items: center;
  border: 0;
  border-radius: var(--radius-ios);
  color: #fff;
  background: rgba(15, 23, 42, 0.8);
  cursor: pointer;
  font-size: 18px;
  font-weight: 900;
}

.scroll-dock button {
  position: relative;
  display: grid;
  width: clamp(34px, 3.2vw, 42px);
  height: clamp(34px, 3.2vw, 42px);
  place-items: center;
  border: 1px solid rgba(255, 255, 255, 0.22);
  border-radius: var(--radius-ios);
  color: transparent;
  background: rgba(15, 23, 42, 0.72);
  backdrop-filter: blur(18px);
  box-shadow: 0 10px 24px rgba(15, 23, 42, 0.22);
  cursor: pointer;
  font-size: 0;
  font-weight: 900;
  transition: transform 160ms ease, box-shadow 160ms ease;
}

.scroll-dock button:hover {
  transform: translateY(-2px);
  border-color: rgba(16, 185, 129, 0.58);
  background: rgba(15, 23, 42, 0.84);
  box-shadow: 0 14px 28px rgba(15, 23, 42, 0.3);
}

.scroll-dock button::before {
  content: "";
  position: absolute;
  left: 50%;
  top: 50%;
  box-sizing: border-box;
  width: clamp(9px, 0.95vw, 12px);
  height: clamp(9px, 0.95vw, 12px);
  border-left: clamp(2px, 0.22vw, 3px) solid #fff;
  border-top: clamp(2px, 0.22vw, 3px) solid #fff;
}

#toTopBtn::before {
  transform: translate(-50%, -50%) rotate(45deg);
}

#toBottomBtn::before {
  transform: translate(-50%, -50%) rotate(225deg);
}

body.mini-mode .scroll-dock {
  bottom: 22px;
}

#miniQuery {
  min-width: 0;
  min-height: 42px;
  padding: 0 12px;
  border: 1px solid rgba(255, 255, 255, 0.28);
  border-radius: var(--radius-control);
  outline: 0;
  color: #fff;
  background: rgba(255, 255, 255, 0.1);
}

#miniQuery::placeholder {
  color: rgba(255, 255, 255, 0.62);
}

#miniSendBtn {
  display: grid;
  place-items: center;
  min-height: 42px;
  padding: 0 13px;
  border: 0;
  border-radius: var(--radius-control);
  color: #fff;
  background: linear-gradient(135deg, var(--green), var(--green-dark));
  cursor: pointer;
  font-weight: 900;
}

.mini-expand {
  display: grid;
}

@keyframes chatPanelIn {
  from {
    opacity: 0;
    transform: translateY(18px) scale(0.96);
  }
  to {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
}

@keyframes bubbleIn {
  from {
    opacity: 0;
    transform: translateY(12px) scale(0.98);
  }
  to {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
}

@keyframes typingPulse {
  0%,
  80%,
  100% {
    transform: translateY(0);
    opacity: 0.38;
  }
  40% {
    transform: translateY(-4px);
    opacity: 1;
  }
}

@keyframes miniPop {
  0% {
    opacity: 0;
    transform: translateY(24px) scale(0.92);
  }
  70% {
    transform: translateY(-3px) scale(1.01);
  }
  100% {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
}

@keyframes miniShrinkIn {
  0% {
    opacity: 0;
    transform: translate(-50%, 28px) scale(0.9);
  }
  70% {
    transform: translate(-50%, -2px) scale(1.01);
  }
  100% {
    opacity: 1;
    transform: translate(-50%, 0) scale(1);
  }
}

@keyframes heroDrift {
  from {
    transform: scale(1);
    filter: saturate(1.05) contrast(1.02);
  }
  to {
    transform: scale(1.04);
    filter: saturate(1.18) contrast(1.08);
  }
}

@keyframes dataBeam {
  from {
    transform: translateX(0) rotate(-8deg);
  }
  to {
    transform: translateX(160vw) rotate(-8deg);
  }
}

.compact {
  margin-bottom: 20px;
}

.feature-strip {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 14px;
}

.feature-strip article {
  min-height: 140px;
  padding: 18px;
  border-radius: var(--radius-ios);
  background: #f3f7fb;
}

.feature-strip span {
  display: block;
  margin-bottom: 14px;
  color: var(--rose);
  font-weight: 900;
}

.feature-strip strong {
  line-height: 1.56;
}

.scene-buttons {
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 20px;
}

.scene-buttons button {
  color: var(--ink);
  border-color: #d8e1ea;
  background: #fff;
  backdrop-filter: none;
}





@supports (height: 100svh) {
  .hero {
    min-height: 100svh;
  }

  .hero-console {
    max-height: calc(100svh - 132px);
  }
}

@media (max-width: 1200px) {
  :root {
    --page-gutter: clamp(12px, 2.6vw, 22px);
    --section-width: min(100%, calc(100% - var(--page-gutter) * 2));
  }

  .topbar {
    width: var(--section-width);
  }

  .hero-console {
    width: min(100%, calc(var(--section-width) + var(--hero-control-rail)));
  }

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

  .ai-tools-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }
}

@media (max-width: 992px) {
  .nav-links {
    display: flex;
    gap: 10px;
    font-size: 13px;
  }

  .topbar {
    top: 10px;
    gap: 10px;
    padding: 10px;
  }

  .nav-actions {
    margin-left: auto;
    gap: 6px;
  }

  .mobile-menu-toggle {
    display: inline-grid;
    place-items: center;
    min-width: 58px;
    height: 38px;
    padding: 0 10px;
    border: 1px solid rgba(15, 23, 42, 0.16);
    border-radius: var(--radius-ios);
    background: rgba(255, 255, 255, 0.88);
    color: var(--ink);
    font-size: 13px;
    font-weight: 800;
    cursor: pointer;
  }

  .mobile-menu-panel {
    position: absolute;
    left: 0;
    right: 0;
    top: calc(100% + 8px);
    z-index: 80;
    display: none;
    grid-template-columns: 1fr;
    gap: 8px;
    padding: 10px;
    border: 1px solid rgba(148, 163, 184, 0.3);
    border-radius: var(--radius-ios);
    background: rgba(255, 255, 255, 0.96);
    box-shadow: 0 16px 34px rgba(15, 23, 42, 0.18);
  }

  .topbar.mobile-menu-open .mobile-menu-panel {
    display: grid;
  }

  .mobile-menu-link,
  .mobile-menu-action {
    display: inline-grid;
    place-items: center;
    min-height: 38px;
    padding: 0 12px;
    border: 1px solid #dbe4ee;
    border-radius: var(--radius-ios);
    color: #334155;
    background: #fff;
    font-size: 13px;
    font-weight: 700;
    text-decoration: none;
    cursor: pointer;
  }

  .hero {
    padding-top: calc(96px + env(safe-area-inset-top, 0px));
    padding-bottom: 320px;
  }

  .hero-content {
    max-width: min(680px, 100%);
    text-align: center;
    margin-inline: auto;
  }

  .hero-console {
    bottom: calc(12px + env(safe-area-inset-bottom, 0px));
    width: calc(100% - var(--page-gutter) * 2);
    max-height: calc(100svh - 102px);
  }

  .model-bar {
    grid-template-columns: 1fr;
    gap: 8px;
  }

  .model-bar > span {
    display: none;
  }

  .search-chat-box {
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
    gap: 8px;
    padding: 8px;
  }

  .search-chat-row {
    position: relative;
  }

  .chat-side-controls {
    position: absolute;
    right: 8px;
    top: -40px;
    z-index: 6;
    grid-auto-flow: column;
    grid-template-columns: repeat(2, var(--hero-expand-size));
    gap: 6px;
  }

  .composer-input-shell,
  .action-pair,
  .attachment-tray {
    grid-column: 1 / -1;
  }

  .action-pair {
    display: grid;
    grid-template-columns: 1fr 1fr;
  }

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

  .api-panel,
  .api-cards {
    grid-template-columns: 1fr;
  }

  .api-model-page .api-workbench-head {
    grid-template-columns: 1fr;
  }

  .api-promo-copy {
    grid-column: auto;
  }

  .api-account-summary {
    justify-self: stretch;
    width: 100%;
    margin-right: 0;
    max-width: none;
  }

  .api-model-market,
  .api-version-item {
    grid-template-columns: 1fr;
  }

  .api-model-page,
  .api-model-page .api-workbench {
    min-height: 0;
  }

  .api-model-page .api-provider-list,
  .api-model-page .api-version-list {
    max-height: min(62svh, 620px);
  }

  .api-model-page .api-promo-copy > span {
    font-size: 36px;
  }

  .api-promo-copy strong {
    font-size: 22px;
  }

  .api-promo-copy p {
    font-size: 14px;
  }

  .api-model-search {
    grid-template-columns: 1fr 42px;
  }

  .api-model-page .api-model-search span {
    grid-column: 1 / -1;
    font-size: 13px;
  }

  .api-version-item .model-version-price,
  .api-version-price-pending {
    justify-self: stretch;
  }
}

@media (max-width: 768px) and (orientation: portrait) {
  .support-widget {
    right: 12px;
    bottom: calc(164px + env(safe-area-inset-bottom, 0px));
    top: auto;
  }

  .support-launcher {
    width: 44px;
    height: 44px;
    min-width: 44px;
    min-height: 44px;
    border-radius: var(--radius-ios);
  }

  .support-launcher-icon {
    width: 29px;
    height: 29px;
  }

  .support-launcher-icon svg {
    width: 29px;
    height: 29px;
  }

  .support-widget.open {
    inset: 0 !important;
    top: 0 !important;
    right: 0 !important;
    bottom: 0 !important;
    left: 0 !important;
    width: 100vw;
    height: 100svh;
    display: grid;
    place-items: stretch;
    padding: 0;
    background: rgba(15, 23, 42, 0.42);
    backdrop-filter: blur(8px);
  }

  .support-widget.open.support-widget-positioned {
    top: 0 !important;
    left: 0 !important;
  }

  .support-widget.open .support-panel {
    width: 100vw;
    height: 100svh;
    max-height: none;
    border-radius: 0;
    display: grid;
    grid-template-rows: auto minmax(0, 1fr) auto;
  }

  .support-widget.open .support-messages {
    height: auto;
    min-height: 0;
    max-height: none;
  }

  .support-widget.open .support-launcher {
    display: none;
  }

  .support-widget.open .support-form {
    padding-bottom: calc(10px + env(safe-area-inset-bottom, 0px));
  }

  .composer-input-row {
    grid-template-columns: 36px minmax(0, 1fr) max-content;
    gap: 6px;
  }

  .send-inline-btn {
    min-height: 36px;
    width: auto;
    min-width: max-content;
    padding: 0 12px;
    font-size: 13px;
    border-radius: var(--radius-ios);
  }

  .theme-toggle,
  .language-btn {
    width: 40px;
    min-width: 40px;
    height: 38px;
    padding: 0;
  }

  .theme-text,
  .language-text,
  .nav-actions .register-trigger {
    display: none !important;
  }

  .nav-links {
    display: none;
  }

  .nav-actions .theme-toggle,
  .nav-actions .language-switcher,
  .nav-actions .register-trigger {
    display: none !important;
  }

  .hero {
    padding-top: calc(88px + env(safe-area-inset-top, 0px));
    padding-bottom: 300px;
  }

  h1 {
    font-size: clamp(31px, 8.8vw, 44px);
    line-height: 1.08;
  }

  .hero-text {
    font-size: 14px;
    line-height: 1.58;
  }

  .search-chat-row {
    grid-template-columns: minmax(0, 1fr);
    gap: 8px;
    position: relative;
    padding-top: 42px;
  }

  .chat-model-picker,
  .model-version-picker {
    grid-column: auto;
    width: 100%;
    max-width: 100%;
  }

  .chat-model-btn,
  .model-version-btn {
    min-height: 46px;
  }

  .action-pair {
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-start;
    gap: 8px;
  }

  .composer-input-shell {
    min-height: 54px;
    padding: 6px;
  }

  .composer-input-row {
    grid-template-columns: 40px minmax(0, 1fr);
    gap: 6px;
  }

  .attach-btn {
    width: 40px;
    min-width: 40px;
    height: 40px;
    min-height: 40px;
  }

  #aiQuery {
    min-height: 44px;
    font-size: 15px;
    line-height: 1.5;
  }

  .metrics {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 8px;
    padding: 12px;
    text-align: center;
  }

  .filter-row,
  .quick-prompts,
  .scene-buttons {
    justify-content: flex-start;
    flex-wrap: nowrap;
    white-space: nowrap;
    overflow: hidden;
    padding-right: 64px;
    max-height: 52px;
  }

  .filter-row.mobile-overflow-open,
  .quick-prompts.mobile-overflow-open,
  .scene-buttons.mobile-overflow-open {
    flex-wrap: wrap;
    white-space: normal;
    overflow: visible;
    max-height: none;
  }

  .group-more-btn {
    display: inline-grid;
    place-items: center;
    min-height: 36px;
    padding: 0 10px;
    border: 1px solid rgba(148, 163, 184, 0.28);
    border-radius: var(--radius-ios);
    color: #334155;
    background: #fff;
    font-size: 12px;
    font-weight: 800;
    cursor: pointer;
    margin-top: 6px;
  }

  .tool-grid {
    grid-template-columns: 1fr;
    gap: 12px;
  }

  .mini-chat {
    left: 0;
    right: 0;
    bottom: 0;
    width: 100%;
    max-width: 100%;
    border-radius: 0;
    border-left: 0;
    border-right: 0;
    border-bottom: 0;
    padding: 8px 10px calc(8px + env(safe-area-inset-bottom, 0px));
    --mini-bottom: calc(8px + env(safe-area-inset-bottom, 0px));
    --mini-expanded-height: min(460px, 62svh);
  }

  body.mini-mode .mini-chat,
  body.mini-mode .mini-chat:not(.compact) {
    left: 0;
    transform: none;
  }

  .mini-input-row {
    border: 0 !important;
    background: transparent !important;
    box-shadow: none !important;
    padding: 0 !important;
  }

  .chat-side-controls {
    position: absolute;
    right: 8px;
    top: 0;
    z-index: 6;
    grid-auto-flow: column;
    grid-template-columns: repeat(2, var(--hero-expand-size));
    gap: 6px;
  }

  .scroll-dock {
    bottom: calc(76px + env(safe-area-inset-bottom, 0px));
  }

  body.mini-mode .scroll-dock {
    bottom: calc(86px + env(safe-area-inset-bottom, 0px));
  }

  .mini-head {
    width: 48px;
    height: 48px;
  }

  .mini-avatar,
  .mini-avatar .app-icon {
    width: 34px;
    height: 34px;
  }
}

@media (max-width: 520px) and (orientation: portrait) {
  .topbar {
    width: calc(100% - 16px);
    padding: 8px;
  }

  .brand span:last-child {
    display: inline;
  }

  .hero {
    padding-bottom: 286px;
  }

  .hero-content .eyebrow {
    display: none;
  }

  h1 {
    font-size: clamp(28px, 9.1vw, 36px);
  }

  .quick-prompts {
    display: flex;
  }

  .mini-chat { width: 100%; }
}


/* mobile hard-fallback overrides 2026-05-12 */
@media (max-width: 768px) and (orientation: portrait) {
  .model-bar,
  .quick-prompts,
  #searchBtn,
  .action-pair {
    display: none !important;
  }

  .hero {
    align-items: end !important;
    padding-bottom: 0 !important;
  }

  .hero-console {
    bottom: 0 !important;
    border-bottom-left-radius: 0 !important;
    border-bottom-right-radius: 0 !important;
  }

  .topbar .brand span:last-child,
  .section-head h2 {
    white-space: nowrap !important;
    font-size: clamp(14px, 4vw, 20px) !important;
  }

  .chat-model-main,
  .chat-model-main .model-option-name,
  .chat-model-main .model-hot-badge,
  .chat-model-main .chat-current-country {
    white-space: nowrap !important;
  }

  .model-version-name {
    font-size: clamp(11px, 3vw, 13px) !important;
  }
}


/* mobile ux refine 2026-05-12 */
@media (max-width: 768px) and (orientation: portrait) {
  .topbar button,
  .search-chat-box button,
  .quick-prompts button,
  .filter-row button,
  .scene-buttons button,
  .chat-side-controls button {
    width: auto;
    max-width: 100%;
    min-width: fit-content;
    white-space: nowrap;
  }

  .search-chat-row {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 8px;
  }

  .search-chat-box,
  .quick-prompts.mobile-inline-prompts {
    flex: 1 1 auto;
    min-width: min(100%, 320px);
  }

  .quick-prompts.mobile-inline-prompts {
    margin-top: 0;
    padding-right: 0;
    overflow: visible;
    max-height: none;
    flex-wrap: nowrap;
  }

  .quick-prompts.mobile-inline-prompts button {
    flex: 0 0 auto;
  }

  .composer-input-row {
    grid-template-columns: 36px minmax(0, 1fr) max-content;
    gap: 6px;
  }

  .search-chat-box .chat-model-btn :is(.model-hot-badge, .aggregate-badge, .chat-current-country, .country-flag),
  .search-chat-box .model-version-btn :is(.model-version-badges, .model-version-main-prices, .model-version-price-chip) {
    display: none !important;
  }

}

@media (max-width: 520px) and (orientation: portrait) {
  .hero-content .eyebrow {
    display: block !important;
  }
}

/* mobile alignment fixes 2026-05-13 */
@media (max-width: 768px) and (orientation: portrait) {
  .hero {
    align-items: start !important;
    padding-top: calc(112px + env(safe-area-inset-top, 0px)) !important;
    padding-bottom: 290px !important;
  }

  .hero-content,
  .hero-content h1,
  .hero-text {
    display: block !important;
    opacity: 1 !important;
    visibility: visible !important;
  }

  .hero-content {
    width: 100%;
    max-width: calc(100% - 24px);
    margin: 0 auto 10px;
    text-align: left;
    z-index: 2;
  }

  .hero-content h1 {
    margin: 6px 0 8px;
    font-size: clamp(28px, 8.8vw, 38px);
    line-height: 1.14;
  }

  .hero-text {
    font-size: 14px;
    line-height: 1.5;
  }

  .chat-side-controls {
    right: 8px;
    top: 2px;
    grid-template-columns: repeat(2, clamp(34px, 9vw, 42px));
    gap: 5px;
  }

  .chat-side-controls button {
    width: clamp(34px, 9vw, 42px);
    height: clamp(34px, 9vw, 42px);
    min-height: clamp(34px, 9vw, 42px);
    border-radius: var(--radius-ios);
  }

  .search-chat-box .action-pair {
    display: none !important;
  }

  .composer-input-row {
    grid-template-columns: 36px minmax(0, 1fr) max-content !important;
    gap: 6px;
  }

  .send-inline-btn {
    display: inline-grid !important;
    place-items: center;
    width: auto !important;
    min-width: max-content;
    min-height: 38px;
    padding: 0 14px;
    border-radius: var(--radius-ios);
    font-size: 14px;
  }

  .ai-launcher {
    right: clamp(10px, 1.35vw, 20px);
    width: clamp(40px, 9.5vw, 42px);
    height: clamp(40px, 9.5vw, 42px);
    border-radius: var(--radius-ios);
    bottom: calc(118px + env(safe-area-inset-bottom, 0px));
  }

  .ai-launcher::before,
  .ai-launcher::after {
    top: 13px;
    width: 5px;
    height: 5px;
  }

  .ai-launcher::before {
    left: 13px;
  }

  .ai-launcher::after {
    right: 13px;
  }

  .ai-launcher span {
    transform: translateY(6px);
    font-size: 11px;
  }

  body.scroll-dock-visible.launcher-mode .ai-launcher {
    bottom: calc(146px + env(safe-area-inset-bottom, 0px));
  }
}

/* mobile nav + composer layout refine 2026-05-13 */
@media (max-width: 768px) and (orientation: portrait) {
  .hero-content {
    text-align: center !important;
  }

  .hero-content h1,
  .hero-text {
    text-align: center !important;
  }

  .topbar {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    row-gap: 8px;
  }

  .brand {
    order: 1;
  }

  .nav-actions {
    order: 2;
    margin-left: auto;
    display: inline-flex !important;
    align-items: center;
    gap: 6px;
  }

  .mobile-menu-toggle {
    order: 1;
    display: inline-grid !important;
  }

  .nav-actions .language-switcher {
    order: 2;
    display: inline-grid !important;
  }

  .nav-actions .login-trigger {
    order: 3;
    display: inline-grid !important;
  }

  .nav-actions .register-trigger {
    display: none !important;
  }

  .nav-links {
    order: 3;
    display: inline-flex !important;
    width: 100%;
    justify-content: center;
    gap: 10px;
    font-size: 13px;
  }

  .search-chat-row {
    padding-top: 52px !important;
  }

  .chat-side-controls {
    top: -44px !important;
    right: 8px;
    gap: 8px !important;
  }

  .search-chat-box {
    grid-template-columns: 1fr 1fr !important;
    column-gap: 8px !important;
    row-gap: 8px !important;
  }

  .chat-model-picker,
  .model-version-picker {
    grid-column: auto !important;
    width: 100% !important;
  }

  .chat-model-btn,
  .model-version-btn {
    width: 100%;
    min-height: 48px !important;
  }

  .composer-input-shell {
    grid-column: 1 / -1 !important;
  }

  .filter-row button,
  .group-more-btn {
    min-height: 40px !important;
    padding: 0 14px !important;
    border-radius: var(--radius-ios) !important;
    font-size: 13px !important;
    font-weight: 800 !important;
  }

  #directory {
    margin-top: 14px !important;
  }

  .mini-chat {
    bottom: 0 !important;
    padding-bottom: env(safe-area-inset-bottom, 0px) !important;
  }
}

/* mobile final overrides 2026-05-13 */
@media (max-width: 768px) and (orientation: portrait) {
  .brand {
    margin-left: 8px !important;
  }

  .topbar {
    display: flex !important;
    flex-wrap: wrap !important;
    align-items: center !important;
    column-gap: 8px !important;
    row-gap: 6px !important;
  }

  .nav-links {
    order: 2 !important;
    display: inline-flex !important;
    width: auto !important;
    flex: 0 1 auto !important;
    margin-left: 4px !important;
    gap: 8px !important;
    justify-content: flex-start !important;
    align-items: center !important;
  }

  .nav-links a {
    white-space: nowrap !important;
    width: auto !important;
    flex: 0 0 auto !important;
    padding: 0 8px !important;
    min-height: 30px !important;
    line-height: 30px !important;
    border-radius: var(--radius-ios) !important;
    font-size: 13px !important;
  }

  .nav-links a[href="#directory"],
  .nav-links a[href="#scenes"] {
    display: none !important;
  }

  .nav-actions {
    order: 3 !important;
    margin-left: auto !important;
    display: inline-flex !important;
    align-items: center !important;
    gap: 6px !important;
  }

  #mobileMenuToggle,
  .mobile-menu-toggle {
    order: 1 !important;
    width: auto !important;
    min-width: fit-content !important;
    padding: 0 14px !important;
    white-space: nowrap !important;
  }

  .nav-actions .language-switcher {
    order: 2 !important;
  }

  .language-btn {
    width: auto !important;
    min-width: fit-content !important;
    padding: 0 10px !important;
    white-space: nowrap !important;
  }

  .nav-actions .login-trigger {
    order: 3 !important;
  }

  .hero {
    display: flex !important;
    flex-direction: column !important;
    justify-content: center !important;
  }

  .hero-content {
    text-align: center !important;
    margin: 0 auto 10px !important;
    transform: translateY(-6vh) !important;
  }

  .hero-content h1,
  .hero-text {
    text-align: center !important;
  }

  .search-chat-box {
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr) !important;
    column-gap: 8px !important;
  }

  .chat-model-picker,
  .model-version-picker {
    width: 100% !important;
  }

  .chat-model-btn,
  .model-version-btn {
    width: 100% !important;
    max-width: none !important;
    min-height: 50px !important;
  }

  .composer-input-shell {
    grid-column: 1 / -1 !important;
    width: 100% !important;
  }

  .chat-side-controls {
    top: auto !important;
    bottom: calc(100% + 6px) !important;
    right: 8px !important;
    gap: 6px !important;
  }

  .group-more-btn {
    white-space: nowrap !important;
    word-break: keep-all !important;
    overflow-wrap: normal !important;
    line-height: 1 !important;
  }

  .mini-chat {
    left: 0 !important;
    right: 0 !important;
    bottom: 0 !important;
    margin: 0 !important;
    padding-bottom: env(safe-area-inset-bottom, 0px) !important;
  }

  .mini-chat .mini-body,
  .mini-chat .mini-input-row,
  .mini-chat .mini-query-wrap {
    align-items: center !important;
  }
}

/* mobile + tablet parity overrides 2026-05-13 */
@media (max-width: 1024px) and (orientation: portrait) {
  .topbar {
    display: flex !important;
    flex-wrap: nowrap !important;
    align-items: center !important;
    gap: 8px !important;
  }

  .brand {
    margin-left: 10px !important;
    margin-right: 2px !important;
  }

  .nav-links {
    order: 2 !important;
    display: inline-flex !important;
    width: auto !important;
    flex: 0 1 auto !important;
    gap: 8px !important;
    margin-left: 0 !important;
    overflow: hidden !important;
  }

  .nav-links a[href="#directory"],
  .nav-links a[href="#scenes"] {
    display: none !important;
  }

  .nav-actions {
    margin-left: auto !important;
    display: inline-flex !important;
    align-items: center !important;
    gap: 6px !important;
  }

  #mobileMenuToggle,
  .mobile-menu-toggle {
    order: 1 !important;
  }

  .nav-actions .language-switcher {
    order: 2 !important;
  }

  .nav-actions .login-trigger {
    order: 3 !important;
  }

  .language-btn {
    width: auto !important;
    min-width: fit-content !important;
    padding-inline: 10px !important;
    white-space: nowrap !important;
  }

  .hero-console {
    padding-left: 20px !important;
    padding-right: 20px !important;
  }

  .chat-stream {
    margin: 0 !important;
    width: 100% !important;
    max-width: 100% !important;
    border-radius: var(--radius-ios) !important;
  }

  .search-chat-box {
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr) !important;
    column-gap: 10px !important;
    row-gap: 10px !important;
  }

  .chat-model-btn,
  .model-version-btn {
    width: 100% !important;
    min-height: 58px !important;
    border-radius: var(--radius-ios) !important;
  }

  .chat-side-controls {
    right: 8px !important;
    top: auto !important;
    bottom: calc(100% + 6px) !important;
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 8px !important;
  }

  .chat-side-controls #heroExpandBtn {
    order: 1 !important;
  }

  .chat-side-controls #heroFullscreenBtn {
    order: 2 !important;
  }

  .chat-side-controls button,
  .ai-launcher {
    width: 64px !important;
    height: 64px !important;
    min-height: 64px !important;
    border-radius: var(--radius-ios) !important;
  }

  .ai-launcher {
    right: 8px !important;
  }

  body.scroll-dock-visible.launcher-mode .ai-launcher {
    bottom: calc(128px + env(safe-area-inset-bottom, 0px)) !important;
  }

  .scroll-dock {
    right: 8px !important;
    bottom: calc(22px + env(safe-area-inset-bottom, 0px)) !important;
  }

  .scroll-dock button {
    width: 64px !important;
    height: 64px !important;
    border-radius: var(--radius-ios) !important;
  }

  .mini-chat {
    left: 0 !important;
    right: 0 !important;
    bottom: 0 !important;
    margin: 0 !important;
    transform: none !important;
    width: 100vw !important;
    max-width: 100vw !important;
    padding-bottom: 0 !important;
  }

  .mini-chat .mini-body,
  .mini-chat .mini-input-row,
  .mini-chat .mini-query-wrap {
    display: flex !important;
    align-items: center !important;
  }
}

/* mobile spacing/order hotfix 2026-05-13 */
@media (max-width: 1024px) and (orientation: portrait) {
  :root {
    --mobile-edge-gap: 14px;
  }

  .topbar {
    width: calc(100% - (var(--mobile-edge-gap) * 2)) !important;
    margin-left: var(--mobile-edge-gap) !important;
    margin-right: var(--mobile-edge-gap) !important;
  }

  #mobileMenuToggle,
  .mobile-menu-toggle {
    order: 2 !important;
    margin-right: 2px !important;
  }

  .nav-actions .language-switcher {
    order: 3 !important;
    margin-left: 0 !important;
  }

  .nav-actions .login-trigger {
    order: 4 !important;
  }

  .hero-console {
    padding-left: var(--mobile-edge-gap) !important;
    padding-right: var(--mobile-edge-gap) !important;
  }

  .search-chat-row {
    padding-top: 0 !important;
    margin-top: 0 !important;
  }

  .chat-stream {
    width: 100% !important;
    max-width: 100% !important;
    margin: 0 !important;
    padding: var(--mobile-edge-gap) !important;
  }

  .chat-stream .bubble {
    margin-left: 0 !important;
    margin-right: 0 !important;
  }

  .search-chat-box {
    width: 100% !important;
    max-width: 100% !important;
    margin: 0 !important;
  }
}

/* mobile hard overrides 2026-05-13 b */
@media (max-width: 1024px) and (orientation: portrait) {
  .topbar {
    gap: 6px !important;
  }

  .nav-links {
    display: inline-flex !important;
    gap: 6px !important;
  }

  .nav-links a {
    display: none !important;
  }

  .nav-links a[data-nav="tools"],
  .nav-links a[data-nav="api"] {
    display: inline-flex !important;
    align-items: center !important;
    white-space: nowrap !important;
  }

  .nav-actions {
    gap: 2px !important;
  }

  #mobileMenuToggle,
  .mobile-menu-toggle {
    order: 2 !important;
    margin-right: 0 !important;
    margin-left: 0 !important;
  }

  .nav-actions .language-switcher {
    order: 3 !important;
    margin-left: 0 !important;
  }

  .hero-console {
    margin-left: 0 !important;
    margin-right: 0 !important;
    width: 100% !important;
    max-width: 100% !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
    padding-top: 0 !important;
  }

  .search-chat-row {
    padding-top: 0 !important;
    margin-top: 0 !important;
  }

  .chat-stream {
    border-left: 0 !important;
    border-right: 0 !important;
    border-radius: 0 !important;
    padding: 0 0 12px 0 !important;
  }

  .chat-stream .bubble {
    margin-top: 12px !important;
    margin-bottom: 12px !important;
  }

  .chat-stream .bubble:first-child {
    margin-top: 0 !important;
  }

  .search-chat-box {
    margin: 0 !important;
    border-left: 0 !important;
    border-right: 0 !important;
    border-radius: 0 !important;
  }

  .chat-side-controls button {
    width: 50px !important;
    height: 50px !important;
    min-height: 50px !important;
    border-radius: var(--radius-ios) !important;
  }

  #attachBtn {
    display: inline-grid !important;
    place-items: center !important;
    text-align: center !important;
    padding: 0 !important;
  }

  #attachBtn > span {
    display: inline-grid !important;
    place-items: center !important;
    width: 100% !important;
    height: 100% !important;
  }

  .mini-chat .mini-body {
    display: flex !important;
    align-items: center !important;
    min-height: 72px !important;
  }

  .mini-chat .mini-input-row,
  .mini-chat .mini-head,
  .mini-chat .mini-query-wrap {
    display: flex !important;
    align-items: center !important;
  }

  .mini-chat .mini-input-row {
    justify-content: center !important;
  }
}

/* mobile header + mini input final lock 2026-05-13 c */
@media (max-width: 1024px) and (orientation: portrait) {
  .topbar {
    width: calc(100% - 20px) !important;
    margin: 10px auto !important;
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
  }

  .nav-links {
    display: none !important;
  }

  .nav-actions {
    display: inline-flex !important;
    align-items: center !important;
    gap: 8px !important;
    margin-left: auto !important;
  }

  #mobileMenuToggle,
  .mobile-menu-toggle,
  .nav-actions .language-switcher,
  .nav-actions .login-trigger {
    margin: 0 !important;
  }

  #mobileMenuToggle,
  .mobile-menu-toggle {
    order: 1 !important;
  }

  .nav-actions .language-switcher {
    order: 2 !important;
  }

  .nav-actions .login-trigger {
    order: 3 !important;
  }

  .mini-chat {
    padding-top: 0 !important;
    padding-bottom: 0 !important;
  }

  .mini-chat .mini-body {
    padding-top: 0 !important;
    padding-bottom: 0 !important;
    min-height: 64px !important;
    display: flex !important;
    align-items: center !important;
  }

  .mini-chat .mini-input-row {
    min-height: 64px !important;
    margin: 0 !important;
    padding: 0 !important;
    display: flex !important;
    align-items: center !important;
  }

  .mini-chat .mini-head,
  .mini-chat .mini-query-wrap {
    height: 100% !important;
    margin: 0 !important;
    display: flex !important;
    align-items: center !important;
  }
}

/* mobile fullscreen/chat final fix 2026-05-13 d */
@media (max-width: 1024px) and (orientation: portrait) {
  body.chat-fullscreen .model-bar,
  body.chat-fullscreen .model-switcher,
  body.chat-fullscreen .model-pills,
  body.chat-fullscreen .more-models {
    display: none !important;
    width: 0 !important;
    max-width: 0 !important;
    overflow: hidden !important;
    margin: 0 !important;
    padding: 0 !important;
  }

  .topbar {
    justify-content: space-between !important;
  }

  .nav-links {
    display: inline-flex !important;
    gap: 8px !important;
    margin-left: 8px !important;
  }

  .nav-links a {
    display: none !important;
  }

  .nav-links a[data-nav="tools"],
  .nav-links a[data-nav="api"] {
    display: inline-flex !important;
  }

  .nav-actions {
    gap: 8px !important;
  }

  #mobileMenuToggle,
  .mobile-menu-toggle {
    order: 1 !important;
  }

  .nav-actions .language-switcher {
    order: 2 !important;
  }

  .nav-actions .login-trigger {
    order: 3 !important;
  }

  .chat-stream {
    margin-top: 10px !important;
    margin-bottom: 10px !important;
    padding-top: 0 !important;
    padding-bottom: 0 !important;
    scrollbar-width: none !important;
  }

  .chat-stream::-webkit-scrollbar {
    height: 0 !important;
    width: 0 !important;
    display: none !important;
  }

  .chat-stream .bubble.ai,
  .chat-stream .bubble.user {
    margin-left: 10px !important;
    margin-right: 10px !important;
  }

  .chat-side-controls button {
    width: 48px !important;
    height: 48px !important;
    min-height: 48px !important;
    border-radius: var(--radius-ios) !important;
  }

  .scroll-dock button {
    width: 48px !important;
    height: 48px !important;
    border-radius: var(--radius-ios) !important;
  }
}

/* mobile spacing/menu/mini final lock 2026-05-13 e */
@media (max-width: 1024px) and (orientation: portrait) {
  .hero-console {
    padding-top: 0 !important;
    padding-bottom: 0 !important;
  }

  .chat-stream {
    margin-top: 8px !important;
    margin-bottom: 8px !important;
  }

  .search-chat-box {
    margin-top: 8px !important;
  }

  .nav-actions {
    gap: 8px !important;
  }

  .mobile-menu-toggle,
  #mobileMenuToggle {
    order: 2 !important;
  }

  .nav-actions .language-switcher {
    order: 3 !important;
  }

  .nav-actions .login-trigger {
    order: 4 !important;
  }

  .mini-chat {
    top: auto !important;
    margin-top: 0 !important;
    padding-top: 0 !important;
  }

  .mini-chat .mini-body {
    margin-top: 0 !important;
    padding-top: 0 !important;
    min-height: 60px !important;
    align-items: center !important;
  }

  .mini-chat .mini-input-row {
    margin-top: 0 !important;
    padding-top: 0 !important;
    min-height: 60px !important;
    align-items: center !important;
  }
}

.attach-menu-panel {
  position: fixed;
  z-index: 2147483651;
  display: grid;
  gap: 10px;
  width: min(280px, calc(100vw - 20px));
  padding: 12px;
  border: 1px solid rgba(255, 255, 255, 0.24);
  border-radius: var(--radius-ios);
  color: #fff;
  background: rgba(15, 23, 42, 0.86);
  box-shadow: var(--shadow);
  backdrop-filter: blur(22px);
}

.attach-menu-panel .attach-menu-option {
  display: grid;
  grid-template-columns: 42px 1fr;
  grid-template-rows: auto auto;
  align-items: center;
  column-gap: 10px;
  min-height: 58px;
  padding: 8px 10px;
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: var(--radius-control);
  background: rgba(255, 255, 255, 0.08);
  color: #fff;
  text-align: left;
  cursor: pointer;
}

.attach-menu-panel .attach-menu-option > span {
  grid-row: 1 / 3;
  display: inline-grid;
  width: 42px;
  height: 42px;
  place-items: center;
  border-radius: var(--radius-icon);
  overflow: hidden;
  color: #ecfdf5;
  background: linear-gradient(135deg, #0f172a, #059669);
  font-size: 13px;
  font-weight: 950;
}

.attach-menu-panel .attach-menu-option strong {
  font-size: 14px;
  font-weight: 900;
  line-height: 1.2;
}

.attach-menu-panel .attach-menu-option small {
  color: rgba(255, 255, 255, 0.72);
  font-size: 14px;
  font-weight: 700;
}

.attach-menu-panel .attach-menu-option:hover,
.attach-menu-panel .attach-menu-option:focus-visible {
  border-color: #22c55e;
  color: #065f46;
  outline: none;
  transform: translateY(-1px);
}

.repo-connect-modal {
  position: fixed;
  inset: 0;
  z-index: 2147482300;
  display: grid;
  place-items: center;
  padding: 18px;
  background: rgba(2, 6, 23, 0.36);
  backdrop-filter: blur(10px);
}

.repo-connect-modal[hidden] {
  display: none;
}

.repo-connect-card {
  position: relative;
  width: min(440px, 100%);
  padding: 20px;
  border: 1px solid rgba(148, 163, 184, 0.28);
  border-radius: var(--radius-ios);
  background:
    radial-gradient(circle at 0 0, rgba(20, 184, 166, 0.14), transparent 34%),
    rgba(248, 250, 252, 0.96);
  box-shadow: 0 28px 70px rgba(2, 6, 23, 0.36);
  color: #0f172a;
}

.repo-connect-close {
  position: absolute;
  top: 14px;
  right: 14px;
  display: inline-grid;
  width: 36px;
  height: 36px;
  place-items: center;
  border: 1px solid rgba(148, 163, 184, 0.4);
  border-radius: var(--radius-ios);
  background: rgba(255, 255, 255, 0.82);
  color: #0f172a;
  font-size: 20px;
  font-weight: 900;
}

.repo-connect-card h2 {
  margin: 4px 44px 8px 0;
  font-size: clamp(24px, 5vw, 32px);
  line-height: 1.05;
}

.repo-connect-copy {
  margin: 0 0 14px;
  color: #475569;
  font-size: 14px;
  font-weight: 700;
  line-height: 1.55;
}

.repo-connect-methods,
.repo-connect-form,
.repo-connect-actions {
  display: grid;
  gap: 10px;
}

.repo-auth-btn,
.repo-refresh-btn,
.repo-list-item {
  display: grid;
  grid-template-columns: 42px 1fr;
  grid-template-rows: auto auto;
  align-items: center;
  column-gap: 10px;
  min-height: 58px;
  padding: 8px 10px;
  border: 1px solid rgba(20, 184, 166, 0.36);
  border-radius: var(--radius-ios);
  background: rgba(236, 253, 245, 0.86);
  color: #064e3b;
  text-align: left;
}

.repo-auth-btn > span,
.repo-refresh-btn > span,
.repo-list-item > span {
  grid-row: 1 / 3;
  display: inline-grid;
  width: 42px;
  height: 42px;
  place-items: center;
  border-radius: var(--radius-ios);
  color: #ecfdf5;
  background: linear-gradient(135deg, #0f172a, #047857);
  font-size: 13px;
  font-weight: 950;
}

.repo-refresh-btn {
  background: rgba(255, 255, 255, 0.78);
  color: #0f172a;
}

.repo-refresh-btn > span {
  background: linear-gradient(135deg, #334155, #0f172a);
}

.repo-auth-btn strong,
.repo-refresh-btn strong,
.repo-list-item strong,
.repo-connect-form label span {
  font-weight: 900;
}

.repo-auth-btn small,
.repo-refresh-btn small,
.repo-list-item small {
  color: #047857;
  font-size: 12px;
  font-weight: 800;
}

.repo-list {
  display: grid;
  gap: 8px;
  max-height: min(260px, 34vh);
  overflow: auto;
  padding: 2px;
}

.repo-list[hidden] {
  display: none;
}

.repo-list-item {
  width: 100%;
  border-color: rgba(203, 213, 225, 0.72);
  background: rgba(255, 255, 255, 0.86);
}

.repo-list-item > span {
  background: linear-gradient(135deg, #0f172a, #0369a1);
}

.repo-connect-form {
  margin-top: 12px;
}

.repo-connect-form label {
  display: grid;
  gap: 6px;
}

.repo-connect-form input {
  width: 100%;
  height: 46px;
  border: 1px solid rgba(148, 163, 184, 0.54);
  border-radius: var(--radius-ios);
  padding: 0 14px;
  background: rgba(255, 255, 255, 0.9);
  color: #0f172a;
  font-size: 14px;
  font-weight: 800;
  outline: none;
}

.repo-connect-form input:focus {
  border-color: #10b981;
  box-shadow: 0 0 0 4px rgba(16, 185, 129, 0.14);
}

.repo-connect-status {
  min-height: 18px;
  margin: 0;
  color: #047857;
  font-size: 12px;
  font-weight: 800;
}

.repo-connect-status.is-error {
  color: #b91c1c;
}

.repo-connect-actions {
  grid-template-columns: 1fr auto;
}

.repo-connect-submit,
.repo-connect-disconnect {
  min-height: 46px;
  border: 0;
  border-radius: var(--radius-ios);
  padding: 0 16px;
  font-size: 14px;
  font-weight: 900;
}

.repo-connect-submit {
  background: linear-gradient(135deg, #10b981, #047857);
  color: #fff;
}

.repo-connect-disconnect {
  background: rgba(15, 23, 42, 0.08);
  color: #334155;
}

@media (max-width: 1024px) and (orientation: portrait) {
  .attach-btn,
  #miniAttachBtn {
    min-width: 40px !important;
    width: 40px !important;
    height: 40px !important;
    min-height: 40px !important;
    font-size: 28px !important;
    line-height: 1 !important;
    font-weight: 700 !important;
  }

  #miniAttachBtn {
    display: inline-grid !important;
    place-items: center !important;
    padding: 0 !important;
  }

  .mini-chat .mini-input-row {
    justify-content: center !important;
  }

  .mini-chat .mini-head {
    margin-left: 0 !important;
    margin-right: 8px !important;
    justify-content: center !important;
  }
}

/* mobile menu/panel/hero refine 2026-05-13 f */
@media (max-width: 1024px) and (orientation: portrait) {
  .hero-content {
    min-height: 170px !important;
    display: flex !important;
    flex-direction: column !important;
    justify-content: center !important;
  }

  .hero-content h1 {
    font-size: clamp(40px, 10vw, 56px) !important;
    line-height: 1.08 !important;
    margin: 8px 0 !important;
  }

  .topbar {
    display: flex !important;
    flex-wrap: nowrap !important;
    align-items: center !important;
  }

  .brand {
    order: 1 !important;
  }

  .nav-links {
    order: 2 !important;
  }

  #mobileMenuToggle,
  .mobile-menu-toggle {
    order: 3 !important;
    margin-left: auto !important;
    border-radius: var(--radius-icon) !important;
  }

  .nav-actions {
    order: 4 !important;
    margin-left: 8px !important;
    gap: 8px !important;
  }

  .mini-chat {
    bottom: 0 !important;
    margin-bottom: 0 !important;
    padding-bottom: 0 !important;
  }

  .mini-chat .mini-body {
    margin: 0 !important;
    padding: 0 !important;
  }

  .mini-chat .mini-input-row {
    margin: 0 !important;
    padding: 0 !important;
    min-height: 58px !important;
    display: flex !important;
    align-items: center !important;
  }

  .mobile-menu-panel {
    display: none !important;
    grid-template-columns: repeat(3, max-content) !important;
    justify-content: center !important;
    align-content: center !important;
    gap: 10px 12px !important;
    padding: 12px !important;
  }

  .topbar.mobile-menu-open .mobile-menu-panel {
    display: grid !important;
  }

  .mobile-menu-panel .mobile-menu-link,
  .mobile-menu-panel .mobile-menu-action {
    width: auto !important;
    min-width: fit-content !important;
    min-height: 40px !important;
    padding: 0 14px !important;
    border-radius: var(--radius-icon) !important;
    white-space: nowrap !important;
  }

  .mobile-menu-panel .mobile-menu-link[data-nav="tools"],
  .mobile-menu-panel .mobile-menu-link[data-nav="api"] {
    display: none !important;
  }

  .mini-chat {
    display: flex !important;
    align-items: center !important;
  }

  .mini-chat .mini-body {
    width: 100% !important;
    height: 100% !important;
    min-height: 0 !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
  }

  .mini-chat .mini-input-row {
    width: 100% !important;
    height: 100% !important;
    min-height: 0 !important;
    display: flex !important;
    align-items: center !important;
  }

  .mini-chat .mini-head,
  .mini-chat .mini-query-wrap {
    align-self: center !important;
  }

  .mini-chat .mini-head {
    margin-left: auto !important;
    margin-right: 8px !important;
  }

  .mini-chat .mini-controls {
    position: absolute !important;
    right: 8px !important;
    top: -34px !important;
    z-index: 9 !important;
    display: inline-grid !important;
    grid-auto-flow: column !important;
    gap: 6px !important;
  }

  .mini-chat .mini-close,
  .mini-chat .mini-expand {
    width: 28px !important;
    height: 28px !important;
    min-height: 28px !important;
    border-radius: var(--radius-ios) !important;
  }

  .scroll-dock button {
    width: 32px !important;
    height: 32px !important;
    border-radius: var(--radius-ios) !important;
  }

  .ai-launcher {
    width: 32px !important;
    height: 32px !important;
    border-radius: var(--radius-ios) !important;
  }

  body.mini-mode .mini-chat:not(.compact) {
    width: calc(100vw - 8px) !important;
    max-width: calc(100vw - 8px) !important;
    left: 4px !important;
    right: 4px !important;
    transform: none !important;
  }

  body.mini-mode .mini-chat:not(.compact) .mini-body {
    display: grid !important;
    grid-template-rows: minmax(0, 1fr) auto !important;
    align-items: stretch !important;
    height: 100% !important;
  }

  body.mini-mode .mini-chat:not(.compact) .mini-stream {
    min-height: 0 !important;
    padding-bottom: 8px !important;
  }

  body.mini-mode .mini-chat:not(.compact) .mini-input-row {
    position: sticky !important;
    bottom: 0 !important;
    z-index: 3 !important;
    margin: 0 !important;
    padding: 0 !important;
    background: transparent !important;
  }

  .mini-chat .mini-controls {
    top: -30px !important;
  }

  .chat-stream {
    margin-top: 6px !important;
    margin-bottom: 6px !important;
  }

  .hero-console {
    --hero-console-gap: 6px !important;
  }

  .auth-card {
    width: min(92vw, 440px) !important;
    max-height: min(84svh, 700px) !important;
    padding: 18px !important;
    border-radius: var(--radius-ios) !important;
  }

  .auth-card h2 {
    font-size: clamp(28px, 7vw, 34px) !important;
  }

  .topbar.nav-overflow .nav-links {
    display: none !important;
  }

  .topbar.nav-overflow.mobile-menu-open .mobile-menu-panel .mobile-menu-link[data-nav="tools"],
  .topbar.nav-overflow.mobile-menu-open .mobile-menu-link[data-nav="api"] {
    display: inline-grid !important;
  }

  .topbar.nav-overflow.mobile-menu-open .mobile-menu-panel {
    grid-template-columns: repeat(2, max-content) !important;
  }
}

/* mobile fullscreen + mini-chat final lock 2026-05-13 */
@media (max-width: 1024px) and (orientation: portrait) {
  body.chat-fullscreen .hero-console,
  body.chat-fullscreen.chat-mode:not(.mini-mode) .hero-console {
    left: 0 !important;
    right: 0 !important;
    width: 100vw !important;
    max-width: 100vw !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
  }

  body.chat-fullscreen .chat-stream {
    margin-top: 4px !important;
    margin-bottom: 4px !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
    width: 100% !important;
    max-width: 100% !important;
    padding-left: 8px !important;
    padding-right: 8px !important;
    overflow-x: hidden !important;
  }

  body.chat-fullscreen .search-chat-row {
    margin-top: 4px !important;
    margin-bottom: 4px !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
    width: 100% !important;
  }

  body.chat-fullscreen .search-chat-box {
    margin-left: 0 !important;
    margin-right: 0 !important;
    width: 100% !important;
    max-width: 100% !important;
  }

  body.mini-mode .mini-chat:not(.compact) {
    left: 0 !important;
    right: 0 !important;
    width: 100vw !important;
    max-width: 100vw !important;
    transform: none !important;
    border-radius: 0 !important;
  }

  body.mini-mode .mini-chat:not(.compact) .mini-body {
    display: grid !important;
    grid-template-rows: minmax(0, 1fr) auto !important;
    align-items: stretch !important;
    height: 100% !important;
    min-height: 0 !important;
  }

  body.mini-mode .mini-chat:not(.compact) .mini-stream {
    min-height: 0 !important;
    height: auto !important;
    overflow: auto !important;
    padding-bottom: 6px !important;
  }

  body.mini-mode .mini-chat:not(.compact) .mini-input-row {
    position: sticky !important;
    bottom: 0 !important;
    width: 100% !important;
    z-index: 4 !important;
    margin: 0 !important;
  }

  .mini-chat .mini-controls {
    top: -38px !important;
    right: 10px !important;
    z-index: 12 !important;
  }

  .mini-chat .mini-close,
  .mini-chat .mini-expand {
    width: 30px !important;
    height: 30px !important;
    min-height: 30px !important;
    border-radius: var(--radius-ios) !important;
  }

  .scroll-dock button,
  .ai-launcher {
    width: 30px !important;
    height: 30px !important;
    border-radius: var(--radius-ios) !important;
  }
}

/* mobile fullscreen spacing/width lock 2026-05-13 */
@media (max-width: 1024px) and (orientation: portrait) {
  body.chat-fullscreen .hero-console,
  body.chat-fullscreen.chat-mode:not(.mini-mode) .hero-console {
    grid-template-columns: minmax(0, 1fr) !important;
    grid-template-rows: minmax(0, 1fr) auto !important;
    grid-template-areas:
      "chat"
      "composer" !important;
    gap: 6px !important;
    padding-top: 6px !important;
    padding-bottom: 6px !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
    left: 0 !important;
    right: 0 !important;
    width: 100vw !important;
    max-width: 100vw !important;
  }

  body.chat-fullscreen .model-bar,
  body.chat-fullscreen .model-switcher,
  body.chat-fullscreen .model-pills,
  body.chat-fullscreen .more-models,
  body.chat-fullscreen .fullscreen-hot-tabs {
    display: none !important;
    width: 0 !important;
    max-width: 0 !important;
    margin: 0 !important;
    padding: 0 !important;
    border: 0 !important;
    overflow: hidden !important;
  }

  body.chat-fullscreen .chat-stream {
    width: 100% !important;
    max-width: 100% !important;
    margin: 2px 0 !important;
    padding: 4px 0 !important;
    overflow-x: hidden !important;
  }

  body.chat-fullscreen .bubble,
  body.chat-fullscreen .bubble.ai,
  body.chat-fullscreen .bubble.user {
    width: 100% !important;
    max-width: 100% !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
  }

  body.chat-fullscreen .search-chat-row,
  body.chat-fullscreen .search-chat-box {
    width: 100% !important;
    max-width: 100% !important;
    margin: 2px 0 !important;
    left: 0 !important;
    right: 0 !important;
  }
}

/* mobile fullscreen/expand hard-fix 2026-05-13 */
@media (max-width: 1024px) and (orientation: portrait) {
  body.chat-fullscreen .fullscreen-utility-bar {
    top: 8px !important;
    right: 8px !important;
    z-index: 2147483648 !important;
  }

  body.chat-fullscreen .chat-stream {
    width: 100% !important;
    max-width: 100% !important;
    margin: 0 !important;
    padding-top: 74px !important;
    padding-bottom: 4px !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
  }

  body.chat-fullscreen .bubble,
  body.chat-fullscreen .bubble.ai,
  body.chat-fullscreen .bubble.user {
    width: calc(100% - 12px) !important;
    max-width: calc(100% - 12px) !important;
    margin-left: 6px !important;
    margin-right: 6px !important;
  }

  body.chat-fullscreen .search-chat-row {
    margin-top: 2px !important;
    margin-bottom: 2px !important;
  }

  body.chat-fullscreen .chat-model-menu {
    z-index: 2147483649 !important;
    position: fixed !important;
    left: 2px !important;
    right: 2px !important;
    width: auto !important;
    max-width: none !important;
    max-height: 60svh !important;
  }

  body.chat-fullscreen .chat-model-menu .model-menu-list {
    overflow-y: auto !important;
    overscroll-behavior: contain !important;
  }

  body.chat-mode:not(.mini-mode) .chat-stream {
    padding-top: 8px !important;
  }

  body.mini-mode .mini-chat {
    left: 0 !important;
    right: 0 !important;
    width: 100vw !important;
    max-width: 100vw !important;
    transform: none !important;
  }

  body.mini-mode .mini-chat .mini-controls {
    right: 8px !important;
    bottom: calc(100% + 8px) !important;
    top: auto !important;
    height: auto !important;
    grid-auto-flow: column !important;
    gap: 8px !important;
    z-index: 80 !important;
  }

  body.chat-fullscreen .fullscreen-login-btn {
    min-width: 0 !important;
    height: 39px !important;
    padding: 10px 16px !important;
    border-radius: var(--radius-ios) !important;
    color: #fff !important;
    background: linear-gradient(135deg, var(--green), var(--green-dark)) !important;
    font-size: 14px !important;
    font-weight: 800 !important;
    line-height: 1 !important;
    box-shadow: none !important;
  }
}

/* mobile mini-chat expand upward lock 2026-05-13 */
@media (max-width: 1024px) and (orientation: portrait) {
  .mini-chat,
  body.mini-mode .mini-chat,
  body.mini-mode .mini-chat.compact,
  body.mini-mode .mini-chat:not(.compact) {
    top: auto !important;
    left: 50% !important;
    right: auto !important;
    bottom: calc(8px + env(safe-area-inset-bottom, 0px)) !important;
    transform: translateX(-50%) !important;
    width: min(720px, calc(100vw - 16px)) !important;
    max-width: calc(100vw - 16px) !important;
    margin: 0 !important;
    border-radius: var(--radius-ios) !important;
  }

  body.mini-mode .mini-chat:not(.compact) {
    height: min(62svh, 520px) !important;
    transform: translateX(-50%) !important;
  }

  body.mini-mode .mini-chat:not(.compact) .mini-body {
    display: grid !important;
    grid-template-rows: minmax(0, 1fr) auto !important;
    align-items: stretch !important;
    height: 100% !important;
    min-height: 0 !important;
    gap: 8px !important;
  }

  body.mini-mode .mini-chat:not(.compact) .mini-stream {
    min-height: 0 !important;
    overflow-y: auto !important;
    overflow-x: hidden !important;
    padding: 0 2px 0 0 !important;
    margin: 0 !important;
  }

  body.mini-mode .mini-chat:not(.compact) .mini-input-row {
    position: sticky !important;
    bottom: 0 !important;
    left: 0 !important;
    right: 0 !important;
    margin: 0 !important;
    z-index: 5 !important;
  }
}

/* mobile interaction polish 2026-05-15 */
@media (max-width: 1024px) and (orientation: portrait) {
  .nav-actions {
    gap: 8px !important;
    margin-left: 0 !important;
  }

  #mobileMenuToggle,
  .mobile-menu-toggle {
    margin: 0 0 0 auto !important;
    transform: none;
  }

  .composer-input-row {
    grid-template-columns: 36px minmax(0, 1fr) max-content !important;
    align-items: center !important;
  }

  .image-generation-panel {
    max-width: 100% !important;
    margin-left: 0 !important;
  }

  .send-inline-btn,
  #sendBtn.send-inline-btn {
    width: auto !important;
    min-width: max-content !important;
    max-width: 36vw !important;
    height: auto !important;
    min-height: 40px !important;
    padding: 0 16px !important;
    white-space: nowrap !important;
    justify-self: end !important;
    font-size: 15px !important;
    line-height: 1 !important;
  }
}

@media (min-width: 769px) and (max-width: 1024px) and (orientation: portrait) {
  .search-chat-box .chat-model-picker,
  .search-chat-box .model-version-picker {
    width: 100% !important;
    max-width: 100% !important;
  }

  .search-chat-box .chat-model-btn,
  .search-chat-box .model-version-btn {
    width: 100% !important;
    max-width: none !important;
    min-height: 50px !important;
  }
}

@media (max-width: 768px) and (orientation: portrait) {
  .auth-modal {
    position: fixed !important;
    inset: 0 !important;
    display: grid !important;
    place-items: center !important;
    padding: max(12px, env(safe-area-inset-top, 0px)) 14px max(12px, env(safe-area-inset-bottom, 0px)) !important;
    overflow: hidden !important;
  }

  .auth-card {
    box-sizing: border-box !important;
    display: grid !important;
    align-content: center !important;
    gap: clamp(10px, 2.8vw, 14px) !important;
    width: min(100%, 420px) !important;
    max-height: calc(100svh - 28px) !important;
    margin: auto !important;
    overflow: auto !important;
    padding: clamp(16px, 4.2vw, 22px) !important;
    border-radius: var(--radius-ios) !important;
    transform-origin: center !important;
    text-align: center !important;
    overscroll-behavior: contain !important;
  }

  .auth-close {
    top: 12px !important;
    right: 12px !important;
    width: clamp(32px, 9vw, 42px) !important;
    height: clamp(32px, 9vw, 42px) !important;
    font-size: clamp(20px, 6vw, 28px) !important;
  }

  .auth-copy {
    display: grid !important;
    justify-items: center !important;
    gap: 6px !important;
    padding-inline: 22px !important;
  }

  .auth-copy h2 {
    margin: 0 !important;
    max-width: 100% !important;
    font-size: clamp(24px, 7vw, 32px) !important;
    line-height: 1.15 !important;
  }

  .auth-copy p:not(.eyebrow),
  .auth-note,
  .auth-oauth p {
    max-width: 100% !important;
    margin: 0 !important;
    font-size: clamp(13px, 3.7vw, 16px) !important;
    line-height: 1.45 !important;
    overflow-wrap: anywhere !important;
  }

  .auth-tabs {
    margin: 4px 0 0 !important;
    padding: 6px !important;
    gap: 6px !important;
  }

  .auth-tab,
  .auth-submit,
  .auth-code-btn,
  .oauth-btn {
    min-height: clamp(44px, 12vw, 54px) !important;
    font-size: clamp(15px, 4.2vw, 18px) !important;
    white-space: nowrap !important;
  }

  .auth-form {
    gap: clamp(9px, 2.6vw, 12px) !important;
    text-align: left !important;
  }

  .auth-form label {
    gap: 6px !important;
    font-size: clamp(13px, 3.6vw, 15px) !important;
  }

  .auth-form input {
    min-height: clamp(44px, 12vw, 54px) !important;
    padding-inline: 14px !important;
    font-size: clamp(14px, 4vw, 17px) !important;
  }

  .auth-code-row {
    grid-template-columns: minmax(0, 1fr) minmax(92px, 34vw) !important;
  }

  .auth-oauth {
    gap: 8px !important;
    margin-top: 2px !important;
  }
}

body.chat-fullscreen .attach-menu-panel {
  z-index: 2147483651;
}

body.chat-fullscreen .repo-connect-modal {
  z-index: 2147483652;
}

@media (max-width: 768px) and (orientation: portrait) {
  .more-model-menu,
  .chat-model-menu,
  .mini-model-menu,
  .model-version-menu {
    left: 0 !important;
    right: auto !important;
    z-index: 2147483647 !important;
    width: 100vw !important;
    max-width: 100vw !important;
    max-height: min(82svh, 720px) !important;
    padding: 12px !important;
    overscroll-behavior: contain !important;
  }

  body.model-menu-open {
    overflow: hidden !important;
  }

  .chat-model-menu {
    position: fixed !important;
    bottom: auto !important;
    transform-origin: left top !important;
  }

  .more-model-menu {
    position: fixed !important;
    bottom: auto !important;
    transform-origin: left top !important;
  }

  .model-menu-list {
    grid-template-columns: 1fr !important;
    max-height: min(66svh, 620px) !important;
    gap: 10px !important;
  }

  .more-model-menu .model-menu-list,
  .chat-model-menu .model-menu-list {
    max-height: none !important;
    overflow-y: auto !important;
    overscroll-behavior: contain !important;
    padding-right: 6px !important;
  }

  .more-model-option,
  .chat-model-option,
  .mini-model-option {
    flex-wrap: nowrap !important;
    min-height: 58px !important;
    height: auto !important;
    align-content: center !important;
    padding: 10px 12px !important;
    white-space: normal !important;
    line-height: 1.18 !important;
    overflow-wrap: anywhere !important;
  }

  .more-model-option .model-option-name,
  .chat-model-option .model-option-name,
  .mini-model-option .model-option-name {
    flex: 1 1 96px !important;
    min-width: 0 !important;
    white-space: normal !important;
    line-height: 1.18 !important;
    overflow-wrap: anywhere !important;
  }

  .more-model-option .model-hot-badge,
  .chat-model-option .model-hot-badge,
  .mini-model-option .model-hot-badge,
  .more-model-option .aggregate-badge,
  .chat-model-option .aggregate-badge,
  .mini-model-option .aggregate-badge {
    flex: 0 0 auto !important;
    max-width: 100% !important;
    white-space: nowrap !important;
    line-height: 1 !important;
  }

  .more-model-option .model-country,
  .chat-model-option .model-country,
  .mini-model-option .model-country {
    flex: 0 0 auto !important;
    margin-left: 0 !important;
    white-space: nowrap !important;
  }

  .model-version-option {
    grid-template-columns: minmax(0, 1fr) !important;
    width: 100% !important;
    height: auto !important;
    min-height: 0 !important;
  }

  .model-version-option .model-version-badges {
    display: inline-flex !important;
    width: fit-content !important;
    min-width: 0 !important;
    flex-wrap: wrap !important;
    overflow: visible !important;
  }

  .model-version-option .model-version-price {
    grid-column: 1 / -1 !important;
    width: 100% !important;
  }

  .ai-launcher {
    width: 44px !important;
    height: 44px !important;
    min-height: 44px !important;
  }

  body.launcher-mode .ai-launcher {
    opacity: 1 !important;
    transform: translateY(0) scale(1) !important;
  }

  .ai-launcher::before,
  .ai-launcher::after {
    top: 14px !important;
    width: 5px !important;
    height: 5px !important;
  }

  .ai-launcher::before {
    left: 14px !important;
  }

  .ai-launcher::after {
    right: 14px !important;
  }

  .ai-launcher span {
    transform: translateY(6px) !important;
    font-size: 11px !important;
  }
}

@media (max-width: 768px) and (orientation: portrait) and (max-height: 759px) {
  .more-model-menu,
  .chat-model-menu,
  .mini-model-menu,
  .model-version-menu {
    max-height: calc(100svh - 8px) !important;
  }

  .model-menu-list {
    max-height: calc(100svh - 96px) !important;
  }
}

@media (max-width: 768px) and (orientation: portrait) {
  body.chat-mode:not(.chat-fullscreen) .hero {
    z-index: 39 !important;
  }

  body.chat-mode:not(.chat-fullscreen) #directory,
  body.chat-mode:not(.chat-fullscreen) #toolGrid {
    position: relative;
    z-index: 0 !important;
  }

  body.chat-mode:not(.chat-fullscreen) .tool-card .app-icon,
  body.chat-mode:not(.chat-fullscreen) .tool-card .favorite-btn {
    z-index: 0 !important;
  }

  body.chat-mode:not(.mini-mode):not(.chat-fullscreen) .hero-console {
    top: 0 !important;
    bottom: 0 !important;
    z-index: 35 !important;
    grid-template-rows: minmax(0, 1fr) auto !important;
    gap: 0 !important;
    align-content: stretch !important;
    padding: 0 !important;
    max-height: none !important;
  }

  body.chat-mode:not(.mini-mode):not(.chat-fullscreen) .chat-stream {
    align-self: stretch !important;
    width: 100% !important;
    height: 100% !important;
    max-height: none !important;
    margin: 0 !important;
    padding: 0 !important;
    border-top: 0 !important;
    border-radius: 0 !important;
  }

  body.chat-mode:not(.mini-mode):not(.chat-fullscreen) .search-chat-row,
  body.chat-mode:not(.mini-mode):not(.chat-fullscreen) .search-chat-box {
    margin-top: 0 !important;
    margin-bottom: 0 !important;
  }

  body.chat-mode:not(.mini-mode):not(.chat-fullscreen) .hero-bg {
    background: linear-gradient(180deg, #07111f 0%, #0f2232 52%, #07111f 100%) !important;
  }

  body.chat-mode:not(.mini-mode):not(.chat-fullscreen) .hero-bg::after {
    background:
      linear-gradient(rgba(255, 255, 255, 0.035) 1px, transparent 1px),
      linear-gradient(90deg, rgba(255, 255, 255, 0.035) 1px, transparent 1px),
      linear-gradient(to bottom, transparent 0 66%, #f6f9fc 100%) !important;
    background-size: 44px 44px, 44px 44px, auto !important;
  }
}

:is(body, .topbar, .search-chat-box, .quick-prompts, .filter-row, .scene-buttons, .chat-side-controls, .model-bar, .model-pills, .mini-chat, .auth-modal, .custom-model-modal, .quota-modal, .support-widget) :is(
  button,
  [role="button"],
  .button,
  .nav-cta,
  .tool-link,
  .start-chat,
  .model-pill,
  .more-model-option,
  .chat-model-option,
  .model-version-option,
  .support-attachment-chip.button,
  .site-notice-button,
  .badge,
  .tag,
  .ad-badge,
  .ad-tag,
  .model-hot-badge,
  .aggregate-badge,
  .model-version-badge,
  .model-version-price-chip,
  .filter-count,
  .api-cards span,
  .tools-interface-grid span,
  .api-flow b,
  .quota-ad-badge,
  .quota-product-groups span,
  .site-notice-mention,
  .model-menu-category-count,
  .attachment-chip,
  .repository-inline-badge,
  .support-bubble-attachments .support-attachment-chip
) {
  border-radius: var(--radius-control) !important;
}

:is(body, .topbar, .search-chat-box, .quick-prompts, .filter-row, .scene-buttons, .chat-side-controls, .model-bar, .model-pills, .mini-chat, .auth-modal, .custom-model-modal, .quota-modal, .support-widget) :is(
  .badge,
  .tag,
  .ad-badge,
  .ad-tag,
  .model-hot-badge,
  .aggregate-badge,
  .model-version-badge,
  .model-version-price-chip,
  .filter-count,
  .api-cards span,
  .tools-interface-grid span,
  .api-flow b,
  .quota-ad-badge,
  .quota-product-groups span,
  .site-notice-mention,
  .model-menu-category-count,
  .attachment-chip,
  .repository-inline-badge,
  .support-bubble-attachments .support-attachment-chip
) {
  align-items: center !important;
  border-radius: var(--radius-label) !important;
  justify-content: center !important;
  text-align: center !important;
}

:where(
  .country-flag,
  .country-flag img,
  .country-badge .country-flag > img,
  .model-pill .country-flag > img,
  .more-model-option .country-flag > img,
  .chat-model-btn .country-flag > img,
  .chat-model-option .country-flag > img,
  .mini-model-option .country-flag > img,
  .tool-card .country-flag > img
) {
  border-radius: var(--radius-flag) !important;
  overflow: hidden;
}

:where(
  .brand-mark,
  .language-flag,
  .user-avatar,
  .user-avatar-small,
  .user-panel-avatar,
  .fullscreen-avatar-btn .user-avatar-small,
  .avatar,
  .mini-avatar,
  .mini-avatar img,
  .app-icon,
  .brand-icon-clean,
  .tool-icon,
  .tool-logo,
  .tool-avatar,
  .ai-icon,
  .model-icon,
  .model-logo,
  .model-avatar,
  .model-pill-icon,
  .model-pill-avatar,
  .model-menu-icon,
  .model-menu-avatar,
  .chat-model-icon,
  .chat-model-avatar,
  .ai-launcher span,
  [data-ai-model-icon],
  [data-brand-icon]
) {
  border-radius: var(--radius-icon) !important;
  overflow: hidden;
}

:where(
  .attachment-chip,
  .attachment-preview,
  .attachment-preview img,
  .bubble-attachment-preview,
  .bubble-attachment-preview img,
  .site-notice-media img,
  .site-notice-media video,
  .support-selected-attachment,
  .support-selected-attachment img,
  .support-image-preview img
) {
  border-radius: var(--radius-icon) !important;
  overflow: hidden;
}

.attachment-chip,
.attachment-preview {
  --attachment-thumb-radius: var(--radius-icon);
  clip-path: inset(0 round var(--radius-icon)) !important;
}

@media (max-width: 1024px) and (orientation: portrait) {
  body.mini-mode .hero-console {
    opacity: 0 !important;
    visibility: hidden !important;
    pointer-events: none !important;
  }

  .mini-chat,
  body.mini-mode .mini-chat,
  body.mini-mode .mini-chat.compact,
  body.mini-mode .mini-chat:not(.compact) {
    top: auto !important;
    left: 50% !important;
    right: auto !important;
    bottom: calc(8px + env(safe-area-inset-bottom, 0px)) !important;
    width: min(720px, calc(100vw - 16px)) !important;
    max-width: calc(100vw - 16px) !important;
    height: var(--mini-compact-height) !important;
    min-height: var(--mini-compact-height) !important;
    margin: 0 !important;
    border-radius: var(--radius-ios) !important;
    transform: translateX(-50%) !important;
    transition: none !important;
    animation: none !important;
    will-change: auto !important;
  }

  .mini-model-menu {
    position: fixed !important;
    transform: translateY(0) scale(0.98) !important;
  }

  .mini-chat.model-open .mini-model-menu,
  .mini-model-menu.open {
    transform: translateY(0) scale(1) !important;
  }

  body.mini-mode .mini-chat:not(.compact) .mini-stream,
  .mini-chat .mini-stream {
    display: none !important;
  }

  .mini-chat .mini-body,
  body.mini-mode .mini-chat:not(.compact) .mini-body {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    height: 100% !important;
  }

  .mini-chat .mini-expand {
    display: none !important;
  }
}

@media (max-width: 768px) and (orientation: portrait) {
  .user-system-page,
  .api-panel {
    width: calc(100vw - 16px) !important;
    gap: 10px !important;
    margin-bottom: 18px !important;
  }

  .user-system-head,
  .api-panel {
    grid-template-columns: 1fr !important;
    padding: 12px !important;
  }

  .user-system-head {
    display: grid !important;
  }

  .user-system-head h2,
  .api-panel h2 {
    font-size: clamp(24px, 8vw, 34px) !important;
  }

  .user-system-actions {
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    justify-content: stretch !important;
    width: 100% !important;
  }

  .user-system-actions button,
  .user-system-recharge,
  .user-system-api-key {
    width: 100% !important;
    min-width: 0 !important;
    padding: 0 10px !important;
  }

  .user-system-stats {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }

  .user-system-grid,
  .user-api-key-row,
  .user-api-key-limits,
  .user-api-key-usage-stats,
  .user-api-key-usage-record {
    grid-template-columns: 1fr !important;
  }

  .user-system-grid section,
  .user-api-key-section,
  .user-api-key-item {
    min-width: 0 !important;
  }

  .user-api-key-section-head {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 8px !important;
  }

  .user-api-key-section-head button,
  .user-api-key-actions {
    width: 100% !important;
  }

  .user-api-key-actions {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }

  .api-workbench {
    padding: 10px !important;
  }

  .api-panel {
    padding: 0 !important;
    border: 0 !important;
    border-radius: 0 !important;
    background: transparent !important;
  }

  .api-flow,
  .api-cards {
    grid-template-columns: 1fr !important;
  }

  .api-code-card code {
    white-space: normal !important;
    overflow-wrap: anywhere !important;
  }

  .api-model-page .api-workbench-head {
    padding: 12px !important;
  }

  .api-promo-copy,
  .api-account-summary {
    grid-row: auto !important;
  }

  .api-model-page .api-promo-copy > span {
    font-size: clamp(26px, 10vw, 36px) !important;
  }

  .api-account-summary {
    justify-self: stretch !important;
    width: 100% !important;
  }

  .api-model-market {
    grid-template-columns: 1fr !important;
    gap: 10px !important;
    padding: 10px !important;
    margin-bottom: 18px !important;
  }

  .api-model-page .api-provider-list {
    max-height: 730px !important;
    overflow-y: auto !important;
    overscroll-behavior: contain !important;
  }

  .api-provider-item {
    grid-template-columns: 44px minmax(0, 1fr) !important;
    padding-inline: 12px !important;
  }

  .api-provider-name-row {
    gap: 8px !important;
  }

  .api-version-item {
    padding-inline: 12px !important;
  }

  .api-model-page .api-version-list {
    max-height: none !important;
  }

  .api-version-list-head {
    display: grid !important;
    grid-template-columns: 1fr !important;
  }

  .api-version-sortbar {
    display: grid !important;
    grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
    gap: 6px !important;
    justify-self: stretch !important;
    margin-left: 0 !important;
  }

  .api-version-sort {
    flex: 1 1 0 !important;
    min-width: 0 !important;
    padding: 0 8px !important;
    font-size: clamp(10px, 2.85vw, 13px) !important;
    line-height: 1 !important;
    white-space: nowrap !important;
  }

  .user-panel {
    position: fixed !important;
    top: calc(78px + env(safe-area-inset-top, 0px)) !important;
    right: auto !important;
    left: 50% !important;
    width: min(340px, calc(100vw - 24px)) !important;
    min-width: 0 !important;
    max-width: none !important;
    max-height: calc(var(--mobile-visual-height, 100dvh) - 96px) !important;
    overflow-y: auto !important;
    overscroll-behavior: contain !important;
    transform: translateX(-50%) translateY(8px) scale(0.98) !important;
  }

  .user-menu.open .user-panel {
    transform: translateX(-50%) translateY(0) scale(1) !important;
  }

  .fullscreen-user-panel {
    position: fixed !important;
    top: calc(78px + env(safe-area-inset-top, 0px)) !important;
    right: auto !important;
    left: 50% !important;
    width: min(340px, calc(100vw - 24px)) !important;
    min-width: 0 !important;
    max-width: none !important;
    max-height: calc(var(--mobile-visual-height, 100dvh) - 96px) !important;
    padding: 12px !important;
    overflow-y: auto !important;
    overscroll-behavior: contain !important;
    transform: translateX(-50%) !important;
  }

  .fullscreen-user-panel .user-panel-card h3 {
    font-size: clamp(20px, 7vw, 30px) !important;
  }

  .fullscreen-user-panel .user-panel-head {
    display: grid !important;
    grid-template-columns: 52px minmax(0, 1fr) !important;
    gap: 10px !important;
  }

  .fullscreen-user-panel .user-panel-avatar {
    width: 52px !important;
    height: 52px !important;
    flex-basis: 52px !important;
  }

  .fullscreen-user-panel .user-stats {
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  }

  .fullscreen-user-panel .user-panel-actions {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }

  .quota-recharge-page .quota-card {
    display: block !important;
    width: 100vw !important;
    min-height: 0 !important;
    max-height: none !important;
    padding: 14px !important;
    border: 0 !important;
    border-radius: 0 !important;
    overflow: visible !important;
    overscroll-behavior: contain !important;
    background:
      linear-gradient(180deg, rgba(11, 55, 90, 0.96), rgba(15, 67, 103, 0.96)),
      #0f3f61 !important;
    box-shadow: none !important;
    backdrop-filter: none !important;
  }

  .quota-modal.quota-recharge-page {
    height: 100dvh !important;
    max-height: 100dvh !important;
    place-items: stretch !important;
    padding: 0 !important;
    overflow-x: hidden !important;
    overflow-y: auto !important;
    overscroll-behavior: contain !important;
    scrollbar-gutter: stable !important;
    background: #0f3f61 !important;
  }

  html:has(.quota-modal.show),
  body:has(.quota-modal.show) {
    overflow: hidden !important;
  }

  .quota-recharge-page .quota-card h2 {
    margin-right: 42px !important;
    font-size: clamp(22px, 7vw, 28px) !important;
  }

  .quota-recharge-page .quota-card > p:not(.eyebrow) {
    white-space: normal !important;
  }

  .quota-recharge-page .quota-preview,
  .quota-recharge-layout,
  .quota-custom-recharge,
  .quota-payment-methods {
    display: grid !important;
    grid-template-columns: 1fr !important;
    height: auto !important;
    min-height: 0 !important;
    overflow: visible !important;
  }

  .quota-recharge-left,
  .quota-recharge-right {
    height: auto !important;
    min-height: 0 !important;
    padding: 10px !important;
    overflow: visible !important;
  }

  .quota-mode-tabs,
  .quota-crypto-methods {
    grid-template-columns: 1fr !important;
  }

  .quota-wallet-popover {
    right: auto !important;
    left: 0 !important;
    width: 100% !important;
  }

  .quota-crypto-select-menu {
    right: 0 !important;
    left: 0 !important;
    width: 100% !important;
  }

  .quota-recharge-left .quota-product-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }

  #aiQuery,
  #miniQuery {
    font-size: max(16px, var(--hero-input-font-size, 16px)) !important;
  }

  #supportInput {
    font-size: 16px !important;
  }

  #aiQuery.is-empty {
    min-height: 44px !important;
    padding-top: 0 !important;
    padding-bottom: 0 !important;
    font-size: 16px !important;
    line-height: 44px !important;
    text-align: center !important;
    white-space: nowrap !important;
  }

  body.mobile-input-focus,
  body.support-input-focus {
    width: 100% !important;
    overflow-y: hidden !important;
    overflow-x: hidden !important;
  }

  body.mobile-input-focus .hero-console {
    position: fixed !important;
    left: 0 !important;
    right: 0 !important;
    top: auto !important;
    bottom: 0 !important;
    width: 100% !important;
    max-width: 100% !important;
    max-height: var(--mobile-visual-height, 100svh) !important;
    padding: 0 !important;
    transform: translate3d(0, calc(var(--mobile-keyboard-inset, 0px) * -1), 0) !important;
    isolation: isolate !important;
    z-index: 2147483654 !important;
    pointer-events: auto !important;
    transition: none !important;
    will-change: transform !important;
  }

  body.mobile-input-focus.chat-mode:not(.mini-mode):not(.chat-fullscreen) .hero-console {
    top: auto !important;
    bottom: 0 !important;
    grid-template-rows: auto !important;
    align-content: end !important;
    z-index: 2147483647 !important;
  }

  body.mobile-input-focus .search-chat-row,
  body.mobile-input-focus .search-chat-box,
  body.mobile-input-focus .composer-input-shell {
    position: relative !important;
    z-index: 2147483655 !important;
    margin-bottom: 0 !important;
    padding-bottom: 0 !important;
    transition: none !important;
  }

  body.mobile-input-focus .scroll-dock,
  body.mobile-input-restoring .scroll-dock {
    display: none !important;
  }

  body.mobile-input-focus.mini-mode .mini-chat,
  body.mobile-input-focus.mini-mode .mini-chat.compact,
  body.mobile-input-focus.mini-mode .mini-chat:not(.compact) {
    bottom: 0 !important;
    transform: translate3d(-50%, calc(var(--mobile-keyboard-inset, 0px) * -1), 0) !important;
    transition: none !important;
    will-change: transform !important;
  }

  body.support-input-focus .support-widget.open,
  body.support-input-focus .support-widget.open.support-widget-positioned {
    top: auto !important;
    bottom: var(--mobile-keyboard-inset, 0px) !important;
    height: var(--mobile-visual-height, 100svh) !important;
    max-height: var(--mobile-visual-height, 100svh) !important;
  }

  body.support-input-focus .support-widget.open .support-panel {
    height: 100% !important;
    max-height: 100% !important;
  }
}

@media (max-width: 1024px) and (orientation: portrait) {
  body.chat-fullscreen .hero,
  body.chat-fullscreen .hero-console,
  body.mobile-input-focus.chat-fullscreen .hero-console {
    position: fixed !important;
    inset: 0 !important;
    left: 0 !important;
    right: 0 !important;
    top: 0 !important;
    bottom: 0 !important;
    width: 100vw !important;
    max-width: 100vw !important;
    height: var(--mobile-visual-height, 100dvh) !important;
    max-height: var(--mobile-visual-height, 100dvh) !important;
    margin: 0 !important;
    transform: none !important;
    z-index: 2147483647 !important;
  }
}

body.chat-fullscreen .hero-console {
  padding-bottom: 18px !important;
}

body.chat-fullscreen .search-chat-row,
body.chat-fullscreen .search-chat-box {
  margin-bottom: 0 !important;
}

body.chat-fullscreen .search-chat-row {
  padding-bottom: 0 !important;
}

:where(.language-menu, .user-panel, .fullscreen-user-panel, .fullscreen-settings-panel, .mobile-menu-panel, .more-model-menu, .chat-model-menu, .mini-model-menu, .model-version-menu, .image-generation-menu, .attach-menu-panel, .country-hover-tip, .support-widget.open) {
  z-index: 2147483656 !important;
}

html.config-ready #globalLoadingOverlay {
  opacity: 0 !important;
  visibility: hidden !important;
  pointer-events: none !important;
}

body.chat-fullscreen .fullscreen-utility-bar,
body.chat-fullscreen :where(.fullscreen-user-panel, .fullscreen-settings-panel, .more-model-menu, .chat-model-menu, .mini-model-menu, .model-version-menu, .image-generation-menu, .attach-menu-panel, .support-widget.open) {
  z-index: 2147483656 !important;
}

body.chat-fullscreen .chat-side-controls {
  gap: 22px !important;
}

:where(.auth-modal, .custom-model-modal, .quota-modal, .site-notice-modal, .repo-connect-modal, .support-image-preview) {
  z-index: 2147483655 !important;
}

:root {
  --floating-action-size: clamp(34px, 3.2vw, 42px);
  --floating-action-right: calc(clamp(10px, 1.35vw, 20px) + clamp(5px, 0.7vw, 8px));
  --floating-action-bottom: clamp(12px, 1.5vw, 22px);
  --floating-action-pad: clamp(5px, 0.7vw, 8px);
  --floating-action-dock-gap: clamp(6px, 0.7vw, 10px);
  --floating-action-gap: 12px;
}

.scroll-dock {
  right: calc(var(--floating-action-right) - var(--floating-action-pad)) !important;
  bottom: var(--floating-action-bottom) !important;
  gap: var(--floating-action-dock-gap) !important;
  padding: var(--floating-action-pad) !important;
}

.scroll-dock button,
.ai-launcher,
.support-launcher {
  width: var(--floating-action-size) !important;
  height: var(--floating-action-size) !important;
  min-width: var(--floating-action-size) !important;
  min-height: var(--floating-action-size) !important;
  border-radius: var(--radius-ios) !important;
}

.ai-launcher::before,
.ai-launcher::after {
  top: calc(var(--floating-action-size) * 0.31) !important;
  width: calc(var(--floating-action-size) * 0.12) !important;
  height: calc(var(--floating-action-size) * 0.12) !important;
}

.ai-launcher::before {
  left: calc(var(--floating-action-size) * 0.31) !important;
}

.ai-launcher::after {
  right: calc(var(--floating-action-size) * 0.31) !important;
}

.ai-launcher span {
  max-width: calc(var(--floating-action-size) - 8px);
  overflow: hidden;
  font-size: clamp(10px, calc(var(--floating-action-size) * 0.27), 15px) !important;
  line-height: 1;
  transform: translateY(calc(var(--floating-action-size) * 0.15)) !important;
}

.ai-launcher,
body.scroll-dock-visible.launcher-mode .ai-launcher {
  right: var(--floating-action-right) !important;
  bottom: calc(var(--floating-action-bottom) + var(--floating-action-pad) + var(--floating-action-pad) + var(--floating-action-size) + var(--floating-action-size) + var(--floating-action-dock-gap) + var(--floating-action-gap)) !important;
}

.support-widget:not(.fullscreen):not(.support-widget-positioned) {
  right: var(--floating-action-right) !important;
  bottom: calc(var(--floating-action-bottom) + var(--floating-action-pad) + var(--floating-action-pad) + var(--floating-action-size) + var(--floating-action-size) + var(--floating-action-dock-gap) + var(--floating-action-gap)) !important;
}

body.launcher-mode .support-widget:not(.fullscreen):not(.support-widget-positioned) {
  bottom: calc(var(--floating-action-bottom) + var(--floating-action-pad) + var(--floating-action-pad) + var(--floating-action-size) + var(--floating-action-size) + var(--floating-action-size) + var(--floating-action-dock-gap) + var(--floating-action-gap) + var(--floating-action-gap)) !important;
}

.support-launcher-icon,
.support-launcher-icon svg {
  width: calc(var(--floating-action-size) - 12px) !important;
  height: calc(var(--floating-action-size) - 12px) !important;
}

@media (max-width: 1024px) and (orientation: portrait) {
  :root {
    --floating-action-size: 44px;
    --floating-action-right: 8px;
    --floating-action-bottom: calc(22px + env(safe-area-inset-bottom, 0px));
    --floating-action-pad: 5px;
    --floating-action-dock-gap: 8px;
  }
}

@media (max-width: 1024px) and (orientation: portrait) {
  body.chat-fullscreen .hero-console {
    gap: 0 !important;
  }

  body.chat-fullscreen .search-chat-row {
    align-self: end !important;
  }

  body.chat-fullscreen .composer-input-shell {
    padding-bottom: 0 !important;
  }

  body.chat-fullscreen .chat-stream {
    margin-bottom: 0 !important;
    padding-bottom: 18px !important;
  }

  body.chat-fullscreen .chat-side-controls,
  .chat-side-controls {
    grid-auto-flow: row !important;
    grid-template-columns: 1fr !important;
    gap: var(--floating-action-dock-gap) !important;
  }

  .chat-side-controls button {
    --mini-control-icon-size: clamp(13px, calc(var(--floating-action-size) * 0.36), 17px);
    --mini-control-icon-stroke: max(2px, calc(var(--mini-control-icon-size) * 0.1));
    display: inline-grid !important;
    place-items: center !important;
    width: var(--floating-action-size) !important;
    height: var(--floating-action-size) !important;
    min-width: var(--floating-action-size) !important;
    min-height: var(--floating-action-size) !important;
    padding: 0 !important;
  }

  .expand-chat-btn::before,
  .fullscreen-chat-btn::before {
    left: 50% !important;
    top: 50% !important;
    transform: translate(-50%, -50%) rotate(45deg) !important;
  }

  .expand-chat-btn.active::before {
    transform: translate(-50%, -50%) rotate(225deg) !important;
  }

  .fullscreen-chat-btn::before {
    transform: translate(-50%, -50%) !important;
  }

  .fullscreen-chat-btn.active::before {
    transform: translate(-50%, -50%) rotate(45deg) !important;
  }

  .support-widget:not(.fullscreen):not(.support-widget-positioned),
  body.launcher-mode .support-widget:not(.fullscreen):not(.support-widget-positioned) {
    right: var(--floating-action-right) !important;
    bottom: calc(var(--floating-action-bottom) + var(--floating-action-size) + var(--floating-action-dock-gap) + var(--floating-action-gap)) !important;
  }

  body.chat-mode .support-widget:not(.fullscreen):not(.support-widget-positioned) {
    bottom: calc(var(--floating-action-bottom) + var(--floating-action-size) + var(--floating-action-size) + var(--floating-action-size) + var(--floating-action-size) + var(--floating-action-dock-gap) + var(--floating-action-dock-gap) + var(--floating-action-dock-gap) + var(--floating-action-gap)) !important;
  }

  body.mobile-input-focus .support-widget:not(.open):not(.fullscreen),
  body.mobile-input-restoring .support-widget:not(.open):not(.fullscreen) {
    display: none !important;
  }
}

@media (max-width: 1024px) and (orientation: portrait) {
  body.chat-fullscreen .hero-console,
  body.chat-fullscreen.chat-mode:not(.mini-mode) .hero-console {
    position: fixed !important;
    overflow: hidden !important;
  }

  body.chat-fullscreen .chat-stream {
    position: absolute !important;
    inset: 0 !important;
    z-index: 0 !important;
    width: 100vw !important;
    height: 100% !important;
    max-height: 100% !important;
    margin: 0 !important;
    padding-top: 74px !important;
    padding-bottom: calc(164px + env(safe-area-inset-bottom, 0px)) !important;
    overflow-y: auto !important;
  }

  body.chat-fullscreen .search-chat-row {
    position: relative !important;
    z-index: 2 !important;
    display: flex !important;
    flex-wrap: wrap !important;
    align-items: center !important;
    gap: 8px !important;
  }

  body.chat-fullscreen .search-chat-box {
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr) !important;
    column-gap: 8px !important;
    row-gap: 8px !important;
    align-items: stretch !important;
  }

  body.chat-fullscreen .chat-model-picker,
  body.chat-fullscreen .model-version-picker {
    grid-column: auto !important;
    width: 100% !important;
    max-width: 100% !important;
  }

  body.chat-fullscreen .chat-model-btn,
  body.chat-fullscreen .model-version-btn {
    width: 100% !important;
    max-width: none !important;
    min-height: 50px !important;
  }

  body.chat-fullscreen .composer-input-shell {
    grid-column: 1 / -1 !important;
    min-height: 54px !important;
    padding: 6px !important;
  }

  body.chat-fullscreen .composer-input-row {
    grid-template-columns: 36px minmax(0, 1fr) max-content !important;
    gap: 6px !important;
  }

  body.chat-fullscreen #sendBtn.send-inline-btn {
    align-self: center !important;
    min-height: 40px !important;
    height: 40px !important;
  }

  body.chat-fullscreen #aiQuery,
  body.chat-fullscreen #aiQuery:not(.is-empty) {
    min-height: 44px !important;
    padding: var(--hero-input-padding-y, 11px) 10px !important;
    font-size: max(16px, var(--hero-input-font-size, 16px)) !important;
    line-height: 1.55 !important;
  }

  body.chat-fullscreen #aiQuery.is-empty {
    min-height: 44px !important;
    padding-top: 0 !important;
    padding-bottom: 0 !important;
    font-size: 16px !important;
    line-height: 44px !important;
    text-align: center !important;
    white-space: nowrap !important;
  }

  body.mobile-input-focus.chat-fullscreen .hero-console {
    top: auto !important;
    bottom: 0 !important;
    height: var(--mobile-visual-height, 100svh) !important;
    max-height: var(--mobile-visual-height, 100svh) !important;
    transform: translate3d(0, calc(var(--mobile-keyboard-inset, 0px) * -1), 0) !important;
    transition: none !important;
    will-change: transform !important;
  }
}

@media (max-width: 1024px) and (orientation: portrait) {
  body.chat-fullscreen .hero,
  body.chat-fullscreen .hero-console,
  body.mobile-input-focus.chat-fullscreen .hero-console {
    background: transparent !important;
    backdrop-filter: none !important;
    box-shadow: none !important;
  }

  body.chat-fullscreen .hero-console,
  body.chat-fullscreen.chat-mode:not(.mini-mode) .hero-console {
    padding: 0 !important;
  }

  body.chat-fullscreen .chat-stream {
    grid-area: 1 / 1 / -1 / -1 !important;
    inset: 0 !important;
    height: 100% !important;
    border: 0 !important;
    background: rgba(15, 23, 42, 0.36) !important;
    backdrop-filter: blur(18px) !important;
    box-shadow: var(--shadow) !important;
    touch-action: pan-y !important;
    overscroll-behavior: contain !important;
    -webkit-overflow-scrolling: touch !important;
  }
}

@media (max-width: 1024px) and (orientation: portrait) {
  .chat-model-menu,
  .model-version-menu,
  .chat-model-menu .model-menu-list {
    overscroll-behavior: contain !important;
    touch-action: pan-y !important;
    -webkit-overflow-scrolling: touch !important;
  }

  .support-widget:not(.fullscreen):not(.support-widget-positioned),
  body.launcher-mode .support-widget:not(.fullscreen):not(.support-widget-positioned) {
    bottom: calc(var(--floating-action-bottom) + var(--floating-action-size) + var(--floating-action-dock-gap) + var(--floating-action-gap) + 36px) !important;
  }

  body.chat-mode .support-widget:not(.fullscreen):not(.support-widget-positioned) {
    bottom: calc(var(--floating-action-bottom) + var(--floating-action-size) + var(--floating-action-size) + var(--floating-action-size) + var(--floating-action-size) + var(--floating-action-dock-gap) + var(--floating-action-dock-gap) + var(--floating-action-dock-gap) + var(--floating-action-gap) + 36px) !important;
  }

  body.mini-mode .ai-launcher {
    opacity: 0 !important;
    transform: translateY(16px) scale(0.82) !important;
    pointer-events: none !important;
  }
}

body.desktop-chat-focus-mode.chat-mode:not(.mini-mode):not(.chat-fullscreen) .chat-stream {
  background: rgba(15, 23, 42, 0.36) !important;
  backdrop-filter: blur(18px) !important;
  -webkit-backdrop-filter: blur(18px) !important;
  box-shadow: var(--shadow) !important;
  overscroll-behavior: contain;
}

@media (min-width: 769px) {
  body.desktop-chat-focus-mode.chat-mode:not(.mini-mode):not(.chat-fullscreen) .hero-console {
    position: fixed !important;
    left: 50% !important;
    right: auto !important;
    top: clamp(14px, 2.2vh, 24px) !important;
    bottom: clamp(10px, 1.8vh, 18px) !important;
    width: min(calc(1040px + var(--hero-control-rail)), calc(100% - var(--page-gutter) - var(--page-gutter))) !important;
    max-height: none !important;
    margin: 0 !important;
    transform: translate3d(-50%, 0, 0) !important;
  }
}

@media (max-width: 1024px) and (orientation: portrait) {
  body.chat-fullscreen .fullscreen-utility-bar {
    position: fixed !important;
    top: calc(8px + env(safe-area-inset-top, 0px)) !important;
    right: 8px !important;
    display: inline-flex !important;
    visibility: visible !important;
    opacity: 1 !important;
    width: auto !important;
    max-width: calc(100vw - 16px) !important;
    z-index: 2147483657 !important;
  }

  body.chat-fullscreen .model-bar {
    position: fixed !important;
    top: calc(58px + env(safe-area-inset-top, 0px)) !important;
    left: 8px !important;
    z-index: 2147483656 !important;
    display: grid !important;
    width: min(286px, calc(100vw - 20px)) !important;
    min-width: 0 !important;
    max-width: min(286px, calc(100vw - 20px)) !important;
    height: auto !important;
    max-height: calc(100dvh - 132px) !important;
    min-height: 0 !important;
    grid-template-columns: 1fr !important;
    grid-template-rows: auto auto minmax(0, 1fr) !important;
    gap: 7px !important;
    margin: 0 !important;
    padding: 8px !important;
    border-width: 1px !important;
    overflow: hidden !important;
  }

  body.chat-fullscreen .fullscreen-primary-tabs,
  body.chat-fullscreen .fullscreen-hot-tabs {
    display: grid !important;
    width: 100% !important;
    max-width: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
    border: 0 !important;
    overflow: visible !important;
  }

  body.chat-fullscreen .model-switcher {
    display: grid !important;
    width: 100% !important;
    max-width: 100% !important;
    height: auto !important;
    min-height: 0 !important;
    margin: 0 !important;
    padding: 0 !important;
    border: 0 !important;
    overflow: hidden !important;
  }

  body.chat-fullscreen .model-pills {
    display: flex !important;
    width: 100% !important;
    max-width: 100% !important;
    height: auto !important;
    max-height: min(40vh, 320px) !important;
    min-height: 0 !important;
    margin: 0 !important;
    padding: 0 4px 0 0 !important;
    border: 0 !important;
    overflow-x: hidden !important;
    overflow-y: auto !important;
  }

  body.chat-fullscreen .more-models {
    display: inline-flex !important;
    width: 100% !important;
    max-width: 100% !important;
    margin: 0 !important;
    overflow: visible !important;
  }
}

body.chat-fullscreen .fullscreen-utility-bar {
  position: fixed !important;
  top: 18px !important;
  right: 18px !important;
  display: inline-flex !important;
  visibility: visible !important;
  opacity: 1 !important;
  pointer-events: auto !important;
  z-index: 2147483657 !important;
}

body.chat-fullscreen .model-bar,
body.chat-fullscreen .chat-stream {
  display: grid !important;
  visibility: visible !important;
  opacity: 1 !important;
  pointer-events: auto !important;
}

body.chat-fullscreen .model-bar {
  z-index: 2147483648 !important;
}

@media (max-width: 1024px) and (orientation: portrait) {
  body.chat-fullscreen .fullscreen-utility-bar {
    top: calc(8px + env(safe-area-inset-top, 0px)) !important;
    right: 8px !important;
  }
}
