:root {
  color-scheme: light;
  --ink: #171717;
  --muted: #7b6671;
  --paper: #fff3f8;
  --panel: #ffffff;
  --line: #efd4df;
  --blush: #ffd8e7;
  --rose: #ec86ad;
  --oxblood: #8b2447;
  --graphite: #2f3437;
  --chrome: #c8ccd0;
  --sage: #dce6df;
  --gold: #b99356;
  --shadow: 0 24px 70px rgba(139, 36, 71, 0.12);
  --neon-rgb: 236, 134, 173;
  --neon-strong-rgb: 139, 36, 71;
  --focus-rgb: 236, 134, 173;
  /* Liquid Glass tokens (iOS 26-style). Drive the .liquid-glass surface system
     at the end of this file. Light themes (rose/blue/fun) share these; noir
     overrides them with a dark translucent tint. */
  --glass-blur: 22px;
  --glass-saturate: 1.8;
  --glass-tint: rgba(255, 255, 255, 0.58);
  --glass-rim: rgba(255, 255, 255, 0.95);
  --glass-edge: rgba(255, 255, 255, 0.55);
  --glass-sheen-1: rgba(255, 255, 255, 0.6);
  --glass-sheen-2: rgba(255, 255, 255, 0.16);
  --glass-drop: rgba(var(--neon-strong-rgb), 0.16);
  --font-ui: "Avenir Next", "SF Pro Text", -apple-system, BlinkMacSystemFont, "Segoe UI", system-ui, sans-serif;
  --font-display: "New York", "Iowan Old Style", "Palatino Linotype", Palatino, ui-serif, serif;
  --radius: 14px;
  --radius-lg: 24px;
  font-family: var(--font-ui);
}

* {
  box-sizing: border-box;
}

body {
  min-height: 100vh;
  margin: 0;
  padding-bottom: calc(104px + env(safe-area-inset-bottom));
  /* Bloco 1 — fundo calmo: cor lisa de --paper. Cada tema (blue/noir/fun)
     redefine --paper, então esta única regra cascateia a cor certa para todos.
     Removidas as 6 camadas de gradiente, as 2 grades repetidas e a animação
     backgroundDrift que competiam com o conteúdo. */
  background: var(--paper);
  color: var(--ink);
}

body[data-theme="blue"] {
  --ink: #101a24;
  --muted: #526b82;
  --paper: #f1f7fc;
  --panel: #ffffff;
  --line: #c8dce9;
  --blush: #d7ebfb;
  --rose: #3d8bd8;
  --oxblood: #0b4f86;
  --graphite: #10283d;
  --chrome: #b5cde0;
  --sage: #dfe9ef;
  --gold: #6c8fb4;
  --shadow: 0 24px 70px rgba(12, 65, 116, 0.16);
  --neon-rgb: 61, 139, 216;
  --neon-strong-rgb: 11, 79, 134;
  --focus-rgb: 61, 139, 216;
  /* Bloco 1 — fundo calmo: herda `body { background: var(--paper) }`; --paper
     já vale #f1f7fc neste tema. */
}

body[data-theme="noir"] {
  color-scheme: dark;
  /* Noir = dark mode NEUTRO: uma única escada de cinzas (base #151517 →
     superfícies #1e1e21 → controles #1a1a1e), texto em cinza neutro e o rose
     da marca reservado a acentos (ativo, CTAs, favorito). Nada de tint plum
     nas superfícies — "apenas escurecer". */
  --ink: #f4f4f6;
  --muted: #a9a9b2;
  --paper: #151517;
  --panel: #1e1e21;
  --line: rgba(255, 255, 255, 0.12);
  --blush: #242428;
  --rose: #ec86ad;
  /* --oxblood vira acento CLARO aqui (é cor de ícone/link/label no dark). */
  --oxblood: #eda3c0;
  --graphite: #0f0f11;
  --chrome: #8f8f98;
  --sage: #242428;
  --gold: #d9b67e;
  --shadow: 0 24px 80px rgba(0, 0, 0, 0.36);
  --neon-rgb: 236, 134, 173;
  /* canal "forte" = oxblood profundo da marca p/ sombras/tints/gradientes
     escuros (era branco — origem dos halos claros que destoavam). */
  --neon-strong-rgb: 139, 36, 71;
  --focus-rgb: 236, 134, 173;
  /* Liquid Glass — tint neutro translúcido; rim discreto (rims fortes eram a
     origem dos "cinzas sem sentido" nas bordas). */
  --glass-tint: rgba(30, 30, 34, 0.62);
  --glass-rim: rgba(255, 255, 255, 0.2);
  --glass-edge: rgba(255, 255, 255, 0.1);
  --glass-sheen-1: rgba(255, 255, 255, 0.07);
  --glass-sheen-2: rgba(255, 255, 255, 0.02);
  --glass-drop: rgba(0, 0, 0, 0.5);
}

body[data-theme="noir"] .capture-panel,
body[data-theme="noir"] .review-panel,
body[data-theme="noir"] .tools-row,
body[data-theme="noir"] .wishlist-switcher,
body[data-theme="noir"] .shared-shell,
body[data-theme="noir"] .shared-detail-panel,
body[data-theme="noir"] .shared-list-card,
body[data-theme="noir"] .shared-item-row,
body[data-theme="noir"] .view-panel,
body[data-theme="noir"] .add-intro,
body[data-theme="noir"] .account-copy,
body[data-theme="noir"] .account-card,
body[data-theme="noir"] .scan-health-panel,
body[data-theme="noir"] .scan-health-metrics > span,
body[data-theme="noir"] .scan-store-row,
body[data-theme="noir"] .scan-recent-row,
body[data-theme="noir"] .metric-grid > span,
body[data-theme="noir"] .list-summary-strip > span,
body[data-theme="noir"] .wishlist-tab,
body[data-theme="noir"] .empty-state,
body[data-theme="noir"] .wish-card,
body[data-theme="noir"] .language-control,
body[data-theme="noir"] .theme-control {
  background:
    linear-gradient(145deg, rgba(255, 255, 255, 0.04), rgba(255, 255, 255, 0)),
    rgba(32, 32, 36, 0.92);
  border-color: rgba(255, 255, 255, 0.1);
  box-shadow: var(--shadow);
}

body[data-theme="noir"] .onboarding-panel,
body[data-theme="noir"] .profile-card,
body[data-theme="noir"] .price-history-detail,
body[data-theme="noir"] .danger-zone,
body[data-theme="noir"] .shared-members-list,
body[data-theme="noir"] .shared-member-chip,
body[data-theme="noir"] .guest-list-notice,
body[data-theme="noir"] .review-notice {
  background:
    linear-gradient(145deg, rgba(255, 255, 255, 0.045), rgba(255, 255, 255, 0.015)),
    rgba(34, 34, 38, 0.94);
  border-color: rgba(255, 255, 255, 0.1);
  color: var(--ink);
}

body[data-theme="noir"] input,
body[data-theme="noir"] select,
body[data-theme="noir"] textarea,
body[data-theme="noir"] .secondary-btn {
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.03), rgba(255, 255, 255, 0)),
    rgba(26, 26, 30, 0.94);
  border-color: rgba(255, 255, 255, 0.16);
  color: var(--ink);
}

body[data-theme="noir"] input::placeholder,
body[data-theme="noir"] textarea::placeholder {
  color: rgba(255, 255, 255, 0.45);
}

body[data-theme="noir"] .primary-btn,
body[data-theme="noir"] .dock-action {
  background: linear-gradient(135deg, #bd5076, #8b2447);
  color: #fff;
  text-shadow: 0 1px 2px rgba(0, 0, 0, 0.28);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.22),
    0 14px 30px rgba(139, 36, 71, 0.42);
}
body[data-theme="noir"] .primary-btn:hover,
body[data-theme="noir"] .dock-action:hover {
  background: linear-gradient(135deg, #c75c82, #9c2a51);
}

body[data-theme="noir"] .section-kicker,
body[data-theme="noir"] .price-line,
body[data-theme="noir"] .shared-list-copy small,
body[data-theme="noir"] .shared-item-row strong,
body[data-theme="noir"] .shared-member-chip small,
body[data-theme="noir"] .text-btn,
body[data-theme="noir"] .danger-btn,
body[data-theme="noir"] .guest-list-notice,
body[data-theme="noir"] .favorite-btn.is-active,
body[data-theme="noir"] .category-chip,
body[data-theme="noir"] .store-chip,
body[data-theme="noir"] .status-pill,
body[data-theme="noir"] .priority-pill {
  color: var(--ink);
}

body[data-theme="noir"] .account-copy p:last-child,
body[data-theme="noir"] .account-status-row p,
body[data-theme="noir"] .view-description,
body[data-theme="noir"] .brand-line,
body[data-theme="noir"] .notes-line,
body[data-theme="noir"] .tag-line,
body[data-theme="noir"] .capture-line,
body[data-theme="noir"] .shared-empty,
body[data-theme="noir"] .shared-list-copy span {
  color: var(--muted);
}

/* Form de conta: era dourado (destoava do rose). Label = rose da marca,
   input = texto claro + borda/placeholder neutros, igual aos demais inputs. */
body[data-theme="noir"] .auth-form label span {
  color: var(--oxblood);
}
body[data-theme="noir"] #authEmail,
body[data-theme="noir"] #authPassword {
  color: var(--ink);
  background: rgba(26, 26, 30, 0.94);
  border-color: rgba(255, 255, 255, 0.16);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.05),
    0 0 0 1px rgba(255, 255, 255, 0.03);
}

body[data-theme="noir"] #authEmail::placeholder,
body[data-theme="noir"] #authPassword::placeholder {
  color: rgba(255, 255, 255, 0.42);
}

body[data-theme="noir"] #authEmail:-webkit-autofill,
body[data-theme="noir"] #authPassword:-webkit-autofill {
  -webkit-text-fill-color: #f4f4f6;
  box-shadow: 0 0 0 1000px #1c1c1f inset;
  caret-color: #ec86ad;
}

body[data-theme="noir"] .hero-lockup::before {
  background:
    linear-gradient(108deg, transparent, rgba(238, 240, 242, 0.14) 28%, rgba(200, 204, 208, 0.05) 58%, transparent 82%);
}

body[data-theme="noir"] .hero-lockup h1 {
  background: none;
  color: #f7f7f4;
  -webkit-text-fill-color: currentColor;
  text-shadow: 0 20px 54px rgba(238, 240, 242, 0.12);
}

body[data-theme="noir"] .account-orb,
body[data-theme="noir"] .profile-avatar,
body[data-theme="noir"] .wishlist-tab.is-system .tab-icon {
  background: linear-gradient(135deg, #bd5076, #8b2447);
  color: #fff;
  box-shadow: 0 14px 30px rgba(139, 36, 71, 0.34);
}

body[data-theme="noir"] #signOutBtn {
  background: rgba(30, 30, 34, 0.94);
  border-color: rgba(255, 255, 255, 0.16);
  color: var(--ink);
}

body[data-theme="noir"] #signOutBtn:hover,
body[data-theme="noir"] .secondary-btn:hover {
  background: rgba(255, 255, 255, 0.08);
  border-color: rgba(255, 255, 255, 0.24);
  color: #ffffff;
}

body[data-theme="noir"] .bottom-dock {
  border-color: rgba(255, 255, 255, 0.12);
  background:
    linear-gradient(145deg, rgba(255, 255, 255, 0.06), rgba(255, 255, 255, 0.02)),
    rgba(24, 24, 28, 0.92);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.08),
    0 0 0 1px rgba(255, 255, 255, 0.04),
    0 24px 70px rgba(0, 0, 0, 0.46);
}

body[data-theme="noir"] .dock-nav-btn {
  color: rgba(247, 247, 244, 0.78);
}

body[data-theme="noir"] .dock-symbol,
body[data-theme="noir"] .shared-list-icon,
body[data-theme="noir"] .shared-icon-option {
  background:
    linear-gradient(145deg, rgba(255, 255, 255, 0.08), rgba(255, 255, 255, 0.02)),
    rgba(30, 30, 34, 0.95);
  border-color: rgba(255, 255, 255, 0.14);
  color: var(--ink);
}

body[data-theme="noir"] .dock-nav-btn.is-active {
  background:
    linear-gradient(145deg, rgba(238, 240, 242, 0.24), rgba(255, 255, 255, 0.08)),
    rgba(20, 20, 20, 0.96);
  color: #ffffff;
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.14),
    0 0 0 1px rgba(238, 240, 242, 0.08),
    0 12px 30px rgba(0, 0, 0, 0.38);
}

body[data-theme="noir"] .dock-nav-btn.is-active .dock-symbol {
  background: linear-gradient(145deg, #bd5076, #8b2447);
  color: #fff;
  border-color: rgba(236, 134, 173, 0.55);
}

body[data-theme="noir"] .dock-action,
body[data-theme="noir"] .fab-add {
  background: linear-gradient(135deg, #bd5076, #8b2447);
  color: #fff;
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.4),
    0 14px 32px rgba(0, 0, 0, 0.4),
    0 0 24px rgba(139, 36, 71, 0.3);
}

body[data-theme="blue"] .bottom-dock,
body[data-theme="fun"] .bottom-dock {
  border-color: rgba(var(--neon-rgb), 0.36);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.86),
    0 0 0 1px rgba(var(--neon-rgb), 0.08),
    0 24px 70px rgba(var(--neon-strong-rgb), 0.18);
}

body[data-theme="blue"] .hero-lockup::before {
  background:
    linear-gradient(108deg, transparent, rgba(255, 255, 255, 0.74) 24%, rgba(61, 139, 216, 0.18) 58%, transparent 82%);
}

body[data-theme="blue"] .eyebrow,
body[data-theme="blue"] .language-control,
body[data-theme="blue"] .theme-control {
  border-color: rgba(61, 139, 216, 0.22);
  box-shadow: 0 14px 34px rgba(12, 65, 116, 0.1);
}

body[data-theme="blue"] .theme-icon,
body[data-theme="blue"] .account-orb,
body[data-theme="blue"] .wishlist-tab.is-system .tab-icon {
  background:
    linear-gradient(135deg, rgba(11, 79, 134, 0.95), rgba(61, 139, 216, 0.84)),
    var(--oxblood);
  color: white;
  box-shadow: 0 12px 26px rgba(12, 65, 116, 0.18);
}

body[data-theme="blue"] .primary-btn,
body[data-theme="blue"] .dock-action {
  background: linear-gradient(180deg, #1769aa, #0b3f70);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.24),
    0 14px 30px rgba(12, 65, 116, 0.22);
}

body[data-theme="blue"] .wishlist-tab.is-active,
body[data-theme="blue"] input:focus,
body[data-theme="blue"] select:focus,
body[data-theme="blue"] textarea:focus {
  border-color: rgba(61, 139, 216, 0.48);
  box-shadow: 0 0 0 4px rgba(61, 139, 216, 0.14);
}

body[data-theme="fun"] {
  --ink: #2a1e2e;
  --muted: #7b657e;
  --paper: #fff4f8;
  --panel: #ffffff;
  --line: #f1d7e6;
  --blush: #ffdce9;
  --rose: #f07ead;
  --oxblood: #9b3d72;
  --graphite: #3a3142;
  --chrome: #d9e6ff;
  --sage: #dff5ec;
  --gold: #f6bd60;
  --shadow: 0 24px 70px rgba(155, 61, 114, 0.13);
  --neon-rgb: 240, 126, 173;
  --neon-strong-rgb: 155, 61, 114;
  --focus-rgb: 240, 126, 173;
  /* Bloco 1 — fundo calmo: herda `body { background: var(--paper) }`; --paper
     já vale #fff4f8 neste tema. O ::before com emojis (abaixo) é traço
     deliberado do tema fun, então fica. */
}

body[data-theme="fun"]::before {
  position: fixed;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  color: rgba(155, 61, 114, 0.12);
  content: "♡  ✨  🎀  ☆  ♡  ✨  🛍️  ☆  ♡  🎀";
  font-size: clamp(1.7rem, 4vw, 3.2rem);
  font-weight: 900;
  letter-spacing: 1.2rem;
  line-height: 2.8;
  overflow: hidden;
  transform: rotate(-8deg) scale(1.08);
  white-space: pre-wrap;
}

body[data-theme="fun"] .hero-lockup::before {
  background:
    linear-gradient(108deg, transparent, rgba(255, 255, 255, 0.78) 24%, rgba(240, 126, 173, 0.18) 58%, transparent 82%);
}

button,
input,
select,
textarea {
  font: inherit;
}

button {
  cursor: pointer;
  /* Prevent wrapped labels like "Detal/hes" or "Adicionar/desejo" inside
     buttons — multi-line button text looks broken on mobile. Long strings
     get truncated with ellipsis instead. */
  white-space: nowrap;
  text-overflow: ellipsis;
  overflow: hidden;
}

button.is-loading {
  position: relative;
  pointer-events: none;
}

button.is-loading::before {
  display: inline-block;
  width: 0.86em;
  height: 0.86em;
  margin-right: 8px;
  border: 2px solid currentColor;
  border-right-color: transparent;
  border-radius: 50%;
  content: "";
  vertical-align: -0.12em;
  animation: buttonSpin 720ms linear infinite;
}

.is-hidden {
  display: none !important;
}

button,
a,
input,
select {
  -webkit-tap-highlight-color: transparent;
}

button,
.wishlist-tab,
.wish-card,
.shared-list-card,
.shared-hub-hero,
.shared-category-chip {
  --tap-x: 50%;
  --tap-y: 50%;
  position: relative;
}

button,
.wishlist-tab,
.shared-list-card,
.shared-hub-hero,
.shared-category-chip {
  overflow: hidden;
}

button.has-ripple::after,
.wishlist-tab.has-ripple::after,
.wish-card.has-ripple::after,
.shared-list-card.has-ripple::after,
.shared-hub-hero.has-ripple::after,
.shared-category-chip.has-ripple::after {
  position: absolute;
  left: var(--tap-x);
  top: var(--tap-y);
  z-index: 3;
  width: 16px;
  height: 16px;
  border-radius: 999px;
  background: radial-gradient(circle, rgba(255, 255, 255, 0.68) 0 22%, rgba(var(--neon-rgb), 0.26) 42%, transparent 72%);
  content: "";
  pointer-events: none;
  transform: translate(-50%, -50%) scale(0);
  animation: rippleOut 460ms ease-out both;
}

button:focus-visible,
a:focus-visible,
input:focus-visible,
select:focus-visible,
[role="tab"]:focus-visible {
  outline: 3px solid rgba(var(--focus-rgb), 0.34);
  outline-offset: 3px;
}

/* Skip link: hidden until focused via keyboard. Lets screen-reader / keyboard
   users jump past the topbar and dock straight to the main content. */
.skip-link {
  position: fixed;
  top: 8px;
  left: 8px;
  z-index: 10000;
  padding: 10px 16px;
  border-radius: 999px;
  background: var(--oxblood);
  color: var(--panel);
  font-weight: 800;
  text-decoration: none;
  transform: translateY(-150%);
  transition: transform 180ms ease;
}

.skip-link:focus,
.skip-link:focus-visible {
  transform: translateY(0);
  outline: 3px solid rgba(var(--focus-rgb), 0.5);
  outline-offset: 3px;
}

#mainContent:focus {
  outline: none;
}

.shell {
  position: relative;
  z-index: 1;
  width: min(1180px, calc(100% - 32px));
  margin: 0 auto;
  padding: 34px 0 48px;
}

.workspace {
  display: grid;
  gap: 18px;
}

.topbar {
  position: relative;
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 24px;
  min-height: 230px;
  padding: 18px 0 12px;
  overflow: hidden;
}

.topbar::after {
  position: absolute;
  right: 8%;
  bottom: 8px;
  width: min(360px, 52vw);
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(var(--neon-strong-rgb), 0.22), rgba(var(--neon-rgb), 0.34), transparent);
  content: "";
  opacity: 0.8;
  transform-origin: right center;
  animation: heroLineIn 800ms ease both;
}

.hero-lockup {
  position: relative;
  isolation: isolate;
  max-width: 780px;
  padding-top: 8px;
}

.hero-lockup::before {
  position: absolute;
  top: -18px;
  left: -18px;
  z-index: -1;
  width: min(560px, 92vw);
  height: 150px;
  border-radius: 0;
  background:
    linear-gradient(108deg, transparent, rgba(255, 255, 255, 0.74) 24%, rgba(var(--neon-rgb), 0.16) 58%, transparent 82%);
  content: "";
  filter: blur(10px);
  opacity: 0.82;
  transform: skewY(-5deg);
  animation: heroAura 7s ease-in-out infinite alternate;
}

.eyebrow {
  display: inline-flex;
  align-items: center;
  min-height: 30px;
  margin: 0 0 10px;
  border: 1px solid rgba(111, 29, 50, 0.12);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.58);
  color: var(--oxblood);
  font-size: 0.78rem;
  font-weight: 800;
  padding: 0 10px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  box-shadow: 0 10px 28px rgba(111, 29, 50, 0.08);
  animation: heroTextIn 520ms ease both;
}

h1 {
  max-width: 760px;
  margin: 0;
  font-family: var(--font-display);
  font-size: clamp(2.1rem, 5vw, 5rem);
  font-weight: 500;
  line-height: 1.06;
  letter-spacing: 0;
  color: var(--ink);
  text-shadow: 0 18px 48px rgba(111, 29, 50, 0.16);
  animation: heroTextIn 620ms 70ms ease both;
}

.hero-lockup h1 {
  display: inline-block;
  overflow: visible;
  padding-bottom: 0.08em;
  background: linear-gradient(115deg, var(--ink) 0%, var(--oxblood) 48%, var(--graphite) 100%);
  background-clip: text;
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
}

.hero-copy {
  max-width: 560px;
  margin: 14px 0 0;
  color: var(--muted);
  font-size: 1.02rem;
  line-height: 1.5;
  animation: heroTextIn 620ms 140ms ease both;
}

.metric-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  justify-content: stretch;
  gap: 10px;
  width: 100%;
}

.metric-grid > span {
  display: grid;
  align-content: space-between;
  gap: 8px;
  min-height: 78px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 12px;
  background: rgba(255, 255, 255, 0.76);
  color: var(--muted);
  box-shadow: 0 12px 32px rgba(47, 52, 55, 0.07);
  -webkit-backdrop-filter: blur(16px);
  backdrop-filter: blur(16px);
  transition:
    border-color 180ms ease,
    box-shadow 180ms ease,
    transform 180ms ease;
}

.metric-grid strong {
  color: var(--ink);
  overflow: hidden;
  font-size: 1.16rem;
  line-height: 1.08;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.metric-grid > span > span,
.list-summary-strip > span > span {
  overflow: hidden;
  font-size: 0.72rem;
  font-weight: 800;
  letter-spacing: 0.02em;
  line-height: 1.2;
  text-overflow: ellipsis;
  text-transform: uppercase;
  white-space: nowrap;
}

.metric-grid > span:hover {
  border-color: rgba(111, 29, 50, 0.22);
  box-shadow: 0 16px 38px rgba(111, 29, 50, 0.1);
  transform: translateY(-1px);
}

.topbar-actions {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 10px;
}

.language-control,
.theme-control {
  position: relative;
  display: flex;
  align-items: center;
  gap: 8px;
  min-height: 58px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: rgba(255, 255, 255, 0.76);
  box-shadow: 0 12px 32px rgba(47, 52, 55, 0.07);
  padding: 8px 10px;
  transition:
    border-color 180ms ease,
    box-shadow 180ms ease,
    transform 180ms ease;
}

.language-control:hover,
.theme-control:hover {
  border-color: rgba(111, 29, 50, 0.22);
  box-shadow: 0 16px 38px rgba(111, 29, 50, 0.1);
  transform: translateY(-1px);
}

.language-icon,
.theme-icon {
  display: grid;
  place-items: center;
  flex: 0 0 36px;
  width: 36px;
  height: 36px;
  border-radius: 14px;
  background:
    linear-gradient(135deg, rgba(244, 223, 229, 0.95), rgba(220, 230, 223, 0.86)),
    var(--panel);
  color: var(--oxblood);
  font-size: 0.72rem;
  font-weight: 950;
}

.theme-icon {
  background:
    linear-gradient(135deg, rgba(111, 29, 50, 0.92), rgba(200, 121, 141, 0.72)),
    var(--panel);
  color: white;
}

.language-control select,
.theme-control select {
  min-height: 38px;
  border: 0;
  border-radius: 12px;
  background: transparent;
  font-weight: 950;
  direction: ltr;
  padding: 0 8px;
  text-align: left;
}

.language-control select:focus,
.theme-control select:focus {
  box-shadow: none;
}

.capture-panel,
.review-panel,
.tools-row,
.wishlist-switcher,
.view-panel,
.add-intro {
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: rgba(255, 255, 255, 0.78);
  box-shadow: var(--shadow);
  -webkit-backdrop-filter: blur(18px);
  backdrop-filter: blur(18px);
}

.view-panel {
  display: grid;
  gap: 16px;
  padding: 14px;
  transform-origin: center top;
  animation: viewEnter 320ms cubic-bezier(0.2, 0.85, 0.2, 1) both;
  will-change: opacity, transform, filter;
}

.view-panel.is-hidden {
  display: none;
}

body.is-view-changing .view-panel:not(.is-hidden) {
  animation:
    viewEnter 320ms cubic-bezier(0.2, 0.85, 0.2, 1) both,
    viewGlow 420ms ease both;
}

.summary-panel {
  display: grid;
  gap: 14px;
  order: 2;
}

.summary-account {
  order: 1;
}

.onboarding-panel {
  order: 3;
}

.onboarding-panel {
  position: relative;
  display: grid;
  gap: 14px;
  border: 1px solid rgba(111, 29, 50, 0.12);
  border-radius: var(--radius-lg);
  background:
    linear-gradient(135deg, rgba(255, 255, 255, 0.88), rgba(248, 235, 239, 0.9)),
    var(--panel);
  padding: 18px;
  box-shadow: 0 18px 42px rgba(111, 29, 50, 0.08);
  animation: panelRise 360ms 120ms ease both;
}

.onboarding-panel.needs-attention,
.account-card.needs-login {
  border-color: rgba(var(--neon-rgb), 0.52);
  box-shadow:
    0 0 0 1px rgba(255, 255, 255, 0.82) inset,
    0 0 0 1px rgba(var(--neon-rgb), 0.2),
    0 0 30px rgba(var(--neon-rgb), 0.22),
    0 18px 48px rgba(var(--neon-strong-rgb), 0.1);
  animation:
    panelRise 360ms 120ms ease both,
    softNeon 2.8s ease-in-out infinite alternate;
}

/* No noir o glow rose pulsante vira farol — dark mode neutro pede um card
   quieto: borda cinza, sem anel branco interno, sem animacao de neon. */
body[data-theme="noir"] .account-card.needs-login {
  border-color: rgba(255, 255, 255, 0.16);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.06),
    0 18px 48px rgba(0, 0, 0, 0.4);
  animation: panelRise 360ms 120ms ease both;
}

.onboarding-panel > div {
  display: grid;
  gap: 4px;
}

.onboarding-panel h3 {
  margin: 0;
  color: var(--ink);
  font-family: var(--font-display);
  font-size: 1.35rem;
  font-weight: 500;
}

.onboarding-panel ol {
  display: grid;
  gap: 8px;
  margin: 0;
  padding-left: 20px;
  color: var(--muted);
  line-height: 1.5;
}

.onboarding-panel li::marker {
  color: var(--oxblood);
  font-weight: 900;
}

.onboarding-panel .secondary-btn {
  justify-self: start;
  min-width: 118px;
}

.view-heading,
.view-actions {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.view-heading h2,
.add-intro h2 {
  margin: 0;
  font-family: var(--font-display);
  font-size: 1.65rem;
  font-weight: 500;
}

.add-intro {
  display: grid;
  gap: 8px;
  padding: 18px;
  box-shadow: none;
}

.add-intro p:last-child {
  max-width: 620px;
  margin: 0;
  color: var(--muted);
  line-height: 1.45;
}

.account-panel {
  display: grid;
  grid-template-columns: minmax(0, 0.9fr) minmax(280px, 1.1fr);
  gap: 16px;
}

.account-copy,
.account-card {
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background:
    linear-gradient(145deg, rgba(255, 255, 255, 0.86), rgba(var(--neon-rgb), 0.06)),
    rgba(255, 255, 255, 0.78);
  padding: 18px;
}

.account-copy h2 {
  margin: 0;
  font-family: var(--font-display);
  font-size: 1.8rem;
  font-weight: 500;
  line-height: 1.05;
}

.account-copy p:last-child,
.account-status-row p {
  margin: 8px 0 0;
  color: var(--muted);
  line-height: 1.45;
}

.scan-health-panel {
  display: grid;
  gap: 14px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: rgba(255, 255, 255, 0.78);
  padding: 18px;
  box-shadow: var(--shadow);
  -webkit-backdrop-filter: blur(18px);
  backdrop-filter: blur(18px);
}

.scan-health-metrics {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
}

.scan-health-metrics > span {
  display: grid;
  gap: 6px;
  min-height: 64px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: rgba(255, 255, 255, 0.72);
  color: var(--muted);
  padding: 10px 12px;
}

.summary-priority-metric {
  display: none !important;
}

.scan-health-metrics strong {
  color: var(--ink);
  font-size: 1.08rem;
  line-height: 1;
}

.scan-health-metrics span span {
  font-size: 0.72rem;
  font-weight: 900;
  letter-spacing: 0.02em;
  text-transform: uppercase;
}

.scan-health-empty {
  border: 1px dashed rgba(200, 121, 141, 0.32);
  border-radius: var(--radius);
  color: var(--muted);
  padding: 14px;
  line-height: 1.45;
}

.scan-health-body {
  display: grid;
  gap: 14px;
}

.scan-health-body.is-collapsed {
  display: none;
}

.scan-health-content {
  display: grid;
  grid-template-columns: minmax(0, 0.9fr) minmax(0, 1.1fr);
  gap: 14px;
}

.scan-health-content h3 {
  margin: 0 0 8px;
  color: var(--ink);
  font-size: 0.88rem;
  letter-spacing: 0.02em;
  text-transform: uppercase;
}

.scan-store-list,
.scan-recent-list {
  display: grid;
  gap: 8px;
}

.scan-store-row,
.scan-recent-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  gap: 10px;
  border: 1px solid var(--line);
  border-radius: 14px;
  background: rgba(255, 255, 255, 0.68);
  padding: 10px 12px;
}

.scan-store-row span,
.scan-recent-row span {
  display: grid;
  gap: 3px;
  min-width: 0;
}

.scan-store-row strong,
.scan-recent-row strong {
  overflow: hidden;
  color: var(--ink);
  font-size: 0.92rem;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.scan-store-row small,
.scan-recent-row small {
  color: var(--muted);
  font-size: 0.76rem;
  font-weight: 800;
}

.scan-store-row em,
.scan-recent-row em {
  max-width: 180px;
  color: var(--muted);
  font-size: 0.75rem;
  font-style: normal;
  font-weight: 800;
  text-align: right;
}

.scan-recent-row.is-ok {
  border-color: rgba(66, 100, 82, 0.22);
}

.scan-recent-row.is-failed {
  border-color: rgba(111, 29, 50, 0.26);
}

.account-card {
  position: relative;
  display: grid;
  gap: 16px;
  box-shadow:
    0 18px 44px rgba(47, 52, 55, 0.08),
    0 0 0 1px rgba(var(--neon-rgb), 0.035);
}

.profile-hud {
  display: grid;
  gap: 12px;
  animation: panelRise 220ms ease both;
}

.profile-card {
  position: relative;
  overflow: hidden;
  display: grid;
  gap: 12px;
  border: 1px solid rgba(var(--neon-rgb), 0.16);
  border-radius: 24px;
  background:
    linear-gradient(135deg, rgba(255, 255, 255, 0.92), rgba(248, 235, 239, 0.82)),
    var(--panel);
  padding: 0 12px 12px;
  box-shadow: 0 18px 46px rgba(var(--neon-strong-rgb), 0.08);
}

.profile-cover {
  height: 92px;
  margin: 0 -12px;
  background:
    radial-gradient(circle at 18% 22%, rgba(255, 255, 255, 0.7), transparent 24%),
    linear-gradient(135deg, rgba(var(--neon-rgb), 0.38), rgba(111, 29, 50, 0.24), rgba(217, 226, 219, 0.78));
}

.profile-main-row {
  display: grid;
  grid-template-columns: auto 1fr;
  align-items: end;
  gap: 12px;
  margin-top: -34px;
}

.profile-identity {
  min-width: 0;
  padding-bottom: 3px;
}

.profile-avatar {
  position: relative;
  overflow: hidden;
  display: grid;
  place-items: center;
  width: 72px;
  height: 72px;
  border: 4px solid rgba(255, 255, 255, 0.88);
  border-radius: 28px;
  background:
    linear-gradient(135deg, rgba(111, 29, 50, 0.94), rgba(200, 121, 141, 0.86)),
    var(--oxblood);
  color: white;
  font-size: 0.72rem;
  font-weight: 950;
  letter-spacing: 0.08em;
  box-shadow: 0 16px 30px rgba(111, 29, 50, 0.2);
}

.profile-avatar.has-photo {
  background: var(--profile-photo) center / cover no-repeat, var(--panel);
  color: transparent;
}

.profile-card strong {
  display: block;
  overflow: hidden;
  color: var(--ink);
  font-size: 1.22rem;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.profile-card #profileHandle,
.profile-card #profileEmail {
  overflow: hidden;
  color: var(--muted);
  font-size: 0.86rem;
  font-weight: 800;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.profile-card #profileEmail {
  margin: 0;
}

.profile-stat-row {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.profile-stat-row span {
  display: inline-flex;
  min-height: 32px;
  align-items: center;
  border: 1px solid rgba(var(--neon-rgb), 0.14);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.62);
  color: var(--muted);
  padding: 0 10px;
  font-size: 0.78rem;
  font-weight: 950;
}

.profile-edit-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr) auto;
  gap: 8px;
  align-items: end;
}

