/* ═══════════════════════════════════════════════════════════════
   Peplink AI Advisor + Comparison Tool + Product Spec Table
   + Key Specs Bar + Product Compare Tab + AI Tab
   + Shop Compare Button + Compare Tray + Compare Modal
   NorthcomPepSync — ps-advisor.css
   ═══════════════════════════════════════════════════════════════ */

/* ── Design tokens ─────────────────────────────────────────── */
:root {
  /* Northcom brand palette — matches northcom.no identity */
  --psa-primary:    #1B6CA8;  /* Northcom medium blue  */
  --psa-primary-dk: #0B2545;  /* Northcom dark navy    */
  --psa-accent:     #00B4D8;  /* Northcom teal (logo O)*/
  --psa-surface:    #ffffff;
  --psa-bg:         #f4f7fb;
  --psa-border:     #d8e2ef;
  --psa-text:       #1a2333;
  --psa-muted:      #64748b;
  --psa-radius:     10px;
  --psa-shadow:     0 4px 24px rgba(0,0,0,.12);
}

/* ════════════════════════════════════════════════════════════
   INLINE CHAT WIDGET  [peplink_advisor shortcode]
   ════════════════════════════════════════════════════════════ */

.ps-advisor-widget {
  display: flex;
  flex-direction: column;
  border: 1px solid var(--psa-border);
  border-radius: var(--psa-radius);
  overflow: hidden;
  font-family: inherit;
  background: var(--psa-surface);
  box-shadow: 0 2px 12px rgba(0,0,0,.07);
}

.ps-advisor-header {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 12px 16px;
  background: var(--psa-primary);
  color: #fff;
  font-weight: 600;
  font-size: .95rem;
}

.ps-advisor-icon { font-size: 1.2rem; }

.ps-advisor-messages {
  flex: 1;
  overflow-y: auto;
  padding: 16px;
  background: var(--psa-bg);
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.ps-advisor-welcome {
  background: #fff;
  border: 1px solid var(--psa-border);
  border-radius: var(--psa-radius);
  padding: 14px 16px;
  font-size: .9rem;
  color: var(--psa-text);
}

.ps-advisor-welcome ul {
  margin: 8px 0 8px 18px;
  padding: 0;
  list-style: disc;
}

.ps-advisor-welcome li { margin-bottom: 4px; }

/* Chat bubbles */
.ps-msg {
  max-width: 82%;
  padding: 10px 14px;
  border-radius: 16px;
  font-size: .9rem;
  line-height: 1.55;
  word-break: break-word;
}

.ps-msg-user {
  align-self: flex-end;
  background: var(--psa-primary);
  color: #fff;
  border-bottom-right-radius: 4px;
}

.ps-msg-assistant {
  align-self: flex-start;
  background: #fff;
  color: var(--psa-text);
  border: 1px solid var(--psa-border);
  border-bottom-left-radius: 4px;
}

/* Prose inside assistant messages */
.ps-msg-assistant p   { margin: 0 0 8px; }
.ps-msg-assistant p:last-child { margin-bottom: 0; }
.ps-msg-assistant ul,
.ps-msg-assistant ol  { margin: 4px 0 8px 18px; padding: 0; }
.ps-msg-assistant li  { margin-bottom: 3px; }
.ps-msg-assistant strong { font-weight: 600; }

/* Thinking indicator */
.ps-msg-thinking {
  align-self: flex-start;
  display: flex;
  gap: 5px;
  padding: 10px 14px;
}

.ps-thinking-dot {
  width: 7px; height: 7px;
  border-radius: 50%;
  background: var(--psa-muted);
  animation: psThinkPulse 1.2s infinite ease-in-out;
}

.ps-thinking-dot:nth-child(2) { animation-delay: .2s; }
.ps-thinking-dot:nth-child(3) { animation-delay: .4s; }

@keyframes psThinkPulse {
  0%, 80%, 100% { transform: scale(.8); opacity: .5; }
  40%            { transform: scale(1);  opacity: 1;   }
}

/* Input row */
.ps-advisor-input-row {
  display: flex;
  gap: 8px;
  padding: 10px 12px;
  background: var(--psa-surface);
  border-top: 1px solid var(--psa-border);
}

.ps-advisor-input {
  flex: 1;
  resize: none;
  border: 1px solid var(--psa-border);
  border-radius: 8px;
  padding: 8px 12px;
  font-size: .9rem;
  font-family: inherit;
  line-height: 1.4;
  transition: border-color .15s;
}

.ps-advisor-input:focus {
  outline: none;
  border-color: var(--psa-accent);
}

.ps-advisor-send {
  align-self: flex-end;
  padding: 8px 18px;
  background: var(--psa-primary);
  color: #fff;
  border: none;
  border-radius: 8px;
  font-size: .9rem;
  font-weight: 600;
  cursor: pointer;
  transition: background .15s;
  white-space: nowrap;
}

.ps-advisor-send:hover  { background: var(--psa-primary-dk); }
.ps-advisor-send:active { transform: scale(.97); }


/* ════════════════════════════════════════════════════════════
   FLOATING ACTION BUTTON  (product pages)
   ════════════════════════════════════════════════════════════ */

.ps-fab-advisor {
  position: fixed;
  bottom: 28px;
  right: 28px;
  z-index: 9999;
  font-family: inherit;
}

.ps-fab-btn {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 12px 20px;
  background: var(--psa-primary);
  color: #fff;
  border: none;
  border-radius: 50px;
  font-size: .95rem;
  font-weight: 600;
  cursor: pointer;
  box-shadow: var(--psa-shadow);
  transition: background .15s, transform .15s;
}

.ps-fab-btn:hover  { background: var(--psa-primary-dk); }
.ps-fab-btn:active { transform: scale(.96); }

/* Slide-up panel */
.ps-fab-panel {
  position: absolute;
  bottom: 60px;
  right: 0;
  width: 380px;
  max-width: calc(100vw - 40px);
  height: 500px;
  display: flex;
  flex-direction: column;
  border-radius: var(--psa-radius);
  overflow: hidden;
  box-shadow: var(--psa-shadow);
  background: var(--psa-surface);
  border: 1px solid var(--psa-border);
  animation: psFabSlideUp .2s ease;
}

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

.ps-fab-panel-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 10px 14px;
  background: var(--psa-primary);
  color: #fff;
  font-size: .88rem;
  font-weight: 600;
}

.ps-fab-close {
  background: none;
  border: none;
  color: #fff;
  font-size: 1.3rem;
  cursor: pointer;
  line-height: 1;
  opacity: .8;
  transition: opacity .15s;
}

.ps-fab-close:hover { opacity: 1; }

