/* ============================================================
   NS Review App — Liquid Glass Components
   Tokens en tokens.css.
   ============================================================ */

/* ===================== APP SHELL ===================== */
.app {
  position: relative;
  z-index: var(--z-base);
  min-height: 100vh;
}

/* Floating nav capsule */
.app-header {
  position: sticky;
  top: 16px;
  z-index: var(--z-nav);
  margin: 16px 16px 0;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding: 10px 14px 10px 18px;
  background: var(--glass-65);
  -webkit-backdrop-filter: var(--blur-mid);
  backdrop-filter: var(--blur-mid);
  border: 1px solid var(--glass-edge-2);
  border-radius: var(--r-pill);
  box-shadow: var(--glass-inner), var(--depth-2);
  flex-wrap: wrap;
}

.brand {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-weight: 700;
  font-size: 15px;
  color: var(--text);
  text-decoration: none;
}
.brand-mark {
  width: 28px;
  height: 28px;
  border-radius: 9px;
  background: linear-gradient(135deg, var(--ns-peach), var(--ns-peach-deep));
  box-shadow: var(--glass-inner), var(--depth-peach);
  display: grid;
  place-items: center;
  color: var(--ink);
  font-weight: 800;
  font-size: 10px;
  letter-spacing: 0.05em;
}

.brand-row {
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
}

.sep-vert {
  width: 1px;
  height: 18px;
  background: var(--hairline);
}

/* Pill / counter / meta */
.pill-meta {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: var(--ink);
  color: #FFF;
  border-radius: var(--r-pill);
  padding: 5px 12px;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.005em;
  font-variant-numeric: tabular-nums;
}
.pill-counter {
  display: inline-flex;
  align-items: center;
  background: rgba(10,10,15,0.06);
  color: var(--text-dim);
  border-radius: var(--r-pill);
  padding: 5px 12px;
  font-size: 12px;
  font-weight: 600;
}

/* Chip (status, ronda) */
.chip {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: var(--glass-80);
  -webkit-backdrop-filter: var(--blur-soft);
  backdrop-filter: var(--blur-soft);
  border: 1px solid var(--glass-edge-2);
  padding: 6px 12px;
  border-radius: var(--r-pill);
  font-size: 12px;
  font-weight: 600;
  color: var(--text-dim);
  box-shadow: var(--glass-inner);
}
.chip .dot {
  width: 7px; height: 7px;
  border-radius: 50%;
}
.chip .dot.green { background: #28C840; box-shadow: 0 0 0 3px rgba(40, 200, 64, 0.18); }
.chip .dot.peach { background: var(--ns-peach-deep); box-shadow: 0 0 0 3px rgba(248, 176, 124, 0.25); }
.chip .dot.blue  { background: var(--ns-blue); box-shadow: 0 0 0 3px rgba(58, 84, 247, 0.20); }

/* ===================== BUTTONS ===================== */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  font-family: var(--font-sans);
  font-weight: 700;
  font-size: 13.5px;
  letter-spacing: 0.005em;
  border: 1px solid transparent;
  border-radius: var(--r-pill);
  padding: 11px 20px;
  cursor: pointer;
  user-select: none;
  white-space: nowrap;
  transition:
    background var(--dur) var(--ease),
    transform var(--dur) var(--ease),
    box-shadow var(--dur) var(--ease),
    border-color var(--dur) var(--ease),
    color var(--dur) var(--ease),
    filter var(--dur) var(--ease);
}
.btn svg { width: 14px; height: 14px; flex-shrink: 0; }
.btn:hover  { transform: translateY(-1px); }
.btn:active { transform: translateY(0); transition-duration: 80ms; }
.btn:disabled { opacity: 0.5; cursor: not-allowed; transform: none; }

/* CTA primaria — Azul NS */
.btn-primary,
.btn-peach { /* alias legacy */
  background: linear-gradient(180deg, #5572FF 0%, var(--ns-blue) 55%, var(--ns-blue-deep) 100%);
  color: #FFFFFF;
  border-color: rgba(40, 64, 204, 0.55);
  text-shadow: 0 1px 0 rgba(20, 30, 90, 0.18);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.32),
    inset 0 -1px 0 rgba(20, 30, 90, 0.32),
    var(--depth-blue);
}
.btn-primary:hover,
.btn-peach:hover {
  filter: brightness(1.06);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.42),
    inset 0 -1px 0 rgba(20, 30, 90, 0.32),
    0 16px 44px -6px rgba(58, 84, 247, 0.58);
}

