/*
 * This is a manifest file that'll be compiled into application.css.
 *
 * With Propshaft, assets are served efficiently without preprocessing steps. You can still include
 * application-wide styles in this file, but keep in mind that CSS precedence will follow the standard
 * cascading order, meaning styles declared later in the document or manifest will override earlier ones,
 * depending on specificity.
 *
 * Consider organizing styles into separate files for maintainability.
 */

:root {
  --font-ui: -apple-system, BlinkMacSystemFont, "Segoe UI", "Hiragino Sans", "Yu Gothic Medium", "Yu Gothic", "Meiryo", sans-serif;
  --font-wordmark: "Avenir Next", "Aptos", "Segoe UI", "Helvetica Neue", Arial, sans-serif;
  --font-accent-en: "Iowan Old Style", "Palatino Linotype", "URW Palladio L", Georgia, serif;

  /* Brand tokens */
  --brand-paper: #f3efe8;
  --brand-paper-strong: #f8f4ef;
  --brand-surface: #fcfaf6;
  --brand-surface-strong: #fffdf9;
  --brand-surface-soft: #f6f1ea;
  --brand-ink: #21383f;
  --brand-ink-strong: #162a30;
  --brand-muted: #69757a;
  --brand-muted-strong: #526167;
  --brand-accent: #8d6446;
  --brand-action: #2b3434;
  --brand-action-hover: #20292b;
  --brand-action-tint: #e5e8e5;
  --brand-public-canvas-start: #f6f1eb;
  --brand-public-canvas-end: #ecefed;
  --brand-app-canvas-start: #f6f2ec;
  --brand-app-canvas-end: #eef2f3;
  --brand-success: #4b6c5f;
  --brand-warning: #8b6a31;
  --brand-danger: #7d473f;
  --brand-danger-hover: #6d3d36;
  --brand-inverse-surface: #2b3434;
  --brand-inverse-surface-deep: #20292b;
  --brand-inverse-text: #f7f3ef;
  --brand-inverse-text-strong: #f5efe7;
  --brand-inverse-link: #f1d4b8;

  --brand-paper-rgb: 243, 239, 232;
  --brand-paper-strong-rgb: 248, 244, 239;
  --brand-surface-rgb: 252, 250, 246;
  --brand-surface-strong-rgb: 255, 253, 249;
  --brand-surface-soft-rgb: 246, 241, 234;
  --brand-ink-rgb: 33, 56, 63;
  --brand-ink-strong-rgb: 22, 42, 48;
  --brand-muted-rgb: 105, 117, 122;
  --brand-muted-strong-rgb: 82, 97, 103;
  --brand-accent-rgb: 141, 100, 70;
  --brand-action-rgb: 43, 52, 52;
  --brand-action-hover-rgb: 32, 41, 43;
  --brand-success-rgb: 75, 108, 95;
  --brand-warning-rgb: 139, 106, 49;
  --brand-danger-rgb: 125, 71, 63;
  --brand-inverse-text-rgb: 247, 243, 239;
  --brand-white-rgb: 255, 255, 255;
  --brand-public-glow-rgb: 226, 210, 193;
  --brand-action-glow-rgb: 229, 232, 229;

  /* Semantic tokens */
  --color-canvas: var(--brand-paper);
  --color-canvas-strong: var(--brand-paper-strong);
  --color-surface: rgba(var(--brand-surface-rgb), 0.92);
  --color-surface-strong: var(--brand-surface-strong);
  --color-surface-soft: var(--brand-surface-soft);
  --color-text: var(--brand-ink);
  --color-text-strong: var(--brand-ink-strong);
  --color-text-muted: var(--brand-muted);
  --color-text-muted-strong: var(--brand-muted-strong);
  --color-border: rgba(var(--brand-muted-strong-rgb), 0.16);
  --color-border-strong: rgba(var(--brand-ink-rgb), 0.24);
  --color-accent: var(--brand-accent);
  --color-accent-soft: rgba(var(--brand-accent-rgb), 0.14);
  --color-primary: var(--brand-action);
  --color-primary-hover: var(--brand-action-hover);
  --color-primary-soft: rgba(var(--brand-action-rgb), 0.14);
  --color-primary-tint: var(--brand-action-tint);
  --color-success: var(--brand-success);
  --color-success-soft: rgba(var(--brand-success-rgb), 0.14);
  --color-warning: var(--brand-warning);
  --color-warning-soft: rgba(var(--brand-warning-rgb), 0.16);
  --color-danger: var(--brand-danger);
  --color-danger-hover: var(--brand-danger-hover);
  --color-danger-soft: rgba(var(--brand-danger-rgb), 0.16);
  --color-inverse-surface: var(--brand-inverse-surface);
  --color-inverse-surface-deep: var(--brand-inverse-surface-deep);
  --color-inverse-text: var(--brand-inverse-text);
  --color-inverse-text-strong: var(--brand-inverse-text-strong);
  --color-inverse-link: var(--brand-inverse-link);
  --color-inverse-muted: rgba(var(--brand-inverse-text-rgb), 0.74);
  --color-inverse-border: rgba(var(--brand-white-rgb), 0.08);

  --shadow-raised: 0 18px 44px rgba(20, 33, 38, 0.08);
  --shadow-soft: 0 10px 28px rgba(20, 33, 38, 0.06);

  /* Component tokens */
  --component-button-primary-bg: var(--color-primary);
  --component-button-primary-border: var(--color-primary);
  --component-button-primary-text: rgb(var(--brand-white-rgb));
  --component-button-primary-hover-bg: var(--color-primary-hover);
  --component-button-primary-hover-border: var(--color-primary-hover);
  --component-button-primary-focus-rgb: var(--brand-action-rgb);
  --component-button-primary-shadow: 0 12px 28px rgba(var(--brand-action-rgb), 0.18);
  --component-public-body-bg:
    radial-gradient(circle at top left, rgba(var(--brand-public-glow-rgb), 0.88), transparent 36%),
    linear-gradient(180deg, var(--brand-public-canvas-start) 0%, var(--brand-public-canvas-end) 100%);
  --component-app-body-bg:
    radial-gradient(circle at top left, rgba(var(--brand-action-glow-rgb), 0.72), transparent 28%),
    linear-gradient(180deg, var(--brand-app-canvas-start) 0%, var(--brand-app-canvas-end) 100%);
  --component-public-note-bg: linear-gradient(180deg, var(--color-inverse-surface), var(--color-inverse-surface-deep));
  --component-public-note-border: var(--color-inverse-border);
  --component-public-note-text: var(--color-inverse-text);
  --component-public-note-heading: var(--color-inverse-text-strong);
  --component-public-note-link: var(--color-inverse-link);
  --component-public-note-muted: var(--color-inverse-muted);

  /* Backward-compatible aliases */
  --service-base: var(--color-canvas);
  --service-base-strong: var(--color-canvas-strong);
  --service-surface: var(--color-surface);
  --service-surface-strong: var(--color-surface-strong);
  --service-surface-soft: var(--color-surface-soft);
  --service-ink: var(--color-text);
  --service-ink-strong: var(--color-text-strong);
  --service-muted: var(--color-text-muted);
  --service-muted-strong: var(--color-text-muted-strong);
  --service-line: var(--color-border);
  --service-line-strong: var(--color-border-strong);
  --service-accent: var(--color-accent);
  --service-accent-soft: var(--color-accent-soft);
  --service-action: var(--color-primary);
  --service-action-hover: var(--color-primary-hover);
  --service-action-soft: var(--color-primary-soft);
  --service-action-tint: var(--color-primary-tint);
  --service-success: var(--color-success);
  --service-success-soft: var(--color-success-soft);
  --service-warning: var(--color-warning);
  --service-warning-soft: var(--color-warning-soft);
  --service-danger: var(--color-danger);
  --service-danger-soft: var(--color-danger-soft);
  --service-shadow: var(--shadow-raised);
  --service-shadow-soft: var(--shadow-soft);
}

