/**
 * Slate & Summit — Design System
 * Reusable ss-* classes for pages, posts, archives, and future Plotboard conversions.
 * Depends on design tokens defined in main.css (:root).
 */

/* ==========================================================================
   1. Design tokens (layout aliases)
   ========================================================================== */

.slate-summit-theme {
  --ss-container-padding: var(--ss-margin-desk);
  --ss-section-padding-y: var(--ss-sp-2xl);
  --ss-section-padding-y-sm: var(--ss-sp-xl);
}

/* ==========================================================================
   2. Base / reset (theme scope)
   ========================================================================== */

.slate-summit-theme .ss-content img,
.slate-summit-theme .ss-article img,
.slate-summit-theme .ss-card img {
  max-width: 100%;
  height: auto;
}

/* ==========================================================================
   3. Typography
   ========================================================================== */

.slate-summit-theme .ss-eyebrow {
  display: inline-block;
  font-family: var(--ss-sans);
  font-size: var(--ss-label);
  font-weight: var(--ss-w-semibold);
  letter-spacing: var(--ss-tracking-label);
  text-transform: uppercase;
  color: var(--ss-amber);
}

.slate-summit-theme .ss-eyebrow--muted {
  color: var(--ss-grey);
  letter-spacing: var(--ss-tracking-label-tight);
}

.slate-summit-theme .ss-heading-xl {
  font-family: var(--ss-serif);
  font-weight: var(--ss-w-medium);
  font-size: clamp(40px, 8vw, var(--ss-display-2));
  line-height: var(--ss-lh-display);
  letter-spacing: var(--ss-tracking-display);
  color: var(--ss-fg-1);
  text-wrap: balance;
}

.slate-summit-theme .ss-heading-lg {
  font-family: var(--ss-serif);
  font-weight: var(--ss-w-medium);
  font-size: clamp(32px, 6vw, var(--ss-h1));
  line-height: var(--ss-lh-headline);
  letter-spacing: -0.02em;
  color: var(--ss-fg-1);
  text-wrap: balance;
}

.slate-summit-theme .ss-heading-md {
  font-family: var(--ss-sans);
  font-weight: var(--ss-w-semibold);
  font-size: var(--ss-h3);
  line-height: 1.3;
  color: var(--ss-fg-1);
}

.slate-summit-theme .ss-text-lg {
  font-size: var(--ss-body-lg);
  line-height: var(--ss-lh-body);
  color: var(--ss-fg-2);
}

.slate-summit-theme .ss-text-body {
  font-size: var(--ss-body);
  line-height: var(--ss-lh-body);
  color: var(--ss-fg-2);
}

.slate-summit-theme .ss-text-sm {
  font-size: var(--ss-caption);
  line-height: var(--ss-lh-caption);
  color: var(--ss-fg-3);
}

.slate-summit-theme .ss-meta {
  font-size: var(--ss-caption);
  letter-spacing: 0.04em;
  color: var(--ss-grey);
}

/* ==========================================================================
   4. Layout containers
   ========================================================================== */

.slate-summit-theme .ss-container {
  width: 100%;
  max-width: var(--ss-content-max);
  margin-left: auto;
  margin-right: auto;
  padding-left: var(--ss-container-padding);
  padding-right: var(--ss-container-padding);
}

.slate-summit-theme .ss-container--narrow {
  max-width: var(--ss-reading-max);
}

.slate-summit-theme .ss-container--wide {
  max-width: var(--ss-content-max);
}

.slate-summit-theme .ss-section {
  padding-top: var(--ss-section-padding-y);
  padding-bottom: var(--ss-section-padding-y);
  position: relative;
}

.slate-summit-theme .ss-section--sm {
  padding-top: var(--ss-section-padding-y-sm);
  padding-bottom: var(--ss-section-padding-y-sm);
}

.slate-summit-theme .ss-section--warm {
  background: var(--ss-bg-2);
}

.slate-summit-theme .ss-section--dark {
  background: var(--ss-bg-dark);
  color: var(--ss-fg-on-dark);
}

.slate-summit-theme .ss-section--dark .ss-heading-lg,
.slate-summit-theme .ss-section--dark .ss-heading-md,
.slate-summit-theme .ss-section--dark .ss-card__title {
  color: var(--ss-fg-on-dark);
}