.ps-fab-messages {
  flex: 1;
  overflow-y: auto;
  padding: 12px;
  background: var(--psa-bg);
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.ps-fab-input-row {
  display: flex;
  gap: 6px;
  padding: 8px 10px;
  border-top: 1px solid var(--psa-border);
}

.ps-fab-input {
  flex: 1;
  resize: none;
  border: 1px solid var(--psa-border);
  border-radius: 6px;
  padding: 6px 10px;
  font-size: .88rem;
  font-family: inherit;
}

.ps-fab-input:focus { outline: none; border-color: var(--psa-accent); }

.ps-fab-send {
  align-self: flex-end;
  padding: 6px 14px;
  background: var(--psa-primary);
  color: #fff;
  border: none;
  border-radius: 6px;
  font-size: .88rem;
  font-weight: 600;
  cursor: pointer;
}

.ps-fab-send:hover { background: var(--psa-primary-dk); }


/* ════════════════════════════════════════════════════════════
   COMPARISON TOOL  [peplink_compare shortcode]
   ════════════════════════════════════════════════════════════ */

.ps-compare-tool {
  font-family: inherit;
  color: var(--psa-text);
}

.ps-compare-header { margin-bottom: 20px; }
.ps-compare-title  { font-size: 1.3rem; font-weight: 700; margin: 0 0 4px; }
.ps-compare-subtitle { color: var(--psa-muted); font-size: .9rem; margin: 0; }

/* Slot selectors */
.ps-compare-selectors {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: 10px;
  margin-bottom: 16px;
}

.ps-compare-slot {
  display: flex;
  align-items: center;
  gap: 6px;
}

.ps-compare-select {
  flex: 1;
  padding: 8px 10px;
  border: 1px solid var(--psa-border);
  border-radius: 8px;
  font-size: .9rem;
  background: #fff;
  color: var(--psa-text);
  cursor: pointer;
}

.ps-compare-select:focus { outline: none; border-color: var(--psa-accent); }

.ps-compare-slot-clear {
  background: none;
  border: 1px solid var(--psa-border);
  border-radius: 50%;
  width: 26px; height: 26px;
  font-size: 1rem;
  line-height: 1;
  cursor: pointer;
  color: var(--psa-muted);
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}

.ps-compare-slot-clear:hover { color: #c0392b; border-color: #c0392b; }

/* Action row */
.ps-compare-actions {
  display: flex;
  align-items: center;
  gap: 14px;
  margin-bottom: 20px;
  flex-wrap: wrap;
}

.ps-compare-run {
  padding: 9px 22px;
  background: var(--psa-primary);
  color: #fff;
  border: none;
  border-radius: 8px;
  font-size: .95rem;
  font-weight: 600;
  cursor: pointer;
  transition: background .15s, opacity .15s;
}

.ps-compare-run:disabled { opacity: .45; cursor: not-allowed; }
.ps-compare-run:not(:disabled):hover { background: var(--psa-primary-dk); }

.ps-compare-diff-toggle {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: .9rem;
  color: var(--psa-muted);
  cursor: pointer;
  user-select: none;
}

/* .ps-compare-ask-ai is styled in the action-group section below */

/* Loading */
.ps-compare-loading {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 20px;
  color: var(--psa-muted);
  font-size: .9rem;
}

.ps-compare-spinner {
  width: 20px; height: 20px;
  border: 2px solid var(--psa-border);
  border-top-color: var(--psa-primary);
  border-radius: 50%;
  animation: psSpinAnim .7s linear infinite;
}

@keyframes psSpinAnim { to { transform: rotate(360deg); } }

/* ── Comparison table wrapper ── */
.ps-compare-table-wrap {
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}

/* ── Section grouping ── */
.ps-compare-section {
  margin-bottom: 28px;
  border: 1px solid var(--psa-border);
  border-radius: 10px;
  overflow: hidden;
}

.ps-compare-section-title {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: .75rem;
  font-weight: 600;
  color: #4a5568;
  text-transform: uppercase;
  letter-spacing: .07em;
  padding: 10px 16px 10px 20px;
  margin: 0;
  background: #f7f9fc;
  border-bottom: 1px solid var(--psa-border);
}

.ps-compare-section-title::before {
  content: '';
  display: inline-block;
  width: 3px;
  height: 14px;
  background: var(--psa-primary);
  border-radius: 2px;
  flex-shrink: 0;
}

/* ── Table ── */
.ps-compare-table {
  width: 100%;
  border-collapse: collapse;
  font-size: .875rem;
}

.ps-compare-table th,
.ps-compare-table td {
  padding: 10px 16px !important;
  text-align: left;
  border-bottom: 1px solid var(--psa-border);
  vertical-align: top;
  line-height: 1.45;
}

.ps-compare-table tbody tr:last-child th,
.ps-compare-table tbody tr:last-child td {
  border-bottom: none;
}

/* Field-name column — sticky so it stays visible on horizontal scroll */
.ps-compare-table th {
  background: #fafbfd;
  font-weight: 500;
  color: var(--psa-muted);
  width: 28%;
  padding-left: 20px !important;
  word-break: break-word;
  position: sticky;
  left: 0;
  z-index: 1;
}

/* Value columns */
.ps-compare-table td {
  color: var(--psa-text);
  background: #fff;
}

/* Alternating row tint — only on non-diff rows to avoid background conflicts */
.ps-compare-table tbody tr:nth-child(even):not(.ps-cmp-differs) th,
.ps-compare-table tbody tr:nth-child(even):not(.ps-cmp-differs) td {
  background: #f9fafc;
}

/* ── Diff highlight — neutral backgrounds only, no colored text ── */
.ps-compare-table tr.ps-cmp-differs th {
  background: #f3f6fb;
  color: var(--psa-text);
  font-weight: 500;
  /* Left accent bar signals the row has differences */
  box-shadow: inset 3px 0 0 rgba(0,85,165,.22);
}

.ps-compare-table tr.ps-cmp-differs td {
  background: #f3f6fb;
}

/* Cells whose value actually differs — slightly deeper tint + weight, text stays dark */
.ps-compare-table td.ps-cmp-diff {
  font-weight: 600;
  color: var(--psa-text);
  background: #e9eef9;
  position: relative;
}

/* Hide identical rows in diff mode */
.ps-compare-diff-mode .ps-cmp-identical { display: none; }

/* ── Product header cards ── */
.ps-cmp-header-cards {
  display: flex;
  margin-bottom: 20px;
  border: 1px solid var(--psa-border);
  border-radius: 12px;
  overflow: hidden;
  box-shadow: 0 2px 8px rgba(0,0,0,.05);
}

.ps-cmp-header-spacer {
  width: 28%;
  flex-shrink: 0;
  background: #fafbfd;
  border-right: 1px solid var(--psa-border);
  display: flex;
  flex-direction: column;
}

/* Full-bleed photo card — flex column: image area grows, glass panel fixed at bottom */
.ps-cmp-header-card {
  flex: 1;
  min-width: 0;
  min-height: 185px;
  position: relative;
  overflow: hidden;
  border-right: 1px solid var(--psa-border);
  background: #f0f4f8;
  display: flex;
  flex-direction: column;
}

/* Coloured accent stripe (z-index above image layers) */
.ps-cmp-header-card::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 3px;
  z-index: 3;
  background: var(--psa-primary);
}

.ps-cmp-header-card:nth-child(2)::before { background: #0B2545; }
.ps-cmp-header-card:nth-child(3)::before { background: #1B6CA8; }
.ps-cmp-header-card:nth-child(4)::before { background: #00B4D8; }
.ps-cmp-header-card:nth-child(5)::before { background: #4dd8e8; }

.ps-cmp-header-card:last-child { border-right: none; }

/* Blurred atmospheric copy of the product image */
.ps-cmp-card-bg-blur {
  position: absolute;
  inset: -12%;
  background-image: var(--card-img, none);
  background-size: cover;
  background-position: center;
  filter: blur(22px) brightness(.9) saturate(1.4);
  opacity: .18;
  pointer-events: none;
  z-index: 0;
}

/* Image display area — flex: 1 so it fills all space above the glass panel */
.ps-cmp-card-img-area {
  flex: 1;
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 12px 16px;
  z-index: 1;
}

.ps-cmp-card-img {
  max-width: 100%;
  max-height: 100%;
  object-fit: contain;
  filter: drop-shadow(0 2px 10px rgba(11,37,69,.12));
  position: relative;
  z-index: 1;
}

.ps-cmp-card-img-placeholder {
  font-size: 2.4rem;
  line-height: 1;
  opacity: .18;
}

/* Frosted glass text panel — flex-shrink: 0 so it stays at bottom and content drives height */
.ps-cmp-card-glass {
  flex-shrink: 0;
  min-height: 82px;
  padding: 9px 12px 10px;
  background: rgba(255,255,255,.78);
  backdrop-filter: blur(14px) saturate(200%);
  -webkit-backdrop-filter: blur(14px) saturate(200%);
  border-top: 1px solid rgba(255,255,255,.7);
  display: flex;
  flex-direction: column;
  gap: 4px;
  z-index: 2;
  box-sizing: border-box;
}

.ps-cmp-card-name {
  font-size: .8rem;
  font-weight: 700;
  color: #0B2545;
  line-height: 1.2;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.ps-cmp-card-series {
  font-size: .64rem;
  color: #4a5568;
  letter-spacing: .01em;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.ps-cmp-card-sku {
  font-size: .62rem;
  color: #64748b;
  font-family: 'SF Mono', 'Cascadia Code', Consolas, monospace;
  letter-spacing: .04em;
  opacity: .8;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.ps-cmp-card-img--lb {
  cursor: zoom-in;
  transition: opacity .15s;
}
.ps-cmp-card-img--lb:hover { opacity: .88; }

/* ════════════════════════════════════════════════════════════
   IMAGE LIGHTBOX
   ════════════════════════════════════════════════════════════ */

#ps-img-lightbox {
  position: fixed;
  inset: 0;
  z-index: 99999;
  display: flex;
  align-items: center;
  justify-content: center;
}

.ps-lb-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(3, 10, 23, .88);
  -webkit-backdrop-filter: blur(6px);
  backdrop-filter: blur(6px);
  cursor: pointer;
}

.ps-lb-inner {
  position: relative;
  z-index: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  max-width: min(90vw, 860px);
  padding: 12px;
}

.ps-lb-caption {
  color: rgba(255,255,255,.92);
  font-size: .9rem;
  font-weight: 600;
  text-align: center;
  padding: 10px 8px 2px;
  max-width: 100%;
  line-height: 1.35;
}

.ps-lb-caption-sku {
  display: block;
  color: rgba(255,255,255,.52);
  font-size: .72rem;
  font-family: 'SF Mono', 'Cascadia Code', Consolas, monospace;
  letter-spacing: .08em;
  margin-top: 3px;
}

.ps-lb-img {
  max-width: 100%;
  max-height: 80vh;
  object-fit: contain;
  border-radius: 10px;
  box-shadow: 0 28px 80px rgba(0,0,0,.6);
  display: block;
  background: #fff;
  padding: 20px;
}

.ps-lb-close {
  position: absolute;
  top: -4px;
  right: -4px;
  width: 32px;
  height: 32px;
  border-radius: 50%;
  background: #fff;
  border: none;
  font-size: 1.1rem;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 2px 10px rgba(0,0,0,.4);
  color: #1a2333;
  transition: background .15s, color .15s;
  line-height: 1;
  z-index: 2;
}

.ps-lb-close:hover { background: #fee2e2; color: #dc2626; }

body.ps-lb-open { overflow: hidden; }

.ps-cmp-card-type {
  display: inline-block;
  font-size: .6rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .05em;
  padding: 2px 8px;
  border-radius: 20px;
  flex-shrink: 0;
  white-space: nowrap;
  align-self: flex-start;
}

.ps-cmp-type-router { background: rgba(58,100,153,.1);  color: #3a6499; }
.ps-cmp-type-access_point { background: rgba(45,106,80,.1); color: #2d6a50; }
.ps-cmp-type-switch { background: rgba(96,80,168,.1);   color: #6050a8; }

/* Badge pinned to top-left of the card image (outside glass panel) */
.ps-cmp-card-type-overlay {
  position: absolute;
  top: 9px;
  left: 9px;
  z-index: 2;
}

/* ── Action group (print / e-post / AI) ── */
.ps-cmp-action-group {
  display: flex;
  align-items: center;
  gap: 6px;
  margin-left: auto;
  flex-wrap: wrap;
}

.ps-cmp-print-btn,
.ps-cmp-email-btn,
.ps-compare-ask-ai {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 6px 13px;
  background: #fff;
  border: 1px solid var(--psa-border);
  border-radius: 7px;
  font-size: .8rem;
  font-weight: 600;
  color: var(--psa-text);
  cursor: pointer;
  transition: background .15s, border-color .15s, color .15s, box-shadow .15s;
  white-space: nowrap;
  box-shadow: 0 1px 3px rgba(0,0,0,.06);
  font-family: inherit;
}

/* Override WP button styles that may bleed in */
.ps-cmp-action-group .button { box-shadow: none !important; }

.ps-cmp-print-btn:hover {
  background: #f0f5ff;
  border-color: var(--psa-primary);
  color: var(--psa-primary);
  box-shadow: 0 2px 6px rgba(0,85,165,.12);
}

.ps-cmp-email-btn:hover {
  background: #f0faff;
  border-color: var(--psa-accent);
  color: #0078a8;
  box-shadow: 0 2px 6px rgba(0,166,226,.12);
}

.ps-compare-ask-ai {
  background: var(--psa-accent);
  border-color: var(--psa-accent);
  color: #fff;
}

.ps-compare-ask-ai:hover {
  background: #008cc3;
  border-color: #008cc3;
  color: #fff;
  box-shadow: 0 2px 8px rgba(0,166,226,.25);
}

/* ── E-post form ── */
.ps-cmp-email-form {
  border-top: 1px solid var(--psa-border);
  background: var(--psa-bg);
}

.ps-cmp-email-inner {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
  padding: 12px 16px;
}

.ps-cmp-email-input,
.ps-cmp-email-subject {
  flex: 1;
  min-width: 160px;
  padding: 8px 10px;
  border: 1px solid var(--psa-border);
  border-radius: 7px;
  font-size: .87rem;
  background: #fff;
}

.ps-cmp-email-input:focus,
.ps-cmp-email-subject:focus {
  outline: none;
  border-color: var(--psa-accent);
  box-shadow: 0 0 0 2px rgba(0,166,226,.15);
}

.ps-cmp-email-btns { display: flex; gap: 6px; flex-shrink: 0; }

.ps-cmp-email-cancel {
  background: none;
  border: 1px solid var(--psa-border);
  border-radius: 7px;
  padding: 7px 12px;
  font-size: .82rem;
  cursor: pointer;
  color: var(--psa-muted);
}

.ps-cmp-email-cancel:hover { border-color: #94a3b8; color: var(--psa-text); }

.ps-cmp-email-msg {
  width: 100%;
  margin: 0;
  font-size: .82rem;
  padding: 0 4px;
  min-height: 1em;
}

/* ── OTP verification panel ── */
.ps-cmp-otp-row {
  display: none;
  flex-direction: column;
  gap: 10px;
  padding: 14px 16px;
  background: #eff6ff;
  border-top: 1px solid #bfdbfe;
}

.ps-cmp-otp-info {
  font-size: .84rem;
  color: #1e40af;
  line-height: 1.5;
  margin: 0;
}

.ps-cmp-otp-input-wrap {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}

.ps-cmp-otp-input {
  width: 140px;
  padding: 9px 12px;
  border: 1.5px solid #93c5fd;
  border-radius: 8px;
  font-size: 1.1rem;
  font-family: 'SF Mono', 'Cascadia Code', Consolas, monospace;
  letter-spacing: .2em;
  text-align: center;
  background: #fff;
  color: var(--psa-text);
}

.ps-cmp-otp-input:focus {
  outline: none;
  border-color: var(--psa-accent);
  box-shadow: 0 0 0 2px rgba(0,166,226,.15);
}

.ps-cmp-otp-submit {
  padding: 9px 18px;
  background: var(--psa-primary);
  color: #fff;
  border: none;
  border-radius: 8px;
  font-size: .88rem;
  font-weight: 600;
  cursor: pointer;
  transition: background .15s;
  white-space: nowrap;
}

.ps-cmp-otp-submit:hover  { background: var(--psa-primary-dk); }
.ps-cmp-otp-submit:disabled { opacity: .5; cursor: not-allowed; }

.ps-cmp-otp-cancel {
  padding: 9px 14px;
  background: none;
  border: 1px solid var(--psa-border);
  border-radius: 8px;
  font-size: .85rem;
  color: var(--psa-muted);
  cursor: pointer;
  transition: border-color .12s, color .12s;
}

.ps-cmp-otp-cancel:hover { border-color: #94a3b8; color: var(--psa-text); }

.ps-cmp-otp-msg {
  font-size: .82rem;
  margin: 0;
  line-height: 1.4;
}

/* Note marker (legacy) */
.ps-spec-note-marker {
  color: var(--psa-accent);
  font-weight: 700;
  cursor: help;
  margin-left: 2px;
}


/* ════════════════════════════════════════════════════════════
   PRODUCT PAGE SPEC TABLE  (WooCommerce product tabs)
   ════════════════════════════════════════════════════════════ */

.ps-specs-wrap {
  font-size: .9rem;
  color: var(--psa-text);
  max-width: 900px;
}

/* Meta row: image + badges */
.ps-specs-meta-row {
  display: flex;
  align-items: flex-start;
  gap: 16px;
  margin-bottom: 20px;
}

.ps-specs-product-image {
  max-width: 120px;
  max-height: 80px;
  object-fit: contain;
  border: 1px solid var(--psa-border);
  border-radius: 6px;
  padding: 6px;
  background: #fff;
}

.ps-specs-meta-info {
  display: flex;
  flex-direction: column;
  gap: 6px;
  justify-content: center;
}

.ps-specs-series {
  font-size: .95rem;
  font-weight: 600;
  color: var(--psa-primary);
}

.ps-specs-badge {
  display: inline-block;
  padding: 3px 10px;
  border-radius: 50px;
  font-size: .78rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .04em;
}

.ps-badge-active  { background: #d1fae5; color: #065f46; }
.ps-badge-default { background: #e2e8f0; color: #475569; }

/* Collapsible sections */
.ps-specs-sections { display: flex; flex-direction: column; gap: 6px; }

.ps-spec-section {
  border: 1px solid var(--psa-border);
  border-radius: 8px;
  overflow: hidden;
  background: #fff;
}

.ps-spec-section-title {
  padding: 10px 16px;
  background: var(--psa-bg);
  font-weight: 600;
  font-size: .9rem;
  color: var(--psa-primary);
  cursor: pointer;
  list-style: none;
  display: flex;
  align-items: center;
  gap: 8px;
}

.ps-spec-section-title::before {
  content: '▸';
  display: inline-block;
  transition: transform .15s;
  font-size: .8rem;
  color: var(--psa-muted);
}

details[open] .ps-spec-section-title::before { transform: rotate(90deg); }

.ps-spec-table {
  width: 100%;
  border-collapse: collapse;
  font-size: .88rem;
}

.ps-spec-table th,
.ps-spec-table td {
  padding: 7px 14px;
  text-align: left;
  border-bottom: 1px solid var(--psa-border);
  vertical-align: top;
}

.ps-spec-table th {
  width: 45%;
  font-weight: 500;
  color: var(--psa-muted);
  background: #fafbfd;
}

.ps-spec-table td { color: var(--psa-text); }

.ps-spec-table tr:last-child th,
.ps-spec-table tr:last-child td { border-bottom: none; }

/* CTA */
.ps-specs-cta-row {
  margin-top: 20px;
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
}

.ps-specs-ask-ai {
  padding: 9px 20px;
  background: var(--psa-primary);
  color: #fff;
  border: none;
  border-radius: 8px;
  font-size: .9rem;
  font-weight: 600;
  cursor: pointer;
  transition: background .15s;
}

.ps-specs-ask-ai:hover { background: var(--psa-primary-dk); }

/* Compare tab link (inside tab list — legacy, kept for compat) */
.ps-tab-compare-btn {
  cursor: pointer;
  font-size: .88rem;
  color: var(--psa-primary);
  display: flex;
  align-items: center;
  gap: 4px;
}


/* ════════════════════════════════════════════════════════════
   KEY SPECS HERO BAR
   ════════════════════════════════════════════════════════════ */

.ps-key-specs-bar {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin: 16px 0 24px;
}

.ps-key-spec {
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 10px 14px;
  border: 1px solid var(--psa-border);
  border-radius: 8px;
  background: #fff;
  min-width: 90px;
  text-align: center;
  gap: 2px;
  transition: background .15s, border-color .15s, box-shadow .15s;
  cursor: pointer;
  font-family: inherit;
  position: relative;
}

.ps-key-spec:hover {
  background: var(--psa-bg);
  border-color: var(--psa-accent);
  box-shadow: 0 2px 10px rgba(0,166,226,.13);
}

.ps-key-spec:focus-visible {
  outline: 2px solid var(--psa-accent);
  outline-offset: 2px;
}

.ps-key-spec::after {
  content: '›';
  position: absolute;
  bottom: 4px;
  right: 6px;
  font-size: .65rem;
  color: var(--psa-muted);
  line-height: 1;
  opacity: 0;
  transition: opacity .15s;
}

.ps-key-spec:hover::after { opacity: 1; }

.ps-key-spec-icon {
  font-size: 1.4rem;
  line-height: 1;
}

.ps-key-spec-value {
  font-size: .92rem;
  font-weight: 700;
  color: var(--psa-text);
  line-height: 1.2;
}

.ps-key-spec-label {
  font-size: .72rem;
  color: var(--psa-muted);
  text-transform: uppercase;
  letter-spacing: .04em;
}


/* ════════════════════════════════════════════════════════════
   NOTE PILL  (replaces asterisk in spec table)
   ════════════════════════════════════════════════════════════ */

.ps-spec-note-pill {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 18px;
  height: 18px;
  background: var(--psa-accent);
  color: #fff;
  border-radius: 50%;
  font-size: .7rem;
  cursor: help;
  margin-left: 4px;
  vertical-align: middle;
}


/* ════════════════════════════════════════════════════════════
   PRODUCT COMPARE TAB
   ════════════════════════════════════════════════════════════ */

.ps-product-compare-tab {
  padding: 20px 0;
}

.ps-pct-intro {
  font-size: .9rem;
  color: var(--psa-muted);
  margin-bottom: 16px;
}

.ps-pct-selectors {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
  align-items: center;
  margin-bottom: 16px;
}

.ps-pct-locked {
  display: flex;
  flex-direction: column;
  padding: 10px 16px;
  background: linear-gradient(135deg, #0B2545 0%, #1B6CA8 100%);
  color: #fff;
  border-radius: 8px;
  min-width: 160px;
  box-shadow: 0 2px 8px rgba(0,85,165,.2);
}

.ps-pct-locked-label {
  font-size: .68rem;
  opacity: .75;
  text-transform: uppercase;
  letter-spacing: .06em;
  font-weight: 600;
}

.ps-pct-locked-name {
  font-size: .9rem;
  font-weight: 700;
  margin-top: 3px;
  line-height: 1.3;
}

.ps-product-compare-tab .ps-compare-slot {
  flex: 1;
  min-width: 160px;
  max-width: 240px;
}


/* ════════════════════════════════════════════════════════════
   PRODUCT AI TAB
   ════════════════════════════════════════════════════════════ */

.ps-product-ai-tab {
  padding: 20px 0;
}

.ps-product-ai-intro {
  margin-bottom: 16px;
  padding: 12px 16px;
  background: var(--psa-bg);
  border-left: 3px solid var(--psa-primary);
  border-radius: 0 8px 8px 0;
  font-size: .9rem;
}


/* ════════════════════════════════════════════════════════════
   SHOP COMPARE BUTTON
   ════════════════════════════════════════════════════════════ */

.ps-shop-compare-btn {
  display: block;
  width: 100%;
  margin-top: 8px;
  padding: 7px 0;
  background: transparent;
  border: 1px solid var(--psa-border);
  border-radius: 6px;
  font-size: .82rem;
  color: var(--psa-muted);
  cursor: pointer;
  transition: border-color .15s, color .15s, background .15s;
}

.ps-shop-compare-btn:hover {
  border-color: var(--psa-primary);
  color: var(--psa-primary);
  background: var(--psa-bg);
}

.ps-shop-compare-btn--active {
  background: var(--psa-primary);
  color: #fff;
  border-color: var(--psa-primary);
}

.ps-shop-compare-btn--active:hover {
  background: var(--psa-primary-dk);
}


/* ════════════════════════════════════════════════════════════
   COMPARE TRAY  (fixed bottom bar)
   ════════════════════════════════════════════════════════════ */

#ps-compare-tray {
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  z-index: 9990;
  background: linear-gradient(135deg, #0a1929 0%, #0d2b4e 100%);
  color: #fff;
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 12px 24px;
  box-shadow: 0 -4px 24px rgba(0,0,0,.3);
  animation: psTraySlideUp .25s ease;
  border-top: 1px solid rgba(255,255,255,.08);
}

@keyframes psTraySlideUp {
  from { transform: translateY(100%); }
  to   { transform: translateY(0); }
}

.ps-tray-chips {
  flex: 1;
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  align-items: center;
}

.ps-tray-chip {
  display: flex;
  align-items: center;
  gap: 6px;
  background: rgba(255,255,255,.15);
  border-radius: 20px;
  padding: 4px 12px;
  font-size: .85rem;
}

.ps-tray-chip-remove {
  background: none;
  border: none;
  color: #fff;
  cursor: pointer;
  font-size: 1rem;
  line-height: 1;
  opacity: .7;
  padding: 0;
}

.ps-tray-chip-remove:hover { opacity: 1; }

.ps-tray-actions {
  display: flex;
  gap: 8px;
  flex-shrink: 0;
}

#ps-tray-compare-btn {
  background: var(--psa-accent);
  color: #fff;
  border: none;
  border-radius: 7px;
  padding: 8px 20px;
  font-size: .88rem;
  font-weight: 700;
  cursor: pointer;
  transition: background .15s, box-shadow .15s;
  letter-spacing: .01em;
}

#ps-tray-compare-btn:not(:disabled):hover {
  background: #008cc3;
  box-shadow: 0 2px 10px rgba(0,166,226,.35);
}

#ps-tray-compare-btn:disabled {
  opacity: .35;
  cursor: not-allowed;
}

#ps-tray-clear-btn {
  background: rgba(255,255,255,.1);
  color: rgba(255,255,255,.8);
  border: 1px solid rgba(255,255,255,.15);
  border-radius: 7px;
  padding: 7px 14px;
  font-size: .85rem;
  cursor: pointer;
  transition: background .15s;
}

#ps-tray-clear-btn:hover {
  background: rgba(255,255,255,.18);
  color: #fff;
}

#ps-tray-close-btn {
  background: rgba(255,255,255,.08);
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 6px;
  color: rgba(255,255,255,.7);
  font-size: 1rem;
  width: 30px;
  height: 30px;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: background .15s, color .15s;
}

#ps-tray-close-btn:hover { background: rgba(255,255,255,.18); color: #fff; }


/* ════════════════════════════════════════════════════════════
   COMPARE MODAL  (full-screen overlay)
   ════════════════════════════════════════════════════════════ */

#ps-compare-modal {
  position: fixed;
  inset: 0;
  z-index: 10000;
  display: flex;
  align-items: flex-start;
  justify-content: center;
  padding: 20px;
}

.ps-modal-backdrop {
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,.6);
  backdrop-filter: blur(2px);
}

.ps-modal-content {
  position: relative;
  background: #fff;
  border-radius: var(--psa-radius);
  width: 100%;
  max-width: 1100px;
  max-height: 90vh;
  overflow-y: auto;
  display: flex;
  flex-direction: column;
  animation: psModalIn .2s ease;
}

@keyframes psModalIn {
  from { transform: scale(.95); opacity: 0; }
  to   { transform: scale(1);   opacity: 1; }
}

.ps-modal-header {
  position: sticky;
  top: 0;
  background: linear-gradient(135deg, #0B2545 0%, #1B6CA8 100%);
  border-bottom: none;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 16px 24px;
  z-index: 1;
}

.ps-modal-title {
  font-size: 1.1rem;
  font-weight: 700;
  margin: 0;
  color: #fff;
  display: flex;
  align-items: center;
  gap: 8px;
}

.ps-modal-title::before {
  content: '⇆';
  opacity: .8;
  font-size: 1rem;
}

.ps-modal-close {
  background: rgba(255,255,255,.15);
  border: 1px solid rgba(255,255,255,.25);
  border-radius: 6px;
  color: #fff;
  font-size: 1rem;
  width: 30px;
  height: 30px;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: background .15s;
  flex-shrink: 0;
}

.ps-modal-close:hover { background: rgba(255,255,255,.28); }

.ps-modal-toolbar {
  padding: 10px 20px;
  border-bottom: 1px solid var(--psa-border);
  display: flex;
  gap: 10px;
  align-items: center;
  flex-wrap: wrap;
  background: #fafbfd;
}

.ps-modal-toolbar .ps-cmp-action-group { margin-left: auto; }

.ps-modal-table-wrap {
  padding: 20px 24px 28px;
}

body.ps-modal-open {
  overflow: hidden;
}


/* ════════════════════════════════════════════════════════════
   SPEC DETAIL MODAL
   ════════════════════════════════════════════════════════════ */

#ps-spec-detail-modal[hidden] { display: none !important; }

#ps-spec-detail-modal {
  position: fixed;
  inset: 0;
  z-index: 100001;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 20px;
}

.ps-sdm__backdrop {
  position: absolute;
  inset: 0;
  background: rgba(11,37,69,.62);
  backdrop-filter: blur(3px);
}

.ps-sdm__box {
  position: relative;
  background: #fff;
  border-radius: 14px;
  width: 100%;
  max-width: 500px;
  max-height: 85vh;
  overflow-y: auto;
  box-shadow: 0 28px 72px rgba(0,0,0,.28);
  animation: ps-sdm-in .2s ease;
}

@keyframes ps-sdm-in {
  from { opacity:0; transform: scale(.95) translateY(-10px); }
  to   { opacity:1; transform: scale(1)   translateY(0); }
}

.ps-sdm__header {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 20px 20px 16px;
  border-bottom: 1px solid var(--psa-border);
  position: sticky;
  top: 0;
  background: #fff;
  z-index: 1;
}

.ps-sdm__icon {
  font-size: 1.9rem;
  line-height: 1;
  flex-shrink: 0;
  width: 52px;
  height: 52px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--psa-bg);
  border: 1px solid var(--psa-border);
  border-radius: 12px;
}

.ps-sdm__header-text { flex: 1; min-width: 0; }

.ps-sdm__title {
  font-size: 1.1rem;
  font-weight: 700;
  color: var(--psa-text);
  margin: 0 0 5px;
  line-height: 1.2;
}

.ps-sdm__section-tag {
  display: inline-block;
  font-size: .69rem;
  font-weight: 700;
  color: var(--psa-primary);
  text-transform: uppercase;
  letter-spacing: .07em;
  background: #e8f0fb;
  padding: 2px 9px;
  border-radius: 20px;
}

.ps-sdm__close {
  background: none;
  border: none;
  color: var(--psa-muted);
  font-size: 1.5rem;
  line-height: 1;
  cursor: pointer;
  padding: 4px 6px;
  border-radius: 6px;
  transition: background .15s, color .15s;
  flex-shrink: 0;
}

.ps-sdm__close:hover { background: #f1f5f9; color: var(--psa-text); }

.ps-sdm__body { padding: 20px; }

.ps-sdm__main-value-wrap {
  background: linear-gradient(135deg, var(--psa-primary) 0%, var(--psa-accent) 100%);
  border-radius: 10px;
  padding: 18px 22px;
  margin-bottom: 18px;
}

.ps-sdm__main-value {
  font-size: 1.55rem;
  font-weight: 700;
  color: #fff;
  line-height: 1.25;
  word-break: break-word;
}

.ps-sdm__note {
  display: flex;
  align-items: flex-start;
  gap: 8px;
  font-size: .875rem;
  color: #7c5c00;
  background: #fffbe6;
  border: 1px solid #fde68a;
  border-radius: 8px;
  padding: 10px 14px;
  margin: 0 0 18px;
  line-height: 1.5;
}

.ps-sdm__note::before { content: 'ℹ️'; flex-shrink: 0; }

.ps-sdm__related-title {
  font-size: .72rem;
  font-weight: 700;
  color: var(--psa-muted);
  text-transform: uppercase;
  letter-spacing: .07em;
  margin: 0 0 10px;
}

.ps-sdm__related-table {
  width: 100%;
  border-collapse: collapse;
  font-size: .875rem;
}

.ps-sdm__related-table tr { border-bottom: 1px solid var(--psa-border); }
.ps-sdm__related-table tr:last-child { border-bottom: none; }

.ps-sdm__related-table th {
  width: 52%;
  font-weight: 500;
  color: var(--psa-muted);
  text-align: left;
  padding: 8px 10px 8px 0;
  vertical-align: top;
}

.ps-sdm__related-table td {
  font-weight: 600;
  color: var(--psa-text);
  text-align: right;
  padding: 8px 0;
  vertical-align: top;
}

.ps-sdm__note-tag {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 15px;
  height: 15px;
  background: var(--psa-accent);
  color: #fff;
  border-radius: 50%;
  font-size: .62rem;
  font-weight: 700;
  margin-left: 4px;
  cursor: help;
  vertical-align: middle;
  text-decoration: none;
}


/* ── E-post form inside modal ────────────────────────── */
#ps-compare-modal .ps-cmp-email-form {
  border-top: none;
  border-bottom: 1px solid var(--psa-border);
}

#ps-compare-modal .ps-cmp-email-inner {
  padding: 10px 24px;
}

/* ── Brand header (logo + compare label + date) ── */
.ps-cmp-brand-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 10px 16px 14px;
  margin-bottom: 18px;
  border: 1px solid var(--psa-border);
  border-radius: 8px;
  background: #fff;
  position: relative;
  overflow: hidden;
}

/* Northcom gradient stripe at the bottom of the header */
.ps-cmp-brand-header::after {
  content: '';
  position: absolute;
  bottom: 0; left: 0; right: 0;
  height: 3px;
  background: linear-gradient(to right, #0B2545 0%, #1B6CA8 50%, #00B4D8 100%);
  pointer-events: none;
}

.ps-cmp-brand-left {
  display: flex;
  align-items: center;
  gap: 10px;
}

.ps-cmp-brand-divider {
  display: inline-block;
  width: 1px;
  height: 20px;
  background: var(--psa-border);
  flex-shrink: 0;
}

.ps-cmp-brand-tagline {
  font-size: .72rem;
  font-weight: 600;
  color: var(--psa-muted);
  text-transform: uppercase;
  letter-spacing: .07em;
  white-space: nowrap;
}

.ps-cmp-brand-right {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 1px;
}

.ps-cmp-brand-date {
  font-size: .78rem;
  font-weight: 600;
  color: var(--psa-text);
  white-space: nowrap;
}

.ps-cmp-brand-count {
  font-size: .68rem;
  color: var(--psa-muted);
  white-space: nowrap;
}

.ps-cmp-brand-logo {
  height: 28px;
  width: auto;
  display: block;
}

.ps-cmp-brand-wordmark {
  font-size: 1rem;
  font-weight: 700;
  color: var(--psa-primary);
  letter-spacing: -.01em;
}

.ps-cmp-brand-meta {
  font-size: .75rem;
  color: var(--psa-muted);
  letter-spacing: .02em;
  white-space: nowrap;
}


/* ════════════════════════════════════════════════════════════
   PRINT
   ════════════════════════════════════════════════════════════ */

@media print {

  /*
   * Force background colours AND pseudo-element backgrounds to print.
   * Without ::before/::after, the coloured top-strips on header cards disappear.
   */
  *, *::before, *::after {
    -webkit-print-color-adjust: exact !important;
    print-color-adjust: exact !important;
    /* Strip decorative shadows so the renderer doesn't produce blotchy output */
    box-shadow: none !important;
    text-shadow: none !important;
  }

  /* Restore the only functional shadow: the diff-row left accent bar */
  .ps-compare-table tr.ps-cmp-differs th {
    box-shadow: inset 3px 0 0 rgba(0,85,165,.3) !important;
  }

  /* Hide every screen-only control */
  .ps-cmp-action-group,
  .ps-cmp-email-form,
  .ps-compare-selectors,
  .ps-compare-run,
  .ps-compare-loading,
  .ps-compare-diff-chk,
  label[for*="diff"],
  #ps-compare-tray,
  .ps-fab-advisor,
  .ps-tray-actions { display: none !important; }

  /* Flatten modal chrome so only the compare content remains */
  #ps-compare-modal {
    position: static !important;
    background: none !important;
    padding: 0 !important;
    display: block !important;
  }
  .ps-modal-content {
    max-height: none !important;
    border-radius: 0 !important;
    overflow: visible !important;
    width: 100% !important;
  }
  .ps-modal-header,
  .ps-modal-toolbar { display: none !important; }
  .ps-modal-table-wrap { padding: 0 !important; overflow: visible !important; }

  /* Table wrap — no clipping/scrollbars */
  .ps-compare-table-wrap { overflow: visible !important; }

  /* Prevent sections from splitting across pages */
  .ps-compare-section   { page-break-inside: avoid; break-inside: avoid; margin-bottom: 14px; }
  .ps-compare-table tbody tr { page-break-inside: avoid; break-inside: avoid; }
  .ps-cmp-header-cards  { page-break-after: avoid; break-after: avoid; }
  .ps-cmp-brand-header  { page-break-after: avoid; break-after: avoid; }

  /* Slightly larger logo for print legibility */
  .ps-cmp-brand-logo { height: 34px; }

  /* Solid fallback for glass panel — backdrop-filter not reliable in PDF renderers */
  .ps-cmp-card-glass {
    background: rgba(255,255,255,.92) !important;
    backdrop-filter: none !important;
    -webkit-backdrop-filter: none !important;
  }
}


/* ════════════════════════════════════════════════════════════
   STICKY PRODUCT NAME BAR
   Appears when header cards scroll off screen (JS-toggled via
   .ps-cmp-sticky-bar--visible). Rendered as a sibling of
   .ps-compare-table-wrap so it escapes the overflow-x context.
   ════════════════════════════════════════════════════════════ */

.ps-cmp-sticky-bar {
  position: sticky;
  top: 0;
  z-index: 12;
  display: flex;
  align-items: stretch;
  background: rgba(255,255,255,.97);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border: 1px solid var(--psa-border);
  border-radius: 10px;
  box-shadow: 0 3px 16px rgba(0,0,0,.1);
  margin-bottom: 16px;
  overflow: hidden;
  opacity: 0;
  transform: translateY(-6px);
  pointer-events: none;
  transition: opacity .2s ease, transform .2s ease;
}

.ps-cmp-sticky-bar--visible {
  opacity: 1;
  transform: translateY(0);
  pointer-events: auto;
}

.ps-cmp-sticky-spacer {
  flex-shrink: 0;
  width: 28%;
  padding: 8px 12px 8px 16px;
  background: #fafbfd;
  border-right: 1px solid var(--psa-border);
  display: flex;
  align-items: center;
  font-size: .65rem;
  font-weight: 700;
  color: var(--psa-muted);
  text-transform: uppercase;
  letter-spacing: .07em;
  white-space: nowrap;
}

.ps-cmp-sticky-col {
  flex: 1;
  min-width: 0;
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 8px 10px;
  border-right: 1px solid var(--psa-border);
  overflow: hidden;
}

.ps-cmp-sticky-col:last-child { border-right: none; }

.ps-cmp-sticky-thumb {
  width: 30px;
  height: 30px;
  object-fit: contain;
  flex-shrink: 0;
  background: #f0f4f8;
  border-radius: 5px;
  padding: 3px;
}

.ps-cmp-sticky-name {
  font-size: .8rem;
  font-weight: 700;
  color: #0B2545;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  flex: 1;
  min-width: 0;
  line-height: 1.25;
}

@media (max-width: 600px) {
  .ps-cmp-sticky-bar { border-radius: 0; border-left: none; border-right: none; margin: 0 -8px 12px; }
  .ps-cmp-sticky-spacer { display: none; }
  .ps-cmp-sticky-thumb { width: 24px; height: 24px; }
  .ps-cmp-sticky-name { font-size: .72rem; }
  .ps-cmp-brand-tagline,
  .ps-cmp-brand-divider { display: none; }
}


/* ════════════════════════════════════════════════════════════
   SEARCHABLE SELECT COMPONENT  (.ps-sbox)
   Activates on non-touch (desktop) only. Native <select> is
   kept hidden as backing store and stays accessible.
   ════════════════════════════════════════════════════════════ */

.ps-sbox {
  position: relative;
  flex: 1;
  min-width: 0;
  display: grid;
}

/* The native select is hidden on desktop but remains in the DOM */
.ps-sbox__native {
  position: absolute !important;
  width: 1px !important;
  height: 1px !important;
  top: 0;
  left: 0;
  opacity: 0 !important;
  pointer-events: none !important;
  overflow: hidden !important;
}

/* Trigger button — looks like a styled select */
.ps-sbox__trigger {
  grid-row: 1;
  grid-column: 1;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  width: 100%;
  padding: 10px 38px 10px 13px;
  border: 1.5px solid #dde6f5;
  border-radius: 10px;
  font-size: .88rem;
  font-family: inherit;
  background: #fafbfd;
  color: var(--psa-text);
  cursor: pointer;
  text-align: left;
  transition: border-color .15s, box-shadow .15s, background .15s;
  line-height: 1.4;
  position: relative;
}

.ps-sbox__trigger::after {
  content: '';
  position: absolute;
  right: 12px;
  top: 50%;
  transform: translateY(-50%);
  width: 14px;
  height: 14px;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%2364748b' stroke-width='2.5'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: center;
  transition: transform .18s;
  pointer-events: none;
}

.ps-sbox[aria-expanded="true"] .ps-sbox__trigger::after {
  transform: translateY(-50%) rotate(180deg);
}

.ps-sbox__trigger:hover {
  border-color: rgba(0,85,165,.4);
  background: #fff;
}

.ps-sbox__trigger:focus {
  outline: none;
  border-color: var(--psa-accent);
  box-shadow: 0 0 0 3px rgba(0,166,226,.14);
  background: #fff;
}

.ps-sbox__value {
  flex: 1;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  color: var(--psa-muted);
  font-style: italic;
}

.ps-sbox__trigger--has-value .ps-sbox__value {
  color: var(--psa-text);
  font-style: normal;
}

/* Dropdown panel */
.ps-sbox__panel {
  position: absolute;
  left: 0;
  right: auto;
  top: calc(100% + 5px);
  z-index: 300;
  background: #fff;
  border: 1.5px solid #dde6f5;
  border-radius: 10px;
  box-shadow: 0 10px 36px rgba(0,0,0,.16);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  max-height: 300px;
  width: max-content;
  min-width: max(100%, 280px);
  max-width: 360px;
  animation: psSboxIn .14s ease;
}

.ps-sbox__panel--up {
  top: auto;
  bottom: calc(100% + 5px);
  animation: psSboxInUp .14s ease;
}

@keyframes psSboxIn   { from { opacity: 0; transform: translateY(-8px); } to { opacity: 1; transform: translateY(0); } }
@keyframes psSboxInUp { from { opacity: 0; transform: translateY(8px);  } to { opacity: 1; transform: translateY(0); } }

/* Search input inside dropdown */
.ps-sbox__search-wrap {
  flex-shrink: 0;
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 8px 10px;
  border-bottom: 1px solid var(--psa-border);
  background: #fafbfd;
}

.ps-sbox__search-icon {
  color: var(--psa-muted);
  flex-shrink: 0;
}

.ps-sbox__search {
  flex: 1;
  border: none;
  background: transparent;
  font-size: .86rem;
  font-family: inherit;
  color: var(--psa-text);
  padding: 0;
}

.ps-sbox__search:focus { outline: none; }
.ps-sbox__search::placeholder { color: #94a3b8; font-style: italic; }

.ps-sbox__count {
  flex-shrink: 0;
  font-size: .68rem;
  color: #94a3b8;
  white-space: nowrap;
  padding: 2px 6px;
  background: var(--psa-bg);
  border-radius: 999px;
}

/* Options list */
.ps-sbox__list {
  flex: 1;
  overflow-y: auto;
  list-style: none;
  margin: 0;
  padding: 4px 0;
  overscroll-behavior: contain;
}

.ps-sbox__group {
  font-size: .67rem;
  font-weight: 700;
  color: var(--psa-muted);
  text-transform: uppercase;
  letter-spacing: .07em;
  padding: 8px 12px 3px;
  pointer-events: none;
}

.ps-sbox__item {
  padding: 7px 12px;
  font-size: .86rem;
  cursor: pointer;
  color: var(--psa-text);
  transition: background .1s, color .1s;
  line-height: 1.35;
  display: flex;
  align-items: center;
  gap: 8px;
}

.ps-sbox__item:hover,
.ps-sbox__item--focused {
  background: var(--psa-bg);
  color: var(--psa-primary);
}

.ps-sbox__item--selected {
  font-weight: 600;
  color: var(--psa-primary);
  background: rgba(27,108,168,.06);
}

.ps-sbox__item--selected::before {
  content: '✓';
  font-size: .78rem;
  color: var(--psa-primary);
  flex-shrink: 0;
  margin-right: 0;
}

.ps-sbox__empty {
  padding: 16px 12px;
  font-size: .84rem;
  color: var(--psa-muted);
  font-style: italic;
  text-align: center;
}

/* Clear "×" — overlaid in the same grid cell as the trigger, centered by grid alignment */
.ps-sbox__clear {
  grid-row: 1;
  grid-column: 1;
  align-self: center;
  justify-self: start;
  margin-left: 10px;
  width: 18px;
  height: 18px;
  background: none;
  border: none;
  border-radius: 50%;
  font-size: .8rem;
  line-height: 1;
  text-align: center;
  cursor: pointer;
  color: #94a3b8;
  padding: 0;
  display: none;
  align-items: center;
  justify-content: center;
  z-index: 2;
  transition: color .12s;
}

.ps-sbox__trigger--has-value ~ .ps-sbox__clear,
.ps-sbox__trigger--has-value + .ps-sbox__clear {
  display: flex;
}

.ps-sbox__clear:hover { color: #dc2626; background: none; }

/* Shift trigger text right to make room for the × on the left */
.ps-sbox__trigger--has-value {
  padding-left: 32px;
}

/* When the searchable widget is active in a slot, the native slot-clear button
   is redundant — the sbox has its own ×. Hide the outer one. */
.ps-compare-slot:has(.ps-sbox) > .ps-compare-slot-clear { display: none !important; }

/* ════════════════════════════════════════════════════════════
   DIFF TOGGLE — custom pill switch
   Applied to both the inline widget and the compare page.
   ════════════════════════════════════════════════════════════ */

.ps-compare-diff-toggle {
  display: inline-flex !important;
  align-items: center !important;
  gap: 9px !important;
  line-height: 1 !important;
}

.ps-compare-diff-toggle span {
  line-height: 1.3;
}

.ps-compare-diff-toggle input[type="checkbox"] {
  -webkit-appearance: none;
  appearance: none;
  width: 34px;
  height: 20px;
  border-radius: 10px;
  background: #d1d5db;
  border: none !important;
  outline: none;
  cursor: pointer;
  flex-shrink: 0;
  position: relative;
  transition: background .2s;
  margin: 0 !important;
  padding: 0 !important;
  display: block !important;
}

.ps-compare-diff-toggle input[type="checkbox"]::before {
  content: '';
  position: absolute;
  width: 14px;
  height: 14px;
  border-radius: 50%;
  background: #fff;
  top: 3px;
  left: 3px;
  transition: transform .2s cubic-bezier(.4,0,.2,1);
  box-shadow: 0 1px 4px rgba(0,0,0,.25);
}

.ps-compare-diff-toggle input[type="checkbox"]:checked {
  background: var(--psa-primary);
}

.ps-compare-diff-toggle input[type="checkbox"]:checked::before {
  transform: translateX(14px);
}

.ps-compare-diff-toggle input[type="checkbox"]:focus-visible {
  box-shadow: 0 0 0 3px rgba(0,85,165,.22);
}

/* Scroll-fade hint on right edge of table wrap (mobile) */
.ps-compare-section {
  position: relative;
}

@media (max-width: 640px) {
  .ps-compare-table-wrap {
    position: relative;
  }
  .ps-compare-table-wrap::after {
    content: '';
    position: sticky;
    right: 0;
    bottom: 0;
    width: 24px;
    align-self: stretch;
    background: linear-gradient(to left, rgba(255,255,255,.95), transparent);
    pointer-events: none;
    flex-shrink: 0;
  }
}

/* ── Responsive ─────────────────────────────────────────── */

@media (max-width: 600px) {
  .ps-fab-panel { width: calc(100vw - 20px); right: 10px; }
  .ps-fab-advisor { bottom: 16px; right: 16px; }
  .ps-fab-btn .ps-fab-label { display: none; }
  .ps-compare-selectors { grid-template-columns: 1fr; }
  .ps-specs-meta-row { flex-direction: column; }
  .ps-pct-selectors { flex-direction: column; }
  .ps-pct-locked { min-width: unset; }
  .ps-product-compare-tab .ps-compare-slot { max-width: unset; }
  #ps-compare-tray { flex-direction: column; align-items: flex-start; gap: 8px; padding: 10px 16px; }
  .ps-tray-chips { min-width: 0; }
  .ps-tray-chip { font-size: .8rem; }
  .ps-tray-actions { width: 100%; justify-content: flex-start; }
  #ps-compare-modal { padding: 0; align-items: flex-end; }
  .ps-modal-content { max-height: 95vh; border-radius: var(--psa-radius) var(--psa-radius) 0 0; max-width: 100%; }
  .ps-modal-toolbar { padding: 10px 14px; }
  #ps-compare-modal .ps-cmp-email-inner { padding: 10px 14px; }
  .ps-modal-table-wrap { padding: 12px 14px 20px; }
  .ps-cmp-header-spacer { display: none; }
  .ps-cmp-header-cards { overflow-x: auto; }
  .ps-cmp-header-card { min-width: 120px; height: 155px; }
  .ps-cmp-card-glass { min-height: 54px; padding: 7px 9px 8px; }
  .ps-cmp-email-inner { flex-direction: column; align-items: stretch; }
  .ps-cmp-email-input, .ps-cmp-email-subject { min-width: unset; }
  .ps-cmp-action-group { justify-content: flex-start; }
  .ps-key-specs-bar { gap: 6px; }
  .ps-key-spec { min-width: 76px; padding: 8px 10px; }
  #ps-spec-detail-modal { padding: 0; align-items: flex-end; }
  .ps-sdm__box { border-radius: 14px 14px 0 0; max-width: 100%; max-height: 90vh; }

  /* Compact compare table on mobile */
  .ps-compare-table th,
  .ps-compare-table td {
    padding: 8px 10px !important;
    font-size: .8rem;
  }
  .ps-compare-table th {
    padding-left: 12px !important;
    min-width: 100px;
    max-width: 130px;
    width: 24% !important;
  }
  .ps-compare-section-title {
    font-size: .7rem;
    padding: 8px 12px 8px 14px;
  }
  .ps-cmp-header-card { min-width: 120px; }
}


/* ════════════════════════════════════════════════════════════
   SHAREABLE COMPARE PAGE  [peplink_compare_page shortcode]
   ════════════════════════════════════════════════════════════ */

.ps-compare-page {
  font-family: inherit;
  color: var(--psa-text);
  margin: 0 calc(-1 * var(--ps-page-bleed, 0px));
}

/* ── Hero banner ─────────────────────────────────────────── */

.ps-cmp-pg-hero {
  background: linear-gradient(145deg, #0B2545 0%, #1B6CA8 55%, #00B4D8 100%);
  padding: 60px 24px 80px;
  text-align: center;
  position: relative;
  overflow: hidden;
}

/* Subtle grid overlay */
.ps-cmp-pg-hero::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(255,255,255,.055) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.055) 1px, transparent 1px);
  background-size: 42px 42px;
  pointer-events: none;
}

/* Cyan glow at centre */
.ps-cmp-pg-hero::after {
  content: '';
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 700px;
  height: 320px;
  background: radial-gradient(ellipse, rgba(0,166,226,.22) 0%, transparent 68%);
  pointer-events: none;
}

.ps-cmp-pg-hero-inner {
  position: relative;
  z-index: 1;
  max-width: 660px;
  margin: 0 auto;
}

.ps-cmp-pg-logo {
  height: 30px;
  width: auto;
  display: block;
  margin: 0 auto 22px;
  filter: brightness(0) invert(1);
  opacity: .9;
}

.ps-cmp-pg-title {
  font-size: clamp(1.65rem, 4vw, 2.5rem);
  font-weight: 700;
  color: #fff;
  margin: 0 0 14px;
  letter-spacing: -.025em;
  line-height: 1.12;
  text-shadow: 0 2px 16px rgba(0,0,0,.25);
}

.ps-cmp-pg-sub {
  font-size: clamp(.9rem, 2vw, 1.05rem);
  color: rgba(255,255,255,.74);
  margin: 0;
  line-height: 1.65;
}

/* ── Selector card ───────────────────────────────────────── */

.ps-cmp-pg-card {
  background: #fff;
  border: 1px solid var(--psa-border);
  border-radius: 18px;
  padding: 30px 30px 22px;
  box-shadow: 0 16px 56px rgba(0,0,0,.14);
  position: relative;
  z-index: 2;
  max-width: 1060px;
  margin: -44px auto 32px;
}

/* Filter row: type pills on the left, diff-toggle pinned right */
.ps-cmp-filter-row {
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
  margin-bottom: 22px;
}

.ps-cmp-filter-row .ps-compare-diff-toggle {
  margin-left: auto;
  flex-shrink: 0;
  white-space: nowrap;
}

/* Type filter pills */
.ps-cmp-type-pills {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}

.ps-cmp-type-pill {
  padding: 5px 18px;
  background: #f1f5f9;
  color: var(--psa-muted);
  border: 1.5px solid #e2e8f0;
  border-radius: 99px;
  font-size: .8rem;
  font-weight: 600;
  cursor: pointer;
  transition: all .15s;
  line-height: 1.5;
}

.ps-cmp-type-pill:hover {
  background: var(--psa-bg);
  border-color: rgba(0,85,165,.4);
  color: var(--psa-primary);
}

.ps-cmp-type-pill--active {
  background: var(--psa-primary);
  color: #fff;
  border-color: var(--psa-primary);
}

/* 4-column selector grid */
.ps-compare-page .ps-compare-selectors {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 14px;
  margin-bottom: 22px;
}

/* Slot: label above, select below */
.ps-compare-page .ps-compare-slot {
  display: flex;
  flex-direction: column;
  gap: 5px;
  position: relative;
}

/* Auto-generated slot labels via CSS */
.ps-compare-page .ps-compare-slot::before {
  font-size: .68rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .075em;
}

.ps-compare-page .ps-compare-slot[data-slot="0"]::before { content: 'Produkt 1'; color: var(--psa-primary); }
.ps-compare-page .ps-compare-slot[data-slot="1"]::before { content: 'Produkt 2'; color: var(--psa-primary); }
.ps-compare-page .ps-compare-slot[data-slot="2"]::before { content: 'Produkt 3  ·  valgfritt'; color: #94a3b8; }
.ps-compare-page .ps-compare-slot[data-slot="3"]::before { content: 'Produkt 4  ·  valgfritt'; color: #94a3b8; }

/* Custom dropdown */
.ps-compare-page .ps-compare-select {
  width: 100%;
  padding: 10px 38px 10px 13px;
  border: 1.5px solid #dde6f5;
  border-radius: 10px;
  font-size: .88rem;
  background: #fafbfd;
  color: var(--psa-text);
  cursor: pointer;
  appearance: none;
  -webkit-appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%2364748b' stroke-width='2.5'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 11px center;
  transition: border-color .15s, box-shadow .15s, background .15s;
}

.ps-compare-page .ps-compare-select:focus {
  outline: none;
  border-color: var(--psa-accent);
  box-shadow: 0 0 0 3px rgba(0,166,226,.14);
  background-color: #fff;
}

/* Clear "×" button — small circle inside the slot, shown via JS */
.ps-compare-page .ps-compare-slot-clear {
  position: absolute;
  right: 32px;
  bottom: 9px;
  width: 19px;
  height: 19px;
  background: #dde6f5;
  border: none;
  border-radius: 50%;
  font-size: .72rem;
  line-height: 19px;
  text-align: center;
  cursor: pointer;
  color: #64748b;
  padding: 0;
  transition: background .12s, color .12s;
  z-index: 1;
}

.ps-compare-page .ps-compare-slot-clear:hover {
  background: #fee2e2;
  color: #dc2626;
}

.ps-compare-page .ps-compare-diff-toggle {
  display: inline-flex;
  align-items: center;
  gap: 9px;
  font-size: .88rem;
  color: var(--psa-muted);
  cursor: pointer;
  user-select: none;
  line-height: 1;
}

.ps-compare-page .ps-compare-diff-toggle span {
  display: inline;
  line-height: 1.2;
  vertical-align: middle;
}

/* ── Share bar ───────────────────────────────────────────── */

.ps-cmp-share-bar {
  max-width: 1060px;
  margin: 0 auto 28px;
  background: linear-gradient(135deg, #eef5ff 0%, #f6f9fd 100%);
  border: 1.5px solid #c2d8f2;
  border-radius: 14px;
  padding: 16px 20px;
  display: flex;
  align-items: center;
  gap: 14px;
  flex-wrap: wrap;
  box-shadow: 0 2px 12px rgba(0,85,165,.07);
}

.ps-cmp-share-left {
  display: flex;
  align-items: center;
  gap: 12px;
  flex: 1;
  min-width: 0;
}

.ps-cmp-share-icon {
  color: var(--psa-primary);
  flex-shrink: 0;
  opacity: .65;
}

.ps-cmp-share-text {
  display: flex;
  flex-direction: column;
  gap: 3px;
  flex: 1;
  min-width: 0;
}

.ps-cmp-share-label {
  font-size: .68rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .09em;
  color: var(--psa-primary);
}

.ps-cmp-share-url {
  width: 100%;
  padding: 6px 10px;
  border: 1px solid #ccdaec;
  border-radius: 7px;
  background: rgba(255,255,255,.85);
  font-size: .77rem;
  color: var(--psa-muted);
  font-family: 'SF Mono', 'Cascadia Code', 'Fira Code', Consolas, monospace;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  cursor: text;
  transition: border-color .15s;
}

.ps-cmp-share-url:focus { outline: none; border-color: var(--psa-accent); }

.ps-cmp-share-actions {
  display: flex;
  gap: 8px;
  flex-shrink: 0;
  flex-wrap: wrap;
  align-items: center;
}

/* Copy button */
.ps-cmp-copy-btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 9px 18px;
  background: var(--psa-primary);
  color: #fff;
  border: none;
  border-radius: 9px;
  font-size: .84rem;
  font-weight: 600;
  cursor: pointer;
  transition: background .15s, transform .1s;
  white-space: nowrap;
}

.ps-cmp-copy-btn:hover  { background: var(--psa-primary-dk); }
.ps-cmp-copy-btn:active { transform: scale(.97); }
.ps-cmp-copy-btn--ok   { background: #16a34a !important; transition: background .2s; }

/* Secondary action buttons (print, email) */
.ps-cmp-share-action {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 9px 16px;
  background: #fff;
  color: var(--psa-primary);
  border: 1.5px solid #c2d8f2;
  border-radius: 9px;
  font-size: .84rem;
  font-weight: 600;
  cursor: pointer;
  transition: background .15s, border-color .15s;
  white-space: nowrap;
}

.ps-cmp-share-action:hover {
  background: var(--psa-bg);
  border-color: var(--psa-primary);
}

/* ── Email form (slides under share bar) ─────────────────── */

.ps-compare-page .ps-cmp-email-form {
  max-width: 1060px;
  margin: -20px auto 28px;
  background: #fff;
  border: 1px solid var(--psa-border);
  border-radius: 0 0 12px 12px;
  border-top: none;
  overflow: hidden;
}

.ps-compare-page .ps-cmp-email-inner {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 16px 20px;
  flex-wrap: wrap;
}

.ps-compare-page .ps-cmp-email-input {
  flex: 1.5;
  min-width: 170px;
  padding: 9px 12px;
  border: 1px solid var(--psa-border);
  border-radius: 8px;
  font-size: .88rem;
  font-family: inherit;
  transition: border-color .15s;
}

.ps-compare-page .ps-cmp-email-subject {
  flex: 2;
  min-width: 150px;
  padding: 9px 12px;
  border: 1px solid var(--psa-border);
  border-radius: 8px;
  font-size: .88rem;
  font-family: inherit;
  transition: border-color .15s;
}

.ps-compare-page .ps-cmp-email-input:focus,
.ps-compare-page .ps-cmp-email-subject:focus {
  outline: none;
  border-color: var(--psa-accent);
}

.ps-compare-page .ps-cmp-email-send {
  padding: 9px 20px;
  background: var(--psa-primary);
  color: #fff;
  border: none;
  border-radius: 8px;
  font-size: .88rem;
  font-weight: 600;
  cursor: pointer;
  white-space: nowrap;
  transition: background .15s;
}

.ps-compare-page .ps-cmp-email-send:hover    { background: var(--psa-primary-dk); }
.ps-compare-page .ps-cmp-email-send:disabled { opacity: .5; cursor: not-allowed; }

.ps-compare-page .ps-cmp-email-cancel {
  background: none;
  border: 1px solid var(--psa-border);
  border-radius: 8px;
  padding: 9px 14px;
  font-size: .88rem;
  cursor: pointer;
  color: var(--psa-muted);
  transition: border-color .15s, color .15s;
}

.ps-compare-page .ps-cmp-email-cancel:hover {
  border-color: var(--psa-primary);
  color: var(--psa-primary);
}

.ps-compare-page .ps-cmp-email-msg {
  width: 100%;
  font-size: .82rem;
  margin: 0;
  padding: 0 20px 12px;
  min-height: 1.2em;
}

/* ── Results area ────────────────────────────────────────── */

.ps-compare-page .ps-compare-result {
  max-width: 1200px;
  margin: 0 auto;
}

.ps-compare-page .ps-compare-loading {
  text-align: center;
  padding: 64px 24px;
  color: var(--psa-muted);
  font-size: .92rem;
}

.ps-cmp-pg-spinner {
  width: 42px;
  height: 42px;
  border: 3px solid #dde6f4;
  border-top-color: var(--psa-primary);
  border-radius: 50%;
  animation: psCmpPgSpin .7s linear infinite;
  margin: 0 auto 18px;
}

@keyframes psCmpPgSpin { to { transform: rotate(360deg); } }

.ps-compare-page .ps-compare-table-wrap { margin-bottom: 16px; }

.ps-compare-page .ps-cmp-action-group {
  display: flex;
  justify-content: center;
  padding: 0 0 40px;
}

.ps-cmp-pg-err {
  text-align: center;
  padding: 24px 20px;
  color: #dc2626;
  background: #fef2f2;
  border: 1px solid #fecaca;
  border-radius: 10px;
  margin: 0;
}

/* Ask AI button in page action group */
.ps-compare-page .ps-compare-ask-ai {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 11px 26px;
  background: #fff;
  color: var(--psa-primary);
  border: 1.5px solid var(--psa-border);
  border-radius: 10px;
  font-size: .92rem;
  font-weight: 600;
  cursor: pointer;
  transition: background .15s, border-color .15s, box-shadow .15s;
}

.ps-compare-page .ps-compare-ask-ai:hover {
  background: var(--psa-bg);
  border-color: var(--psa-primary);
  box-shadow: 0 2px 14px rgba(0,85,165,.1);
}

/* ── Notes / comment box (in header spacer) ─────────────── */

.ps-cmp-notes-box {
  flex: 1;
  display: flex;
  flex-direction: column;
  padding: 12px 14px 14px;
  gap: 7px;
}

.ps-cmp-notes-header {
  display: flex;
  align-items: center;
  gap: 5px;
  font-size: .68rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .08em;
  color: var(--psa-primary);
  padding-bottom: 6px;
  border-bottom: 1px solid var(--psa-border);
}

/* Contenteditable note field — looks like plain paper, not a form */
.ps-cmp-notes-area {
  flex: 1;
  display: block;
  min-height: 90px;
  padding: 9px 11px;
  border-radius: 8px;
  border: 1.5px solid transparent;
  background: transparent;
  font-size: .82rem;
  font-family: inherit;
  line-height: 1.6;
  color: var(--psa-text);
  cursor: text;
  word-break: break-word;
  overflow-y: auto;
  transition: border-color .15s, background .15s, box-shadow .15s;
  -webkit-user-modify: read-write-plaintext-only;
}

.ps-cmp-notes-area:hover {
  background: rgba(255,255,255,.65);
  border-color: rgba(0,180,216,.22);
}

.ps-cmp-notes-area:focus {
  outline: none;
  background: #fff;
  border-color: var(--psa-accent);
  box-shadow: 0 0 0 3px rgba(0,180,216,.11);
}

/* Placeholder via ::before on empty contenteditable */
.ps-cmp-notes-area:empty::before {
  content: attr(data-placeholder);
  color: #94a3b8;
  font-style: italic;
  pointer-events: none;
  display: block;
}

/* Notes rendered text in print window */
.ps-cmp-notes-print {
  flex: 1;
  font-size: .82rem;
  color: var(--psa-text);
  line-height: 1.55;
  white-space: pre-wrap;
  word-break: break-word;
  padding: 9px 11px;
  background: #fff;
  border: 1px solid #dde6f5;
  border-radius: 8px;
  min-height: 90px;
}

.ps-cmp-notes-print:empty::before,
.ps-cmp-notes-print--empty {
  color: #94a3b8;
  font-style: italic;
}

@media print {
  .ps-cmp-notes-area { display: none !important; }
  .ps-cmp-notes-print { border-color: #d8e2ef !important; }
}

/* ── Compare page responsive ─────────────────────────────── */

@media (max-width: 1080px) {
  .ps-cmp-pg-card { margin-left: 16px; margin-right: 16px; }
  .ps-cmp-share-bar { margin-left: 16px; margin-right: 16px; }
  .ps-compare-page .ps-cmp-email-form { margin-left: 16px; margin-right: 16px; }
}

@media (max-width: 860px) {
  .ps-compare-page .ps-compare-selectors {
    grid-template-columns: repeat(2, 1fr);
  }

  /* Collapse action button labels to icon-only to save bar space */
  .ps-cmp-btn-label,
  .ps-cmp-copy-label {
    display: none;
  }

  .ps-cmp-copy-btn,
  .ps-cmp-share-action {
    padding: 9px 11px;
  }
}

@media (max-width: 600px) {
  .ps-cmp-pg-hero { padding: 44px 20px 64px; }

  .ps-cmp-pg-card {
    margin: -36px 12px 24px;
    padding: 22px 16px 18px;
    border-radius: 14px;
  }

  .ps-cmp-filter-row {
    gap: 10px;
  }

  .ps-compare-page .ps-compare-selectors {
    grid-template-columns: 1fr;
    gap: 10px;
  }

  .ps-cmp-share-bar {
    flex-direction: column;
    align-items: stretch;
    margin-left: 12px;
    margin-right: 12px;
    padding: 14px;
  }

  .ps-cmp-share-actions {
    flex-wrap: nowrap;
    gap: 6px;
  }

  .ps-cmp-copy-btn,
  .ps-cmp-share-action {
    flex: 1;
    justify-content: center;
    font-size: .8rem;
    padding: 8px 10px;
  }

  .ps-compare-page .ps-cmp-email-form { margin-left: 12px; margin-right: 12px; }
  .ps-compare-page .ps-cmp-email-inner { flex-direction: column; gap: 8px; }
  .ps-compare-page .ps-cmp-email-input,
  .ps-compare-page .ps-cmp-email-subject { min-width: unset; width: 100%; }
}