html {
  background: var(--service-base);
}

body {
  background: var(--service-base);
  color: var(--service-ink);
  font-family: var(--font-ui);
  min-height: 100vh;
}

h1,
h2,
h3,
h4,
h5,
h6,
.h1,
.h2,
.h3,
.h4,
.h5,
.h6 {
  color: var(--service-ink-strong);
  letter-spacing: -0.015em;
}

p,
li,
dd {
  line-height: 1.7;
}

a {
  color: var(--service-action);
}

a:hover,
a:focus {
  color: var(--service-action-hover);
}

code {
  background: var(--service-danger-soft);
  border-radius: 0.35rem;
  color: var(--service-danger);
  padding: 0.08rem 0.35rem;
}

.text-body-secondary,
.form-text,
.navbar-text {
  color: var(--service-muted) !important;
}

.link-secondary,
.link-dark {
  color: var(--service-muted-strong) !important;
  text-decoration-thickness: 0.08em;
  text-underline-offset: 0.16em;
}

.link-secondary:hover,
.link-secondary:focus,
.link-dark:hover,
.link-dark:focus {
  color: var(--service-action) !important;
}

.public-body {
  background: var(--component-public-body-bg);
}

.app-body {
  background: var(--component-app-body-bg);
}

.public-nav,
.app-nav {
  backdrop-filter: blur(14px);
  border-color: var(--service-line) !important;
  box-shadow: 0 1px 0 rgba(255, 255, 255, 0.45);
}

