/*
 * Membership frontend (subscriber + registration) styles.
 *
 * Keep this file scoped to the membership layout (membership.php) by using
 * the `.m-*` classes as the primary hooks, so changes don't leak into events/admin.
 */

:root {
  /* Colors */
  --m-bg: #f6f7fb;
  --m-surface: #ffffff;
  --m-surface-2: #f9fafb;
  --m-border: #e5e7eb;
  --m-border-light: rgba(229, 231, 235, 0.9);
  --m-text: #333333;
  --m-muted: #6b7280;
  --m-accent: #2563eb;
  --m-accent-ink: #0b2a6f;
  --m-accent-10: rgba(37, 99, 235, 0.10);
  --m-accent-15: rgba(37, 99, 235, 0.15);
  --m-accent-25: rgba(37, 99, 235, 0.25);
  --m-accent-35: rgba(37, 99, 235, 0.35);
  --m-accent-70: rgba(37, 99, 235, 0.70);
  --m-danger: #b91c1c;
  --m-success: #166534;
  --m-warning: #92400e;
  --m-overlay-light: rgba(17, 24, 39, 0.02);
  --m-overlay-subtle: rgba(17, 24, 39, 0.05);

  /* Typography scale */
  --m-text-xs: 0.75em;
  --m-text-sm: 0.875em;
  --m-text-base: 0.9375em;
  --m-text-md: 1.0625em;
  --m-text-lg: 1.125em;
  --m-text-xl: 1.25em;
  --m-text-2xl: 1.5em;
  --m-text-3xl: 1.625em;
  --m-text-4xl: 1.75em;
  --m-text-5xl: 2.25em;

  /* Font weights */
  --m-font-medium: 600;
  --m-font-semibold: 700;
  --m-font-bold: 800;

  /* Letter-spacing */
  --m-tracking-tight: -0.01em;
  --m-tracking-tighter: -0.02em;
  --m-tracking-tightest: -0.03em;

  /* Border radii */
  --m-radius-sm: 10px;
  --m-radius-md: 12px;
  --m-radius-lg: 14px;
  --m-radius-xl: 16px;
  --m-radius-full: 999px;

  /* Shadows */
  --m-shadow: 0 10px 30px rgba(17, 24, 39, 0.08);
  --m-shadow-sm: 0 6px 16px rgba(17, 24, 39, 0.06);
  --m-shadow-xs: 0 2px 8px rgba(37, 99, 235, 0.08);

  /* Layout */
  --m-container-max: 980px;
  --m-container-pad: 1.25rem;
}

/* ==========================================================================
   Layout
   ========================================================================== */

.m-body {
  color: var(--m-text);
  font-family: ui-sans-serif, system-ui, -apple-system, "Segoe UI", "Helvetica Neue", Arial, "Noto Sans", "Liberation Sans", sans-serif;
  /*font-size: 1.6rem; /* Reset base (Milligram sets html to 62.5%, so 1.6rem = 16px) */
  line-height: 1.55;
  background-color:#fcfdfe;
  min-height: 100vh;
}

.m-shell {
  min-height: 100vh;
  display: flex;
  flex-direction: column;
}

.m-main {
  flex: 1;
}

.m-container {
  max-width: var(--m-container-max);
  margin: 0 auto;
  padding: 2.25rem var(--m-container-pad) 2.75rem;
}

/* ==========================================================================
   Header
   ========================================================================== */

.m-header {
  background: rgba(255, 255, 255, 0.80);
  border-bottom: 1px solid var(--m-border-light);
  backdrop-filter: blur(10px);
}

.m-header-inner {
  max-width: var(--m-container-max);
  margin: 0 auto;
  padding: 0.95rem var(--m-container-pad);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
}

.m-brand {
  min-width: 0;
}

