:root {
  --font-sans: "Hiragino Kaku Gothic ProN", "Yu Gothic", Meiryo, sans-serif;
  --color-bg: #eef1f5;
  --color-surface: #ffffff;
  --color-surface-alt: #fafcff;
  --color-surface-soft: #fcfdff;
  --color-border: #dfe5ee;
  --color-border-strong: #d8dfeb;
  --color-border-hover: #c9d6ea;
  --color-text: #333333;
  --color-text-soft: #5d6778;
  --color-text-heading: #2f3b52;
  --color-primary: #3f6fc9;
  --color-primary-strong: #315cae;
  --shadow-shell: 0 6px 18px rgba(31, 45, 61, 0.06);
  --shadow-card: 0 3px 10px rgba(31, 45, 61, 0.035);
  --shadow-card-hover: 0 8px 18px rgba(31, 45, 61, 0.06);
  --radius-lg: 18px;
  --radius-md: 12px;
  --layout-max-width: 1200px;
  --layout-gutter: 20px;
  --layout-chrome-height: 64px;
  --font-size-field-label: 14px;
  --font-size-field-hint: 12px;
  --font-size-control: 14px;
  --font-size-control-base: 16px;
  --font-size-button: 15px;
  --font-size-heading-page: 26px;
  --font-size-heading-page-mobile: 24px;
  --font-size-heading-card: 20px;
  --font-size-heading-section: 18px;
  --font-size-heading-list: 18px;
  --space-page-x: 16px;
  --space-shell-y: 28px;
  --space-shell-x: 32px;
  --space-section: 34px;
  --space-grid: 18px;
  --order-aside-width: 300px;
}

* {
  box-sizing: border-box;
}

body {
  margin: 0;
  font-family: var(--font-sans);
  background: linear-gradient(180deg, #f6f8fb 0%, var(--color-bg) 100%);
  color: var(--color-text);
}

body[data-layout-base="sticky-chrome"] {
  display: flex;
  flex-direction: column;
  min-height: 100vh;
}

a {
  color: inherit;
  text-decoration: none;
}

.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

.mock-page {
  width: 100%;
  max-width: var(--layout-max-width);
  margin: 0 auto;
  padding: 0 var(--layout-gutter);
}

.app-header__inner,
.app-footer__inner {
  max-width: var(--layout-max-width);
  margin: 0 auto;
  padding-left: var(--layout-gutter);
  padding-right: var(--layout-gutter);
}

.app-header,
.app-footer {
  position: sticky;
  z-index: 100;
  background: rgba(255, 255, 255, 0.96);
  backdrop-filter: blur(10px);
}

.app-header__inner {
  padding-top: 10px;
  padding-bottom: 8px;
}

.app-header__top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px 24px;
  flex-wrap: wrap;
}

.app-brand {
  display: inline-flex;
  align-items: baseline;
  gap: 2px;
  font-size: 28px;
  font-weight: 700;
  letter-spacing: 0.03em;
  color: var(--color-primary);
  line-height: 1.1;
}

.app-brand__suffix {
  letter-spacing: 0.12em;
  margin-left: 4px;
  font-size: 0.82em;
}

.app-brand--mg {
  flex-wrap: wrap;
  gap: 10px 18px;
}

.app-brand__system {
  color: var(--color-text-heading);
  font-size: 0.82em;
  font-weight: 700;
  letter-spacing: 0.04em;
}

.status-bar {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 14px;
}

.status-link {
  display: inline-flex;
  align-items: baseline;
  gap: 8px;
  min-height: 24px;
  color: var(--color-text-heading);
  transition: color 0.15s ease;
}

.status-link:hover {
  color: var(--color-text-heading);
}

.status-link__label {
  font-size: 11px;
  color: var(--color-text-soft);
}

.status-link__value {
  font-size: 14px;
  font-weight: 700;
}

.status-link__anchor {
  color: var(--color-primary);
}

.status-link__anchor:hover {
  color: var(--color-primary-strong);
}

.link-list {
  display: flex;
  flex-wrap: wrap;
  gap: 0;
  margin-top: 10px;
  padding-top: 10px;
  border-top: 1px solid #edf2f8;
}

.link-list__item {
  display: inline-flex;
  align-items: center;
  min-height: 30px;
  padding: 0 12px;
  color: var(--color-text-heading);
  font-size: 13px;
  font-weight: 600;
  white-space: nowrap;
  transition: color 0.15s ease, background-color 0.15s ease;
}

.link-list__form {
  display: inline-flex;
  margin: 0;
}

.link-list__button {
  appearance: none;
  border: 0;
  background: transparent;
  font-family: inherit;
  cursor: pointer;
}

.link-list__item + .link-list__item {
  position: relative;
}

.link-list__item + .link-list__form .link-list__item {
  position: relative;
}

.link-list__item + .link-list__item::before,
.link-list__item + .link-list__form .link-list__item::before {
  content: "";
  position: absolute;
  left: 0;
  top: 50%;
  width: 1px;
  height: 14px;
  background: #dbe3ef;
  transform: translateY(-50%);
}

.link-list__item:hover {
  background: #f7faff;
  color: var(--color-primary);
}

.app-content {
  flex: 1 0 auto;
  padding-top: 28px;
  padding-bottom: 36px;
}

.app-content > .mock-page {
  display: grid;
  gap: var(--space-section);
}

.content-section + .content-section {
  margin-top: var(--space-section);
}

.section-heading {
  margin: 0 0 16px;
  padding: 14px 18px;
  border: 1px solid var(--color-border-strong);
  border-radius: var(--radius-md);
  background: var(--color-surface-alt);
  font-size: var(--font-size-heading-section);
  font-weight: 700;
  color: var(--color-text-heading);
}

.section-heading--split {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: 12px;
}

.section-heading__title {
  margin: 0;
  font: inherit;
  color: inherit;
}

.section-heading__meta {
  flex: 0 0 auto;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 30px;
  padding: 0 14px;
  border: 0;
  border-radius: 999px;
  background: #eef4ff;
  color: var(--color-primary);
  font-size: 15px;
  font-weight: 700;
}

.tile-grid {
  display: grid;
  gap: var(--space-grid);
}

.tile-grid--cards {
  grid-template-columns: repeat(3, 1fr);
}

.tile-grid--actions {
  grid-template-columns: repeat(2, 1fr);
  gap: 22px;
}

.tile {
  display: flex;
  flex-direction: column;
  justify-content: center;
  min-height: 162px;
  padding: 22px 18px;
  border: 1px solid #dbe3f0;
  border-radius: var(--radius-lg);
  background: var(--color-surface);
  box-shadow: var(--shadow-card);
  text-align: center;
  transition: transform 0.15s ease, box-shadow 0.15s ease, border-color 0.15s ease;
}

.tile:hover {
  transform: translateY(-2px);
  box-shadow: var(--shadow-card-hover);
  border-color: var(--color-border-hover);
}

.tile--action {
  align-items: center;
  min-height: 146px;
  background: linear-gradient(to bottom, #ffffff, #fafcff);
  font-size: 24px;
  font-weight: 700;
  color: var(--color-primary);
  text-decoration: underline;
}

.tile__meta {
  font-size: 24px;
  font-weight: 700;
  color: var(--color-primary);
  text-decoration: underline;
  margin-bottom: 16px;
}

.tile__label,
.tile__text {
  color: var(--color-primary);
  text-decoration: underline;
  line-height: 1.6;
  font-size: 15px;
  font-weight: 600;
}

.app-footer {
  margin-top: auto;
  bottom: 0;
  border-top: 1px solid rgba(223, 229, 238, 0.96);
  box-shadow: 0 -4px 14px rgba(31, 45, 61, 0.04);
}

.app-header {
  top: 0;
  border-bottom: 1px solid rgba(223, 229, 238, 0.92);
  box-shadow: 0 4px 14px rgba(31, 45, 61, 0.05);
}

.app-header__inner,
.app-footer__inner {
  min-height: var(--layout-chrome-height);
  display: flex;
  flex-direction: column;
  justify-content: center;
}

.app-footer__inner {
  flex-direction: row;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
}

.app-footer {
  color: #4a5568;
  font-size: 13px;
}

.app-footer__brand {
  font-weight: 700;
  color: var(--color-text-heading);
}

.app-footer__meta {
  font-size: 12px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--color-text-soft);
}

.page-intro {
  display: block;
  padding: 16px 20px;
  border: 1px solid var(--color-border);
  border-radius: 16px;
  background: linear-gradient(135deg, #ffffff, #f6faff);
  box-shadow: var(--shadow-card);
}

.page-intro__eyebrow {
  display: inline-block;
  margin-bottom: 4px;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.08em;
  color: var(--color-primary);
}

.page-intro__title {
  margin: 0;
  font-size: var(--font-size-heading-page);
  line-height: 1.2;
  color: var(--color-text-heading);
}

.page-intro__text {
  margin: 8px 0 0;
  font-size: 14px;
  line-height: 1.8;
  color: var(--color-text-soft);
}

.page-intro__meta {
  min-width: 240px;
  padding: 13px 16px;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  background: linear-gradient(to bottom, #ffffff, #f8fbff);
  box-shadow: var(--shadow-card);
}

.page-intro__meta-label {
  display: block;
  margin-bottom: 6px;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.08em;
  color: var(--color-primary);
}

.page-intro__meta-value {
  margin: 0;
  font-size: 20px;
  font-weight: 700;
  color: var(--color-text-heading);
  line-height: 1.45;
}

.page-actions {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 12px;
  margin-top: -10px;
}

.page-support-row {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 12px;
  margin-top: -10px;
}

.page-status-card {
  min-width: 240px;
  display: grid;
  gap: 6px;
  padding: 13px 16px;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  background: linear-gradient(to bottom, #ffffff, #f8fbff);
  box-shadow: var(--shadow-card);
}

.page-status-line {
  display: inline-flex;
  align-items: baseline;
  justify-content: flex-end;
  gap: 10px;
  min-height: 32px;
  color: var(--color-text-heading);
}

.page-status-card__label {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.08em;
  color: var(--color-primary);
}

.page-status-card__value {
  font-size: 20px;
  font-weight: 700;
  line-height: 1.35;
  color: var(--color-text-heading);
}

.flow-steps {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 12px;
  margin-bottom: 28px;
}

.flow-step {
  padding: 16px 18px;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  background: #f7faff;
}

.flow-step--active {
  border-color: #aec4ef;
  background: linear-gradient(135deg, #f7fbff, #edf4ff);
  box-shadow: var(--shadow-card);
}

.flow-step--complete {
  background: linear-gradient(135deg, #ffffff, #f5f9ff);
}

.flow-step__label {
  display: inline-block;
  margin-bottom: 6px;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.08em;
  color: var(--color-primary);
}

.flow-step__title {
  margin: 0;
  font-size: 18px;
  color: var(--color-text-heading);
}

.order-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) var(--order-aside-width);
  gap: 24px;
  align-items: start;
}

.stack {
  display: grid;
  gap: 22px;
}

.panel {
  border: 1px solid var(--color-border);
  border-radius: 18px;
  background: #ffffff;
  box-shadow: var(--shadow-card);
  overflow: hidden;
}

.panel__header {
  padding: 20px 22px 16px;
  border-bottom: 1px solid #edf1f6;
  background: linear-gradient(to bottom, #ffffff, #fbfcfe);
}

.panel__eyebrow {
  display: inline-block;
  margin-bottom: 6px;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.08em;
  color: var(--color-primary);
}

.panel__title {
  margin: 0;
  font-size: 28px;
  color: var(--color-text-heading);
}

.panel__text {
  margin: 8px 0 0;
  font-size: 14px;
  line-height: 1.8;
  color: var(--color-text-soft);
}

.panel__body {
  padding: 22px;
}

.form-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 18px 20px;
}

.form-grid--single {
  grid-template-columns: 1fr;
}

.product-info-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(360px, 0.48fr);
  gap: 18px;
  align-items: start;
  margin: 18px 0 22px;
}

.product-info-layout--edit {
  grid-template-columns: 1fr;
}

.product-customer-panel {
  margin: 0;
}

.product-submission-panel {
  margin: 0;
}

.product-submission-panel .panel__header {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 4px 16px;
  align-items: center;
  padding: 16px 22px 14px;
}

.product-submission-panel .panel__eyebrow,
.product-submission-panel .panel__title {
  grid-column: 1;
}

.product-submission-panel .panel__eyebrow {
  margin-bottom: 0;
}

.product-submission-panel .panel__header .button {
  grid-column: 2;
  grid-row: 1 / 3;
  justify-self: end;
  align-self: center;
}

.product-submission-panel .panel__body {
  display: grid;
  gap: 0;
  background: var(--color-surface);
}

.product-submission-panel .submission-confirm-box {
  margin-top: 16px;
  padding: 14px 16px;
}

.product-submission-panel .submission-confirm-box__textarea {
  min-height: 88px;
}

.product-customer-panel .panel__title,
.product-submission-panel .panel__title {
  font-size: var(--font-size-heading-card);
}

.detail-grid.product-customer-grid {
  grid-template-columns: minmax(120px, 0.8fr) minmax(150px, 1fr) minmax(240px, 1.6fr) minmax(150px, 1fr);
}

.detail-grid.product-submission-grid,
.form-grid.product-submission-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.product-definition-list--customer {
  width: 100%;
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.product-definition-list--submission {
  width: 100%;
  grid-template-columns: 1fr;
}

.product-definition-list--customer div:nth-child(odd) {
  border-right: 1px solid #e5ebf4;
}

.product-definition-list--submission div {
  border-bottom: 1px solid #e5ebf4;
}

.product-definition-list--customer div:nth-last-child(-n + 2),
.product-definition-list--submission div:last-child {
  border-bottom: 0;
}

.product-definition-list--submission div {
  grid-template-columns: minmax(150px, 28%) minmax(0, 1fr);
}

.product-definition-list--form div {
  min-height: 58px;
}

.product-definition-list--form dt,
.product-definition-list--form dd {
  padding-top: 10px;
  padding-bottom: 10px;
}

.product-definition-list--form .input,
.product-definition-list--form .select {
  min-height: 38px;
  border-radius: 10px;
}

.product-definition-list dd {
  min-width: 0;
}

.product-submission-edit-layout {
  display: grid;
  grid-template-columns: minmax(360px, 0.46fr) minmax(0, 1fr);
  gap: 16px;
  align-items: stretch;
}

.product-submission-edit-layout .product-definition-list--submission {
  height: 100%;
}

.product-submission-edit-layout .submission-confirm-box {
  margin-top: 0;
}

.product-submission-edit-layout .submission-confirm-box__textarea {
  min-height: 70px;
}

.product-status-card-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 18px;
  margin-top: 18px;
}

.product-status-card {
  padding: 20px;
  border: 1px solid #dfe7f2;
  border-radius: 8px;
  background: #ffffff;
  box-shadow: 0 8px 24px rgba(18, 39, 69, 0.04);
}

.product-status-card--wide {
  grid-column: 1 / -1;
}

.product-status-card__header {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: start;
  gap: 12px;
  margin: 0 0 18px;
  padding-bottom: 12px;
  border-bottom: 1px solid #e8eef6;
}

.product-status-card__title {
  margin: 0;
  font-size: var(--font-size-heading-card);
  color: var(--color-text-heading);
}

.product-status-card__grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 16px 18px;
}

.detail-item--full {
  grid-column: 1 / -1;
}

.submission-confirm-box {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  grid-template-rows: auto auto auto;
  gap: 18px;
  align-items: stretch;
  margin-top: 18px;
  padding: 16px;
  border: 1px solid #e3eaf4;
  border-radius: 8px;
  background: #f7f9fc;
}

.submission-confirm-box__content {
  display: contents;
}

.submission-confirm-box__title {
  grid-column: 1;
  grid-row: 1;
  margin: 0;
  font-size: 1.05rem;
  font-weight: 700;
  color: var(--color-text-heading);
}

.submission-confirm-box__notice {
  grid-column: 1;
  grid-row: 2;
  margin: 0;
  font-weight: 700;
  color: #3f6fc9;
}

.submission-confirm-box__textarea {
  grid-column: 1;
  grid-row: 3;
  min-height: 108px;
  background: #ffffff;
}

.submission-confirm-box__button {
  grid-column: 2;
  grid-row: 3;
  align-self: stretch;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  white-space: nowrap;
}

.field {
  display: grid;
  gap: 8px;
}

.field--full {
  grid-column: 1 / -1;
}

.field--inline {
  display: flex;
  align-items: center;
  gap: 12px;
}

.field__label {
  font-size: var(--font-size-field-label);
  font-weight: 700;
  color: var(--color-text-heading);
}

.field__hint {
  font-size: var(--font-size-field-hint);
  color: var(--color-text-soft);
}

.input,
.select,
.textarea {
  width: 100%;
  border: 1px solid #cfd9ea;
  border-radius: 12px;
  background: #fdfefe;
  color: var(--color-text);
  font: inherit;
  font-size: var(--font-size-control-base);
  transition: border-color 0.15s ease, box-shadow 0.15s ease, background-color 0.15s ease;
}

.input,
.select {
  min-height: 48px;
  padding: 0 14px;
}

.textarea {
  min-height: 120px;
  padding: 14px;
  resize: vertical;
}

.textarea--compact {
  min-height: 76px;
}

.product-status-card--shipping .select {
  width: min(100%, 180px);
}

.product-status-card .detail-item {
  border-color: #e7edf5;
  border-radius: 8px;
  background: #f7f9fc;
}

.submission-detail-page {
  display: grid;
  gap: 18px;
}

.submission-data-panel .panel__title,
.submission-mail-panel .panel__title,
.submission-download-panel .panel__title {
  font-size: var(--font-size-heading-card);
}

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

.submission-definition-list div:nth-child(odd) {
  border-right: 1px solid #e5ebf4;
}

.submission-definition-list div:nth-last-child(-n + 2) {
  border-bottom: 0;
}

.submission-definition-list div:nth-last-child(3) {
  border-bottom: 0;
}

.submission-definition-list__full {
  grid-column: 1 / -1;
}

.submission-definition-list div.submission-definition-list__full {
  border-right: 0;
}

.submission-definition-list .submission-definition-list__full {
  border-top: 1px solid #e5ebf4;
}

.submission-definition-list .submission-definition-list__full:nth-last-child(-n + 2) {
  border-bottom: 0;
}

.submission-status-control__row {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}

.submission-status-control .select {
  width: min(100%, 180px);
}

.field__hint--alert {
  color: #d9463e;
  font-weight: 700;
}

.submission-mail-panel .panel__body {
  background: #fffdf0;
}

.submission-mail-panel__notice {
  margin: 0 0 12px;
  color: #d9463e;
  font-weight: 700;
}

.submission-mail-panel__action {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 16px;
  align-items: stretch;
}

.submission-mail-panel__textarea {
  min-height: 104px;
  background: #ffffff;
}

.submission-mail-panel__button {
  align-self: stretch;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  white-space: nowrap;
}

.submission-history-list {
  display: grid;
  gap: 14px;
}

.submission-history-card {
  display: grid;
  gap: 14px;
  padding: 16px;
  border: 1px solid #dfe7f2;
  border-radius: 8px;
  background: #ffffff;
}

.submission-history-card--current {
  border-color: #b7c8e6;
  background: #fbfdff;
}

.submission-history-card__header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
}

