/* Connections page — translated from /tmp/bzzip_design/.../connections.jsx
 * Tokens taken from shared.jsx `T` object (light theme).
 */

:root {
  --conn-primary: #0ea5e9;
  --conn-primary-hover: #0284c7;
  --conn-focus-ring: rgba(14, 165, 233, 0.15);
  --conn-bg0: #ffffff;
  --conn-bg1: #f8fafc;
  --conn-bg2: #f1f5f9;
  --conn-bg3: #e2e8f0;
  --conn-text0: #0f172a;
  --conn-text1: #334155;
  --conn-text2: #475569;
  --conn-text3: #64748b;
  --conn-text4: #94a3b8;
  --conn-success-bg: #dcfce7;
  --conn-success-border: #86efac;
  --conn-success-text: #166534;
  --conn-error-bg: #fee2e2;
  --conn-error-border: #fecaca;
  --conn-error-text: #dc2626;
  --conn-wa: #25d366;
  --conn-fb: #1877f2;
  --conn-ig-gradient: linear-gradient(45deg, #f09433, #e6683c, #dc2743, #cc2366, #bc1888);
  --conn-font: system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
  --conn-mono: ui-monospace, SFMono-Regular, "SF Mono", Menlo, Consolas, monospace;
}

.connections-page {
  font-family: var(--conn-font);
  color: var(--conn-text0);
  background: var(--conn-bg1);
  min-height: calc(100vh - 64px);
  padding: 28px 36px 60px;
}

.connections-page__inner {
  max-width: 980px;
  margin: 0 auto;
}

/* Topbar (in-page) ---------------------------------------------------- */
.connections-topbar {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 0 0 18px;
  font-size: 13px;
  color: var(--conn-text3);
}
.connections-topbar__crumb-current {
  color: var(--conn-text1);
  font-weight: 600;
}
.connections-topbar__spacer {
  flex: 1;
}
.connections-topbar__docs {
  background: #fff;
  color: var(--conn-text1);
  border: 1px solid var(--conn-bg3);
  font-size: 13px;
  font-weight: 600;
  padding: 7px 12px;
  border-radius: 10px;
  text-decoration: none;
}
.connections-topbar__docs:hover {
  background: var(--conn-bg2);
}

/* Page heading -------------------------------------------------------- */
.connections-heading {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 20px;
  flex-wrap: wrap;
}
.connections-heading__title {
  font-size: 24px;
  font-weight: 700;
  margin: 0;
  letter-spacing: -0.3px;
  color: var(--conn-text0);
}
.connections-heading__desc {
  font-size: 14px;
  color: var(--conn-text2);
  margin: 6px 0 0;
  max-width: 600px;
  line-height: 1.55;
}
.connections-heading__add {
  background: var(--conn-primary);
  color: #fff;
  border: none;
  font-family: var(--conn-font);
  font-size: 13px;
  font-weight: 600;
  padding: 10px 16px;
  border-radius: 10px;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  gap: 6px;
}
.connections-heading__add:hover {
  background: var(--conn-primary-hover);
}

/* Channel tabs -------------------------------------------------------- */
.channel-tabs {
  margin-top: 24px;
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}
.channel-tab {
  height: 48px;
  padding: 0 18px;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  border-radius: 12px;
  background: transparent;
  border: 1px solid transparent;
  color: var(--conn-text3);
  font-weight: 600;
  font-size: 14px;
  font-family: var(--conn-font);
  cursor: pointer;
  text-decoration: none;
}
.channel-tab:hover {
  background: var(--conn-bg2);
}
.channel-tab--active {
  background: #fff;
  border-color: var(--conn-primary);
  box-shadow: 0 4px 12px rgba(14, 165, 233, 0.10);
  color: var(--conn-primary);
}
.channel-tab__icon {
  width: 24px;
  height: 24px;
  border-radius: 6px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: #fff;
}
.channel-tab__icon--whatsapp { background: var(--conn-wa); }
.channel-tab__icon--facebook { background: var(--conn-fb); }
.channel-tab__icon--instagram { background: var(--conn-ig-gradient); }

/* Method segmented control ------------------------------------------- */
.method-segments {
  margin-top: 20px;
  display: inline-flex;
  padding: 4px;
  gap: 4px;
  background: var(--conn-bg2);
  border-radius: 12px;
}
.method-segment {
  padding: 8px 16px;
  border-radius: 8px;
  background: transparent;
  border: none;
  font-weight: 600;
  font-size: 13px;
  color: var(--conn-text3);
  font-family: var(--conn-font);
  cursor: pointer;
  text-decoration: none;
  line-height: 1.2;
}
.method-segment--active {
  background: #fff;
  color: var(--conn-text0);
  box-shadow: 0 1px 2px rgba(15, 23, 42, 0.08);
}

/* Quick connect panel ------------------------------------------------- */
.connections-panel {
  margin-top: 20px;
}
.quick-connect {
  background: #fff;
  border: 1px solid var(--conn-bg3);
  border-radius: 16px;
  padding: 56px 32px;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
}
.quick-connect__icon-block {
  width: 120px;
  height: 120px;
  border-radius: 28px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #fff;
}
.quick-connect__icon-block--whatsapp { background: var(--conn-wa); box-shadow: 0 12px 32px rgba(37, 211, 102, 0.30); }
.quick-connect__icon-block--facebook { background: var(--conn-fb); box-shadow: 0 12px 32px rgba(24, 119, 242, 0.30); }
.quick-connect__icon-block--instagram { background: var(--conn-ig-gradient); box-shadow: 0 12px 32px rgba(220, 39, 67, 0.30); }
.quick-connect__title {
  font-size: 24px;
  font-weight: 600;
  margin: 28px 0 0;
  letter-spacing: -0.2px;
}
.quick-connect__body {
  margin: 12px 0 0;
  max-width: 480px;
  font-size: 14px;
  color: var(--conn-text2);
  line-height: 1.55;
}
.quick-connect__cta {
  margin-top: 28px;
  background: var(--conn-primary);
  color: #fff;
  border: none;
  font-family: var(--conn-font);
  font-size: 16px;
  font-weight: 600;
  padding: 12px 24px;
  border-radius: 12px;
  width: 320px;
  max-width: 100%;
  cursor: pointer;
  box-shadow: 0 4px 12px rgba(14, 165, 233, 0.25);
  text-decoration: none;
  display: inline-block;
  text-align: center;
}
.quick-connect__cta:hover {
  background: var(--conn-primary-hover);
}
.quick-connect__takes {
  margin-top: 12px;
  font-size: 13px;
  color: var(--conn-text3);
}
.quick-connect__switch {
  margin-top: 24px;
  font-size: 13px;
  color: var(--conn-text3);
}
.quick-connect__switch a {
  color: var(--conn-primary);
  text-decoration: underline;
  cursor: pointer;
  background: none;
  border: none;
  font-size: inherit;
  font-family: inherit;
  padding: 0;
}
.quick-connect__trust {
  margin-top: 36px;
  display: flex;
  gap: 24px;
  color: var(--conn-text3);
  font-size: 12px;
  flex-wrap: wrap;
  justify-content: center;
}
.trust-item {
  display: inline-flex;
  align-items: center;
  gap: 6px;
}
.trust-item__check {
  width: 16px;
  height: 16px;
  border-radius: 50%;
  background: var(--conn-success-bg);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--conn-success-text);
  flex-shrink: 0;
}