/* Ghost glass */
.btn-ghost,
.btn-glass {
  background: var(--glass-80);
  color: var(--text);
  border-color: var(--glass-edge-2);
  -webkit-backdrop-filter: var(--blur-soft);
  backdrop-filter: var(--blur-soft);
  box-shadow: var(--glass-inner), var(--depth-1);
}
.btn-ghost:hover,
.btn-glass:hover {
  background: var(--glass-95);
  border-color: var(--hairline-strong);
  box-shadow: var(--glass-inner), var(--depth-2);
}

/* Aprobar (success tinted) */
.btn-approve {
  background: linear-gradient(180deg, #6BCB91 0%, #4DAF7C 55%, #3A8C61 100%);
  color: #FFFFFF;
  border-color: rgba(58, 140, 97, 0.55);
  text-shadow: 0 1px 0 rgba(20, 60, 35, 0.18);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.32),
    inset 0 -1px 0 rgba(20, 60, 35, 0.30),
    0 12px 36px -6px rgba(77, 175, 124, 0.45);
}
.btn-approve:hover {
  filter: brightness(1.06);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.42),
    inset 0 -1px 0 rgba(20, 60, 35, 0.30),
    0 16px 44px -6px rgba(77, 175, 124, 0.58);
}

/* Danger */
.btn-danger {
  background: linear-gradient(180deg, #F58273 0%, #E76F51 55%, #B5523B 100%);
  color: #FFFFFF;
  border-color: rgba(181, 82, 59, 0.55);
}

/* Icon square */
.btn-icon {
  width: 36px;
  height: 36px;
  padding: 0;
  display: grid;
  place-items: center;
  border-radius: var(--r-pill);
  background: var(--glass-80);
  border: 1px solid var(--glass-edge-2);
  color: var(--text-dim);
  cursor: pointer;
  transition: background var(--dur), border-color var(--dur), color var(--dur);
}
.btn-icon:hover { background: var(--glass-95); border-color: var(--hairline-strong); color: var(--text); }

/* ===================== SEGMENTED CONTROL ===================== */
.segmented,
.tool-group,
.viewport-group {
  display: inline-flex;
  background: var(--glass-50);
  -webkit-backdrop-filter: var(--blur-soft);
  backdrop-filter: var(--blur-soft);
  border: 1px solid var(--glass-edge-2);
  border-radius: var(--r-pill);
  padding: 3px;
  gap: 2px;
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.5), 0 1px 2px rgba(0,0,0,0.04);
}
.segmented button,
.tool-btn,
.viewport-btn {
  position: relative;
  border: none;
  background: transparent;
  color: var(--text-dim);
  font-family: var(--font-sans);
  font-weight: 600;
  font-size: 12.5px;
  padding: 7px 14px;
  border-radius: var(--r-pill);
  cursor: pointer;
  transition: color var(--dur) var(--ease), background var(--dur) var(--ease);
  display: inline-flex;
  align-items: center;
  gap: 6px;
  user-select: none;
}
.segmented button svg,
.tool-btn svg,
.viewport-btn svg { width: 14px; height: 14px; opacity: 0.85; }
.segmented button:hover,
.tool-btn:hover,
.viewport-btn:hover { color: var(--text); background: rgba(255,255,255,0.4); }
.segmented button[aria-pressed="true"],
.viewport-btn.active {
  background: var(--glass-95);
  color: var(--text);
  box-shadow:
    0 0 0 1px rgba(10,10,15,0.05),
    0 4px 12px -4px rgba(15, 23, 42, 0.18),
    inset 0 1px 0 rgba(255,255,255,0.9);
}

