/* ============================================================
   AUM AI — Connect Data Sources styles
   ============================================================ */

.conn-head { display: flex; justify-content: space-between; align-items: flex-end; gap: 20px; margin-bottom: 24px; flex-wrap: wrap; }
.conn-head .port-title { display: flex; align-items: center; gap: 12px; }
.conn-head .port-title svg { color: var(--ink-3); }
.conn-synced { display: inline-flex; align-items: center; gap: 7px; font-size: 13px; color: var(--ink-3); padding: 8px 14px; border-radius: 99px; border: 1px solid var(--border); background: var(--surface); }
.conn-synced b { color: var(--ink-2); font-family: var(--font-mono); font-size: 12.5px; }

.conn-banner { display: flex; align-items: center; gap: 14px; padding: 18px 22px; margin-bottom: 22px; }
.conn-banner-ic { width: 38px; height: 38px; flex: none; border-radius: 11px; display: grid; place-items: center; background: var(--surface-inset); color: var(--ink-3); }
.conn-banner p { flex: 1; margin: 0; font-size: 15px; color: var(--ink-2); }
@media (max-width: 600px){ .conn-banner { flex-wrap: wrap; } .conn-banner p { flex-basis: 100%; } }

.src-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; }
.src-card { display: flex; flex-direction: column; gap: 16px; padding: 24px; transition: all .3s var(--ease); }
.src-card:not(.soon):hover { transform: translateY(-3px); box-shadow: var(--shadow-md); border-color: var(--border-strong); }
.src-card.soon { opacity: .72; }
.src-top { display: flex; align-items: flex-start; gap: 12px; }
.src-ic { width: 42px; height: 42px; flex: none; border-radius: 12px; display: grid; place-items: center; background: color-mix(in oklch, var(--brand-blue) 9%, var(--surface-inset)); color: var(--accent); }
.src-card.soon .src-ic { background: var(--surface-inset); color: var(--ink-3); }
.src-titles { flex: 1; min-width: 0; }
.src-titles h3 { font-size: 18px; }
.src-soon { display: inline-block; margin-top: 4px; font-size: 11px; font-weight: 600; text-transform: uppercase; letter-spacing: .04em; color: var(--ink-3); padding: 3px 9px; border-radius: 99px; border: 1px solid var(--border); background: var(--surface-inset); }
.src-status { display: flex; align-items: center; gap: 8px; flex: none; }
.src-x { width: 20px; height: 20px; display: grid; place-items: center; border-radius: 50%; background: var(--surface-inset); color: var(--ink-faint); }
.src-x.on { background: var(--pos-bg); color: var(--pos); }
.src-badge { font-size: 12px; font-weight: 600; padding: 4px 10px; border-radius: 99px; border: 1px solid var(--border); color: var(--ink-3); white-space: nowrap; }
.src-badge.on { color: var(--pos); border-color: color-mix(in oklch, var(--pos) 30%, transparent); background: var(--pos-bg); }
.src-desc { font-size: 14px; color: var(--ink-2); margin: 0; flex: 1; line-height: 1.5; }
.src-cta { display: flex; align-items: center; justify-content: center; gap: 10px; height: 50px; border: none; border-radius: 13px; background: var(--solid-bg); color: var(--solid-ink); font-family: inherit; font-weight: 600; font-size: 15px; transition: all .2s var(--ease); }
.src-cta:not(.disabled):not(.done):hover { transform: translateY(-1px); box-shadow: var(--shadow-md); }
.src-cta.disabled { background: var(--surface-inset); color: var(--ink-faint); cursor: not-allowed; }
.src-cta.done { background: var(--pos-bg); color: var(--pos); }
.src-spin { width: 17px; height: 17px; border-radius: 50%; border: 2px solid color-mix(in oklch, var(--solid-ink) 30%, transparent); border-top-color: var(--solid-ink); animation: spin .7s linear infinite; }

.conn-fine { text-align: center; font-size: 13px; color: var(--ink-3); margin: 36px 0 0; }

/* Manual entry form */
.me-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.me-field { display: flex; flex-direction: column; gap: 6px; }
.me-field span { font-size: 12.5px; font-weight: 600; color: var(--ink-3); }
.me-field input, .me-field select { border: 1px solid var(--border-strong); background: var(--surface-2); border-radius: 11px; padding: 11px 13px; font-family: inherit; font-size: 14.5px; color: var(--ink); outline: none; transition: border-color .2s; }
.me-field input:focus, .me-field select:focus { border-color: var(--accent); }

@media (max-width: 920px){ .src-grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 600px){ .src-grid, .me-grid { grid-template-columns: 1fr; } }