.slate-summit-theme .ss-section--dark .ss-text-lg,
.slate-summit-theme .ss-section--dark .ss-text-body,
.slate-summit-theme .ss-section--dark .ss-card__excerpt {
  color: var(--ss-fg-on-dark-2);
}

.slate-summit-theme .ss-section--dark .ss-card__meta,
.slate-summit-theme .ss-eyebrow--on-dark {
  color: var(--ss-fg-on-dark-3);
}

.slate-summit-theme .ss-section--dark .ss-eyebrow:not(.ss-eyebrow--on-dark) {
  color: var(--ss-amber);
}

.slate-summit-theme .ss-card--on-dark {
  background: var(--ss-bg-dark-2);
  border-color: rgba(245, 243, 238, 0.12);
}

.slate-summit-theme .ss-card--on-dark:hover {
  transform: translateY(-2px);
}

.slate-summit-theme .ss-card--on-dark .ss-card__title {
  color: var(--ss-fg-on-dark);
}

.slate-summit-theme .ss-card--on-dark .ss-card__excerpt {
  color: var(--ss-fg-on-dark-2);
}

.slate-summit-theme .ss-button-outline--on-dark {
  color: var(--ss-fg-on-dark);
  border-color: rgba(245, 243, 238, 0.45);
}

.slate-summit-theme .ss-button-outline--on-dark:hover {
  background: rgba(245, 243, 238, 0.08);
  border-color: var(--ss-fg-on-dark);
  color: var(--ss-fg-on-dark);
}

.slate-summit-theme .ss-list-on-dark {
  margin: var(--ss-sp-md) 0 0;
  padding-left: 1.25em;
  color: var(--ss-fg-on-dark-2);
  line-height: 1.65;
}

.slate-summit-theme .ss-list-on-dark li + li {
  margin-top: 0.35em;
}

.slate-summit-theme .ss-grid-3--spaced-top {
  margin-top: var(--ss-sp-lg);
}

.slate-summit-theme .ss-section-hd {
  margin-bottom: var(--ss-sp-lg);
  max-width: 760px;
}

.slate-summit-theme .ss-section-hd .ss-eyebrow {
  margin-bottom: var(--ss-sp-sm);
}

/* ==========================================================================
   5. Buttons
   ========================================================================== */

.slate-summit-theme .ss-button,
.slate-summit-theme .ss-button-secondary,
.slate-summit-theme .ss-button-outline {
  font-family: var(--ss-sans);
  font-size: 14px;
  font-weight: var(--ss-w-medium);
  padding: 12px 22px;
  border-radius: var(--ss-r-ui);
  letter-spacing: 0.015em;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  line-height: 1;
  text-decoration: none;
  border: none;
  cursor: pointer;
  transition: opacity var(--ss-dur-quick) var(--ss-ease), background-color var(--ss-dur-quick);
  min-height: 44px;
}

.slate-summit-theme .ss-button {
  background: var(--ss-amber);
  color: var(--ss-alpine);
}

.slate-summit-theme .ss-button:hover {
  background: #b5882e;
  opacity: 1;
}

.slate-summit-theme .ss-button-secondary {
  background: var(--ss-charcoal);
  color: var(--ss-alpine);
}

.slate-summit-theme .ss-button-outline {
  background: transparent;
  color: var(--ss-charcoal);
  border: 1px solid var(--ss-charcoal);
}

.slate-summit-theme .ss-button--lg {
  font-size: 15px;
  padding: 14px 26px;
}

.slate-summit-theme .ss-link {
  font-family: var(--ss-sans);
  font-size: 14px;
  font-weight: var(--ss-w-medium);
  color: var(--ss-amber);
  text-decoration: underline;
  text-decoration-color: var(--ss-link-underline);
  text-underline-offset: 3px;
}

.slate-summit-theme .ss-link:hover {
  text-decoration-color: var(--ss-amber);
}

/* ==========================================================================
   6. Grids
   ========================================================================== */

.slate-summit-theme .ss-grid-2,
.slate-summit-theme .ss-grid-3 {
  display: grid;
  gap: var(--ss-sp-md);
  min-width: 0;
}

.slate-summit-theme .ss-grid-2 {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.slate-summit-theme .ss-grid-3 {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.slate-summit-theme .ss-grid-2--align-start {
  align-items: start;
}

.slate-summit-theme .ss-inline-actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--ss-sp-sm);
  align-items: center;
}

/* ==========================================================================
   7. Cards
   ========================================================================== */