.profile-edit-grid label {
  display: grid;
  gap: 5px;
  min-width: 0;
}

.profile-edit-grid label span {
  color: var(--muted);
  font-size: 0.68rem;
  font-weight: 950;
  text-transform: uppercase;
}

.profile-edit-grid .secondary-btn {
  min-height: 46px;
}

/* 11H — bio curta do perfil publico ocupa a linha inteira do grid. */
.profile-edit-grid .profile-bio-label {
  grid-column: 1 / -1;
}

.profile-edit-grid textarea {
  border: 1px solid var(--line);
  border-radius: 12px;
  background: var(--panel);
  color: var(--ink);
  font: inherit;
  font-size: 0.85rem;
  padding: 10px 12px;
  min-height: 54px;
  resize: none;
}

/* 11H — avatar da criadora quando ha foto de perfil na nuvem. */
.shared-author-avatar.has-photo {
  background-image: var(--author-photo);
  background-size: cover;
  background-position: center;
  color: transparent;
}

/* 11H — bio exibida na pagina de perfil publico da criadora. */
.shared-detail-bio {
  margin: 4px 0 0;
  color: var(--muted);
  font-size: 0.92rem;
  line-height: 1.45;
  max-width: 48ch;
}

.profile-actions {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}

.profile-actions .secondary-btn {
  width: 100%;
}

#signOutBtn {
  border-color: rgba(166, 49, 66, 0.28);
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.9), rgba(255, 244, 246, 0.86)),
    var(--panel);
  color: #a63142;
  box-shadow: 0 12px 28px rgba(166, 49, 66, 0.08);
}

#signOutBtn:hover {
  border-color: rgba(166, 49, 66, 0.44);
  background:
    linear-gradient(180deg, rgba(255, 250, 251, 0.96), rgba(255, 232, 237, 0.9)),
    var(--panel);
  box-shadow: 0 16px 34px rgba(166, 49, 66, 0.12);
}

.danger-zone {
  overflow: hidden;
  border: 1px solid rgba(111, 29, 50, 0.08);
  border-radius: 16px;
  background: rgba(255, 255, 255, 0.38);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.52);
  opacity: 0.74;
  transition: opacity 180ms ease, border-color 180ms ease, background 180ms ease, box-shadow 180ms ease;
}

.danger-zone:hover,
.danger-zone[open] {
  border-color: rgba(111, 29, 50, 0.16);
  background:
    linear-gradient(135deg, rgba(255, 255, 255, 0.78), rgba(248, 235, 239, 0.52)),
    var(--panel);
  box-shadow: 0 12px 28px rgba(111, 29, 50, 0.06);
  opacity: 1;
}

.danger-zone summary {
  cursor: pointer;
  color: var(--muted);
  font-size: 0.72rem;
  font-weight: 950;
  list-style: none;
  padding: 11px 13px;
  text-transform: uppercase;
}

.danger-zone summary::after {
  content: "+";
  float: right;
  color: var(--muted);
}

.danger-zone[open] summary::after {
  content: "-";
}

.danger-zone summary::-webkit-details-marker {
  display: none;
}

.danger-zone p,
.danger-zone label,
.danger-zone button {
  margin-left: 14px;
  margin-right: 14px;
}

.danger-zone p {
  margin-top: 0;
  color: var(--muted);
  font-size: 0.84rem;
  line-height: 1.5;
}

.danger-zone label {
  display: grid;
  gap: 8px;
  color: var(--muted);
  font-size: 0.76rem;
  font-weight: 900;
  text-transform: uppercase;
}

.danger-zone button {
  width: calc(100% - 28px);
  margin-bottom: 14px;
}

.danger-btn {
  color: var(--oxblood);
}

.danger-zone .danger-btn:not(:disabled) {
  border-color: rgba(166, 49, 66, 0.3);
  background:
    linear-gradient(180deg, rgba(166, 49, 66, 0.94), rgba(111, 29, 50, 0.95)),
    #a63142;
  color: #fff;
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.2),
    0 16px 34px rgba(111, 29, 50, 0.2);
}

.account-status-row {
  display: grid;
  grid-template-columns: auto 1fr;
  align-items: center;
  gap: 12px;
}

.account-orb {
  display: grid;
  place-items: center;
  width: 54px;
  height: 54px;
  border-radius: 20px;
  background:
    linear-gradient(135deg, rgba(244, 223, 229, 0.95), rgba(220, 230, 223, 0.86)),
    var(--panel);
  color: var(--oxblood);
  font-weight: 950;
}

.auth-form {
  display: grid;
  gap: 12px;
}

.wishlist-switcher {
  display: grid;
  gap: 14px;
  padding: 14px;
  box-shadow: none;
}

.switcher-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
}

.guest-list-notice {
  margin: -4px 0 0;
  border: 1px solid rgba(200, 121, 141, 0.24);
  border-radius: 16px;
  background: rgba(248, 235, 239, 0.72);
  color: var(--oxblood);
  padding: 10px 12px;
  font-size: 0.9rem;
  font-weight: 750;
  line-height: 1.35;
}

.view-description {
  max-width: 640px;
  margin: 6px 0 0;
  color: var(--muted);
  font-size: 0.95rem;
  line-height: 1.45;
}

.shared-heading {
  position: relative;
  overflow: hidden;
  min-height: 128px;
  border: 1px solid rgba(var(--neon-rgb), 0.16);
  border-radius: 28px;
  background:
    linear-gradient(112deg, rgba(255, 255, 255, 0.92), rgba(var(--neon-rgb), 0.09) 46%, rgba(255, 255, 255, 0.7)),
    repeating-linear-gradient(90deg, rgba(var(--neon-strong-rgb), 0.045) 0 1px, transparent 1px 42px),
    var(--panel);
  padding: 18px;
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.72),
    0 18px 46px rgba(var(--neon-strong-rgb), 0.08);
}

.shared-heading::after {
  position: absolute;
  right: 18px;
  bottom: 16px;
  width: min(260px, 42%);
  height: 2px;
  border-radius: 999px;
  background: linear-gradient(90deg, transparent, rgba(var(--neon-rgb), 0.56), rgba(var(--neon-strong-rgb), 0.22));
  content: "";
}

.shared-heading h2 {
  font-size: clamp(2rem, 4.2vw, 4rem);
  line-height: 0.9;
}

.shared-shell,
.shared-detail-panel {
  position: relative;
  overflow: hidden;
  display: grid;
  gap: 14px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background:
    linear-gradient(145deg, rgba(255, 255, 255, 0.86), rgba(255, 255, 255, 0.62)),
    repeating-linear-gradient(0deg, rgba(var(--neon-strong-rgb), 0.035) 0 1px, transparent 1px 36px),
    rgba(255, 255, 255, 0.74);
  padding: 14px;
  box-shadow: 0 16px 42px rgba(47, 52, 55, 0.07);
  animation: panelRise 260ms ease both;
}

.shared-shell::before {
  position: absolute;
  inset: 0;
  border-radius: inherit;
  background:
    linear-gradient(120deg, transparent 0 48%, rgba(var(--neon-rgb), 0.09) 48% 50%, transparent 50%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.34), transparent 38%);
  content: "";
  pointer-events: none;
}

.shared-shell > * {
  position: relative;
  z-index: 1;
}

.view-panel[data-view-panel="shared"].is-detail-open .shared-heading,
.view-panel[data-view-panel="shared"].is-detail-open .shared-shell {
  display: none;
}

.shared-detail-panel.is-hub-preview {
  overflow: hidden;
  gap: 16px;
  min-height: min(780px, calc(100vh - 128px));
  border-color: rgba(var(--neon-rgb), 0.2);
  background:
    linear-gradient(112deg, rgba(255, 255, 255, 0.92), rgba(var(--neon-rgb), 0.12) 42%, rgba(255, 255, 255, 0.72)),
    repeating-linear-gradient(90deg, rgba(var(--neon-strong-rgb), 0.045) 0 1px, transparent 1px 44px),
    var(--panel);
  box-shadow:
    0 0 0 1px rgba(255, 255, 255, 0.42) inset,
    0 24px 80px rgba(var(--neon-strong-rgb), 0.16);
  transform: translateX(var(--swipe-x, 0));
  animation: hubDetailEnter 360ms cubic-bezier(0.16, 1, 0.3, 1) both;
  touch-action: pan-y;
}

.shared-detail-panel.is-hub-preview::before {
  position: absolute;
  inset: 12px;
  border: 1px solid rgba(var(--neon-rgb), 0.12);
  border-radius: 26px;
  content: "";
  pointer-events: none;
}

.shared-detail-panel.is-hub-preview > * {
  position: relative;
  z-index: 1;
}

.shared-detail-panel.is-hub-preview.is-swiping {
  transition: none;
}

.shared-detail-panel.is-hub-preview.is-swipe-cancel {
  transition: transform 180ms cubic-bezier(0.16, 1, 0.3, 1);
}

.shared-detail-panel.is-hub-preview.is-leaving {
  animation: hubDetailLeave 220ms ease both;
}

@keyframes hubDetailEnter {
  from {
    opacity: 0;
    transform: translateX(34px) scale(0.985);
  }
  to {
    opacity: 1;
    transform: translateX(var(--swipe-x, 0)) scale(1);
  }
}

@keyframes hubDetailLeave {
  to {
    opacity: 0;
    transform: translateX(46px) scale(0.985);
  }
}

.shared-toolbar {
  display: grid;
  gap: 12px;
  border: 1px solid rgba(var(--neon-rgb), 0.12);
  border-radius: 24px;
  background:
    linear-gradient(145deg, rgba(255, 255, 255, 0.74), rgba(var(--neon-rgb), 0.045)),
    rgba(255, 255, 255, 0.58);
  padding: 10px;
  box-shadow: 0 12px 28px rgba(var(--neon-strong-rgb), 0.055);
}

.segmented-control {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 6px;
  border: 1px solid var(--line);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.62);
  padding: 5px;
}

.segmented-control button {
  min-height: 40px;
  border: 0;
  border-radius: 999px;
  background: transparent;
  color: var(--muted);
  font: inherit;
  font-weight: 900;
}

.segmented-control button.is-active {
  background: var(--ink);
  color: var(--panel);
  box-shadow: 0 10px 24px rgba(47, 52, 55, 0.14);
}

.shared-toolbar-row,
.shared-create-panel,
.shared-add-row {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 10px;
}

.shared-toolbar-row {
  grid-template-columns: auto minmax(180px, 1fr) minmax(142px, auto) auto;
  align-items: center;
}

.shared-refresh-btn {
  min-width: 92px;
}

.shared-hub-categories {
  display: flex;
  gap: 8px;
  overflow-x: auto;
  margin-inline: -2px;
  padding: 2px 2px 5px;
  scrollbar-width: none;
}

.shared-hub-categories::-webkit-scrollbar {
  display: none;
}

.shared-hub-categories.is-hidden {
  display: none;
}

.shared-category-chip {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  flex: 0 0 auto;
  min-height: 38px;
  border: 1px solid rgba(var(--neon-rgb), 0.32);
  border-radius: 999px;
  background:
    linear-gradient(145deg, rgba(255, 255, 255, 0.86), rgba(var(--neon-rgb), 0.06)),
    rgba(255, 255, 255, 0.62);
  color: var(--ink);
  font: inherit;
  font-size: 0.78rem;
  font-weight: 950;
  padding: 0 13px 0 9px;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.66);
  transition: transform 180ms ease, background 180ms ease, border-color 180ms ease, color 180ms ease, box-shadow 180ms ease;
}

.shared-category-chip span {
  display: block;
  width: 22px;
  height: 22px;
  border: 1.5px solid rgba(var(--neon-strong-rgb), 0.55);
  border-radius: 8px;
  background:
    linear-gradient(135deg, rgba(var(--neon-rgb), 0.42), rgba(255, 255, 255, 0.7)),
    var(--panel);
  color: var(--ink);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.7), 0 2px 6px rgba(var(--neon-strong-rgb), 0.16);
}

.shared-category-chip strong {
  font: inherit;
  font-weight: 950;
}

.shared-category-chip:hover,
.shared-category-chip.is-active {
  transform: translateY(-1px);
  border-color: rgba(var(--neon-rgb), 0.48);
  background:
    linear-gradient(145deg, rgba(var(--neon-strong-rgb), 0.96), rgba(var(--neon-rgb), 0.72)),
    var(--ink);
  color: var(--panel);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.18),
    0 12px 26px rgba(var(--neon-strong-rgb), 0.12);
}

.shared-category-chip:hover span,
.shared-category-chip.is-active span {
  border-color: rgba(255, 255, 255, 0.34);
  background: rgba(255, 255, 255, 0.88);
  color: var(--oxblood);
  box-shadow: 0 6px 14px rgba(var(--neon-strong-rgb), 0.18);
}

/* Etapa 11D: categoria sem listas ainda aparece, mas com dica visual sutil. */
.shared-category-chip.is-empty:not(.is-active) {
  opacity: 0.55;
}

.shared-hub-sort {
  min-width: 0;
}

.shared-hub-sort.is-hidden {
  display: none;
}

.shared-create-panel {
  grid-template-columns: minmax(140px, 0.8fr) minmax(170px, 1fr) minmax(120px, auto) minmax(230px, 1.2fr) auto auto;
  align-items: center;
  animation: panelRise 220ms ease both;
}

.cover-file-control {
  position: relative;
  display: inline-grid;
  place-items: center;
  min-height: 48px;
  border: 1px solid rgba(var(--neon-rgb), 0.18);
  border-radius: 16px;
  background:
    linear-gradient(145deg, rgba(255, 255, 255, 0.84), rgba(var(--neon-rgb), 0.07)),
    rgba(255, 255, 255, 0.66);
  color: var(--oxblood);
  cursor: pointer;
  font-size: 0.76rem;
  font-weight: 950;
  overflow: hidden;
  padding: 0 12px;
  text-align: center;
  text-transform: uppercase;
}

.cover-file-control input {
  position: absolute;
  inset: 0;
  cursor: pointer;
  opacity: 0;
}

.native-shared-icon-select {
  position: absolute;
  width: 1px;
  height: 1px;
  overflow: hidden;
  opacity: 0;
  pointer-events: none;
}

.shared-icon-picker {
  display: grid;
  grid-template-columns: repeat(6, minmax(44px, 1fr));
  gap: 7px;
}

.shared-icon-option {
  display: grid;
  place-items: center;
  gap: 5px;
  min-height: 62px;
  border: 1px solid rgba(var(--neon-rgb), 0.16);
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.68);
  color: var(--muted);
  font: inherit;
  padding: 7px 5px;
  transition: transform 180ms ease, border-color 180ms ease, background 180ms ease, box-shadow 180ms ease, color 180ms ease;
}

.shared-icon-option:hover {
  transform: translateY(-1px);
  border-color: rgba(var(--neon-rgb), 0.34);
  color: var(--ink);
}

.shared-icon-option.is-selected {
  border-color: rgba(var(--neon-rgb), 0.52);
  background:
    linear-gradient(145deg, rgba(var(--neon-rgb), 0.16), rgba(255, 255, 255, 0.88)),
    var(--panel);
  color: var(--oxblood);
  box-shadow:
    0 0 0 1px rgba(var(--neon-rgb), 0.08),
    0 12px 26px rgba(var(--neon-strong-rgb), 0.1);
}

.shared-icon-option small {
  overflow: hidden;
  max-width: 100%;
  font-size: 0.62rem;
  font-weight: 950;
  line-height: 1;
  text-overflow: ellipsis;
  text-transform: uppercase;
  white-space: nowrap;
}

.shared-lists-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 12px;
}

.shared-lists-grid.is-explore-grid {
  grid-template-columns: minmax(0, 1fr);
  align-items: start;
  gap: 12px;
}

.shared-hub-hero {
  position: relative;
  overflow: hidden;
  display: grid;
  grid-template-columns: minmax(150px, 0.82fr) minmax(0, 1.18fr);
  gap: 14px;
  min-height: 210px;
  border: 1px solid rgba(var(--neon-rgb), 0.22);
  border-radius: 28px;
  background:
    linear-gradient(124deg, rgba(255, 255, 255, 0.94), rgba(var(--neon-rgb), 0.105) 52%, rgba(255, 255, 255, 0.74)),
    repeating-linear-gradient(90deg, rgba(var(--neon-strong-rgb), 0.045) 0 1px, transparent 1px 32px),
    var(--panel);
  padding: 12px;
  box-shadow:
    0 0 0 1px rgba(255, 255, 255, 0.48) inset,
    0 26px 74px rgba(var(--neon-strong-rgb), 0.14);
  cursor: pointer;
  animation: panelRise 280ms ease both;
  transition: transform 180ms ease, border-color 180ms ease, box-shadow 180ms ease;
}

.shared-hub-hero::before {
  position: absolute;
  inset: 12px;
  border: 1px solid rgba(var(--neon-rgb), 0.12);
  border-radius: 22px;
  content: "";
  pointer-events: none;
}

.shared-hub-hero:hover,
.shared-hub-hero:focus-visible {
  border-color: rgba(var(--neon-rgb), 0.42);
  box-shadow:
    0 0 0 1px rgba(255, 255, 255, 0.54) inset,
    0 26px 76px rgba(var(--neon-strong-rgb), 0.18);
  transform: translateY(-1px);
}

.shared-hub-hero.is-hidden {
  display: none;
}

.hub-hero-cover {
  position: relative;
  overflow: hidden;
  display: grid;
  height: clamp(176px, 22vw, 248px);
  min-height: 0;
  border: 1px solid rgba(var(--neon-rgb), 0.18);
  border-radius: 22px;
  background:
    linear-gradient(135deg, rgba(var(--neon-rgb), 0.18), rgba(255, 255, 255, 0.78)),
    var(--panel);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.76),
    0 16px 34px rgba(var(--neon-strong-rgb), 0.1);
}

.hub-hero-cover img {
  width: 100%;
  height: 100%;
  min-height: 0;
  object-fit: cover;
}

.hub-hero-cover img.is-hidden {
  display: none;
}

.hub-hero-cover::after {
  position: absolute;
  inset: auto 10px 10px 10px;
  height: 36%;
  border-radius: 18px;
  background: linear-gradient(180deg, transparent, rgba(18, 18, 18, 0.2));
  content: "";
  opacity: 0.42;
  pointer-events: none;
}

.hub-hero-copy {
  display: grid;
  align-content: center;
  gap: 9px;
  min-width: 0;
  padding: 10px 8px 10px 0;
}

.hub-hero-title-row {
  display: grid;
  grid-template-columns: 42px minmax(0, 1fr);
  gap: 9px;
  align-items: center;
  min-width: 0;
}

.hub-hero-title-row .shared-list-icon {
  width: 42px;
  height: 42px;
  border-radius: 15px;
  background: rgba(255, 255, 255, 0.82);
  box-shadow: 0 12px 22px rgba(0, 0, 0, 0.1);
}

.hub-hero-copy h3 {
  margin: 0;
  color: var(--ink);
  font-family: var(--font-serif);
  font-size: clamp(1.55rem, 3vw, 2.45rem);
  font-weight: 750;
  line-height: 1;
}

.hub-hero-preview {
  display: -webkit-box;
  margin: 0;
  overflow: hidden;
  color: var(--muted);
  font-size: 0.84rem;
  font-weight: 800;
  line-height: 1.35;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
}

.hub-creator {
  margin: 0;
  width: fit-content;
  border: 0;
  background: transparent;
  color: var(--muted);
  cursor: pointer;
  padding: 0;
  font-size: 0.96rem;
  font-weight: 800;
  text-align: left;
  transition: color 180ms ease, transform 180ms ease;
}

.hub-creator:hover,
.hub-creator:focus-visible,
.hub-creator-link:hover,
.hub-creator-link:focus-visible {
  color: var(--oxblood);
  transform: translateY(-1px);
}

.hub-hero-stats {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.hub-hero-stats span {
  border: 1px solid rgba(var(--neon-rgb), 0.16);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.66);
  color: var(--ink);
  padding: 6px 8px;
  font-size: 0.7rem;
  font-weight: 950;
}

.hub-hero-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 4px;
}

.hub-hero-actions .primary-btn,
.hub-hero-actions .secondary-btn,
.hub-hero-actions .shared-like-btn {
  min-height: 38px;
}

.shared-feed-title {
  margin: 0;
  color: var(--ink);
  font-size: 0.9rem;
  font-weight: 950;
  letter-spacing: 0;
}

.shared-feed-title.is-hidden {
  display: none;
}

/* Etapa 11C/D Fase 4: sections distintas no Hub. */
.hub-section {
  display: grid;
  gap: 10px;
  animation: cardIn 280ms cubic-bezier(0.2, 0.85, 0.2, 1) both;
}

.hub-section + .hub-section {
  margin-top: 18px;
}

.hub-section-title {
  margin: 0;
  color: var(--ink);
  font-size: 1.06rem;
  font-weight: 950;
  letter-spacing: -0.012em;
  display: flex;
  align-items: center;
  gap: 8px;
}

.hub-section-title::before {
  content: "";
  display: inline-block;
  width: 6px;
  height: 18px;
  border-radius: 4px;
  background: linear-gradient(180deg, rgba(var(--neon-strong-rgb), 0.95), rgba(var(--neon-rgb), 0.7));
}

.hub-section[data-section-key="trending"] .hub-section-title::before {
  background: linear-gradient(180deg, #ff6b35, #ff9a55);
}

.hub-section[data-section-key="forYou"] .hub-section-title::before {
  background: linear-gradient(180deg, rgba(var(--neon-strong-rgb), 0.95), rgba(var(--neon-rgb), 0.7));
}

.hub-section[data-section-key="mostSaved"] .hub-section-title::before {
  background: linear-gradient(180deg, #4a90e2, #7ab3ec);
}

.hub-section[data-section-key="recent"] .hub-section-title::before {
  background: linear-gradient(180deg, #4caf50, #88c992);
}

.hub-section-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: 10px;
  align-items: start;
}

.shared-list-card {
  position: relative;
  overflow: hidden;
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 12px;
  align-items: center;
  border: 1px solid var(--line);
  border-radius: 20px;
  background: rgba(255, 255, 255, 0.78);
  padding: 12px;
  box-shadow: 0 12px 30px rgba(47, 52, 55, 0.06);
  animation: cardIn 260ms cubic-bezier(0.2, 0.85, 0.2, 1) both;
  animation-delay: calc(var(--card-index, 0) * 32ms);
  transition: transform 180ms ease, border-color 180ms ease, box-shadow 180ms ease;
}

.shared-list-card.is-hub-card {
  grid-template-columns: minmax(96px, 110px) minmax(0, 1fr);
  align-items: start;
  min-height: 100%;
  column-gap: 8px;
  row-gap: 5px;
  border-color: rgba(var(--neon-rgb), 0.18);
  border-radius: 18px;
  background:
    linear-gradient(145deg, rgba(255, 255, 255, 0.94), rgba(var(--neon-rgb), 0.055)),
    rgba(255, 255, 255, 0.78);
  padding: 8px;
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.72),
    0 14px 34px rgba(var(--neon-strong-rgb), 0.075);
}

/* The full card opens the detail view on click, so the "Entrar" CTA at the
   bottom is redundant. Hiding it lets two cards fit per viewport. */
.shared-list-card.is-hub-card .shared-open-btn {
  display: none;
}

.shared-list-card.is-hub-card::before {
  position: absolute;
  top: 9px;
  right: 9px;
  width: 26px;
  height: 2px;
  border-radius: 999px;
  background: linear-gradient(90deg, rgba(var(--neon-rgb), 0.12), rgba(var(--neon-strong-rgb), 0.38));
  content: "";
  pointer-events: none;
}

.shared-list-card:hover {
  transform: translateY(-2px);
  border-color: rgba(var(--neon-rgb), 0.36);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.82),
    0 18px 40px rgba(var(--neon-strong-rgb), 0.1);
}

.shared-status-note {
  grid-column: 1 / -1;
  border: 1px solid rgba(var(--neon-rgb), 0.22);
  border-radius: 18px;
  background:
    linear-gradient(145deg, rgba(255, 255, 255, 0.86), rgba(var(--neon-rgb), 0.1)),
    var(--panel);
  color: var(--muted);
  padding: 12px 14px;
  font-size: 0.84rem;
  font-weight: 850;
  line-height: 1.35;
}

.shared-skeleton-card {
  pointer-events: none;
}

.shared-skeleton-cover,
.shared-skeleton-lines i {
  display: block;
  overflow: hidden;
  border-radius: 14px;
  background:
    linear-gradient(105deg, rgba(255, 255, 255, 0.28) 0%, rgba(var(--neon-rgb), 0.16) 34%, rgba(255, 255, 255, 0.52) 50%, rgba(var(--neon-rgb), 0.12) 68%, rgba(255, 255, 255, 0.28) 100%),
    rgba(255, 255, 255, 0.58);
  background-size: 220% 100%;
  animation: skeletonGlide 1150ms ease-in-out infinite;
}

.shared-skeleton-cover {
  grid-column: 1;
  grid-row: 1 / span 3;
  min-height: 112px;
}

.shared-skeleton-lines {
  grid-column: 2;
  display: grid;
  gap: 8px;
  align-content: start;
  padding-top: 4px;
}

.shared-skeleton-lines i {
  height: 12px;
}

.shared-skeleton-lines i:nth-child(1) {
  width: 58%;
}

.shared-skeleton-lines i:nth-child(2) {
  width: 92%;
}

.shared-skeleton-lines i:nth-child(3) {
  width: 70%;
}

@keyframes skeletonGlide {
  0% {
    background-position: 120% 0;
  }

  100% {
    background-position: -120% 0;
  }
}

.shared-skeleton-section {
  display: grid;
  gap: 10px;
  animation: cardIn 280ms cubic-bezier(0.2, 0.85, 0.2, 1) both;
}

.shared-skeleton-section + .shared-skeleton-section {
  margin-top: 18px;
}

.shared-skeleton-section-title {
  display: block;
  width: clamp(120px, 38%, 200px);
  height: 18px;
  border-radius: 6px;
  background:
    linear-gradient(105deg, rgba(255, 255, 255, 0.28) 0%, rgba(var(--neon-rgb), 0.16) 34%, rgba(255, 255, 255, 0.52) 50%, rgba(var(--neon-rgb), 0.12) 68%, rgba(255, 255, 255, 0.28) 100%),
    rgba(255, 255, 255, 0.58);
  background-size: 220% 100%;
  animation: skeletonGlide 1150ms ease-in-out infinite;
}

.shared-empty-rich {
  grid-column: 1 / -1;
  display: grid;
  gap: 12px;
  justify-items: center;
  text-align: center;
  padding: 42px 24px 36px;
  border: 1px solid rgba(0, 0, 0, 0.08);
  border-radius: 24px;
  background:
    linear-gradient(160deg, rgba(255, 255, 255, 0.92), rgba(var(--neon-rgb), 0.08) 60%, rgba(var(--neon-rgb), 0.16)),
    var(--panel);
  box-shadow: 0 12px 28px rgba(31, 31, 31, 0.06);
  animation: cardIn 320ms cubic-bezier(0.2, 0.85, 0.2, 1) both;
}

.shared-empty-rich-icon {
  display: grid;
  place-items: center;
  width: 64px;
  height: 64px;
  border-radius: 50%;
  background:
    radial-gradient(circle at 30% 30%, rgba(255, 255, 255, 0.9), rgba(var(--neon-rgb), 0.18)),
    rgba(var(--neon-rgb), 0.12);
  font-size: 2rem;
  line-height: 1;
}

.shared-empty-rich-icon-tile {
  color: var(--ink);
}

/* Keep the inner shared-mini-icon at its native 28x28 transform-tuned size and
   let the 64x64 parent center it. Forcing 36x36 here causes the glyph
   transforms (translate(2px,2px), etc.) to anchor in the top-left corner of an
   oversized box, breaking visual centering. */
.shared-empty-rich-icon-tile .shared-mini-icon {
  width: 28px;
  height: 28px;
}

.shared-empty-rich-title {
  margin: 0;
  font-size: 1.08rem;
  font-weight: 950;
  letter-spacing: -0.014em;
  color: var(--ink);
}

.shared-empty-rich-body {
  margin: 0;
  max-width: 340px;
  font-size: 0.9rem;
  font-weight: 650;
  line-height: 1.45;
  color: var(--muted);
}

.shared-empty-rich-actions {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 8px;
  margin-top: 4px;
}

.shared-empty-rich-actions .primary-btn,
.shared-empty-rich-actions .secondary-btn {
  width: auto;
  min-width: 140px;
  padding-inline: 18px;
}

body[data-theme="noir"] .shared-empty-rich {
  background:
    linear-gradient(160deg, rgba(255, 255, 255, 0.05), rgba(255, 255, 255, 0.01)),
    var(--panel);
  border-color: rgba(255, 255, 255, 0.1);
}

body[data-theme="noir"] .shared-empty-rich-icon {
  background:
    radial-gradient(circle at 30% 30%, rgba(255, 255, 255, 0.16), rgba(var(--neon-rgb), 0.24)),
    rgba(var(--neon-rgb), 0.18);
}

.shared-scope-btn {
  position: relative;
}

.shared-scope-btn::before {
  content: "♥";
  margin-right: 6px;
  font-size: 0.9em;
  color: var(--neon-strong);
  vertical-align: -1px;
}

.shared-scope-btn.is-active {
  background: linear-gradient(135deg, rgba(var(--neon-strong-rgb), 0.18), rgba(var(--neon-rgb), 0.12));
  border-color: rgba(var(--neon-strong-rgb), 0.5);
  color: var(--ink);
}

.shared-empty-rich-icon-heart {
  color: var(--neon-strong);
}

.shared-similar {
  margin-top: 22px;
  display: grid;
  gap: 10px;
  animation: cardIn 320ms cubic-bezier(0.2, 0.85, 0.2, 1) both;
}

.shared-similar.is-hidden {
  display: none;
}

.shared-similar-title {
  margin: 0;
  font-size: 1rem;
  font-weight: 950;
  letter-spacing: -0.012em;
  color: var(--ink);
  display: flex;
  align-items: center;
  gap: 8px;
}

.shared-similar-title::before {
  content: "";
  display: inline-block;
  width: 5px;
  height: 16px;
  border-radius: 4px;
  background: linear-gradient(180deg, rgba(var(--neon-strong-rgb), 0.95), rgba(var(--neon-rgb), 0.7));
}

.shared-similar-strip {
  display: grid;
  gap: 8px;
}

.shared-similar-card {
  all: unset;
  display: grid;
  grid-template-columns: 36px 1fr auto;
  align-items: center;
  gap: 12px;
  padding: 10px 14px;
  border: 1px solid rgba(0, 0, 0, 0.08);
  border-radius: 18px;
  background: linear-gradient(145deg, rgba(255, 255, 255, 0.9), rgba(var(--neon-rgb), 0.06)), var(--panel);
  cursor: pointer;
  transition: transform 160ms ease, border-color 160ms ease, box-shadow 160ms ease;
}

.shared-similar-card:hover {
  border-color: rgba(var(--neon-rgb), 0.4);
  transform: translateY(-1px);
  box-shadow: 0 8px 20px rgba(31, 31, 31, 0.08);
}

.shared-similar-card:focus-visible {
  outline: 2px solid var(--neon-strong);
  outline-offset: 2px;
}

.shared-similar-icon {
  display: block;
  color: var(--ink);
  width: 36px;
  height: 36px;
}

.shared-similar-copy {
  display: grid;
  gap: 2px;
  min-width: 0;
}