.submission-history-card__status {
  display: flex;
  align-items: center;
  gap: 8px;
  color: var(--color-text-heading);
  font-size: 16px;
  font-weight: 700;
}

.submission-history-card__badge {
  display: inline-flex;
  align-items: center;
  min-height: 24px;
  padding: 0 9px;
  border-radius: 999px;
  background: var(--color-primary);
  color: #ffffff;
  font-size: 12px;
  font-weight: 700;
}

.submission-history-card__meta {
  margin: 6px 0 0;
  color: var(--color-text-soft);
  font-size: 13px;
  font-weight: 700;
}

.submission-history-card__copy {
  display: inline-grid;
  place-items: center;
  width: 36px;
  min-width: 36px;
  height: 36px;
  min-height: 36px;
  padding: 0;
  border: 1px solid #d6e0ef;
  border-radius: 8px;
  background: #ffffff;
  color: var(--color-text-soft);
  cursor: pointer;
  transition: color 0.2s ease, border-color 0.2s ease, background 0.2s ease;
}

.submission-history-card__copy:hover {
  border-color: #b7c8e6;
  background: #f7faff;
  color: var(--color-primary);
}

.submission-history-card__copy svg {
  width: 18px;
  height: 18px;
  fill: none;
  stroke: currentColor;
  stroke-width: 2;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.submission-history-card__download-all {
  min-width: 148px;
  white-space: nowrap;
}

.submission-history-card__path {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 12px;
  align-items: center;
  padding: 10px 12px;
  border: 1px solid #e5ebf4;
  border-radius: 8px;
  background: #f8fbff;
}

.submission-history-card__path-summary {
  display: grid;
  gap: 3px;
  min-width: 0;
}

.submission-history-card__path-label {
  color: var(--color-text-soft);
  font-size: 12px;
  font-weight: 700;
}

.submission-history-card__path-text {
  color: var(--color-text-heading);
  font-size: 13px;
  font-weight: 700;
}

.submission-file-list {
  display: grid;
  border: 1px solid #e5ebf4;
  border-radius: 8px;
  overflow: hidden;
}

.submission-file-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto auto;
  gap: 14px;
  align-items: center;
  padding: 12px 14px;
  background: #ffffff;
}

.submission-file-row + .submission-file-row {
  border-top: 1px solid #e5ebf4;
}

.submission-file-row__main {
  display: grid;
  gap: 4px;
  min-width: 0;
}

.submission-file-row__name {
  overflow-wrap: anywhere;
  color: var(--color-text-heading);
  font-weight: 700;
}

.submission-file-row__meta,
.submission-file-row__count,
.submission-history-card__note {
  color: var(--color-text-soft);
  font-size: 13px;
  font-weight: 700;
}

.submission-file-row__count {
  white-space: nowrap;
}

.submission-file-row__button {
  min-width: 126px;
}

.submission-history-card__note {
  margin: 0;
}

.mg-table__number {
  text-align: right;
  font-variant-numeric: tabular-nums;
}

.shipping-registration {
  display: grid;
  grid-template-columns: minmax(280px, 0.8fr) minmax(0, 1fr);
  gap: 14px;
  align-items: end;
  width: 100%;
}

.shipping-registration__textarea {
  min-height: 108px;
}

.shipping-registration__side {
  display: grid;
  justify-items: start;
  gap: 10px;
}

.shipping-registration__note {
  margin: 0;
  font-size: 14px;
  line-height: 1.7;
  color: var(--color-text);
}

.shipping-registration__note span {
  display: block;
}

.shipping-registration__button {
  justify-self: start;
}

.input:focus,
.select:focus,
.textarea:focus {
  outline: none;
  border-color: #8eade8;
  box-shadow: 0 0 0 4px rgba(63, 111, 201, 0.12);
}

.choice-row {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.chip {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 42px;
  padding: 0 14px;
  border: 1px solid #cfd9ea;
  border-radius: 999px;
  background: #ffffff;
  font-size: 14px;
  font-weight: 600;
  color: var(--color-text-heading);
}

.chip--selected {
  border-color: #9cb8ea;
  background: #eef4ff;
  color: var(--color-primary);
}

.check-grid {
  display: grid;
  gap: 10px;
}

.check-card {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  padding: 14px 16px;
  border: 1px solid #d9e2f0;
  border-radius: 14px;
  background: #ffffff;
}

.check-card__icon {
  width: 18px;
  height: 18px;
  margin-top: 2px;
  border: 2px solid #95addd;
  border-radius: 6px;
  background: #eef4ff;
}

.check-card__title {
  margin: 0;
  font-size: 14px;
  font-weight: 700;
  color: var(--color-text-heading);
}

.check-card__text {
  margin: 4px 0 0;
  font-size: 13px;
  line-height: 1.7;
  color: var(--color-text-soft);
}

.aside-card {
  position: sticky;
  top: 24px;
  display: grid;
  gap: 18px;
  padding: 20px;
  border: 1px solid var(--color-border);
  border-radius: 18px;
  background: linear-gradient(to bottom, #ffffff, #f8fbff);
  box-shadow: var(--shadow-card);
}

.aside-card__section + .aside-card__section {
  padding-top: 18px;
  border-top: 1px solid #e6edf7;
}

.aside-card__title {
  margin: 0 0 12px;
  font-size: 16px;
  color: var(--color-text-heading);
}

.summary-list {
  display: grid;
  gap: 10px;
}

.summary-row {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 12px;
  font-size: 14px;
}

.summary-row__label {
  color: var(--color-text-soft);
}

.summary-row__value {
  font-weight: 700;
  color: var(--color-text-heading);
  text-align: right;
}

.summary-total {
  padding-top: 12px;
  border-top: 1px solid #e6edf7;
}

.summary-total .summary-row__value {
  font-size: 20px;
  color: var(--color-primary);
}

.button-row {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  gap: 12px;
  margin-top: 28px;
}

.button-group {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
}

.button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 48px;
  padding: 0 20px;
  border: 1px solid #9fb5df;
  border-radius: 14px;
  background: #ffffff;
  color: var(--color-primary);
  font-size: 15px;
  font-weight: 700;
  transition: transform 0.15s ease, box-shadow 0.15s ease, border-color 0.15s ease;
}

.button:hover {
  transform: translateY(-1px);
  box-shadow: 0 8px 16px rgba(63, 111, 201, 0.08);
  border-color: #8eade8;
}

.button:focus-visible,
.chip:focus-visible,
.link-list__item:focus-visible,
.tile:focus-visible {
  outline: 3px solid rgba(63, 111, 201, 0.22);
  outline-offset: 3px;
}

.button--primary {
  background: linear-gradient(135deg, #3f6fc9, #5e89da);
  border-color: var(--color-primary-strong);
  color: #ffffff;
}

.button--muted {
  background: #f8fbff;
}

.note {
  padding: 14px 16px;
  border: 1px solid #dce6f5;
  border-radius: 12px;
  background: #f8fbff;
  font-size: 13px;
  line-height: 1.8;
  color: var(--color-text-soft);
}

.review-stack {
  display: grid;
  gap: 18px;
}

.review-card {
  border: 1px solid var(--color-border);
  border-radius: 18px;
  background: #ffffff;
  box-shadow: var(--shadow-card);
}

.review-card__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding: 18px 20px 14px;
  border-bottom: 1px solid #edf1f6;
  background: linear-gradient(to bottom, #ffffff, #fbfcfe);
}

.review-card__title {
  margin: 0;
  font-size: var(--font-size-heading-card);
  color: var(--color-text-heading);
}

.review-card__body {
  padding: 18px 20px 20px;
}

.detail-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px 20px;
}

.detail-item {
  display: grid;
  gap: 4px;
  padding: 14px 16px;
  border: 1px solid #e5ebf5;
  border-radius: 14px;
  background: #fbfcff;
}

.detail-item__label {
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.08em;
  color: var(--color-text-soft);
}

.detail-item__value {
  font-size: 16px;
  color: var(--color-text-heading);
}

.account-page {
  display: grid;
  gap: 24px;
}

.account-profile-card {
  width: 100%;
}

.account-profile-sections {
  display: grid;
  gap: 20px;
}

.account-hero {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 20px;
  align-items: center;
  padding: 24px 28px;
  border: 1px solid var(--color-border);
  border-radius: 20px;
  background: linear-gradient(135deg, #ffffff, #f6faff);
  box-shadow: var(--shadow-card);
}

.account-hero__eyebrow {
  display: inline-block;
  margin-bottom: 6px;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.08em;
  color: var(--color-primary);
}

.account-hero__title {
  margin: 0;
  font-size: 28px;
  line-height: 1.2;
  color: var(--color-text-heading);
}

.account-hero__text {
  margin: 10px 0 0;
  max-width: 680px;
  font-size: 14px;
  line-height: 1.8;
  color: var(--color-text-soft);
}

.account-hero__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  justify-content: flex-end;
}

.button--compact {
  min-height: 42px;
  padding: 0 16px;
}

.account-summary {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 16px;
}

.account-stat {
  display: grid;
  gap: 8px;
  padding: 18px 20px;
  border: 1px solid #dce6f3;
  border-radius: 18px;
  background: #ffffff;
  box-shadow: var(--shadow-card);
}

.account-stat__label {
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.08em;
  color: var(--color-text-soft);
}

.account-stat__value {
  font-size: 22px;
  font-weight: 700;
  color: var(--color-text-heading);
}

.account-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.4fr) minmax(280px, 0.8fr);
  gap: 24px;
  align-items: start;
}

.account-stack {
  display: grid;
  gap: 20px;
}

.account-card {
  border: 1px solid var(--color-border);
  border-radius: 18px;
  background: #ffffff;
  box-shadow: var(--shadow-card);
  overflow: hidden;
}

.account-card__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding: 18px 22px 14px;
  border-bottom: 1px solid #edf1f6;
  background: linear-gradient(to bottom, #ffffff, #fbfcfe);
}

.account-card__title {
  margin: 0;
  font-size: var(--font-size-heading-card);
  color: var(--color-text-heading);
}

.account-card__text {
  margin: 6px 0 0;
  font-size: 13px;
  line-height: 1.7;
  color: var(--color-text-soft);
}

.account-card__body {
  padding: 22px;
}

.profile-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px 16px;
}

.profile-grid--register {
  gap: 18px 20px;
}

.profile-item {
  display: grid;
  gap: 6px;
  padding: 14px 16px;
  border: 1px solid #e4ebf5;
  border-radius: 14px;
  background: #fbfcff;
}

.profile-item--full {
  grid-column: 1 / -1;
}

.profile-item__label {
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.08em;
  color: var(--color-text-soft);
}

.profile-item__value {
  font-size: 16px;
  line-height: 1.6;
  color: var(--color-text-heading);
}

.account-aside {
  display: grid;
  gap: 20px;
}

.mini-list {
  display: grid;
  gap: 12px;
}

.mini-list__item {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  padding: 12px 0;
  border-bottom: 1px solid #edf2f8;
  font-size: 14px;
}

.mini-list__item:last-child {
  border-bottom: 0;
  padding-bottom: 0;
}

.mini-list__label {
  color: var(--color-text-soft);
}

.mini-list__value {
  font-weight: 700;
  color: var(--color-text-heading);
  text-align: right;
}

.account-actions {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  gap: 14px;
}

.account-danger-zone {
  display: grid;
  gap: 0;
  padding: 0;
  border: 1px solid var(--color-border);
  border-radius: 16px;
  background: #ffffff;
  box-shadow: var(--shadow-card);
  overflow: hidden;
}

.account-danger-zone__main,
.account-danger-zone__danger {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
  padding: 18px 20px;
}

.account-danger-zone__danger {
  border-top: 1px solid #f0dada;
  background: #fffafa;
}

.account-danger-zone__title {
  margin: 0;
  font-size: 15px;
  color: var(--color-text-heading);
}

.account-danger-zone__danger-title {
  margin: 0;
  font-size: 15px;
  color: #7f4545;
}

.account-danger-zone__text {
  margin: 5px 0 0;
  font-size: 13px;
  line-height: 1.7;
  color: var(--color-text-soft);
}

.account-danger-zone__actions {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 12px;
}

.button--danger {
  border-color: #e3c2c2;
  color: #9a4c4c;
  background: #fffafa;
}

.point-history-page {
  display: grid;
  gap: 24px;
}