.m-brand-link {
  display: inline-block;
  color: var(--m-text);
  text-decoration: none;
  font-weight: var(--m-font-semibold);
  letter-spacing: var(--m-tracking-tighter);
  line-height: 1.2;
  font-size: var(--m-text-lg);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  max-width: 62vw;
}

.m-brand-link:hover {
  text-decoration: none;
}

.m-nav {
  display: flex;
  align-items: center;
  gap: 0.25rem;
  flex-wrap: wrap;
  justify-content: flex-end;
}

.m-nav-form {
  margin: 0;
}

.m-nav-link {
  color: var(--m-muted);
  text-decoration: none;
  padding: 0.4em 0.7em;
  border-radius: var(--m-radius-full);
  font-weight: var(--m-font-medium);
  font-size: var(--m-text-base);
}

.m-nav-link:hover {
  color: var(--m-text);
  background: var(--m-overlay-subtle);
}

.m-nav-link.is-active {
  color: var(--m-accent-ink);
  background: var(--m-accent-10);
}

button.m-nav-button,
input[type="submit"].m-nav-button {
  appearance: none;
  border: 0;
  background: transparent;
  box-shadow: none;
  line-height: 1.2;
  height: auto;
  margin: 0;
  color: var(--m-muted);
}

button.m-nav-button:hover,
button.m-nav-button:focus,
input[type="submit"].m-nav-button:hover,
input[type="submit"].m-nav-button:focus {
  color: var(--m-text);
  background: var(--m-overlay-subtle);
  outline: none;
}

.m-link-button {
  /*appearance: none;
  border: 0;
  background: transparent;
  box-shadow: none;
  color: var(--m-accent);
  font: inherit;
  font-weight: var(--m-font-medium);
  line-height: 1.4;
  height: auto;
  margin: 0;
  padding: 0;
  text-decoration: none;
  text-transform: none;
  letter-spacing: normal;*/
    margin-top:20px;
}

.m-link-button:hover,
.m-link-button:focus {
  /*color: var(--m-accent);
  background: transparent;
  text-decoration: underline;
  outline: none;*/
}

/* ==========================================================================
   Footer
   ========================================================================== */

.m-footer {
  border-top: 1px solid var(--m-border-light);
  background: rgba(255, 255, 255, 0.70);
}

.m-footer-inner {
  max-width: var(--m-container-max);
  margin: 0 auto;
  padding: 1rem var(--m-container-pad);
  color: var(--m-muted);
}

.m-site-footer {
  display: flex;
  align-items: center;
  gap: 1.25rem;
  padding: 0.25rem 0 1rem;
  margin-bottom: 1rem;
  border-bottom: 1px solid var(--m-border);
}

.m-site-footer__logo img {
  display: block;
  max-width: 180px;
  max-height: 72px;
  width: auto;
  height: auto;
}

.m-site-footer__info {
  font-size: var(--m-text-sm);
  line-height: 1.6;
}

.m-footer-meta p {
  margin: 0;
}

/* ==========================================================================
   Card (main content container)
   ========================================================================== */

.m-card {
  background: var(--m-surface);
  border: 1px solid var(--m-border);
  border-radius: var(--m-radius-lg);
  box-shadow: var(--m-shadow);
  padding: 1.75rem 1.6rem;
}

.m-card > :last-child {
  margin-bottom: 0;
}

.m-handoff-banner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  margin: 0 0 1rem;
  padding: 0.95rem 1rem;
  border: 1px solid var(--m-accent-25);
  border-radius: var(--m-radius-md);
  background: var(--m-accent-10);
}

.m-card .m-handoff-banner p {
  margin: 0.2rem 0 0;
}

.m-handoff-banner__content {
  min-width: 0;
}

.m-handoff-banner .button {
  margin: 0;
  flex-shrink: 0;
}

/* ==========================================================================
   Typography
   ========================================================================== */

.m-card h1 {
  font-size: var(--m-text-5xl);
  margin: 0 0 0.75em;
  letter-spacing: var(--m-tracking-tightest);
  line-height: 1.2;
}