.public-nav {
  background-color: rgba(249, 246, 241, 0.84);
}

.app-nav {
  background-color: rgba(246, 242, 237, 0.9);
}

.brand-wordmark {
  color: var(--service-ink-strong);
  font-family: var(--font-wordmark);
  font-size: 1.04rem;
  font-weight: 600;
  letter-spacing: 0.018em;
  line-height: 1;
}

.brand-wordmark .domain {
  color: var(--service-muted);
  font-weight: 500;
}

.brand-wordmark:hover,
.brand-wordmark:focus {
  color: var(--service-ink-strong);
}

.mobile-nav-toggle {
  align-items: center;
  background: rgba(255, 255, 255, 0.4);
  border: 1px solid var(--service-line);
  border-radius: 999px;
  color: var(--service-ink-strong);
  display: none;
  font-size: 0.92rem;
  font-weight: 600;
  gap: 0.6rem;
  padding: 0.55rem 0.9rem;
  transition: background-color 0.2s ease, border-color 0.2s ease, color 0.2s ease;
}

.mobile-nav-toggle:hover,
.mobile-nav-toggle:focus {
  background: rgba(255, 255, 255, 0.68);
  border-color: var(--service-line-strong);
  color: var(--service-action);
}

.mobile-nav-toggle-icon {
  background: currentColor;
  border-radius: 999px;
  box-shadow: 0 6px 0 currentColor, 0 -6px 0 currentColor;
  display: inline-block;
  height: 2px;
  width: 0.95rem;
}

.mobile-nav-shell {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}

.mobile-nav-brand-row {
  align-items: center;
  display: flex;
  gap: 0.75rem;
  justify-content: space-between;
}

.mobile-nav-panel {
  display: flex;
  flex-direction: column;
  gap: 0.9rem;
}

.mobile-nav-panel.is-open {
  display: flex;
}

.mobile-nav-links,
.mobile-nav-actions,
.mobile-nav-meta {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}

.mobile-nav-links .nav-link,
.mobile-nav-links .public-nav-link {
  border-radius: 1rem;
  padding: 0.8rem 0.9rem;
}

.mobile-nav-actions .btn,
.mobile-nav-meta .btn,
.mobile-nav-meta form {
  width: 100%;
}

.mobile-nav-account {
  align-self: flex-start;
  background: var(--service-action-soft);
  border-radius: 999px;
  color: var(--service-muted-strong);
  display: inline-flex;
  font-size: 0.84rem;
  font-weight: 600;
  letter-spacing: 0.01em;
  padding: 0.45rem 0.8rem;
}

.mobile-nav-subscription-link {
  align-items: center;
  display: inline-flex;
  flex-wrap: wrap;
  gap: 0.45rem;
}

.mobile-nav-subscription-caption {
  background: color-mix(in srgb, var(--service-action-soft) 72%, white);
  border-radius: 999px;
  color: var(--service-muted);
  font-size: 0.76rem;
  font-weight: 500;
  line-height: 1;
  padding: 0.28rem 0.55rem;
}

.app-nav-link,
.public-nav-link {
  color: var(--service-muted-strong);
  font-size: 0.95rem;
  transition: background-color 0.2s ease, color 0.2s ease;
}

.app-nav-link:hover,
.app-nav-link:focus,
.public-nav-link:hover,
.public-nav-link:focus {
  color: var(--service-ink-strong);
}

.app-nav-link.active,
.public-nav-link.is-active {
  color: var(--service-ink-strong);
  font-weight: 600;
}

.btn {
  border-radius: 1rem;
  font-weight: 600;
  letter-spacing: 0.01em;
}