.point-history-hero {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 20px;
  align-items: center;
  padding: 24px 28px;
  border: 1px solid var(--color-border);
  border-radius: 20px;
  background: linear-gradient(135deg, #ffffff, #f6faff);
  box-shadow: var(--shadow-card);
}

.point-history-hero__eyebrow {
  display: inline-block;
  margin-bottom: 6px;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.08em;
  color: var(--color-primary);
}

.point-history-hero__title {
  margin: 0;
  font-size: 28px;
  line-height: 1.2;
  color: var(--color-text-heading);
}

.point-history-balance {
  display: grid;
  gap: 6px;
  min-width: 250px;
  padding: 13px 16px;
  border: 1px solid #d7e2f2;
  border-radius: 18px;
  background: linear-gradient(135deg, #ffffff, #f5f9ff);
  box-shadow: var(--shadow-card);
}

.point-history-balance__label {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.08em;
  color: var(--color-primary);
}

.point-history-balance__value {
  font-size: 24px;
  font-weight: 700;
  line-height: 1.2;
  color: var(--color-text-heading);
}

.point-history-card {
  border: 1px solid var(--color-border);
  border-radius: 18px;
  background: #ffffff;
  box-shadow: var(--shadow-card);
  overflow: hidden;
}

.point-history-card__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
  padding: 18px 22px 14px;
  border-bottom: 1px solid #edf1f6;
  background: linear-gradient(to bottom, #ffffff, #fbfcfe);
}

.point-history-card__title {
  margin: 0;
  font-size: var(--font-size-heading-card);
  color: var(--color-text-heading);
}

.point-history-card__text {
  margin: 6px 0 0;
  font-size: 13px;
  line-height: 1.7;
  color: var(--color-text-soft);
}

.point-history-current {
  flex: 0 0 auto;
  display: inline-flex;
  align-items: baseline;
  gap: 10px;
  padding-left: 18px;
  border-left: 1px solid #e3ebf6;
}

.point-history-current__label {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.08em;
  color: var(--color-primary);
}

.point-history-current__value {
  font-size: 20px;
  font-weight: 700;
  color: var(--color-text-heading);
}

.point-history-list {
  display: grid;
  gap: 12px;
  padding: 18px;
}

.point-history-item {
  display: grid;
  grid-template-columns: 150px minmax(0, 1fr) 140px;
  gap: 16px;
  align-items: center;
  padding: 16px 18px;
  border: 1px solid #e0e8f4;
  border-radius: 16px;
  background: #fbfcff;
}

.point-history-item__date {
  font-size: 14px;
  font-weight: 700;
  color: var(--color-text-heading);
}

.point-history-item__content {
  min-width: 0;
}

.point-history-item__type {
  display: inline-flex;
  align-items: center;
  min-height: 32px;
  padding: 0 12px;
  border-radius: 999px;
  background: #eef4ff;
  color: var(--color-primary);
  font-size: 13px;
  font-weight: 700;
}

.point-history-item__point {
  justify-self: end;
  font-size: 20px;
  font-weight: 700;
  color: var(--color-text-heading);
}

.point-history-item--plus .point-history-item__point {
  color: var(--color-primary);
}

.point-history-item--minus .point-history-item__type {
  background: #f7f8fb;
  color: var(--color-text-soft);
}

.point-history-item--minus .point-history-item__point {
  color: var(--color-text-soft);
}

.message-page {
  display: grid;
  gap: 24px;
}

.message-actions {
  display: flex;
  justify-content: flex-end;
}

.message-create-button {
  min-width: 150px;
}

.message-list {
  display: grid;
  border-top: 1px solid #d9e2ef;
}

.message-item {
  display: grid;
  gap: 22px;
  padding: 22px 14px 24px;
  border-bottom: 1px solid #d9e2ef;
}

.message-item__header {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 20px;
}

.message-item__title {
  margin: 0;
  font-size: var(--font-size-heading-list);
  line-height: 1.35;
}

.message-item__title a {
  color: var(--color-text-heading);
  text-decoration: underline;
  text-underline-offset: 0.18em;
}

.message-item__title a:hover,
.message-item__title a:focus-visible {
  color: var(--color-primary);
}

.message-item__date {
  flex: 0 0 auto;
  color: var(--color-text-heading);
  font-size: 14px;
  font-weight: 700;
  white-space: nowrap;
}

.message-item__preview {
  margin: 0;
  color: var(--color-text-heading);
  font-size: 16px;
  line-height: 1.7;
}

.message-pagination {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 16px;
  min-height: 160px;
  color: var(--color-text-heading);
  font-size: 24px;
  font-weight: 700;
}

.message-pagination__link {
  color: inherit;
  text-decoration: none;
}

.message-pagination__link:hover,
.message-pagination__link:focus-visible {
  color: var(--color-primary);
  text-decoration: underline;
  text-underline-offset: 0.18em;
}

.message-pagination__current {
  color: #000000;
}

.message-compose-page {
  display: grid;
  gap: 24px;
}

.message-compose-form {
  display: grid;
  gap: 20px;
  padding: 24px;
  border: 1px solid var(--color-border);
  border-radius: 18px;
  background: #ffffff;
  box-shadow: var(--shadow-card);
}

.message-compose-row {
  display: grid;
  gap: 8px;
  align-items: start;
}

.message-compose-row--body {
  align-items: start;
  padding-top: 4px;
}

.message-compose-label {
  display: inline-flex;
  align-items: center;
  color: var(--color-text-heading);
  font-size: 16px;
  font-weight: 700;
  line-height: 1.4;
  text-align: left;
}

.message-compose-title,
.message-compose-select {
  width: 100%;
  border-color: #d6e0ef;
  background-color: #fbfdff;
  font-size: 16px;
}

.message-compose-body {
  min-height: 420px;
  padding: 18px 20px;
  border-color: #d6e0ef;
  background: #fbfdff;
  font-size: 16px;
  line-height: 1.75;
  resize: vertical;
}

.message-compose-title:focus,
.message-compose-select:focus,
.message-compose-body:focus {
  background: #ffffff;
}

.message-compose-actions {
  display: flex;
  justify-content: space-between;
  gap: 16px;
  padding-top: 10px;
}

.message-compose-button {
  min-width: 150px;
}

.message-thread-page {
  display: grid;
  gap: 22px;
}

.message-thread-summary {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
  padding: 12px 14px;
  border: 1px solid #e4ebf5;
  border-radius: 14px;
  background: #fbfdff;
}

.range-field {
  display: flex;
  align-items: end;
  gap: 10px;
  min-width: 0;
}

.range-field .field {
  min-width: 0;
}

.range-field__separator {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 38px;
  color: var(--color-text-soft);
  font-size: var(--font-size-control-base);
  font-weight: 700;
}

.message-thread-summary__item {
  display: grid;
  gap: 6px;
  min-width: 0;
}

.message-thread-summary__label {
  color: var(--color-text-soft);
  font-size: 12px;
  font-weight: 700;
}

.message-thread-summary__value {
  color: var(--color-text-heading);
  font-size: 15px;
  font-weight: 700;
}

.message-thread {
  display: grid;
  gap: 24px;
  margin-top: 10px;
  min-height: 520px;
  padding: 0 28px 32px;
  border: 1px solid var(--color-border);
  border-radius: 18px;
  background: #ffffff;
  box-shadow: var(--shadow-card);
  overflow: hidden;
}

.message-thread__title {
  word-break: break-all;
  overflow-wrap: break-word;
  display: flex;
  align-items: center;
  margin: 0 -28px 8px;
  min-height: 58px;
  padding: 0 18px;
  border-bottom: 1px solid #e4ebf5;
  background: #fbfdff;
  color: var(--color-text-heading);
  font-size: var(--font-size-heading-card);
  font-weight: 700;
  line-height: 1.3;
}

/* 吹き出しの共通設定 */
.message-bubble {
  display: flex;             /* 内側をflexにしてコントロールしやすく */
  flex-direction: column;    /* 名前と本文を縦に並べる */
  gap: 8px;
  
  width: fit-content;        /* 文字量に合わせて枠を縮める（VBのAutoSize=True） */
  max-width: 65%;            /* 吹き出しが広がりすぎない（LINEっぽい絶妙な幅） */
  word-break: break-all;     /* 長い英語やURL、文字も枠の端で強制的に折り返す */
  
  padding: 14px 18px;        /* LINE風に少しだけコンパクトに */
  border: 1px solid #d6e0ef;
  border-radius: 16px;
  background: #ffffff;
}

/* ユーザー側（右寄せ・LINEでいう自分側） */
.message-bubble--right {
  justify-self: end;
  border-color: #b9cbed;
  background: #eef4ff;       /* 薄い青（お好みでLINE風の薄緑に変えてもOK） */
  
  /* 👇 右側の吹き出しのカドだけを少し尖らせてLINEっぽくする（お好みで！） */
  border-top-right-radius: 4px; 
}

/* スタッフ側（左寄せ・LINEでいう相手側） */
.message-bubble--left {
  justify-self: start;
  border-color: #e4ebf5;
  background: #ffffff;
  
  /* 👇 左側の吹き出しのカドだけを少し尖らせる */
  border-top-left-radius: 4px;
}
/* もし右側の吹き出しの時だけ、名前と日付を右揃えにしたい場合 */
.message-bubble--right .message-bubble__meta {
  align-items: flex-end;     /* 右側の吹き出しは右揃えにする */
}
/*
.message-bubble {
  display: grid;
  gap: 8px;
  max-width: min(720px, 82%);
  padding: 18px 20px;
  border: 1px solid #d6e0ef;
  border-radius: 16px;
  background: #ffffff;
}

.message-bubble--user {
  justify-self: end;
  border-color: #b9cbed;
  background: #eef4ff;
}

.message-bubble--staff {
  justify-self: start;
}
*/

/* 名前と日付を包んでいるエリア */
.message-bubble__meta {
  display: flex;
  flex-direction: column;    /* 【重要】横並びから「縦並び」に変える */
  align-items: flex-start;   /* 左揃えにする */
  gap: 4px;                  /* 名前と日付の間の上下の隙間 */
  
  color: var(--color-text-soft);
  font-size: 12px;
  font-weight: 700;
  margin-bottom: 8px;        /* 本文との間の隙間 */
}
/*.message-bubble__meta {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  color: var(--color-text-soft);
  font-size: 12px;
  font-weight: 700;
}
*/

.message-bubble__sender {
  color: var(--color-text-heading);
}

.message-bubble__text {
  margin: 0;
  color: var(--color-text-heading);
  font-size: 16px;
  line-height: 1.8;
}

.message-reply {
  display: grid;
  gap: 12px;
  padding: 18px;
  border: 1px solid #e4ebf5;
  border-radius: 16px;
  background: #ffffff;
}

.message-reply__title {
  margin: 0;
  color: var(--color-text-heading);
  font-size: 17px;
}

.message-reply__body {
  min-height: 150px;
  border-color: #d6e0ef;
  background: #fbfdff;
  font-size: 16px;
  line-height: 1.7;
  resize: vertical;
}

.message-reply__actions {
  display: flex;
  justify-content: space-between;
  gap: 16px;
}

.mg-message-search {
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: end;
}

.mg-message-search__grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(160px, 1fr));
  gap: 12px 14px;
}

.mg-message-search__wide {
  grid-column: span 2;
}

.mg-message-date-range {
  grid-column: span 2;
}

.mg-message-search__actions {
  display: flex;
  justify-content: flex-end;
}

.mg-message-list {
  border-top: 0;
}

.mg-message-item {
  padding-inline: 18px;
  border: 1px solid #d9e2ef;
  border-radius: 16px;
  background: #ffffff;
  box-shadow: var(--shadow-card);
}

.mg-message-item + .mg-message-item {
  margin-top: 14px;
}

.mg-message-item__meta {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px 14px;
  color: var(--color-text-soft);
  font-size: 13px;
  font-weight: 700;
}

.mg-message-thread-summary {
  grid-template-columns: repeat(4, minmax(0, 1fr)) auto;
  align-items: center;
}

.mg-message-thread-summary__action {
  display: flex;
  justify-content: flex-end;
}

.mg-message-resolve-button {
  min-width: 150px;
}

.mg-message-thread-page .message-bubble--user {
  justify-self: start;
}

.mg-message-thread-page .message-bubble--staff {
  justify-self: end;
  border-color: #b9cbed;
  background: #eef4ff;
}

.upload-consent-page {
  display: grid;
  gap: 22px;
}

.upload-consent-card {
  padding: 22px 24px;
  border: 1px solid var(--color-border);
  border-radius: 18px;
  background: #ffffff;
  color: var(--color-text-heading);
  box-shadow: var(--shadow-card);
}

.upload-consent-card__title {
  margin: 0 0 14px;
  font-size: 19px;
  font-weight: 700;
}

.upload-consent-list {
  display: grid;
  gap: 10px;
  margin: 0;
  padding: 0;
  list-style: none;
  font-size: var(--font-size-button);
  line-height: 1.7;
}

.upload-consent-list li {
  position: relative;
  padding-left: 22px;
}

.upload-consent-list li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0.72em;
  width: 8px;
  height: 8px;
  border-radius: 999px;
  background: var(--color-primary);
}

.upload-consent-policy {
  display: grid;
  gap: 8px;
  border-color: #e4ebf5;
  background: #fbfdff;
  font-size: 15px;
  line-height: 1.9;
}

.upload-consent-policy p {
  margin: 0;
}

.upload-consent-actions {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding-top: 8px;
}

.upload-consent-button {
  min-width: 160px;
}

.upload-page {
  display: grid;
  gap: 22px;
}

.upload-card {
  display: grid;
  gap: 20px;
  padding: 24px;
  border: 1px solid var(--color-border);
  border-radius: 18px;
  background: #ffffff;
  box-shadow: var(--shadow-card);
}

.upload-card__header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 20px;
}

.upload-card__title {
  margin: 0;
  color: var(--color-text-heading);
  font-size: 20px;
  font-weight: 700;
}

.upload-card__lead {
  margin: 8px 0 0;
  color: var(--color-text-soft);
  font-size: 14px;
  line-height: 1.6;
}

.upload-target {
  display: grid;
  gap: 4px;
  min-width: 150px;
  padding: 12px 14px;
  border: 1px solid #d6e0ef;
  border-radius: 14px;
  background: #f8fbff;
}

.upload-target__label,
.upload-info__label {
  color: var(--color-text-soft);
  font-size: 12px;
  font-weight: 700;
}

.upload-target__value,
.upload-info__value {
  color: var(--color-text-heading);
  font-size: 15px;
  font-weight: 700;
}

.upload-info-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
}

.upload-info {
  display: grid;
  gap: 5px;
  padding: 12px 14px;
  border: 1px solid #e4ebf5;
  border-radius: 14px;
  background: #fbfdff;
}

.upload-dropzone {
  overflow: hidden;
  border: 1px solid #d6e0ef;
  border-radius: 18px;
  background: #fbfdff;
}

.upload-dropzone__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  min-height: 64px;
  padding: 10px 12px 10px 18px;
  border-bottom: 1px solid #e4ebf5;
  background: #ffffff;
}

.upload-dropzone__filename {
  color: var(--color-text-heading);
  font-size: 15px;
  font-weight: 700;
}

.upload-add-button {
  min-width: 104px;
  min-height: 40px;
}

.upload-dropzone__body {
  display: grid;
  min-height: 430px;
  place-items: center;
  padding: 32px;
  border: 1px dashed #a9bddf;
  border-radius: 14px;
  margin: 18px;
  background: #ffffff;
}

.upload-dropzone__empty {
  display: grid;
  gap: 8px;
  justify-items: center;
  text-align: center;
}

.upload-dropzone__text {
  margin: 0;
  color: var(--color-text-heading);
  font-size: 18px;
  font-weight: 700;
}

.upload-dropzone__subtext {
  margin: 0;
  color: var(--color-text-soft);
  font-size: 13px;
}

.upload-actions {
  display: flex;
  justify-content: flex-end;
  padding-top: 4px;
}

.upload-submit-button {
  min-width: 180px;
}

.express-upload-page {
  display: grid;
  gap: 20px;
}

.express-upload-section {
  display: grid;
  gap: 16px;
  padding: 20px;
  border: 1px solid var(--color-border);
  border-radius: 18px;
  background: #ffffff;
  box-shadow: var(--shadow-card);
}

.express-upload-section__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
}

.express-upload-section__title {
  margin: 0;
  color: var(--color-text-heading);
  font-size: 20px;
  font-weight: 700;
}

.express-file-table {
  overflow: hidden;
  border: 1px solid #d6e0ef;
  border-radius: 16px;
  background: #ffffff;
}

.express-file-table__row {
  display: grid;
  grid-template-columns: 72px 120px minmax(180px, 1fr) 150px 140px;
  gap: 12px;
  align-items: center;
  min-height: 64px;
  padding: 0 16px;
  border-top: 1px solid #e4ebf5;
  color: var(--color-text-heading);
  font-size: 16px;
}

.express-file-table__row:first-child {
  border-top: 0;
}

.express-file-table__row--head {
  min-height: 52px;
  background: #fbfdff;
  color: var(--color-text-soft);
  font-size: 13px;
  font-weight: 700;
}

.express-file-check {
  display: inline-flex;
  align-items: center;
}

.express-file-check input {
  width: 20px;
  height: 20px;
  accent-color: var(--color-primary);
}

.express-file-button {
  min-height: 40px;
  min-width: 112px;
  padding: 0 14px;
}

.express-upload-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
}

.express-upload-button {
  min-width: 210px;
}

.express-submit-actions {
  display: flex;
  justify-content: flex-end;
  padding-top: 70px;
}

.express-submit-button {
  min-width: 220px;
}

.express-modal {
  position: fixed;
  inset: 0;
  z-index: 100;
  display: none;
  padding: 28px;
}

.express-modal:target {
  display: grid;
  place-items: center;
}

.express-modal__backdrop {
  position: absolute;
  inset: 0;
  background: rgba(10, 18, 33, 0.68);
}

.express-modal__panel {
  position: relative;
  z-index: 1;
  width: min(100%, 1320px);
  max-height: calc(100vh - 56px);
  overflow: auto;
  border-radius: 12px;
  background: #ffffff;
  box-shadow: 0 24px 60px rgba(10, 18, 33, 0.28);
}

.express-modal__panel--image {
  width: min(100%, 980px);
}