.m-card h2 {
  font-size: var(--m-text-3xl);
  margin: 1.25em 0 0.5em;
  letter-spacing: var(--m-tracking-tighter);
  line-height: 1.25;
}

.m-card h3 {
  font-size: var(--m-text-xl);
  font-weight: var(--m-font-semibold);
  margin: 1.25em 0 0.5em;
  letter-spacing: var(--m-tracking-tight);
  line-height: 1.3;
  color: var(--m-text);
}

.m-card p {
  color: var(--m-text);
  line-height: 1.6;
}

.m-card small,
.m-card .muted,
.m-card .m-muted {
  color: var(--m-muted);
}

.m-help {
  color: var(--m-muted);
  font-size: var(--m-text-m);
  margin: 0.25em 0 1em;
}

/* ==========================================================================
   Links
   ========================================================================== */

.m-card a {
  color: var(--m-accent);
  text-decoration: none;
}

.m-card a:hover {
  text-decoration: underline;
}

/* ==========================================================================
   Flash messages
   ========================================================================== */

.m-card .message {
  border-radius: var(--m-radius-md);
  border: 1px solid var(--m-border);
  background: var(--m-surface-2);
  color: var(--m-text);
  padding: 0.85rem 0.95rem;
  margin: 0 0 1rem;
  box-shadow: var(--m-shadow-sm);
}

.m-card .message.error {
  border-color: rgba(185, 28, 28, 0.25);
  background: rgba(185, 28, 28, 0.06);
  color: var(--m-danger);
}

.m-card .message.success {
  border-color: rgba(22, 101, 52, 0.25);
  background: rgba(22, 101, 52, 0.06);
  color: var(--m-success);
}

.m-card .message.warning {
  border-color: rgba(146, 64, 14, 0.25);
  background: rgba(146, 64, 14, 0.07);
  color: var(--m-warning);
}

/* ==========================================================================
   Forms
   ========================================================================== */

.m-card form {
  margin: 0;
}

.m-card label {
  font-weight: var(--m-font-semibold);
  color: var(--m-text);
  letter-spacing: var(--m-tracking-tight);
}

.m-card .m-required-marker {
  color: var(--m-danger);
  font-weight: var(--m-font-bold);
}

.m-card .m-native-required .required > label::after {
  content: " *";
  color: var(--m-danger);
  font-weight: var(--m-font-bold);
}

.m-card .m-required-copy {
  margin-bottom: 0.8rem;
}

.m-card input[type="email"],
.m-card input[type="number"],
.m-card input[type="password"],
.m-card input[type="search"],
.m-card input[type="tel"],
.m-card input[type="text"],
.m-card input[type="url"],
.m-card select,
.m-card textarea {
  border-radius: var(--m-radius-md);
  border: 1px solid rgba(148, 163, 184, 0.65);
  background: #fff;
  box-shadow: 0 1px 0 var(--m-overlay-light);
}

.m-card input[type="email"]:focus,
.m-card input[type="number"]:focus,
.m-card input[type="password"]:focus,
.m-card input[type="search"]:focus,
.m-card input[type="tel"]:focus,
.m-card input[type="text"]:focus,
.m-card input[type="url"]:focus,
.m-card select:focus,
.m-card textarea:focus {
  border-color: var(--m-accent-70);
  box-shadow: 0 0 0 4px var(--m-accent-15);
}

.m-card .help {
  color: var(--m-muted);
  font-size: var(--m-text-sm);
}

.m-card .m-field-help .input {
  margin-bottom: 0.35rem;
}

.m-card .m-field-help .m-help {
  margin: 0 0 1rem;
}

.m-card fieldset {
  border: 0;
  padding: 0;
  margin: 0 0 1.8rem;
}

.m-card .m-subfieldset {
  border: 1px solid var(--m-border-light);
  border-radius: var(--m-radius-md);
  background: rgba(249, 250, 251, 0.55);
  padding: 0.95rem 1rem 0.2rem;
  margin: 0 0 1rem;
}