.shared-similar-name {
  font-size: 0.94rem;
  font-weight: 900;
  color: var(--ink);
  letter-spacing: -0.008em;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.shared-similar-meta {
  font-size: 0.78rem;
  font-weight: 700;
  color: var(--muted);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.shared-similar-likes {
  font-size: 0.82rem;
  font-weight: 850;
  color: var(--muted);
  white-space: nowrap;
}

body[data-theme="noir"] .shared-similar-card {
  background: linear-gradient(145deg, rgba(255, 255, 255, 0.05), rgba(255, 255, 255, 0.01)), var(--panel);
  border-color: rgba(255, 255, 255, 0.1);
}

body[data-theme="noir"] .shared-similar-card:hover {
  border-color: rgba(var(--neon-rgb), 0.5);
}

.shared-list-cover {
  display: none;
}

.shared-list-card.is-hub-card .shared-list-cover {
  grid-column: 1;
  grid-row: 1 / span 3;
  position: relative;
  overflow: hidden;
  display: grid;
  place-items: center;
  min-height: 100%;
  max-height: 110px;
  border: 1px solid rgba(var(--neon-rgb), 0.2);
  border-radius: 14px;
  background:
    linear-gradient(145deg, rgba(var(--neon-rgb), 0.18), rgba(255, 255, 255, 0.78)),
    repeating-linear-gradient(135deg, rgba(var(--neon-strong-rgb), 0.08) 0 1px, transparent 1px 12px);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.76),
    0 10px 20px rgba(var(--neon-strong-rgb), 0.075);
}

.shared-list-card.is-hub-card .shared-list-cover {
  aspect-ratio: 1 / 1;
}

.shared-list-card.is-hub-card .shared-list-cover::after {
  position: absolute;
  inset: auto 7px 7px 7px;
  height: 22px;
  border-radius: 999px;
  background: linear-gradient(90deg, rgba(255, 255, 255, 0.72), rgba(var(--neon-rgb), 0.22));
  content: "";
  opacity: 0.7;
  pointer-events: none;
}

.shared-list-cover img {
  width: 100%;
  height: 100%;
  min-height: 0;
  object-fit: cover;
}

.shared-list-cover img.is-hidden {
  display: none;
}

.shared-list-cover .shared-list-icon {
  width: 46px;
  height: 46px;
  border-radius: 16px;
}

.shared-list-card.is-hub-card .shared-list-cover .shared-list-icon {
  display: none;
}

.shared-list-cover.has-image .shared-list-icon {
  position: absolute;
  right: 7px;
  bottom: 7px;
  width: 34px;
  height: 34px;
  border-radius: 13px;
  background: rgba(255, 255, 255, 0.82);
  box-shadow: 0 10px 18px rgba(0, 0, 0, 0.12);
}

.shared-list-card.is-hub-card > .shared-list-icon {
  display: none;
}

.shared-list-card.is-hub-card .shared-list-copy {
  grid-column: 2;
  grid-row: 1;
  align-content: start;
  gap: 4px;
  padding: 0 2px;
}

.shared-list-card.is-hub-card .shared-list-copy strong {
  display: -webkit-box;
  overflow: hidden;
  font-size: 0.94rem;
  line-height: 1.08;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
}

.shared-list-card.is-hub-card .shared-list-copy small {
  display: inline-flex;
  width: fit-content;
  border: 1px solid rgba(var(--neon-rgb), 0.18);
  border-radius: 999px;
  background: rgba(var(--neon-rgb), 0.08);
  color: var(--oxblood);
  font-size: 0.54rem;
  padding: 3px 6px;
}

.shared-list-card.is-hub-card .shared-list-copy > span {
  display: -webkit-box;
  overflow: hidden;
  color: var(--muted);
  font-size: 0.68rem;
  font-weight: 850;
  line-height: 1.2;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
}

.shared-hub-meta {
  grid-column: 2;
  grid-row: 2;
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 4px;
  margin-top: 2px;
}

.shared-hub-meta.is-hidden {
  display: none;
}

.shared-hub-meta span,
.hub-creator-link {
  display: inline-flex;
  width: auto;
  border: 0;
  border-radius: 999px;
  background: transparent;
  color: var(--muted);
  padding: 0;
  font: inherit;
  font-size: 0.56rem;
  font-weight: 950;
  line-height: 1.08;
  cursor: pointer;
  text-transform: uppercase;
}

.shared-hub-meta span {
  cursor: default;
}

.shared-like-btn {
  align-self: start;
  justify-self: end;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  min-height: 34px;
  border: 1.5px solid rgba(var(--neon-strong-rgb), 0.55);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.92);
  color: var(--ink);
  padding: 0 10px;
  font: inherit;
  font-size: 0.8rem;
  font-weight: 950;
  transition: transform 180ms ease, border-color 180ms ease, background 180ms ease, color 180ms ease, box-shadow 180ms ease;
}

.shared-like-btn::before {
  color: var(--oxblood);
  content: "\2661";
  font-size: 1.15rem;
  line-height: 1;
  font-weight: 900;
}

.shared-like-btn.is-liked {
  border-color: rgba(var(--neon-rgb), 0.4);
  background: rgba(var(--neon-rgb), 0.14);
  color: var(--ink);
  box-shadow: 0 8px 20px rgba(var(--neon-strong-rgb), 0.1);
}

.shared-like-btn.is-liked::before {
  content: "\2665";
  animation: favoritePop 520ms cubic-bezier(0.2, 0.9, 0.2, 1.16) both;
}

.shared-like-btn:hover {
  transform: translateY(-1px);
}

.shared-like-btn.is-hidden {
  display: none;
}

.shared-card-actions {
  grid-column: 2;
  grid-row: 3;
  align-self: end;
  display: flex;
  align-items: center;
  gap: 6px;
}

.shared-card-actions.is-hidden {
  display: none;
}

.shared-card-actions .shared-like-btn,
.shared-save-btn {
  flex: 1 1 0;
  justify-content: center;
}

.shared-card-actions .shared-like-btn {
  min-height: 32px;
  padding: 0 8px;
  font-size: 0.72rem;
}

.shared-save-btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  min-height: 32px;
  border: 1.5px solid rgba(var(--neon-strong-rgb), 0.55);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.92);
  color: var(--ink);
  padding: 0 10px;
  font: inherit;
  font-size: 0.72rem;
  font-weight: 950;
  transition: transform 180ms ease, border-color 180ms ease, background 180ms ease, color 180ms ease, box-shadow 180ms ease;
}

.shared-save-btn::before,
.hub-save-btn::before {
  color: var(--oxblood);
  content: "+";
  font-size: 1.15rem;
  line-height: 1;
  font-weight: 900;
}

.shared-save-btn.is-saved,
.hub-save-btn.is-saved {
  border-color: rgba(var(--neon-rgb), 0.42);
  background: rgba(var(--neon-rgb), 0.12);
  color: var(--ink);
}

.shared-save-btn.is-saved::before,
.hub-save-btn.is-saved::before {
  content: "\2713";
  animation: checkPop 420ms cubic-bezier(0.2, 0.9, 0.2, 1.16) both;
}

.shared-save-btn:hover {
  transform: translateY(-1px);
}

.shared-save-btn.is-hidden,
.shared-card-actions:empty {
  display: none;
}

.shared-list-card.is-recurring {
  border-color: rgba(var(--neon-rgb), 0.62);
  background:
    linear-gradient(135deg, rgba(var(--neon-rgb), 0.2), rgba(255, 255, 255, 0.82)),
    var(--panel);
  box-shadow:
    0 0 0 1px rgba(var(--neon-rgb), 0.18),
    0 0 24px rgba(255, 102, 178, 0.16),
    0 0 28px rgba(93, 157, 255, 0.12),
    0 18px 42px rgba(var(--neon-strong-rgb), 0.14);
  animation: recurringNeon 3.4s ease-in-out infinite alternate;
}

.shared-list-card.is-recurring::after {
  position: absolute;
  inset: 0;
  z-index: 0;
  border-radius: inherit;
  border: 1px solid transparent;
  background:
    linear-gradient(135deg, rgba(255, 112, 176, 0.72), rgba(96, 181, 255, 0.62), rgba(214, 178, 94, 0.54)) border-box;
  content: "";
  opacity: 0.55;
  pointer-events: none;
  mask:
    linear-gradient(#000 0 0) padding-box,
    linear-gradient(#000 0 0);
  mask-composite: exclude;
}

.shared-list-card.is-recurring > * {
  position: relative;
  z-index: 1;
}

.shared-list-icon {
  position: relative;
  display: grid;
  place-items: center;
  width: 58px;
  height: 58px;
  border: 1px solid rgba(var(--neon-rgb), 0.18);
  border-radius: 20px;
  background:
    linear-gradient(145deg, rgba(255, 255, 255, 0.82), rgba(var(--neon-rgb), 0.16)),
    var(--panel);
  color: var(--oxblood);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.72),
    0 12px 24px rgba(var(--neon-strong-rgb), 0.08);
}

.shared-mini-icon,
.shared-list-icon::before,
.shared-list-icon::after {
  position: relative;
  display: block;
  content: "";
}

.shared-mini-icon {
  position: relative;
  width: 28px;
  height: 28px;
  color: currentColor;
}

.shared-mini-icon::before,
.shared-mini-icon::after {
  position: absolute;
  display: block;
  content: "";
}

.shared-list-icon::before,
.shared-list-icon::after {
  color: currentColor;
}

.shared-mini-grocery::before,
.shared-list-icon[data-shared-icon="grocery"]::before {
  width: 23px;
  height: 14px;
  border: 3px solid currentColor;
  border-top: 0;
  border-radius: 0 0 7px 7px;
  transform: translate(2px, 2px) skewX(-14deg);
}

.shared-mini-grocery::after,
.shared-list-icon[data-shared-icon="grocery"]::after {
  position: absolute;
  left: 4px;
  bottom: 2px;
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: currentColor;
  box-shadow:
    15px 0 0 currentColor,
    -3px -21px 0 -1px currentColor;
  content: "";
}

.shared-mini-trip::before,
.shared-list-icon[data-shared-icon="trip"]::before {
  width: 30px;
  height: 28px;
  background:
    radial-gradient(ellipse at 50% 100%, transparent 0 45%, currentColor 46% 56%, transparent 57%) 1px 2px / 24px 13px no-repeat,
    linear-gradient(currentColor, currentColor) 13px 13px / 3px 13px no-repeat,
    radial-gradient(ellipse at 50% 100%, transparent 0 52%, currentColor 53% 64%, transparent 65%) 5px 21px / 20px 7px no-repeat;
  transform: rotate(-5deg);
}

.shared-mini-trip::after,
.shared-list-icon[data-shared-icon="trip"]::after {
  position: absolute;
  right: -2px;
  top: -1px;
  width: 8px;
  height: 8px;
  border: 2px solid currentColor;
  border-radius: 50%;
  box-shadow:
    0 -6px 0 -3px currentColor,
    0 6px 0 -3px currentColor,
    6px 0 0 -3px currentColor,
    -6px 0 0 -3px currentColor,
    4px 4px 0 -3px currentColor,
    -4px -4px 0 -3px currentColor;
  content: "";
}

.shared-mini-clothes::before,
.shared-list-icon[data-shared-icon="clothes"]::before {
  width: 26px;
  height: 22px;
  background: currentColor;
  clip-path: polygon(18% 8%, 35% 0, 43% 10%, 57% 10%, 65% 0, 82% 8%, 96% 34%, 80% 44%, 74% 28%, 74% 100%, 26% 100%, 26% 28%, 20% 44%, 4% 34%);
}

.shared-mini-clothes::after,
.shared-list-icon[data-shared-icon="clothes"]::after {
  position: absolute;
  top: 4px;
  width: 9px;
  height: 4px;
  border: 2px solid var(--panel);
  border-top: 0;
  border-radius: 0 0 8px 8px;
  content: "";
}

.shared-mini-home::before,
.shared-list-icon[data-shared-icon="home"]::before {
  width: 23px;
  height: 18px;
  border: 3px solid currentColor;
  border-top: 0;
  border-radius: 0 0 5px 5px;
  transform: translateY(6px);
}

.shared-mini-home::after,
.shared-list-icon[data-shared-icon="home"]::after {
  position: absolute;
  top: 3px;
  width: 20px;
  height: 20px;
  border-top: 3px solid currentColor;
  border-left: 3px solid currentColor;
  box-shadow: 8px 16px 0 -6px currentColor;
  transform: rotate(45deg);
  content: "";
}

.shared-mini-event::before,
.shared-list-icon[data-shared-icon="event"]::before {
  width: 25px;
  height: 22px;
  border: 3px solid currentColor;
  border-radius: 6px;
  transform: translateY(4px);
}

.shared-mini-event::after,
.shared-list-icon[data-shared-icon="event"]::after {
  position: absolute;
  top: 1px;
  width: 28px;
  height: 10px;
  border: 3px solid currentColor;
  border-radius: 8px 8px 4px 4px;
  background:
    linear-gradient(90deg, transparent 43%, currentColor 43% 57%, transparent 57%);
  box-shadow: 0 13px 0 -5px currentColor;
  content: "";
}

.shared-mini-other::before,
.shared-list-icon[data-shared-icon="other"]::before {
  width: 8px;
  height: 8px;
  border-radius: 3px;
  background: currentColor;
  box-shadow:
    11px 0 0 currentColor,
    0 11px 0 currentColor,
    11px 11px 0 currentColor;
}

.shared-mini-other::after,
.shared-list-icon[data-shared-icon="other"]::after {
  display: none;
}

.shared-mini-grocery,
.shared-list-icon[data-shared-icon="grocery"] {
  --shared-icon-mask: url("public/icons/shared/grocery.png?v=20260524-study-event-polish");
}

.shared-mini-trip,
.shared-list-icon[data-shared-icon="trip"] {
  --shared-icon-mask: url("public/icons/shared/trip.png?v=20260524-study-event-polish");
}

.shared-mini-clothes,
.shared-list-icon[data-shared-icon="clothes"] {
  --shared-icon-mask: url("public/icons/shared/clothes.png?v=20260524-study-event-polish");
}

.shared-mini-home,
.shared-list-icon[data-shared-icon="home"] {
  --shared-icon-mask: url("public/icons/shared/home.png?v=20260524-study-event-polish");
}

.shared-mini-event,
.shared-list-icon[data-shared-icon="event"] {
  --shared-icon-mask: url("public/icons/shared/event.png?v=20260524-study-event-polish");
}

.shared-mini-gift,
.shared-list-icon[data-shared-icon="gift"],
.shared-mini-tech,
.shared-list-icon[data-shared-icon="tech"],
.shared-mini-beauty,
.shared-list-icon[data-shared-icon="beauty"],
.shared-mini-study,
.shared-list-icon[data-shared-icon="study"] {
  /* Fallback guard; each icon below overrides this with its own mask. */
  --shared-icon-mask: url("public/icons/shared/other.png?v=20260524-study-event-polish");
}

.shared-mini-gift,
.shared-list-icon[data-shared-icon="gift"] {
  --shared-icon-mask: url("public/icons/shared/gift.png?v=20260524-study-event-polish");
}

.shared-mini-tech,
.shared-list-icon[data-shared-icon="tech"] {
  --shared-icon-mask: url("public/icons/shared/tech.png?v=20260524-study-event-polish");
}

.shared-mini-beauty,
.shared-list-icon[data-shared-icon="beauty"] {
  --shared-icon-mask: url("public/icons/shared/beauty.png?v=20260524-study-event-polish");
}

.shared-mini-study,
.shared-list-icon[data-shared-icon="study"] {
  --shared-icon-mask: url("public/icons/shared/study.png?v=20260524-study-event-polish");
}

.shared-mini-other,
.shared-list-icon[data-shared-icon="other"] {
  --shared-icon-mask: url("public/icons/shared/other.png?v=20260524-study-event-polish");
}

.shared-mini-icon::before,
.shared-list-icon[data-shared-icon]::before {
  width: 100% !important;
  height: 100% !important;
  border: 0 !important;
  border-radius: 0 !important;
  background: currentColor !important;
  box-shadow: none !important;
  clip-path: none !important;
  transform: none !important;
  -webkit-mask: var(--shared-icon-mask) center / contain no-repeat;
  mask: var(--shared-icon-mask) center / contain no-repeat;
}

.shared-mini-icon::after,
.shared-list-icon[data-shared-icon]::after {
  display: none !important;
}

.shared-list-copy {
  display: grid;
  gap: 5px;
  min-width: 0;
}

.shared-list-copy strong {
  overflow: hidden;
  color: var(--ink);
  font-size: 1rem;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.shared-list-copy small {
  color: var(--oxblood);
  font-size: 0.72rem;
  font-weight: 950;
  text-transform: uppercase;
}

.shared-list-copy span,
.shared-empty {
  color: var(--muted);
  font-size: 0.86rem;
  font-weight: 800;
}

.shared-list-card .secondary-btn {
  grid-column: 1 / -1;
  width: 100%;
}

.shared-list-card.is-hub-card .secondary-btn {
  grid-column: 1 / -1;
}

.shared-detail-panel.is-hidden,
.shared-create-panel.is-hidden {
  display: none;
}

.shared-detail-head {
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: 12px;
}

.shared-detail-panel.is-hub-preview .shared-detail-head {
  position: sticky;
  top: 8px;
  z-index: 4;
  border: 1px solid rgba(var(--neon-rgb), 0.14);
  border-radius: 22px;
  background: rgba(255, 255, 255, 0.76);
  padding: 8px;
  -webkit-backdrop-filter: blur(18px);
  backdrop-filter: blur(18px);
  box-shadow: 0 12px 28px rgba(47, 52, 55, 0.08);
}

.shared-detail-panel.is-hub-preview #closeSharedDetailBtn {
  display: grid;
  place-items: center;
  width: 44px;
  min-width: 44px;
  height: 44px;
  overflow: hidden;
  border-radius: 50%;
  color: var(--ink);
  font-family: var(--font-ui);
  font-size: 2rem;
  font-weight: 700;
  line-height: 1;
}

.shared-detail-panel.is-hub-preview #closeSharedDetailBtn::before {
  display: none;
}

.shared-detail-hero {
  display: grid;
  grid-template-columns: minmax(180px, 0.72fr) minmax(0, 1fr);
  gap: 14px;
  align-items: stretch;
}

.shared-detail-hero.is-hub-preview {
  border: 1px solid rgba(var(--neon-rgb), 0.16);
  border-radius: 28px;
  background:
    linear-gradient(145deg, rgba(255, 255, 255, 0.78), rgba(var(--neon-rgb), 0.08)),
    rgba(255, 255, 255, 0.58);
  padding: 10px;
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.66),
    0 16px 42px rgba(var(--neon-strong-rgb), 0.08);
}

.shared-detail-hero.is-creator-profile {
  border: 1px solid rgba(var(--neon-rgb), 0.14);
  border-radius: 28px;
  background:
    radial-gradient(circle at 12% 10%, rgba(var(--neon-rgb), 0.18), transparent 30%),
    linear-gradient(145deg, rgba(255, 255, 255, 0.76), rgba(255, 255, 255, 0.58));
  padding: 10px;
}

.shared-detail-cover {
  position: relative;
  overflow: hidden;
  min-height: 240px;
  border: 1px solid rgba(var(--neon-rgb), 0.18);
  border-radius: 26px;
  background:
    linear-gradient(145deg, rgba(var(--neon-rgb), 0.16), rgba(255, 255, 255, 0.72)),
    repeating-linear-gradient(135deg, rgba(var(--neon-strong-rgb), 0.08) 0 1px, transparent 1px 14px);
  box-shadow: 0 18px 46px rgba(var(--neon-strong-rgb), 0.12);
}

.shared-detail-cover::after {
  position: absolute;
  inset: auto 12px 12px 12px;
  height: 34%;
  border-radius: 22px;
  background: linear-gradient(180deg, transparent, rgba(18, 18, 18, 0.24));
  content: "";
  opacity: 0.36;
  pointer-events: none;
}

.shared-detail-cover img {
  width: 100%;
  height: 100%;
  min-height: 240px;
  object-fit: cover;
}

.shared-detail-cover img.is-hidden {
  display: none;
}

.shared-detail-cover .shared-list-icon {
  position: absolute;
  right: 14px;
  bottom: 14px;
  z-index: 1;
  width: 58px;
  height: 58px;
  background: rgba(255, 255, 255, 0.84);
  -webkit-backdrop-filter: blur(10px);
  backdrop-filter: blur(10px);
}

.shared-detail-hero-copy {
  display: grid;
  align-content: end;
  gap: 12px;
  min-width: 0;
}

.shared-detail-stats {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}

.shared-detail-stats span {
  display: grid;
  gap: 6px;
  min-height: 74px;
  border: 1px solid rgba(var(--neon-rgb), 0.16);
  border-radius: 20px;
  background:
    linear-gradient(145deg, rgba(255, 255, 255, 0.78), rgba(var(--neon-rgb), 0.055)),
    rgba(255, 255, 255, 0.66);
  padding: 11px;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.62);
}

.shared-detail-stats small {
  overflow: hidden;
  color: var(--muted);
  font-size: 0.68rem;
  font-weight: 950;
  text-overflow: ellipsis;
  text-transform: uppercase;
  white-space: nowrap;
}

.shared-detail-stats strong {
  overflow: hidden;
  color: var(--ink);
  font-size: 1rem;
  line-height: 1.1;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.shared-detail-hint {
  margin: 0;
  color: var(--muted);
  font-size: 0.82rem;
  font-weight: 800;
}

.shared-detail-panel.is-hub-preview #sharedDetailTitle {
  margin: 0;
  font-family: var(--font-serif);
  font-size: clamp(1.55rem, 4vw, 2.85rem);
  line-height: 0.98;
}

.shared-detail-panel.is-hub-preview #sharedDetailMeta {
  max-width: 58ch;
  font-weight: 850;
}

.shared-detail-actions {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 8px;
}

.hub-safety-btn {
  min-height: 40px;
}

.hub-creator-profile-btn {
  border-color: rgba(var(--neon-rgb), 0.32);
  background: rgba(var(--neon-rgb), 0.1);
}

.shared-recurring-toggle {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  min-height: 44px;
  border: 1px solid rgba(var(--neon-rgb), 0.24);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.7);
  color: var(--ink);
  padding: 0 13px;
  font-size: 0.82rem;
  font-weight: 950;
}

.shared-recurring-toggle input {
  width: 18px;
  min-height: 18px;
  accent-color: var(--oxblood);
}

.shared-add-row {
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr) auto;
}

.shared-members-list {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 8px;
  border: 1px solid rgba(var(--neon-rgb), 0.18);
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.58);
  padding: 10px;
}

.shared-members-list.is-hidden {
  display: none;
}

.shared-members-title {
  width: 100%;
  margin: 0;
  color: var(--muted);
  font-size: 0.72rem;
  font-weight: 950;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.shared-member-chip {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  max-width: 100%;
  border: 1px solid rgba(var(--neon-rgb), 0.18);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.72);
  color: var(--ink);
  padding: 7px 10px;
  font-size: 0.78rem;
  font-weight: 850;
}

.shared-member-chip strong {
  overflow: hidden;
  max-width: min(280px, 62vw);
  text-overflow: ellipsis;
  white-space: nowrap;
}

.shared-member-chip small {
  border-radius: 999px;
  background: rgba(var(--neon-rgb), 0.12);
  color: var(--oxblood);
  padding: 3px 7px;
  font-size: 0.66rem;
  font-weight: 950;
  text-transform: uppercase;
}

.shared-items-list {
  display: grid;
  gap: 8px;
}

.shared-items-list.creator-profile-lists {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  align-items: start;
  gap: 10px;
}

.shared-items-list.creator-profile-lists .shared-list-card {
  min-height: 100%;
}

.shared-item-row {
  position: relative;
  overflow: hidden;
  display: grid;
  grid-template-columns: 52px minmax(0, 1fr) auto auto;
  align-items: center;
  gap: 11px;
  border: 1px solid var(--line);
  min-height: 72px;
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.68);
  padding: 9px 12px 9px 9px;
}

.shared-detail-panel.is-hub-preview .shared-item-row {
  border-color: rgba(var(--neon-rgb), 0.16);
  background:
    linear-gradient(145deg, rgba(255, 255, 255, 0.84), rgba(var(--neon-rgb), 0.045)),
    rgba(255, 255, 255, 0.68);
  box-shadow: 0 10px 24px rgba(var(--neon-strong-rgb), 0.055);
}

.shared-detail-panel.is-hub-preview .shared-item-row::after {
  position: absolute;
  right: 12px;
  top: 11px;
  width: 18px;
  height: 2px;
  border-radius: 999px;
  background: rgba(var(--neon-rgb), 0.36);
  content: "";
  pointer-events: none;
}

.shared-item-thumb {
  position: relative;
  overflow: hidden;
  display: grid;
  place-items: center;
  width: 52px;
  height: 52px;
  border: 1px solid rgba(var(--neon-rgb), 0.16);
  border-radius: 15px;
  background:
    linear-gradient(145deg, rgba(var(--neon-rgb), 0.14), rgba(255, 255, 255, 0.76)),
    var(--panel);
}

.shared-item-thumb::before {
  color: rgba(111, 29, 50, 0.72);
  content: "WD";
  font-family: var(--font-serif);
  font-size: 1.05rem;
  font-weight: 700;
  opacity: 0.58;
}

.shared-item-thumb.has-image::before,
.shared-item-thumb img.is-hidden {
  display: none;
}

.shared-item-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.shared-item-copy {
  display: grid;
  gap: 3px;
  min-width: 0;
}

.shared-item-name {
  min-width: 0;
  overflow: hidden;
  color: var(--ink);
  font-weight: 900;
  line-height: 1.12;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.shared-item-row strong {
  color: var(--oxblood);
  font-size: 0.88rem;
  line-height: 1.1;
}

.shared-item-row a {
  color: var(--oxblood);
  font-size: 0.78rem;
  font-weight: 950;
  text-transform: uppercase;
}

.shared-item-row a:empty {
  display: none;
}

.shared-remove-item {
  width: 34px;
  height: 34px;
  min-height: 34px;
  padding: 0;
  color: var(--oxblood);
}

.section-kicker {
  margin: 0 0 4px;
  color: var(--muted);
  font-size: 0.76rem;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: 0.12em;
}

.switcher-head h2 {
  margin: 0;
  font-family: var(--font-display);
  font-size: 1.55rem;
  font-weight: 500;
}

.switcher-actions {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 10px;
}

.wishlist-tabs {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(210px, 1fr));
  gap: 10px;
  overflow-x: auto;
  padding: 2px 2px 6px;
  scrollbar-width: thin;
}

.wishlist-tab {
  display: grid;
  grid-template-columns: auto 1fr;
  align-items: center;
  column-gap: 10px;
  row-gap: 2px;
  min-width: 0;
  min-height: 92px;
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  background: rgba(255, 255, 255, 0.72);
  color: var(--ink);
  padding: 10px 12px;
  text-align: left;
  overflow: hidden;
  box-shadow: 0 10px 30px rgba(47, 52, 55, 0.06);
  transition:
    background 180ms ease,
    border-color 180ms ease,
    box-shadow 180ms ease,
    transform 180ms ease;
}

.wishlist-tab:hover {
  transform: translateY(-1px);
  border-color: rgba(111, 29, 50, 0.24);
}

/* Drag-to-reorder: lifted source + animated drop target hint. */
.wishlist-tab[draggable="true"] {
  cursor: grab;
}

.wishlist-tab[draggable="true"]:active {
  cursor: grabbing;
}

.wishlist-tab.is-dragging {
  opacity: 0.55;
  transform: scale(0.96) rotate(-1deg);
  border-color: rgba(var(--neon-strong-rgb), 0.6);
  box-shadow: 0 24px 60px rgba(var(--neon-strong-rgb), 0.25);
  z-index: 2;
}

.wishlist-tab.is-drop-target {
  border-color: rgba(var(--neon-strong-rgb), 0.7);
  background:
    linear-gradient(145deg, rgba(255, 255, 255, 0.96), rgba(var(--neon-rgb), 0.18)),
    rgba(255, 255, 255, 0.86);
  transform: translateY(-2px) scale(1.02);
  box-shadow: 0 22px 48px rgba(var(--neon-strong-rgb), 0.18);
}

.wishlist-tab.is-drop-target::after {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  border: 2px dashed rgba(var(--neon-strong-rgb), 0.7);
  pointer-events: none;
  animation: dropTargetPulse 800ms ease-in-out infinite alternate;
}

@keyframes dropTargetPulse {
  from { opacity: 0.55; }
  to { opacity: 1; }
}

.wishlist-tab.is-primary .tab-icon::after {
  /* Tiny indicator that the primary list is the home base. */
  content: "•";
  position: absolute;
  top: -2px;
  right: -2px;
  width: 10px;
  height: 10px;
  display: grid;
  place-items: center;
  border-radius: 999px;
  background: var(--oxblood);
  color: white;
  font-size: 12px;
  line-height: 1;
}

.wishlist-tab.is-primary .tab-icon {
  position: relative;
}

.wishlist-tab.is-active {
  /* Selected list now reads unmistakably: thicker accented border, neon-tinted
     fill, slight scale-up, accent line on the left edge and stronger shadow. */
  border: 2px solid rgba(var(--neon-strong-rgb), 0.85);
  background:
    linear-gradient(135deg, rgba(var(--neon-rgb), 0.22), rgba(255, 255, 255, 0.96)),
    var(--panel);
  box-shadow:
    inset 4px 0 0 rgba(var(--neon-strong-rgb), 0.95),
    0 18px 42px rgba(var(--neon-strong-rgb), 0.22);
  transform: translateY(-1px);
}

.wishlist-tab.is-active .tab-label {
  color: var(--ink);
  font-weight: 950;
}

body[data-theme="noir"] .wishlist-tab.is-active {
  /* Coral glow against the deep panel — the active tab pops in the dark UI. */
  background:
    linear-gradient(135deg, rgba(255, 158, 179, 0.22), rgba(255, 255, 255, 0.06)),
    var(--blush);
  box-shadow:
    inset 4px 0 0 rgba(255, 158, 179, 0.95),
    0 18px 42px rgba(230, 107, 138, 0.32);
}

.wishlist-tab.is-system .tab-icon {
  background:
    linear-gradient(135deg, rgba(111, 29, 50, 0.95), rgba(200, 121, 141, 0.78)),
    var(--oxblood);
  color: white;
  box-shadow: 0 12px 24px rgba(111, 29, 50, 0.16);
}

.tab-icon,
.dock-icon {
  display: inline-grid;
  place-items: center;
  width: 38px;
  height: 38px;
  border-radius: 15px;
  border: 1.5px solid rgba(var(--neon-strong-rgb), 0.42);
  background:
    linear-gradient(135deg, rgba(244, 223, 229, 0.95), rgba(220, 230, 223, 0.86)),
    var(--panel);
  color: var(--ink);
  font-size: 0.76rem;
  font-weight: 950;
  letter-spacing: 0.04em;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.7);
}

.tab-label {
  overflow: hidden;
  color: var(--ink);
  font-weight: 900;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.tab-count {
  grid-column: 2;
  color: var(--muted);
  font-size: 0.78rem;
  font-weight: 800;
}

/* Per-card share state badge + share button. Together they make it obvious
   each list has its own sharing setup, not one global setting at the bottom. */
.tab-share-badge {
  grid-column: 2;
  justify-self: start;
  display: inline-flex;
  align-items: center;
  padding: 2px 9px;
  border-radius: 999px;
  font-size: 0.66rem;
  font-weight: 950;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  border: 1px solid rgba(var(--neon-rgb), 0.22);
  background: rgba(255, 255, 255, 0.78);
  color: var(--muted);
  margin-top: 2px;
}

.tab-share-badge[data-state="public"] {
  border-color: rgba(var(--neon-strong-rgb), 0.55);
  background: linear-gradient(145deg, rgba(var(--neon-rgb), 0.34), rgba(var(--neon-strong-rgb), 0.18));
  color: var(--oxblood);
}

.tab-share-badge[data-state="synced"] {
  border-color: rgba(74, 144, 226, 0.6);
  background: rgba(74, 144, 226, 0.16);
  color: #2d5b9c;
}

.tab-share-action {
  grid-column: 1 / -1;
  margin-top: 6px;
  border: 1px solid rgba(var(--neon-rgb), 0.32);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.86);
  color: var(--oxblood);
  padding: 6px 14px;
  font-size: 0.78rem;
  font-weight: 800;
  cursor: pointer;
  transition: background 160ms ease, transform 160ms ease, border-color 160ms ease;
}

.tab-share-action:hover {
  background: linear-gradient(145deg, rgba(var(--neon-rgb), 0.22), rgba(var(--neon-strong-rgb), 0.18));
  border-color: rgba(var(--neon-strong-rgb), 0.5);
  transform: translateY(-1px);
}

/* "Pulsing" highlight applied to the share panel after the user clicks a
   per-card Share button, so it is obvious that the panel below now applies
   to the chosen list. */
.personal-share-panel.is-pulsing {
  animation: sharePanelPulse 1100ms ease-out 1;
}

@keyframes sharePanelPulse {
  0% { box-shadow: 0 0 0 0 rgba(var(--neon-strong-rgb), 0); }
  35% { box-shadow: 0 0 0 8px rgba(var(--neon-strong-rgb), 0.32); }
  100% { box-shadow: 0 0 0 0 rgba(var(--neon-strong-rgb), 0); }
}

.personal-share-heading {
  margin: 0;
  display: flex;
  align-items: baseline;
  gap: 8px;
  flex-wrap: wrap;
  color: var(--ink);
  font-size: 1.08rem;
}

.personal-share-list-name {
  color: var(--oxblood);
  font-weight: 950;
  letter-spacing: -0.01em;
}

.create-list-panel {
  display: grid;
  grid-template-columns: 1fr auto auto;
  gap: 10px;
  padding-top: 2px;
  animation: panelRise 220ms ease both;
}

.create-list-panel.is-hidden {
  display: none;
}

.capture-panel {
  padding: 14px;
}

.link-row {
  display: grid;
  grid-template-columns: 1fr auto auto;
  gap: 10px;
}

input,
select,
textarea {
  width: 100%;
  border: 1px solid var(--line);
  border-radius: 14px;
  background: var(--panel);
  color: var(--ink);
  outline: none;
  padding: 0 14px;
  transition:
    border-color 160ms ease,
    box-shadow 160ms ease,
    background 160ms ease,
    color 160ms ease;
}

input:-webkit-autofill,
input:-webkit-autofill:hover,
input:-webkit-autofill:focus {
  -webkit-text-fill-color: var(--ink);
  box-shadow: 0 0 0 1000px var(--panel) inset;
  caret-color: var(--ink);
  transition: background-color 9999s ease-in-out 0s;
}

input:focus,
select:focus,
textarea:focus {
  border-color: var(--rose);
  box-shadow: 0 0 0 4px rgba(var(--focus-rgb), 0.16);
}

input,
select {
  min-height: 46px;
}

textarea {
  min-height: 86px;
  padding: 12px 14px;
  resize: vertical;
}

.primary-btn,
.secondary-btn,
.text-btn,
.icon-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  max-width: 100%;
  min-width: 0;
  min-height: 44px;
  border: 0;
  border-radius: 999px;
  padding: 8px 16px;
  font-weight: 800;
  line-height: 1.12;
  text-align: center;
  /* Keep button labels on a single line — falling back to ellipsis if the
     container forces it. Multi-line labels like "Detal/hes" or
     "Adicionar/desejo" used to render when label + container were close. */
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  transition:
    background 180ms ease,
    border-color 180ms ease,
    color 180ms ease,
    box-shadow 180ms ease,
    transform 180ms ease,
    opacity 180ms ease;
}

.primary-btn::before,
.secondary-btn::before,
.dock-action::before {
  position: absolute;
  inset: 1px auto 1px -62%;
  z-index: 0;
  width: 58%;
  border-radius: inherit;
  background: linear-gradient(105deg, transparent, rgba(255, 255, 255, 0.34), transparent);
  content: "";
  opacity: 0;
  pointer-events: none;
  transform: skewX(-18deg);
  transition: opacity 180ms ease, translate 300ms ease;
}