/* Advanced panel ------------------------------------------------------ */
.advanced-panel {
  background: #fff;
  border: 1px solid var(--conn-bg3);
  border-radius: 16px;
  padding: 28px;
  max-width: 720px;
}
.advanced-panel__intro {
  margin: 0;
  font-size: 14px;
  color: var(--conn-text2);
}
.advanced-panel__intro a,
.advanced-panel__intro button.linklike {
  color: var(--conn-primary);
  text-decoration: underline;
  background: none;
  border: none;
  font: inherit;
  cursor: pointer;
  padding: 0;
}

.connect-fields {
  margin-top: 20px;
  display: flex;
  flex-direction: column;
  gap: 20px;
  max-width: 560px;
}
.connect-field__label {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 13px;
  font-weight: 600;
  color: var(--conn-text0);
  margin-bottom: 6px;
}
.connect-field__row {
  display: flex;
  align-items: center;
  gap: 8px;
}
.connect-field__inputwrap {
  flex: 1;
  position: relative;
  background: #fff;
  border: 1px solid var(--conn-bg3);
  border-radius: 10px;
  padding: 0 14px;
  display: flex;
  align-items: center;
}
.connect-field__inputwrap:focus-within {
  border-color: var(--conn-primary);
  box-shadow: 0 0 0 3px var(--conn-focus-ring);
}
.connect-field__inputwrap--locked {
  background: var(--conn-bg2);
}
.connect-field__input {
  flex: 1;
  padding: 12px 0;
  font-size: 14px;
  color: var(--conn-text0);
  font-family: var(--conn-font);
  background: transparent;
  border: none;
  outline: none;
  width: 100%;
  min-width: 0;
}
.connect-field__input--mono {
  font-family: var(--conn-mono);
}
.connect-field__input::placeholder {
  color: var(--conn-text4);
}
.connect-field__eye {
  margin-left: 8px;
  color: var(--conn-text3);
  cursor: pointer;
  background: none;
  border: none;
  padding: 4px;
  display: inline-flex;
}
.connect-field__lock-tag {
  margin-left: 8px;
  color: var(--conn-text3);
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-size: 11px;
  font-weight: 600;
}
.connect-field__info {
  width: 28px;
  height: 28px;
  border-radius: 8px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--conn-text3);
  cursor: help;
  border: 1px solid var(--conn-bg3);
  background: #fff;
  position: relative;
}
.connect-field__info > summary {
  list-style: none;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100%;
  cursor: help;
}
.connect-field__info > summary::-webkit-details-marker { display: none; }
.connect-field__info[open] > summary {
  color: var(--conn-primary);
}
.connect-field__info-popover {
  position: absolute;
  top: calc(100% + 6px);
  inset-inline-end: 0;
  background: var(--conn-text0);
  color: #fff;
  font-size: 12px;
  padding: 8px 10px;
  border-radius: 8px;
  width: 240px;
  z-index: 20;
  font-weight: 400;
}
.connect-field__helper {
  margin-top: 6px;
  font-size: 12px;
  color: var(--conn-text3);
  line-height: 1.5;
}
.connect-field__helper code {
  font-family: var(--conn-mono);
  font-size: 12px;
  background: var(--conn-bg2);
  padding: 0 6px;
  border-radius: 4px;
}
.connect-field__helper a {
  color: var(--conn-primary);
}