.btn-lg {
  border-radius: 1.1rem;
}

.btn-dark {
  --bs-btn-bg: var(--component-button-primary-bg);
  --bs-btn-border-color: var(--component-button-primary-border);
  --bs-btn-color: var(--component-button-primary-text);
  --bs-btn-hover-bg: var(--component-button-primary-hover-bg);
  --bs-btn-hover-border-color: var(--component-button-primary-hover-border);
  --bs-btn-hover-color: var(--component-button-primary-text);
  --bs-btn-active-bg: var(--component-button-primary-hover-bg);
  --bs-btn-active-border-color: var(--component-button-primary-hover-border);
  --bs-btn-active-color: var(--component-button-primary-text);
  --bs-btn-focus-shadow-rgb: var(--component-button-primary-focus-rgb);
  box-shadow: var(--component-button-primary-shadow);
}

.btn-outline-dark {
  --bs-btn-color: var(--service-action);
  --bs-btn-border-color: rgba(var(--brand-action-rgb), 0.26);
  --bs-btn-hover-color: rgb(var(--brand-white-rgb));
  --bs-btn-hover-bg: var(--service-action);
  --bs-btn-hover-border-color: var(--service-action);
  --bs-btn-active-color: rgb(var(--brand-white-rgb));
  --bs-btn-active-bg: var(--service-action-hover);
  --bs-btn-active-border-color: var(--service-action-hover);
  --bs-btn-focus-shadow-rgb: var(--brand-action-rgb);
  background: rgba(255, 255, 255, 0.38);
}

.btn-outline-secondary {
  --bs-btn-color: var(--service-muted-strong);
  --bs-btn-border-color: var(--service-line-strong);
  --bs-btn-hover-color: var(--service-ink-strong);
  --bs-btn-hover-bg: rgba(255, 255, 255, 0.66);
  --bs-btn-hover-border-color: var(--service-line-strong);
  --bs-btn-active-color: var(--service-ink-strong);
  --bs-btn-active-bg: rgba(255, 255, 255, 0.8);
  --bs-btn-active-border-color: var(--service-line-strong);
  --bs-btn-focus-shadow-rgb: var(--brand-action-rgb);
  background: rgba(255, 255, 255, 0.3);
}

.btn-quiet-danger {
  --bs-btn-color: var(--service-danger);
  --bs-btn-border-color: rgba(125, 71, 63, 0.42);
  --bs-btn-hover-color: rgb(var(--brand-white-rgb));
  --bs-btn-hover-bg: var(--service-danger);
  --bs-btn-hover-border-color: var(--service-danger);
  --bs-btn-active-color: rgb(var(--brand-white-rgb));
  --bs-btn-active-bg: var(--color-danger-hover);
  --bs-btn-active-border-color: var(--color-danger-hover);
  --bs-btn-focus-shadow-rgb: 125, 71, 63;
  background: rgba(255, 255, 255, 0.34);
}

.form-control,
.form-select {
  background-color: rgba(255, 255, 255, 0.78);
  border-color: var(--service-line);
  border-radius: 1rem;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.55);
  color: var(--service-ink-strong);
  padding: 0.82rem 1rem;
}

.form-control::placeholder,
.form-select::placeholder {
  color: rgba(105, 117, 122, 0.78);
}

.form-control:focus,
.form-select:focus {
  background-color: var(--service-surface-strong);
  border-color: rgba(var(--brand-action-rgb), 0.36);
  box-shadow: 0 0 0 0.22rem var(--service-action-soft);
  color: var(--service-ink-strong);
}

.form-check-input {
  border-color: var(--service-line-strong);
}

.form-check-input:focus {
  border-color: rgba(var(--brand-action-rgb), 0.36);
  box-shadow: 0 0 0 0.22rem var(--service-action-soft);
}

.form-check-input:checked {
  background-color: var(--service-action);
  border-color: var(--service-action);
}

.alert {
  border: none;
  border-radius: 1.25rem;
  box-shadow: var(--service-shadow-soft);
}

.alert-success {
  background: var(--service-success-soft);
  color: var(--service-success);
}

.alert-warning {
  background: var(--service-warning-soft);
  color: var(--service-warning);
}

.alert-danger {
  background: var(--service-danger-soft);
  color: var(--service-danger);
}

