/* MS Configurator v1.1 – 3-column layout, repost support */

:root {
    --ms-cfg-accent: #ff7043; --ms-cfg-accent-hover: #e6623a; --ms-cfg-accent-bg: rgba(255,112,67,0.07);
    --ms-cfg-navy: #00144a; --ms-cfg-navy-light: #1a2e5a; --ms-cfg-white: #fff;
    --ms-cfg-text: #1a1a1a; --ms-cfg-text-muted: #888; --ms-cfg-text-light: #aaa;
    --ms-cfg-card-bg: #fff; --ms-cfg-card-border: #e5e5e5; --ms-cfg-card-radius: 12px;
    --ms-cfg-divider: #eee; --ms-cfg-input-border: #d5d5d5; --ms-cfg-gap: 1.5rem;
    --ms-cfg-info-bg: #fef9e7; --ms-cfg-info-border: #fce9a0;
}
.ms-configurator { font-family: inherit; color: var(--ms-cfg-text); max-width: 1200px; margin: 0 auto; }
.ms-configurator *, .ms-configurator *::before, .ms-configurator *::after { box-sizing: border-box; }

/* Header */
.ms-cfg__header { margin-bottom: 2rem; }
.ms-cfg__title { font-size: 1.75rem; font-weight: 800; color: var(--ms-cfg-navy); margin: 0 0 .5rem; letter-spacing: -.02em; line-height: 1.2; }
.ms-cfg__subtitle { font-size: .95rem; color: var(--ms-cfg-text-muted); margin: 0; line-height: 1.55; max-width: 600px; }

/* 3-col */
.ms-cfg__layout { display: grid; grid-template-columns: 220px 1fr 280px; gap: var(--ms-cfg-gap); align-items: start; }
@media (max-width: 1024px) { .ms-cfg__layout { grid-template-columns: 1fr; } }