/* Test result panel --------------------------------------------------- */
.test-result {
  margin-top: 24px;
  border-radius: 12px;
  padding: 16px;
  display: flex;
  gap: 12px;
  align-items: flex-start;
}
.test-result[hidden] { display: none; }
.test-result--success {
  background: var(--conn-success-bg);
  border: 1px solid var(--conn-success-border);
  color: var(--conn-success-text);
}
.test-result--error {
  background: var(--conn-error-bg);
  border: 1px solid var(--conn-error-border);
  color: var(--conn-error-text);
}
.test-result__icon { flex-shrink: 0; margin-top: 1px; }
.test-result__title { font-size: 14px; font-weight: 700; }
.test-result__detail { font-size: 13px; margin-top: 4px; }

/* Action row ---------------------------------------------------------- */
.advanced-actions {
  margin-top: 24px;
  display: flex;
  gap: 10px;
  align-items: center;
  flex-wrap: wrap;
}
.btn-test {
  background: #fff;
  color: var(--conn-primary);
  border: 1px solid var(--conn-primary);
  font-family: var(--conn-font);
  font-size: 14px;
  font-weight: 600;
  padding: 10px 18px;
  border-radius: 10px;
  cursor: pointer;
}
.btn-save {
  background: var(--conn-primary);
  color: #fff;
  border: none;
  font-family: var(--conn-font);
  font-size: 14px;
  font-weight: 600;
  padding: 10px 18px;
  border-radius: 10px;
  cursor: pointer;
}
.btn-save:disabled,
.btn-save[disabled] {
  background: #cbd5e1;
  color: var(--conn-text3);
  cursor: not-allowed;
}
.advanced-actions__hint {
  margin-inline-start: auto;
  font-size: 12px;
  color: var(--conn-text3);
}