.slate-summit-theme .ss-card {
  background: var(--ss-bg-1);
  border: 0.5px solid var(--ss-grey-light);
  border-radius: var(--ss-r-overlay);
  padding: var(--ss-sp-md) var(--ss-sp-md);
  display: flex;
  flex-direction: column;
  gap: var(--ss-sp-sm);
  min-width: 0;
  height: 100%;
  transition: transform var(--ss-dur-standard) var(--ss-ease-out);
}

.slate-summit-theme .ss-card:hover {
  transform: translateY(-2px);
}

.slate-summit-theme .ss-card__title {
  font-family: var(--ss-serif);
  font-weight: var(--ss-w-medium);
  font-size: 22px;
  line-height: 1.2;
  color: var(--ss-fg-1);
  margin: 0;
}

.slate-summit-theme .ss-card__title a {
  color: inherit;
  text-decoration: none;
}

.slate-summit-theme .ss-card__title a:hover {
  color: var(--ss-amber);
}

.slate-summit-theme .ss-card__excerpt {
  font-size: 15px;
  line-height: 1.65;
  color: var(--ss-fg-2);
  flex: 1;
  margin: 0;
}

.slate-summit-theme .ss-card__meta {
  font-size: var(--ss-micro);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--ss-grey);
}

.slate-summit-theme .ss-card__thumb {
  margin: calc(var(--ss-sp-md) * -1) calc(var(--ss-sp-md) * -1) var(--ss-sp-sm);
  overflow: hidden;
  border-radius: var(--ss-r-overlay) var(--ss-r-overlay) 0 0;
}

.slate-summit-theme .ss-card__thumb img {
  width: 100%;
  aspect-ratio: 16 / 10;
  object-fit: cover;
  display: block;
}

/* ==========================================================================
   8. Page template styles
   ========================================================================== */

.slate-summit-theme .ss-page-hero {
  padding: var(--ss-sp-2xl) 0 var(--ss-sp-xl);
  background: linear-gradient(
    180deg,
    var(--ss-alpine) 0%,
    var(--ss-alpine-warm) 100%
  );
  border-bottom: 0.5px solid var(--ss-rule);
}

.slate-summit-theme .ss-page-hero .ss-heading-xl {
  margin: 0 0 var(--ss-sp-sm);
}

.slate-summit-theme .ss-page-hero .ss-text-lg {
  max-width: 640px;
  margin: 0;
}

.slate-summit-theme .ss-content,
.slate-summit-theme .ss-article__body {
  font-size: 17px;
  line-height: 1.75;
  color: var(--ss-fg-2);
}

.slate-summit-theme .ss-content > * + *,
.slate-summit-theme .ss-article__body > * + * {
  margin-top: 1.1em;
}

.slate-summit-theme .ss-content h2,
.slate-summit-theme .ss-article__body h2 {
  font-family: var(--ss-serif);
  font-weight: var(--ss-w-medium);
  font-size: var(--ss-h2);
  color: var(--ss-fg-1);
  margin-top: 1.6em;
  margin-bottom: 0.5em;
}

.slate-summit-theme .ss-content h3,
.slate-summit-theme .ss-article__body h3 {
  font-family: var(--ss-sans);
  font-weight: var(--ss-w-semibold);
  font-size: var(--ss-h3);
  color: var(--ss-fg-1);
  margin-top: 1.4em;
}

.slate-summit-theme .ss-content ul,
.slate-summit-theme .ss-content ol,
.slate-summit-theme .ss-article__body ul,
.slate-summit-theme .ss-article__body ol {
  list-style: revert;
  padding-left: 1.4em;
}

.slate-summit-theme .ss-content a,
.slate-summit-theme .ss-article__body a {
  color: var(--ss-link);
}

.slate-summit-theme .ss-content blockquote,
.slate-summit-theme .ss-article__body blockquote {
  border-left: 3px solid var(--ss-amber);
  padding-left: var(--ss-sp-md);
  font-family: var(--ss-serif);
  font-style: italic;
  color: var(--ss-fg-1);
}

/* Legacy page wrapper aliases (maps old content-page to design system) */
.slate-summit-theme .content-page {
  padding: var(--ss-section-padding-y) 0;
  min-height: 50vh;
}

.slate-summit-theme .content-page__inner {
  max-width: var(--ss-reading-max);
}

