:root {
  --bg: #f4f7fb;
  --card: #ffffff;
  --text: #17324d;
  --muted: #5d7288;
  --accent: #1d6fdc;
  --accent-2: #eaf3ff;
  --border: #d8e2ee;
  --danger: #c0392b;
}
* { box-sizing: border-box; }
body {
  margin: 0;
  font-family: Inter, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  background: var(--bg);
  color: var(--text);
}
button, input, select {
  font: inherit;
}
button {
  border: 0;
  border-radius: 10px;
  padding: 0.8rem 1rem;
  background: var(--accent);
  color: white;
  cursor: pointer;
}
button.secondary { background: #294d75; }
button.ghost {
  background: transparent;
  border: 1px solid var(--border);
  color: var(--text);
}
button.icon-btn {
  background: transparent;
  color: var(--text);
  padding: 0.25rem 0.5rem;
}
.topbar {
  display: flex;
  justify-content: space-between;
  gap: 1.5rem;
  align-items: center;
  max-width: 1180px;
  margin: 0 auto;
  padding: 1rem 1rem 0.75rem;
}
.subtitle, .muted { color: var(--muted); }

.brand-wrap {
  display: flex;
  gap: 1.2rem;
  align-items: center;
  flex: 1 1 auto;
  min-width: 0;
}
.brand-copy {
  display: grid;
  gap: 0.35rem;
  align-content: center;
}
.brand-logo {
  width: min(420px, 36vw);
  max-width: 100%;
  height: auto;
  display: block;
}
.topbar-side {
  display: grid;
  justify-items: end;
  align-content: center;
  gap: 0.7rem;
}
.platform-badge {
  display: flex;
  justify-content: flex-end;
  width: 100%;
}
.platform-logo {
  display: block;
  width: min(350px, 28vw);
  min-width: 220px;
  height: auto;
}
.export-actions {
  margin-top: 0.85rem;
  flex-wrap: wrap;
}
.preview-row {
  padding: 0.45rem 0;
  border-bottom: 1px dashed var(--border);
}
.preview-row:last-child {
  border-bottom: 0;
}

.layout {
  max-width: 1180px;
  margin: 0 auto 2rem;
  padding: 0 1rem 2rem;
}
.card {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 18px;
  padding: 1rem;
  box-shadow: 0 10px 24px rgba(12, 40, 75, 0.04);
}
.hero {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 1rem;
  margin-bottom: 1rem;
}
.hero-copy {
  display: grid;
  gap: 1rem;
  align-content: start;
}
.hero-branding {
  display: grid;
  gap: 0.35rem;
}
.hero-title {
  margin: 0;
  color: #1e4f9a;
  line-height: 1.02;
  font-size: clamp(2.1rem, 3.8vw, 3.2rem);
}
.hero-subtitle {
  margin: 0;
  color: var(--muted);
  font-size: 1rem;
}
.hero-today {
  display: grid;
  gap: 0.2rem;
}
#todayLabel {
  margin: 0;
  font-size: 1.55rem;
  line-height: 1.05;
}
#todayDate {
  margin: 0;
  color: var(--text);
}
.hero-actions, .header-actions, .field-row, .wizard-actions, .tabs, .section-head {
  display: flex;
  gap: 0.75rem;
  align-items: center;
}
.grid-2 {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1rem;
  margin-bottom: 1rem;
}
.field-row label, .stacked-form label, .field-grid label {
  display: grid;
  gap: 0.35rem;
  color: var(--muted);
}
.field-row.compact { justify-content: flex-end; }
input:not([type="checkbox"]):not([type="radio"]), select {
  width: 100%;
  padding: 0.75rem;
  border-radius: 10px;
  border: 1px solid var(--border);
  background: #fff;
}
input[type="checkbox"],
input[type="radio"] {
  width: auto;
  padding: 0;
  border: 0;
  border-radius: 0;
  background: transparent;
  accent-color: var(--accent);
}
.table-wrap { overflow: auto; }
table { width: 100%; border-collapse: collapse; }
th, td {
  text-align: left;
  padding: 0.8rem;
  border-bottom: 1px solid var(--border);
  vertical-align: top;
}
.dialog-shell {
  width: min(760px, 92vw);
  border: 0;
  border-radius: 20px;
  padding: 0;
}
.dialog-shell.wide { width: min(980px, 94vw); }
.subscribe-dialog-shell { width: min(1180px, 96vw); }
dialog::backdrop { background: rgba(18, 28, 38, 0.5); }
.dialog-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 1rem 1rem 0.75rem;
  border-bottom: 1px solid var(--border);
}
.dialog-header h2 {
  margin: 0;
  color: #1e4f9a;
  letter-spacing: -0.01em;
}
.tabs {
  padding: 0.75rem 1rem 0;
  border-bottom: 1px solid var(--border);
}
.tab {
  background: transparent;
  color: var(--text);
  border-radius: 10px 10px 0 0;
  border: 1px solid transparent;
  padding: 0.7rem 1rem;
}
.tab.active {
  background: var(--accent-2);
  border-color: var(--border);
  border-bottom-color: var(--accent-2);
}
.tab-panel { display: none; padding: 1rem; }
.tab-panel.active { display: block; }
.provider-list, #historyList, #importPreview, #editDayFormWrap, #wizardBody {
  margin-top: 1rem;
}
.provider-item, .history-item, .preview-box, .coverage-block {
  border: 1px solid var(--border);
  border-radius: 14px;
  padding: 0.85rem;
  margin-bottom: 0.75rem;
  background: #fff;
}
.provider-item {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 0.75rem;
}
.provider-item-copy {
  display: grid;
  gap: 0.18rem;
  min-width: 0;
}
.provider-form-actions {
  align-items: center;
}
.provider-form-note {
  margin-top: -0.2rem;
}
.field-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.75rem;
}
.activity-list {
  display: grid;
  gap: 0.85rem;
}
.activity-item {
  border: 1px solid var(--border);
  border-radius: 14px;
  padding: 0.9rem;
  background: linear-gradient(180deg, #ffffff 0%, #f8fbff 100%);
}
.activity-item-head {
  display: flex;
  justify-content: space-between;
  gap: 1rem;
  align-items: flex-start;
}
.activity-item-head strong {
  display: block;
  margin-bottom: 0.2rem;
}
.activity-meta-line {
  color: var(--muted);
  font-size: 0.92rem;
}
.activity-summary {
  margin: 0.65rem 0 0;
}
.activity-change-list {
  margin: 0.55rem 0 0;
  padding-left: 1.15rem;
}
.activity-change-list li {
  margin-bottom: 0.35rem;
}
.activity-actions {
  display: flex;
  gap: 0.6rem;
  margin-top: 0.8rem;
  flex-wrap: wrap;
}
.activity-actions button {
  padding: 0.55rem 0.8rem;
}
.activity-badge {
  display: inline-flex;
  align-items: center;
  border-radius: 999px;
  background: var(--accent-2);
  color: var(--accent);
  padding: 0.35rem 0.65rem;
  font-size: 0.85rem;
  font-weight: 600;
  white-space: nowrap;
}
.activity-source-text {
  margin-top: 0.85rem;
  border: 1px solid var(--border);
  border-radius: 14px;
  background: #fbfdff;
  padding: 0.95rem;
  white-space: pre-wrap;
  line-height: 1.45;
  max-height: 60vh;
  overflow: auto;
}
.field-grid .full,
.field-grid.two-col .full { grid-column: 1 / -1; }
.stacked-form {
  display: grid;
  gap: 0.85rem;
}
.split-section {
  border: 1px solid var(--border);
  border-radius: 14px;
  padding: 0.8rem;
}
.split-section h4 { margin-top: 0; }
.badge {
  display: inline-flex;
  padding: 0.2rem 0.5rem;
  border-radius: 999px;
  font-size: 0.8rem;
  background: var(--accent-2);
  color: var(--accent);
}
.note {
  color: var(--muted);
  font-size: 0.95rem;
}
.wizard-progress {
  padding: 1rem 1rem 0;
  color: var(--muted);
}
.wizard-actions {
  justify-content: space-between;
  padding: 1rem;
  border-top: 1px solid var(--border);
}
.choice-grid {
  display: grid;
  gap: 0.75rem;
  padding: 1rem;
}
.choice-grid button {
  text-align: left;
  background: #fff;
  color: var(--text);
  border: 1px solid var(--border);
}
.choice-grid button.selected {
  background: var(--accent-2);
  border-color: var(--accent);
}
.inline-actions { display: flex; gap: 0.5rem; flex-wrap: wrap; }
.small { font-size: 0.9rem; }
.danger { color: var(--danger); }
.ai-intake-summary {
  margin: 0.85rem 0;
}
.warning-list {
  margin: 0.6rem 0 0;
  padding-left: 1.1rem;
}
.warning-list li + li {
  margin-top: 0.3rem;
}
@media (max-width: 800px) {
  .grid-2, .field-grid {
    grid-template-columns: 1fr;
  }
  .hero, .topbar {
    flex-direction: column;
    align-items: stretch;
  }
  .brand-wrap {
    flex-direction: column;
    align-items: flex-start;
  }
  .topbar-side {
    width: 100%;
    justify-items: start;
    order: -1;
    gap: 0.55rem;
  }
  .platform-badge {
    justify-content: flex-start;
  }
  .platform-logo {
    width: min(270px, 70vw);
    min-width: 0;
  }
  .brand-logo {
    width: min(360px, 84vw);
    max-width: 100%;
  }
  .brand-wrap {
    order: 1;
  }
  .hero-copy {
    gap: 0.85rem;
  }
  .hero-title {
    font-size: clamp(1.75rem, 7vw, 2.45rem);
  }
  .field-row.compact {
    justify-content: stretch;
    flex-wrap: wrap;
  }
}

.inline-error{margin:8px 0 0;padding:10px 12px;border-radius:10px;background:#fff1f2;border:1px solid #fecdd3;color:#9f1239;font-size:.95rem;}

.session-status{
  display:inline-flex;
  align-items:center;
  padding:.45rem .7rem;
  border-radius:999px;
  border:1px solid var(--border);
  background:#fff;
  color:var(--muted);
  font-size:.9rem;
}
.dialog-shell.narrow{width:min(480px,92vw);}
.compact-actions{padding:0;border-top:0;justify-content:flex-end;}
#passwordMessage{margin-top:.75rem;}
/* MOBILE SELECT FIX */
@media (max-width: 768px) {

  select {
    appearance: auto;
    -webkit-appearance: menulist;
    font-size: 16px;
    padding: 10px;
    min-height: 44px;
    width: 100%;
    box-sizing: border-box;
  }

  button {
    min-height: 44px;
  }

  input:not([type="checkbox"]):not([type="radio"]) {
    min-height: 44px;
  }

  .modal,
  .wizard,
  .dialog {
    overflow: visible !important;
  }

  select:focus {
    outline: 2px solid #3b82f6;
  }

}


#wizardDialog .dialog-shell {
  width: min(820px, 96vw);
}

#wizardBody,
#wizardDialog .dialog-shell {
  overflow-x: hidden;
}