.alert-secondary {
  background: rgba(82, 97, 103, 0.11);
  color: var(--service-muted-strong);
}

.badge.rounded-pill {
  font-weight: 600;
  letter-spacing: 0.01em;
}

.badge.text-bg-light {
  background: var(--service-surface-soft) !important;
  border: 1px solid var(--service-line);
  color: var(--service-ink) !important;
}

.service-badge {
  border: 1px solid transparent;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.45);
}

.service-badge--quiet {
  background: var(--service-surface-soft) !important;
  border-color: var(--service-line);
  color: var(--service-ink) !important;
}

.service-badge--action {
  background: var(--service-action-tint) !important;
  border-color: rgba(var(--brand-action-rgb), 0.16);
  color: var(--service-action-hover) !important;
}

.service-badge--success {
  background: var(--service-success-soft) !important;
  border-color: rgba(75, 108, 95, 0.2);
  color: var(--service-success) !important;
}

.card {
  background: rgba(252, 250, 246, 0.9);
  border: 1px solid var(--service-line);
  border-radius: 1.4rem;
  box-shadow: var(--service-shadow-soft);
}

.card-footer {
  border-top: 1px solid var(--service-line);
}

.public-surface,
.app-panel {
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.92), rgba(250, 247, 242, 0.9));
  border: 1px solid var(--service-line);
  border-radius: 1.6rem;
  box-shadow: var(--service-shadow);
}

.app-panel--hero {
  background:
    radial-gradient(circle at top left, rgba(var(--brand-action-glow-rgb), 0.88), transparent 32%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.95), rgba(246, 242, 236, 0.92));
}

.app-panel--status {
  background:
    linear-gradient(180deg, rgba(251, 249, 245, 0.96), rgba(246, 240, 232, 0.9));
}

.preparation-page-intro {
  background:
    radial-gradient(circle at top left, rgba(var(--brand-action-glow-rgb), 0.82), transparent 34%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.95), rgba(246, 242, 236, 0.92));
}

.preparation-page-intro h1 {
  font-size: clamp(1.9rem, 4.2vw, 2.75rem);
  letter-spacing: -0.03em;
}

.preparation-form {
  overflow: hidden;
}

.preparation-form-section + .preparation-form-section {
  border-top: 1px solid var(--service-line);
  margin-top: 1.6rem;
  padding-top: 1.6rem;
}

.preparation-form-header {
  margin-bottom: 1rem;
  max-width: 46rem;
}

.preparation-form-header h2 {
  margin-bottom: 0.35rem;
}

.preparation-form-note {
  background: linear-gradient(180deg, rgba(246, 241, 234, 0.86), rgba(243, 238, 230, 0.76));
  border: 1px solid var(--service-line);
  border-radius: 1.1rem;
  color: var(--service-muted-strong);
  padding: 0.95rem 1rem;
}

.preparation-form-note strong {
  color: var(--service-ink-strong);
}

.preparation-message-body {
  min-height: clamp(13rem, 34vw, 20rem);
  resize: vertical;
}

.preparation-form-footer {
  border-top: 1px solid var(--service-line);
  display: grid;
  gap: 0.9rem;
}

.preparation-submit-stack {
  display: grid;
  gap: 0.75rem;
}

.preparation-form-footer .btn,
.preparation-submit-stack .btn {
  width: 100%;
}

.public-kicker,
.service-kicker {
  color: var(--service-accent);
  font-family: var(--font-accent-en);
  font-size: 0.95rem;
  font-style: italic;
  font-weight: 600;
  letter-spacing: 0.02em;
}

.public-hero-title {
  font-size: clamp(2.05rem, 4.6vw, 3.25rem);
  letter-spacing: -0.03em;
  line-height: 1.15;
  max-width: 16ch;
}

.public-lead {
  color: var(--service-muted-strong);
  font-size: clamp(1.05rem, 1.35vw, 1.18rem);
  line-height: 1.82;
}

.public-primary-actions {
  display: grid;
  gap: 0.75rem;
}

.public-flow-step {
  background:
    linear-gradient(180deg, rgba(247, 242, 235, 0.92), rgba(244, 238, 229, 0.86));
  border: 1px solid rgba(73, 93, 99, 0.13);
  border-radius: 1.25rem;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.55);
  padding: 1rem 1.125rem;
}

.public-flow-step h2 {
  font-size: 1rem;
}