.express-preview,
.express-image-preview {
  color: var(--color-text-heading);
}

.express-preview {
  display: grid;
  gap: 14px;
  padding: 16px 18px 18px;
}

.express-preview__header,
.express-image-preview__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
}

.express-preview__title {
  margin: 0;
  font-size: 18px;
}

.express-preview__close,
.express-image-preview__close {
  color: var(--color-text-heading);
  font-size: 36px;
  line-height: 1;
  text-decoration: none;
}

.express-preview__meta {
  width: fit-content;
  max-width: 100%;
  padding: 10px 14px;
  border: 1px solid #d6e0ef;
  border-radius: 10px;
  background: #fbfdff;
  font-size: 14px;
  font-weight: 700;
}

.express-preview__workspace {
  display: grid;
  grid-template-columns: 300px minmax(0, 1fr);
  gap: 16px;
}

.express-preview__thumbs,
.express-preview__main,
.express-image-preview__canvas {
  border: 1px solid var(--color-text-heading);
  background: #ffffff;
}

.express-preview__thumbs {
  display: grid;
  gap: 28px;
  align-content: start;
  max-height: 720px;
  overflow: auto;
  padding: 14px 26px;
}

.express-preview__thumb,
.express-preview__spread {
  position: relative;
  display: grid;
  place-items: center;
  min-height: 174px;
  border: 1px solid #1c3158;
  background: #ffffff;
}

.express-preview__thumb {
  width: 128px;
  min-height: 174px;
  justify-self: center;
}

.express-preview__spread {
  grid-template-columns: 1fr 1fr;
  min-height: 166px;
}

.express-preview__spread::after {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  left: 50%;
  width: 1px;
  background: #1c3158;
}

.express-preview__spread--active {
  border: 3px solid #e97832;
}

.express-preview__page-label {
  position: absolute;
  top: -24px;
  font-size: 12px;
  font-weight: 700;
}

.express-preview__page-label--left {
  left: 30%;
}

.express-preview__page-label--right {
  right: 30%;
}

.express-preview__main {
  position: relative;
  display: grid;
  grid-template-rows: auto 1fr auto;
  gap: 10px;
  min-height: 860px;
  padding: 16px 24px;
}

.express-preview__page-title {
  display: grid;
  grid-template-columns: 1fr 1fr;
  font-size: 20px;
  font-weight: 700;
  text-align: center;
}

.express-preview__spread-main {
  position: relative;
  display: grid;
  grid-template-columns: 1fr 1fr;
  place-items: center;
  min-height: 700px;
  border: 1px solid #1c3158;
  background: #ffffff;
}

.express-preview__spread-main::after,
.express-image-preview__canvas::after {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  left: 50%;
  width: 1px;
  background: #1c3158;
}

.express-preview__arrow {
  justify-self: center;
  width: 0;
  height: 0;
  border-inline: 22px solid transparent;
}

.express-preview__arrow--top {
  border-bottom: 28px solid #777777;
}

.express-preview__arrow--bottom {
  border-top: 28px solid #777777;
}

.express-preview__actions {
  display: flex;
  justify-content: space-between;
  gap: 16px;
}

.express-preview__button {
  min-width: 200px;
}

.express-image-preview {
  position: relative;
  display: grid;
  gap: 18px;
  padding: 16px;
}

.express-image-preview__header {
  font-size: 15px;
  font-weight: 700;
}

.express-image-preview__canvas {
  position: relative;
  display: grid;
  grid-template-columns: 1fr 1fr;
  place-items: center;
  min-height: 720px;
  margin: 0 54px;
}

.express-image-preview__canvas .express-art:first-child {
  grid-column: 1;
}

.express-image-preview__canvas .express-art:last-child {
  grid-column: 2;
}

.express-image-preview__close {
  position: absolute;
  right: 20px;
  bottom: 16px;
}

.express-image-preview__nav {
  position: absolute;
  top: 50%;
  width: 0;
  height: 0;
  border: 0;
  background: transparent;
}

.express-image-preview__nav--prev {
  left: 18px;
  border-top: 28px solid transparent;
  border-bottom: 28px solid transparent;
  border-right: 34px solid #777777;
  transform: translateY(-50%);
}

.express-image-preview__nav--next {
  right: 18px;
  border-top: 28px solid transparent;
  border-bottom: 28px solid transparent;
  border-left: 34px solid #777777;
  transform: translateY(-50%);
}

.express-art {
  width: 72px;
  height: 72px;
  border: 2px solid #1c3158;
  color: #1c3158;
}

.express-art--large {
  width: 220px;
  height: 220px;
}

.express-art--sun {
  position: relative;
  width: 96px;
  height: 96px;
  border: 0;
}

.express-art--sun::before,
.express-art--sun::after {
  content: "";
  position: absolute;
  inset: 18px;
  border: 3px solid currentColor;
  border-radius: 999px;
}

.express-art--sun::after {
  inset: 0;
  border-radius: 18px;
  transform: rotate(45deg);
}

.express-art--bolt {
  width: 80px;
  height: 180px;
  border: 0;
  background: transparent;
  clip-path: none;
}

.express-art--bolt::before {
  content: "";
  display: block;
  width: 100%;
  height: 100%;
  background: #1c3158;
  clip-path: polygon(58% 0, 24% 42%, 48% 42%, 28% 100%, 82% 34%, 56% 34%);
}

.express-art--bolt::after {
  content: "";
  display: block;
  width: calc(100% - 8px);
  height: calc(100% - 8px);
  margin: calc(-100% + 4px) 0 0 4px;
  background: #ffffff;
  clip-path: polygon(58% 0, 24% 42%, 48% 42%, 28% 100%, 82% 34%, 56% 34%);
}

.express-art--bolt.express-art--large {
  width: 270px;
  height: 570px;
}