.primary-btn:hover::before,
.secondary-btn:hover::before,
.dock-action:hover::before,
.primary-btn:focus-visible::before,
.secondary-btn:focus-visible::before,
.dock-action:focus-visible::before {
  opacity: 1;
  translate: 220% 0;
}

.primary-btn > *,
.secondary-btn > *,
.dock-action > * {
  position: relative;
  z-index: 1;
}

.primary-btn:active,
.secondary-btn:active,
.icon-btn:active,
.wishlist-tab:active,
.dock-nav-btn:active,
.dock-action:active {
  transform: scale(0.97);
}

.primary-btn {
  background: linear-gradient(180deg, #252525, #101010);
  color: white;
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.2),
    0 12px 28px rgba(23, 23, 23, 0.2);
}

.primary-btn:hover {
  background: var(--oxblood);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.24),
    0 16px 34px rgba(var(--neon-strong-rgb), 0.18);
  transform: translateY(-1px);
}

.primary-btn:disabled {
  cursor: wait;
  opacity: 0.72;
}

.secondary-btn {
  border: 1px solid var(--line);
  background: rgba(255, 255, 255, 0.78);
  color: var(--ink);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.8);
}

.secondary-btn:hover {
  border-color: var(--rose);
  background: color-mix(in srgb, var(--panel) 92%, var(--blush) 8%);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.84),
    0 12px 26px rgba(var(--neon-strong-rgb), 0.1);
  transform: translateY(-1px);
}

.secondary-btn:disabled {
  cursor: not-allowed;
  opacity: 0.42;
}

.danger-btn {
  color: var(--oxblood);
}

.compact-btn {
  min-width: 84px;
}

.text-btn {
  min-height: auto;
  background: transparent;
  color: var(--oxblood);
  padding: 0;
}

.confirm-overlay {
  position: fixed;
  inset: 0;
  z-index: 80;
  display: grid;
  place-items: center;
  padding: 22px;
  background:
    radial-gradient(circle at 50% 42%, rgba(var(--neon-rgb), 0.13), transparent 34%),
    rgba(18, 14, 17, 0.34);
  -webkit-backdrop-filter: blur(16px);
  backdrop-filter: blur(16px);
  animation: confirmOverlayIn 180ms ease both;
}

.confirm-overlay.is-hidden {
  display: none;
}

.confirm-overlay.is-leaving {
  animation: confirmOverlayOut 160ms ease both;
}

.confirm-card {
  position: relative;
  display: grid;
  gap: 16px;
  width: min(100%, 420px);
  border: 1px solid rgba(255, 255, 255, 0.68);
  border-radius: var(--radius-lg);
  background:
    linear-gradient(145deg, rgba(255, 255, 255, 0.94), rgba(248, 235, 239, 0.9)),
    var(--panel);
  padding: 20px;
  box-shadow:
    0 34px 90px rgba(47, 52, 55, 0.28),
    0 0 0 1px rgba(var(--neon-rgb), 0.1);
  transform-origin: center;
  animation: confirmCardIn 240ms cubic-bezier(0.2, 0.9, 0.2, 1.1) both;
}

.confirm-overlay.is-leaving .confirm-card {
  animation: confirmCardOut 150ms ease both;
}

.confirm-icon {
  display: grid;
  place-items: center;
  width: 58px;
  height: 58px;
  border-radius: 21px;
  background:
    linear-gradient(145deg, rgba(166, 49, 66, 0.96), rgba(111, 29, 50, 0.92)),
    #a63142;
  color: white;
  font-weight: 950;
  box-shadow:
    0 18px 40px rgba(111, 29, 50, 0.22),
    0 0 0 8px rgba(166, 49, 66, 0.08);
  animation: confirmIconPulse 1.65s ease-in-out infinite alternate;
}

.confirm-overlay[data-tone="signout"] .confirm-icon {
  background:
    linear-gradient(145deg, rgba(var(--neon-strong-rgb), 0.9), rgba(166, 49, 66, 0.9)),
    #a63142;
}

.confirm-copy {
  display: grid;
  gap: 8px;
}

.confirm-copy h2 {
  margin: 0;
  font-family: var(--font-display);
  font-size: 1.6rem;
  font-weight: 500;
  line-height: 1.08;
}

.confirm-copy p:last-child {
  margin: 0;
  color: var(--muted);
  line-height: 1.5;
}

.confirm-input-wrap {
  display: grid;
  gap: 8px;
  animation: panelRise 180ms ease both;
}

.confirm-input-wrap.is-hidden {
  display: none;
}

.confirm-input-wrap span {
  color: var(--muted);
  font-size: 0.76rem;
  font-weight: 950;
  text-transform: uppercase;
}

.confirm-input-wrap input {
  width: 100%;
  min-height: 48px;
  border: 1px solid rgba(var(--neon-rgb), 0.28);
  border-radius: 16px;
  background: rgba(255, 255, 255, 0.76);
  color: var(--ink);
  font: inherit;
  font-weight: 850;
  outline: none;
  padding: 0 14px;
  transition: border-color 160ms ease, box-shadow 160ms ease, background 160ms ease;
}

.confirm-input-wrap input:focus {
  border-color: rgba(var(--neon-rgb), 0.54);
  background: rgba(255, 255, 255, 0.96);
  box-shadow: 0 0 0 4px rgba(var(--neon-rgb), 0.12);
}

.confirm-actions {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1.1fr);
  gap: 10px;
}

.confirm-actions button {
  width: 100%;
}

.confirm-accept-btn {
  background:
    linear-gradient(180deg, rgba(166, 49, 66, 0.98), rgba(111, 29, 50, 0.98)),
    #a63142;
  color: white;
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.2),
    0 16px 34px rgba(111, 29, 50, 0.22),
    0 0 0 0 rgba(166, 49, 66, 0.2);
  animation: confirmButtonGlow 1.8s ease-in-out infinite alternate;
}

body[data-theme="noir"] .confirm-card {
  border-color: rgba(255, 255, 255, 0.12);
  background:
    linear-gradient(145deg, rgba(36, 36, 40, 0.96), rgba(28, 28, 32, 0.94)),
    var(--panel);
}

body[data-theme="noir"] .confirm-accept-btn,
body[data-theme="noir"] #signOutBtn,
body[data-theme="noir"] .danger-zone .danger-btn:not(:disabled) {
  border-color: rgba(255, 255, 255, 0.2);
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.1), rgba(255, 255, 255, 0.03)),
    #1c1c1f;
  color: var(--ink);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.1),
    0 16px 34px rgba(0, 0, 0, 0.26);
}

body[data-theme="noir"] .confirm-icon {
  /* Antes era um disco prata gradiente — o cinza que mais destoava no dark.
     Agora: chip neutro elevado com glifo claro, na mesma escada dos cards. */
  background: linear-gradient(145deg, #2e2e33, #232327);
  color: var(--ink);
  box-shadow:
    0 18px 40px rgba(0, 0, 0, 0.28),
    0 0 0 8px rgba(255, 255, 255, 0.04);
}

.capture-meta {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  min-height: 30px;
  margin-top: 10px;
  color: var(--muted);
  font-size: 0.92rem;
}

.paste-hint {
  margin: 8px 2px 0;
  color: var(--oxblood);
  font-size: 0.86rem;
  font-weight: 850;
  line-height: 1.4;
}

.capture-meta span[data-tone="error"] {
  color: var(--oxblood);
}

.capture-meta span[data-tone="success"] {
  color: #426452;
}

.capture-meta span.status-flash {
  animation: statusFlash 480ms ease both;
}

.flow-state {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 8px;
  margin: 12px 0 0;
  padding: 0;
  list-style: none;
}

.flow-state li {
  min-height: 34px;
  border: 1px solid var(--line);
  border-radius: 14px;
  background: rgba(255, 255, 255, 0.7);
  color: var(--muted);
  display: grid;
  place-items: center;
  font-size: 0.78rem;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.flow-state li.is-active {
  border-color: rgba(111, 29, 50, 0.3);
  background: rgba(111, 29, 50, 0.08);
  color: var(--oxblood);
}

.review-panel {
  display: grid;
  grid-template-columns: minmax(220px, 330px) 1fr;
  gap: 18px;
  padding: 16px;
}

.review-panel.is-hidden {
  display: none;
}

.review-image-wrap {
  position: relative;
  overflow: hidden;
  min-height: 310px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background:
    linear-gradient(135deg, rgba(244, 223, 229, 0.8), rgba(220, 230, 223, 0.8)),
    var(--panel);
}

.review-image-wrap img,
.card-image {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.review-image-wrap img.is-hidden,
.card-image.is-hidden {
  display: none;
}

.image-fallback,
.card-image-placeholder {
  position: absolute;
  inset: 0;
  display: grid;
  place-items: center;
  color: rgba(23, 23, 23, 0.46);
  font-family: var(--font-display);
  font-size: 3rem;
}

.image-fallback.is-hidden,
.card-image-placeholder.is-hidden {
  display: none;
}

.review-form {
  display: grid;
  gap: 14px;
}

.review-notice {
  display: none;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: rgba(251, 250, 248, 0.72);
  color: var(--muted);
  padding: 12px;
  font-size: 0.92rem;
  line-height: 1.4;
}

.review-notice.is-visible {
  display: block;
}

.review-notice[data-tone="warning"] {
  border-color: rgba(185, 147, 86, 0.32);
  background: rgba(185, 147, 86, 0.1);
  color: #75562a;
}

.review-notice[data-tone="success"] {
  border-color: rgba(66, 100, 82, 0.24);
  background: rgba(220, 230, 223, 0.55);
  color: #426452;
}

.form-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}

.review-advanced-field {
  display: none;
}

label {
  display: grid;
  gap: 7px;
  color: var(--graphite);
  font-size: 0.82rem;
  font-weight: 800;
}

.required-mark {
  color: var(--muted);
  font-size: 0.72rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

input[aria-invalid="true"] {
  border-color: var(--oxblood);
  box-shadow: 0 0 0 4px rgba(111, 29, 50, 0.12);
}

.span-2 {
  grid-column: span 2;
}

.form-error {
  min-height: 20px;
  margin: 0;
  color: var(--oxblood);
  font-size: 0.9rem;
  font-weight: 800;
}

.form-actions {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 10px;
}

.tools-row {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  padding: 12px;
  box-shadow: none;
}

.search-wrap {
  flex: 1 1 260px;
}

.tools-row select {
  flex: 1 1 150px;
  max-width: 190px;
}

.tools-row button {
  flex: 0 0 auto;
  min-width: 138px;
}

.density-toggle {
  display: inline-grid;
  place-items: center;
  flex: 0 0 48px;
  width: 48px;
  min-width: 48px;
  min-height: 48px;
  border: 1px solid var(--line);
  border-radius: 16px;
  background:
    linear-gradient(145deg, rgba(255, 255, 255, 0.86), rgba(var(--neon-rgb), 0.08)),
    var(--panel);
  color: var(--oxblood);
  box-shadow: 0 12px 28px rgba(47, 52, 55, 0.08);
  transition:
    border-color 180ms ease,
    box-shadow 180ms ease,
    transform 180ms ease,
    background 180ms ease;
}

.density-toggle:hover,
.density-toggle.is-active {
  border-color: rgba(var(--neon-rgb), 0.46);
  box-shadow:
    0 0 0 1px rgba(var(--neon-rgb), 0.16),
    0 14px 34px rgba(var(--neon-strong-rgb), 0.14);
  transform: translateY(-1px);
}

.density-icon {
  display: grid;
  grid-template-columns: repeat(2, 8px);
  gap: 4px;
  transition: gap 180ms ease, grid-template-columns 180ms ease;
}

.density-icon i {
  display: block;
  width: 8px;
  height: 8px;
  border-radius: 3px;
  background: currentColor;
}

.density-toggle.is-active .density-icon {
  grid-template-columns: 20px;
  gap: 3px;
}

.density-toggle.is-active .density-icon i {
  width: 20px;
  height: 4px;
  border-radius: 999px;
}

.wishlist-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 16px;
}

.wishlist-grid.is-list-directory {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  align-items: start;
}

body[data-wishlist-density="compact"] #wishlistGrid.is-list-directory {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.wishlist-directory-card {
  display: grid;
  grid-template-columns: 82px minmax(0, 1fr);
  gap: 12px;
  align-items: center;
  border: 1px solid rgba(var(--neon-rgb), 0.18);
  border-radius: 22px;
  background:
    linear-gradient(145deg, rgba(255, 255, 255, 0.9), rgba(var(--neon-rgb), 0.06)),
    var(--panel);
  padding: 12px;
  box-shadow: 0 14px 34px rgba(var(--neon-strong-rgb), 0.075);
  animation: cardIn 260ms cubic-bezier(0.2, 0.85, 0.2, 1) both;
  animation-delay: calc(var(--card-index, 0) * 34ms);
  cursor: pointer;
}

.wishlist-directory-cover {
  position: relative;
  overflow: hidden;
  display: grid;
  place-items: center;
  width: 82px;
  height: 82px;
  border: 1px solid rgba(var(--neon-rgb), 0.18);
  border-radius: 18px;
  background:
    linear-gradient(145deg, rgba(var(--neon-rgb), 0.16), rgba(255, 255, 255, 0.8)),
    var(--panel);
}

.wishlist-directory-cover img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.wishlist-directory-cover span {
  color: var(--oxblood);
  font-size: 0.9rem;
  font-weight: 950;
}

.wishlist-directory-copy {
  display: grid;
  gap: 5px;
  min-width: 0;
}

.wishlist-directory-copy small {
  color: var(--oxblood);
  font-size: 0.66rem;
  font-weight: 950;
  text-transform: uppercase;
}

.wishlist-directory-copy strong {
  overflow: hidden;
  color: var(--ink);
  font-size: 1.05rem;
  line-height: 1.1;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.wishlist-directory-copy p {
  margin: 0;
  overflow: hidden;
  color: var(--muted);
  font-size: 0.82rem;
  font-weight: 800;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.wishlist-directory-card .secondary-btn {
  grid-column: 1 / -1;
  width: 100%;
}

.list-directory-empty {
  grid-column: 1 / -1;
}

.wish-card {
  overflow: hidden;
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  background: var(--panel);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.85),
    0 18px 38px rgba(47, 52, 55, 0.1);
  transition:
    border-color 160ms ease,
    box-shadow 160ms ease,
    transform 160ms ease;
  animation: cardIn 260ms cubic-bezier(0.2, 0.85, 0.2, 1) both;
  animation-delay: calc(var(--card-index, 0) * 34ms);
}

.wish-card:hover {
  border-color: rgba(111, 29, 50, 0.24);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.9),
    0 26px 58px rgba(47, 52, 55, 0.14);
  transform: translateY(-3px);
}

/* "Mais expandido" no modo full: por padrao escondemos os detalhes mais
   secundarios (mini-grafico, detalhe historico, capture-line, comparativos).
   Quando o card recebe .is-expanded eles deslizam pra fora suavemente. */
.wishlist-grid:not(.is-compact) .wish-card .price-history-mini,
.wishlist-grid:not(.is-compact) .wish-card .price-history-detail,
.wishlist-grid:not(.is-compact) .wish-card .capture-line,
.wishlist-grid:not(.is-compact) .wish-card .comparison-row,
body[data-wishlist-density="full"] #wishlistGrid .wish-card .price-history-mini,
body[data-wishlist-density="full"] #wishlistGrid .wish-card .price-history-detail,
body[data-wishlist-density="full"] #wishlistGrid .wish-card .capture-line,
body[data-wishlist-density="full"] #wishlistGrid .wish-card .comparison-row {
  max-height: 0;
  margin-block: 0;
  padding-block: 0;
  overflow: hidden;
  opacity: 0;
  pointer-events: none;
  transition:
    max-height 240ms cubic-bezier(0.2, 0.85, 0.25, 1),
    opacity 200ms ease,
    margin-block 200ms ease,
    padding-block 200ms ease;
}

.wishlist-grid:not(.is-compact) .wish-card.is-expanded .price-history-mini,
.wishlist-grid:not(.is-compact) .wish-card.is-expanded .price-history-detail,
.wishlist-grid:not(.is-compact) .wish-card.is-expanded .capture-line,
.wishlist-grid:not(.is-compact) .wish-card.is-expanded .comparison-row,
body[data-wishlist-density="full"] #wishlistGrid .wish-card.is-expanded .price-history-mini,
body[data-wishlist-density="full"] #wishlistGrid .wish-card.is-expanded .price-history-detail,
body[data-wishlist-density="full"] #wishlistGrid .wish-card.is-expanded .capture-line,
body[data-wishlist-density="full"] #wishlistGrid .wish-card.is-expanded .comparison-row {
  max-height: 480px;
  opacity: 1;
  pointer-events: auto;
  margin-block: 6px;
  padding-block: 4px;
}

/* Subtle visual hint that the card is interactive on full mode too. */
.wishlist-grid:not(.is-compact) .wish-card,
body[data-wishlist-density="full"] #wishlistGrid .wish-card {
  cursor: pointer;
}

.wishlist-grid:not(.is-compact) .wish-card.is-expanded,
body[data-wishlist-density="full"] #wishlistGrid .wish-card.is-expanded {
  border-color: rgba(var(--neon-strong-rgb), 0.42);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.9),
    0 22px 50px rgba(var(--neon-strong-rgb), 0.16);
}

.wishlist-grid.is-compact {
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
}

body[data-wishlist-density="compact"] #wishlistGrid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
}

.wishlist-grid.is-compact .wish-card {
  display: grid;
  grid-template-columns: 68px minmax(0, 1fr);
  align-items: center;
  min-height: 92px;
  border-radius: 18px;
  cursor: pointer;
  box-shadow: 0 12px 28px rgba(47, 52, 55, 0.08);
}

body[data-wishlist-density="compact"] #wishlistGrid .wish-card {
  display: grid;
  grid-template-columns: 68px minmax(0, 1fr);
  align-items: center;
  min-height: 92px;
  border-radius: 18px;
  cursor: pointer;
  box-shadow: 0 12px 28px rgba(47, 52, 55, 0.08);
}

.wishlist-grid.is-compact .wish-card:hover {
  transform: translateY(-1px);
}

.wishlist-grid.is-compact .wish-card:not(.is-expanded) .card-image-frame {
  align-self: stretch;
  padding: 10px 0 10px 10px;
}

body[data-wishlist-density="compact"] #wishlistGrid .wish-card:not(.is-expanded) .card-image-frame {
  align-self: stretch;
  padding: 10px 0 10px 10px;
}

.wishlist-grid.is-compact .wish-card:not(.is-expanded) .card-image-link {
  width: 58px;
  height: 58px;
  border-radius: 16px;
  aspect-ratio: 1;
  pointer-events: none;
}

body[data-wishlist-density="compact"] #wishlistGrid .wish-card:not(.is-expanded) .card-image-link {
  width: 58px;
  height: 58px;
  border-radius: 16px;
  aspect-ratio: 1;
  pointer-events: none;
}

body[data-wishlist-density="compact"] #wishlistGrid .wish-card:not(.is-expanded) .card-image-placeholder {
  font-size: 1rem;
}

.wishlist-grid.is-compact .wish-card:not(.is-expanded) .favorite-btn {
  top: 4px;
  right: -4px;
  width: 25px;
  height: 25px;
  min-height: 25px;
  font-size: 0.72rem;
}

body[data-wishlist-density="compact"] #wishlistGrid .wish-card:not(.is-expanded) .favorite-btn {
  top: 4px;
  right: -4px;
  width: 25px;
  height: 25px;
  min-height: 25px;
  font-size: 0.72rem;
}

.wishlist-grid.is-compact .wish-card:not(.is-expanded) .favorite-btn span {
  font-size: 0.82rem;
}

.wishlist-grid.is-compact .wish-card:not(.is-expanded) .card-body {
  gap: 4px;
  min-width: 0;
  padding: 10px 12px 10px 6px;
}

body[data-wishlist-density="compact"] #wishlistGrid .wish-card:not(.is-expanded) .card-body {
  gap: 4px;
  min-width: 0;
  padding: 10px 12px 10px 6px;
}

.wishlist-grid.is-compact .wish-card:not(.is-expanded) .card-topline,
.wishlist-grid.is-compact .wish-card:not(.is-expanded) .brand-line,
.wishlist-grid.is-compact .wish-card:not(.is-expanded) .org-row,
.wishlist-grid.is-compact .wish-card:not(.is-expanded) .tag-line,
.wishlist-grid.is-compact .wish-card:not(.is-expanded) .notes-line,
.wishlist-grid.is-compact .wish-card:not(.is-expanded) .price-alert-line,
.wishlist-grid.is-compact .wish-card:not(.is-expanded) .price-history-mini,
.wishlist-grid.is-compact .wish-card:not(.is-expanded) .price-history-detail,
.wishlist-grid.is-compact .wish-card:not(.is-expanded) .capture-line,
.wishlist-grid.is-compact .wish-card:not(.is-expanded) .comparison-row,
.wishlist-grid.is-compact .wish-card:not(.is-expanded) .card-footer {
  display: none !important;
}

body[data-wishlist-density="compact"] #wishlistGrid .wish-card:not(.is-expanded) .card-topline,
body[data-wishlist-density="compact"] #wishlistGrid .wish-card:not(.is-expanded) .brand-line,
body[data-wishlist-density="compact"] #wishlistGrid .wish-card:not(.is-expanded) .org-row,
body[data-wishlist-density="compact"] #wishlistGrid .wish-card:not(.is-expanded) .tag-line,
body[data-wishlist-density="compact"] #wishlistGrid .wish-card:not(.is-expanded) .notes-line,
body[data-wishlist-density="compact"] #wishlistGrid .wish-card:not(.is-expanded) .price-alert-line,
body[data-wishlist-density="compact"] #wishlistGrid .wish-card:not(.is-expanded) .price-history-mini,
body[data-wishlist-density="compact"] #wishlistGrid .wish-card:not(.is-expanded) .price-history-detail,
body[data-wishlist-density="compact"] #wishlistGrid .wish-card:not(.is-expanded) .capture-line,
body[data-wishlist-density="compact"] #wishlistGrid .wish-card:not(.is-expanded) .comparison-row,
body[data-wishlist-density="compact"] #wishlistGrid .wish-card:not(.is-expanded) .card-footer {
  display: none !important;
}

.wishlist-grid.is-compact .wish-card:not(.is-expanded) h3 {
  display: block;
  min-height: 0;
  margin: 0;
  overflow: hidden;
  font-size: 1.02rem;
  line-height: 1.18;
  text-overflow: ellipsis;
  white-space: nowrap;
}

body[data-wishlist-density="compact"] #wishlistGrid .wish-card:not(.is-expanded) h3 {
  display: block;
  min-height: 0;
  margin: 0;
  overflow: hidden;
  font-size: 1.02rem;
  line-height: 1.18;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.wishlist-grid.is-compact .wish-card:not(.is-expanded) .price-line {
  overflow: hidden;
  font-family: var(--font-sans);
  font-size: 0.92rem;
  font-weight: 950;
  line-height: 1.18;
  text-overflow: ellipsis;
  white-space: nowrap;
}

body[data-wishlist-density="compact"] #wishlistGrid .wish-card:not(.is-expanded) .price-line {
  overflow: hidden;
  font-family: var(--font-sans);
  font-size: 0.92rem;
  font-weight: 950;
  line-height: 1.18;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.wishlist-grid.is-compact .wish-card.is-expanded {
  grid-column: 1 / -1;
  grid-template-columns: 1fr;
}

body[data-wishlist-density="compact"] #wishlistGrid .wish-card.is-expanded {
  grid-column: 1 / -1;
  grid-template-columns: 1fr;
}

.wishlist-grid.is-compact .wish-card.is-expanded .card-image-link {
  aspect-ratio: 4 / 3;
}

.wish-card.is-highlighted {
  border-color: rgba(111, 29, 50, 0.55);
  box-shadow: 0 22px 48px rgba(111, 29, 50, 0.18);
  transform: translateY(-2px);
}

/* ===================== BLOCO 3 — Cards de produto mínimos =====================
   Estado fechado = só imagem + nome + preço + favorito + dot de prioridade.
   O resto aparece ao tocar (.is-expanded). price-history, capture-line e
   comparison-row já são colapsados pelas regras de full mode acima. */
.wish-card:not(.is-expanded) .card-topline,
.wish-card:not(.is-expanded) .brand-line,
.wish-card:not(.is-expanded) .org-row,
.wish-card:not(.is-expanded) .tag-line,
.wish-card:not(.is-expanded) .notes-line,
.wish-card:not(.is-expanded) .price-alert-line,
.wish-card:not(.is-expanded) .card-footer {
  display: none;
}

/* 3c — grid 2 colunas; no estado fechado o card não tem moldura (a imagem
   arredondada É o visual). Ao expandir, o painel volta e ocupa as 2 colunas. */
.wishlist-grid {
  grid-template-columns: 1fr 1fr;
  gap: 14px;
}
.wishlist-grid:not(.is-compact) .wish-card {
  border: 0;
  background: transparent;
  box-shadow: none;
  overflow: visible;
}
.wishlist-grid:not(.is-compact) .wish-card:hover {
  transform: none;
  box-shadow: none;
}
.wishlist-grid:not(.is-compact) .wish-card.is-expanded {
  grid-column: 1 / -1;
  border: 1px solid var(--line);
  background: var(--panel);
  box-shadow: 0 18px 38px rgba(47, 52, 55, 0.1);
  overflow: hidden;
}
.wish-card .card-image-frame {
  border-radius: 18px;
  overflow: hidden;
}
.wishlist-grid:not(.is-compact) .wish-card:not(.is-expanded) .card-body {
  gap: 2px;
  padding: 9px 2px 2px;
}
.wish-card:not(.is-expanded) h3 {
  min-height: 0;
  margin: 0;
  font-size: 0.86rem;
  font-weight: 600;
  line-height: 1.25;
}
.wish-card:not(.is-expanded) .price-line {
  margin: 3px 0 0;
  font-family: var(--font-display);
  font-size: 0.95rem;
  font-weight: 700;
  line-height: 1.1;
}

/* 3b — prioridade vira um dot sobre a imagem (canto inferior esquerdo).
   Só Alta/Média mostram dot; Baixa/sem-prioridade = nenhum. Cores via tokens
   (var(--oxblood)=alta, var(--gold)=média) para não quebrar os 4 temas — o
   guia sugeria #e0392f/#e3a008, trocados por tokens p/ respeitar a regra 1. */
.wish-card .priority-pill {
  min-height: 0;
  padding: 0;
  border: 0;
  background: none;
  font-size: 0;
}
.wish-card .priority-pill::before {
  content: "";
  display: none;
  position: absolute;
  left: 9px;
  bottom: 9px;
  z-index: 2;
  width: 9px;
  height: 9px;
  border-radius: 50%;
  border: 2px solid var(--panel);
  box-shadow: 0 2px 6px rgba(var(--neon-strong-rgb), 0.4);
}
.wish-card .priority-pill[data-priority="Alta"]::before {
  display: block;
  background: var(--oxblood);
}
.wish-card .priority-pill[data-priority="Media"]::before {
  display: block;
  background: var(--gold);
}
/* ===================== fim BLOCO 3 ===================== */

.card-image-frame {
  position: relative;
}

.card-image-link {
  position: relative;
  display: block;
  aspect-ratio: 4 / 3;
  overflow: hidden;
  background:
    linear-gradient(135deg, rgba(244, 223, 229, 0.9), rgba(200, 204, 208, 0.8)),
    var(--panel);
}

.card-image-link::after {
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, transparent 50%, rgba(23, 23, 23, 0.16));
  content: "";
  opacity: 0;
  transition: opacity 180ms ease;
}

.wish-card:hover .card-image-link::after {
  opacity: 1;
}

.favorite-btn {
  position: absolute;
  top: 9px;
  right: 9px;
  z-index: 2;
  display: grid;
  place-items: center;
  width: 28px;
  height: 28px;
  border: 1px solid rgba(255, 255, 255, 0.74);
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.85);
  color: var(--burgundy);
  box-shadow: 0 14px 28px rgba(47, 52, 55, 0.16);
  -webkit-backdrop-filter: blur(16px);
  backdrop-filter: blur(16px);
  cursor: pointer;
  transition:
    background 180ms ease,
    color 180ms ease,
    transform 180ms ease,
    box-shadow 180ms ease;
}

.favorite-btn span {
  font-size: 0.92rem;
  line-height: 1;
  transform: translateY(-1px);
}

.favorite-btn:hover,
.favorite-btn.is-active {
  background: linear-gradient(180deg, #fff7fa, #f3d7df);
  color: #6f1d32;
  box-shadow: 0 16px 32px rgba(111, 29, 50, 0.2);
  transform: translateY(-1px);
}

.favorite-btn.is-active span {
  animation: favoritePop 520ms cubic-bezier(0.2, 0.9, 0.2, 1.16) both;
}

.favorite-btn:active {
  transform: scale(0.94);
}

.wish-card.is-favorite {
  border-color: rgba(111, 29, 50, 0.28);
}

.card-image {
  transition: transform 240ms ease;
}

.wish-card:hover .card-image {
  transform: scale(1.035);
}

.card-body {
  display: grid;
  gap: 10px;
  padding: 15px;
}

.card-topline,
.card-footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}

.card-actions {
  display: inline-flex;
  align-items: center;
  gap: 4px;
}

.priority-pill,
.store-chip,
.status-pill,
.category-chip {
  display: inline-flex;
  align-items: center;
  max-width: 100%;
  min-height: 28px;
  border: 1px solid var(--line);
  border-radius: 999px;
  padding: 0 10px;
  color: var(--muted);
  font-size: 0.78rem;
  font-weight: 800;
  white-space: nowrap;
}

.priority-pill[data-priority="Alta"] {
  border-color: rgba(111, 29, 50, 0.28);
  background: rgba(111, 29, 50, 0.08);
  color: var(--oxblood);
}

.priority-pill[data-priority="Media"] {
  border-color: rgba(185, 147, 86, 0.34);
  background: rgba(185, 147, 86, 0.1);
  color: #75562a;
}

.priority-pill[data-priority="Baixa"] {
  border-color: rgba(47, 52, 55, 0.2);
  background: rgba(220, 230, 223, 0.58);
  color: var(--graphite);
}

.org-row {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.status-pill[data-status="Comprado"] {
  border-color: rgba(66, 100, 82, 0.24);
  background: rgba(220, 230, 223, 0.7);
  color: #426452;
}

.status-pill[data-status="Pesquisando"] {
  border-color: rgba(185, 147, 86, 0.34);
  background: rgba(185, 147, 86, 0.1);
  color: #75562a;
}

.status-pill[data-status="Descartado"] {
  opacity: 0.72;
}

.tag-line,
.notes-line {
  min-height: 18px;
  margin: -2px 0 0;
  color: var(--muted);
  font-size: 0.82rem;
  line-height: 1.35;
}

.tag-line {
  font-weight: 850;
}

.notes-line {
  display: -webkit-box;
  overflow: hidden;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
}

.icon-btn {
  display: inline-grid;
  place-items: center;
  width: 36px;
  min-height: 36px;
  padding: 0;
  border: 1px solid transparent;
  background: transparent;
  color: var(--muted);
  font-size: 0.76rem;
  font-weight: 950;
  line-height: 1;
}

.icon-btn:hover {
  border-color: var(--line);
  background: var(--paper);
  color: var(--oxblood);
}

.wish-card h3 {
  min-height: 48px;
  margin: 0;
  font-size: 1.08rem;
  line-height: 1.25;
}

.brand-line {
  min-height: 20px;
  margin: 0;
  color: var(--muted);
  font-size: 0.9rem;
}

.price-line {
  color: var(--oxblood);
  font-family: var(--font-display);
  font-size: 1.65rem;
  line-height: 1;
}

.price-alert-line {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
  min-height: 20px;
  margin: -2px 0 0;
  color: var(--muted);
  font-size: 0.82rem;
  font-weight: 800;
}

.price-alert-line.is-deal {
  color: #426452;
}

.price-alert-line.is-increase {
  color: var(--oxblood);
}

.price-alert-badge {
  border: 1px solid currentColor;
  border-radius: 999px;
  padding: 4px 8px;
  background: rgba(255, 255, 255, 0.66);
  font-size: 0.68rem;
  line-height: 1;
  text-transform: uppercase;
}

.price-alert-line strong {
  min-width: 0;
  color: var(--ink);
  font-size: 0.82rem;
}

.price-history-mini {
  display: grid;
  grid-template-columns: 54px 1fr;
  align-items: center;
  gap: 8px;
  min-height: 28px;
  margin-top: -4px;
  color: var(--muted);
}

.price-history-mini.is-hidden {
  display: none;
}

.price-history-mini svg {
  width: 54px;
  height: 28px;
  color: var(--chrome);
  overflow: visible;
}

.price-history-mini[data-direction="down"] svg {
  color: #426452;
}

.price-history-mini[data-direction="up"] svg {
  color: var(--oxblood);
}

.price-history-mini span {
  overflow: hidden;
  color: var(--muted);
  font-size: 0.74rem;
  font-weight: 850;
  text-overflow: ellipsis;
  text-transform: uppercase;
  white-space: nowrap;
}

.price-history-detail {
  overflow: hidden;
  border: 1px solid var(--line);
  border-radius: 14px;
  background: rgba(255, 255, 255, 0.58);
}

.price-history-detail.is-hidden {
  display: none;
}

.price-history-detail summary {
  cursor: pointer;
  color: var(--ink);
  font-size: 0.78rem;
  font-weight: 950;
  list-style: none;
  padding: 10px 12px;
  text-transform: uppercase;
}

.price-history-detail summary::-webkit-details-marker {
  display: none;
}

.price-history-detail summary::after {
  float: right;
  color: var(--muted);
  content: "+";
}

.price-history-detail[open] summary::after {
  content: "-";
}

.price-history-stats {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
  border-top: 1px solid var(--line);
  padding: 10px 12px;
}

.price-history-stats span {
  display: grid;
  gap: 3px;
  min-width: 0;
}

.price-history-stats small {
  color: var(--muted);
  font-size: 0.68rem;
  font-weight: 900;
  text-transform: uppercase;
}

.price-history-stats strong {
  overflow: hidden;
  color: var(--ink);
  font-size: 0.9rem;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.price-history-list {
  display: grid;
  gap: 1px;
  padding: 0 12px 12px;
}

.price-history-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  border-top: 1px solid rgba(111, 29, 50, 0.08);
  padding: 7px 0;
}

.price-history-row span {
  color: var(--muted);
  font-size: 0.74rem;
  font-weight: 800;
}

.price-history-row strong {
  color: var(--ink);
  font-size: 0.82rem;
}

.capture-line {
  min-height: 20px;
  margin: -4px 0 0;
  color: var(--muted);
  font-size: 0.76rem;
  font-weight: 850;
  text-transform: uppercase;
  letter-spacing: 0.06em;
}

.capture-line[data-quality="complete"] {
  color: #426452;
}

.capture-line[data-quality="weak"] {
  color: #75562a;
}

.comparison-row {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 6px;
  margin-top: -4px;
}

.comparison-row > span {
  color: var(--muted);
  font-size: 0.72rem;
  font-weight: 900;
  text-transform: uppercase;
}

.comparison-row a {
  border: 1px solid rgba(111, 29, 50, 0.12);
  border-radius: 999px;
  background: rgba(255, 247, 250, 0.8);
  color: var(--burgundy);
  font-size: 0.72rem;
  font-weight: 900;
  padding: 6px 8px;
  text-decoration: none;
}

.buy-link {
  color: var(--ink);
  font-size: 0.86rem;
  font-weight: 900;
  text-decoration: none;
}

.buy-link:hover {
  color: var(--oxblood);
}

.empty-state {
  display: grid;
  place-items: center;
  gap: 12px;
  min-height: 310px;
  border: 1px dashed rgba(111, 29, 50, 0.28);
  border-radius: var(--radius-lg);
  background: rgba(255, 255, 255, 0.46);
  text-align: center;
  padding: 26px;
}

.empty-state.is-hidden {
  display: none;
}

.empty-state h2 {
  margin: 0;
  font-family: var(--font-display);
  font-size: 1.9rem;
  font-weight: 500;
}

.empty-state p {
  max-width: 430px;
  margin: 0;
  color: var(--muted);
  line-height: 1.55;
}

.empty-visual {
  position: relative;
  width: 160px;
  height: 110px;
}

.empty-card {
  position: absolute;
  width: 92px;
  height: 66px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  box-shadow: 0 14px 28px rgba(47, 52, 55, 0.12);
  animation: cardFloat 4.8s ease-in-out infinite;
}

.card-one {
  left: 8px;
  top: 28px;
  background: var(--blush);
  transform: rotate(-9deg);
}

.card-two {
  left: 50px;
  top: 10px;
  background: var(--sage);
  animation-delay: 500ms;
}

.card-three {
  right: 4px;
  top: 35px;
  background: var(--chrome);
  transform: rotate(8deg);
  animation-delay: 900ms;
}

.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
}