/* Active TOOL = azul NS (la herramienta primaria del cliente) */
.tool-btn[aria-pressed="true"] {
  background: linear-gradient(180deg, #5572FF 0%, var(--ns-blue) 100%);
  color: #FFFFFF;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.32),
    0 6px 18px -4px rgba(58, 84, 247, 0.50);
}
.tool-btn[aria-pressed="true"] svg { opacity: 1; }

/* ===================== NS BROWSER CHROME ===================== */
/* Browser ficticio: live orb + ronda progress (NO macOS dots) */
.ns-chrome {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 4px 10px;
  background: var(--glass-50);
  border: 1px solid var(--glass-edge-2);
  border-radius: var(--r-pill);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.6);
}
.live-orb {
  position: relative;
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: radial-gradient(circle at 30% 30%, #FFE0C2, var(--ns-peach-deep));
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.85),
    0 0 0 3px rgba(248, 176, 124, 0.25);
}
.live-orb::after {
  content: '';
  position: absolute;
  inset: -4px;
  border-radius: 50%;
  border: 1px solid rgba(248, 176, 124, 0.55);
  animation: live-pulse 2.2s var(--ease) infinite;
}
@keyframes live-pulse {
  0%   { transform: scale(0.9); opacity: 0.9; }
  100% { transform: scale(1.8); opacity: 0; }
}
.ronda-progress {
  display: inline-flex;
  align-items: center;
  gap: 4px;
}
.ronda-dot {
  width: 18px;
  height: 4px;
  border-radius: 2px;
  background: rgba(10, 10, 15, 0.12);
}
.ronda-dot.done   { background: var(--ink); }
.ronda-dot.active {
  background: linear-gradient(90deg, var(--ns-peach), var(--ns-peach-deep));
  box-shadow: 0 0 0 2px rgba(248,176,124,0.22);
}