.express-art--cloud {
  width: 96px;
  height: 74px;
  border-radius: 45% 55% 48% 52%;
  background:
    radial-gradient(circle at 24% 58%, #ffffff 0 20px, transparent 21px),
    radial-gradient(circle at 42% 42%, #ffffff 0 22px, transparent 23px),
    radial-gradient(circle at 62% 40%, #ffffff 0 24px, transparent 25px),
    radial-gradient(circle at 76% 58%, #ffffff 0 22px, transparent 23px);
  outline: 2px solid #1c3158;
}

.express-art--star {
  border: 0;
  background: #1c3158;
  clip-path: polygon(50% 0, 61% 36%, 98% 36%, 68% 57%, 79% 94%, 50% 72%, 21% 94%, 32% 57%, 2% 36%, 39% 36%);
}

.express-preview__thumb .express-art,
.express-preview__spread .express-art {
  align-self: center;
  justify-self: center;
}

.express-preview__thumb .express-art--sun {
  transform: translateY(8px);
}

.express-preview__spread .express-art:first-of-type {
  grid-column: 1;
}

.express-preview__spread .express-art:last-of-type {
  grid-column: 2;
}

.express-preview__spread-main .express-art {
  grid-column: 1;
  justify-self: center;
  align-self: center;
}

.express-preview__spread--active .express-art--bolt {
  transform: translateX(-26px);
}

.express-preview__spread-main .express-art--bolt {
  transform: translateX(-18px);
}

.cart-page {
  display: grid;
  gap: 24px;
}

.cart-shell {
  display: grid;
  gap: 20px;
  padding: 20px;
  border: 1px solid var(--color-border);
  border-radius: 22px;
  background: #ffffff;
  box-shadow: var(--shadow-card);
}

.cart-card {
  display: grid;
  gap: 18px;
  padding: 18px;
  border: 1px solid #d9e3f2;
  border-radius: 18px;
  background: linear-gradient(180deg, #ffffff 0%, #fbfdff 100%);
}

.cart-card__top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  flex-wrap: wrap;
}

.cart-card__heading {
  display: flex;
  align-items: center;
  gap: 14px;
  flex-wrap: wrap;
}

.cart-card__title {
  margin: 0;
  font-size: 32px;
  line-height: 1.2;
  color: var(--color-text-heading);
}

.cart-card__status {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 10px;
  flex-wrap: wrap;
}

.cart-card__deadline {
  font-size: 18px;
  font-weight: 700;
  color: #d73f3f;
}

.cart-chip {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 42px;
  padding: 0 16px;
  border: 1px dashed #95addd;
  border-radius: 14px;
  background: #ffffff;
  font-size: 14px;
  font-weight: 700;
  color: var(--color-text-heading);
}

.order-history-card__top {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 16px;
  flex-wrap: wrap;
}

.order-history-date {
  display: grid;
  gap: 6px;
}

.order-history-date__label {
  font-size: 13px;
  font-weight: 700;
  letter-spacing: 0.08em;
  color: var(--color-text-soft);
}

.order-history-date__value {
  font-size: 20px;
  font-weight: 700;
  color: var(--color-text-heading);
}

.order-history-actions {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 10px;
  flex-wrap: wrap;
}

.cart-overview {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 16px;
  align-items: stretch;
}

.cart-overview__side {
  display: grid;
  grid-template-rows: repeat(2, minmax(0, 1fr));
  gap: 16px;
}

.cart-delivery-panel {
  grid-column: span 2;
  grid-template-rows: auto minmax(0, 1fr);
  align-content: stretch;
}

.cart-info-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 16px;
}

.cart-panel {
  display: grid;
  gap: 14px;
  align-content: start;
  padding: 16px;
  border: 1px solid #dbe4f1;
  border-radius: 16px;
  background: #ffffff;
}

.cart-panel--link {
  color: inherit;
  text-decoration: none;
  transition: color 0.16s ease;
}

.cart-panel--link:focus-visible {
  outline: 3px solid rgba(65, 112, 200, 0.24);
  outline-offset: 3px;
}

.cart-panel__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.cart-icon-button {
  flex: 0 0 auto;
  width: 36px;
  min-width: 36px;
  min-height: 36px;
  height: 36px;
  padding: 0;
  border-radius: 999px;
  border-color: #d6e0ef;
  background: #ffffff;
  color: var(--color-text-soft);
  font-size: 20px;
  line-height: 1;
  box-shadow: 0 6px 14px rgba(31, 45, 61, 0.04);
}

.cart-icon-button:hover {
  color: var(--color-primary);
  background: #f7faff;
}

.cart-panel__title {
  margin: 0;
  font-size: var(--font-size-heading-card);
  color: var(--color-primary);
  word-break: keep-all;
  overflow-wrap: normal;
}

.cart-panel__title-link {
  color: inherit;
  text-decoration: none;
  text-underline-offset: 0.18em;
}

.cart-panel__title-link:hover,
.cart-panel__title-link:focus-visible {
  color: var(--color-primary-strong);
  text-decoration: underline;
}

.cart-panel__stack {
  display: grid;
  gap: 10px;
}

.cart-panel__item {
  display: grid;
  gap: 6px;
}

.cart-panel__label {
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.08em;
  color: var(--color-text-soft);
}

.cart-panel__value {
  font-size: 16px;
  line-height: 1.7;
  color: var(--color-text-heading);
}

.cart-delivery {
  display: grid;
  grid-template-rows: repeat(2, minmax(0, 1fr));
  gap: 16px;
}

.cart-delivery__option {
  display: grid;
  gap: 10px;
  padding: 16px;
  border: 1px solid #dbe4f1;
  border-radius: 14px;
  background: #fbfdff;
}

.cart-delivery__title {
  margin: 0;
  font-size: 16px;
  color: var(--color-text-heading);
}

.cart-delivery__title-link {
  width: fit-content;
  color: var(--color-primary);
  text-decoration: none;
  text-underline-offset: 0.18em;
}

.cart-delivery__title-link:hover,
.cart-delivery__title-link:focus-visible {
  color: var(--color-primary);
  text-decoration: underline;
}

.cart-note__text {
  margin: 0;
  font-size: 16px;
  line-height: 1.7;
  color: var(--color-text-heading);
}

.cart-products {
  display: grid;
  gap: 16px;
}

.cart-products__header {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 16px;
  flex-wrap: wrap;
}

.cart-products__title {
  margin: 0;
  font-size: var(--font-size-heading-card);
  color: var(--color-text-heading);
}

.cart-products__total {
  font-size: 20px;
  font-weight: 700;
  color: var(--color-text-heading);
}

.cart-product-list {
  display: grid;
  gap: 12px;
}

.cart-product {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 88px 84px;
  gap: 16px;
  align-items: center;
  padding: 14px 16px;
  border: 1px solid #e5ebf5;
  border-radius: 14px;
  background: #fbfcff;
}

.order-history-product {
  grid-template-columns: minmax(0, 1fr) 88px 84px 88px;
}

.order-history-product__status {
  font-size: 14px;
  font-weight: 700;
  color: var(--color-text-soft);
  text-align: center;
}

.order-history-product__status-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 34px;
  border: 1px dashed #b9c4d3;
  border-radius: 999px;
  background: #ffffff;
  transition: border-color 0.2s ease, color 0.2s ease, background 0.2s ease;
}

.order-history-product__status-link:hover {
  border-color: var(--color-primary);
  background: #fff7ef;
  color: var(--color-primary);
}

.order-history-product__button {
  border-style: dashed;
  background: #ffffff;
}

.order-history-product__button--solid {
  border-style: solid;
}

.order-history-payment {
  width: 100%;
}

.cart-product__name {
  margin: 0;
  font-size: 16px;
  color: var(--color-text-heading);
}

.cart-product__price {
  font-size: 15px;
  font-weight: 700;
  color: var(--color-text-heading);
  text-align: right;
}

.button--mini {
  min-height: 40px;
  padding: 0 16px;
  border-radius: 12px;
  width: 88px;
}

.cart-payment {
  display: grid;
  grid-template-columns: 1fr;
  gap: 14px;
}

.cart-payment__summary {
  display: grid;
  gap: 14px;
  padding: 18px;
  border: 1px solid #dbe4f1;
  border-radius: 16px;
  background: #ffffff;
}

.cart-payment__title {
  margin: 0;
  font-size: var(--font-size-heading-card);
  color: var(--color-primary);
}

.cart-payment__title-link {
  color: inherit;
  text-decoration: none;
  text-underline-offset: 0.18em;
}

.cart-payment__title-link:hover,
.cart-payment__title-link:focus-visible {
  color: var(--color-primary-strong);
  text-decoration: underline;
}

.cart-payment__method {
  font-size: 16px;
  color: var(--color-text-heading);
}

.cart-payment__rows {
  display: grid;
  gap: 10px;
}

.cart-payment__row {
  display: flex;
  justify-content: space-between;
  gap: 16px;
  font-size: 15px;
  color: var(--color-text-heading);
}

.cart-payment__total {
  padding-top: 12px;
  border-top: 1px solid #e6edf7;
  text-align: right;
  font-size: 18px;
  font-weight: 700;
  color: var(--color-text-heading);
}

.cart-payment__actions {
  display: flex;
  justify-content: flex-end;
  padding-top: 0;
}

.cart-action-button {
  min-height: 58px;
  width: 100%;
  padding: 0 18px;
  border-radius: 14px;
  border-color: #bfd0ea;
  background: #ffffff;
  color: var(--color-text-heading);
  box-shadow: 0 8px 18px rgba(31, 45, 61, 0.05);
}

.cart-action-button--secondary {
  border-style: dashed;
  color: var(--color-primary);
}

.cart-action-button--neutral {
  background: linear-gradient(180deg, #ffffff 0%, #f7faff 100%);
}

.cart-action-button--primary {
  min-height: 52px;
  width: auto;
  min-width: 260px;
  border-color: #8eade8;
  background: linear-gradient(135deg, #3f6fc9 0%, #5f89d8 100%);
  color: #ffffff;
  font-size: 16px;
  box-shadow: 0 8px 18px rgba(63, 111, 201, 0.14);
}

.cart-action-button--primary:hover {
  box-shadow: 0 12px 24px rgba(63, 111, 201, 0.18);
}

.order-history-action-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 48px;
  min-width: 132px;
  width: auto;
  padding: 0 20px;
  border-color: #9fb5df;
  background: #ffffff;
  color: var(--color-primary);
  font-size: 14px;
  font-weight: 700;
  box-shadow: 0 6px 14px rgba(31, 45, 61, 0.04);
}

.order-history-action-button:hover {
  color: var(--color-primary-strong);
  background: #f7faff;
  box-shadow: 0 6px 14px rgba(63, 111, 201, 0.08);
}

.order-history-payment-actions {
  margin-top: -4px;
}

.mg-order-card {
  gap: 18px;
}

.mg-order-status {
  color: #3d7d35;
}

.mg-order-product .order-history-product__button {
  border-style: solid;
}

.payment-page {
  display: grid;
  gap: 24px;
}

.payment-layout {
  display: grid;
  gap: 24px;
  width: 100%;
}

.payment-workspace {
  border: 1px solid var(--color-border);
  border-radius: 18px;
  background: #ffffff;
  box-shadow: var(--shadow-card);
  overflow: hidden;
}

.payment-step {
  display: grid;
  grid-template-columns: 190px minmax(0, 1fr);
  gap: 26px;
  padding: 24px 28px;
}

.payment-step + .payment-step {
  border-top: 1px solid #edf1f6;
}

.payment-step__head {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  min-width: 0;
  padding-top: 2px;
  border-right: 1px solid #e6edf7;
}

.payment-step__title {
  display: flex;
  align-items: center;
  gap: 10px;
  margin: 0;
  color: var(--color-text-heading);
  font-size: 19px;
  font-weight: 700;
  line-height: 1.35;
}

.payment-step__title::before {
  content: "";
  flex: 0 0 auto;
  width: 4px;
  height: 22px;
  border-radius: 999px;
  background: var(--color-primary);
}

.payment-point-balance {
  display: inline-flex;
  align-items: center;
  min-height: 26px;
  margin: 8px 0 0 14px;
  padding: 0 10px;
  border-radius: 999px;
  background: #eef4ff;
  color: var(--color-primary-strong);
  font-size: 13px;
  font-weight: 700;
  line-height: 1;
  white-space: nowrap;
}

.payment-detail {
  display: grid;
  gap: 18px;
  padding: 0;
}

.payment-detail__rows {
  display: grid;
  gap: 12px;
}

.payment-detail__row,
.payment-detail__total {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 16px;
  color: var(--color-text-heading);
}

.payment-detail__row {
  padding: 0 2px;
  font-size: 15px;
}

.payment-detail__row strong,
.payment-detail__total strong {
  white-space: nowrap;
}

.payment-detail__total {
  padding-top: 16px;
  border-top: 1px solid #e6edf7;
  font-size: 19px;
  font-weight: 700;
}

.payment-detail__total--strong {
  font-size: 22px;
  color: var(--color-primary);
}

.payment-adjustment {
  display: grid;
  gap: 14px;
  align-content: start;
  padding: 6px 0;
}

.button.payment-adjustment__apply {
  min-height: 40px;
  min-width: 104px;
  padding: 0 22px;
}

.payment-choice {
  gap: 8px;
}

.payment-point-control {
  display: flex;
  align-items: center;
  gap: 12px;
  width: 100%;
  min-height: 40px;
}

.payment-point-entry {
  display: flex;
  align-items: center;
  gap: 8px;
}

.payment-point-entry {
  flex: 0 0 auto;
}

.payment-point-input {
  position: relative;
  display: block;
  width: 125px;
}

.payment-point-input .input {
  min-height: 40px;
  padding-right: 42px;
  text-align: right;
}

.payment-point-input__unit {
  position: absolute;
  right: 14px;
  top: 50%;
  transform: translateY(-50%);
  color: var(--color-text-soft);
  font-size: 14px;
  font-weight: 700;
  pointer-events: none;
}

.button.payment-point-apply {
  min-height: 40px;
  min-width: 96px;
  padding: 0 20px;
}

.payment-methods {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
  padding: 0;
}

.payment-method {
  display: flex;
  align-items: center;
  gap: 10px;
  min-height: 56px;
  padding: 0 16px;
  border: 1px solid #d4deee;
  border-radius: 14px;
  background: #ffffff;
  color: var(--color-text-heading);
  font-size: 15px;
  font-weight: 700;
}

.payment-method input {
  accent-color: var(--color-primary);
}

.payment-method--active {
  border-color: #9cb8ea;
  background: #f3f7ff;
  color: var(--color-primary);
}

.payment-card-form {
  padding-top: 18px;
}

.payment-summary {
  top: 92px;
}

.payment-submit-button {
  min-width: 180px;
}

.document-page {
  display: grid;
  gap: 24px;
}

.document-shell {
  display: grid;
  grid-template-columns: minmax(300px, 360px) minmax(0, 1fr);
  gap: 22px;
  align-items: start;
}

.document-form,
.document-card {
  border: 1px solid var(--color-border);
  border-radius: 18px;
  background: #ffffff;
  box-shadow: var(--shadow-card);
}

.document-form {
  display: grid;
  gap: 18px;
  padding: 20px;
}

.document-order {
  display: flex;
  justify-content: space-between;
  gap: 14px;
  padding: 14px 16px;
  border: 1px solid #e4ebf5;
  border-radius: 14px;
  background: #fbfcff;
}

.document-order__label {
  font-size: 13px;
  font-weight: 700;
  color: var(--color-text-soft);
}

.document-order__value {
  font-size: 15px;
  font-weight: 700;
  color: var(--color-text-heading);
}

.document-fields {
  display: grid;
  gap: 16px;
}

.document-card {
  overflow: hidden;
}

.document-card__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding: 18px 22px 14px;
  border-bottom: 1px solid #edf1f6;
  background: linear-gradient(to bottom, #ffffff, #fbfcfe);
}

.document-card__eyebrow {
  display: inline-block;
  margin-bottom: 5px;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.08em;
  color: var(--color-primary);
}

.document-card__title {
  margin: 0;
  font-size: 22px;
  color: var(--color-text-heading);
}

.document-card__badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 30px;
  padding: 0 12px;
  border-radius: 999px;
  background: #eef4ff;
  color: var(--color-primary);
  font-size: 13px;
  font-weight: 700;
}

.document-detail {
  display: grid;
  gap: 18px;
  padding: 20px 22px 22px;
}

.document-detail__section {
  display: grid;
  gap: 10px;
}

.document-detail__section--summary {
  padding-top: 16px;
  border-top: 1px solid #dfe7f3;
}

.document-detail__title {
  margin: 0 0 2px;
  font-size: 15px;
  color: var(--color-text-soft);
}

.document-line {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 120px;
  gap: 16px;
  align-items: baseline;
  font-size: 15px;
  color: var(--color-text-heading);
}

.document-line span:last-child {
  text-align: right;
  font-weight: 700;
}

.document-line--discount span:last-child {
  color: #7a5b5b;
}

.document-total {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 140px;
  gap: 16px;
  align-items: baseline;
  padding-top: 18px;
  border-top: 1px solid #cdd8ea;
  font-size: 18px;
  font-weight: 700;
  color: var(--color-text-heading);
}

.document-total strong {
  text-align: right;
}

.document-actions {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 20px;
}

.document-action-button {
  min-height: 64px;
  border-color: #9fb5df;
  background: linear-gradient(180deg, #ffffff 0%, #f7faff 100%);
  color: var(--color-primary);
  font-size: 18px;
  font-weight: 700;
}

.login-header {
  position: sticky;
  top: 0;
  z-index: 100;
  border-bottom: 1px solid rgba(223, 229, 238, 0.92);
  background: rgba(255, 255, 255, 0.96);
  backdrop-filter: blur(10px);
  box-shadow: 0 4px 14px rgba(31, 45, 61, 0.05);
}

.login-header__inner {
  min-height: var(--layout-chrome-height);
  max-width: var(--layout-max-width);
  display: flex;
  align-items: center;
  margin: 0 auto;
  padding: 10px var(--layout-gutter);
}

.login-page {
  display: grid;
  gap: 24px;
  min-height: calc(100vh - (var(--layout-chrome-height) * 2) - 128px);
  align-content: center;
}

.login-panel {
  display: grid;
  width: min(100%, 680px);
  grid-template-columns: 1fr;
  gap: 30px;
  justify-self: center;
  align-items: stretch;
  margin-bottom: 22px;
}

.login-panel__main,
.login-banner {
  border: 1px solid var(--color-border);
  border-radius: 18px;
  background: #ffffff;
  box-shadow: var(--shadow-shell);
}

.login-panel__main {
  display: grid;
  gap: 20px;
  padding: 22px;
}

.login-panel__header {
  display: grid;
  gap: 6px;
}

.login-panel__title {
  margin: 0;
  font-size: var(--font-size-heading-card);
  color: var(--color-text-heading);
}

.login-panel__text {
  margin: 0;
  font-size: 13px;
  line-height: 1.7;
  color: var(--color-text-soft);
}

.login-form {
  display: grid;
  gap: 18px;
}

.login-form__actions {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
  flex-wrap: wrap;
  padding-top: 6px;
}

.login-form__primary {
  display: grid;
  justify-items: end;
  gap: 10px;
}

.login-primary-button,
.login-secondary-button {
  min-width: 190px;
}

.login-help-text {
  font-size: 13px;
  color: var(--color-text-heading);
}

.login-help-link {
  color: var(--color-primary);
  text-decoration: underline;
  text-underline-offset: 3px;
}

.login-help-link:hover {
  color: var(--color-primary);
}

.login-banner {
  min-height: 150px;
  display: grid;
  place-items: center;
  padding: 24px;
  background:
    linear-gradient(135deg, rgba(63, 111, 201, 0.08), rgba(255, 255, 255, 0.96)),
    repeating-linear-gradient(135deg, rgba(63, 111, 201, 0.05) 0 12px, rgba(63, 111, 201, 0.02) 12px 24px);
  text-align: center;
}

.login-banner__label {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 30px;
  padding: 0 12px;
  border-radius: 999px;
  background: rgba(63, 111, 201, 0.12);
  color: var(--color-primary);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.08em;
}

.login-banner__text {
  margin: 12px 0 0;
  font-size: 34px;
  font-weight: 700;
  color: var(--color-text-heading);
}

.register-page {
  display: grid;
  gap: 24px;
}

.register-card {
  border: 1px solid var(--color-border);
  border-radius: 18px;
  background: #ffffff;
  box-shadow: var(--shadow-card);
  overflow: hidden;
}

.register-card__header {
  padding: 18px 22px 14px;
  border-bottom: 1px solid #edf1f6;
  background: linear-gradient(to bottom, #ffffff, #fbfcfe);
}

.register-card__title {
  margin: 0;
  font-size: var(--font-size-heading-card);
  color: var(--color-text-heading);
}

.register-card__text {
  margin: 6px 0 0;
  font-size: 13px;
  line-height: 1.7;
  color: var(--color-text-soft);
}

.register-form {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 18px 20px;
  padding: 22px;
}

.register-form--single {
  grid-template-columns: 1fr;
}

.register-address {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 12px;
  align-items: end;
}

.register-address__button .button {
  min-width: 120px;
}

.field__label--spacer {
  visibility: hidden;
}

.register-actions {
  display: flex;
  justify-content: flex-end;
  margin-top: -4px;
}

.register-actions--split {
  justify-content: space-between;
  gap: 14px;
}

.register-submit-button {
  min-width: 180px;
}

.password-page {
  display: grid;
  gap: 24px;
}

.mg-auth-page {
  gap: 22px;
  min-height: calc(100vh - (var(--layout-chrome-height) * 2) - 128px);
  align-content: center;
}

.password-card {
  width: 100%;
  border: 1px solid var(--color-border);
  border-radius: 18px;
  background: #ffffff;
  box-shadow: var(--shadow-card);
  overflow: hidden;
}

.password-card__header {
  padding: 18px 22px 14px;
  border-bottom: 1px solid #edf1f6;
  background: linear-gradient(to bottom, #ffffff, #fbfcfe);
}

.password-card__title {
  margin: 0;
  font-size: var(--font-size-heading-card);
  color: var(--color-text-heading);
}

.password-card__text {
  margin: 6px 0 0;
  font-size: 13px;
  line-height: 1.7;
  color: var(--color-text-soft);
}

.password-form {
  display: grid;
  gap: 18px;
  padding: 22px;
}

.mg-auth-card {
  width: min(100%, 640px);
  min-height: 0;
  display: grid;
  grid-template-rows: auto 1fr;
  justify-self: center;
  box-shadow: var(--shadow-shell);
}

.mg-auth-form {
  width: 100%;
  align-content: start;
  gap: 20px;
  padding: 28px 36px 34px;
}

.mg-auth-form .field {
  width: 100%;
  grid-template-columns: 140px minmax(0, 1fr);
  align-items: center;
  gap: 18px;
}

.mg-auth-card .form-message {
  margin: 22px 36px -8px;
  padding: 10px 14px;
  border: 1px solid #d8eadf;
  border-radius: 6px;
  background: #f4fbf6;
  color: #287047;
  font-size: 13px;
  line-height: 1.6;
}

.mg-auth-form .field-error {
  width: calc(100% - 158px);
  margin: -14px 0 0 158px;
  color: #c33d3d;
  font-size: 13px;
  line-height: 1.6;
}

.mg-auth-code-input {
  letter-spacing: 0.08em;
}

.mg-auth-status {
  width: calc(100% - 158px);
  margin: -10px 0 0 158px;
  color: var(--color-text-soft);
  font-size: 13px;
  line-height: 1.6;
}

.mg-auth-resend {
  width: calc(100% - 158px);
  margin: -8px 0 0 158px;
  font-size: 13px;
  line-height: 1.6;
  text-align: right;
  color: var(--color-text-soft);
}

.mg-auth-resend a,
.mg-auth-resend__button {
  margin-left: 6px;
  color: var(--color-primary);
  font-weight: 700;
  text-decoration: underline;
  text-underline-offset: 3px;
}

.mg-auth-resend__button {
  padding: 0;
  border: 0;
  background: transparent;
  cursor: pointer;
}

.mg-auth-resend__button:disabled {
  color: var(--color-text-soft);
  cursor: not-allowed;
  text-decoration: none;
  opacity: 0.72;
}

.password-actions {
  display: flex;
  justify-content: space-between;
  gap: 14px;
  padding-top: 4px;
}

.mg-auth-actions {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  margin-top: 4px;
  padding-top: 18px;
  border-top: 1px solid #edf1f6;
}

.mg-auth-actions__left,
.mg-auth-actions__right {
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
}

.mg-auth-actions__right {
  justify-content: flex-end;
  margin-left: auto;
}

.mg-auth-actions .password-action-button {
  min-width: 150px;
}

.password-actions--end {
  justify-content: flex-end;
}

.password-action-button {
  min-width: 180px;
}

.mg-auth-primary-button {
  min-width: 210px;
}

.mock-page--mg {
  max-width: 1680px;
}

.mg-page {
  display: grid;
  gap: 22px;
}

.mg-search-panel,
.mg-table-card,
.mg-bulk-actions {
  border: 1px solid var(--color-border);
  border-radius: 18px;
  background: #ffffff;
  box-shadow: var(--shadow-card);
}

.mg-search-panel {
  display: grid;
  gap: 14px;
  padding: 16px 18px;
}

.mg-search-grid {
  display: grid;
  grid-template-columns: repeat(6, minmax(150px, 1fr));
  gap: 12px 14px;
}

.mg-search-panel .field,
.mg-search-actions .field,
.mg-export-date {
  gap: 7px;
}

.mg-search-panel .field__label,
.mg-search-actions .field__label,
.mg-export-date .field__label {
  font-size: var(--font-size-field-hint);
}

.mg-search-panel .input,
.mg-search-panel .select,
.mg-search-actions .input,
.mg-search-actions .select,
.mg-export-date .input {
  min-height: 38px;
  padding-left: 12px;
  padding-right: 12px;
  font-size: var(--font-size-control);
}

.mg-search-grid .field--wide {
  grid-column: span 2;
}

.mg-search-grid .mg-search-row-start {
  grid-column: 1;
}

.mg-search-actions {
  display: flex;
  justify-content: flex-end;
  align-items: end;
  gap: 12px;
  padding-top: 2px;
}

.mg-sort-field {
  width: 180px;
}

.mg-count-field {
  width: 120px;
}

.mg-search-button {
  min-width: 112px;
  min-height: 38px;
}

.mg-status-update-panel {
  padding-top: 18px;
  padding-bottom: 18px;
}

.mg-status-update-grid {
  display: grid;
  grid-template-columns: minmax(190px, 1fr) 92px minmax(190px, 1fr) 92px minmax(190px, 1fr) 112px;
  gap: 12px;
  align-items: end;
}

.mg-status-update-grid .field {
  gap: 7px;
}

.mg-status-update-grid .field__label {
  font-size: var(--font-size-field-hint);
}

.mg-status-update-grid .input,
.mg-status-update-grid .select {
  min-height: 38px;
  padding-left: 12px;
  padding-right: 12px;
  font-size: var(--font-size-control);
}

.mg-inline-button {
  min-height: 38px;
  min-width: 0;
}

.mg-table-card {
  overflow: hidden;
}

.mg-table-scroll {
  overflow-x: auto;
}

.mg-table {
  width: 100%;
  min-width: 1180px;
  border-collapse: separate;
  border-spacing: 0;
  font-size: 13px;
}

.mg-table--status-update {
  min-width: 900px;
}

.mg-table th,
.mg-table td {
  padding: 12px 14px;
  border-bottom: 1px solid #e5ebf4;
  border-right: 1px solid #edf1f6;
  background: #ffffff;
  line-height: 1.5;
  vertical-align: middle;
}

.mg-table th:last-child,
.mg-table td:last-child {
  border-right: 0;
}

.mg-table th {
  background: #f8fbff;
  color: var(--color-text-soft);
  font-size: 12px;
  font-weight: 700;
  white-space: nowrap;
}

.mg-table tbody tr:hover td {
  background: #fbfdff;
}

.mg-table--orders tbody.mg-order-group:hover td {
  background: #fbfdff;
}

.mg-table--orders .mg-order-cell {
  border-right-color: #edf1f6;
  text-align: center;
  vertical-align: middle;
}

.mg-table--orders .mg-order-cell--destination {
  text-align: left;
}

.mg-table a {
  color: var(--color-primary);
  font-weight: 700;
  text-decoration: underline;
  text-underline-offset: 3px;
}

.mg-table a.mg-status {
  border: 1px solid currentColor;
  text-decoration: underline;
  text-underline-offset: 3px;
}

.mg-status {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 28px;
  padding: 0 10px;
  border-radius: 999px;
  background: #eef4ff;
  color: var(--color-primary);
  font-size: 12px;
  font-weight: 700;
  white-space: nowrap;
}

.mg-status--progress {
  background: #fff7e8;
  color: #9a681c;
}

.mg-status--draft {
  background: #eef4ff;
  color: var(--color-primary);
}

.mg-status--complete {
  background: #eef8f1;
  color: #2f7a4f;
}

.mg-table a.mg-status--complete {
  color: #2f7a4f;
}

.mg-status--cancel {
  background: #fff0f0;
  color: #a04b4b;
}

.mg-pagination {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 18px;
  color: var(--color-text-heading);
  font-size: 20px;
  font-weight: 700;
}

.mg-pagination a {
  color: var(--color-primary);
  text-decoration: underline;
  text-underline-offset: 4px;
}

.mg-bulk-actions {
  display: flex;
  align-items: end;
  justify-content: space-between;
  gap: 20px;
  padding: 20px;
}

.mg-bulk-actions .button-group {
  max-width: 760px;
}

.mg-bulk-actions .button {
  min-width: 180px;
}

.mg-export-date {
  width: 180px;
}

.mg-sales-panel {
  gap: 22px;
  padding: 20px;
}

.mg-sales-condition {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(160px, 220px) minmax(220px, 320px);
  gap: 16px;
  align-items: end;
}

.mg-sales-period .field {
  width: min(100%, 220px);
}

.mg-sales-product,
.mg-sales-product-name {
  min-width: 0;
}

.mg-sales-options {
  display: grid;
  grid-template-columns: repeat(4, minmax(170px, 1fr));
  gap: 12px;
}

.mg-sales-option {
  display: flex;
  align-items: center;
  gap: 10px;
  min-height: 52px;
  padding: 12px 14px;
  border: 1px solid #dfe7f3;
  border-radius: 14px;
  background: #fbfdff;
  color: var(--color-text-heading);
  font-size: 14px;
  font-weight: 700;
  cursor: pointer;
  transition: border-color 0.15s ease, background-color 0.15s ease, box-shadow 0.15s ease;
}

.mg-sales-option:hover {
  border-color: var(--color-border-hover);
  background: #f7faff;
  box-shadow: var(--shadow-card);
}

.mg-sales-option input {
  flex: 0 0 auto;
  width: 18px;
  height: 18px;
  accent-color: var(--color-primary);
}

.mg-sales-actions {
  display: flex;
  justify-content: flex-end;
}

.mg-sales-preview {
  display: grid;
}

.mg-sales-preview__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding: 18px 20px;
  border-bottom: 1px solid #edf1f6;
  background: linear-gradient(to bottom, #ffffff, #fbfcfe);
}

.mg-sales-preview__title {
  margin: 0;
  color: var(--color-text-heading);
  font-size: var(--font-size-heading-section);
}

.mg-sales-preview__meta {
  margin: 4px 0 0;
  color: var(--color-text-soft);
  font-size: 13px;
}

.mg-sales-csv-button {
  min-width: 140px;
}

.mg-table--sales {
  min-width: 780px;
}

.mg-master-panel {
  display: grid;
  gap: 18px;
  padding: 20px;
  border: 1px solid var(--color-border);
  border-radius: 18px;
  background: #ffffff;
  box-shadow: var(--shadow-card);
}

.mg-master-status {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  color: #1f9f58;
  font-size: 16px;
  font-weight: 700;
}

.mg-master-status__dot {
  width: 10px;
  height: 10px;
  border-radius: 999px;
  background: #1fbd65;
  box-shadow: 0 0 0 4px rgba(31, 189, 101, 0.12);
}

.mg-master-upload {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 14px;
}

.mg-master-file-button,
.mg-master-upload-button,
.mg-master-import-button {
  min-width: 150px;
}

.mg-master-file-name {
  min-width: 180px;
  color: var(--color-text-heading);
  font-size: 15px;
  font-weight: 700;
}

.mg-master-file-list {
  display: grid;
  overflow: hidden;
}

.mg-master-file-list__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding: 18px 20px;
  border-bottom: 1px solid #edf1f6;
  background: linear-gradient(to bottom, #ffffff, #fbfcfe);
}

.mg-master-file-list__title {
  margin: 0;
  color: var(--color-text-heading);
  font-size: var(--font-size-heading-section);
}

.mg-master-file-list__meta {
  margin: 4px 0 0;
  color: var(--color-text-soft);
  font-size: 13px;
}

.mg-master-files {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0;
  max-height: 560px;
  overflow: auto;
}

.mg-master-file {
  display: flex;
  align-items: center;
  gap: 8px;
  min-height: 42px;
  padding: 9px 16px;
  border-bottom: 1px solid #edf1f6;
  color: var(--color-text-heading);
  font-size: 14px;
  font-weight: 700;
}

.mg-master-file:nth-child(odd) {
  border-right: 1px solid #edf1f6;
}

.mg-master-file__mark {
  flex: 0 0 18px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--color-text-soft);
  font-size: 13px;
  font-weight: 700;
}

.mg-master-file__mark--required::before {
  content: "";
  width: 10px;
  height: 10px;
  background: var(--color-text-heading);
}

.mg-master-file__mark--group {
  color: #9a681c;
}

.mg-master-file__mark--note {
  color: var(--color-primary);
}

.mg-master-actions {
  display: flex;
  justify-content: flex-end;
}

.mg-settings-section {
  display: grid;
  gap: 0;
  border: 1px solid var(--color-border);
  border-radius: 18px;
  background: #ffffff;
  box-shadow: var(--shadow-card);
  overflow: hidden;
}

.mg-settings-section__header {
  padding: 16px 18px;
  border-bottom: 1px solid #edf1f6;
  background: linear-gradient(to bottom, #ffffff, #fbfcfe);
}

.mg-settings-section__title {
  margin: 0;
  color: var(--color-text-heading);
  font-size: var(--font-size-heading-section);
}

.mg-settings-list {
  display: grid;
  gap: 0;
  margin: 0;
  padding: 18px 20px;
}

.mg-settings-list div,
.mg-settings-row {
  display: grid;
  grid-template-columns: 220px minmax(0, 1fr);
  gap: 18px;
  align-items: center;
  min-height: 54px;
}

.mg-settings-list dt,
.mg-settings-label {
  color: var(--color-text-heading);
  font-size: 15px;
  font-weight: 700;
}

.mg-settings-list dd,
.mg-settings-value {
  margin: 0;
  color: var(--color-text-heading);
  font-size: 15px;
  font-weight: 700;
}

.mg-settings-usage {
  display: flex;
  align-items: center;
  gap: 12px;
}

.mg-settings-usage__bar {
  position: relative;
  display: block;
  width: min(100%, 240px);
  height: 10px;
  border-radius: 999px;
  background: #e8eef7;
  overflow: hidden;
}

.mg-settings-usage__bar span {
  display: block;
  height: 100%;
  border-radius: inherit;
  background: var(--color-primary);
}

.mg-settings-form {
  display: grid;
  gap: 10px;
  padding: 18px 20px 22px;
}

.mg-settings-folder {
  display: flex;
  align-items: stretch;
  width: min(100%, 560px);
}

.mg-settings-folder .input {
  border-top-right-radius: 0;
  border-bottom-right-radius: 0;
}

.mg-settings-folder__button {
  min-width: 48px;
  border-top-left-radius: 0;
  border-bottom-left-radius: 0;
}

.mg-settings-days {
  display: inline-flex;
  align-items: center;
  gap: 10px;
}

.mg-settings-days .input {
  width: 90px;
  text-align: right;
}

.mg-settings-time {
  width: 120px;
}

.mg-member-actions {
  justify-content: flex-end;
  gap: 12px;
}

.mg-detail-card {
  display: grid;
  gap: 10px;
  padding: 0;
}

.mg-detail-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 20px;
  align-items: start;
}

.mg-detail-card .section-heading {
  margin: 0;
}

.mg-definition-list {
  display: grid;
  margin: 0;
  border: 1px solid #d6e0ef;
  border-radius: 16px;
  overflow: hidden;
  background: #ffffff;
}

.mg-definition-list div {
  display: grid;
  grid-template-columns: minmax(150px, 34%) minmax(0, 1fr);
  min-height: 48px;
  border-bottom: 1px solid #e5ebf4;
}

.mg-definition-list div:last-child {
  border-bottom: 0;
}

.mg-definition-list dt,
.mg-definition-list dd {
  display: flex;
  align-items: center;
  margin: 0;
  padding: 12px 16px;
  line-height: 1.5;
}

.mg-definition-list dt {
  justify-content: center;
  border-right: 1px solid #e5ebf4;
  background: #fbfdff;
  color: var(--color-text-heading);
  font-weight: 700;
}

.mg-definition-list dd {
  color: var(--color-text);
}

.mg-definition-list__tall {
  min-height: 96px;
}

.mg-order-meta-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 16px;
}

.mg-order-meta-card {
  display: grid;
  gap: 10px;
  align-content: start;
}

.mg-order-meta-card--wide {
  grid-column: 1 / -1;
}

.mg-order-meta-card--wide .mg-definition-list {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.mg-order-meta-card--wide .mg-definition-list div:nth-child(odd) {
  border-right: 1px solid #e5ebf4;
}

.mg-order-meta-card--wide .mg-definition-list div:nth-last-child(-n + 2) {
  border-bottom: 0;
}

.mg-order-meta-card__title {
  margin: 0;
  color: var(--color-text-soft);
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.08em;
}

.mg-order-edit-form {
  padding: 16px;
  border: 1px solid #e5ebf4;
  border-radius: 8px;
  background: #fbfdff;
}

.mg-order-edit-page .button-row {
  margin-top: 18px;
}

.mg-modal {
  position: fixed;
  inset: 0;
  z-index: 500;
  display: none;
  place-items: center;
  padding: 24px;
}

.mg-modal:target {
  display: grid;
}

.mg-modal__backdrop {
  position: absolute;
  inset: 0;
  background: rgba(31, 45, 61, 0.35);
}

.mg-modal__panel {
  position: relative;
  z-index: 1;
  width: min(100%, 560px);
  max-height: min(720px, calc(100vh - 48px));
  display: grid;
  grid-template-rows: auto minmax(0, 1fr);
  overflow: hidden;
  border: 1px solid var(--color-border-strong);
  border-radius: 18px;
  background: #ffffff;
  box-shadow: 0 24px 60px rgba(31, 45, 61, 0.2);
}

.mg-modal__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding: 18px 20px;
  border-bottom: 1px solid #edf1f6;
  background: #fbfdff;
}

.mg-modal__title {
  margin: 0;
  color: var(--color-text-heading);
  font-size: 20px;
}

.mg-modal__close {
  display: inline-grid;
  place-items: center;
  width: 36px;
  height: 36px;
  border: 1px solid #d6e0ef;
  border-radius: 50%;
  color: var(--color-primary);
  font-weight: 700;
}

.mg-modal__body {
  display: grid;
  gap: 16px;
  overflow: auto;
  padding: 20px;
}

.mg-modal__summary {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  color: var(--color-text-heading);
  font-weight: 700;
}

.mg-table--modal {
  min-width: 0;
  border: 1px solid #e5ebf4;
  border-radius: 12px;
  overflow: hidden;
}

.mg-point-control {
  display: grid;
  grid-template-columns: minmax(150px, 1fr) minmax(160px, 180px) minmax(140px, auto) 96px;
  align-items: end;
  gap: 14px;
  padding: 16px;
  border: 1px solid #e5ebf4;
  border-radius: 14px;
  background: #fbfdff;
  color: var(--color-text-heading);
}

.mg-point-control__summary,
.mg-point-control__result {
  display: grid;
  gap: 6px;
  font-size: 13px;
}

.mg-point-control__summary strong,
.mg-point-control__result strong {
  font-size: 18px;
}

.mg-point-control__label,
.mg-point-control__result span {
  color: var(--color-text-soft);
  font-weight: 700;
}

.mg-point-control__input {
  gap: 7px;
}

.mg-point-control__input .input {
  min-height: 42px;
}

.mg-point-control__button {
  min-height: 42px;
}

.delivery-page {
  display: grid;
  gap: 24px;
}

.delivery-actions {
  display: flex;
  justify-content: space-between;
  gap: 14px;
  margin-top: -10px;
}

.delivery-list {
  display: grid;
  gap: 16px;
}

.delivery-card {
  position: relative;
  display: grid;
  grid-template-columns: 180px minmax(0, 1fr) auto;
  gap: 20px;
  align-items: stretch;
  padding: 18px;
  border: 1px solid var(--color-border);
  border-radius: 18px;
  background: #ffffff;
  box-shadow: var(--shadow-card);
}

.delivery-card:hover {
  box-shadow: var(--shadow-card-hover);
  border-color: var(--color-border-hover);
}

.delivery-card__link {
  display: contents;
  color: inherit;
}

.delivery-card__link:focus-visible .delivery-card__label,
.delivery-card__link:focus-visible .delivery-card__body {
  outline: 3px solid rgba(63, 111, 201, 0.22);
  outline-offset: 3px;
}

.delivery-card--main {
  border-color: #cbdaf3;
  background: linear-gradient(135deg, #ffffff, #f8fbff);
}

.delivery-card__label {
  display: flex;
  align-items: center;
  justify-content: center;
  padding-right: 18px;
  border-right: 1px solid #e3ebf6;
}

.delivery-card__badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 34px;
  padding: 0 14px;
  border-radius: 999px;
  background: #eef4ff;
  color: var(--color-primary);
  font-size: 15px;
  font-weight: 700;
}

.delivery-card__body {
  min-width: 0;
  padding-right: 40px;
}

.delivery-card__address {
  display: grid;
  gap: 8px;
  font-size: 16px;
  line-height: 1.55;
  color: var(--color-text-heading);
}

.delivery-card__delete {
  position: absolute;
  top: 14px;
  right: 14px;
  width: 36px;
  height: 36px;
  border: 0;
  border-radius: 999px;
  background: transparent;
  color: var(--color-text-heading);
  font-size: 30px;
  line-height: 1;
  cursor: pointer;
  transition: background-color 0.15s ease, color 0.15s ease;
}

.delivery-card__delete:hover {
  background: #fff2f2;
  color: #9a4c4c;
}

.delivery-info-page {
  display: grid;
  gap: 20px;
}

.delivery-info-card__header {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: 16px;
}

.delivery-info-form {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.delivery-info-zip {
  display: grid;
  grid-template-columns: auto auto;
  gap: 12px;
  align-items: end;
  justify-content: start;
}

.delivery-info-zip__inputs,
.delivery-info-phone {
  display: inline-grid;
  grid-template-columns: 76px auto 92px;
  gap: 10px;
  align-items: center;
  width: fit-content;
  max-width: 100%;
}

.delivery-info-phone {
  grid-template-columns: 72px auto 92px auto 92px;
}

.delivery-info-zip__separator {
  color: var(--color-text-soft);
  font-weight: 700;
}

.delivery-info-search .button {
  min-width: 120px;
}

.delivery-info-search {
  align-self: end;
}

.delivery-info-search .field__label--spacer {
  display: none;
}

.deadline-page {
  display: grid;
  gap: 18px;
}

.deadline-card {
  display: grid;
  gap: 22px;
  padding: 24px;
  border: 1px solid #dbe4f1;
  border-radius: 18px;
  background: #ffffff;
  box-shadow: 0 14px 36px rgba(31, 45, 61, 0.06);
}

.deadline-date-section,
.deadline-delivery-section {
  display: grid;
  gap: 18px;
}

.deadline-date-panel {
  display: grid;
  grid-template-columns: minmax(260px, 390px);
  align-items: center;
}

.deadline-field {
  display: grid;
  grid-template-columns: 140px minmax(180px, 260px);
  gap: 14px;
  align-items: center;
}

.deadline-field__label {
  font-size: 14px;
  font-weight: 700;
  color: var(--color-text-soft);
}

.deadline-date-control {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 52px;
  width: min(100%, 390px);
  min-height: 54px;
}

.deadline-date-input {
  width: 100%;
  min-height: 54px;
  padding: 8px 16px;
  border: 1px solid #c9d7eb;
  border-right: 0;
  border-radius: 12px 0 0 12px;
  background: #ffffff;
  color: var(--color-text-heading);
  font: inherit;
  font-size: 20px;
}

.deadline-calendar-button {
  display: inline-grid;
  place-items: center;
  min-width: 52px;
  min-height: 54px;
  padding: 0;
  border: 1px solid #c9d7eb;
  border-radius: 0 12px 12px 0;
  background: #f7faff;
  color: var(--color-primary);
  cursor: pointer;
  transition: background-color 0.15s ease, border-color 0.15s ease, color 0.15s ease;
}

.deadline-calendar-button:hover {
  border-color: #9bb9e8;
  background: #eef4ff;
  color: var(--color-primary-strong);
}

.deadline-calendar-button svg {
  width: 23px;
  height: 23px;
  fill: none;
  stroke: currentColor;
  stroke-width: 2;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.deadline-section-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding-top: 2px;
}

.deadline-section-head__title {
  margin: 0;
  font-size: 20px;
  color: var(--color-text-heading);
}

.deadline-section-head__text {
  margin: 6px 0 0;
  color: var(--color-text-soft);
  line-height: 1.6;
}

.deadline-delivery-list {
  display: grid;
  gap: 14px;
}

.deadline-delivery-card {
  position: relative;
  display: grid;
  gap: 10px;
  padding: 20px 58px 20px 20px;
  border: 1px solid #dbe4f1;
  border-radius: 16px;
  background: #fbfdff;
}

.deadline-delivery-card__body {
  display: grid;
  gap: 8px;
}

.deadline-delivery-card__label {
  width: fit-content;
  padding: 4px 10px;
  border-radius: 999px;
  background: #eef4ff;
  color: var(--color-primary);
  font-size: 13px;
  font-weight: 700;
}

.deadline-delivery-card__title {
  margin: 0;
  color: var(--color-text-heading);
  font-size: 20px;
}

.deadline-delivery-card__text {
  margin: 0;
  color: var(--color-text);
  font-size: 16px;
  line-height: 1.7;
}

.deadline-delivery-card__delete {
  position: absolute;
  top: 14px;
  right: 14px;
  width: 36px;
  height: 36px;
  border: 0;
  border-radius: 999px;
  background: transparent;
  color: var(--color-text-soft);
  font-size: 26px;
  line-height: 1;
  cursor: pointer;
}

.deadline-delivery-card__delete:hover {
  color: #9a4c4c;
  background: #fff2f2;
}

.deadline-actions {
  display: flex;
  justify-content: space-between;
  gap: 12px;
}

.support-event-page {
  display: grid;
  gap: 20px;
}

.support-event-filter {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  align-items: center;
  padding: 18px;
  border: 1px solid var(--color-border);
  border-radius: 18px;
  background: #ffffff;
  box-shadow: var(--shadow-card);
}

.support-event-month,
.support-event-date-tab {
  min-height: 48px;
  padding: 0 18px;
  border: 1px solid #cbd8ec;
  border-radius: 12px;
  background: #ffffff;
  color: var(--color-text-heading);
  font: inherit;
  font-weight: 700;
  cursor: pointer;
}

.support-event-month {
  display: inline-flex;
  align-items: center;
  gap: 18px;
}

.support-event-month__icon {
  color: var(--color-primary);
  font-size: 16px;
  line-height: 1;
}

.support-event-date-tabs {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.support-event-date-tab {
  color: var(--color-primary);
}

.support-event-date-tab--active,
.support-event-date-tab:hover {
  border-color: #8eade8;
  background: #eef4ff;
}

.support-event-list {
  display: grid;
  gap: 14px;
}

.support-event-card {
  display: grid;
  grid-template-columns: 110px minmax(0, 1fr) 150px;
  gap: 18px;
  align-items: center;
  padding: 18px;
  border: 1px solid var(--color-border);
  border-radius: 18px;
  background: #ffffff;
  box-shadow: var(--shadow-card);
}

.support-event-card--selectable {
  color: inherit;
  text-decoration: none;
  transition: border-color 0.16s ease, box-shadow 0.16s ease, transform 0.16s ease;
}

.support-event-card--selectable:hover,
.support-event-card--selectable:focus-visible {
  border-color: #9bb9e8;
  box-shadow: 0 18px 36px rgba(28, 60, 110, 0.1);
  transform: translateY(-2px);
}

.support-event-card--selectable:focus-visible {
  outline: 3px solid rgba(65, 112, 200, 0.24);
  outline-offset: 3px;
}

.support-event-card--selectable:hover .support-event-card__title,
.support-event-card--selectable:focus-visible .support-event-card__title {
  color: var(--color-primary);
  text-decoration: underline;
  text-underline-offset: 0.18em;
}

.support-event-card__date {
  display: grid;
  place-items: center;
  min-height: 96px;
  border-right: 1px solid #e3ebf6;
  color: var(--color-text-heading);
}

.support-event-card__date-day {
  font-size: 28px;
  font-weight: 700;
  line-height: 1;
}

.support-event-card__date-week {
  font-size: 14px;
  font-weight: 700;
  color: var(--color-text-soft);
}

.support-event-card__main {
  min-width: 0;
  display: grid;
  grid-template-columns: minmax(180px, 0.9fr) minmax(240px, 1.1fr);
  gap: 16px;
  align-items: center;
}

.support-event-card__summary {
  display: grid;
  gap: 7px;
}

.support-event-card__badge {
  width: fit-content;
  padding: 4px 10px;
  border-radius: 999px;
  background: #eef4ff;
  color: var(--color-primary);
  font-size: 12px;
  font-weight: 700;
}

.support-event-card__title {
  margin: 0;
  font-size: 22px;
  color: var(--color-text-heading);
}

.support-event-card__text {
  margin: 0;
  color: var(--color-text-soft);
  line-height: 1.7;
}

.support-event-banner {
  min-height: 116px;
  display: grid;
  place-items: center;
  border: 1px solid #cad9ee;
  border-radius: 14px;
  background:
    linear-gradient(135deg, rgba(63, 111, 201, 0.14), rgba(255, 255, 255, 0.92)),
    repeating-linear-gradient(135deg, rgba(63, 111, 201, 0.08) 0 12px, rgba(63, 111, 201, 0.03) 12px 24px);
  color: var(--color-primary);
  font-size: 14px;
  font-weight: 700;
  letter-spacing: 0.08em;
}

.support-event-banner--green {
  background:
    linear-gradient(135deg, rgba(63, 148, 120, 0.16), rgba(255, 255, 255, 0.92)),
    repeating-linear-gradient(135deg, rgba(63, 148, 120, 0.08) 0 12px, rgba(63, 148, 120, 0.03) 12px 24px);
  color: #2f7d68;
}

.support-event-banner--rose {
  background:
    linear-gradient(135deg, rgba(172, 85, 112, 0.14), rgba(255, 255, 255, 0.92)),
    repeating-linear-gradient(135deg, rgba(172, 85, 112, 0.08) 0 12px, rgba(172, 85, 112, 0.03) 12px 24px);
  color: #944b62;
}

.support-event-banner--amber {
  background:
    linear-gradient(135deg, rgba(184, 130, 45, 0.14), rgba(255, 255, 255, 0.92)),
    repeating-linear-gradient(135deg, rgba(184, 130, 45, 0.08) 0 12px, rgba(184, 130, 45, 0.03) 12px 24px);
  color: #8a6428;
}

.support-event-card__meta {
  display: grid;
  gap: 8px;
  color: var(--color-text-heading);
  line-height: 1.6;
}

.coupon-page {
  display: grid;
  gap: 24px;
}

.coupon-hero {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 20px;
  align-items: center;
  padding: 24px 28px;
  border: 1px solid var(--color-border);
  border-radius: 20px;
  background: linear-gradient(135deg, #ffffff, #f6faff);
  box-shadow: var(--shadow-card);
}

.coupon-hero__eyebrow {
  display: inline-block;
  margin-bottom: 6px;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.08em;
  color: var(--color-primary);
}

.coupon-hero__title {
  margin: 0;
  font-size: 28px;
  line-height: 1.2;
  color: var(--color-text-heading);
}

.coupon-hero__text {
  margin: 10px 0 0;
  max-width: 720px;
  font-size: 14px;
  line-height: 1.8;
  color: var(--color-text-soft);
}

.coupon-hero__status {
  min-width: 250px;
  display: grid;
  gap: 7px;
  padding: 13px 16px;
  border: 1px solid #dce6f3;
  border-radius: 18px;
  background: linear-gradient(to bottom, #ffffff, #f9fbff);
  box-shadow: var(--shadow-card);
}

.coupon-hero__status-label {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.08em;
  color: var(--color-primary);
}

.coupon-hero__status-value {
  font-size: 20px;
  font-weight: 700;
  color: var(--color-text-heading);
}

.coupon-hero__status-text {
  font-size: 13px;
  line-height: 1.7;
  color: var(--color-text-soft);
}

.coupon-redeem {
  display: grid;
  gap: 18px;
  padding: 22px;
  border: 1px solid var(--color-border);
  border-radius: 18px;
  background: #ffffff;
  box-shadow: var(--shadow-card);
}

.coupon-redeem__header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
}

.coupon-redeem__title {
  margin: 0;
  font-size: 22px;
  color: var(--color-text-heading);
}

.coupon-redeem__text {
  margin: 6px 0 0;
  font-size: 13px;
  line-height: 1.7;
  color: var(--color-text-soft);
}

.coupon-redeem__form {
  display: flex;
  flex-wrap: wrap;
  gap: 14px;
  align-items: center;
}

.coupon-redeem__form .input {
  flex: 1 1 320px;
}

.coupon-section {
  display: grid;
  gap: 18px;
}

.coupon-section .section-heading--split {
  font-size: 20px;
}

.coupon-list {
  display: grid;
  gap: 16px;
}

.coupon-card {
  display: grid;
  grid-template-columns: 220px minmax(0, 1fr) auto;
  gap: 20px;
  align-items: center;
  padding: 18px;
  border: 1px solid var(--color-border);
  border-radius: 18px;
  background: #ffffff;
  box-shadow: var(--shadow-card);
}

.coupon-card__visual {
  min-height: 132px;
  display: grid;
  place-items: center;
  padding: 18px;
  border: 1px dashed #a9bddf;
  border-radius: 16px;
  background:
    linear-gradient(135deg, rgba(63, 111, 201, 0.08), rgba(255, 255, 255, 0.96)),
    repeating-linear-gradient(135deg, rgba(63, 111, 201, 0.05) 0 12px, rgba(63, 111, 201, 0.02) 12px 24px);
  text-align: center;
}

.coupon-card__visual-badge {
  display: inline-block;
  margin-bottom: 8px;
  padding: 5px 10px;
  border-radius: 999px;
  background: rgba(63, 111, 201, 0.12);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.08em;
  color: var(--color-primary);
}

.coupon-card__visual-title {
  margin: 0;
  font-size: 24px;
  color: var(--color-text-heading);
}

.coupon-card__content {
  display: grid;
  gap: 10px;
}

.coupon-card__title {
  margin: 0;
  font-size: 24px;
  color: var(--color-text-heading);
}

.coupon-card__lead {
  margin: 0;
  font-size: 14px;
  line-height: 1.7;
  color: var(--color-text-soft);
}

.coupon-meta {
  display: grid;
  gap: 10px;
}

.coupon-meta__item {
  display: grid;
  gap: 4px;
  padding: 10px 12px;
  border: 1px solid #e5ebf5;
  border-radius: 12px;
  background: #fbfcff;
}

.coupon-meta__label {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.08em;
  color: var(--color-text-soft);
}

.coupon-meta__value {
  font-size: 15px;
  color: var(--color-text-heading);
}

.coupon-card__action {
  min-width: 180px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.coupon-card__action--primary {
  min-width: 180px;
  justify-content: center;
}

.coupon-card--applied {
  border-color: #cddcf3;
  background: linear-gradient(135deg, #ffffff, #f8fbff);
}

.coupon-card--applied .coupon-card__visual {
  border-style: solid;
}

.button--success {
  background: linear-gradient(135deg, #3f6fc9, #5e89da);
  border-color: var(--color-primary-strong);
  color: #ffffff;
}

.button--cta {
  min-height: 56px;
  min-width: 180px;
  padding: 0 30px;
  border-radius: 999px;
  box-shadow: 0 12px 24px rgba(63, 111, 201, 0.18);
}

.button--cta:hover {
  box-shadow: 0 16px 30px rgba(63, 111, 201, 0.22);
}

.button--apply {
  min-height: 52px;
  min-width: 180px;
  padding: 0 28px;
  border-radius: 999px;
  box-shadow: 0 12px 24px rgba(63, 111, 201, 0.14);
}

.button--apply:hover {
  box-shadow: 0 16px 30px rgba(63, 111, 201, 0.2);
}

.button--release {
  min-height: 52px;
  min-width: 180px;
  padding: 0 28px;
  border-color: #b9c9e4;
  border-radius: 999px;
  background: linear-gradient(180deg, #ffffff 0%, #f5f8fd 100%);
  color: var(--color-text-heading);
  box-shadow: 0 10px 20px rgba(31, 45, 61, 0.08);
}

.button--release:hover {
  border-color: #9fb5df;
  box-shadow: 0 14px 26px rgba(31, 45, 61, 0.12);
}

.coupon-acquire-page {
  display: grid;
  gap: 24px;
}

.coupon-acquire-card {
  display: grid;
  gap: 24px;
  padding: 24px;
  border: 1px solid var(--color-border);
  border-radius: 20px;
  background: #ffffff;
  box-shadow: var(--shadow-card);
}

.coupon-acquire-visual {
  min-height: 220px;
  display: grid;
  place-items: center;
  padding: 24px;
  border: 1px dashed #a9bddf;
  border-radius: 18px;
  background:
    linear-gradient(135deg, rgba(63, 111, 201, 0.08), rgba(255, 255, 255, 0.96)),
    repeating-linear-gradient(135deg, rgba(63, 111, 201, 0.05) 0 12px, rgba(63, 111, 201, 0.02) 12px 24px);
  text-align: center;
}

.coupon-acquire-visual__inner {
  display: grid;
  gap: 10px;
  justify-items: center;
}

.coupon-acquire-visual__badge {
  display: inline-block;
  padding: 5px 10px;
  border-radius: 999px;
  background: rgba(63, 111, 201, 0.12);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.08em;
  color: var(--color-primary);
}

.coupon-acquire-visual__title {
  margin: 0;
  font-size: 34px;
  color: var(--color-text-heading);
}

.coupon-acquire-detail {
  display: grid;
  gap: 12px;
  padding: 18px 20px;
  border: 1px solid #e4ebf5;
  border-radius: 18px;
  background: #fbfcff;
}

.coupon-acquire-detail__row {
  display: grid;
  gap: 4px;
}

.coupon-acquire-detail__label {
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.08em;
  color: var(--color-text-soft);
}

.coupon-acquire-detail__value {
  font-size: 17px;
  line-height: 1.7;
  color: var(--color-text-heading);
}

.coupon-acquire-confirm {
  display: grid;
  gap: 18px;
  width: min(100%, 520px);
  margin: 0 auto;
  justify-items: center;
  padding: 12px 2px 0;
  text-align: center;
}

.coupon-acquire-confirm__text {
  margin: 0;
  font-size: 26px;
  line-height: 1.5;
  color: var(--color-text-heading);
}

.coupon-acquire-actions {
  display: flex;
  width: 100%;
  justify-content: center;
  align-items: center;
  gap: 16px;
}

@media (max-width: 900px) {
  .tile-grid--cards,
  .tile-grid--mg-summary {
    grid-template-columns: repeat(2, 1fr);
  }

  .tile-grid--actions {
    grid-template-columns: 1fr;
  }

  .flow-steps,
  .detail-grid,
  .form-grid,
  .order-layout,
  .page-intro,
  .account-hero,
  .account-grid,
  .account-summary,
  .coupon-hero,
  .point-history-hero,
  .document-shell,
  .mg-search-grid,
  .login-panel,
  .delivery-card,
  .support-event-card,
  .support-event-card__main,
  .cart-overview,
  .cart-info-grid,
  .cart-payment,
  .payment-step,
  .payment-methods,
  .document-actions {
    grid-template-columns: 1fr;
  }

  .detail-grid.product-customer-grid,
  .detail-grid.product-submission-grid,
  .form-grid.product-submission-grid,
  .product-info-layout,
  .product-status-card-grid,
  .product-status-card__grid {
    grid-template-columns: 1fr;
  }

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

  .shipping-registration {
    grid-template-columns: 1fr;
  }

  .shipping-registration__side,
  .shipping-registration__button {
    justify-items: stretch;
    justify-self: stretch;
  }

  .submission-confirm-box__content {
    display: grid;
    gap: 8px;
  }

  .submission-confirm-box__title,
  .submission-confirm-box__notice,
  .submission-confirm-box__textarea,
  .submission-confirm-box__button {
    grid-column: auto;
    grid-row: auto;
  }

  .submission-confirm-box__button {
    width: 100%;
  }

  .payment-step {
    gap: 16px;
  }

  .mg-auth-card {
    min-height: auto;
  }

  .mg-search-grid .field--wide {
    grid-column: auto;
  }

  .mg-search-actions,
  .mg-bulk-actions {
    align-items: stretch;
    flex-direction: column;
  }

  .mg-sales-condition,
  .mg-sales-options {
    grid-template-columns: 1fr;
  }

  .mg-sales-period,
  .mg-sales-preview__header {
    align-items: stretch;
    flex-direction: column;
  }

  .mg-sales-period .field {
    width: 100%;
  }

  .mg-order-meta-grid {
    grid-template-columns: 1fr;
  }

  .mg-order-meta-card--wide .mg-definition-list {
    grid-template-columns: 1fr;
  }

  .mg-order-meta-card--wide .mg-definition-list div:nth-child(odd) {
    border-right: 0;
  }

  .mg-order-meta-card--wide .mg-definition-list div:nth-last-child(-n + 2) {
    border-bottom: 1px solid #e5ebf4;
  }

  .mg-order-meta-card--wide .mg-definition-list div:last-child {
    border-bottom: 0;
  }

  .product-definition-list--customer,
  .product-definition-list--submission {
    grid-template-columns: 1fr;
  }

  .product-definition-list--customer div:nth-child(odd),
  .product-definition-list--submission div {
    border-right: 0;
  }

  .product-definition-list--customer div:nth-last-child(-n + 2),
  .product-definition-list--submission div {
    border-bottom: 1px solid #e5ebf4;
  }

  .product-definition-list--customer div:last-child,
  .product-definition-list--submission div:last-child {
    border-bottom: 0;
  }

  .product-submission-edit-layout {
    grid-template-columns: 1fr;
  }

  .mg-master-upload,
  .mg-master-file-list__header,
  .mg-master-actions {
    align-items: stretch;
    flex-direction: column;
  }

  .mg-master-files {
    grid-template-columns: 1fr;
  }

  .mg-master-file:nth-child(odd) {
    border-right: 0;
  }

  .mg-master-file-button,
  .mg-master-upload-button,
  .mg-master-import-button {
    width: 100%;
  }

  .mg-settings-list div,
  .mg-settings-row {
    grid-template-columns: 1fr;
    gap: 8px;
  }

  .mg-settings-folder {
    width: 100%;
  }

  .mg-status-update-grid {
    grid-template-columns: 1fr;
  }

  .mg-detail-grid {
    grid-template-columns: 1fr;
  }

  .mg-definition-list div,
  .mg-point-control {
    grid-template-columns: 1fr;
  }

  .mg-definition-list dt {
    justify-content: flex-start;
    border-right: 0;
    border-bottom: 1px solid #e5ebf4;
  }

  .mg-sort-field,
  .mg-count-field,
  .mg-export-date {
    width: 100%;
  }

  .payment-step__head {
    padding-top: 0;
    padding-bottom: 4px;
    border-right: 0;
  }

  .payment-point-control {
    flex-wrap: wrap;
  }

  .payment-point-input {
    width: min(100%, 180px);
  }

  .cart-delivery-panel {
    grid-column: auto;
    grid-template-rows: none;
    align-content: start;
  }

  .cart-overview__side,
  .cart-delivery {
    grid-template-rows: none;
  }

  .cart-payment__actions {
    justify-content: stretch;
  }

  .cart-payment__actions .cart-action-button--primary {
    width: 100%;
    min-width: 0;
  }

  .page-intro {
    flex-direction: column;
  }

  .coupon-hero,
  .coupon-card {
    grid-template-columns: 1fr;
  }

  .coupon-card__action {
    min-width: 0;
    width: 100%;
  }

  .cart-card__status {
    justify-content: flex-start;
  }

  .page-intro__meta {
    min-width: 0;
    width: 100%;
  }

  .page-actions,
  .page-support-row {
    justify-content: flex-start;
  }

  .page-status-card {
    min-width: 0;
    width: 100%;
  }

  .page-status-line {
    width: 100%;
    justify-content: flex-start;
  }

  .point-history-balance {
    min-width: 0;
    width: 100%;
  }

  .aside-card {
    position: static;
  }
}

@media (max-width: 640px) {
  .mock-page {
    padding: 0 14px;
  }

  .app-header__inner,
  .app-footer__inner {
    padding-left: 14px;
    padding-right: 14px;
  }

  .app-content {
    padding-top: 20px;
    padding-bottom: 24px;
  }

  .app-brand {
    font-size: 24px;
  }

  .app-brand__suffix {
    display: inline-block;
    margin-left: 4px;
    letter-spacing: 0.1em;
  }

  .tile-grid--cards,
  .tile-grid--mg-summary {
    grid-template-columns: 1fr;
  }

  .tile {
    min-height: 140px;
  }

  .section-heading {
    font-size: 16px;
    padding: 12px 14px;
  }

  .tile--action {
    min-height: 110px;
    font-size: 21px;
  }

  .link-list {
    gap: 6px 0;
  }

  .status-bar {
    width: 100%;
    justify-content: flex-start;
  }

  .status-link {
    gap: 6px;
  }

  .link-list__item {
    min-height: 32px;
    padding: 0 10px;
  }

  .app-footer__inner {
    align-items: flex-start;
    flex-direction: column;
    justify-content: center;
  }

  .page-intro__title,
  .panel__title,
  .review-card__title,
  .account-hero__title,
  .coupon-hero__title,
  .point-history-hero__title {
    font-size: var(--font-size-heading-page-mobile);
  }

  .page-intro,
  .account-hero,
  .coupon-hero,
  .point-history-hero {
    padding: 14px 16px;
  }

  .page-intro__meta-value {
    font-size: 20px;
  }

  .review-card__header {
    align-items: flex-start;
    flex-direction: column;
  }

  .point-history-card__header {
    align-items: flex-start;
    flex-direction: column;
  }

  .point-history-current {
    padding-left: 0;
    border-left: 0;
  }

  .coupon-redeem__header,
  .page-intro,
  .account-hero,
  .account-card__header,
  .account-actions,
  .account-danger-zone__main,
  .account-danger-zone__danger,
  .account-danger-zone__actions,
  .point-history-hero,
  .cart-card__top,
  .cart-products__header {
    grid-template-columns: 1fr;
    align-items: flex-start;
    flex-direction: column;
  }

  .point-history-item {
    grid-template-columns: 1fr;
    gap: 10px;
  }

  .point-history-item__point {
    justify-self: start;
  }

  .message-item {
    gap: 16px;
    padding-inline: 0;
  }

  .message-item__header {
    align-items: flex-start;
    flex-direction: column;
    gap: 8px;
  }

  .message-pagination {
    min-height: 120px;
  }

  .message-compose-row,
  .message-compose-row--body {
    grid-template-columns: 1fr;
    gap: 8px;
  }

  .message-compose-form {
    padding: 18px;
  }

  .message-compose-label {
    min-height: 0;
    text-align: left;
  }

  .message-compose-actions {
    flex-direction: column;
    padding-top: 16px;
  }

  .message-compose-button {
    width: 100%;
  }

  .message-thread-summary {
    grid-template-columns: 1fr;
  }

  .message-thread {
    min-height: 440px;
    padding: 0 14px 18px;
  }

  .message-thread__title {
    margin: 0 -14px;
    min-height: 52px;
    padding: 0 14px;
    font-size: var(--font-size-heading-section);
  }

  .message-bubble {
    max-width: 100%;
  }

  .message-bubble__meta {
    align-items: flex-start;
    flex-direction: column;
    gap: 4px;
  }

  .message-reply {
    padding: 16px;
  }

  .message-reply__actions {
    flex-direction: column;
  }

  .mg-message-search,
  .mg-message-search__grid,
  .mg-message-date-range,
  .mg-message-thread-summary {
    grid-template-columns: 1fr;
  }

  .mg-message-search__wide,
  .mg-message-date-range {
    grid-column: auto;
  }

  .mg-message-date-range {
    align-items: stretch;
    flex-direction: column;
  }

  .range-field__separator {
    min-height: auto;
    justify-content: center;
  }

  .mg-message-search__actions,
  .mg-message-thread-summary__action,
  .mg-message-resolve-button {
    width: 100%;
  }

  .mg-message-thread-summary__action {
    justify-content: stretch;
  }

  .mg-message-resolve-button {
    min-width: 0;
  }

  .upload-consent-actions {
    flex-direction: column;
    min-height: 0;
  }

  .upload-consent-button {
    width: 100%;
  }

  .upload-card {
    padding: 16px;
  }

  .upload-card__header {
    flex-direction: column;
  }

  .upload-target {
    width: 100%;
  }

  .upload-info-grid {
    grid-template-columns: 1fr;
  }

  .upload-dropzone__header {
    align-items: stretch;
    flex-direction: column;
    min-height: 0;
  }

  .upload-add-button,
  .upload-submit-button {
    width: 100%;
  }

  .upload-dropzone__body {
    min-height: 320px;
  }

  .upload-actions {
    min-height: 0;
  }

  .express-upload-section {
    padding: 16px;
  }

  .express-file-table {
    overflow-x: auto;
  }

  .express-file-table__row {
    grid-template-columns: 56px 90px minmax(160px, 1fr) 110px 120px;
    min-width: 560px;
    padding: 0 12px;
  }

  .express-upload-button,
  .express-submit-button {
    width: 100%;
  }

  .express-submit-actions {
    padding-top: 24px;
  }

  .express-modal {
    padding: 12px;
  }

  .express-preview__workspace {
    grid-template-columns: 1fr;
  }

  .express-preview__thumbs {
    grid-auto-flow: column;
    grid-auto-columns: 170px;
    overflow-x: auto;
    max-height: none;
  }

  .express-preview__main {
    min-height: 620px;
  }

  .express-preview__spread-main {
    min-height: 500px;
  }

  .express-image-preview__canvas {
    min-height: 420px;
  }

  .express-image-preview__canvas {
    margin: 0 34px;
  }

  .express-preview__actions {
    flex-direction: column;
  }

  .express-preview__button {
    width: 100%;
  }

  .express-art--large {
    width: 150px;
    height: 150px;
  }

  .express-art--bolt.express-art--large {
    width: 150px;
    height: 320px;
  }

  .cart-card__heading {
    width: 100%;
    justify-content: flex-start;
  }

  .cart-product {
    grid-template-columns: 1fr;
    align-items: flex-start;
  }

  .register-form,
  .register-address {
    grid-template-columns: 1fr;
  }

  .register-address__button .button,
  .register-submit-button {
    width: 100%;
  }

  .register-actions {
    justify-content: stretch;
  }

  .register-actions--split {
    flex-direction: column;
  }

  .password-actions {
    flex-direction: column;
  }

  .mg-auth-form {
    padding: 20px;
  }

  .mg-auth-form .field {
    grid-template-columns: 1fr;
    gap: 8px;
  }

  .mg-auth-card .form-message {
    margin: 16px 20px -4px;
  }

  .mg-auth-form .field-error {
    width: 100%;
    margin: -12px 0 0;
  }

  .mg-auth-status {
    width: 100%;
    margin: -10px 0 0;
  }

  .mg-auth-resend {
    width: 100%;
    margin-left: 0;
  }

  .mg-auth-actions {
    align-items: stretch;
    gap: 12px;
  }

  .mg-auth-actions__left,
  .mg-auth-actions__right {
    width: 100%;
  }

  .password-action-button {
    width: 100%;
    min-width: 0;
  }

  .mg-auth-primary-button {
    width: 100%;
    min-width: 0;
  }

  .delivery-actions {
    flex-direction: column;
  }

  .deadline-card {
    padding: 18px;
  }

  .deadline-field {
    grid-template-columns: 1fr;
  }

  .deadline-date-panel {
    grid-template-columns: 1fr;
  }

  .deadline-date-control {
    width: 100%;
  }

  .deadline-section-head,
  .deadline-actions {
    flex-direction: column;
    align-items: stretch;
  }

  .delivery-card__label {
    justify-content: flex-start;
    padding-right: 0;
    padding-bottom: 14px;
    border-right: 0;
    border-bottom: 1px solid #e3ebf6;
  }

  .delivery-card__body {
    padding-right: 0;
  }

  .delivery-info-card__header {
    align-items: flex-start;
    flex-direction: column;
  }

  .delivery-info-form,
  .delivery-info-zip {
    grid-template-columns: 1fr;
  }

  .delivery-info-zip__inputs,
  .delivery-info-phone {
    display: grid;
    grid-template-columns: 1fr;
    width: 100%;
  }

  .delivery-info-zip__separator {
    display: none;
  }

  .delivery-info-search .button,
  .delivery-info-card__header .button {
    width: 100%;
  }

  .support-event-filter,
  .support-event-date-tabs {
    align-items: stretch;
    flex-direction: column;
  }

  .support-event-month,
  .support-event-date-tab {
    width: 100%;
  }

  .support-event-card__date {
    min-height: 0;
    place-items: start;
    padding-bottom: 14px;
    border-right: 0;
    border-bottom: 1px solid #e3ebf6;
  }

  .support-event-card__date-day {
    font-size: 24px;
  }

  .support-event-banner {
    min-height: 104px;
  }

  .login-form__actions,
  .login-form__primary {
    width: 100%;
    justify-items: stretch;
  }

  .login-form__actions {
    flex-direction: column;
  }

  .login-form__primary,
  .page-actions .button--primary,
  .delivery-actions .button--primary,
  .deadline-actions .button--primary,
  .password-actions .button--primary,
  .register-actions .button--primary,
  .button-row .button-group:has(.button--primary) {
    order: -1;
  }

  .login-primary-button,
  .login-secondary-button {
    width: 100%;
    min-width: 0;
  }

  .document-card__header {
    align-items: flex-start;
    flex-direction: column;
  }

  .document-line,
  .document-total {
    grid-template-columns: 1fr auto;
  }

  .profile-grid {
    grid-template-columns: 1fr;
  }

  .button--compact {
    width: auto;
  }

  .button-row,
  .button-group {
    flex-direction: column;
  }

  .section-heading--split {
    align-items: center;
    flex-direction: row;
    flex-wrap: wrap;
  }

  .coupon-acquire-confirm__text {
    font-size: 22px;
  }

  .coupon-card__action--primary,
  .button--apply,
  .button--release,
  .coupon-acquire-actions .button--cta {
    width: 100%;
  }

  .button {
    width: 100%;
  }

  .payment-point-entry {
    flex: 1 1 0;
    min-width: 0;
  }

  .payment-point-input {
    width: 100%;
  }

  .payment-point-apply {
    flex: 0 0 auto;
    width: auto;
    min-width: 88px;
  }

  .cart-icon-button {
    width: 36px;
    min-width: 36px;
    height: 36px;
    min-height: 36px;
  }

  .submission-definition-list,
  .submission-mail-panel__action {
    grid-template-columns: 1fr;
  }

  .submission-definition-list div:nth-child(odd) {
    border-right: 0;
  }

  .submission-definition-list div:nth-last-child(-n + 2) {
    border-bottom: 1px solid #e5ebf4;
  }

  .submission-definition-list div:last-child {
    border-bottom: 0;
  }

  .submission-status-control__row,
  .submission-mail-panel__button {
    width: 100%;
  }

  .submission-history-card__header,
  .submission-file-row {
    grid-template-columns: 1fr;
  }

  .submission-history-card__header {
    display: grid;
  }

  .submission-history-card__download-all,
  .submission-file-row__button {
    width: 100%;
  }

  .submission-history-card__path {
    grid-template-columns: minmax(0, 1fr) auto;
  }
}