.public-muted-list {
  margin-bottom: 0;
  padding-left: 1.2rem;
}

.public-muted-list li + li {
  margin-top: 0.85rem;
}

.public-note {
  background: var(--component-public-note-bg);
  border: 1px solid var(--component-public-note-border);
  border-radius: 1.5rem;
  box-shadow: var(--service-shadow);
  color: var(--component-public-note-text);
}

.public-note h1,
.public-note h2,
.public-note h3,
.public-note h4,
.public-note h5,
.public-note h6,
.public-note .h1,
.public-note .h2,
.public-note .h3,
.public-note .h4,
.public-note .h5,
.public-note .h6 {
  color: var(--component-public-note-heading);
}

.public-note p,
.public-note li {
  color: var(--component-public-note-text);
}

.public-note a {
  color: var(--component-public-note-link);
}

.public-note .text-body-secondary {
  color: var(--component-public-note-muted) !important;
}

.public-qa + .public-qa {
  border-top: 1px solid var(--service-line);
  margin-top: 1.5rem;
  padding-top: 1.5rem;
}

.public-price-card {
  background:
    radial-gradient(circle at top left, rgba(var(--brand-action-glow-rgb), 0.72), transparent 32%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.95), rgba(246, 242, 236, 0.9));
  border: 1px solid var(--service-line);
  border-radius: 1.35rem;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.55);
}

.public-definition-list {
  display: grid;
  gap: 1rem;
  margin: 0;
}

.public-definition-list dt {
  color: var(--service-muted);
  font-size: 0.92rem;
  font-weight: 600;
  margin-bottom: 0.35rem;
}

.public-definition-list dd {
  color: var(--service-ink-strong);
  margin-bottom: 0;
}

.public-footer {
  border-top: 1px solid var(--service-line);
  margin-top: 3rem;
}

.public-footer-shell {
  display: grid;
  gap: 1.5rem;
}

.public-footer-brand,
.public-footer-support {
  max-width: 32rem;
}

.public-footer-links {
  display: grid;
  gap: 0.5rem 1.2rem;
}

.public-check-input {
  float: none;
  flex-shrink: 0;
  margin: 0.2rem 0 0;
}

.external-auth-button {
  background: rgba(255, 255, 255, 0.66);
  color: var(--service-ink-strong);
}

.public-auth-divider {
  align-items: center;
  color: var(--service-muted);
  display: flex;
  font-size: 0.86rem;
  font-weight: 600;
  gap: 0.75rem;
  line-height: 1;
}

.public-auth-divider::before,
.public-auth-divider::after {
  background: var(--service-line);
  content: "";
  flex: 1;
  height: 1px;
}

.service-pill-row {
  display: flex;
  flex-wrap: wrap;
  gap: 0.65rem;
}

.service-pill {
  align-items: center;
  background: var(--service-surface-soft);
  border: 1px solid var(--service-line);
  border-radius: 999px;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.45);
  color: var(--service-ink-strong);
  display: inline-flex;
  font-size: 0.92rem;
  font-weight: 600;
  line-height: 1;
  padding: 0.72rem 1rem;
}

.service-status-badge {
  align-items: center;
  border: 1px solid transparent;
  border-radius: 999px;
  display: inline-flex;
  font-size: 0.84rem;
  font-weight: 600;
  letter-spacing: 0.01em;
  line-height: 1;
  padding: 0.5rem 0.78rem;
}

.service-status-badge--active {
  background: var(--service-success-soft);
  border-color: rgba(75, 108, 95, 0.2);
  color: var(--service-success);
}

.service-status-badge--warning {
  background: var(--service-warning-soft);
  border-color: rgba(139, 106, 49, 0.22);
  color: var(--service-warning);
}

.service-status-badge--danger {
  background: var(--service-danger-soft);
  border-color: rgba(125, 71, 63, 0.22);
  color: var(--service-danger);
}

.service-status-badge--quiet {
  background: rgba(82, 97, 103, 0.12);
  border-color: rgba(82, 97, 103, 0.18);
  color: var(--service-muted-strong);
}

.app-status-list dt {
  color: var(--service-muted) !important;
}

.app-status-list dd {
  color: var(--service-ink-strong);
}

.recipient-option {
  background: var(--service-surface-soft);
}

.recipient-option-input {
  flex-shrink: 0;
  margin: 0.2rem 0 0;
}