.m-card legend {
  display: block;
  width: 100%;
  font-size: var(--m-text-xl);
  font-weight: var(--m-font-bold);
  color: var(--m-text);
  margin: 1.75rem 0 1rem;
  padding: 0 0 0.6rem;
  border-bottom: 2px solid var(--m-border);
  letter-spacing: var(--m-tracking-tighter);
}

.m-card .m-subfieldset legend {
  font-size: var(--m-text-base);
  font-weight: var(--m-font-semibold);
  margin: 0 0 0.85rem;
  padding: 0;
  border-bottom: 0;
}

.m-card .m-checkbox-stack .input.checkbox,
.m-card .m-checkbox-stack .checkbox {
  margin-bottom: 0.45rem;
}

.m-card .m-checkbox-stack .input.checkbox:last-child,
.m-card .m-checkbox-stack .checkbox:last-child {
  margin-bottom: 0;
}

.m-card input[type="checkbox"] {
  transform: translateY(1px);
}

.m-card .input.checkbox label,
.m-card label[for*="contact_by_"],
.m-card label[for*="newsletter_"],
.m-card label[for*="third_party_"] {
  font-weight: var(--m-font-medium);
}

.m-card .m-checkbox-stack .input.checkbox label,
.m-card .m-checkbox-stack .checkbox label {
  display: flex;
  align-items: center;
  margin: 0;
  font-weight: var(--m-font-medium);
}

.m-card .m-checkbox-stack .input.checkbox label > input[type="checkbox"],
.m-card .m-checkbox-stack .checkbox label > input[type="checkbox"] {
  margin: 0 1rem 0 0;
  transform: translateY(1px);
}

/* ==========================================================================
   Buttons
   ========================================================================== */

.m-card button,
.m-card .button,
.m-card input[type="button"],
.m-card input[type="reset"],
.m-card input[type="submit"] {
  /*border-radius: var(--m-radius-full);
  border-color: var(--m-accent-25);
  background: var(--m-accent);
  color: #fff;
  font-weight: var(--m-font-bold);
  letter-spacing: var(--m-tracking-tight);
  height: auto;
  padding: 0.7rem 1.05rem;*/
}

.m-card .button.button-outline,
.m-card button.button-outline,
.m-card input[type="submit"].button-outline {
/*  background: transparent;
  color: var(--m-accent);
  border-color: var(--m-accent-35);*/
}

.m-card button:hover,
.m-card .button:hover,
.m-card input[type="submit"]:hover {
  /*filter: brightness(0.96);*/
}

/* ==========================================================================
   Tables
   ========================================================================== */

.m-card table:not(.confirm-table) {
  width: 100%;
  border-collapse: separate;
  border-spacing: 0;
}

.m-card table:not(.confirm-table) thead th {
  background: rgba(249, 250, 251, 0.9);
  border-bottom: 1px solid var(--m-border-light);
  color: var(--m-muted);
  font-weight: var(--m-font-semibold);
  font-size: var(--m-text-sm);
  text-transform: uppercase;
  letter-spacing: 0.025em;
}

.m-card table:not(.confirm-table) th,
.m-card table:not(.confirm-table) td {
  padding: 0.7rem 0.75rem;
  border-bottom: 1px solid rgba(229, 231, 235, 0.8);
  vertical-align: top;
}

.m-card table:not(.confirm-table) tbody tr:hover td {
  background: var(--m-overlay-light);
}

/* ==========================================================================
   Details/summary
   ========================================================================== */

.m-card details {
  border: 1px solid var(--m-border-light);
  border-radius: var(--m-radius-md);
  background: rgba(249, 250, 251, 0.55);
  padding: 0.75rem 0.85rem;
}

.m-card summary {
  cursor: pointer;
  color: var(--m-accent);
  font-weight: var(--m-font-bold);
}