/* Sidebar */
.ms-cfg__sidebar { position: sticky; top: 2rem; }
.ms-cfg__sidebar-inner { background: var(--ms-cfg-card-bg); border: 1px solid var(--ms-cfg-card-border); border-radius: var(--ms-cfg-card-radius); padding: 1.25rem; }
.ms-cfg__sidebar-label { display: block; font-size: .7rem; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; color: var(--ms-cfg-text-muted); margin-bottom: 1rem; }
.ms-cfg__sidebar-models { display: flex; flex-direction: column; gap: .85rem; margin-bottom: 1.25rem; }
.ms-cfg__sidebar-model { display: flex; align-items: center; gap: .65rem; position: relative; }
.ms-cfg__sidebar-avatar { width: 44px; height: 44px; border-radius: 50%; object-fit: cover; flex-shrink: 0; background: #f0f0f0; }
.ms-cfg__sidebar-avatar--placeholder { display: inline-flex; align-items: center; justify-content: center; font-weight: 700; font-size: 1rem; color: var(--ms-cfg-text-muted); }
.ms-cfg__sidebar-info { display: flex; flex-direction: column; min-width: 0; }
.ms-cfg__sidebar-name { font-weight: 600; font-size: .9rem; color: var(--ms-cfg-text); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.ms-cfg__sidebar-link { text-decoration: none; color: inherit; }
.ms-cfg__sidebar-link:hover .ms-cfg__sidebar-name { color: var(--ms-cfg-accent); text-decoration: underline; }
.ms-cfg__sidebar-link:hover .ms-cfg__sidebar-avatar { opacity: .85; }
.ms-cfg__sidebar-price { font-size: .75rem; color: var(--ms-cfg-text-muted); }
.ms-cfg__sidebar-remove { display: inline-flex; align-items: center; justify-content: center; width: 22px; height: 22px; border-radius: 50%; border: none; background: transparent; color: #d32f2f; font-size: 1.1rem; font-weight: 700; cursor: pointer; padding: 0; flex-shrink: 0; opacity: .5; transition: all .15s; line-height: 1; }
.ms-cfg__sidebar-remove:hover { opacity: 1; background: #ffeaea; }
.ms-cfg__sidebar-add { display: flex; align-items: center; justify-content: center; width: 100%; padding: .6em 1em; border: 1px solid var(--ms-cfg-card-border); border-radius: 8px; background: transparent; color: var(--ms-cfg-text); font-size: .85rem; font-weight: 600; text-decoration: none; cursor: pointer; transition: all .15s; }
.ms-cfg__sidebar-add:hover { border-color: var(--ms-cfg-accent); color: var(--ms-cfg-accent); background: var(--ms-cfg-accent-bg); }

/* Center */
.ms-cfg__center { display: flex; flex-direction: column; gap: 1rem; }

/* Group card */
.ms-cfg__group { background: var(--ms-cfg-card-bg); border: 1px solid var(--ms-cfg-card-border); border-left: 4px solid var(--ms-cfg-navy); border-radius: var(--ms-cfg-card-radius); box-shadow: 0 2px 8px rgba(0,20,74,.06); padding: 1.1rem 1rem; transition: box-shadow .2s; }
.ms-cfg__group:hover { box-shadow: 0 4px 16px rgba(0,20,74,.1); }
.ms-cfg__group-header { display: flex; align-items: center; justify-content: space-between; margin-bottom: .75rem; padding-bottom: .6rem; border-bottom: 1px solid var(--ms-cfg-divider); flex-wrap: wrap; gap: .4rem; }
.ms-cfg__group-header-left { display: flex; align-items: center; gap: .5rem; }
.ms-cfg__group-badge { display: inline-flex; align-items: center; justify-content: center; width: 30px; height: 30px; border-radius: 50%; background: var(--ms-cfg-navy); color: #fff; font-size: .85rem; font-weight: 700; flex-shrink: 0; }
.ms-cfg__group-title { font-size: 1rem; font-weight: 800; color: var(--ms-cfg-navy); margin: 0; }
.ms-cfg__group-header-right { display: flex; align-items: center; gap: .5rem; }
.ms-cfg__group-price { font-size: 1.1rem; font-weight: 800; color: var(--ms-cfg-navy); font-variant-numeric: tabular-nums; }
.ms-cfg__group-remove { width: 28px; height: 28px; display: inline-flex; align-items: center; justify-content: center; border: 1px solid var(--ms-cfg-card-border); border-radius: 50%; background: transparent; color: var(--ms-cfg-text-muted); font-size: 1rem; cursor: pointer; transition: all .15s; padding: 0; line-height: 1; }
.ms-cfg__group-remove:hover { background: #d32f2f; color: #fff; border-color: #d32f2f; }
.ms-cfg__group-toggle { width: 28px; height: 28px; display: inline-flex; align-items: center; justify-content: center; border: 1px solid var(--ms-cfg-card-border); border-radius: 50%; background: transparent; color: var(--ms-cfg-text-muted); cursor: pointer; transition: all .15s; padding: 0; }
.ms-cfg__group-toggle:hover { border-color: var(--ms-cfg-navy); color: var(--ms-cfg-navy); }
.ms-cfg__group-toggle svg { display: block; }
.ms-cfg__group-warning { font-size: .72rem; font-weight: 600; color: #d32f2f; background: #fff5f5; padding: .15em .5em; border-radius: 4px; margin-left: .5rem; }
.ms-cfg__group--collapsed { padding: .65rem 1rem; }
.ms-cfg__group--collapsed .ms-cfg__group-header { margin-bottom: 0; padding-bottom: 0; border-bottom: none; }

/* Field + stepper */
.ms-cfg__field { margin-bottom: 1rem; }
.ms-cfg__field-label { display: block; font-weight: 600; font-size: .85rem; color: var(--ms-cfg-text); margin-bottom: .35rem; }
.ms-cfg__optional { font-weight: 400; font-style: italic; color: var(--ms-cfg-text-muted); }
.ms-cfg__field-hint { display: block; font-size: .8rem; color: var(--ms-cfg-text-muted); margin-top: .4rem; }
.ms-cfg__stepper { display: inline-flex; align-items: center; border: 1px solid var(--ms-cfg-input-border); border-radius: 8px; overflow: hidden; transition: border-color .15s; }
.ms-cfg__stepper:focus-within { border-color: var(--ms-cfg-navy); }
.ms-cfg__stepper-btn { width: 44px; height: 44px; display: inline-flex; align-items: center; justify-content: center; border: none; background: transparent; font-size: 1.2rem; font-weight: 500; cursor: pointer; font-family: inherit; color: var(--ms-cfg-text); transition: background .12s; padding: 0; }
.ms-cfg__stepper-btn:hover { background: #f5f5f5; }
.ms-cfg__stepper-input { width: 56px; height: 44px; text-align: center; border: none; border-left: 1px solid var(--ms-cfg-input-border); border-right: 1px solid var(--ms-cfg-input-border); font-size: 1.1rem; font-weight: 700; font-family: inherit; background: #fff; color: var(--ms-cfg-text); -moz-appearance: textfield; }
.ms-cfg__stepper-input::-webkit-inner-spin-button, .ms-cfg__stepper-input::-webkit-outer-spin-button { -webkit-appearance: none; margin: 0; }

/* Model cards (with per-model repost) */
.ms-cfg__models-section { margin-bottom: .75rem; }
.ms-cfg__models-list { display: flex; flex-direction: column; gap: .35rem; }

.ms-cfg__model-card { border: 1px solid var(--ms-cfg-card-border); border-radius: 8px; overflow: visible; transition: all .15s; background: #fff; }
.ms-cfg__model-card:hover { border-color: #ccc; }
.ms-cfg__model-card--active { border-color: var(--ms-cfg-navy); background: #fafbfd; }

.ms-cfg__model-row { display: flex; align-items: center; gap: .5rem; padding: .45rem .65rem; cursor: pointer; }
.ms-cfg__model-checkbox-wrap { flex-shrink: 0; }
.ms-cfg__model-checkbox-wrap input[type="checkbox"] { width: 18px; height: 18px; accent-color: var(--ms-cfg-navy); cursor: pointer; }
.ms-cfg__model-avatar { width: 36px; height: 36px; border-radius: 50%; object-fit: cover; flex-shrink: 0; }
.ms-cfg__model-name { flex: 1; font-weight: 600; font-size: .925rem; color: var(--ms-cfg-text); }
.ms-cfg__model-name-wrap { flex: 1; display: flex; flex-direction: column; min-width: 0; }
.ms-cfg__model-followers { font-size: .7rem; color: var(--ms-cfg-text-muted); font-weight: 400; line-height: 1.2; }
.ms-cfg__model-add-price { font-size: .85rem; color: var(--ms-cfg-text-muted); font-weight: 500; white-space: nowrap; display: flex; flex-direction: column; align-items: flex-end; line-height: 1.2; }
.ms-cfg__model-add-price-sub { font-size: .68rem; font-weight: 400; color: #999; }

/* Per-model repost stepper */
.ms-cfg__model-repost { padding: .3rem .65rem .35rem 2.6rem; border-top: 1px dashed var(--ms-cfg-divider); }
.ms-cfg__repost-header { display: flex; align-items: center; gap: .25rem; margin-bottom: .2rem; font-size: .72rem; font-weight: 600; color: var(--ms-cfg-text-muted); position: relative; }
.ms-cfg__repost-row { display: flex; align-items: center; gap: .4rem; margin-bottom: .15rem; font-size: .78rem; position: relative; flex-wrap: wrap; }
.ms-cfg__repost-row-label { font-weight: 600; color: var(--ms-cfg-text); min-width: 110px; font-size: .75rem; }
.ms-cfg__repost-row-price { font-size: .68rem; color: var(--ms-cfg-text-muted); flex: 1; }
.ms-cfg__repost-stepper { display: inline-flex; align-items: center; border: 1px solid var(--ms-cfg-input-border); border-radius: 5px; overflow: hidden; }
.ms-cfg__repost-step-btn { width: 24px; height: 24px; display: inline-flex; align-items: center; justify-content: center; border: none; background: transparent; font-size: .8rem; font-weight: 500; cursor: pointer; color: var(--ms-cfg-text); transition: background .12s; padding: 0; font-family: inherit; }
.ms-cfg__repost-step-btn:hover:not(:disabled) { background: #f0f0f0; }
.ms-cfg__repost-step-btn:disabled { opacity: .3; cursor: default; }
.ms-cfg__repost-step-val { width: 24px; height: 24px; display: inline-flex; align-items: center; justify-content: center; font-size: .75rem; font-weight: 700; border-left: 1px solid var(--ms-cfg-input-border); border-right: 1px solid var(--ms-cfg-input-border); font-variant-numeric: tabular-nums; }
.ms-cfg__repost-toggle { display: flex; align-items: center; gap: .5rem; cursor: pointer; font-size: .85rem; }
.ms-cfg__repost-toggle input[type="checkbox"] { width: 16px; height: 16px; accent-color: var(--ms-cfg-accent); cursor: pointer; }
.ms-cfg__repost-toggle span { font-weight: 600; color: var(--ms-cfg-text); }
.ms-cfg__repost-price { font-weight: 400 !important; color: var(--ms-cfg-text-muted) !important; font-size: .8rem; margin-left: auto; }
.ms-cfg__repost-stepper { margin-top: .5rem; }

/* Undo toast */
.ms-cfg__undo { display: flex; align-items: center; gap: .75rem; padding: .75rem 1rem; margin-bottom: 1rem; background: var(--ms-cfg-navy); color: #fff; border-radius: 8px; font-size: .875rem; animation: ms-cfg-fade-in .3s ease; }
.ms-cfg__undo span { flex: 1; }
.ms-cfg__undo-btn { padding: .35em .85em; border: 1px solid rgba(255,255,255,.3); border-radius: 6px; background: transparent; color: #fff; font-family: inherit; font-size: .8rem; font-weight: 600; cursor: pointer; transition: all .15s; white-space: nowrap; }
.ms-cfg__undo-btn:hover { background: rgba(255,255,255,.15); border-color: rgba(255,255,255,.5); }
.ms-cfg__undo-close { width: 24px; height: 24px; display: inline-flex; align-items: center; justify-content: center; border: none; background: transparent; color: rgba(255,255,255,.5); font-size: 1rem; cursor: pointer; padding: 0; border-radius: 50%; transition: all .12s; }
.ms-cfg__undo-close:hover { color: #fff; background: rgba(255,255,255,.1); }

/* Removed-models notice */
.ms-cfg__removed-notice { display: flex; align-items: center; gap: .75rem; padding: .75rem 1rem; margin-bottom: 1rem; background: #d32f2f; color: #fff; border-radius: 8px; font-size: .85rem; line-height: 1.4; animation: ms-cfg-fade-in .3s ease; }
.ms-cfg__removed-notice span { flex: 1; }
@keyframes ms-cfg-fade-in { from { opacity: 0; transform: translateY(-8px); } to { opacity: 1; transform: translateY(0); } }

/* Notes */
.ms-cfg__note-section { padding-top: .85rem; border-top: 1px solid var(--ms-cfg-divider); }
.ms-cfg__note-input { display: block; width: 100%; padding: .55rem .7rem; border: 1px solid var(--ms-cfg-input-border); border-radius: 6px; font-family: inherit; font-size: .85rem; color: var(--ms-cfg-text); background: #fff; resize: vertical; transition: border-color .15s; line-height: 1.5; }
.ms-cfg__note-input::placeholder { color: var(--ms-cfg-text-light); font-size: .75rem; line-height: 1.4; }
.ms-cfg__note-input:focus { outline: none; border-color: var(--ms-cfg-navy); }

/* License radio */
.ms-cfg__license-radio { width: 18px; height: 18px; accent-color: var(--ms-cfg-navy); cursor: pointer; }

/* Add group */
.ms-cfg__add-group { display: flex; align-items: center; justify-content: center; width: 100%; padding: .75em 1.2em; border: 2px dashed var(--ms-cfg-card-border); border-radius: var(--ms-cfg-card-radius); background: transparent; color: var(--ms-cfg-text-muted); font-family: inherit; font-size: .85rem; font-weight: 600; cursor: pointer; transition: all .18s; }
.ms-cfg__add-group:hover { border-color: var(--ms-cfg-navy); color: var(--ms-cfg-navy); background: rgba(0,20,74,.02); }

/* Price overview */
.ms-cfg__price-overview { position: sticky; top: 2rem; }
.ms-cfg__price-inner { background: var(--ms-cfg-card-bg); border: 1px solid var(--ms-cfg-card-border); border-radius: var(--ms-cfg-card-radius); padding: 1.5rem; }
.ms-cfg__price-label { display: block; font-size: .7rem; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; color: var(--ms-cfg-text-muted); margin-bottom: 1.25rem; }
.ms-cfg__price-group { margin-bottom: .5rem; }
.ms-cfg__price-group-header { display: flex; align-items: center; gap: .35rem; padding: .25rem 0; cursor: pointer; }
.ms-cfg__price-group-title { font-size: .825rem; font-weight: 700; color: var(--ms-cfg-text); }
.ms-cfg__price-group-chevron { flex-shrink: 0; color: var(--ms-cfg-text-muted); display: flex; align-items: center; }
.ms-cfg__price-group-chevron svg { display: block; }
.ms-cfg__price-group-total { margin-left: auto; font-size: .825rem; font-weight: 700; color: var(--ms-cfg-text); font-variant-numeric: tabular-nums; }
.ms-cfg__price-group-details { padding-left: .65rem; border-left: 2px solid var(--ms-cfg-divider); margin: .15rem 0 .35rem .25rem; }
.ms-cfg__price-detail { display: flex; justify-content: space-between; align-items: baseline; padding: .1rem 0; font-size: .75rem; color: var(--ms-cfg-text-muted); }
.ms-cfg__price-detail span:last-child { font-weight: 500; font-variant-numeric: tabular-nums; }
.ms-cfg__price-detail--sub { font-size: .7rem; opacity: .75; padding-left: .5rem; }
.ms-cfg__price-detail--laufzeit { position: relative; }
.ms-cfg__price-detail--section-label { font-size: .7rem; font-weight: 700; text-transform: uppercase; letter-spacing: .04em; color: #646970; margin-top: .4rem; padding-bottom: .1rem; border-bottom: 1px solid #e5e7eb; }
.ms-cfg__price-detail--indent { padding-left: .8rem; }
.ms-cfg__price-detail--indent.ms-cfg__price-detail--sub { padding-left: 1.3rem; }
.ms-cfg__price-line { display: flex; justify-content: space-between; align-items: baseline; padding: .2rem 0; font-size: .825rem; color: var(--ms-cfg-text-muted); }
.ms-cfg__price-line span:last-child { font-weight: 600; color: var(--ms-cfg-text); font-variant-numeric: tabular-nums; }
.ms-cfg__price-line--muted { font-style: italic; opacity: .75; }
.ms-cfg__price-subtotal { display: flex; justify-content: space-between; align-items: baseline; padding: .75rem 0 .35rem; margin-top: .5rem; border-top: 1px solid var(--ms-cfg-divider); font-size: .875rem; color: var(--ms-cfg-text); }
.ms-cfg__price-subtotal strong { font-size: 1rem; font-variant-numeric: tabular-nums; }
.ms-cfg__price-total { display: flex; justify-content: space-between; align-items: baseline; padding: .75rem 0; margin-top: .25rem; border-top: 2px solid var(--ms-cfg-text); }
.ms-cfg__price-total span { font-size: .95rem; font-weight: 700; }
.ms-cfg__price-total strong { font-size: 1.5rem; font-weight: 800; font-variant-numeric: tabular-nums; }
.ms-cfg__price-info { display: flex; align-items: center; gap: .5rem; padding: .65rem .85rem; margin: 1rem 0; background: var(--ms-cfg-info-bg); border: 1px solid var(--ms-cfg-info-border); border-radius: 8px; font-size: .8rem; color: #6b5c00; line-height: 1.4; }
.ms-cfg__price-info-icon { flex-shrink: 0; font-size: 1rem; }
.ms-cfg__rights-check { display: flex; align-items: flex-start; gap: .5rem; font-size: .75rem; color: var(--ms-cfg-text); margin: .75rem 0 .5rem; line-height: 1.4; cursor: pointer; }
.ms-cfg__rights-check input { margin-top: .15rem; flex-shrink: 0; width: 16px; height: 16px; accent-color: var(--ms-cfg-navy); cursor: pointer; }
.ms-cfg__cta-wrap { position: relative; }
.ms-cfg__cta-tooltip { display: none; position: absolute; bottom: 100%; left: 0; right: 0; margin-bottom: .4rem; padding: .5rem .65rem; background: #1a1a1a; color: #fff; border-radius: 6px; font-size: .72rem; line-height: 1.5; z-index: 20; }
.ms-cfg__cta-tooltip span { display: block; }
.ms-cfg__cta-tooltip::after { content: ''; position: absolute; top: 100%; left: 50%; transform: translateX(-50%); border: 5px solid transparent; border-top-color: #1a1a1a; }
.ms-cfg__cta-wrap:hover .ms-cfg__cta-tooltip { display: block; animation: ms-cfg-fade-in .15s ease; }
.ms-cfg__price-cta:not(:disabled) + .ms-cfg__cta-tooltip { display: none !important; }
.ms-cfg__price-cta { display: flex; align-items: center; justify-content: center; width: 100%; padding: .85em 1.5em; border: none; border-radius: 8px; background: var(--ms-cfg-navy); color: #fff; font-family: inherit; font-size: .925rem; font-weight: 700; cursor: pointer; transition: all .2s; }
.ms-cfg__price-cta:hover { background: var(--ms-cfg-navy-light); transform: translateY(-1px); box-shadow: 0 4px 14px rgba(0,20,74,.2); }
.ms-cfg__price-cta:active { transform: translateY(0); box-shadow: none; }
.ms-cfg__price-cta:disabled { opacity: .5; cursor: not-allowed; transform: none; box-shadow: none; }
.ms-cfg__price-cta:disabled:hover { background: var(--ms-cfg-navy); transform: none; box-shadow: none; }

/* Loading / empty / error */
.ms-cfg__loading, .ms-cfg__empty, .ms-cfg__error { text-align: center; padding: 4rem 1.5rem; color: var(--ms-cfg-text-muted); font-size: .95rem; }
.ms-cfg__spinner { width: 36px; height: 36px; border: 3px solid var(--ms-cfg-card-border); border-top-color: var(--ms-cfg-accent); border-radius: 50%; margin: 0 auto 1.25rem; animation: ms-spin .65s linear infinite; }
@keyframes ms-spin { to { transform: rotate(360deg); } }
.ms-cfg__error { color: #d32f2f; }
.ms-cfg__empty-link { display: inline-block; margin-top: 1rem; color: var(--ms-cfg-navy); font-weight: 600; text-decoration: none; }
.ms-cfg__empty-link:hover { text-decoration: underline; }

/* Responsive */
@media (max-width: 1024px) {
    .ms-cfg__sidebar { position: static; }
    .ms-cfg__sidebar-inner { display: flex; align-items: center; flex-wrap: wrap; gap: .75rem; }
    .ms-cfg__sidebar-label { width: 100%; margin-bottom: 0; }
    .ms-cfg__sidebar-models { flex-direction: row; flex-wrap: wrap; gap: .75rem; margin-bottom: 0; }
    .ms-cfg__sidebar-add { width: auto; padding: .5em 1em; }
    .ms-cfg__price-overview { position: static; order: 3; }
}
@media (max-width: 600px) {
    .ms-cfg__title { font-size: 1.35rem; }
    .ms-cfg__group { padding: 1.15rem; }
    .ms-cfg__group-header { flex-direction: column; align-items: flex-start; }
    .ms-cfg__group-header-right { width: 100%; justify-content: space-between; }
    .ms-cfg__group-title { font-size: 1.05rem; }
    .ms-cfg__group-price { font-size: 1.15rem; }
    .ms-cfg__model-row { padding: .55rem .65rem; }
    .ms-cfg__model-add-price { display: none; }
    .ms-cfg__sidebar-info { display: none; }
    .ms-cfg__price-total strong { font-size: 1.25rem; }
}

/* Upload area */
.ms-cfg__upload { margin-bottom: .75rem; }
.ms-cfg__upload-zone { position: relative; display: flex; align-items: center; justify-content: center; min-height: 72px; padding: .65rem; border: 2px dashed var(--ms-cfg-input-border); border-radius: 8px; background: #fafafa; cursor: pointer; transition: all .18s; text-align: center; }
.ms-cfg__upload-zone:hover { border-color: var(--ms-cfg-navy); background: rgba(0,20,74,.02); }
.ms-cfg__upload-zone--dragover { border-color: var(--ms-cfg-accent); background: var(--ms-cfg-accent-bg); }
.ms-cfg__upload-zone--has-file { border-style: solid; border-color: var(--ms-cfg-navy); background: #fff; cursor: default; }
.ms-cfg__upload-zone--error { border-color: #d32f2f; background: #fff5f5; }
.ms-cfg__upload-placeholder { display: flex; flex-direction: column; align-items: center; gap: .4rem; color: var(--ms-cfg-text-muted); }
.ms-cfg__upload-placeholder-icon { font-size: 1.5rem; opacity: .5; }
.ms-cfg__upload-placeholder-text { font-size: .8rem; font-weight: 500; }
.ms-cfg__upload-placeholder-hint { font-size: .68rem; color: var(--ms-cfg-text-light); }
.ms-cfg__upload-preview { display: flex; align-items: center; gap: 1rem; width: 100%; }
.ms-cfg__upload-thumb { width: 64px; height: 64px; object-fit: cover; border-radius: 8px; flex-shrink: 0; }
.ms-cfg__upload-info { flex: 1; min-width: 0; text-align: left; }
.ms-cfg__upload-name { font-weight: 600; font-size: .85rem; color: var(--ms-cfg-text); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; display: block; }
.ms-cfg__upload-size { font-size: .75rem; color: var(--ms-cfg-text-muted); }
.ms-cfg__upload-remove { width: 28px; height: 28px; display: inline-flex; align-items: center; justify-content: center; border: 1px solid var(--ms-cfg-card-border); border-radius: 50%; background: transparent; color: var(--ms-cfg-text-muted); font-size: 1rem; cursor: pointer; transition: all .15s; padding: 0; flex-shrink: 0; }
.ms-cfg__upload-remove:hover { background: #d32f2f; color: #fff; border-color: #d32f2f; }
.ms-cfg__upload-progress { position: absolute; bottom: 0; left: 0; height: 3px; background: var(--ms-cfg-accent); border-radius: 0 0 8px 8px; transition: width .2s; }
.ms-cfg__upload-progress--indeterminate { width: 30%; animation: ms-cfg-progress 1.5s ease-in-out infinite; }
@keyframes ms-cfg-progress { 0% { left: 0; width: 20%; } 50% { left: 40%; width: 40%; } 100% { left: 100%; width: 20%; } }

/* Upload progress bar with percentage */
.ms-cfg__upload-progress-wrap { display: flex; align-items: center; gap: .75rem; width: 80%; max-width: 320px; }
.ms-cfg__upload-progress-track { flex: 1; height: 8px; background: var(--ms-cfg-divider); border-radius: 4px; overflow: hidden; }
.ms-cfg__upload-progress-bar { height: 100%; background: var(--ms-cfg-accent); border-radius: 4px; transition: width .15s ease; min-width: 2%; }
.ms-cfg__upload-progress-label { font-size: .85rem; font-weight: 700; color: var(--ms-cfg-navy); min-width: 3em; text-align: right; font-variant-numeric: tabular-nums; }

/* License group frame */
.ms-cfg__license-group { border: 1px solid var(--ms-cfg-card-border); border-radius: 8px; padding: .6rem; display: flex; flex-wrap: wrap; gap: .35rem; position: relative; background: #fafbfd; }
.ms-cfg__license-group-label { font-size: .68rem; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; color: var(--ms-cfg-text-muted); margin-bottom: .1rem; width: 100%; }
.ms-cfg__license-group > .ms-cfg__option-wrap { flex: 1; min-width: 0; }
@media (max-width: 480px) { .ms-cfg__license-group > .ms-cfg__option-wrap { flex: 0 0 100%; } }
.ms-cfg__license-option { display: flex; align-items: center; width: 100%; padding: .45rem .5rem; border: 1px solid var(--ms-cfg-card-border); border-radius: 6px; gap: .3rem; background: #fff; transition: all .15s; cursor: pointer; font-size: .82rem; }
.ms-cfg__license-option--active { background: var(--ms-cfg-accent-bg); border-color: var(--ms-cfg-accent); }
.ms-cfg__license-option > .ms-cfg__repost-toggle > span { white-space: nowrap; }
.ms-cfg__license-option .ms-cfg__repost-price { white-space: nowrap; font-size: .72rem; }

/* Spartipp */
.ms-cfg__spartipp { padding: .5rem .7rem; margin-top: .5rem; background: #e8f5e9; border: 1px solid #a5d6a7; border-radius: 6px; font-size: .72rem; color: #2e7d32; line-height: 1.4; }
.ms-cfg__spartipp .ms-cfg__spartipp-badge { display: inline; margin-right: .3rem; }
.ms-cfg__spartipp > span:last-child { display: inline; }
.ms-cfg__spartipp-badge { font-weight: 800; white-space: nowrap; font-size: .72rem; }

/* License duration selector in price sidebar */
.ms-cfg__duration-selector { margin-bottom: .5rem; }
.ms-cfg__duration-label { display: block; font-size: .72rem; font-weight: 700; letter-spacing: .06em; text-transform: uppercase; color: var(--ms-cfg-text-muted); margin-bottom: .4rem; }
.ms-cfg__duration-options { display: flex; gap: .35rem; }
.ms-cfg__duration-btn { flex: 1; padding: .45em .3em; border: 1px solid var(--ms-cfg-card-border); border-radius: 6px; background: #fff; color: var(--ms-cfg-text); font-family: inherit; font-size: .78rem; font-weight: 600; cursor: pointer; transition: all .15s; text-align: center; line-height: 1.3; }
.ms-cfg__duration-btn:hover { border-color: var(--ms-cfg-navy); }
.ms-cfg__duration-btn--active { background: var(--ms-cfg-navy); color: #fff; border-color: var(--ms-cfg-navy); }
.ms-cfg__duration-btn--active:hover { background: var(--ms-cfg-navy-light); color: #fff; border-color: var(--ms-cfg-navy-light); }
.ms-cfg__duration-btn-years { display: block; font-size: .8rem; font-weight: 700; }
.ms-cfg__duration-btn-save { display: block; font-size: .62rem; font-weight: 600; color: #2e7d32; margin-top: .1rem; }
.ms-cfg__duration-btn--active .ms-cfg__duration-btn-save { color: #a5d6a7; }
.ms-cfg__duration-btn-strike { display: block; font-size: .8rem; font-weight: 700; color: #1a1a1a; text-decoration: line-through; text-decoration-color: rgba(183, 28, 28, 0.55); text-decoration-thickness: 1px; }
.ms-cfg__duration-btn--active .ms-cfg__duration-btn-strike { color: #fff; text-decoration-color: rgba(255, 82, 82, 0.6); }
.ms-cfg__duration-btn-years--lifetime { color: #2e7d32; font-size: .62rem; font-weight: 700; margin-top: .1rem; }
.ms-cfg__duration-btn--active .ms-cfg__duration-btn-years--lifetime { color: #a5d6a7; }
.ms-cfg__spartipp--success { background: #c8e6c9; border-color: #66bb6a; color: #1b5e20; display: block; }
.ms-cfg__spartipp--success .ms-cfg__spartipp-badge { color: #1b5e20; display: inline; margin-right: .3rem; }
.ms-cfg__spartipp--success > span:last-child { display: inline; }
.ms-cfg__duration-btn small { display: block; font-size: .65rem; font-weight: 400; opacity: .8; }
.ms-cfg__upload-error { font-size: .8rem; color: #d32f2f; margin-top: .4rem; }
.ms-cfg__upload input[type="file"] { display: none; }

/* Briefing hint */
.ms-cfg__briefing-hint { display: block; font-size: .78rem; color: #6b5c00; background: var(--ms-cfg-info-bg); border: 1px solid var(--ms-cfg-info-border); border-radius: 6px; padding: .6rem .8rem; margin-bottom: .5rem; line-height: 1.45; }

/* Validation error on required fields */
.ms-cfg__field-error { font-size: .8rem; color: #d32f2f; margin-top: .35rem; font-weight: 500; }

/* Option info tooltip (hover desktop / click mobile) */
.ms-cfg__option-wrap { position: relative; }
.ms-cfg__option-icon { display: inline-flex; align-items: center; justify-content: center; width: 22px; height: 22px; border-radius: 50%; background: transparent; color: var(--ms-cfg-text-muted); font-size: .65rem; font-weight: 700; font-style: normal; cursor: pointer; flex-shrink: 0; margin-left: .4rem; line-height: 1; vertical-align: middle; transition: color .15s; }
.ms-cfg__option-icon:hover { color: var(--ms-cfg-navy); }
.ms-cfg__option-icon svg { display: block; }
.ms-cfg__option-tooltip { display: none; position: absolute; left: 0; right: 0; top: 100%; margin-top: 0; padding: .7rem .85rem; background: #fff; border: 1px solid var(--ms-cfg-card-border); border-radius: 8px; box-shadow: 0 4px 16px rgba(0,20,74,.1); font-size: .8rem; color: var(--ms-cfg-text); line-height: 1.5; z-index: 20; }
.ms-cfg__option-tooltip::before { content: ''; position: absolute; top: -.35rem; left: 0; right: 0; height: .35rem; }
.ms-cfg__option-tooltip--visible { display: block; animation: ms-cfg-fade-in .15s ease; }
.ms-cfg__option-tooltip-link { color: var(--ms-cfg-navy); font-weight: 600; text-decoration: none; white-space: nowrap; }
.ms-cfg__option-tooltip-link:hover { text-decoration: underline; color: var(--ms-cfg-accent); }

/* Scene picker */
.ms-cfg__scene-group { margin-top: .75rem; border: 1px solid var(--ms-cfg-card-border); border-radius: 8px; padding: .6rem; background: #fafbfd; position: relative; }
.ms-cfg__scene-group-label { display: block; font-size: .68rem; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; color: var(--ms-cfg-text-muted); margin-bottom: .4rem; }
.ms-cfg__scene-section { margin-bottom: .75rem; padding-bottom: .75rem; border-bottom: 1px solid var(--ms-cfg-divider); }
.ms-cfg__scene-options { display: flex; flex-wrap: wrap; gap: .35rem; }
.ms-cfg__scene-cb-label { display: inline-flex; align-items: center; gap: .35rem; padding: .3rem .65rem; border: 1px solid var(--ms-cfg-card-border); border-radius: 6px; background: #fff; font-size: .78rem; font-weight: 500; color: var(--ms-cfg-text); cursor: pointer; transition: all .15s; user-select: none; }
.ms-cfg__scene-cb-label:hover { border-color: var(--ms-cfg-navy); }
.ms-cfg__scene-cb-label--active { background: var(--ms-cfg-accent-bg); border-color: var(--ms-cfg-accent); color: var(--ms-cfg-accent-hover); }
.ms-cfg__scene-cb-label input[type="checkbox"] { width: 14px; height: 14px; accent-color: var(--ms-cfg-accent); cursor: pointer; }
.ms-cfg__scene-cb-label input[type="checkbox"]:disabled { opacity: .4; cursor: not-allowed; }
.ms-cfg__scene-cb-label:has(input:disabled) { opacity: .5; cursor: not-allowed; border-color: var(--ms-cfg-card-border); background: #f5f5f5; }
.ms-cfg__exclusion-notice { margin-top: .55rem; padding: .45rem .6rem; background: #fff5f5; border: 1px solid #f5c6c6; border-radius: 5px; font-size: .65rem; line-height: 1.4; color: #8a2e2e; }
.ms-cfg__exclusion-notice-title { display: block; font-weight: 600; margin-bottom: .2rem; }
.ms-cfg__exclusion-notice-list { display: flex; flex-wrap: wrap; gap: .2rem .7rem; }
.ms-cfg__exclusion-notice-item { white-space: nowrap; opacity: .85; }

/* Scene capability badges on model cards */
.ms-cfg__scene-badges { display: flex; flex-wrap: wrap; gap: .2rem; margin-top: .15rem; }
.ms-cfg__scene-badge { display: inline-block; padding: .05rem .35rem; border-radius: 3px; font-size: .55rem; font-weight: 600; line-height: 1.4; letter-spacing: .02em; white-space: nowrap; }
.ms-cfg__scene-badge--ok { background: #e8f5e9; color: #2e7d32; }
.ms-cfg__scene-badge--no { background: #ffebee; color: #c62828; }

/* Scene-blocked model card */
.ms-cfg__model-card--scene-blocked { opacity: .55; }
.ms-cfg__model-card--scene-blocked .ms-cfg__model-avatar { filter: grayscale(.6); }

/* Models locked (no scene selected) */
.ms-cfg__models-locked { display: flex; align-items: center; gap: .6rem; padding: .85rem 1rem; border: 1px dashed var(--ms-cfg-card-border); border-radius: 8px; background: #f8f8fa; color: var(--ms-cfg-text-muted); font-size: .8rem; line-height: 1.4; }
.ms-cfg__models-locked-icon { font-size: 1.1rem; flex-shrink: 0; }