/* ==========================================================================
   9. Post / article template styles
   ========================================================================== */

.slate-summit-theme .ss-article {
  max-width: var(--ss-reading-max);
  margin: 0 auto;
}

.slate-summit-theme .ss-article__header {
  margin-bottom: var(--ss-sp-lg);
  padding-bottom: var(--ss-sp-md);
  border-bottom: 0.5px solid var(--ss-rule);
}

.slate-summit-theme .ss-article__header .ss-heading-xl {
  margin-bottom: var(--ss-sp-sm);
}

.slate-summit-theme .ss-article__meta {
  display: flex;
  flex-wrap: wrap;
  gap: var(--ss-sp-sm) var(--ss-sp-md);
  align-items: center;
}

.slate-summit-theme .ss-article__featured {
  margin: 0 0 var(--ss-sp-lg);
  border-radius: var(--ss-r-overlay);
  overflow: hidden;
  border: 0.5px solid var(--ss-grey-light);
}

.slate-summit-theme .ss-article__featured img {
  width: 100%;
  display: block;
  aspect-ratio: 16 / 9;
  object-fit: cover;
}

.slate-summit-theme .ss-article__footer {
  margin-top: var(--ss-sp-xl);
  padding-top: var(--ss-sp-md);
  border-top: 0.5px solid var(--ss-rule);
  display: flex;
  flex-wrap: wrap;
  gap: var(--ss-sp-md);
  justify-content: space-between;
  align-items: center;
}

/* ==========================================================================
   10. Archive / insights listing
   ========================================================================== */

.slate-summit-theme .ss-archive-header {
  padding-bottom: var(--ss-sp-lg);
  margin-bottom: var(--ss-sp-lg);
  border-bottom: 0.5px solid var(--ss-rule);
}

.slate-summit-theme .ss-archive-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: var(--ss-sp-md);
}

.slate-summit-theme .ss-pagination {
  margin-top: var(--ss-sp-xl);
  display: flex;
  justify-content: center;
  gap: var(--ss-sp-sm);
  flex-wrap: wrap;
}

.slate-summit-theme .ss-pagination .page-numbers {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 44px;
  min-height: 44px;
  padding: 0 12px;
  font-size: 14px;
  font-weight: var(--ss-w-medium);
  color: var(--ss-body-grey);
  text-decoration: none;
  border: 0.5px solid var(--ss-grey-light);
  border-radius: var(--ss-r-ui);
}

.slate-summit-theme .ss-pagination .page-numbers.current,
.slate-summit-theme .ss-pagination .page-numbers:hover {
  background: var(--ss-charcoal);
  color: var(--ss-alpine);
  border-color: var(--ss-charcoal);
}

/* ==========================================================================
   11. Tables
   ========================================================================== */

.slate-summit-theme .ss-table-wrap {
  width: 100%;
  max-width: 100%;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  border: 0.5px solid var(--ss-grey-light);
  border-radius: var(--ss-r-overlay);
  background: var(--ss-bg-1);
}

.slate-summit-theme .ss-table {
  width: 100%;
  min-width: 520px;
  border-collapse: collapse;
  font-size: 15px;
  line-height: 1.5;
}

.slate-summit-theme .ss-table th,
.slate-summit-theme .ss-table td {
  padding: 14px 16px;
  text-align: left;
  vertical-align: top;
  border-bottom: 0.5px solid var(--ss-rule);
}

.slate-summit-theme .ss-table thead th {
  font-family: var(--ss-sans);
  font-size: var(--ss-micro);
  font-weight: var(--ss-w-semibold);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--ss-grey);
  background: var(--ss-bg-2);
}

.slate-summit-theme .ss-table tbody tr:last-child td {
  border-bottom: none;
}

.slate-summit-theme .ss-table tbody tr:hover td {
  background: rgba(245, 243, 238, 0.5);
}

/* ==========================================================================
   12. Quote / testimonial
   ========================================================================== */

.slate-summit-theme .ss-quote {
  margin: 0;
  padding: var(--ss-sp-lg) 0 0;
  border-top: 0.5px solid var(--ss-rule);
}

.slate-summit-theme .ss-quote__text {
  margin: 0 0 var(--ss-sp-md);
  padding: 0 0 0 var(--ss-sp-md);
  border-left: 3px solid var(--ss-amber);
  font-family: var(--ss-serif);
  font-size: clamp(22px, 4vw, 28px);
  font-weight: var(--ss-w-medium);
  font-style: italic;
  line-height: 1.35;
  color: var(--ss-fg-1);
}