/* ==========================================================================
   Helper classes
   ========================================================================== */

.m-actions {
  display: flex;
  gap: 0.5rem;
  flex-wrap: wrap;
  align-items: center;
  margin: 0.75rem 0 0;
}

.m-actions--top {
  margin: 0;
  justify-content: flex-end;
}

.m-page-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 1rem;
  margin-bottom: 1.25rem;
}

.m-page-head h1 {
  margin: 0;
}

.m-divider {
  height: 1px;
  background: var(--m-border-light);
  margin: 1rem 0;
}

.m-card ul {
  padding-left: 1.15rem;
}

.m-compact-list {
  margin: 0;
  padding-left: 1.15rem;
}

.m-compact-list li {
  margin: 0.2rem 0;
}

.m-subnote {
  margin: 0.25em 0 0;
  font-size: var(--m-text-sm);
  color: var(--m-muted);
}

.m-details {
  margin: 0.5rem 0 0;
}

.m-inner-table {
  margin-top: 0.75rem;
}

.m-table-subrow {
  padding-top: 0 !important;
}

.m-recaptcha {
  margin: 1rem 0;
}

.m-stack {
  display: grid;
  gap: 0.9rem;
}

.m-split {
  display: grid;
  gap: 1.25rem;
  margin-top: 1.25rem;
}

.m-primary-cta {
  width: 100%;
}

/* ==========================================================================
   Confirmation grid
   ========================================================================== */

.m-confirm-grid {
  display: grid;
  grid-template-columns: 1.15fr 0.85fr;
  gap: 1.25rem;
  align-items: start;
}

.m-confirm-side {
  position: sticky;
  top: 1rem;
  align-self: start;
}

/* ==========================================================================
   Panel (inset box)
   ========================================================================== */

.m-panel {
  border: 1px solid var(--m-border-light);
  border-radius: var(--m-radius-lg);
  background: rgba(249, 250, 251, 0.75);
  padding: 1.1rem 1rem;
}

.m-panel h3 {
  margin-top: 0;
}

.m-card h3.m-panel-title {
  font-size: var(--m-text-4xl);
  font-weight: var(--m-font-bold);
  letter-spacing: var(--m-tracking-tightest);
  line-height: 1.15;
  margin: 0 0 0.5em;
}

.m-panel h3 + .m-compact-list {
  margin-top: 0.35rem;
  margin-bottom: 0.9rem;
}

.m-panel .m-compact-list + .m-divider {
  margin-top: 1rem;
}

.m-panel p {
  margin-bottom: 0.9rem;
}

/* ==========================================================================
   Total display
   ========================================================================== */

.m-total {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
  padding: 0.6rem 0.75rem;
  border-radius: var(--m-radius-md);
  border: 1px solid var(--m-border-light);
  background: rgba(255, 255, 255, 0.75);
  margin: 0.75rem 0 0.6rem;
}

.m-total-label {
  color: var(--m-muted);
  font-weight: var(--m-font-semibold);
  letter-spacing: var(--m-tracking-tight);
  font-size: var(--m-text-base);
}

.m-total-value {
  font-weight: var(--m-font-bold);
  letter-spacing: var(--m-tracking-tighter);
  font-size: var(--m-text-2xl);
  font-variant-numeric: tabular-nums;
  color: var(--m-text);
}

/* ==========================================================================
   Payment breakdown table
   ========================================================================== */

.m-payment-breakdown {
  width: 100%;
  border-collapse: separate;
  border-spacing: 0;
  border: 1px solid var(--m-border-light);
  border-radius: var(--m-radius-md);
  background: rgba(255, 255, 255, 0.75);
  margin: 0.75rem 0 0.6rem;
  overflow: hidden;
}

.m-payment-breakdown th,
.m-payment-breakdown td {
  padding: 0.55rem 0.75rem;
  vertical-align: top;
}