.compact-choice-grid {
  padding: 0.75rem;
}

.wizard-helper-row {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 0.75rem;
  padding: 0.8rem 0.9rem;
  border: 1px dashed var(--border);
  border-radius: 14px;
  background: #f8fbff;
}

.subtle-action {
  padding: 0.45rem 0.75rem;
  border-radius: 999px;
  white-space: nowrap;
  color: var(--muted);
  background: #fff;
  border: 1px solid var(--border);
  align-self: center;
  flex: 0 0 auto;
}

.mode-summary-pill {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  width: fit-content;
  max-width: 100%;
  padding: 0.45rem 0.7rem;
  border-radius: 999px;
  background: var(--accent-2);
  color: var(--text);
  border: 1px solid #cfe0fb;
  font-size: 0.92rem;
}

.multi-date-picker-grid {
  align-items: end;
}

.multi-date-picker-actions {
  display: flex;
  gap: 0.5rem;
  flex-wrap: wrap;
  align-items: center;
}

.selected-date-chip-list {
  display: flex;
  flex-wrap: wrap;
  gap: 0.55rem;
  margin-top: 0.75rem;
}

.selected-date-chip {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  padding: 0.35rem 0.55rem;
  border-radius: 999px;
  background: #f4f8ff;
  border: 1px solid #d8e4fb;
  color: var(--text);
  font-size: 0.92rem;
}