.slate-summit-theme .ss-quote__author {
  font-family: var(--ss-sans);
  font-size: var(--ss-caption);
  font-style: normal;
  letter-spacing: 0.04em;
  color: var(--ss-grey);
}

/* ==========================================================================
   13. Forms
   Use .ss-field-label on <label> — not .ss-label (homepage typography utility).
   ========================================================================== */

.slate-summit-theme form.ss-form,
.slate-summit-theme .ss-form {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: var(--ss-sp-md);
  width: 100%;
  max-width: 480px;
  margin: 0;
}

.slate-summit-theme .ss-form .ss-field {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: 8px;
  width: 100%;
  min-width: 0;
  margin: 0;
}

.slate-summit-theme .ss-form .ss-field-label,
.slate-summit-theme .ss-form label.ss-field-label {
  display: block;
  width: 100%;
  font-family: var(--ss-sans);
  font-size: var(--ss-caption);
  font-weight: var(--ss-w-semibold);
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--ss-fg-1);
  margin: 0;
}

.slate-summit-theme .ss-form .ss-input,
.slate-summit-theme .ss-form .ss-textarea,
.slate-summit-theme .ss-form .ss-select,
.slate-summit-theme .ss-form input.ss-input,
.slate-summit-theme .ss-form textarea.ss-textarea,
.slate-summit-theme .ss-form select.ss-select {
  display: block;
  width: 100%;
  max-width: 100%;
  margin: 0;
  font-family: var(--ss-sans);
  font-size: 16px;
  line-height: 1.4;
  color: var(--ss-fg-1);
  background-color: var(--ss-bg-1);
  border: 0.5px solid var(--ss-grey-light);
  border-radius: var(--ss-r-ui);
  padding: 12px 14px;
  min-height: 44px;
  box-sizing: border-box;
  -webkit-appearance: none;
  appearance: none;
  transition: border-color var(--ss-dur-quick) var(--ss-ease), box-shadow var(--ss-dur-quick);
}

.slate-summit-theme .ss-form .ss-textarea,
.slate-summit-theme .ss-form textarea.ss-textarea {
  min-height: 120px;
  resize: vertical;
}

.slate-summit-theme .ss-form .ss-select,
.slate-summit-theme .ss-form select.ss-select {
  cursor: pointer;
  padding-right: 36px;
  background-image: linear-gradient(45deg, transparent 50%, var(--ss-grey) 50%),
    linear-gradient(135deg, var(--ss-grey) 50%, transparent 50%);
  background-position: calc(100% - 18px) calc(50% + 2px), calc(100% - 12px) calc(50% + 2px);
  background-size: 6px 6px, 6px 6px;
  background-repeat: no-repeat;
}

.slate-summit-theme .ss-form .ss-input:focus,
.slate-summit-theme .ss-form .ss-textarea:focus,
.slate-summit-theme .ss-form .ss-select:focus,
.slate-summit-theme .ss-form input.ss-input:focus,
.slate-summit-theme .ss-form textarea.ss-textarea:focus,
.slate-summit-theme .ss-form select.ss-select:focus {
  outline: none;
  border-color: var(--ss-amber);
  box-shadow: 0 0 0 3px rgba(201, 151, 58, 0.2);
}

.slate-summit-theme .ss-form .ss-input::placeholder,
.slate-summit-theme .ss-form .ss-textarea::placeholder,
.slate-summit-theme .ss-form input.ss-input::placeholder,
.slate-summit-theme .ss-form textarea.ss-textarea::placeholder {
  color: var(--ss-fg-3);
}

.slate-summit-theme .ss-form > .ss-button,
.slate-summit-theme .ss-form > button.ss-button {
  align-self: flex-start;
  margin-top: var(--ss-sp-xs);
}

/* ==========================================================================
   14. Lists (checklist)
   ========================================================================== */

.slate-summit-theme .ss-checklist {
  list-style: none;
  margin: 0 0 var(--ss-sp-md);
  padding: 0;
}

.slate-summit-theme .ss-checklist li {
  position: relative;
  padding-left: 1.5em;
  margin-bottom: 0.5em;
  font-size: 15px;
  line-height: 1.55;
  color: var(--ss-fg-2);
}