.recipient-option-label {
  align-items: flex-start;
  cursor: pointer;
  display: flex;
  gap: 0.875rem;
  margin-bottom: 0;
  width: 100%;
}

.recipient-option-body {
  display: block;
  flex: 1;
  flex-shrink: 0;
  min-width: 0;
}

.record-page-actions,
.record-card-actions,
.form-footer-actions,
.recipient-picker-grid {
  display: grid;
  gap: 0.75rem;
}

.record-page-actions,
.record-page-actions .btn,
.record-card-actions,
.record-card-actions .btn,
.record-card-actions form,
.record-card-actions form .btn,
.form-footer-actions .btn,
.recipient-picker-grid {
  width: 100%;
}

.record-list-card {
  border: 1px solid var(--service-line);
  border-radius: 1.25rem;
}

.recipient-picker-card {
  background: rgba(246, 241, 234, 0.72);
  border: 1px solid var(--service-line);
  border-radius: 1.1rem;
  transition: background-color 0.2s ease, border-color 0.2s ease, box-shadow 0.2s ease;
}

.recipient-picker-card.is-selected,
.recipient-picker-card:has(.recipient-picker-input:checked) {
  background: rgba(var(--brand-action-glow-rgb), 0.82);
  border-color: rgba(var(--brand-action-rgb), 0.26);
  box-shadow: 0 10px 24px rgba(var(--brand-action-rgb), 0.08);
}

.recipient-picker-input {
  flex-shrink: 0;
  margin: 0.15rem 0 0;
}

.recipient-picker-label {
  align-items: flex-start;
  cursor: pointer;
  display: flex;
  gap: 0.875rem;
  margin-bottom: 0;
  padding: 1rem;
  width: 100%;
}

.recipient-picker-body {
  display: flex;
  flex: 1;
  flex-direction: column;
  gap: 0.3rem;
  min-width: 0;
}

.countdown-timer {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}

.countdown-timer-heading {
  color: var(--service-ink);
  font-size: clamp(1rem, 1.45vw, 1.18rem);
  font-weight: 600;
  letter-spacing: 0.01em;
  line-height: 1.45;
}

.countdown-timer-frame {
  background:
    linear-gradient(180deg, rgba(248, 244, 239, 0.98), rgba(243, 237, 228, 0.92));
  border: 1px solid var(--service-line);
  border-radius: 1.5rem;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.65);
  padding: clamp(1.5rem, 3vw, 2rem) clamp(1.5rem, 4vw, 2.75rem);
}

.countdown-timer-grid {
  align-items: start;
  display: grid;
  gap: clamp(0.85rem, 1.6vw, 1.4rem);
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.countdown-timer-unit {
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
  min-width: 0;
  padding-inline: clamp(0.35rem, 1vw, 0.85rem);
  text-align: center;
}

.countdown-timer-amount {
  color: var(--service-action-hover);
  font-family: var(--font-accent-en);
  font-size: clamp(2.1rem, 5.8vw, 4.1rem);
  font-variant-numeric: oldstyle-nums proportional-nums;
  font-weight: 500;
  letter-spacing: -0.025em;
  line-height: 0.92;
  white-space: nowrap;
}

.countdown-timer-label {
  color: var(--service-muted-strong);
  font-family: var(--font-accent-en);
  font-size: clamp(1rem, 2.3vw, 1.8rem);
  font-style: italic;
  line-height: 1.1;
}

.countdown-timer--home .countdown-timer-frame {
  background:
    radial-gradient(circle at top left, rgba(var(--brand-action-glow-rgb), 0.92), transparent 34%),
    linear-gradient(180deg, rgba(248, 250, 251, 1), rgba(241, 245, 247, 0.96));
}

.countdown-timer--home .countdown-timer-amount {
  font-size: clamp(1.95rem, 5.4vw, 3.7rem);
}

.countdown-timer--public .countdown-timer-amount {
  font-size: clamp(2rem, 5.1vw, 3.95rem);
}

.countdown-timer--home .countdown-timer-label {
  font-size: clamp(0.95rem, 2vw, 1.5rem);
}

.countdown-timer--public .countdown-timer-frame {
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.72),
    0 8px 18px rgba(var(--brand-action-rgb), 0.04);
}

.home-primary-action,
.home-section-action {
  display: grid;
  gap: 0.75rem;
}