.selected-date-chip button {
  min-height: auto;
  padding: 0.1rem 0.35rem;
  border-radius: 999px;
}

@media (max-width: 800px) {
  #wizardDialog {
    padding: 0.35rem;
  }

  #wizardDialog .dialog-shell {
    width: min(100vw - 0.7rem, 840px);
    max-width: calc(100vw - 0.7rem);
  }

  .dialog-header,
  .wizard-progress,
  #wizardBody,
  .wizard-actions {
    padding-left: 0.85rem;
    padding-right: 0.85rem;
  }

  .wizard-helper-row {
    flex-direction: column;
    align-items: stretch;
  }

  .subtle-action {
    width: fit-content;
    align-self: flex-start;
  }

  .choice-grid button {
    white-space: normal;
    line-height: 1.3;
  }

  .multi-date-picker-actions {
    align-items: stretch;
  }
}


/* UI tweaks v2 */
#wizardDialog .dialog-shell {
  width: min(860px, 97vw);
}

#wizardBody {
  overflow-wrap: anywhere;
}

#wizardBody .preview-box,
#wizardBody label,
#wizardBody .small,
#wizardBody .note {
  overflow-wrap: anywhere;
}

#todayCard + .card .field-row {
  flex-wrap: nowrap;
  align-items: end;
}