.bottom-dock {
  position: fixed;
  right: 50%;
  bottom: calc(18px + env(safe-area-inset-bottom));
  z-index: 20;
  display: flex;
  align-items: center;
  max-width: min(460px, calc(100% - 24px));
  border: 1px solid rgba(var(--neon-rgb), 0.24);
  border-radius: 30px;
  background:
    linear-gradient(145deg, rgba(255, 255, 255, 0.88), rgba(var(--neon-rgb), 0.08)),
    rgba(255, 255, 255, 0.82);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.9),
    0 0 0 1px rgba(255, 255, 255, 0.42),
    0 24px 70px rgba(var(--neon-strong-rgb), 0.16);
  padding: 8px;
  -webkit-backdrop-filter: blur(24px) saturate(1.25);
  backdrop-filter: blur(24px) saturate(1.25);
  transform: translateX(50%);
  animation: dockIn 420ms 180ms cubic-bezier(0.2, 0.8, 0.2, 1) both;
}

/* Bloco 2 — FAB "+": Adicionar saiu do dock e virou botão flutuante. Visível só
   nas views Resumo e Listas (onde faz sentido adicionar um item). */
.fab-add {
  position: fixed;
  right: 20px;
  bottom: calc(104px + env(safe-area-inset-bottom));
  width: 56px;
  height: 56px;
  border: 0;
  border-radius: 50%;
  background: var(--oxblood);
  color: #fff;
  display: none;
  align-items: center;
  justify-content: center;
  box-shadow: 0 16px 30px -10px rgba(var(--neon-strong-rgb), 0.7);
  cursor: pointer;
  z-index: 40;
  animation: dockIn 420ms 220ms cubic-bezier(0.2, 0.8, 0.2, 1) both;
}

body[data-active-view="summary"] .fab-add,
body[data-active-view="lists"] .fab-add {
  display: flex;
}

.toast-viewport {
  position: fixed;
  right: 18px;
  bottom: calc(96px + env(safe-area-inset-bottom));
  z-index: 30;
  display: grid;
  gap: 10px;
  width: min(340px, calc(100% - 36px));
  pointer-events: none;
}

.toast {
  position: relative;
  overflow: hidden;
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  align-items: center;
  gap: 10px;
  border: 1px solid rgba(230, 224, 223, 0.86);
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.86);
  color: var(--ink);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.9),
    0 20px 48px rgba(47, 52, 55, 0.16);
  padding: 12px 14px;
  -webkit-backdrop-filter: blur(22px) saturate(1.25);
  backdrop-filter: blur(22px) saturate(1.25);
  font-size: 0.92rem;
  font-weight: 850;
  animation: toastIn 240ms cubic-bezier(0.2, 0.85, 0.2, 1) both;
}

.toast::after {
  position: absolute;
  right: 12px;
  bottom: 7px;
  left: 12px;
  height: 2px;
  border-radius: 999px;
  background: currentColor;
  content: "";
  opacity: 0.22;
  transform-origin: left center;
  animation: toastTimer 2600ms linear both;
}

.toast-icon {
  display: grid;
  place-items: center;
  width: 26px;
  height: 26px;
  border-radius: 10px;
  background: rgba(var(--neon-rgb), 0.12);
  color: var(--oxblood);
  font-size: 0.78rem;
  font-weight: 950;
}

.toast-message {
  min-width: 0;
  overflow-wrap: anywhere;
}

.toast-success {
  border-color: rgba(66, 100, 82, 0.24);
  color: #426452;
}

.toast-success .toast-icon {
  background: rgba(66, 100, 82, 0.12);
  color: #426452;
}

.toast-error {
  border-color: rgba(111, 29, 50, 0.28);
  color: var(--oxblood);
}

.toast.is-leaving {
  animation: toastOut 180ms ease both;
}

.tap-pop {
  animation: tapPop 210ms ease both;
}

.dock-nav-btn,
.dock-action {
  border: 0;
  color: color-mix(in srgb, var(--ink) 70%, var(--muted) 30%);
  min-width: 0;
  overflow: hidden;
  transition:
    background 180ms ease,
    color 180ms ease,
    box-shadow 180ms ease,
    transform 180ms ease,
    width 180ms ease;
}

[dir="rtl"] body {
  direction: rtl;
}

[dir="rtl"] .metric-grid,
[dir="rtl"] .tools-row,
[dir="rtl"] .form-grid,
[dir="rtl"] .wishlist-tabs {
  direction: rtl;
}

[dir="rtl"] .language-control,
[dir="rtl"] .bottom-dock,
[dir="rtl"] .card-topline,
[dir="rtl"] .card-footer,
[dir="rtl"] .org-row,
[dir="rtl"] .view-heading,
[dir="rtl"] .view-actions,
[dir="rtl"] .switcher-head,
[dir="rtl"] .switcher-actions,
[dir="rtl"] .capture-meta,
[dir="rtl"] .form-actions {
  flex-direction: row-reverse;
}

[dir="rtl"] .wishlist-tab {
  text-align: right;
}

[dir="rtl"] .tab-count {
  grid-column: 2;
}

[dir="rtl"] input,
[dir="rtl"] textarea {
  text-align: right;
}

[dir="rtl"] input[type="url"],
[dir="rtl"] #itemImage,
[dir="rtl"] #itemLink,
[dir="rtl"] #productUrl {
  direction: ltr;
  text-align: left;
}

.dock-nav-btn {
  /* Bloco 2 — dock de 4 abas: ícone ACIMA do rótulo, compacto, distribuído por
     igual (flex: 1). O antigo layout horizontal com min-width 136px estourava o
     dock com 4 itens (4×136 = 544px > ~366px no mobile). */
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 4px;
  flex: 1 1 0;
  min-width: 0;
  max-width: 100%;
  height: 56px;
  border-radius: 18px;
  background: transparent;
  padding: 6px 4px;
  font-size: 10.5px;
  font-weight: 800;
}

.dock-nav-btn span:last-child,
.dock-action span:last-child {
  min-width: 0;
  overflow: hidden;
  line-height: 1.05;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.dock-nav-btn.is-active {
  background:
    linear-gradient(145deg, rgba(255, 255, 255, 0.96), rgba(var(--neon-rgb), 0.11)),
    var(--panel);
  color: var(--ink);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.74),
    0 12px 28px rgba(var(--neon-strong-rgb), 0.13);
  transform: translateY(-1px);
}

.dock-nav-btn.is-locked {
  cursor: pointer;
  opacity: 0.42;
  filter: saturate(0.72);
}

.dock-nav-btn.is-locked::after {
  content: "";
  position: relative;
  right: auto;
  bottom: auto;
  width: 8px;
  height: 6px;
  border: 2px solid currentColor;
  border-radius: 2px;
  background: var(--panel);
}

.dock-symbol {
  position: relative;
  display: grid;
  place-items: center;
  width: 30px;
  height: 30px;
  border-radius: 12px;
  border: 1px solid rgba(var(--neon-rgb), 0.22);
  background:
    linear-gradient(145deg, rgba(var(--neon-rgb), 0.18), rgba(255, 255, 255, 0.78)),
    var(--panel);
  color: var(--oxblood);
  font-weight: 950;
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.66),
    0 8px 18px rgba(var(--neon-strong-rgb), 0.08);
}

.dock-nav-btn.is-active .dock-symbol {
  background:
    linear-gradient(145deg, rgba(var(--neon-strong-rgb), 0.92), rgba(var(--neon-rgb), 0.78)),
    var(--oxblood);
  color: var(--panel);
  border-color: rgba(var(--neon-rgb), 0.5);
  animation: dockIconPulse 520ms cubic-bezier(0.2, 0.9, 0.2, 1.12) both;
}

.dock-symbol::before,
.dock-symbol::after {
  display: block;
  content: "";
}

/* (ícones de dock desenhados em CSS removidos — o dock usa SVG inline.) */

.list-summary-strip {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
}

.personal-share-panel {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 12px;
  align-items: center;
  border: 1px solid rgba(var(--neon-rgb), 0.22);
  border-radius: 22px;
  background:
    radial-gradient(circle at 10% 0%, rgba(var(--neon-rgb), 0.18), transparent 36%),
    rgba(255, 255, 255, 0.72);
  padding: 14px;
  box-shadow: 0 18px 42px rgba(var(--neon-strong-rgb), 0.08);
}

.personal-share-panel h2 {
  margin: 0;
  color: var(--ink);
  font-size: 1.08rem;
}

.personal-share-status,
.personal-share-actions {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  flex-wrap: wrap;
  gap: 8px;
}

.personal-share-actions {
  grid-column: 1 / -1;
}

/* Category filter for Principal — same icon language as the Hub chips. */
.wishlist-category-filter {
  display: flex;
  gap: 8px;
  overflow-x: auto;
  scrollbar-width: none;
  padding: 6px 2px 10px;
  margin-bottom: 4px;
}

.wishlist-category-filter.is-hidden {
  display: none;
}

.wishlist-category-filter::-webkit-scrollbar {
  display: none;
}

.wishlist-category-chip {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  flex-shrink: 0;
  border: 1px solid rgba(var(--neon-rgb), 0.38);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.78);
  color: var(--ink);
  padding: 7px 14px 7px 7px;
  font-size: 0.82rem;
  font-weight: 800;
  cursor: pointer;
  transition: transform 180ms ease, border-color 180ms ease, background 180ms ease;
}

.wishlist-category-chip span {
  display: inline-grid;
  place-items: center;
  width: 28px;
  height: 28px;
  border-radius: 999px;
  border: 1.5px solid rgba(var(--neon-strong-rgb), 0.5);
  background: rgba(255, 255, 255, 0.92);
  color: var(--ink);
  box-shadow: 0 2px 6px rgba(var(--neon-strong-rgb), 0.14);
}

.wishlist-category-chip:hover,
.wishlist-category-chip.is-active {
  transform: translateY(-1px);
  border-color: rgba(var(--neon-rgb), 0.48);
  background:
    linear-gradient(145deg, rgba(var(--neon-strong-rgb), 0.96), rgba(var(--neon-rgb), 0.72)),
    var(--ink);
  color: var(--panel);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.18),
    0 12px 26px rgba(var(--neon-strong-rgb), 0.12);
}

.wishlist-category-chip:hover span,
.wishlist-category-chip.is-active span {
  border-color: rgba(255, 255, 255, 0.34);
  background: rgba(255, 255, 255, 0.88);
  color: var(--oxblood);
  box-shadow: 0 6px 14px rgba(var(--neon-strong-rgb), 0.18);
}

.wishlist-category-chip.is-empty:not(.is-active) {
  opacity: 0.55;
}

/* Per-item chip pointing back to the item's source list (Principal only). */
.source-list-chip {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  align-self: start;
  border: 1.5px solid rgba(var(--neon-strong-rgb), 0.4);
  border-radius: 999px;
  background: rgba(var(--neon-rgb), 0.14);
  color: var(--ink);
  padding: 3px 10px 3px 4px;
  margin-bottom: 6px;
  font-size: 0.74rem;
  font-weight: 850;
  cursor: pointer;
  transition: background 160ms ease, border-color 160ms ease, transform 160ms ease;
}

.source-list-chip span {
  display: inline-grid;
  place-items: center;
  width: 22px;
  height: 22px;
  border-radius: 999px;
  border: 1.5px solid rgba(var(--neon-strong-rgb), 0.45);
  background: rgba(255, 255, 255, 0.96);
  color: var(--ink);
}

.source-list-chip:hover {
  background: rgba(var(--neon-rgb), 0.18);
  border-color: rgba(var(--neon-strong-rgb), 0.42);
  transform: translateY(-1px);
}

.feeder-lists-panel {
  display: grid;
  gap: 12px;
  border: 1px dashed rgba(var(--neon-rgb), 0.32);
  border-radius: 22px;
  background:
    radial-gradient(circle at 0% 0%, rgba(var(--neon-rgb), 0.16), transparent 40%),
    rgba(255, 255, 255, 0.78);
  padding: 14px;
  animation: cardIn 280ms cubic-bezier(0.2, 0.85, 0.2, 1) both;
}

.feeder-lists-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  flex-wrap: wrap;
}

.feeder-lists-copy {
  margin: 0;
  color: var(--muted);
  font-size: 0.86rem;
  line-height: 1.4;
}

.feeder-lists-active {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  min-height: 32px;
}

.feeder-lists-empty {
  margin: 0;
  color: var(--muted);
  font-size: 0.86rem;
  font-style: italic;
}

.feeder-chip {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  border: 1px solid rgba(var(--neon-rgb), 0.32);
  border-radius: 999px;
  background:
    linear-gradient(145deg, rgba(255, 255, 255, 0.94), rgba(var(--neon-rgb), 0.12)),
    rgba(255, 255, 255, 0.82);
  padding: 6px 6px 6px 14px;
  font-size: 0.86rem;
  font-weight: 700;
  color: var(--ink);
  box-shadow: 0 6px 14px rgba(var(--neon-strong-rgb), 0.08);
  animation: cardIn 200ms cubic-bezier(0.2, 0.85, 0.25, 1) both;
}

.feeder-chip small {
  color: var(--muted);
  font-weight: 600;
}

.feeder-chip-remove {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 24px;
  height: 24px;
  border: 0;
  border-radius: 999px;
  background: rgba(var(--neon-strong-rgb), 0.18);
  color: var(--oxblood);
  font-size: 0.86rem;
  font-weight: 950;
  line-height: 1;
  cursor: pointer;
  transition: background 160ms ease, transform 160ms ease;
}

.feeder-chip-remove:hover {
  background: rgba(var(--neon-strong-rgb), 0.32);
  transform: scale(1.06);
}

.feeder-lists-editor {
  display: grid;
  gap: 10px;
  border-top: 1px solid rgba(var(--neon-rgb), 0.18);
  padding-top: 12px;
  animation: cardIn 200ms cubic-bezier(0.2, 0.85, 0.25, 1) both;
}

.feeder-lists-checkboxes {
  display: grid;
  gap: 6px;
  max-height: 280px;
  overflow-y: auto;
}

.feeder-list-row {
  display: grid;
  grid-template-columns: auto 1fr auto;
  gap: 10px;
  align-items: center;
  border: 1px solid var(--line);
  border-radius: 14px;
  background: rgba(255, 255, 255, 0.74);
  padding: 10px 12px;
  cursor: pointer;
  transition: border-color 160ms ease, background 160ms ease;
}

.feeder-list-row:hover {
  border-color: rgba(var(--neon-rgb), 0.4);
  background: rgba(var(--neon-rgb), 0.08);
}

.feeder-list-row input[type="checkbox"] {
  width: 18px;
  height: 18px;
  accent-color: var(--oxblood);
}

.feeder-list-row strong {
  font-weight: 700;
  color: var(--ink);
}

.feeder-list-row small {
  color: var(--muted);
  font-size: 0.78rem;
}

.feeder-lists-actions {
  display: flex;
  gap: 8px;
  justify-content: flex-end;
  flex-wrap: wrap;
}

.share-state-pill,
.share-sync-pill {
  display: inline-flex;
  align-items: center;
  min-height: 34px;
  max-width: 160px;
  border: 1px solid rgba(var(--neon-rgb), 0.2);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.66);
  color: var(--muted);
  padding: 0 11px;
  font-size: 0.74rem;
  font-weight: 950;
  text-transform: uppercase;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.share-state-pill[data-state="public"],
.share-sync-pill[data-state="synced"] {
  border-color: rgba(var(--neon-rgb), 0.42);
  background: rgba(var(--neon-rgb), 0.14);
  color: var(--oxblood);
  box-shadow: 0 8px 20px rgba(var(--neon-strong-rgb), 0.08);
}

.share-sync-pill[data-state="locked"] {
  opacity: 0.7;
}

.list-summary-strip > span {
  display: grid;
  align-content: space-between;
  gap: 8px;
  min-height: 64px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: rgba(255, 255, 255, 0.78);
  color: var(--muted);
  padding: 10px 12px;
}

.list-summary-strip strong {
  color: var(--ink);
  overflow: hidden;
  font-size: 1.12rem;
  line-height: 1.08;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.dock-action {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  place-items: center;
  min-width: 112px;
  max-width: 150px;
  width: auto;
  height: 52px;
  margin-inline: 0;
  border-radius: 22px;
  background: linear-gradient(180deg, #252525, #101010);
  color: white;
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.22),
    0 12px 28px rgba(23, 23, 23, 0.2);
  font-size: 0.9rem;
  font-weight: 950;
  line-height: 1;
  transition:
    box-shadow 180ms ease,
    transform 180ms ease,
    filter 180ms ease;
}

.dock-action:hover {
  filter: brightness(1.04);
  transform: translateY(-1px);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.24),
    0 16px 34px rgba(23, 23, 23, 0.24),
    0 0 24px rgba(var(--neon-rgb), 0.16);
}

.dock-action span:first-child {
  font-size: 1.4rem;
  font-weight: 500;
}

@keyframes heroTextIn {
  from {
    opacity: 0;
    transform: translateY(12px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@keyframes heroAura {
  from {
    opacity: 0.62;
    transform: translate3d(0, 0, 0) skewY(-5deg) scale(0.98);
  }
  to {
    opacity: 0.94;
    transform: translate3d(12px, -8px, 0) skewY(-5deg) scale(1.04);
  }
}

@keyframes heroLineIn {
  from {
    opacity: 0;
    transform: scaleX(0.4);
  }
  to {
    opacity: 0.8;
    transform: scaleX(1);
  }
}

@keyframes softNeon {
  from {
    box-shadow:
      0 0 0 1px rgba(255, 255, 255, 0.82) inset,
      0 0 0 1px rgba(var(--neon-rgb), 0.16),
      0 0 20px rgba(var(--neon-rgb), 0.14),
      0 18px 48px rgba(var(--neon-strong-rgb), 0.08);
  }
  to {
    box-shadow:
      0 0 0 1px rgba(255, 255, 255, 0.9) inset,
      0 0 0 1px rgba(var(--neon-rgb), 0.28),
      0 0 34px rgba(var(--neon-rgb), 0.24),
      0 20px 52px rgba(var(--neon-strong-rgb), 0.12);
  }
}

@keyframes rippleOut {
  0% {
    opacity: 0.52;
    transform: translate(-50%, -50%) scale(0);
  }

  100% {
    opacity: 0;
    transform: translate(-50%, -50%) scale(18);
  }
}

@keyframes recurringNeon {
  from {
    box-shadow:
      0 0 0 1px rgba(var(--neon-rgb), 0.18),
      0 0 18px rgba(255, 102, 178, 0.12),
      0 0 22px rgba(93, 157, 255, 0.1),
      0 18px 42px rgba(var(--neon-strong-rgb), 0.1);
  }
  to {
    box-shadow:
      0 0 0 1px rgba(var(--neon-rgb), 0.28),
      0 0 30px rgba(255, 102, 178, 0.22),
      0 0 34px rgba(93, 157, 255, 0.18),
      0 22px 48px rgba(var(--neon-strong-rgb), 0.14);
  }
}

@keyframes dockIconPulse {
  0% {
    transform: translateY(1px) scale(0.94);
  }

  58% {
    transform: translateY(-2px) scale(1.08);
  }

  100% {
    transform: translateY(0) scale(1);
  }
}

@keyframes dockIn {
  from {
    opacity: 0;
    transform: translateY(18px) scale(0.96);
  }
  to {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
}

@keyframes panelRise {
  from {
    opacity: 0;
    transform: translateY(10px) scale(0.99);
  }
  to {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
}

@keyframes viewEnter {
  from {
    opacity: 0;
    filter: blur(8px);
    transform: translateY(14px) scale(0.986);
  }
  to {
    opacity: 1;
    filter: blur(0);
    transform: translateY(0) scale(1);
  }
}

@keyframes viewGlow {
  0% {
    box-shadow:
      var(--shadow),
      0 0 0 rgba(var(--neon-rgb), 0);
  }
  45% {
    box-shadow:
      var(--shadow),
      0 0 34px rgba(var(--neon-rgb), 0.12);
  }
  100% {
    box-shadow:
      var(--shadow),
      0 0 0 rgba(var(--neon-rgb), 0);
  }
}

@keyframes cardIn {
  from {
    opacity: 0;
    filter: blur(6px);
    transform: translateY(12px) scale(0.982);
  }
  to {
    opacity: 1;
    filter: blur(0);
    transform: translateY(0) scale(1);
  }
}

/* Exit animation applied imperatively (`.is-leaving`) before DOM removal. */
@keyframes cardOut {
  from {
    opacity: 1;
    transform: translateY(0) scale(1);
    max-height: 480px;
    margin-bottom: var(--card-out-margin, 12px);
  }
  to {
    opacity: 0;
    transform: translateY(-6px) scale(0.96);
    max-height: 0;
    margin-bottom: 0;
    padding-top: 0;
    padding-bottom: 0;
  }
}

.wish-card.is-leaving,
.shared-list-card.is-leaving,
.shared-item-row.is-leaving,
.shared-items-list > article.is-leaving,
.shared-items-list > li.is-leaving {
  overflow: hidden;
  pointer-events: none;
  animation: cardOut 220ms cubic-bezier(0.2, 0.85, 0.25, 1) forwards;
}

@keyframes favoritePop {
  0% {
    transform: translateY(-1px) scale(0.76) rotate(-10deg);
  }

  58% {
    transform: translateY(-2px) scale(1.18) rotate(8deg);
  }

  100% {
    transform: translateY(-1px) scale(1) rotate(0);
  }
}

@keyframes checkPop {
  0% {
    transform: scale(0.72);
  }

  62% {
    transform: scale(1.18);
  }

  100% {
    transform: scale(1);
  }
}

@keyframes buttonSpin {
  to {
    transform: rotate(360deg);
  }
}

@keyframes statusFlash {
  0% {
    opacity: 0.62;
    transform: translateY(2px);
  }

  100% {
    opacity: 1;
    transform: translateY(0);
  }
}

@keyframes cardFloat {
  0%,
  100% {
    translate: 0 0;
  }
  50% {
    translate: 0 -6px;
  }
}

@keyframes tapPop {
  0% {
    transform: scale(1);
  }
  45% {
    transform: scale(0.965);
  }
  100% {
    transform: scale(1);
  }
}

@keyframes toastIn {
  from {
    opacity: 0;
    filter: blur(8px);
    transform: translateY(12px) scale(0.97);
  }
  to {
    opacity: 1;
    filter: blur(0);
    transform: translateY(0) scale(1);
  }
}

@keyframes toastTimer {
  from {
    transform: scaleX(1);
  }

  to {
    transform: scaleX(0);
  }
}

@keyframes toastOut {
  from {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
  to {
    opacity: 0;
    transform: translateY(8px) scale(0.98);
  }
}

@keyframes confirmOverlayIn {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}

@keyframes confirmOverlayOut {
  from {
    opacity: 1;
  }
  to {
    opacity: 0;
  }
}

@keyframes confirmCardIn {
  from {
    opacity: 0;
    transform: translateY(18px) scale(0.96);
  }
  to {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
}

@keyframes confirmCardOut {
  from {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
  to {
    opacity: 0;
    transform: translateY(12px) scale(0.97);
  }
}

@keyframes confirmIconPulse {
  from {
    transform: translateY(0) scale(1);
    box-shadow:
      0 18px 40px rgba(111, 29, 50, 0.2),
      0 0 0 8px rgba(166, 49, 66, 0.07);
  }
  to {
    transform: translateY(-2px) scale(1.02);
    box-shadow:
      0 22px 46px rgba(111, 29, 50, 0.26),
      0 0 0 12px rgba(166, 49, 66, 0.04);
  }
}

@keyframes confirmButtonGlow {
  from {
    box-shadow:
      inset 0 1px 0 rgba(255, 255, 255, 0.2),
      0 16px 34px rgba(111, 29, 50, 0.2),
      0 0 0 0 rgba(166, 49, 66, 0.18);
  }
  to {
    box-shadow:
      inset 0 1px 0 rgba(255, 255, 255, 0.24),
      0 18px 38px rgba(111, 29, 50, 0.24),
      0 0 0 6px rgba(166, 49, 66, 0.06);
  }
}

@media (max-width: 900px) {
  .topbar,
  .review-panel,
  .account-panel {
    grid-template-columns: 1fr;
  }

  .topbar {
    display: grid;
    min-height: auto;
  }

  .metric-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    width: 100%;
  }

  .wishlist-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .wishlist-grid.is-compact {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  body[data-wishlist-density="compact"] #wishlistGrid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .tools-row select,
  .tools-row button:not(.density-toggle) {
    flex: 1 1 calc(50% - 10px);
    max-width: none;
  }
}

@media (max-width: 680px) {
  .shell {
    width: min(100% - 20px, 1180px);
    padding-top: 20px;
  }

  h1 {
    font-size: 2.35rem;
  }

  .hero-copy {
    font-size: 0.96rem;
  }

  .metric-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .list-summary-strip {
    grid-template-columns: 1fr;
  }

  .personal-share-panel {
    grid-template-columns: 1fr;
  }

  /* Stack heading + primary action on mobile so the description does not
     wrap into a too-narrow column beside the button (e.g. "Adicionar
     desejo" used to push "Listas Pessoais" copy into 4-word lines). */
  .view-heading {
    flex-direction: column;
    align-items: flex-start;
    gap: 10px;
  }

  .view-heading > .primary-btn,
  .view-heading > .secondary-btn,
  .view-heading .view-actions {
    width: 100%;
    align-self: stretch;
  }

  .view-heading .view-actions {
    display: flex;
    flex-direction: column;
    gap: 8px;
  }

  .view-heading .view-actions > .primary-btn,
  .view-heading .view-actions > .secondary-btn {
    display: flex;
    width: 100%;
  }

  .personal-share-status,
  .personal-share-actions {
    justify-content: stretch;
  }

  .personal-share-actions .secondary-btn {
    width: 100%;
  }

  .metric-grid > span {
    min-height: 66px;
    padding: 10px;
  }

  .metric-grid strong {
    font-size: 1.04rem;
  }

  .link-row,
  .tools-row,
  .form-grid,
  .create-list-panel,
  .shared-toolbar-row,
  .shared-create-panel,
  .shared-detail-head,
  .shared-detail-actions,
  .shared-add-row,
  .scan-health-content {
    grid-template-columns: 1fr;
  }

  /* Bloco 3 — o grid de itens fica em 2 colunas no mobile (como na imagem-
     modelo), em vez de cair para 1 coluna. */
  .wishlist-grid {
    grid-template-columns: 1fr 1fr;
  }

  .wishlist-grid.is-compact {
    grid-template-columns: 1fr;
  }

  .wishlist-grid.is-list-directory {
    grid-template-columns: 1fr;
  }

  body[data-wishlist-density="compact"] #wishlistGrid.is-list-directory {
    grid-template-columns: 1fr;
  }

  body[data-wishlist-density="compact"] #wishlistGrid {
    grid-template-columns: 1fr;
  }

  .density-toggle {
    flex-basis: 52px;
    width: 52px;
    min-width: 52px;
  }

  .shared-detail-actions {
    justify-content: stretch;
  }

  .shared-detail-actions .secondary-btn {
    width: 100%;
  }

  .shared-icon-picker {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .shared-lists-grid.is-explore-grid {
    /* Mockup 03 (Explorar): 2 colunas tambem no celular (igual ao desktop);
       so o gap encolhe um pouco. */
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 12px;
  }

  .hub-feature-cover {
    height: 116px;
  }

  .hub-feature-title {
    font-size: 1.2rem;
  }

  .hub-feed-cover {
    height: 88px;
  }

  .shared-item-row {
    grid-template-columns: 48px minmax(0, 1fr) auto;
    gap: 9px;
    min-height: 68px;
  }

  .shared-item-thumb {
    width: 48px;
    height: 48px;
  }

  .shared-item-row a {
    display: none;
  }

  .shared-detail-panel.is-hub-preview {
    min-height: calc(100vh - 112px);
    border-radius: 26px 26px 0 0;
    padding: 10px;
  }

  .shared-detail-panel.is-hub-preview .shared-detail-head {
    grid-template-columns: auto minmax(0, 1fr);
  }

  .shared-detail-panel.is-hub-preview .shared-detail-actions {
    grid-column: 1 / -1;
  }

  .shared-detail-panel.is-hub-preview #sharedDetailTitle {
    font-size: 1.48rem;
  }

  .shared-detail-hero.is-hub-preview {
    border-radius: 22px;
    padding: 8px;
  }

  .shared-detail-hero {
    grid-template-columns: 1fr;
  }

  .shared-detail-cover,
  .shared-detail-cover img {
    min-height: 220px;
  }

  .shared-detail-stats {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .shared-item-row {
    grid-template-columns: auto minmax(0, 1fr) auto;
  }

  .shared-item-row a,
  .shared-item-row .shared-remove-item {
    grid-column: 2 / -1;
  }

  .switcher-head,
  .switcher-actions {
    align-items: stretch;
    flex-direction: column;
  }

  .span-2 {
    grid-column: auto;
  }

  .capture-meta,
  .form-actions {
    align-items: stretch;
    flex-direction: column;
  }

  .view-actions .primary-btn,
  .switcher-actions .primary-btn,
  .switcher-actions .secondary-btn,
  .form-actions .primary-btn,
  .form-actions .secondary-btn,
  .profile-actions .secondary-btn,
  .link-row .primary-btn,
  .link-row .secondary-btn {
    width: 100%;
  }

  .profile-actions {
    grid-template-columns: 1fr;
  }

  .profile-edit-grid {
    grid-template-columns: 1fr;
  }

  .wishlist-tab {
    min-width: 158px;
  }

  .scan-health-metrics {
    grid-template-columns: 1fr;
  }

  .scan-store-row,
  .scan-recent-row {
    grid-template-columns: 1fr;
  }

  .scan-store-row em,
  .scan-recent-row em {
    max-width: none;
    text-align: left;
  }

  .dock-nav-btn {
    min-width: 0;
    padding: 6px 2px;
  }

  /* Bloco 2 — no redesign o rótulo fica VISÍVEL no mobile (abaixo do ícone),
     como na imagem-modelo. Antes era escondido (dock só-ícone < 680px). */
  .dock-nav-btn span:last-child {
    display: block;
    font-size: 10px;
  }

  .dock-action {
    min-width: 112px;
    max-width: 132px;
  }

  .review-image-wrap {
    min-height: 240px;
  }
}

@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    scroll-behavior: auto !important;
    transition-duration: 0.01ms !important;
  }
}

/* =================================================================
   LIQUID GLASS SURFACE SYSTEM (iOS 26-style)
   Token-driven via --glass-* (see :root + noir). Self-contained:
   delete this block + the --glass-* token declarations to revert.

   Two tiers, mirroring Apple's guidance:
   - CHROME (nav/control layer): fully translucent glass with backdrop
     blur + saturation + refractive rim. Few instances on screen.
   - CONTENT CARDS: sculpted rim + diagonal sheen but stay opaque and
     legible, no heavy blur (there can be 50+ on screen).
   Selectors include body[data-theme="noir"] variants so they beat the
   theme-specific background overrides defined earlier in the file.
   ================================================================= */

/* --- CHROME: true liquid glass (translucent + backdrop blur) --- */
.view-panel,
.capture-panel,
.review-panel,
.tools-row,
.wishlist-switcher,
.add-intro,
.bottom-dock,
.confirm-card,
.toast,
.wishlist-tab,
body[data-theme="noir"] .view-panel,
body[data-theme="noir"] .capture-panel,
body[data-theme="noir"] .review-panel,
body[data-theme="noir"] .tools-row,
body[data-theme="noir"] .wishlist-switcher,
body[data-theme="noir"] .add-intro,
body[data-theme="noir"] .bottom-dock,
body[data-theme="noir"] .confirm-card,
body[data-theme="noir"] .toast,
body[data-theme="noir"] .wishlist-tab,
body[data-theme="blue"] .bottom-dock,
body[data-theme="fun"] .bottom-dock {
  background:
    linear-gradient(135deg, var(--glass-sheen-1) 0%, transparent 34%, transparent 66%, var(--glass-sheen-2) 100%),
    var(--glass-tint);
  -webkit-backdrop-filter: blur(var(--glass-blur)) saturate(var(--glass-saturate));
  backdrop-filter: blur(var(--glass-blur)) saturate(var(--glass-saturate));
  box-shadow:
    inset 0 1.5px 0 var(--glass-rim),
    inset 0 0 0 1px var(--glass-edge),
    inset 0 -16px 32px -18px var(--glass-rim),
    0 18px 44px var(--glass-drop);
  border-color: var(--glass-edge);
}

/* The dock is the hero glass element — keep its pill radius + give it a
   slightly stronger blur so the content scrolling behind it lenses nicely. */
.bottom-dock,
body[data-theme="noir"] .bottom-dock,
body[data-theme="blue"] .bottom-dock,
body[data-theme="fun"] .bottom-dock {
  -webkit-backdrop-filter: blur(28px) saturate(1.9);
  backdrop-filter: blur(28px) saturate(1.9);
}

/* --- CONTENT CARDS: sculpted rim + sheen, stay legible (no blur) --- */
.wish-card,
.shared-list-card.is-hub-card,
body[data-theme="noir"] .wish-card,
body[data-theme="noir"] .shared-list-card.is-hub-card {
  background:
    linear-gradient(135deg, var(--glass-sheen-1) 0%, transparent 32%, transparent 88%, var(--glass-sheen-2) 100%),
    var(--panel);
  box-shadow:
    inset 0 1.5px 0 var(--glass-rim),
    inset 0 0 0 1px var(--glass-edge),
    0 18px 42px var(--glass-drop);
  border-color: var(--glass-edge);
}

.wish-card:hover,
.shared-list-card.is-hub-card:hover,
body[data-theme="noir"] .wish-card:hover,
body[data-theme="noir"] .shared-list-card.is-hub-card:hover {
  box-shadow:
    inset 0 1.5px 0 var(--glass-rim),
    inset 0 0 0 1px var(--glass-edge),
    inset 0 -18px 36px -18px var(--glass-rim),
    0 28px 60px var(--glass-drop);
  transform: translateY(-3px);
}

/* Graceful fallback when backdrop-filter is unsupported (older WebViews):
   make the glass tint near-opaque so surfaces never look broken/see-through. */
@supports not ((backdrop-filter: blur(1px)) or (-webkit-backdrop-filter: blur(1px))) {
  :root {
    --glass-tint: rgba(255, 255, 255, 0.93);
  }
  body[data-theme="noir"] {
    --glass-tint: rgba(30, 30, 34, 0.96);
  }
}

/* Respect the user's reduced-transparency preference (a11y): drop the blur
   and use a near-solid tint so the UI stays calm and high-contrast. */
@media (prefers-reduced-transparency: reduce) {
  :root {
    --glass-blur: 0px;
    --glass-tint: rgba(255, 255, 255, 0.97);
  }
  body[data-theme="noir"] {
    --glass-tint: rgba(32, 32, 36, 0.98);
  }
}

/* ===================== BLOCO 4 — Tela Listas enxuta =====================
   Cabeçalho "Desejos" + menu ••• | pílulas roláveis | busca + filtro | resumo */
[data-view-panel="lists"] .lists-heading {
  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: space-between;
  text-align: left;
  gap: 12px;
  margin-bottom: 14px;
}
[data-view-panel="lists"] .lists-heading h2 {
  margin: 0;
  font-family: var(--font-display);
  font-weight: 500;
  font-size: 1.85rem;
  line-height: 1.1;
}

/* Switcher de listas vira faixa de pílulas roláveis (mostra só o nome). */
.wishlist-tabs {
  display: flex;
  grid-template-columns: none;
  gap: 8px;
  overflow-x: auto;
  scrollbar-width: none;
  -webkit-overflow-scrolling: touch;
  padding: 0 0 4px;
  margin-bottom: 14px;
}
.wishlist-tabs::-webkit-scrollbar {
  display: none;
}
.wishlist-tab {
  display: inline-flex;
  flex: none;
  grid-template-columns: none;
  align-items: center;
  min-height: 0;
  border-radius: 999px;
  background: var(--panel);
  border: 1px solid var(--line);
  color: var(--muted);
  padding: 9px 16px;
  box-shadow: none;
}
.wishlist-tab:hover {
  transform: none;
}
.wishlist-tab .tab-icon,
.wishlist-tab .tab-count,
.wishlist-tab .tab-share-badge,
.wishlist-tab .tab-share-action {
  display: none;
}
.wishlist-tab .tab-label {
  font-size: 0.82rem;
  font-weight: 600;
  white-space: nowrap;
}
.wishlist-tab.is-active {
  background: var(--oxblood);
  border-color: var(--oxblood);
  color: var(--paper);
  transform: none;
}
.wishlist-tab.is-active .tab-label {
  color: var(--paper);
}

/* Esconde o que saiu do empilhamento (foi pro menu ••• ou pro detalhe). */
.switcher-head,
.personal-share-panel,
#feederListsPanel,
#wishlistDensityBtn {
  display: none;
}
.wishlist-switcher {
  border: 0;
  background: transparent;
  box-shadow: none;
  padding: 0;
  margin: 0 0 4px;
}

/* Tools-row = busca + botão de filtro. */
.tools-row {
  display: flex;
  gap: 10px;
  align-items: center;
}
.tools-row .search-wrap {
  flex: 1;
}

/* Menu ••• de ações da lista (details nativo, sem JS de toggle). */
.list-menu {
  position: relative;
  flex: none;
}
.list-menu > summary {
  list-style: none;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  border-radius: 12px;
  border: 1px solid var(--line);
  background: var(--panel);
  color: var(--oxblood);
  cursor: pointer;
}
.list-menu > summary::-webkit-details-marker {
  display: none;
}
.list-menu-pop {
  position: absolute;
  right: 0;
  top: calc(100% + 6px);
  z-index: 30;
  display: flex;
  flex-direction: column;
  min-width: 210px;
  padding: 6px;
  border-radius: 16px;
  border: 1px solid var(--line);
  background: var(--panel);
  box-shadow: var(--shadow);
}
.list-menu-item {
  width: 100%;
  justify-content: flex-start;
  text-align: left;
  border: 0 !important;
  background: transparent !important;
  color: var(--ink) !important;
  border-radius: 10px;
  padding: 10px 12px !important;
  min-height: 0 !important;
  box-shadow: none !important;
  font-weight: 600;
}
.list-menu-item:hover {
  background: var(--blush) !important;
}
.list-menu-item.danger-btn {
  color: var(--oxblood) !important;
}

/* Painel de filtro (reúne os 4 <select> que saíram da tools-row). */
.filter-menu {
  position: relative;
  flex: none;
}
.filter-menu > summary {
  list-style: none;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 46px;
  height: 46px;
  border-radius: 14px;
  border: 1px solid var(--line);
  background: var(--panel);
  color: var(--oxblood);
  cursor: pointer;
}
.filter-menu > summary::-webkit-details-marker {
  display: none;
}
.filter-menu-pop {
  position: absolute;
  right: 0;
  top: calc(100% + 6px);
  z-index: 30;
  display: flex;
  flex-direction: column;
  gap: 8px;
  min-width: 220px;
  padding: 12px;
  border-radius: 16px;
  border: 1px solid var(--line);
  background: var(--panel);
  box-shadow: var(--shadow);
}
.filter-menu-pop select {
  width: 100%;
}

/* Linha de resumo discreta; esconde o "top wish" (modelo = itens · valor). */
/* Linha de resumo: UMA linha discreta (itens · valor), não dois caixotes. */
.list-summary-strip {
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  gap: 0 6px;
  margin: 8px 0 14px;
  font-size: 0.82rem;
  color: var(--muted);
}
.list-summary-strip > span {
  display: inline;
  min-height: 0;
  border: 0;
  background: none;
  padding: 0;
  border-radius: 0;
  color: var(--muted);
}
.list-summary-strip > span:first-child::after {
  content: "·";
  margin-left: 6px;
}
.list-summary-strip > span:nth-child(3) {
  display: none;
}
.list-summary-strip strong {
  font-size: inherit;
  font-weight: 700;
  color: var(--ink);
}
/* ===================== fim BLOCO 4 ===================== */

/* ============ FIDELIDADE — dock = barra chapada (igual ao mockup) ============
   Sobrepõe o dock flutuante liquid-glass: barra full-width com borda no topo,
   aba ativa só em COR (sem fundo de pílula), ícones sem moldura. As cores de
   inativo usam color-mix(--muted, --paper) p/ aproximar o tom claro do mockup
   (#bda6b0) sem hex novo, mantendo os 4 temas. */
.bottom-dock {
  left: 0;
  right: 0;
  bottom: 0;
  width: auto;
  max-width: none;
  transform: none;
  border: 0;
  border-top: 1px solid var(--line);
  border-radius: 0;
  background: rgba(255, 255, 255, 0.9);
  box-shadow: none;
  padding: 12px 14px calc(18px + env(safe-area-inset-bottom));
  -webkit-backdrop-filter: blur(14px);
  backdrop-filter: blur(14px);
  justify-content: space-around;
}
body[data-theme="noir"] .bottom-dock {
  border-top: 1px solid var(--line);
  background: rgba(22, 22, 26, 0.96);
  box-shadow: none;
}

.dock-nav-btn {
  flex: none;
  height: auto;
  border-radius: 0;
  background: transparent;
  padding: 0;
  color: color-mix(in srgb, var(--muted) 58%, var(--paper));
  font-size: 10.5px;
  font-weight: 600;
}
.dock-nav-btn span:last-child {
  font-size: 10.5px;
}
.dock-nav-btn.is-active {
  background: transparent;
  box-shadow: none;
  transform: none;
  color: var(--oxblood);
  font-weight: 700;
}
body[data-theme="noir"] .dock-nav-btn {
  color: color-mix(in srgb, var(--muted) 74%, var(--paper));
}
body[data-theme="noir"] .dock-nav-btn.is-active {
  background: transparent;
  box-shadow: none;
  color: var(--oxblood);
}

/* Ícones do dock sem moldura — só o traço, herdando a cor da aba (currentColor). */
.dock-symbol,
body[data-theme="noir"] .dock-symbol,
.dock-nav-btn.is-active .dock-symbol,
body[data-theme="noir"] .dock-nav-btn.is-active .dock-symbol {
  width: auto;
  height: auto;
  border: 0;
  background: none;
  box-shadow: none;
  color: inherit;
}

/* FAB ajustado para limpar a barra chapada. */
.fab-add {
  right: 22px;
  bottom: calc(86px + env(safe-area-inset-bottom));
}
/* ============ fim FIDELIDADE dock ============ */

/* ===================== BLOCO 5 — Tela Resumo enxuta =====================
   Saudação + 3 métricas + CTA + "Adicionados há pouco" + "Suas listas". */
.summary-panel {
  background: transparent;
  border: 0;
  box-shadow: none;
  padding: 0;
}

.summary-greeting {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 22px;
}
.summary-eyebrow {
  margin: 0 0 4px;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.2em;
  color: color-mix(in srgb, var(--rose) 60%, var(--muted));
}
#summaryGreeting {
  margin: 0;
  font-family: var(--font-display);
  font-weight: 500;
  font-size: 1.85rem;
  line-height: 1.1;
}
.summary-avatar {
  flex: none;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 42px;
  height: 42px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--blush), var(--rose));
  color: var(--paper);
  font-weight: 700;
  font-size: 15px;
}

/* 3 métricas em cartões brancos. */
.metric-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 10px;
  margin-bottom: 22px;
}
.metric-card {
  display: block;
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: 18px;
  padding: 16px 14px;
}
.metric-card strong {
  display: block;
  font-family: var(--font-display);
  font-size: 26px;
  font-weight: 500;
  line-height: 1;
}
.metric-card.metric-alerts strong {
  color: var(--oxblood);
}
.metric-card span {
  font-size: 12px;
  color: var(--muted);
}