.m-payment-breakdown th {
  text-align: left;
  font-weight: var(--m-font-medium);
  color: var(--m-text);
}

.m-payment-breakdown td {
  text-align: right;
  font-variant-numeric: tabular-nums;
  white-space: nowrap;
}

.m-payment-breakdown tr + tr th,
.m-payment-breakdown tr + tr td {
  border-top: 1px solid var(--m-border-light);
}

.m-payment-breakdown .m-payment-total th {
  color: var(--m-muted);
  font-weight: var(--m-font-semibold);
}

.m-payment-breakdown .m-payment-total td {
  font-weight: var(--m-font-bold);
  font-size: var(--m-text-lg);
}

/* ==========================================================================
   Payment section
   ========================================================================== */

.m-payment {
  display: grid;
  gap: 1.5rem;
  align-items: start;
}

.m-payment-hero h1 {
  margin-bottom: 0.35rem;
}

.m-kicker {
  text-transform: uppercase;
  letter-spacing: 0.12em;
  font-weight: var(--m-font-semibold);
  font-size: var(--m-text-xs);
  color: var(--m-muted);
  margin: 0 0 0.35em;
}

.m-payment-features {
  list-style: none;
  padding: 0;
  margin: 1rem 0 0;
  display: grid;
  gap: 0.6rem;
}

.m-payment-features li {
  display: flex;
  align-items: flex-start;
  gap: 0.6rem;
  font-weight: var(--m-font-medium);
}

.m-payment-features li::before {
  content: "✓";
  color: var(--m-success);
  font-weight: var(--m-font-bold);
  margin-top: 0.1rem;
}

.m-payment-panel {
  border: 1px solid var(--m-border-light);
  border-radius: var(--m-radius-xl);
  background: rgba(249, 250, 251, 0.85);
  padding: 1.25rem 1.1rem;
}

.m-payment-note {
  margin: 0.35rem 0 1rem;
}

.m-payment-cta {
  font-size: 1em;
  padding: 0.75em 1em;
}

.m-payment-footnote {
  margin-top: 0.75em;
  font-size: var(--m-text-sm);
}

/* ==========================================================================
   Choice box
   ========================================================================== */

.m-choice {
  border: 1px solid var(--m-border-light);
  border-radius: var(--m-radius-md);
  background: rgba(255, 255, 255, 0.7);
  padding: 0.85rem 0.9rem 0.2rem;
}

.m-choice strong {
  display: inline-block;
  margin-bottom: 0.2rem;
}

.m-choice .input {
  margin-bottom: 0.25rem;
}

.m-subscription-fieldset > .m-split {
  grid-column: 1 / -1;
}

.m-subscription-fieldset .m-panel,
.m-subscription-fieldset .m-choice .input,
.m-subscription-fieldset .m-choice select {
  width: 100%;
}

/* ==========================================================================
   Confirmation tables
   ========================================================================== */

.membership-confirm .confirm-table {
  width: 100%;
  table-layout: fixed;
  border-collapse: separate;
  border-spacing: 0;
  margin-bottom: 1.5rem;
}

.membership-confirm .confirm-table th {
  width: 240px;
  color: var(--m-muted);
  font-weight: var(--m-font-medium);
  white-space: normal;
  overflow-wrap: anywhere;
  word-break: break-word;
}

.membership-confirm .confirm-table td,
.membership-confirm .confirm-table th {
  padding: 0.6rem 0.4rem;
  vertical-align: top;
}

.membership-confirm .confirm-table td {
  padding-left: 1.6rem;
}

.membership-confirm .confirm-table tr + tr th,
.membership-confirm .confirm-table tr + tr td {
  border-top: 1px solid #eef2f7;
}

/* ==========================================================================
   Dashboard
   ========================================================================== */

.m-dashboard-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 0.75rem;
  margin-top: 1.25rem;
}