#todayCard + .card .field-row label {
  flex: 1 1 auto;
  min-width: 0;
}

#jumpDateBtn {
  flex: 0 0 auto;
  margin-left: 0.35rem;
}

.section-head {
  align-items: flex-start;
}

.section-head .field-row.compact {
  margin-left: auto;
  flex-wrap: nowrap;
  align-items: end;
}

.section-head .field-row.compact label {
  min-width: 0;
}

.section-head .field-row.compact label:first-child {
  flex: 1 1 11rem;
}

.section-head .field-row.compact label:nth-child(2) {
  flex: 0 0 5.5rem;
}

.section-head .field-row.compact button {
  flex: 0 0 auto;
}

@media (max-width: 800px) {
  #wizardDialog {
    padding: 0.15rem;
  }

  #wizardDialog .dialog-shell {
    width: min(100vw - 0.3rem, 920px);
    max-width: calc(100vw - 0.3rem);
    border-radius: 18px;
  }

  .dialog-header,
  .wizard-progress,
  #wizardBody,
  .wizard-actions {
    padding-left: 0.7rem;
    padding-right: 0.7rem;
  }

  #wizardProgress,
  #wizardBody,
  #wizardBody label,
  #wizardBody .small,
  #wizardBody input,
  #wizardBody select,
  #wizardBody button {
    font-size: 0.97rem;
  }

  #todayCard + .card .field-row {
    gap: 0.55rem;
  }

  #jumpDateBtn {
    margin-left: 0.15rem;
  }

  .section-head {
    flex-direction: column;
    gap: 0.65rem;
  }

  .section-head .field-row.compact {
    width: 100%;
    justify-content: flex-start;
    gap: 0.45rem;
  }

  .section-head .field-row.compact label:first-child {
    flex: 1 1 auto;
  }

  .section-head .field-row.compact label:nth-child(2) {
    flex: 0 0 4.9rem;
  }

  .section-head .field-row.compact button {
    padding-left: 0.8rem;
    padding-right: 0.8rem;
  }
}