/* CTA principal. */
.summary-cta {
  width: 100%;
  border: 0;
  border-radius: 18px;
  background: var(--oxblood);
  color: var(--paper);
  font-size: 16px;
  font-weight: 600;
  padding: 17px;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 9px;
  cursor: pointer;
  box-shadow: 0 14px 26px -12px rgba(var(--neon-strong-rgb), 0.6);
}

/* Cabeçalhos de seção. */
.summary-section-head {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  margin: 30px 0 14px;
}
.summary-section-head h3 {
  margin: 0;
  font-family: var(--font-display);
  font-size: 19px;
  font-weight: 500;
}
.summary-section-head .text-btn {
  font-size: 13px;
  font-weight: 600;
  color: var(--oxblood);
}

/* Recentes. */
.summary-recents {
  display: flex;
  gap: 12px;
}
.summary-recents.is-empty {
  color: var(--muted);
  font-size: 13px;
}
.summary-recent-card {
  flex: 1;
  display: block;
  border: 0;
  background: transparent;
  padding: 0;
  text-align: left;
  cursor: pointer;
}
.summary-recent-thumb {
  display: block;
  height: 104px;
  border-radius: 16px;
  margin-bottom: 8px;
  background: linear-gradient(150deg, var(--blush), color-mix(in srgb, var(--rose) 26%, var(--paper)));
  background-size: cover;
  background-position: center;
}
.summary-recent-name {
  display: block;
  margin: 0;
  font-size: 13px;
  font-weight: 600;
  line-height: 1.25;
}
.summary-recent-price {
  display: block;
  margin: 2px 0 0;
  font-size: 13px;
  font-weight: 700;
  color: var(--oxblood);
}

/* Linhas de listas. */
.summary-lists {
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.summary-list-row {
  display: flex;
  align-items: center;
  gap: 13px;
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: 16px;
  padding: 13px 15px;
  cursor: pointer;
  text-align: left;
}
.summary-list-icon {
  display: flex;
  color: var(--oxblood);
}
.summary-list-name {
  flex: 1;
  font-size: 14px;
  font-weight: 600;
  color: var(--ink);
}
.summary-list-count {
  font-size: 13px;
  color: var(--muted);
}
/* ===================== fim BLOCO 5 ===================== */

/* ===================== BLOCO 6 — Tela Conta =====================
   Perfil centralizado + linhas de ajuste + sair + danger. Tema/idioma migram
   do topbar para as linhas (setupAccountView). */
.topbar {
  display: none;
}

[data-view-panel="account"] .account-panel.summary-account {
  background: transparent;
  border: 0;
  box-shadow: none;
  padding: 8px 0 0;
}
[data-view-panel="account"] .account-copy {
  display: none;
}
[data-view-panel="account"] .account-card {
  background: transparent;
  border: 0;
  box-shadow: none;
  padding: 0;
}
/* Status só faz sentido deslogado; quando logado o perfil aparece. */
[data-view-panel="account"] .account-card:not(.needs-login) .account-status-row {
  display: none;
}

/* Perfil (profileHud restilizado para o mockup: avatar grande, centrado). */
.profile-hud {
  display: block;
}
.profile-hud .profile-card.social-profile-card {
  background: transparent;
  border: 0;
  box-shadow: none;
  padding: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
}
.profile-hud .profile-cover,
.profile-hud .profile-edit-grid,
.profile-hud #profileEmail,
.profile-hud #profileStats,
.profile-hud .profile-identity .section-kicker,
.profile-hud .profile-actions {
  display: none;
}
.profile-hud .profile-main-row {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 12px;
}
.profile-hud .profile-avatar {
  width: 78px;
  height: 78px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--blush), var(--rose));
  color: var(--paper);
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 28px;
  display: flex;
  align-items: center;
  justify-content: center;
}
.profile-hud #profileDisplayName {
  display: block;
  margin: 0 0 3px;
  font-family: var(--font-display);
  font-weight: 500;
  font-size: 24px;
}
.profile-hud #profileHandle {
  font-size: 13.5px;
  color: var(--muted);
}
.profile-hud .profile-stat-row {
  display: flex;
  justify-content: center;
  margin-top: 12px;
}
/* Pill verde "sincronizado". O verde é semântico (sucesso), fora da paleta de
   tema — mantém legível em todos os temas. */
.profile-hud #profileSyncBadge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: rgba(31, 122, 77, 0.12);
  color: #1f7a4d;
  font-size: 12px;
  font-weight: 600;
  padding: 7px 13px;
  border-radius: 999px;
}

/* Linhas de ajuste. */
.account-settings {
  display: flex;
  flex-direction: column;
  gap: 8px;
  margin-top: 24px;
}
.account-row {
  display: flex;
  align-items: center;
  gap: 14px;
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: 16px;
  padding: 15px 16px;
  cursor: pointer;
  text-align: left;
  width: 100%;
}
.account-row-icon {
  display: flex;
  color: var(--oxblood);
}
.account-row-label {
  flex: 1;
  font-size: 14.5px;
  font-weight: 600;
  color: var(--ink);
}
.account-row-control {
  display: flex;
  align-items: center;
}
.account-row-control select {
  border: 0;
  background: transparent;
  color: var(--muted);
  font-size: 13px;
  font-weight: 600;
  text-align: right;
  padding: 0;
  cursor: pointer;
}

/* Sair da conta. */
.account-signout-btn {
  width: 100%;
  margin-top: 22px;
  border: 1px solid var(--line);
  background: var(--panel);
  color: var(--oxblood);
  font-size: 14.5px;
  font-weight: 600;
  padding: 15px;
  border-radius: 16px;
  cursor: pointer;
}

/* Danger zone (excluir conta) no fim, recolhida. */
.account-danger {
  margin-top: 12px;
  border: 1px solid var(--line);
  border-radius: 16px;
  background: var(--panel);
  padding: 4px 16px;
}
.account-danger > summary {
  padding: 12px 0;
  font-size: 13.5px;
  font-weight: 600;
  color: var(--muted);
  cursor: pointer;
  list-style: none;
}
.account-danger > summary::-webkit-details-marker {
  display: none;
}
/* ===================== fim BLOCO 6 ===================== */

/* ===================== BLOCO 7 — Sistema de ícones (SVG inline) =====================
   Os ícones de categoria que eram desenhados em CSS (::before/::after) agora são
   SVG inline (categoryIconSvg). Onde o span recebe .icon-svg, suprimimos os
   pseudo-elementos e deixamos o SVG controlar o tamanho. */
.shared-mini-icon.icon-svg {
  width: auto;
  height: auto;
}
.shared-mini-icon.icon-svg::before,
.shared-mini-icon.icon-svg::after {
  content: none;
  display: none;
}
.icon-svg svg {
  display: block;
}
/* ===================== fim BLOCO 7 ===================== */

/* ===================== Explorar (Hub) — alinhar ao mockup 03 =====================
   Heading enxuto (sem kicker/card) + esconder busca/sort/atualizar/nova. */
[data-view-panel="shared"] .shared-heading {
  background: transparent;
  border: 0;
  box-shadow: none;
  padding: 0;
  margin-bottom: 4px;
}
[data-view-panel="shared"] .shared-heading .section-kicker {
  display: none;
}
[data-view-panel="shared"] .shared-heading h2 {
  margin: 0 0 4px;
  font-family: var(--font-display);
  font-weight: 500;
  font-size: 1.85rem;
  line-height: 1.1;
}
[data-view-panel="shared"] .shared-heading .view-description {
  margin: 0 0 14px;
  font-size: 13px;
  color: var(--muted);
}
/* O mockup nao mostra busca/sort/atualizar/nova-lista no Hub. */
.shared-toolbar .shared-search,
#sharedHubSortWrap,
#sharedRefreshHubBtn,
#newSharedListBtn {
  display: none !important;
}
.shared-shell {
  background: transparent;
  border: 0;
  box-shadow: none;
  padding: 0;
}
.shared-toolbar {
  background: transparent;
  border: 0;
  box-shadow: none;
  padding: 0;
}
/* A toolbar-row ficou vazia (tudo escondido) + o scope antigo vira o segmento. */
.shared-toolbar-row,
#sharedHubScopeBtn {
  display: none !important;
}
/* Segmento "Em alta / Salvas" (mockup 03). */
.hub-segment {
  display: flex;
  background: color-mix(in srgb, var(--rose) 16%, var(--paper));
  border-radius: 13px;
  padding: 4px;
  margin-bottom: 18px;
}
.hub-segment-tab {
  flex: 1;
  border: 0;
  background: transparent;
  color: var(--muted);
  font-size: 13px;
  font-weight: 600;
  padding: 8px;
  border-radius: 10px;
  cursor: pointer;
}
.hub-segment-tab.is-active {
  background: var(--panel);
  color: var(--ink);
  box-shadow: 0 2px 6px rgba(var(--neon-strong-rgb), 0.12);
}

/* ---- Card de destaque (mockup 03): capa em gradiente + pilula "Em destaque",
   titulo serifado e rodape curtidas/salvos + @handle. Neutraliza a moldura
   horizontal antiga de .shared-hub-hero. ---- */
[data-view-panel="shared"] .shared-hub-hero {
  display: block;
  grid-template-columns: none;
  gap: 0;
  min-height: 0;
  margin-bottom: 16px;
  padding: 0;
  border: 1px solid var(--line);
  border-radius: 18px;
  background: var(--panel);
  box-shadow: 0 12px 30px rgba(var(--neon-strong-rgb), 0.08);
  cursor: pointer;
}
[data-view-panel="shared"] .shared-hub-hero::before {
  display: none;
}
[data-view-panel="shared"] .shared-hub-hero:hover,
[data-view-panel="shared"] .shared-hub-hero:focus-visible {
  transform: translateY(-1px);
  border-color: rgba(var(--neon-rgb), 0.4);
  box-shadow: 0 16px 36px rgba(var(--neon-strong-rgb), 0.12);
}
.hub-feature-cover {
  position: relative;
  display: block;
  height: 132px;
  overflow: hidden;
  border-radius: 17px 17px 0 0;
  background:
    linear-gradient(150deg, rgba(var(--neon-rgb), 0.62), rgba(var(--neon-rgb), 0.18) 58%, rgba(255, 255, 255, 0.42)),
    var(--blush);
}
.hub-feature-cover img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.hub-feature-cover img.is-hidden {
  display: none;
}
.hub-feature-badge {
  position: absolute;
  top: 12px;
  left: 12px;
  display: inline-flex;
  align-items: center;
  gap: 5px;
  border-radius: 999px;
  background: rgba(var(--neon-strong-rgb), 0.52);
  -webkit-backdrop-filter: blur(8px);
  backdrop-filter: blur(8px);
  color: var(--paper);
  padding: 5px 11px;
  font-size: 11px;
  font-weight: 700;
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.36);
}
.hub-feature-badge::before {
  content: "\2605";
  font-size: 10px;
  line-height: 1;
}
.hub-feature-title {
  display: block;
  margin: 12px 14px 0;
  color: var(--ink);
  font-family: var(--font-display);
  font-size: 1.32rem;
  font-weight: 500;
  line-height: 1.12;
}
.hub-feature-foot {
  display: flex;
  align-items: center;
  gap: 10px;
  margin: 7px 14px 14px;
}
.hub-feature-stats {
  display: flex;
  align-items: center;
  gap: 16px;
  flex: 1;
  min-width: 0;
}
.hub-feature-stats .hub-stat {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  color: var(--muted);
  font-size: 12px;
  font-weight: 600;
}
.hub-stat-likes::before {
  content: "\2665";
  color: var(--oxblood);
  font-size: 12px;
  line-height: 1;
}
.hub-feature-handle {
  flex: none;
  border: 0;
  background: transparent;
  color: var(--oxblood);
  padding: 0;
  font: inherit;
  font-size: 12px;
  font-weight: 700;
  cursor: pointer;
}
.hub-feature-handle:hover,
.hub-feature-handle:focus-visible {
  text-decoration: underline;
}

/* ---- Grade 2 colunas + card simples do mockup (capa, titulo serifado,
   "N salvaram"). Variacao sutil de tonalidade por posicao, so com tokens. ---- */
[data-view-panel="shared"] .shared-lists-grid.is-explore-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  align-items: start;
  gap: 14px;
}
.shared-list-card.hub-feed-card {
  display: flex;
  flex-direction: column;
  gap: 0;
  padding: 0;
  overflow: hidden;
  border: 1px solid var(--line);
  border-radius: 16px;
  background: var(--panel);
  box-shadow: 0 10px 24px rgba(var(--neon-strong-rgb), 0.06);
  cursor: pointer;
}
.hub-feed-cover {
  position: relative;
  height: 96px;
  overflow: hidden;
  background:
    linear-gradient(150deg, rgba(var(--neon-rgb), 0.5), rgba(var(--neon-rgb), 0.14) 62%, rgba(255, 255, 255, 0.34)),
    var(--blush);
}
.hub-feed-card:nth-child(3n+2) .hub-feed-cover {
  background:
    linear-gradient(150deg, rgba(var(--neon-strong-rgb), 0.22), rgba(var(--neon-rgb), 0.1) 60%, rgba(255, 255, 255, 0.34)),
    color-mix(in srgb, var(--rose) 24%, var(--paper));
}
.hub-feed-card:nth-child(3n) .hub-feed-cover {
  background:
    linear-gradient(150deg, color-mix(in srgb, var(--gold) 44%, transparent), rgba(255, 255, 255, 0.3) 70%),
    color-mix(in srgb, var(--gold) 22%, var(--paper));
}
.hub-feed-cover img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.hub-feed-cover img.is-hidden {
  display: none;
}
.hub-feed-title {
  margin: 10px 12px 0;
  color: var(--ink);
  font-family: var(--font-display);
  font-size: 0.98rem;
  font-weight: 500;
  line-height: 1.14;
}
.hub-feed-saves {
  margin: 4px 12px 12px;
  color: var(--muted);
  font-size: 11px;
  font-weight: 600;
}
.shared-list-card.hub-feed-card:hover {
  transform: translateY(-2px);
  border-color: rgba(var(--neon-rgb), 0.36);
  box-shadow: 0 16px 32px rgba(var(--neon-strong-rgb), 0.1);
}

/* Skeleton do card vertical (espelha capa + 2 linhas). */
.hub-feed-card.shared-skeleton-card {
  cursor: default;
}
.hub-feed-card .shared-skeleton-cover {
  grid-column: auto;
  grid-row: auto;
  min-height: 0;
  height: 96px;
  border-radius: 0;
}
.hub-feed-card .shared-skeleton-lines {
  grid-column: auto;
  padding: 10px 12px 12px;
  gap: 7px;
}
.hub-feed-card .shared-skeleton-lines i:nth-child(1) {
  width: 82%;
}
.hub-feed-card .shared-skeleton-lines i:nth-child(2) {
  width: 46%;
}
/* ===================== fim Explorar ===================== */

/* ===================== BLOCO 1 v2 — empty-states & skeleton =====================
   Nunca mostrar tela morta: lista vazia / busca sem resultado / skeleton ao
   detectar link. Cores via tokens; animacoes respeitam prefers-reduced-motion. */
.empty-state {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding: 48px 24px;
  min-height: 0;
  border: 0;
  background: transparent;
  border-radius: 0;
}
.empty-state__art {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 120px;
  height: 120px;
  border-radius: 34px;
  margin-bottom: 26px;
  background: linear-gradient(150deg, var(--blush), color-mix(in srgb, var(--rose) 40%, var(--paper)));
  color: var(--oxblood);
  animation: floatUp 3.4s ease-in-out infinite;
}
.empty-state__art.is-search {
  background: linear-gradient(150deg, var(--sage), var(--chrome));
  color: var(--muted);
}
.empty-state h3 {
  margin: 0 0 10px;
  font-family: var(--font-display);
  font-weight: 500;
  font-size: 24px;
}
.empty-state p {
  margin: 0 0 26px;
  max-width: 260px;
  font-size: 15px;
  line-height: 1.5;
  color: var(--muted);
}
.empty-state__btn {
  min-width: 0;
}
.empty-state__btn.primary-btn {
  background: var(--oxblood);
  color: var(--paper);
}

@keyframes floatUp {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(-10px); }
}

/* Skeleton shimmer ao detectar produto. */
@keyframes shimmer {
  0% { background-position: -380px 0; }
  100% { background-position: 380px 0; }
}
.skel {
  background: linear-gradient(90deg, var(--line) 25%, var(--paper) 50%, var(--line) 75%);
  background-size: 760px 100%;
  animation: shimmer 1.4s infinite linear;
  border-radius: 8px;
}
.capture-skeleton {
  display: flex;
  flex-direction: column;
  gap: 14px;
  padding: 4px 0;
}
.capture-skeleton-status {
  display: flex;
  align-items: center;
  gap: 8px;
  margin: 0;
  font-size: 13px;
  font-weight: 600;
  color: var(--oxblood);
}
.capture-spinner {
  width: 14px;
  height: 14px;
  flex: none;
  border-radius: 50%;
  border: 2px solid color-mix(in srgb, var(--oxblood) 28%, transparent);
  border-top-color: var(--oxblood);
  animation: spin 0.7s linear infinite;
}
@keyframes spin {
  to { transform: rotate(360deg); }
}
.capture-skeleton-card {
  display: flex;
  gap: 14px;
}
.capture-skeleton-img {
  flex: none;
  width: 96px;
  height: 96px;
  border-radius: 16px;
}
.capture-skeleton-lines {
  display: flex;
  flex-direction: column;
  gap: 9px;
  flex: 1;
  padding-top: 6px;
}
.capture-skeleton-lines .skel {
  height: 12px;
}
.capture-skeleton-field {
  height: 44px;
  border-radius: 14px;
}
.capture-skeleton-row {
  display: flex;
  gap: 12px;
}
.capture-skeleton-field-half {
  flex: 1;
  height: 44px;
  border-radius: 14px;
}

/* Durante a detecção, o painel de diagnóstico de scan some para o skeleton
   ficar limpo (o restante da limpeza do "add" é o Bloco 9b do v1). */
body.is-detecting .scan-health-panel {
  display: none;
}

@media (prefers-reduced-motion: reduce) {
  .empty-state__art,
  .skel,
  .capture-spinner {
    animation: none;
  }
}
/* ===================== fim BLOCO 1 v2 ===================== */

/* ===================== BLOCO 9a — detalhe do item (liquid glass) =====================
   Aberto ao tocar num card. Foto full-bleed no topo + folha de vidro deslizando
   por cima, com preco, queda, chips, historico, notas e barra "Comprar no site".
   Usa so tokens da paleta; o verde da queda e os dots de prioridade sao cores
   semanticas (sucesso/urgencia), iguais as ja usadas no app (badge sincronizado). */
.item-detail {
  position: fixed;
  inset: 0;
  z-index: 70;
  display: flex;
  flex-direction: column;
  background: var(--paper);
  overflow: hidden;
  animation: itemDetailFade 220ms ease both;
}
.item-detail.is-hidden {
  display: none;
}
.item-detail.is-leaving {
  animation: itemDetailFade 200ms ease reverse both;
}