.slate-summit-theme .ss-checklist li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0.45em;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--ss-amber);
}

/* ==========================================================================
   15. Style guide page helpers
   ========================================================================== */

.slate-summit-theme .ss-style-guide__nav {
  display: flex;
  flex-wrap: wrap;
  gap: var(--ss-sp-sm) var(--ss-sp-md);
  margin-top: var(--ss-sp-md);
}

.slate-summit-theme .ss-style-guide__stack {
  display: flex;
  flex-direction: column;
  gap: var(--ss-sp-lg);
}

.slate-summit-theme .ss-style-guide__sample {
  padding-bottom: var(--ss-sp-md);
  border-bottom: 0.5px solid var(--ss-rule);
}

.slate-summit-theme .ss-style-guide__sample:last-child {
  border-bottom: none;
  padding-bottom: 0;
}

.slate-summit-theme .ss-style-guide__thumb-placeholder {
  display: block;
  width: 100%;
  aspect-ratio: 16 / 10;
  background: linear-gradient(135deg, var(--ss-bg-2) 0%, var(--ss-grey-light) 100%);
}

/* ==========================================================================
   16. CTA band
   ========================================================================== */

.slate-summit-theme .ss-cta-band {
  background: var(--ss-bg-dark);
  color: var(--ss-fg-on-dark);
  padding: var(--ss-sp-2xl) 0;
  text-align: center;
}

.slate-summit-theme .ss-cta-band .ss-heading-lg {
  color: var(--ss-alpine);
  margin-bottom: var(--ss-sp-sm);
}

.slate-summit-theme .ss-cta-band .ss-text-lg {
  color: var(--ss-fg-on-dark-2);
  max-width: 560px;
  margin: 0 auto var(--ss-sp-md);
}

.slate-summit-theme .ss-cta-band__actions {
  display: flex;
  gap: var(--ss-sp-sm);
  justify-content: center;
  flex-wrap: wrap;
}

/* ==========================================================================
   17. Responsive utilities
   ========================================================================== */

@media (max-width: 1024px) {
  .slate-summit-theme {
    --ss-container-padding: 32px;
  }

  .slate-summit-theme .ss-grid-3 {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .slate-summit-theme .ss-archive-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 768px) {
  .slate-summit-theme {
    --ss-container-padding: 20px;
    --ss-section-padding-y: 72px;
  }

  .slate-summit-theme .ss-grid-2,
  .slate-summit-theme .ss-grid-3,
  .slate-summit-theme .ss-archive-grid {
    grid-template-columns: minmax(0, 1fr);
  }

.slate-summit-theme .ss-cta-band__actions .ss-button,
  .slate-summit-theme .ss-cta-band__actions .ss-button-outline {
    width: auto;
  }

  .slate-summit-theme .ss-page-hero + .ss-section .ss-button,
  .slate-summit-theme .ss-article__footer .ss-link {
    width: auto;
    justify-content: flex-start;
    text-align: left;
  }

  .slate-summit-theme .ss-card .ss-link {
    width: auto;
    min-height: auto;
    justify-content: flex-start;
  }

  .slate-summit-theme .ss-cta-band__actions {
    flex-direction: column;
    align-items: stretch;
  }

  .slate-summit-theme .ss-cta-band__actions .ss-button,
  .slate-summit-theme .ss-cta-band__actions .ss-button-outline {
    width: 100%;
  }

  .slate-summit-theme .ss-article__footer {
    flex-direction: column;
    align-items: flex-start;
  }
}

@media (max-width: 480px) {
  .slate-summit-theme {
    --ss-container-padding: 16px;
    --ss-section-padding-y: 56px;
  }

  .slate-summit-theme .ss-page-hero {
    padding-top: var(--ss-sp-xl);
    padding-bottom: var(--ss-sp-lg);
  }

  .slate-summit-theme .ss-table th,
  .slate-summit-theme .ss-table td {
    padding: 12px;
    font-size: 14px;
  }

  .slate-summit-theme .ss-inline-actions .ss-button,
  .slate-summit-theme .ss-inline-actions .ss-button-secondary,
  .slate-summit-theme .ss-inline-actions .ss-button-outline {
    width: 100%;
    justify-content: center;
  }

  .slate-summit-theme .ss-form > .ss-button,
  .slate-summit-theme .ss-form > button.ss-button {
    width: 100%;
    justify-content: center;
  }
}