/* UI tweaks v3 */
@media (max-width: 800px) {
  dialog {
    width: calc(100vw - 1rem);
    max-width: calc(100vw - 1rem);
    padding: 0;
    margin: 0.5rem;
    border: 0;
  }

  #wizardDialog {
    width: calc(100vw - 1rem);
    max-width: calc(100vw - 1rem);
    padding: 0;
    margin: 0.5rem;
  }

  #wizardDialog .dialog-shell {
    width: 100%;
    max-width: 100%;
    border-radius: 16px;
  }

  .dialog-header {
    padding-top: 0.9rem;
    padding-bottom: 0.65rem;
  }

  .dialog-header h2 {
    font-size: 1.35rem;
    line-height: 1.15;
  }

  .dialog-header,
  .wizard-progress,
  #wizardBody,
  .wizard-actions {
    padding-left: 0.8rem;
    padding-right: 0.8rem;
  }

  #todayCard + .card .field-row {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    align-items: end;
    gap: 0.65rem;
  }

  #todayCard + .card .field-row label {
    min-width: 0;
  }

  #jumpDateBtn {
    margin-left: 0;
    min-width: 7.6rem;
    align-self: end;
  }

  .section-head {
    align-items: stretch;
  }

  .section-head .field-row.compact {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 5.1rem auto;
    width: 100%;
    gap: 0.55rem;
    align-items: end;
  }

  .section-head .field-row.compact label,
  .section-head .field-row.compact label:first-child,
  .section-head .field-row.compact label:nth-child(2) {
    min-width: 0;
    width: 100%;
    flex: initial;
  }

  .section-head .field-row.compact button {
    justify-self: end;
    min-width: 7.5rem;
    padding-left: 0.85rem;
    padding-right: 0.85rem;
  }
}

@media (max-width: 520px) {
  .section-head .field-row.compact {
    grid-template-columns: minmax(0, 1fr) 4.8rem auto;
  }

  .dialog-header h2 {
    font-size: 1.28rem;
  }
}


/* UI tweaks v4 */
.wizard-context-banner {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.75rem;
  padding: 0.85rem 1rem;
  border: 1px solid var(--border);
  border-radius: 14px;
  background: var(--accent-2);
  color: var(--text);
}

.wizard-context-banner.single {
  grid-template-columns: 1fr;
}

.wizard-context-banner strong,
.wizard-context-banner span {
  display: block;
}

.wizard-context-banner strong {
  font-size: 0.82rem;
  letter-spacing: 0.02em;
  text-transform: uppercase;
  color: var(--muted);
  margin-bottom: 0.2rem;
}

.wizard-context-banner span {
  font-weight: 600;
}

@media (max-width: 800px) {
  .wizard-context-banner {
    grid-template-columns: 1fr;
    padding: 0.8rem 0.9rem;
  }
}

/* Mobile control layout fix v2: Quick Jump + Upcoming Schedule */
@media (max-width: 800px) {
  #todayCard + .card .field-row {
    display: grid;
    grid-template-columns: minmax(0, 1fr);
    gap: 0.7rem;
    align-items: stretch;
  }

  #todayCard + .card .field-row label,
  #todayCard + .card .field-row button,
  #jumpDateBtn {
    width: 100%;
    min-width: 0;
  }

  #jumpDateBtn {
    margin-left: 0;
    align-self: stretch;
    justify-self: stretch;
  }

  .section-head {
    align-items: stretch;
    gap: 0.8rem;
  }

  .section-head .field-row.compact {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 6rem;
    grid-template-areas:
      "start days"
      "refresh refresh";
    width: 100%;
    gap: 0.7rem;
    align-items: end;
    margin-left: 0;
  }

  .section-head .field-row.compact label,
  .section-head .field-row.compact label:first-child,
  .section-head .field-row.compact label:nth-child(2) {
    min-width: 0;
    width: 100%;
    flex: initial;
  }

  .section-head .field-row.compact label:first-child {
    grid-area: start;
  }

  .section-head .field-row.compact label:nth-child(2) {
    grid-area: days;
  }

  .section-head .field-row.compact button {
    grid-area: refresh;
    width: 100%;
    min-width: 0;
    justify-self: stretch;
  }
}