.home-primary-action .btn,
.home-primary-action-form,
.home-primary-action-form .btn,
.home-section-action .btn,
.home-section-action-form,
.home-section-action-form .btn {
  width: 100%;
}

.home-support-section + .home-support-section {
  border-top: 1px solid var(--service-line);
  padding-top: 1rem;
}

.public-flow-divider {
  border-color: var(--service-line);
  opacity: 1;
}

@media (min-width: 576px) {
  .public-primary-actions {
    align-items: center;
    display: flex;
    flex-wrap: wrap;
  }

  .home-primary-action,
  .home-section-action {
    display: block;
  }

  .home-primary-action .btn,
  .home-primary-action-form,
  .home-primary-action-form .btn,
  .home-section-action .btn,
  .home-section-action-form,
  .home-section-action-form .btn {
    width: auto;
  }

  .form-footer-actions {
    align-items: center;
    display: flex;
    flex-direction: row;
    justify-content: space-between;
  }

  .form-footer-actions .btn {
    width: auto;
  }

  .preparation-form-footer {
    align-items: center;
    display: flex;
    justify-content: space-between;
  }

  .preparation-form-footer > .btn {
    width: auto;
  }

  .preparation-submit-stack {
    justify-items: end;
  }

  .preparation-submit-stack .btn {
    width: auto;
  }
}

@media (min-width: 768px) {
  .mobile-nav-shell {
    align-items: center;
    flex-direction: row;
    gap: 1rem;
    justify-content: space-between;
  }

  .mobile-nav-brand-row {
    flex-shrink: 0;
  }

  .mobile-nav-panel {
    align-items: center;
    display: flex !important;
    flex: 1;
    flex-direction: row;
    gap: 1rem;
    justify-content: space-between;
  }

  .mobile-nav-links {
    align-items: center;
    flex-direction: row;
    gap: 0.25rem;
  }

  .mobile-nav-panel--public {
    gap: clamp(1.5rem, 3vw, 3rem);
  }

  .mobile-nav-panel--public .mobile-nav-links {
    gap: clamp(1.1rem, 1.8vw, 1.8rem);
    margin-left: clamp(2rem, 4vw, 4rem);
  }

  .mobile-nav-actions,
  .mobile-nav-meta {
    align-items: center;
    flex-direction: row;
    gap: 0.75rem;
  }

  .mobile-nav-account {
    align-self: auto;
  }

  .mobile-nav-actions .btn,
  .mobile-nav-meta .btn,
  .mobile-nav-meta form {
    width: auto;
  }

  .mobile-nav-links .nav-link,
  .mobile-nav-links .public-nav-link {
    border-radius: 0;
    padding: initial;
  }

  .record-page-actions,
  .record-card-actions {
    width: auto;
  }

  .record-card-actions {
    align-self: stretch;
    grid-auto-flow: row;
    min-width: 11rem;
  }

  .recipient-picker-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .public-definition-list {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .public-footer-shell {
    align-items: start;
    grid-template-columns: minmax(0, 1.6fr) minmax(0, 1.1fr) minmax(15rem, 0.9fr);
  }

  .public-footer-links {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 767.98px) {
  [data-controller~="mobile-nav"].is-ready .mobile-nav-toggle {
    display: inline-flex;
  }

  [data-controller~="mobile-nav"].is-ready .mobile-nav-panel {
    display: none;
  }

  [data-controller~="mobile-nav"].is-ready .mobile-nav-panel.is-open {
    display: flex;
  }

  .app-nav-link.active,
  .public-nav-link.is-active {
    background: rgba(var(--brand-action-rgb), 0.08);
  }

  .public-surface,
  .public-note,
  .app-panel {
    border-radius: 1.25rem;
  }

  .public-hero-title {
    font-size: clamp(1.9rem, 8vw, 2.5rem);
  }

  .countdown-timer-frame {
    border-radius: 1.25rem;
    padding: 1rem 1.1rem;
  }

  .countdown-timer-grid {
    gap: 0.9rem;
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .countdown-timer-unit {
    padding-inline: 0.2rem;
  }

  .record-list-card .card-body {
    padding: 1.25rem;
  }
}

@media (max-width: 991.98px) {
  .countdown-timer-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .countdown-timer-amount,
  .countdown-timer--public .countdown-timer-amount,
  .countdown-timer--home .countdown-timer-amount {
    font-size: clamp(2.3rem, 10vw, 4.4rem);
  }
}