.m-dashboard-card {
  display: block;
  padding: 1rem 1.1rem;
  border: 1px solid var(--m-border);
  border-radius: var(--m-radius-sm);
  background: var(--m-surface-2);
  text-decoration: none;
  color: var(--m-text);
  transition: border-color 0.15s, box-shadow 0.15s;
}

.m-dashboard-card:hover {
  border-color: var(--m-accent-35);
  box-shadow: var(--m-shadow-xs);
  text-decoration: none;
}

.m-dashboard-card strong {
  display: block;
  font-size: var(--m-text-md);
  margin-bottom: 0.2em;
}

.m-dashboard-card span {
  display: block;
  font-size: var(--m-text-base);
  color: var(--m-muted);
  line-height: 1.45;
}

.m-nav-list {
  list-style: none;
  padding: 0;
  margin: 1.25em 0 0;
}

.m-nav-list li {
  margin: 0;
}

.m-nav-list li + li {
  border-top: 1px solid var(--m-border);
}

.m-nav-list li a {
  display: block;
  padding: 0.875em 0.25em;
  font-weight: var(--m-font-medium);
  font-size: var(--m-text-md);
}

/* ==========================================================================
   Responsive: Mobile (max 640px)
   ========================================================================== */

@media screen and (max-width: 640px) {
  .m-header-inner {
    padding: 0.85rem 1rem;
  }

  .m-container {
    padding: 1.4rem 1rem 2rem;
  }

  .m-card {
    padding: 1.25rem 1.1rem;
  }

  .m-card h1 {
    font-size: var(--m-text-4xl);
  }

  .m-page-head {
    flex-direction: column;
    align-items: stretch;
    gap: 0.75rem;
  }

  .m-actions--top {
    justify-content: flex-start;
  }

  .m-confirm-grid {
    grid-template-columns: 1fr;
  }

  .m-confirm-side {
    position: static;
  }

  .membership-confirm .confirm-table th {
    width: 160px;
  }
}

/* ==========================================================================
   Responsive: Tablet+ (min 540px)
   ========================================================================== */

@media screen and (min-width: 540px) {
  .m-dashboard-grid {
    grid-template-columns: repeat(3, 1fr);
  }
}

/* ==========================================================================
   Responsive: Medium screens (min 900px)
   ========================================================================== */

@media screen and (min-width: 900px) {
  .m-split {
    grid-template-columns: 1fr 1fr;
  }

  .m-payment {
    grid-template-columns: minmax(0, 1.2fr) minmax(0, 0.8fr);
  }
}

/* ==========================================================================
   Responsive: Large screens (min 1100px)
   ========================================================================== */

@media screen and (min-width: 1100px) {
  :root {
    --m-container-max: 1160px;
  }
}

/* ==========================================================================
   Responsive: Wide screens (min 1200px)
   ========================================================================== */

@media screen and (min-width: 1200px) {
  .m-card fieldset {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 0.9rem 1.25rem;
    align-items: start;
  }

  .m-card legend,
  .m-card fieldset > p,
  .m-card fieldset > details,
  .m-card fieldset > .m-actions,
  .m-card fieldset .input.checkbox,
  .m-card fieldset .input.radio,
  .m-card fieldset .input.file {
    grid-column: 1 / -1;
  }
}

@media screen and (max-width: 639px) {
  .m-site-footer {
    flex-direction: column;
    align-items: stretch;
  }

  .m-handoff-banner {
    align-items: flex-start;
    flex-direction: column;
  }
}

/* ==========================================================================
   Responsive: Extra-wide screens (min 1400px)
   ========================================================================== */

@media screen and (min-width: 1400px) {
  :root {
    --m-container-max: 1320px;
    --m-container-pad: 1.75rem;
  }

  .m-confirm-grid {
    grid-template-columns: 1.25fr 0.75fr;
    gap: 1.5rem;
  }

  .membership-confirm .confirm-table th {
    width: 280px;
  }
}