/* --- Foto --- */
.item-detail__media {
  position: relative;
  flex: 0 0 46%;
  min-height: 270px;
  overflow: hidden;
  background:
    radial-gradient(120% 90% at 30% 12%, color-mix(in srgb, var(--paper) 70%, transparent), transparent 60%),
    linear-gradient(165deg, color-mix(in srgb, var(--rose) 52%, var(--paper)), var(--rose));
}
.item-detail__photo {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.item-detail__photo.is-hidden {
  display: none;
}
.item-detail__photo-fallback {
  position: absolute;
  inset: 0;
  display: grid;
  place-items: center;
}
.item-detail__photo-fallback.is-hidden {
  display: none;
}
.item-detail__photo-fallback span {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 46px;
  color: color-mix(in srgb, var(--oxblood) 36%, var(--paper));
}

/* --- Botoes de vidro (voltar / share / favoritar) --- */
.item-detail__nav {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: calc(14px + env(safe-area-inset-top)) 16px 0;
  z-index: 3;
}
.item-detail__nav-right {
  display: flex;
  gap: 10px;
}
.item-detail__glass-btn {
  width: 42px;
  height: 42px;
  border-radius: 50%;
  display: grid;
  place-items: center;
  cursor: pointer;
  color: var(--oxblood);
  background: var(--glass-tint);
  border: 1px solid var(--glass-edge);
  box-shadow: inset 0 1px 0 var(--glass-rim), 0 6px 16px -8px rgba(var(--neon-strong-rgb), 0.5);
  -webkit-backdrop-filter: blur(16px) saturate(1.6);
  backdrop-filter: blur(16px) saturate(1.6);
  transition: transform 140ms ease, background 140ms ease;
}
.item-detail__glass-btn:active {
  transform: scale(0.92);
}
.item-detail__glass-btn.is-active {
  background: color-mix(in srgb, var(--oxblood) 16%, var(--glass-tint));
}
.item-detail__glass-btn.is-active svg {
  fill: var(--oxblood);
}

/* --- Folha de vidro --- */
.item-detail__sheet {
  position: relative;
  z-index: 2;
  flex: 1 1 auto;
  min-height: 0;
  margin-top: -56px;
  display: flex;
  flex-direction: column;
  border-radius: 34px 34px 0 0;
  background: color-mix(in srgb, var(--paper) 80%, transparent);
  border-top: 1px solid var(--glass-rim);
  box-shadow:
    0 -16px 50px -20px rgba(var(--neon-strong-rgb), 0.4),
    inset 0 1px 0 var(--glass-rim);
  -webkit-backdrop-filter: blur(26px) saturate(1.8);
  backdrop-filter: blur(26px) saturate(1.8);
  animation: itemDetailSheet 320ms cubic-bezier(0.2, 0.8, 0.2, 1) both;
}
.item-detail__handle {
  width: 42px;
  height: 5px;
  border-radius: 999px;
  background: color-mix(in srgb, var(--oxblood) 22%, transparent);
  margin: 10px auto 2px;
  flex: 0 0 auto;
}
.item-detail__scroll {
  flex: 1 1 auto;
  min-height: 0;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
  padding: 8px 24px 12px;
}

/* --- Textos --- */
.item-detail__eyebrow {
  margin: 6px 0 6px;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: color-mix(in srgb, var(--oxblood) 62%, var(--rose));
}
.item-detail__eyebrow:empty {
  display: none;
}
.item-detail__title {
  margin: 0 0 14px;
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 26px;
  line-height: 1.16;
  color: var(--ink);
}
.item-detail__price-row {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 10px;
  margin-bottom: 16px;
}
.item-detail__price {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 34px;
  line-height: 1;
  color: var(--ink);
}
.item-detail__drop {
  display: inline-flex;
  align-items: center;
  gap: 3px;
  padding: 6px 11px;
  border-radius: 999px;
  font-size: 13px;
  font-weight: 700;
  background: rgba(31, 122, 77, 0.14);
  color: #1f7a4d;
}
.item-detail__drop.is-hidden {
  display: none;
}
.item-detail__drop svg {
  width: 13px;
  height: 13px;
}
.item-detail__old-price {
  font-size: 15px;
  color: var(--muted);
  text-decoration: line-through;
}
.item-detail__old-price.is-hidden {
  display: none;
}

/* --- Chips de meta --- */
.item-detail__chips {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-bottom: 22px;
}
.item-detail__chip {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 7px 13px;
  border-radius: 999px;
  font-size: 12.5px;
  font-weight: 600;
  color: var(--ink);
  background: color-mix(in srgb, var(--paper) 55%, transparent);
  border: 1px solid var(--glass-edge);
  box-shadow: inset 0 1px 0 var(--glass-rim);
}
.item-detail__chip-dot {
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: var(--gold);
}
.item-detail__chip[data-priority="Alta"] .item-detail__chip-dot {
  background: #e0392f;
}
.item-detail__chip[data-priority="Media"] .item-detail__chip-dot {
  background: var(--gold);
}
.item-detail__chip[data-priority="Baixa"] .item-detail__chip-dot {
  background: #4f9e78;
}

/* --- Onde comprar: multi-loja + comparar + acompanhar melhor preco --- */
.item-detail__stores {
  margin-bottom: 22px;
}
.item-detail__stores.is-hidden { display: none; }
.item-detail__stores-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  margin-bottom: 10px;
}
.item-detail__stores-head .item-detail__label { margin: 0; }
.item-detail__add-store {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  border: 1px solid var(--glass-edge);
  border-radius: 999px;
  background: color-mix(in srgb, var(--paper) 55%, transparent);
  color: var(--oxblood);
  padding: 5px 11px;
  font-size: 12px;
  font-weight: 700;
  cursor: pointer;
}
.item-detail__store-list {
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.store-row {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 10px 12px;
  border-radius: 14px;
  border: 1px solid var(--glass-edge);
  background: color-mix(in srgb, var(--paper) 45%, transparent);
}
.store-row.is-best {
  border-color: color-mix(in srgb, #1f7a4d 55%, transparent);
  background: color-mix(in srgb, #1f7a4d 12%, var(--paper));
}
.store-row__name {
  flex: 1 1 auto;
  min-width: 0;
  font-size: 13.5px;
  font-weight: 600;
  color: var(--ink);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.store-row__best {
  flex: none;
  font-size: 9.5px;
  font-weight: 800;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: #fff;
  background: #1f7a4d;
  padding: 3px 7px;
  border-radius: 999px;
}
.store-row__best.is-hidden { display: none; }
.store-row__price {
  flex: none;
  font-size: 13.5px;
  font-weight: 700;
  color: var(--ink);
  white-space: nowrap;
}
.store-row.is-best .store-row__price { color: #1f7a4d; }
.store-row__open,
.store-row__remove {
  flex: none;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 30px;
  height: 30px;
  border-radius: 50%;
  border: 0;
  background: transparent;
  cursor: pointer;
}
.store-row__open { color: var(--oxblood); }
.store-row__remove { color: var(--muted); font-size: 18px; line-height: 1; }
.store-row__remove.is-hidden { display: none; }

.item-detail__compare { margin-top: 14px; }
.item-detail__compare.is-hidden { display: none; }
.item-detail__compare-label {
  margin: 0 0 8px;
  font-size: 11.5px;
  font-weight: 600;
  color: var(--muted);
}
.item-detail__compare-chips { display: flex; flex-wrap: wrap; gap: 8px; }
.compare-chip {
  display: inline-flex;
  align-items: center;
  padding: 6px 12px;
  border-radius: 999px;
  border: 1px solid var(--glass-edge);
  background: color-mix(in srgb, var(--paper) 55%, transparent);
  color: var(--ink);
  font-size: 12px;
  font-weight: 600;
  text-decoration: none;
}
.compare-chip:active { transform: scale(0.97); }

.item-detail__track {
  margin-top: 16px;
  padding-top: 14px;
  border-top: 1px solid var(--glass-edge);
}
.track-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}
.track-copy strong { display: block; font-size: 13.5px; font-weight: 700; color: var(--ink); }
.track-sub { font-size: 11.5px; color: var(--muted); }
.track-toggle {
  flex: none;
  width: 46px;
  height: 28px;
  border-radius: 999px;
  border: 0;
  background: color-mix(in srgb, var(--ink) 18%, transparent);
  position: relative;
  cursor: pointer;
  transition: background 0.18s ease;
}
.track-toggle .track-knob {
  position: absolute;
  top: 3px;
  left: 3px;
  width: 22px;
  height: 22px;
  border-radius: 50%;
  background: #fff;
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.25);
  transition: transform 0.18s ease;
}
.track-toggle.is-on { background: var(--oxblood); }
.track-toggle.is-on .track-knob { transform: translateX(18px); }
.track-target {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  width: 100%;
  margin-top: 12px;
  padding: 10px 12px;
  border-radius: 12px;
  border: 1px solid var(--glass-edge);
  background: color-mix(in srgb, var(--paper) 45%, transparent);
  color: var(--ink);
  font-size: 12.5px;
  font-weight: 600;
  cursor: pointer;
}
.track-target.is-hidden { display: none; }
.track-target svg { color: var(--oxblood); flex: none; }

/* --- Historico + notas --- */
.item-detail__label {
  margin: 0 0 10px;
  font-size: 10.5px;
  font-weight: 700;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--muted);
}
.item-detail__history {
  margin-bottom: 22px;
}
.item-detail__history.is-hidden,
.item-detail__notes.is-hidden {
  display: none;
}
.item-detail__bars {
  display: flex;
  align-items: flex-end;
  gap: 9px;
  height: 96px;
  margin-bottom: 8px;
}
.item-detail__bar {
  flex: 1 1 0;
  border-radius: 8px 8px 4px 4px;
  background: rgba(var(--neon-strong-rgb), 0.16);
}
.item-detail__bar.is-current {
  background: linear-gradient(180deg, var(--rose), var(--oxblood));
}
.item-detail__history-caption {
  margin: 0;
  font-size: 12px;
  color: var(--muted);
}
.item-detail__notes {
  margin-bottom: 8px;
}
.item-detail__notes-text {
  margin: 0;
  font-size: 14.5px;
  line-height: 1.5;
  color: color-mix(in srgb, var(--ink) 82%, var(--muted));
}

/* --- Gerenciar (editar / remover) — preserva acesso ja que o card nao expande --- */
.item-detail__manage {
  display: flex;
  gap: 10px;
  margin-top: 18px;
}
.item-detail__manage-btn {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  padding: 9px 14px;
  border-radius: 13px;
  font-size: 13px;
  font-weight: 600;
  cursor: pointer;
  color: var(--ink);
  background: color-mix(in srgb, var(--paper) 50%, transparent);
  border: 1px solid var(--glass-edge);
}
.item-detail__manage-btn.is-danger {
  color: var(--oxblood);
}
.item-detail__manage-btn:active {
  transform: scale(0.97);
}

/* --- Barra fixa "Comprar no site" --- */
.item-detail__buybar {
  flex: 0 0 auto;
  padding: 16px 24px calc(18px + env(safe-area-inset-bottom));
  background: linear-gradient(180deg, transparent, color-mix(in srgb, var(--paper) 92%, transparent) 42%);
}
.item-detail__buy {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 17px;
  border-radius: 18px;
  font-size: 15px;
  font-weight: 700;
  text-decoration: none;
  color: var(--paper);
  background: var(--oxblood);
  box-shadow: 0 16px 30px -12px rgba(var(--neon-strong-rgb), 0.7);
}
.item-detail__buy.is-disabled {
  opacity: 0.5;
  pointer-events: none;
}

@keyframes itemDetailFade {
  from { opacity: 0; }
  to { opacity: 1; }
}
@keyframes itemDetailSheet {
  from { transform: translateY(34px); opacity: 0.4; }
  to { transform: translateY(0); opacity: 1; }
}
@media (prefers-reduced-motion: reduce) {
  .item-detail,
  .item-detail.is-leaving,
  .item-detail__sheet {
    animation: none;
  }
}
/* ===================== fim BLOCO 9a ===================== */

/* ===================== BLOCO 9b — adicionar produto em 3 passos =====================
   Fluxo enxuto (mockup 06): cabecalho com voltar + "Adicionar item", stepper
   Link/Revisar/Salvo, link colapsado + card "Detectamos", form minimo (Nome,
   Preco, Lista) com "+ Mais detalhes" revelando os avancados, e barra fixa
   "Salvar na lista". So tokens da paleta; verde do check e semantico (sucesso). */

/* O dock some no fluxo focado de adicionar — o botao voltar assume a navegacao. */
body[data-active-view="add"] .bottom-dock {
  display: none;
}
/* Esconde a intro antiga, o relatorio de scan e o preview grande de imagem. */
[data-view-panel="add"] .add-intro,
[data-view-panel="add"] .scan-health-panel,
[data-view-panel="add"] .review-image-wrap {
  display: none;
}

/* --- Cabecalho --- */
.add-heading {
  display: grid;
  grid-template-columns: 40px 1fr 40px;
  align-items: center;
  margin-bottom: 4px;
}
.add-back-btn {
  width: 40px;
  height: 40px;
  display: grid;
  place-items: center;
  border-radius: 50%;
  cursor: pointer;
  color: var(--oxblood);
  background: var(--panel);
  border: 1px solid var(--line);
}
.add-back-btn:active {
  transform: scale(0.94);
}
.add-heading h2 {
  margin: 0;
  text-align: center;
  font-family: var(--font-display);
  font-weight: 500;
  font-size: 1.5rem;
  color: var(--ink);
}

/* --- Stepper Link / Revisar / Salvo (circulos numerados + conectores) --- */
.flow-state {
  display: flex;
  align-items: center;
  gap: 0;
  margin: 8px 0 18px;
  padding: 0;
  list-style: none;
  counter-reset: step;
}
.flow-state li {
  display: flex;
  align-items: center;
  gap: 8px;
  flex: 1 1 0;
  min-height: 0;
  border: 0;
  border-radius: 0;
  background: transparent;
  color: var(--muted);
  font-size: 0.8rem;
  font-weight: 700;
  text-transform: none;
  letter-spacing: 0;
}
.flow-state li:last-child {
  flex: 0 0 auto;
}
.flow-state li::before {
  counter-increment: step;
  content: counter(step);
  width: 24px;
  height: 24px;
  display: grid;
  place-items: center;
  border-radius: 50%;
  flex: 0 0 auto;
  background: color-mix(in srgb, var(--muted) 22%, var(--paper));
  color: var(--muted);
  font-size: 0.74rem;
  font-weight: 800;
}
.flow-state li:not(:last-child)::after {
  content: "";
  flex: 1 1 auto;
  min-width: 12px;
  height: 2px;
  margin-left: 8px;
  border-radius: 999px;
  background: var(--line);
}
.flow-state li.is-active {
  color: var(--oxblood);
}
.flow-state li.is-active::before {
  background: var(--oxblood);
  color: var(--paper);
}
.flow-state li.is-done {
  color: var(--oxblood);
}
/* Passo concluido = circulo cheio oxblood mantendo o NUMERO (igual ao mockup). */
.flow-state li.is-done::before {
  background: var(--oxblood);
  color: var(--paper);
}
.flow-state li.is-done:not(:last-child)::after {
  background: var(--oxblood);
}

/* --- Link colapsado (etapa Revisar): check verde + url + Trocar --- */
[data-view-panel="add"][data-stage="review"] .capture-panel .link-row,
[data-view-panel="add"][data-stage="review"] .capture-panel .capture-meta,
[data-view-panel="add"][data-stage="review"] .capture-panel #pasteHint {
  display: none;
}
[data-view-panel="add"]:not([data-stage="review"]) .captured-link {
  display: none;
}
.captured-link {
  display: flex;
  align-items: center;
  gap: 9px;
}
.captured-link.is-hidden {
  display: none;
}
.captured-link-check {
  flex: 0 0 auto;
  color: #1f7a4d;
}
.captured-link-url {
  flex: 1 1 auto;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  font-size: 0.85rem;
  color: var(--muted);
}
.captured-link .text-btn {
  flex: 0 0 auto;
  color: var(--oxblood);
  font-weight: 700;
}

/* --- Card "Detectamos" (sem moldura: miniatura + texto soltos, como no mockup) --- */
.detected-card {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 0;
  background: transparent;
  border: 0;
}
.detected-card.is-hidden {
  display: none;
}
.detected-thumb {
  position: relative;
  width: 64px;
  height: 64px;
  flex: 0 0 auto;
  border-radius: 14px;
  overflow: hidden;
  display: grid;
  place-items: center;
  background: linear-gradient(160deg, color-mix(in srgb, var(--rose) 50%, var(--paper)), var(--rose));
}
.detected-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.detected-thumb img.is-hidden {
  display: none;
}
.detected-thumb span {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 1.1rem;
  color: color-mix(in srgb, var(--oxblood) 40%, var(--paper));
}
.detected-thumb span.is-hidden {
  display: none;
}
.detected-info {
  display: grid;
  gap: 3px;
  min-width: 0;
}
.detected-eyebrow {
  margin: 0;
  font-size: 0.62rem;
  font-weight: 800;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--muted);
}
.detected-name {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 1rem;
  line-height: 1.2;
  color: var(--ink);
}
.detected-price {
  font-size: 0.92rem;
  font-weight: 700;
  color: var(--oxblood);
}

/* --- "+ Mais detalhes" + revelacao dos campos avancados --- */
.more-details-toggle {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  justify-self: start;
  padding: 6px 2px;
  border: 0;
  background: transparent;
  color: var(--oxblood);
  font-size: 0.9rem;
  font-weight: 700;
  cursor: pointer;
}
.more-details-sign {
  flex: 0 0 auto;
  transition: transform 160ms ease;
}
.more-details-toggle.is-open .more-details-sign {
  transform: rotate(45deg);
}
.more-details-hint {
  font-size: 0.78rem;
  font-weight: 500;
  color: var(--muted);
}
@media (prefers-reduced-motion: reduce) {
  .more-details-sign {
    transition: none;
  }
}
.review-form.show-advanced .review-advanced-field {
  display: grid;
}

/* --- Painel de review em coluna unica + barra fixa "Salvar na lista" --- */
[data-view-panel="add"] .review-panel {
  grid-template-columns: 1fr;
}
/* Form em 2 colunas mesmo no mobile, p/ Preco | Lista lado a lado (mockup 06).
   Os campos largos usam .span-2 (Nome, Mais detalhes, Imagem, Link, Notas). O
   media query mobile zera o .span-2, entao restauramos aqui. */
[data-view-panel="add"] .review-form .form-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}
[data-view-panel="add"] .review-form .form-grid .span-2 {
  grid-column: span 2;
}
[data-view-panel="add"] .review-form .form-actions {
  position: sticky;
  bottom: 0;
  margin: 8px -16px 0;
  padding: 14px 16px calc(14px + env(safe-area-inset-bottom));
  background: linear-gradient(180deg, transparent, color-mix(in srgb, var(--paper) 94%, transparent) 38%);
}
[data-view-panel="add"] .review-form .form-actions #cancelReviewBtn {
  display: none;
}
[data-view-panel="add"] .review-form .form-actions button[type="submit"] {
  width: 100%;
  min-height: 52px;
  border-radius: 18px;
  font-size: 1rem;
}
[data-view-panel="add"] .review-form .form-actions button[type="submit"]::before {
  content: "\2713";
  margin-right: 8px;
  font-weight: 700;
}
/* ===================== fim BLOCO 9b ===================== */

/* ===================== BLOCO 9c — lista publica do Hub (mockup 07) =====================
   Reorganiza SO a previa de lista publica (.is-hub-preview): capa full-bleed no
   topo + botao voltar de vidro -> folha branca (titulo, autor, curtidas/salvaram,
   Salvar lista, itens) -> moderacao discreta no rodape. A lista do dono e o perfil
   do criador ficam intactos. So tokens da paleta; verde do check semantico. */
.shared-detail-panel.is-hub-preview:not(.is-creator-profile) {
  display: flex;
  flex-direction: column;
  gap: 0;
  padding: 0;
  overflow: hidden;
  background: var(--panel);
}
.shared-detail-panel.is-hub-preview:not(.is-creator-profile)::before {
  display: none;
}

/* Ordem: capa -> folha(head) -> itens -> similares -> moderacao */
.shared-detail-panel.is-hub-preview:not(.is-creator-profile) #sharedDetailHero {
  order: 1;
}
.shared-detail-panel.is-hub-preview:not(.is-creator-profile) .shared-detail-head {
  order: 2;
}
.shared-detail-panel.is-hub-preview:not(.is-creator-profile) #sharedItemsList {
  order: 3;
}
.shared-detail-panel.is-hub-preview:not(.is-creator-profile) #sharedSimilarLists {
  order: 4;
}
.shared-detail-panel.is-hub-preview:not(.is-creator-profile) #sharedHubSafety {
  order: 5;
}

/* Capa full-bleed no topo */
.shared-detail-panel.is-hub-preview:not(.is-creator-profile) .shared-detail-hero {
  display: block;
  margin: 0;
  padding: 0;
  border: 0;
  border-radius: 0;
  background: none;
}
.shared-detail-panel.is-hub-preview:not(.is-creator-profile) .shared-detail-hero-copy {
  display: none;
}
.shared-detail-panel.is-hub-preview:not(.is-creator-profile) .shared-detail-cover {
  min-height: 240px;
  border: 0;
  border-radius: 0;
  box-shadow: none;
}

/* Folha branca subindo sobre a base da capa. position:static p/ o botao voltar
   (absolute) se ancorar no PAINEL (e flutuar na capa), nao na folha; o z-index
   ainda funciona porque a folha e um flex-item. */
.shared-detail-panel.is-hub-preview:not(.is-creator-profile) .shared-detail-head {
  position: static;
  z-index: 2;
  display: block;
  margin-top: -30px;
  padding: 24px 20px 4px;
  background: var(--panel);
  border: 0;
  border-radius: 30px 30px 0 0;
  box-shadow: none;
  -webkit-backdrop-filter: none;
  backdrop-filter: none;
}

/* Botao voltar de vidro flutuando sobre a capa */
.shared-detail-panel.is-hub-preview:not(.is-creator-profile) #closeSharedDetailBtn {
  position: absolute;
  top: calc(14px + env(safe-area-inset-top));
  left: 16px;
  z-index: 5;
  width: 42px;
  min-width: 42px;
  height: 42px;
  padding: 0;
  border-radius: 50%;
  display: grid;
  place-items: center;
  font-size: 1.5rem;
  line-height: 1;
  color: var(--oxblood);
  background: var(--glass-tint);
  border: 1px solid var(--glass-edge);
  box-shadow: inset 0 1px 0 var(--glass-rim), 0 6px 16px -8px rgba(var(--neon-strong-rgb), 0.5);
  -webkit-backdrop-filter: blur(16px) saturate(1.6);
  backdrop-filter: blur(16px) saturate(1.6);
}

/* Titulo serif na folha */
.shared-detail-panel.is-hub-preview:not(.is-creator-profile) #sharedDetailTitle {
  margin: 0;
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 1.9rem;
  line-height: 1.12;
  color: var(--ink);
}

/* Bloco do autor (avatar + nome + @handle) */
.shared-detail-author {
  display: flex;
  align-items: center;
  gap: 10px;
  width: 100%;
  margin: 14px 0 0;
  padding: 0;
  border: 0;
  background: transparent;
  text-align: left;
  cursor: pointer;
}
.shared-detail-author.is-hidden {
  display: none;
}
.shared-author-avatar {
  width: 38px;
  height: 38px;
  flex: 0 0 auto;
  border-radius: 50%;
  display: grid;
  place-items: center;
  font-weight: 700;
  font-size: 0.82rem;
  color: color-mix(in srgb, var(--oxblood) 72%, var(--paper));
  background: linear-gradient(160deg, color-mix(in srgb, var(--rose) 55%, var(--paper)), var(--rose));
}
.shared-author-meta {
  display: grid;
  gap: 1px;
  min-width: 0;
}
/* Handle e a linha forte de cima; nome (real) fica como subtitulo mutado (mockup 07). */
.shared-author-handle {
  font-size: 0.92rem;
  font-weight: 700;
  color: var(--ink);
}
.shared-author-name {
  font-size: 0.8rem;
  color: var(--muted);
}

/* Stats curtidas / salvaram */
.shared-hub-stats {
  display: flex;
  gap: 26px;
  margin: 16px 0 0;
}
.shared-hub-stats.is-hidden {
  display: none;
}
.shared-hub-stats span {
  display: flex;
  flex-direction: column;
  gap: 1px;
}
.shared-hub-stats strong {
  font-size: 1.1rem;
  font-weight: 800;
  color: var(--ink);
}
.shared-hub-stats small {
  font-size: 0.72rem;
  color: var(--muted);
}

/* "Salvar lista" prominente (oxblood) na folha */
.shared-detail-panel.is-hub-preview:not(.is-creator-profile) .shared-detail-actions {
  display: block;
  margin-top: 18px;
}
.shared-detail-panel.is-hub-preview:not(.is-creator-profile) #shareSharedListBtn {
  width: 100%;
  min-height: 52px;
  border-radius: 16px;
  font-size: 1rem;
  font-weight: 700;
  color: var(--paper);
  background: var(--oxblood);
  border: 0;
  box-shadow: 0 16px 30px -14px rgba(var(--neon-strong-rgb), 0.7);
}

/* Itens em linhas limpas dentro da folha */
.shared-detail-panel.is-hub-preview:not(.is-creator-profile) #sharedItemsList {
  padding: 6px 20px 10px;
  background: var(--panel);
}
.shared-detail-panel.is-hub-preview:not(.is-creator-profile) .shared-item-row {
  border: 0;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
  border-bottom: 1px solid var(--line);
}
.shared-detail-panel.is-hub-preview:not(.is-creator-profile) .shared-item-row::after {
  display: none;
}
.shared-detail-panel.is-hub-preview:not(.is-creator-profile) .shared-item-row > a {
  display: none;
}

/* Moderacao discreta no rodape */
.shared-hub-safety {
  display: none;
}
.shared-detail-panel.is-hub-preview:not(.is-creator-profile) #sharedHubSafety {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  padding: 14px 20px calc(18px + env(safe-area-inset-bottom));
  background: var(--panel);
}
.shared-hub-safety .hub-safety-btn {
  min-height: 0;
  padding: 7px 12px;
  font-size: 0.8rem;
}
/* ===================== fim BLOCO 9c ===================== */

/* ===================== BLOCO 9d — painel de filtros em chips (bottom sheet) =====================
   O botao de filtro da aba Listas abre este sheet de chips (ordenar/status/
   prioridade/categoria) em vez dos <select> nativos. Chip ativo = oxblood +
   texto paper; inativo = panel + borda --line. So tokens da paleta (vermelho/
   verde dos dots de prioridade sao semanticos, iguais ao resto do app);
   respeita prefers-reduced-motion. */
.filter-sheet {
  position: fixed;
  inset: 0;
  z-index: 78;
  display: flex;
  align-items: flex-end;
  justify-content: center;
  background:
    radial-gradient(circle at 50% 62%, rgba(var(--neon-rgb), 0.12), transparent 42%),
    rgba(18, 14, 17, 0.34);
  -webkit-backdrop-filter: blur(12px);
  backdrop-filter: blur(12px);
  animation: filterSheetFade 200ms ease both;
}
.filter-sheet.is-hidden {
  display: none;
}
.filter-sheet.is-leaving {
  animation: filterSheetFade 200ms ease reverse both;
}

.filter-sheet__panel {
  width: min(640px, 100%);
  max-height: min(86vh, 720px);
  display: flex;
  flex-direction: column;
  background: var(--panel);
  border: 1px solid var(--line);
  border-bottom: 0;
  border-radius: 28px 28px 0 0;
  box-shadow: 0 -24px 60px -28px rgba(var(--neon-strong-rgb), 0.5);
  animation: filterSheetUp 280ms cubic-bezier(0.2, 0.8, 0.2, 1) both;
}
.filter-sheet__handle {
  flex: 0 0 auto;
  width: 42px;
  height: 5px;
  margin: 10px auto 2px;
  border-radius: 999px;
  background: color-mix(in srgb, var(--oxblood) 22%, transparent);
}
.filter-sheet__head {
  flex: 0 0 auto;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 10px 22px 6px;
}
.filter-sheet__head h2 {
  margin: 0;
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 1.4rem;
  color: var(--ink);
}
.filter-sheet__head .text-btn {
  color: var(--oxblood);
  font-weight: 700;
}
.filter-sheet__scroll {
  flex: 1 1 auto;
  min-height: 0;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
  padding: 8px 22px 12px;
}
.filter-group {
  margin-bottom: 20px;
}
.filter-group.is-hidden {
  display: none;
}
.filter-group__label {
  margin: 0 0 10px;
  font-size: 10.5px;
  font-weight: 700;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--muted);
}
.filter-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}
.filter-chip {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  padding: 9px 15px;
  border-radius: 999px;
  cursor: pointer;
  font-size: 0.85rem;
  font-weight: 600;
  color: var(--ink);
  background: var(--panel);
  border: 1px solid var(--line);
  transition: transform 120ms ease, background 120ms ease;
}
.filter-chip:active {
  transform: scale(0.96);
}
.filter-chip.is-active {
  color: var(--paper);
  background: var(--oxblood);
  border-color: var(--oxblood);
}
.filter-chip__dot {
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: var(--gold);
}
.filter-chip__dot[data-priority="Alta"] {
  background: #e0392f;
}
.filter-chip__dot[data-priority="Media"] {
  background: var(--gold);
}
.filter-chip__dot[data-priority="Baixa"] {
  background: #4f9e78;
}
.filter-chip.is-active .filter-chip__dot {
  box-shadow: 0 0 0 2px color-mix(in srgb, var(--paper) 55%, transparent);
}
.filter-sheet__foot {
  flex: 0 0 auto;
  padding: 12px 22px calc(16px + env(safe-area-inset-bottom));
  background: linear-gradient(180deg, transparent, var(--panel) 28%);
}
.filter-sheet__foot .primary-btn {
  width: 100%;
  min-height: 52px;
  border-radius: 16px;
  font-size: 1rem;
  font-weight: 700;
  color: var(--paper);
  background: var(--oxblood);
}
@keyframes filterSheetFade {
  from { opacity: 0; }
  to { opacity: 1; }
}
@keyframes filterSheetUp {
  from { transform: translateY(100%); }
  to { transform: translateY(0); }
}
@media (prefers-reduced-motion: reduce) {
  .filter-sheet,
  .filter-sheet.is-leaving,
  .filter-sheet__panel {
    animation: none;
  }
}
/* ===================== fim BLOCO 9d ===================== */

/* ===================== BLOCO 2 v2 — onboarding de 1o uso (3 slides) =====================
   Overlay full-screen mostrado so no 1o uso. 3 slides deslizando na horizontal,
   dots de progresso, slide 3 com "Ativar notificacoes". So tokens da paleta;
   reusa @keyframes floatUp (Bloco 1 v2); pulseRing novo. Respeita
   prefers-reduced-motion. */
.onboarding {
  position: fixed;
  inset: 0;
  z-index: 90;
  display: flex;
  flex-direction: column;
  background:
    radial-gradient(120% 80% at 50% 0%, color-mix(in srgb, var(--rose) 18%, var(--paper)), transparent 60%),
    var(--paper);
  animation: filterSheetFade 240ms ease both;
}
.onboarding.is-hidden {
  display: none;
}
.onboarding.is-leaving {
  animation: filterSheetFade 240ms ease reverse both;
}
/* Trava o scroll de fundo enquanto o onboarding cobre a tela. */
body.has-onboarding {
  overflow: hidden;
}
.onboarding__skip {
  position: absolute;
  top: calc(12px + env(safe-area-inset-top));
  right: 14px;
  z-index: 2;
  color: var(--muted);
  font-weight: 700;
}
.onboarding__viewport {
  flex: 1 1 auto;
  min-height: 0;
  overflow: hidden;
}
.onboarding__track {
  display: flex;
  height: 100%;
  transition: transform 300ms cubic-bezier(0.65, 0, 0.35, 1);
}
.onboarding__slide {
  flex: 0 0 100%;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding: 40px 34px;
}
.onboarding__art {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 132px;
  height: 132px;
  margin-bottom: 30px;
  border-radius: 38px;
  color: var(--oxblood);
  background: linear-gradient(150deg, var(--blush), color-mix(in srgb, var(--rose) 40%, var(--paper)));
  box-shadow: 0 24px 50px -24px rgba(var(--neon-strong-rgb), 0.5);
  animation: floatUp 3.4s ease-in-out infinite;
}
.onboarding__pulse {
  position: absolute;
  inset: 0;
  border-radius: inherit;
  border: 2px solid var(--oxblood);
  opacity: 0;
  animation: pulseRing 2.2s ease-out infinite;
}
/* Slide 2 (mockup 05): tile mais claro, sem icone, com pilula de preco flutuante. */
.onboarding__art--tile {
  background: linear-gradient(150deg, color-mix(in srgb, var(--blush) 72%, var(--paper)), color-mix(in srgb, var(--rose) 24%, var(--paper)));
}
.onboarding__price-pill {
  position: absolute;
  left: -12px;
  bottom: 16px;
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 7px 12px;
  border-radius: 999px;
  background: var(--panel);
  color: var(--ink);
  font-size: 0.8rem;
  font-weight: 700;
  box-shadow: 0 12px 26px -10px rgba(var(--neon-strong-rgb), 0.55);
}
.onboarding__price-pill svg {
  color: #1f7a4d;
}
.onboarding__slide h2 {
  margin: 0 0 12px;
  max-width: 320px;
  font-family: var(--font-display);
  font-weight: 500;
  font-size: 26px;
  line-height: 1.18;
  color: var(--ink);
}
.onboarding__slide p {
  margin: 0;
  max-width: 300px;
  font-size: 15.5px;
  line-height: 1.5;
  color: var(--muted);
}
.onboarding__foot {
  flex: 0 0 auto;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 14px;
  padding: 16px 24px calc(20px + env(safe-area-inset-bottom));
}
.onboarding__dots {
  display: flex;
  align-items: center;
  gap: 8px;
}
.onboarding__dot {
  width: 7px;
  height: 7px;
  border-radius: 999px;
  background: color-mix(in srgb, var(--oxblood) 22%, transparent);
  transition: width 200ms ease, background 200ms ease;
}
.onboarding__dot.is-active {
  width: 22px;
  background: var(--oxblood);
}
.onboarding__cta {
  width: 100%;
  max-width: 360px;
  min-height: 52px;
  border-radius: 16px;
  font-size: 1rem;
  font-weight: 700;
  color: var(--paper);
  background: var(--oxblood);
}
.onboarding__cta.is-hidden,
.onboarding__later.is-hidden {
  display: none;
}
.onboarding__later {
  color: var(--muted);
  font-weight: 700;
}
@keyframes pulseRing {
  0% { transform: scale(0.82); opacity: 0.55; }
  100% { transform: scale(2.1); opacity: 0; }
}
@media (prefers-reduced-motion: reduce) {
  .onboarding,
  .onboarding.is-leaving,
  .onboarding__art,
  .onboarding__pulse {
    animation: none;
  }
  .onboarding__track {
    transition: none;
  }
}
/* ===================== fim BLOCO 2 v2 ===================== */

/* ===================== BLOCO 3 v2 — microinteracoes =====================
   Favoritar (heartPop + onda), salvar (miniatura voa em arco - WAAPI no JS),
   queda de preco (selo verde entra com heartPop + onda verde). Curtas e
   elegantes; desligadas em prefers-reduced-motion. Cores via tokens; o verde
   da onda usa o mesmo hex semantico de sucesso (#1f7a4d) ja usado no app. */