/* URL bar */
.url-bar {
  flex: 1;
  display: flex;
  align-items: center;
  gap: 8px;
  background: var(--glass-50);
  border: 1px solid var(--glass-edge-2);
  border-radius: var(--r-pill);
  padding: 6px 14px;
  font-size: 12.5px;
  color: var(--text-dim);
  font-family: var(--font-mono);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.url-bar svg { flex-shrink: 0; opacity: 0.7; }

/* ===================== TOOL PANEL (Photoshop/Canva-style, inline en grid) ===================== */
.tool-panel {
  display: flex;
  flex-direction: column;
  gap: 6px;
  background: var(--glass-65);
  -webkit-backdrop-filter: var(--blur-mid);
  backdrop-filter: var(--blur-mid);
  border: 1px solid var(--glass-edge-2);
  border-radius: var(--r-xl);
  padding: 8px;
  box-shadow: var(--glass-inner), var(--depth-2);
}
/* Variante INLINE para uso en CSS grid (no flotante) */
.tool-panel-inline { position: static; width: 100%; }
.tool-panel .tool-btn {
  display: grid;
  grid-template-columns: 24px auto;
  align-items: center;
  gap: 8px;
  padding: 10px 14px 10px 12px;
  border-radius: var(--r-md);
  width: 100%;
  justify-content: flex-start;
  font-size: 12.5px;
  background: transparent;
  color: var(--text-dim);
}
.tool-panel .tool-btn svg { width: 18px; height: 18px; }
.tool-panel .tool-btn:hover { background: var(--glass-95); color: var(--text); }
.tool-panel .tool-btn[aria-pressed="true"] {
  background: linear-gradient(180deg, #5572FF 0%, var(--ns-blue) 100%);
  color: #FFFFFF;
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.32), 0 6px 18px -4px rgba(58, 84, 247, 0.50);
}
.tool-panel .tool-btn .tool-key {
  margin-left: auto;
  background: rgba(10,10,15,0.06);
  color: var(--text-faint);
  font-family: var(--font-mono);
  font-size: 10px;
  padding: 2px 6px;
  border-radius: 4px;
}
.tool-panel .tool-btn[aria-pressed="true"] .tool-key {
  background: rgba(255,255,255,0.18);
  color: rgba(255,255,255,0.85);
}
.tool-panel .tool-divider {
  height: 1px;
  background: var(--hairline);
  margin: 4px 8px;
}
/* Viewport buttons en el header — labels visibles */
.viewport-group .viewport-btn .viewport-label { display: inline; margin-left: 2px; }
.viewport-group .viewport-btn svg { opacity: 0.85; }

@media (max-width: 1100px) {
  .tool-panel-inline {
    flex-direction: row;
    overflow-x: auto;
  }
  .tool-panel .tool-btn { width: auto; }
  .tool-panel .tool-btn .tool-key { display: none; }
  .tool-panel .tool-divider { width: 1px; height: 24px; margin: 0 4px; }
}

/* ===================== COMMENTS PANEL (inline en grid, no flotante) ===================== */
.comments-panel {
  background: var(--glass-80);
  -webkit-backdrop-filter: var(--blur-deep);
  backdrop-filter: var(--blur-deep);
  border: 1px solid var(--glass-edge-2);
  border-radius: var(--r-xl);
  box-shadow: var(--glass-inner), var(--depth-3);
  display: flex;
  flex-direction: column;
  overflow: hidden;
  max-height: calc(100vh - 140px);
}
.comments-panel-inline { width: 100%; }
.comments-panel header {
  padding: 16px 18px 12px;
  border-bottom: 1px solid var(--hairline);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}
.comments-panel header h3 {
  margin: 0;
  font-size: 14px;
  font-weight: 700;
  letter-spacing: -0.01em;
}
.comments-panel header .count {
  background: var(--ink);
  color: #FFF;
  font-size: 11px;
  font-weight: 700;
  padding: 3px 9px;
  border-radius: var(--r-pill);
  font-variant-numeric: tabular-nums;
}
.comments-panel .comments-body {
  flex: 1;
  overflow-y: auto;
  padding: 12px 14px 16px;
  display: flex;
  flex-direction: column;
  gap: 10px;
  scrollbar-width: thin;
  scrollbar-color: rgba(10,10,15,0.18) transparent;
}
.comments-panel .comments-body::-webkit-scrollbar { width: 6px; }
.comments-panel .comments-body::-webkit-scrollbar-thumb { background: rgba(10,10,15,0.18); border-radius: 3px; }
.comment-card {
  background: var(--glass-95);
  border: 1px solid var(--hairline);
  border-radius: var(--r-md);
  padding: 12px 14px;
  display: flex;
  gap: 10px;
  cursor: pointer;
  transition: background var(--dur) var(--ease), border-color var(--dur) var(--ease), transform var(--dur) var(--ease);
}
.comment-card:hover {
  background: #FFF;
  border-color: var(--hairline-strong);
  transform: translateX(-2px);
}
.comment-card .num {
  width: 26px; height: 26px;
  border-radius: 50%;
  background: linear-gradient(135deg, #FFE2C7, var(--ns-peach));
  color: var(--ink);
  font-weight: 700;
  font-size: 12px;
  display: grid;
  place-items: center;
  flex-shrink: 0;
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.6);
}
.comment-card.resuelto .num {
  background: linear-gradient(135deg, #8FE0B0, var(--status-resuelto));
  color: #FFF;
}
.comment-card .body { flex: 1; min-width: 0; }
.comment-card p {
  margin: 0;
  font-size: 13px;
  color: var(--text);
  line-height: 1.45;
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.comment-card small {
  display: block;
  margin-top: 6px;
  color: var(--text-muted);
  font-size: 11px;
  font-family: var(--font-mono);
  letter-spacing: 0.04em;
  text-transform: uppercase;
}
.comments-empty {
  padding: 30px 16px;
  text-align: center;
  color: var(--text-muted);
  font-size: 13px;
}
.comments-empty .icon {
  width: 44px; height: 44px;
  margin: 0 auto 10px;
  border-radius: 50%;
  background: var(--glass-95);
  border: 1px solid var(--hairline);
  display: grid;
  place-items: center;
  color: var(--text-faint);
}

@media (max-width: 1100px) {
  .comments-panel { max-height: 400px; }
  .comments-panel .comments-body { max-height: 320px; }
}

/* ===================== FILE INPUT styled ===================== */
input[type="file"] {
  font-family: var(--font-sans);
  font-size: 13px;
  color: var(--text-muted);
  padding: 0;
  border: 1px dashed var(--hairline-strong);
  border-radius: var(--r-md);
  background: rgba(255,255,255,0.5);
  -webkit-backdrop-filter: blur(8px);
  backdrop-filter: blur(8px);
  width: 100%;
  cursor: pointer;
  transition: border-color var(--dur), background var(--dur);
}
input[type="file"]:hover {
  border-color: var(--ns-blue);
  background: rgba(255,255,255,0.75);
}
input[type="file"]::file-selector-button,
input[type="file"]::-webkit-file-upload-button {
  font-family: var(--font-sans);
  font-weight: 700;
  font-size: 13px;
  color: var(--text);
  background: var(--glass-95);
  border: none;
  border-right: 1px solid var(--hairline-strong);
  padding: 10px 16px;
  margin-right: 12px;
  cursor: pointer;
  border-radius: var(--r-md) 0 0 var(--r-md);
  transition: background var(--dur);
}
input[type="file"]::file-selector-button:hover,
input[type="file"]::-webkit-file-upload-button:hover {
  background: var(--paper-2);
}

/* ===================== DEVICE FRAME ===================== */
.device-frame {
  transition: width var(--dur-slow) var(--ease);
  margin-inline: auto;
  position: relative;
  border-radius: var(--r-2xl);
  background: var(--glass-95);
  -webkit-backdrop-filter: var(--blur-deep);
  backdrop-filter: var(--blur-deep);
  border: 1px solid var(--glass-edge-2);
  box-shadow: var(--glass-inner), var(--depth-3);
  overflow: hidden;
}
.device-desktop { width: 100%; }
.device-tablet  { width: 768px; max-width: 100%; }
.device-mobile  { width: 375px; max-width: 100%; }

/* Modo desktop: iframe se renderea a 1440px reales (viewport real desktop)
   y se escala visualmente con transform para encajar en el contenedor.
   IMPORTANTE: position:absolute para que su width 1440px NO afecte el grid layout. */
.device-desktop .device-stage {
  position: relative;
  overflow: hidden;
}
.device-desktop .preview-iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 1440px;
  transform-origin: top left;
}

.device-toolbar {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 12px 16px;
  border-bottom: 1px solid var(--hairline);
  background: linear-gradient(180deg, rgba(255,255,255,0.55), rgba(255,255,255,0.20));
}

.device-stage {
  position: relative;
  height: calc(100vh - 280px);
  min-height: 480px;
  background: #fff;
  overflow: hidden;
}

.preview-iframe {
  display: block;
  width: 100%;
  height: 100%;
  border: none;
  background: #fff;
}

/* ===================== CLICK CATCHER ===================== */
.click-catcher {
  position: absolute;
  inset: 0;
  z-index: var(--z-overlay);
  pointer-events: none;
  background: transparent;
}
.click-catcher[data-tool="pin"],
.click-catcher[data-tool="box"] {
  pointer-events: auto;
  cursor: crosshair;
  touch-action: none;
  -webkit-user-select: none;
  user-select: none;
}

.box-preview {
  position: absolute;
  border: 2px solid var(--ns-blue);
  background: rgba(58, 84, 247, 0.10);
  pointer-events: none;
  border-radius: 6px;
  box-shadow:
    0 0 0 1px rgba(255,255,255,0.85),
    0 6px 18px -4px rgba(58, 84, 247, 0.30);
}

/* ===================== PINS ===================== */
.pins-overlay {
  position: absolute;
  inset: 0;
  pointer-events: none;
  z-index: calc(var(--z-overlay) + 1);
}

.pin {
  position: absolute;
  width: 32px;
  height: 32px;
  border-radius: 50%;
  transform: translate(-50%, -50%);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-weight: 700;
  font-size: 12px;
  color: var(--ink);
  background: linear-gradient(135deg, #FFE2C7, var(--ns-peach));
  border: 2px solid rgba(255,255,255,0.85);
  box-shadow:
    var(--depth-peach),
    inset 0 1px 0 rgba(255,255,255,0.75);
  cursor: pointer;
  pointer-events: auto;
  user-select: none;
  transition: transform var(--dur) var(--ease-out), box-shadow var(--dur) var(--ease-out);
}
.pin:hover {
  transform: translate(-50%, -50%) scale(1.15);
  box-shadow:
    0 14px 38px -4px rgba(248,176,124,0.62),
    inset 0 1px 0 rgba(255,255,255,0.85);
}
.pin.resuelto {
  background: linear-gradient(135deg, #8FE0B0, var(--status-resuelto));
  color: #FFF;
}

.pin-box {
  position: absolute;
  border: 2px solid rgba(248, 176, 124, 0.85);
  background: rgba(252, 200, 164, 0.16);
  border-radius: 10px;
  cursor: pointer;
  pointer-events: auto;
  backdrop-filter: blur(1px);
  box-shadow:
    inset 0 0 0 1px rgba(255,255,255,0.55),
    0 8px 24px -6px rgba(248,176,124,0.45);
  transition: background var(--dur) var(--ease);
}
.pin-box:hover {
  background: rgba(252, 200, 164, 0.26);
}
.pin-box .pin-box-badge {
  position: absolute;
  top: -14px;
  left: -14px;
  width: 30px;
  height: 30px;
  border-radius: 50%;
  background: linear-gradient(135deg, #FFE2C7, var(--ns-peach));
  color: var(--ink);
  font-weight: 700;
  font-size: 12px;
  display: grid;
  place-items: center;
  border: 2px solid rgba(255,255,255,0.85);
  box-shadow: var(--depth-peach);
}
.pin-box.resuelto {
  border-color: rgba(91, 196, 137, 0.85);
  background: rgba(91, 196, 137, 0.14);
}
.pin-box.resuelto .pin-box-badge {
  background: linear-gradient(135deg, #8FE0B0, var(--status-resuelto));
  color: #FFF;
}

/* ===================== DIALOGS (popups) ===================== */
dialog {
  border: none;
  padding: 0;
  border-radius: var(--r-xl);
  background: var(--glass-95);
  -webkit-backdrop-filter: var(--blur-deep);
  backdrop-filter: var(--blur-deep);
  border: 1px solid var(--glass-edge-2);
  box-shadow: var(--glass-inner), var(--depth-3);
  max-width: calc(100vw - 2rem);
  color: var(--text);
}
dialog::backdrop {
  background: rgba(10, 10, 15, 0.35);
  backdrop-filter: blur(8px);
}

.popup-inner {
  width: min(440px, calc(100vw - 2rem));
  padding: 22px 24px 20px;
}
.popup-title {
  font-family: var(--font-display);
  font-size: 17px;
  font-weight: 700;
  letter-spacing: -0.015em;
  margin: 0 0 4px;
}
.popup-meta {
  font-size: 11px;
  color: var(--text-muted);
  margin: 0 0 14px;
  font-family: var(--font-mono);
}

.input,
.textarea {
  width: 100%;
  border: 1px solid var(--hairline-strong);
  background: rgba(255,255,255,0.7);
  color: var(--text);
  border-radius: var(--r-md);
  padding: 11px 13px;
  font-family: var(--font-sans);
  font-size: 14px;
  outline: none;
  transition: border-color var(--dur) var(--ease), background var(--dur) var(--ease), box-shadow var(--dur) var(--ease);
}
.textarea { resize: vertical; min-height: 92px; }
.input:focus,
.textarea:focus {
  border-color: var(--ns-blue);
  background: #FFF;
  box-shadow: 0 0 0 3px rgba(58, 84, 247, 0.22);
}

.field-label {
  display: block;
  color: var(--text-muted);
  font-size: 12px;
  font-weight: 600;
  margin: 14px 0 6px;
  letter-spacing: 0.005em;
}

.popup-actions {
  display: flex;
  justify-content: flex-end;
  gap: 8px;
  margin-top: 18px;
}

/* ===================== CARDS (dashboard) ===================== */
.card {
  background: var(--glass-95);
  -webkit-backdrop-filter: var(--blur-soft);
  backdrop-filter: var(--blur-soft);
  border: 1px solid var(--glass-edge-2);
  border-radius: var(--r-xl);
  padding: var(--space-6);
  box-shadow: var(--glass-inner), var(--depth-1);
  border-top: 3px solid rgba(10,10,15,0.08);
  transition: box-shadow var(--dur) var(--ease), transform var(--dur) var(--ease);
}
.card:hover {
  box-shadow: var(--glass-inner), var(--depth-2);
  transform: translateY(-2px);
}
.card[data-status="revision"]            { border-top-color: var(--ns-peach-deep); }
.card[data-status="cambios_pendientes"]  { border-top-color: var(--status-en-progreso); }
.card[data-status="aprobado"]            { border-top-color: var(--status-aprobado); }
.card[data-status="cerrado"]             { border-top-color: var(--text-faint); }

/* Sticker badge (NS signature, legacy) */
.sticker-badge {
  display: inline-flex;
  align-items: center;
  background: var(--ns-peach);
  color: var(--ink);
  border: 2px solid #FFF;
  border-radius: var(--r-sm);
  padding: 5px 12px;
  font-weight: 800;
  font-size: 12px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  box-shadow: var(--depth-0);
}
.sticker-badge.inverted {
  background: var(--ink);
  color: #FFF;
  border-color: #FFF;
}

/* Mobile blocker */
.mobile-blocker {
  border-radius: var(--r-lg);
  background: var(--glass-95);
  border: 1px solid var(--glass-edge-2);
  padding: 16px;
  font-size: 14px;
  color: var(--text-dim);
  margin-bottom: 12px;
  box-shadow: var(--glass-inner), var(--depth-1);
}

/* Utils */
.hidden { display: none !important; }

/* Reduced motion */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.001ms !important;
    transition-duration: 0.001ms !important;
  }
}