/* Setup Guide accordion ---------------------------------------------- */
.setup-guide {
  margin-top: 28px;
  background: #fff;
  border: 1px solid var(--conn-bg3);
  border-radius: 12px;
  padding: 12px 18px;
  max-width: 720px;
}
.setup-guide__summary {
  list-style: none;
  cursor: pointer;
  font-size: 14px;
  font-weight: 600;
  color: var(--conn-text1);
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 6px 0;
}
.setup-guide__summary::-webkit-details-marker { display: none; }
.setup-guide__summary::before {
  content: "▸";
  color: var(--conn-text3);
  transition: transform 0.15s;
}
.setup-guide[open] > .setup-guide__summary::before {
  transform: rotate(90deg);
}
[dir="rtl"] .setup-guide__summary::before { content: "◂"; }
[dir="rtl"] .setup-guide[open] > .setup-guide__summary::before { transform: rotate(-90deg); }
.setup-guide__steps {
  margin: 14px 0 8px;
  padding: 0;
  list-style: none;
  counter-reset: step;
  display: flex;
  flex-direction: column;
  gap: 14px;
}
.setup-guide__step {
  counter-increment: step;
  padding-inline-start: 36px;
  position: relative;
}
.setup-guide__step::before {
  content: counter(step);
  position: absolute;
  inset-inline-start: 0;
  top: 0;
  width: 26px;
  height: 26px;
  border-radius: 50%;
  background: var(--conn-bg2);
  color: var(--conn-text1);
  font-size: 12px;
  font-weight: 700;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
.setup-guide__step-title {
  font-size: 13px;
  font-weight: 700;
  color: var(--conn-text0);
}
.setup-guide__step-body {
  font-size: 13px;
  color: var(--conn-text2);
  line-height: 1.55;
  margin-top: 4px;
}
.setup-guide__step-body code {
  font-family: var(--conn-mono);
  font-size: 12px;
  background: var(--conn-bg2);
  padding: 0 6px;
  border-radius: 4px;
}
.setup-guide__step-body a {
  color: var(--conn-primary);
}

/* Existing connections ----------------------------------------------- */
.existing-connections {
  margin-top: 36px;
}
.existing-connections__heading {
  font-size: 15px;
  font-weight: 700;
  margin: 0 0 12px;
  color: var(--conn-text1);
}
.existing-connections__list {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.connection-card {
  background: #fff;
  border: 1px solid var(--conn-bg3);
  border-radius: 12px;
  padding: 16px;
  padding-inline-start: 22px;
  position: relative;
  overflow: hidden;
  display: flex;
  align-items: center;
  gap: 16px;
}
.connection-card__stripe {
  position: absolute;
  inset-inline-start: 0;
  top: 0;
  bottom: 0;
  width: 4px;
}
.connection-card__stripe--whatsapp { background: var(--conn-wa); }
.connection-card__stripe--facebook { background: var(--conn-fb); }
.connection-card__stripe--instagram { background: var(--conn-ig-gradient); }
.connection-card__icon {
  width: 40px;
  height: 40px;
  border-radius: 10px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  color: #fff;
}
.connection-card__icon--whatsapp { background: var(--conn-wa); }
.connection-card__icon--facebook { background: var(--conn-fb); }
.connection-card__icon--instagram { background: var(--conn-ig-gradient); }
.connection-card__body { flex: 1; min-width: 0; }
.connection-card__title-row {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}
.connection-card__name {
  font-size: 14px;
  font-weight: 700;
}
.state-pill {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.3px;
  padding: 3px 8px;
  border-radius: 24px;
  text-transform: uppercase;
}
.state-pill::before {
  content: "";
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: currentColor;
}
.state-pill--active { background: var(--conn-success-bg); color: var(--conn-success-text); }
.state-pill--expired { background: var(--conn-error-bg); color: var(--conn-error-text); }
.state-pill--disconnected { background: var(--conn-bg2); color: var(--conn-text3); }
.connection-card__detail { font-size: 13px; color: var(--conn-text2); margin-top: 4px; }
.connection-card__meta { font-size: 12px; color: var(--conn-text3); margin-top: 2px; }
.connection-card__actions { display: flex; gap: 8px; flex-shrink: 0; }
.btn-reconnect {
  background: #fff;
  color: var(--conn-text1);
  border: 1px solid var(--conn-bg3);
  font-family: var(--conn-font);
  font-size: 13px;
  font-weight: 600;
  padding: 7px 12px;
  border-radius: 10px;
  cursor: pointer;
}
.btn-disconnect {
  background: transparent;
  color: var(--conn-error-text);
  border: none;
  font-family: var(--conn-font);
  font-size: 13px;
  font-weight: 600;
  padding: 8px 12px;
  border-radius: 8px;
  cursor: pointer;
}

/* Expired / reconnect banner ----------------------------------------- */
.expired-banner {
  background: var(--conn-error-bg);
  border: 1px solid var(--conn-error-border);
  color: var(--conn-error-text);
  border-radius: 12px;
  padding: 14px 16px;
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 20px;
}
.expired-banner__body { flex: 1; }
.expired-banner__title { font-weight: 700; font-size: 14px; }
.expired-banner__desc { font-size: 13px; margin-top: 2px; }
.expired-banner__cta {
  background: transparent;
  color: var(--conn-error-text);
  border: 1px solid var(--conn-error-border);
  border-radius: 8px;
  padding: 6px 12px;
  font-size: 13px;
  font-weight: 600;
  cursor: pointer;
  text-decoration: none;
  display: inline-block;
}

/* RTL flips ----------------------------------------------------------- */
[dir="rtl"] .quick-connect__switch a::after,
[dir="rtl"] .connections-topbar { direction: rtl; }
[dir="rtl"] .channel-tab,
[dir="rtl"] .connection-card,
[dir="rtl"] .advanced-actions { direction: rtl; }

/* Responsive ---------------------------------------------------------- */
@media (max-width: 768px) {
  .connections-page { padding: 18px 16px 40px; }
  .connections-heading { flex-direction: column; }
  .channel-tab { height: 44px; padding: 0 12px; font-size: 13px; }
  .quick-connect { padding: 36px 16px; }
  .advanced-panel { padding: 18px; }
  .connection-card { flex-wrap: wrap; }
  .connection-card__actions { width: 100%; justify-content: flex-end; }
}