@media (max-width: 520px) {
  .section-head .field-row.compact {
    grid-template-columns: minmax(0, 1fr) 5.25rem;
  }
}


textarea {
  width: 100%;
  padding: 0.75rem;
  border-radius: 10px;
  border: 1px solid var(--border);
  background: #fff;
  font: inherit;
  resize: vertical;
}

.wizard-success-banner {
  border: 1px solid #cfe8d0;
  background: #f3fbf4;
  color: #1d5b2a;
}

.email-meta-grid {
  display: grid;
  gap: 0.75rem;
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

@media (max-width: 800px) {
  .email-meta-grid {
    grid-template-columns: 1fr;
  }
}


.checkbox-row {
  display:flex !important;
  align-items:center;
  gap:.6rem;
  color:var(--text) !important;
}
.checkbox-row input[type="checkbox"] {
  width:auto;
  margin:0;
}
.stretch-row {
  align-items:stretch;
}
.stretch-row input {
  flex:1;
}
.button-link {
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border-radius:10px;
  padding:0.8rem 1rem;
  background:var(--accent);
  color:#fff;
  text-decoration:none;
  font-weight:700;
  box-shadow:0 12px 28px rgba(31,111,235,0.2);
}
.platform-grid {
  display:grid;
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:1rem;
  margin-top:1rem;
}
.subscribe-intro-card {
  border:1px solid rgba(30,79,154,0.16);
  border-radius:18px;
  padding:1rem 1.1rem;
  background:#ffffff;
  box-shadow:0 14px 36px rgba(15,23,42,0.08);
  display:grid;
  gap:0.6rem;
}
.subscribe-intro-card p {
  margin:0;
}
.subscribe-intro-card strong {
  color:#1e4f9a;
}
.subscribe-feed-card {
  border:1px solid rgba(148,163,184,0.32);
  border-radius:18px;
  padding:1rem;
  background:linear-gradient(180deg, #ffffff 0%, #f8fbff 100%);
  box-shadow:0 12px 32px rgba(15,23,42,0.08);
  margin-top:1rem;
}
.subscribe-feed-card-head {
  margin-bottom:0.75rem;
}
.platform-card {
  position:relative;
  border:1px solid rgba(148,163,184,0.28);
  border-radius:22px;
  padding:1.1rem;
  background:linear-gradient(180deg, #ffffff 0%, #fbfdff 100%);
  display:flex;
  flex-direction:column;
  gap:0.9rem;
  box-shadow:0 18px 42px rgba(15,23,42,0.08);
}
.platform-card::before {
  content:"";
  position:absolute;
  inset:0 auto 0 0;
  width:8px;
  border-radius:22px 0 0 22px;
  background:#dbeafe;
}
.platform-card-google::before {
  background:linear-gradient(180deg, #4285f4 0 25%, #ea4335 25% 50%, #fbbc05 50% 75%, #34a853 75% 100%);
}
.platform-card-apple::before {
  background:linear-gradient(180deg, #5c6570 0%, #a7b0ba 100%);
}
.platform-card-outlook::before {
  background:linear-gradient(180deg, #0078d4 0%, #2b88d8 45%, #4db2ff 100%);
}
.platform-card h3 {
  margin:0;
  font-size:1.15rem;
}
.platform-card p {
  margin:0;
}
.platform-card-intro {
  display:grid;
  gap:0.3rem;
  min-height:4.5rem;
}
.platform-card-apple .platform-card-intro {
  min-height:6rem;
}
.platform-card-note {
  min-height:2.8rem;
}
.platform-image-button {
  display:block;
  position:relative;
  border-radius:18px;
  overflow:hidden;
  border:1px solid rgba(148,163,184,0.28);
  box-shadow:0 14px 34px rgba(15,23,42,0.12);
  aspect-ratio:1.75 / 1;
  background:#fff;
  cursor:pointer;
  transition:transform 120ms ease, box-shadow 120ms ease, border-color 120ms ease;
}
.platform-image-button:hover {
  transform:translateY(-1px);
  box-shadow:0 18px 38px rgba(15,23,42,0.16);
  border-color:rgba(31,111,235,0.32);
}
.platform-image-button:focus-visible {
  outline:3px solid rgba(31,111,235,0.28);
  outline-offset:3px;
}
.platform-image-button img {
  display:block;
  width:100%;
  height:100%;
  object-fit:contain;
  object-position:center;
  background:#fff;
}
.platform-card-apple .platform-image-button img {
  object-position:center 56%;
}
.platform-image-cta {
  position:absolute;
  right:28px;
  bottom:8px;
  display:inline-flex;
  align-items:center;
  gap:0.35rem;
  padding:0.3rem 0.58rem;
  border-radius:999px;
  background:rgba(15,23,42,0.82);
  color:#fff;
  font-size:0.7rem;
  font-weight:800;
  letter-spacing:0.02em;
  box-shadow:0 14px 30px rgba(15,23,42,0.26), 0 3px 8px rgba(15,23,42,0.18);
  text-shadow:0 1px 1px rgba(15,23,42,0.22);
}
.platform-image-cta::before {
  content:"";
  width:0.4rem;
  height:0.4rem;
  border-right:2px solid currentColor;
  border-bottom:2px solid currentColor;
  transform:rotate(-45deg);
}
.platform-manual {
  border-top:1px solid rgba(226,232,240,0.95);
  padding-top:0.85rem;
  display:grid;
  gap:0.55rem;
}
.platform-manual-title {
  font-size:0.82rem;
  font-weight:800;
  letter-spacing:0.08em;
  text-transform:uppercase;
  color:#475569;
}
.platform-steps {
  color:#516074;
  margin:0;
  padding-left:1.2rem;
}
.platform-steps li + li {
  margin-top:0.4rem;
}

@media (max-width: 720px) {
  .subscribe-dialog-shell {
    width:min(760px, 92vw);
  }
  .platform-grid {
    grid-template-columns:1fr;
  }
  .platform-card {
    padding:1rem;
  }
  .platform-image-cta {
    right:22px;
    bottom:8px;
    font-size:0.66rem;
    padding:0.28rem 0.52rem;
  }
}


.provider-lookup-results {
  display: grid;
  gap: 12px;
}

.provider-call-section {
  border: 1px solid #dbe5f0;
  border-radius: 14px;
  padding: 14px 16px;
  background: #fff;
}

.provider-call-section h4 {
  margin: 0 0 8px;
}

.provider-call-section ul {
  margin: 0;
  padding-left: 20px;
}

.provider-call-section li + li {
  margin-top: 6px;
}


.provider-lookup-summary-card {
  display: grid;
  gap: 0.35rem;
  padding: 0.85rem 1rem;
  margin-bottom: 0.85rem;
  border-radius: 12px;
  background: rgba(37, 99, 235, 0.08);
  border: 1px solid rgba(37, 99, 235, 0.18);
}

.mobile-swap-summary-copy {
  display: none;
}


.swap-selection-panels{display:grid;grid-template-columns:1fr 1fr;gap:14px}.swap-provider-box{min-height:220px}.swap-track-section+.swap-track-section{margin-top:14px}.swap-track-heading{font-weight:700;margin:6px 0 8px}.swap-group{border:1px solid #dbe6f6;border-radius:14px;padding:8px 10px;margin:10px 0;background:#fff;box-shadow:0 1px 2px rgba(15,23,42,.04)}.swap-group summary{cursor:pointer;list-style:none}.swap-group summary::-webkit-details-marker{display:none}.swap-group-summary{display:flex;align-items:center;gap:10px}.swap-group[open]{border-color:#bfd3f5;background:linear-gradient(180deg,#fff 0%,#f7fbff 100%)}.swap-group[open] .swap-group-caret{transform:rotate(90deg)}.swap-group-caret{display:inline-flex;align-items:center;justify-content:center;transition:transform .15s ease;color:#1f5fbf;font-size:1.2rem;font-weight:700;line-height:1;inline-size:18px;flex:0 0 18px}.swap-group-label{display:grid;grid-template-columns:18px minmax(0,1fr);align-items:center;column-gap:12px;font-weight:600;cursor:pointer;flex:1;padding:8px 6px;border-radius:10px}.swap-group-label:hover,.swap-day-row:hover{background:#f6faff}.swap-group-label input,.swap-day-row input{margin:0;inline-size:18px;block-size:18px;flex:0 0 auto}.swap-group-label-text{display:grid;gap:2px;min-width:0}.swap-group-title{display:block;line-height:1.3}.swap-group-meta{display:block;font-size:.78rem;color:#5f6f86;font-weight:600;letter-spacing:.01em}.swap-group-days{display:grid;gap:6px;padding:8px 0 0 34px}.swap-day-row{display:grid;grid-template-columns:18px minmax(0,1fr);align-items:center;column-gap:12px;min-height:24px;padding:7px 6px;border-radius:10px;cursor:pointer}.swap-day-row span{display:block;line-height:1.35;min-width:0}.inline-error[hidden]{display:none}.wizard-context-banner.swap{display:grid;grid-template-columns:1fr;gap:10px;padding:18px 20px;background:linear-gradient(180deg,rgba(37,99,235,.12) 0%,rgba(37,99,235,.06) 100%);border:1px solid rgba(37,99,235,.18);border-radius:16px}.wizard-context-swap-layout{display:flex;align-items:center;justify-content:center;gap:28px;min-height:92px;width:100%}.wizard-context-provider-column{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;flex:0 0 250px;max-width:250px;text-align:center}.wizard-context-provider-name{font-size:1rem;line-height:1.15;text-transform:uppercase;letter-spacing:.02em;max-width:100%;white-space:nowrap;margin:0;color:#27405f}.wizard-context-provider-dates{color:#27405f;font-weight:700;font-size:1rem;line-height:1.25;max-width:100%;white-space:nowrap}.wizard-context-swap-center{display:flex;align-items:center;justify-content:center;flex:0 0 88px;height:100%}.wizard-context-swap-arrows{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:0;line-height:1}.wizard-context-swap-arrow{display:block;font-size:3.6rem;font-weight:900;line-height:.72;color:#111827;font-family:Arial,Helvetica,sans-serif}.wizard-context-swap-arrow-left{transform:translateX(-8px)}.wizard-context-swap-arrow-right{transform:translateX(8px)}@media (max-width: 760px){.swap-selection-panels{grid-template-columns:1fr}.swap-provider-box{min-height:auto}.wizard-context-banner.swap{padding:14px 16px}.mobile-swap-summary-copy{display:grid;margin-top:10px}.wizard-context-swap-layout{flex-direction:column;gap:10px;min-height:0}.wizard-context-provider-column{flex:0 1 auto;max-width:none;width:100%}.wizard-context-provider-name,.wizard-context-provider-dates{white-space:normal}.wizard-context-swap-center{flex:auto;height:auto}.wizard-context-swap-arrows{transform:none}.wizard-context-swap-arrow{font-size:2.7rem}.wizard-context-swap-arrow-left,.wizard-context-swap-arrow-right{transform:none}.swap-group{padding:8px}.swap-group-summary{gap:8px}.swap-group-caret{inline-size:16px;flex-basis:16px}.swap-group-label,.swap-day-row{column-gap:10px;padding:8px 4px}.swap-group-label input,.swap-day-row input{inline-size:20px;block-size:20px}.swap-group-days{padding:8px 0 0 26px}}