@keyframes heartPop {
  0% { transform: scale(1); }
  40% { transform: scale(1.35); }
  100% { transform: scale(1); }
}
.heart-pop {
  animation: heartPop 0.4s ease;
}
/* O heartPop vence o favoritePop pre-existente no icone do card (mesma propriedade
   animation no mesmo span) — pop unico e consistente ao favoritar/desfavoritar. */
.favorite-btn.is-active span.heart-pop {
  animation: heartPop 0.4s ease;
}

/* Onda (ring) de um disparo atras do alvo. Reusa @keyframes pulseRing do Bloco 2. */
.micro-wave {
  position: absolute;
  inset: 0;
  border-radius: inherit;
  border: 2px solid var(--oxblood);
  pointer-events: none;
  opacity: 0;
  animation: pulseRing 0.7s ease-out;
}
.micro-wave--green {
  border-color: #1f7a4d;
}
/* Ancoras das ondas (precisam de position p/ o inset:0 funcionar). */
.price-alert-badge {
  position: relative;
}
.item-detail__glass-btn {
  position: relative;
}

/* Clone que voa do review ate a pilula da lista ao salvar. */
.fly-clone {
  z-index: 120;
  pointer-events: none;
  border-radius: 14px;
  overflow: hidden;
  box-shadow: 0 18px 40px -16px rgba(var(--neon-strong-rgb), 0.6);
}

@media (prefers-reduced-motion: reduce) {
  .heart-pop {
    animation: none;
  }
  .micro-wave {
    display: none;
  }
}
/* ===================== fim BLOCO 3 v2 ===================== */

/* ===================== BLOCO 4 v2 — detalhe da SUA lista (mockup 09/10) =====================
   Layout de dono: capa-banner com "Editar capa", titulo serif + menu •••, resumo,
   Publicar/Compartilhar, itens arrastaveis e sheet publicar. Tudo com tokens da
   paleta; os blocos do painel sao reordenados via `order` so no modo dono. */

/* Ordem no modo dono: capa -> cabecalho -> rotulo -> itens -> add -> resto. */
.shared-detail-panel.is-owner-detail #sharedDetailHero { order: 1; }
.shared-detail-panel.is-owner-detail .shared-detail-head { order: 2; }
.shared-detail-panel.is-owner-detail #sharedItemsLabel { order: 3; }
.shared-detail-panel.is-owner-detail #sharedItemsList { order: 4; }
.shared-detail-panel.is-owner-detail .shared-add-row { order: 5; }
.shared-detail-panel.is-owner-detail #sharedMembersList { order: 6; }
.shared-detail-panel.is-owner-detail #sharedSimilarLists { order: 7; }
.shared-detail-panel.is-owner-detail #sharedHubSafety { order: 8; }

/* Capa vira banner (mockup 09): so a capa, sem a coluna de stats/hint. */
.shared-detail-panel.is-owner-detail #sharedDetailHero {
  display: block;
  grid-template-columns: none;
  gap: 0;
}
.shared-detail-panel.is-owner-detail .shared-detail-hero-copy {
  display: none;
}
.shared-detail-panel.is-owner-detail .shared-detail-cover {
  height: 132px;
  min-height: 132px;
  border-radius: 20px;
  background:
    linear-gradient(150deg, rgba(var(--neon-rgb), 0.6), rgba(var(--neon-rgb), 0.16) 60%, rgba(255, 255, 255, 0.4)),
    var(--blush);
}
.shared-detail-panel.is-owner-detail .shared-detail-cover img {
  height: 132px;
  min-height: 0;
}
.shared-detail-panel.is-owner-detail .shared-detail-cover .shared-list-icon {
  display: none;
}

/* Controles sobre a capa (voltar + Editar capa) so no modo dono. */
.shared-cover-controls {
  display: contents;
}
.shared-detail-panel.is-owner-detail .shared-cover-controls {
  position: absolute;
  inset: 10px 10px auto 10px;
  z-index: 2;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
}
.shared-detail-panel.is-owner-detail .shared-cover-controls #closeSharedDetailBtn {
  display: grid;
  place-items: center;
  width: 38px;
  min-width: 38px;
  height: 38px;
  padding: 0;
  border-radius: 50%;
  border: 1px solid var(--glass-edge);
  background: var(--glass-tint);
  -webkit-backdrop-filter: blur(10px);
  backdrop-filter: blur(10px);
  color: var(--ink);
  font-size: 1.5rem;
  line-height: 1;
  box-shadow: inset 0 1px 0 var(--glass-rim), 0 6px 16px -8px rgba(0, 0, 0, 0.4);
}
.glass-cover-btn {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  min-height: 38px;
  border-radius: 999px;
  border: 1px solid var(--glass-edge);
  background: var(--glass-tint);
  -webkit-backdrop-filter: blur(10px);
  backdrop-filter: blur(10px);
  color: var(--ink);
  padding: 0 13px;
  font-size: 0.82rem;
  font-weight: 800;
  cursor: pointer;
  box-shadow: inset 0 1px 0 var(--glass-rim), 0 6px 16px -8px rgba(0, 0, 0, 0.4);
}
.glass-cover-btn .glass-cover-ico {
  font-size: 0.92rem;
  line-height: 1;
}
.glass-cover-btn:hover {
  border-color: rgba(var(--neon-rgb), 0.5);
}

/* Cabecalho do dono: titulo (1fr) + ••• (auto), Publicar/Compartilhar abaixo. */
.shared-detail-panel.is-owner-detail .shared-detail-head {
  grid-template-columns: minmax(0, 1fr) auto;
  grid-template-areas:
    "headline menu"
    "actions actions";
  align-items: start;
  gap: 8px 10px;
  position: static;
}
.shared-detail-panel.is-owner-detail .shared-detail-headline {
  grid-area: headline;
  min-width: 0;
}
.shared-detail-panel.is-owner-detail .shared-detail-menu-wrap {
  grid-area: menu;
}
.shared-detail-panel.is-owner-detail .shared-detail-actions {
  grid-area: actions;
  justify-content: stretch;
  flex-wrap: nowrap;
}
.shared-detail-panel.is-owner-detail #sharedDetailTitle {
  margin: 0;
  font-family: var(--font-display);
  font-weight: 500;
  font-size: 1.7rem;
  line-height: 1.08;
}
.shared-detail-panel.is-owner-detail #sharedDetailMeta {
  margin: 4px 0 0;
  color: var(--muted);
  font-size: 13px;
  font-weight: 600;
}

/* Menu ••• so existe no modo dono. */
.shared-detail-panel:not(.is-owner-detail) .shared-detail-menu-wrap {
  display: none;
}
.shared-detail-menu-wrap {
  position: relative;
}
.shared-detail-menu-btn {
  width: 38px;
  height: 38px;
  min-height: 38px;
  padding: 0;
  font-size: 1.4rem;
  line-height: 1;
  color: var(--ink);
}
.shared-detail-menu-btn.is-hidden {
  display: none;
}
.shared-detail-menu {
  position: absolute;
  top: calc(100% + 6px);
  right: 0;
  z-index: 20;
  display: grid;
  gap: 2px;
  min-width: 188px;
  border: 1px solid var(--line);
  border-radius: 16px;
  background: var(--panel);
  padding: 6px;
  box-shadow: 0 18px 40px rgba(var(--neon-strong-rgb), 0.18);
  animation: panelRise 160ms ease both;
}
.shared-detail-menu.is-hidden {
  display: none;
}
.shared-menu-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  width: 100%;
  border: 0;
  border-radius: 11px;
  background: transparent;
  color: var(--ink);
  padding: 10px 12px;
  font: inherit;
  font-size: 0.9rem;
  font-weight: 700;
  text-align: left;
  cursor: pointer;
}
.shared-menu-item:hover {
  background: rgba(var(--neon-rgb), 0.1);
}
.shared-menu-toggle {
  cursor: default;
}
.shared-menu-danger {
  color: #e0392f;
}
.shared-menu-danger:hover {
  background: color-mix(in srgb, #e0392f 10%, transparent);
}

/* Linha Publicar (oxblood) + Compartilhar (outline). */
.shared-detail-panel.is-owner-detail .shared-detail-actions .secondary-btn {
  flex: 1 1 0;
  min-height: 42px;
  justify-content: center;
}
.shared-detail-panel.is-owner-detail #publishSharedListBtn {
  border-color: transparent;
  background: var(--oxblood);
  color: var(--paper);
}
.shared-detail-panel.is-owner-detail #publishSharedListBtn:hover {
  background: color-mix(in srgb, var(--oxblood) 88%, #000);
}

/* Rotulo "ITENS · arraste para reordenar". */
.shared-items-label {
  display: flex;
  align-items: baseline;
  gap: 8px;
  margin: 0;
  color: var(--muted);
}
.shared-items-label.is-hidden {
  display: none;
}
.shared-items-label strong {
  color: var(--ink);
  font-size: 0.72rem;
  font-weight: 950;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}
.shared-items-label span {
  font-size: 0.72rem;
  font-weight: 700;
}
.shared-items-label span:empty {
  display: none;
}

/* Itens arrastaveis: a linha inteira e a alca (mockup 09 nao tem alca de pontos,
   so o texto "arraste para reordenar") + estados de arraste. */
.shared-item-row.is-reorderable {
  cursor: grab;
}
.shared-item-row.is-reorderable:active {
  cursor: grabbing;
}
.shared-item-row.is-dragging {
  opacity: 0.55;
  transform: scale(1.02);
  box-shadow: 0 16px 34px rgba(var(--neon-strong-rgb), 0.2);
}
.shared-item-row.is-drop-target {
  border-color: rgba(var(--neon-rgb), 0.55);
  box-shadow: inset 0 0 0 2px rgba(var(--neon-rgb), 0.4);
}

/* Linhas compactas de uma so linha no detalhe do dono (mockup 09): thumb +
   nome/preco + remover. Sobrescreve o wrap responsivo (grid-column: 2 / -1)
   que joga o "x" pra segunda linha em telas estreitas. */
.shared-detail-panel.is-owner-detail .shared-item-row {
  grid-template-columns: auto minmax(0, 1fr) auto;
  min-height: 64px;
}
.shared-detail-panel.is-owner-detail .shared-item-row a {
  display: none;
}
.shared-detail-panel.is-owner-detail .shared-item-row .shared-remove-item {
  grid-column: auto;
  align-self: center;
}

/* Sheet publicar / compartilhar (reaproveita o shell .filter-sheet). */
.publish-sheet__head {
  display: grid;
  gap: 4px;
}
.publish-sheet__copy {
  margin: 0;
  color: var(--muted);
  font-size: 13px;
  font-weight: 600;
}
.publish-sheet__link {
  display: flex;
  gap: 8px;
  align-items: center;
}
.publish-sheet__link-input {
  flex: 1 1 0;
  min-width: 0;
  border: 1px solid var(--line);
  border-radius: 12px;
  background: var(--paper);
  color: var(--ink);
  padding: 11px 12px;
  font-size: 13px;
  font-weight: 600;
}
.publish-sheet__targets {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
  margin-top: 14px;
}
.publish-target {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 7px;
  border: 1px solid var(--line);
  border-radius: 16px;
  background: var(--panel);
  color: var(--ink);
  padding: 14px 8px;
  font-size: 12px;
  font-weight: 800;
  cursor: pointer;
}
.publish-target:hover {
  border-color: rgba(var(--neon-rgb), 0.42);
}
.publish-target__ico {
  display: grid;
  place-items: center;
  width: 42px;
  height: 42px;
  border-radius: 50%;
  background: rgba(var(--neon-rgb), 0.14);
  color: var(--oxblood);
}
.publish-sheet__foot {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}
.publish-sheet__private {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  color: var(--ink);
  font-size: 13px;
  font-weight: 700;
}
body.has-publish-sheet {
  overflow: hidden;
}

/* Reduced motion: sem escala/anim no arraste e no menu. */
@media (prefers-reduced-motion: reduce) {
  .shared-detail-menu {
    animation: none;
  }
  .shared-item-row.is-dragging {
    transform: none;
  }
}
/* ===================== fim BLOCO 4 v2 ===================== */

/* ===================== BLOCO 5 v2 — Seus alertas (mockup 12) =====================
   Tela dedicada de alertas de queda: resumo, card de queda ativa (verde),
   linhas de monitoramento com preco-alvo / toggle. Verde semantico #1f7a4d
   reutilizado (regra permite); demais cores via tokens. */
.alerts-heading {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 16px;
}
.alerts-heading h2 {
  margin: 0;
  font-family: var(--font-display);
  font-weight: 500;
  font-size: 1.85rem;
  line-height: 1.1;
}
.alerts-summary {
  margin: 2px 0 0;
  color: var(--muted);
  font-size: 13px;
  font-weight: 600;
}
.alerts-list {
  display: grid;
  gap: 12px;
}
.alert-card {
  border: 1px solid var(--line);
  border-radius: 18px;
  background: var(--panel);
  padding: 12px;
  box-shadow: 0 10px 24px rgba(var(--neon-strong-rgb), 0.06);
}
.alert-card--drop {
  border-color: color-mix(in srgb, #1f7a4d 30%, var(--line));
  background:
    linear-gradient(150deg, color-mix(in srgb, #1f7a4d 12%, transparent), transparent 60%),
    var(--panel);
}
.alert-card-head {
  display: grid;
  grid-template-columns: 56px minmax(0, 1fr);
  gap: 12px;
  align-items: center;
}
.alert-thumb {
  position: relative;
  overflow: hidden;
  display: grid;
  place-items: center;
  width: 56px;
  height: 56px;
  border-radius: 14px;
  background:
    linear-gradient(145deg, rgba(var(--neon-rgb), 0.18), rgba(255, 255, 255, 0.7)),
    var(--blush);
}
.alert-thumb img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.alert-thumb img.is-hidden {
  display: none;
}
.alert-card-copy {
  min-width: 0;
  display: grid;
  gap: 4px;
}
.alert-name {
  color: var(--ink);
  font-weight: 800;
  line-height: 1.15;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.alert-prices {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}
.alert-price-now {
  color: var(--ink);
  font-weight: 950;
  font-size: 1.02rem;
}
.alert-price-old {
  color: var(--muted);
  font-size: 0.82rem;
}
.alert-price-old.is-hidden {
  display: none;
}
.alert-drop-badge {
  display: inline-flex;
  align-items: center;
  border-radius: 999px;
  background: color-mix(in srgb, #1f7a4d 16%, transparent);
  color: #1f7a4d;
  padding: 3px 9px;
  font-size: 0.72rem;
  font-weight: 950;
}
.alert-card-actions {
  display: flex;
  gap: 8px;
  margin-top: 12px;
}
.alert-card-actions .primary-btn,
.alert-card-actions .secondary-btn {
  flex: 1 1 0;
  min-height: 40px;
  justify-content: center;
}
/* "Comprar agora" em oxblood (CTA v2, igual ao Publicar do Bloco 4) em vez do
   primary-btn preto padrao. Especificidade alta p/ vencer o override de
   .primary-btn do tema noir. */
.alert-card .alert-card-actions .alert-buy-btn,
body[data-theme="noir"] .alert-card .alert-card-actions .alert-buy-btn {
  border-color: transparent;
  background-color: var(--oxblood);
  background-image: none;
  color: var(--paper);
}
.alert-card .alert-card-actions .alert-buy-btn:hover {
  background-color: color-mix(in srgb, var(--oxblood) 88%, #000);
}
.alert-buy-btn.is-hidden {
  display: none;
}
.alert-watch {
  display: grid;
  grid-template-columns: 48px minmax(0, 1fr) auto auto;
  align-items: center;
  gap: 11px;
}
.alert-watch .alert-thumb {
  width: 48px;
  height: 48px;
  border-radius: 13px;
}
.alert-watch-copy {
  min-width: 0;
  display: grid;
  gap: 2px;
}
.alert-watch-status {
  color: var(--muted);
  font-size: 0.78rem;
  font-weight: 700;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.alert-edit-btn {
  display: grid;
  place-items: center;
  width: 36px;
  height: 36px;
  border: 1px solid var(--line);
  border-radius: 50%;
  background: var(--panel);
  color: var(--oxblood);
  cursor: pointer;
}
.alert-edit-btn:hover {
  border-color: rgba(var(--neon-rgb), 0.4);
}
.alert-watch-toggle {
  position: relative;
  display: inline-flex;
  width: 46px;
  height: 28px;
  flex: none;
  cursor: pointer;
}
.alert-watch-toggle input {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  margin: 0;
  opacity: 0;
  cursor: pointer;
}
.alert-toggle-track {
  position: relative;
  flex: 1;
  border-radius: 999px;
  background: color-mix(in srgb, var(--muted) 40%, var(--paper));
  transition: background 180ms ease;
}
.alert-toggle-track::after {
  content: "";
  position: absolute;
  top: 3px;
  left: 3px;
  width: 22px;
  height: 22px;
  border-radius: 50%;
  background: #fff;
  box-shadow: 0 2px 6px rgba(0, 0, 0, 0.25);
  transition: transform 180ms ease;
}
.alert-watch-toggle input:checked + .alert-toggle-track {
  background: var(--oxblood);
}
.alert-watch-toggle input:checked + .alert-toggle-track::after {
  transform: translateX(18px);
}
.alerts-empty {
  display: grid;
  gap: 6px;
  text-align: center;
  padding: 40px 20px;
  color: var(--muted);
}
.alerts-empty strong {
  color: var(--ink);
  font-size: 1.02rem;
}
.alerts-empty span {
  font-size: 0.86rem;
  font-weight: 600;
}
.alerts-empty .primary-btn {
  justify-self: center;
  margin-top: 10px;
  min-height: 44px;
  padding: 0 22px;
}
.metric-card.metric-alerts {
  cursor: pointer;
}
.metric-card.metric-alerts:hover {
  border-color: rgba(var(--neon-rgb), 0.4);
}
@media (prefers-reduced-motion: reduce) {
  .alert-toggle-track,
  .alert-toggle-track::after {
    transition: none;
  }
}
/* ===================== fim BLOCO 5 v2 ===================== */

/* ===================== BLOCO 6 v2 — boot screen (mockup 14) =====================
   Tela de carregamento web: gradiente claro + icone (coracao) + wordmark serif
   + spinner + tagline. Some quando body.app-ready; fallback aos 6s. */
.app-boot {
  position: fixed;
  inset: 0;
  z-index: 9000;
  display: grid;
  place-content: center;
  justify-items: center;
  gap: 16px;
  background: linear-gradient(180deg, #fff6fa, #f9cfe0);
  animation: appBootSafety 0.4s ease 6s forwards;
}
body.app-ready .app-boot {
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.45s ease, visibility 0s linear 0.45s;
}
/* Cores fixas da marca (valores do tema rose): o boot e um splash de marca,
   igual ao splash nativo (PNG claro) — nao reage ao tema escuro do app. */
.app-boot__icon {
  display: grid;
  place-items: center;
  width: 84px;
  height: 84px;
  border-radius: 24px;
  background: linear-gradient(150deg, #ec86ad, #8b2447);
  box-shadow: 0 18px 40px rgba(139, 36, 71, 0.28);
  animation: appBootFloat 2.4s ease-in-out infinite;
}
.app-boot__icon svg {
  width: 46px;
  height: 46px;
}
.app-boot__wordmark {
  margin: 0;
  color: #171717;
  font-family: var(--font-display);
  font-weight: 500;
  font-size: 1.95rem;
  letter-spacing: -0.01em;
}
.app-boot__spinner {
  width: 26px;
  height: 26px;
  border-radius: 50%;
  border: 2.5px solid rgba(139, 36, 71, 0.18);
  border-top-color: #8b2447;
  animation: appBootSpin 0.8s linear infinite;
}
.app-boot__tagline {
  margin: 0;
  color: #8b2447;
  font-size: 12px;
  font-weight: 700;
}
@keyframes appBootFloat {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(-7px); }
}
@keyframes appBootSpin {
  to { transform: rotate(360deg); }
}
@keyframes appBootSafety {
  to { opacity: 0; visibility: hidden; }
}
@media (prefers-reduced-motion: reduce) {
  .app-boot__icon,
  .app-boot__spinner {
    animation: none;
  }
  body.app-ready .app-boot {
    transition: none;
  }
}
/* ===================== fim BLOCO 6 v2 ===================== */

/* ===================== BLOCO 7 v2 — dark mode liquid glass (mockups 15/16) =====================
   Noir neutro (refeito por feedback): fundo cinza-escuro com leve luz no topo
   (nao preto chapado, nao plum), superficies translucidas neutras, dock e
   folha em liquid glass, rose so como acento. Tudo scoped a noir. */

/* Fundo neutro com leve elevacao no topo. */
body[data-theme="noir"] {
  background:
    radial-gradient(125% 92% at 50% -10%, #1e1e22 0%, #17171a 50%, #121215 100%) fixed;
}

/* Paineis de pagina transparentes para o fundo radial aparecer. */
body[data-theme="noir"] .view-panel,
body[data-theme="noir"] .shared-shell {
  background: transparent;
  border-color: transparent;
  box-shadow: none;
}

/* Cards: vidro translucido + borda clara (mockup 15). */
body[data-theme="noir"] .wish-card,
body[data-theme="noir"] .shared-list-card,
body[data-theme="noir"] .hub-feed-card,
body[data-theme="noir"] .alert-card,
body[data-theme="noir"] .metric-grid > span {
  background:
    linear-gradient(150deg, rgba(255, 255, 255, 0.07), rgba(255, 255, 255, 0.02)),
    rgba(255, 255, 255, 0.06);
  border-color: rgba(255, 255, 255, 0.12);
}
body[data-theme="noir"] .wish-card img,
body[data-theme="noir"] .hub-feed-cover img,
body[data-theme="noir"] .alert-thumb img {
  border: 1px solid rgba(255, 255, 255, 0.08);
}

/* Dock liquid glass flutuante (mockup 15). Substitui de proposito as regras
   noir anteriores de .bottom-dock (dock plano) pela barra de vidro flutuante;
   o conteudo ja tem padding-bottom 104px, que sobra sobre a dock (topo ~71px). */
body[data-theme="noir"] .bottom-dock {
  left: 14px;
  right: 14px;
  bottom: calc(14px + env(safe-area-inset-bottom));
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: 28px;
  background: rgba(26, 26, 30, 0.68);
  -webkit-backdrop-filter: blur(26px) saturate(1.4);
  backdrop-filter: blur(26px) saturate(1.4);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.12),
    0 18px 50px rgba(0, 0, 0, 0.5);
  padding: 10px 12px calc(10px + env(safe-area-inset-bottom));
}
body[data-theme="noir"] .dock-nav-btn.is-active {
  background: transparent;
  box-shadow: none;
  color: #ec86ad;
}
body[data-theme="noir"] .dock-nav-btn.is-active .dock-symbol {
  background: linear-gradient(150deg, #ec86ad, #b03a63);
  color: #fff;
  border-color: rgba(236, 134, 173, 0.5);
}

/* Folha de detalhe (mockup 16): vidro neutro + rim discreto. */
body[data-theme="noir"] .item-detail__sheet {
  background: rgba(25, 25, 29, 0.74);
  border-top-color: rgba(255, 255, 255, 0.12);
  box-shadow:
    0 -16px 50px -20px rgba(0, 0, 0, 0.7),
    inset 0 1px 0 rgba(255, 255, 255, 0.1);
  -webkit-backdrop-filter: blur(30px) saturate(1.4);
  backdrop-filter: blur(30px) saturate(1.4);
}

/* Selo de queda em verde claro no dark (alpha um pouco maior p/ a pilula ler). */
body[data-theme="noir"] .item-detail__drop,
body[data-theme="noir"] .alert-drop-badge {
  background: rgba(95, 214, 160, 0.2);
  color: #5fd6a0;
}

/* Botao de compra / comprar agora em gradiente rose (mockups 15/16). Tom mais
   fechado + text-shadow p/ o texto branco passar AA mesmo na ponta clara. */
body[data-theme="noir"] .item-detail__buy,
body[data-theme="noir"] .alert-card .alert-card-actions .alert-buy-btn {
  background: linear-gradient(135deg, #bd5076, #8b2447);
  color: #fff;
  text-shadow: 0 1px 2px rgba(0, 0, 0, 0.35);
}

/* Pill de lista ativa (Principal) em rose (mockup 15). Substitui a regra noir
   anterior do .wishlist-tab.is-active; mantem profundidade com glow rose. */
body[data-theme="noir"] .wishlist-tab.is-active {
  background: linear-gradient(150deg, #d4628a, #8b2447);
  border-color: transparent;
  color: #fff;
  text-shadow: 0 1px 2px rgba(0, 0, 0, 0.3);
  box-shadow: 0 10px 24px rgba(189, 80, 118, 0.34);
}
/* ===================== fim BLOCO 7 v2 ===================== */

/* ===================== AJUSTES POS-AUDITORIA (feedback do user) =====================
   Hub: capa menor + gradiente visivel; volta criador + curtir/salvar nos cards;
   curtir interativo no destaque; correcoes do dark (chips e capas). */

/* Capa do card do feed: menor e com cor CLARA (antes o gradiente desbotava
   pra branco e o card parecia vazio). Pastel solido por variacao de posicao. */
.hub-feed-cover {
  display: block;
  width: 100%;
  height: 76px;
  /* o card e flex column com align-items:center; sem largura explicita a capa
     (cujo unico filho em fluxo, o img, fica hidden) colapsava pra 0px. */
  align-self: stretch;
  background: linear-gradient(150deg, var(--rose), color-mix(in srgb, var(--rose) 42%, var(--paper)));
}
.hub-feed-card:nth-child(3n+2) .hub-feed-cover {
  background: linear-gradient(150deg, color-mix(in srgb, var(--oxblood) 60%, var(--rose)), color-mix(in srgb, var(--oxblood) 38%, var(--paper)));
}
.hub-feed-card:nth-child(3n) .hub-feed-cover {
  background: linear-gradient(150deg, var(--gold), color-mix(in srgb, var(--gold) 45%, var(--paper)));
}
.hub-feature-cover {
  height: 124px;
}

/* Curtir sobreposto no canto da capa (card do feed). */
.hub-feed-like {
  position: absolute;
  top: 8px;
  right: 8px;
  display: inline-flex;
  align-items: center;
  gap: 4px;
  border: 0;
  border-radius: 999px;
  background: rgba(var(--neon-strong-rgb), 0.42);
  -webkit-backdrop-filter: blur(6px);
  backdrop-filter: blur(6px);
  color: var(--paper);
  padding: 4px 8px;
  font-size: 11px;
  font-weight: 800;
  cursor: pointer;
}
.hub-feed-like .heart {
  font-size: 12px;
  line-height: 1;
}
.hub-feed-like.is-liked {
  background: var(--oxblood);
}

/* Rodape do card: criador (esq) + salvar (dir). */
.hub-feed-foot {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  margin: 6px 12px 12px;
}
.hub-feed-creator {
  border: 0;
  background: transparent;
  color: var(--oxblood);
  padding: 0;
  font: inherit;
  font-size: 11px;
  font-weight: 700;
  cursor: pointer;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.hub-feed-save {
  flex: none;
  border: 1px solid var(--line);
  border-radius: 999px;
  background: var(--panel);
  color: var(--muted);
  padding: 4px 9px;
  font: inherit;
  font-size: 11px;
  font-weight: 700;
  cursor: pointer;
}
.hub-feed-save.is-saved {
  border-color: transparent;
  background: rgba(var(--neon-rgb), 0.16);
  color: var(--oxblood);
}

/* Destaque: curtir/salvar viram botoes interativos (heartPop). */
.hub-feature-stats .hub-stat {
  border: 0;
  background: transparent;
  padding: 0;
  font: inherit;
  cursor: pointer;
}
.hub-feature-stats .hub-stat-likes {
  display: inline-flex;
  align-items: center;
  gap: 5px;
}
.hub-stat-likes::before { content: none !important; }
.hub-feature-stats .hub-stat-likes .heart {
  color: var(--oxblood);
  font-size: 13px;
  line-height: 1;
}
.hub-feature-stats .hub-stat.is-saved {
  color: var(--oxblood);
  font-weight: 800;
}

/* ---- Dark (noir): Hub corrigido ---- */
/* Capas do Hub quentes (rose/plum) em vez do cinza do --neon noir. */
body[data-theme="noir"] .hub-feature-cover,
body[data-theme="noir"] .hub-feed-cover {
  background:
    linear-gradient(150deg, rgba(236, 134, 173, 0.5), rgba(139, 36, 71, 0.32) 72%, rgba(40, 26, 36, 0.2)),
    #241820 !important;
}
/* Chips de categoria legiveis no escuro (antes ficavam brancos lavados). */
body[data-theme="noir"] .shared-category-chip {
  background: rgba(255, 255, 255, 0.06);
  border-color: rgba(255, 255, 255, 0.14);
  color: var(--ink);
}
body[data-theme="noir"] .shared-category-chip.is-active {
  background: linear-gradient(150deg, #d4628a, #8b2447);
  border-color: transparent;
  color: #fff;
}
body[data-theme="noir"] .shared-category-chip .shared-mini-icon {
  color: var(--ink);
  opacity: 0.9;
}
body[data-theme="noir"] .hub-feed-save {
  background: rgba(255, 255, 255, 0.06);
  border-color: rgba(255, 255, 255, 0.14);
  color: var(--muted);
}
/* ===================== fim AJUSTES POS-AUDITORIA ===================== */

/* ===================== NOIR = DARK MODE DA MARCA (sem branco/cinza) =====================
   O noir remapeava os tokens de accent p/ grayscale (rose/oxblood viravam
   branco/cinza) — superfícies claras que destoavam e matavam o contraste. Os
   tokens já voltaram p/ rose (bloco de tema). Aqui ficam os elementos que NÃO
   são token-driven (fundos brancos literais) + os que usam o canal "forte"
   (agora oxblood escuro) como FUNDO e precisavam de texto claro. Tudo scoped a
   body[data-theme="noir"] — temas claros (rose/blue/fun) intactos. */

/* CTAs sólidos da marca: gradiente rose->oxblood + texto branco (o base usa
   var(--oxblood) como fundo com texto var(--paper), que no escuro inverteria). */
body[data-theme="noir"] .summary-cta {
  background: linear-gradient(135deg, #bd5076, #8b2447);
  color: #fff;
  text-shadow: 0 1px 2px rgba(0, 0, 0, 0.28);
  box-shadow: 0 14px 28px -10px rgba(139, 36, 71, 0.65);
}
body[data-theme="noir"] .summary-avatar {
  background: linear-gradient(135deg, #bd5076, #8b2447);
  color: #fff;
  box-shadow: 0 12px 26px rgba(139, 36, 71, 0.3);
}

/* Chips de categoria das Listas: fundo branco literal -> vidro escuro. */
body[data-theme="noir"] .wishlist-category-chip {
  background: rgba(255, 255, 255, 0.05);
}
body[data-theme="noir"] .wishlist-category-chip span {
  background: rgba(255, 255, 255, 0.08);
  color: var(--ink);
}
/* Chip ativo (Listas e Hub): o gradiente já vira rose (tokens). Texto branco e
   a bolha do ícone vira um frost translúcido (NÃO um disco branco sólido). */
body[data-theme="noir"] .wishlist-category-chip:hover,
body[data-theme="noir"] .wishlist-category-chip.is-active {
  color: #fff;
}
body[data-theme="noir"] .wishlist-category-chip:hover span,
body[data-theme="noir"] .wishlist-category-chip.is-active span,
body[data-theme="noir"] .shared-category-chip.is-active span {
  background: rgba(255, 255, 255, 0.18);
  border-color: rgba(255, 255, 255, 0.28);
  color: #fff;
}
/* Bolha do ícone do chip do Hub (inativo): o 2º stop do gradiente era branco
   literal (rgba(255,255,255,.7)) — troca por tint rose escuro. */
body[data-theme="noir"] .shared-category-chip span {
  background:
    linear-gradient(135deg, rgba(236, 134, 173, 0.3), rgba(139, 36, 71, 0.2)),
    rgba(255, 255, 255, 0.04);
}

/* Botão favoritar (☆): bolha branca -> vidro escuro + coração rose. */
body[data-theme="noir"] .favorite-btn {
  background: rgba(20, 14, 18, 0.66);
  border-color: rgba(255, 255, 255, 0.18);
  color: #f2a0bf;
}
body[data-theme="noir"] .favorite-btn.is-active {
  color: #ec86ad;
}

/* Capa placeholder do card (WD): gradiente claro -> rose/plum escuro + o
   monograma "WD" (era cinza escuro) vira claro p/ não sumir no fundo escuro. */
body[data-theme="noir"] .card-image-link {
  background:
    linear-gradient(150deg, rgba(236, 134, 173, 0.32), rgba(139, 36, 71, 0.22) 70%),
    var(--panel);
}
body[data-theme="noir"] .image-fallback,
body[data-theme="noir"] .card-image-placeholder {
  color: rgba(255, 255, 255, 0.55);
}

/* Linhas de comparação ("Google" etc.): pílula clara -> vidro escuro. */
body[data-theme="noir"] .comparison-row a {
  background: rgba(255, 255, 255, 0.06);
  border-color: rgba(236, 134, 173, 0.32);
  color: #f2a0bf;
}

/* Selos/pílulas que usam o canal "forte" (agora oxblood ESCURO) como fundo:
   o texto era var(--paper) (escuro) -> agora claro p/ não sumir no escuro. */
body[data-theme="noir"] .hub-feature-badge,
body[data-theme="noir"] .hub-feed-like {
  color: #fff;
}
body[data-theme="noir"] .hub-feed-like.is-liked {
  background: #8b2447;
  color: #fff;
}
/* ===================== fim NOIR dark mode da marca ===================== */
