.autoschedule-page {
    --as-bg: var(--bs-body-bg);
    --as-surface: #ffffff;
    --as-surface-soft: #f4f7ff;
    --as-surface-strong: #eef3ff;
    --as-border: rgba(15, 23, 42, 0.09);
    --as-shadow: 0 22px 45px rgba(17, 24, 39, 0.08);
    --as-text: #101828;
    --as-muted: #667085;
    --as-accent: var(--bs-primary);
    --as-accent-soft: rgba(var(--bs-primary-rgb), 0.12);
    --as-success-soft: rgba(25, 135, 84, 0.12);
    --as-warning-soft: rgba(255, 193, 7, 0.12);
    max-width: 1760px;
    overflow-x: clip;
}

[data-theme="dark"] .autoschedule-page {
    --as-bg: #0a0c27;
    --as-surface: #1f245f;
    --as-surface-soft: #171c49;
    --as-surface-strong: #2b3176;
    --as-border: rgba(255, 255, 255, 0.12);
    --as-shadow: 0 24px 48px rgba(0, 0, 0, 0.28);
    --as-text: rgba(255, 255, 255, 0.96);
    --as-muted: rgba(255, 255, 255, 0.68);
    --as-accent: #8bb6ff;
    --as-accent-soft: rgba(139, 182, 255, 0.14);
    --as-success-soft: rgba(79, 217, 145, 0.14);
    --as-warning-soft: rgba(255, 183, 134, 0.16);
}

[data-theme="dark"] .autoschedule-page .autoschedule-progress {
    background: color-mix(in srgb, #1f245f 82%, transparent);
}

[data-theme="dark"] .autoschedule-page .autoschedule-flash-success {
    background: rgba(79, 217, 145, 0.12);
    border-color: rgba(79, 217, 145, 0.18) !important;
    color: rgba(233, 255, 242, 0.94);
}

.autoschedule-page .alert {
    border-radius: 1rem;
}

[data-theme="dark"] .autoschedule-page .alert-success,
[data-theme="dark"] .autoschedule-page .autoschedule-flash-success {
    background: linear-gradient(180deg, rgba(79, 217, 145, 0.16), rgba(79, 217, 145, 0.07));
    border-color: rgba(79, 217, 145, 0.24) !important;
    color: rgba(233, 255, 242, 0.96);
}

[data-theme="dark"] .autoschedule-page .alert-warning {
    background: linear-gradient(180deg, rgba(255, 183, 134, 0.18), rgba(255, 183, 134, 0.08));
    border-color: rgba(255, 183, 134, 0.24) !important;
    color: rgba(255, 236, 220, 0.96);
}

[data-theme="dark"] .autoschedule-page .alert-danger {
    background: linear-gradient(180deg, rgba(255, 126, 145, 0.18), rgba(255, 126, 145, 0.08));
    border-color: rgba(255, 126, 145, 0.24) !important;
    color: rgba(255, 234, 238, 0.96);
}

[data-theme="dark"] .autoschedule-page .alert .text-secondary {
    color: rgba(255, 255, 255, 0.72) !important;
}

.autoschedule-page .autoschedule-run-status {
    display: none;
    align-items: center;
    gap: 1rem;
    margin-bottom: 1rem;
    padding: 1.15rem 1.2rem;
    border-radius: 1.2rem;
    border: 1px solid rgba(var(--bs-primary-rgb), 0.16);
    background: linear-gradient(180deg, rgba(var(--bs-primary-rgb), 0.08), rgba(var(--bs-primary-rgb), 0.03));
    box-shadow: 0 18px 36px rgba(17, 24, 39, 0.08);
}

.autoschedule-page .autoschedule-run-status.is-visible {
    display: flex;
}

.autoschedule-page .autoschedule-run-status.is-processing {
    border-color: rgba(25, 135, 84, 0.2);
    background: linear-gradient(180deg, rgba(25, 135, 84, 0.1), rgba(25, 135, 84, 0.03));
}

.autoschedule-page .autoschedule-run-status.is-failed {
    border-color: rgba(220, 53, 69, 0.22);
    background: linear-gradient(180deg, rgba(220, 53, 69, 0.09), rgba(220, 53, 69, 0.03));
}

[data-theme="dark"] .autoschedule-page .autoschedule-run-status {
    border-color: rgba(139, 182, 255, 0.24);
    background: linear-gradient(180deg, rgba(139, 182, 255, 0.14), rgba(139, 182, 255, 0.05));
}

[data-theme="dark"] .autoschedule-page .autoschedule-run-status.is-processing {
    border-color: rgba(79, 217, 145, 0.28);
    background: linear-gradient(180deg, rgba(79, 217, 145, 0.16), rgba(79, 217, 145, 0.05));
}

[data-theme="dark"] .autoschedule-page .autoschedule-run-status.is-failed {
    border-color: rgba(255, 126, 145, 0.28);
    background: linear-gradient(180deg, rgba(255, 126, 145, 0.16), rgba(255, 126, 145, 0.05));
}

.autoschedule-page .autoschedule-run-status-icon {
    width: 3rem;
    height: 3rem;
    flex: 0 0 auto;
    border-radius: 999px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: rgba(var(--bs-primary-rgb), 0.12);
    color: var(--as-accent);
}

.autoschedule-page .autoschedule-run-status.is-processing .autoschedule-run-status-icon {
    background: rgba(25, 135, 84, 0.14);
    color: #198754;
}

.autoschedule-page .autoschedule-run-status.is-failed .autoschedule-run-status-icon {
    background: rgba(220, 53, 69, 0.12);
    color: #dc3545;
}

[data-theme="dark"] .autoschedule-page .autoschedule-run-status.is-processing .autoschedule-run-status-icon {
    color: #8ff0b1;
}

[data-theme="dark"] .autoschedule-page .autoschedule-run-status.is-failed .autoschedule-run-status-icon {
    color: #ffb8c2;
}

.autoschedule-page .autoschedule-run-status-copy {
    min-width: 0;
    flex: 1 1 auto;
    display: flex;
    flex-direction: column;
    gap: 0.55rem;
}

.autoschedule-page .autoschedule-run-status-kicker {
    font-size: 0.74rem;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.09em;
    color: var(--as-accent);
    margin-bottom: 0.18rem;
}

.autoschedule-page .autoschedule-run-status-title {
    font-size: 1rem;
    font-weight: 800;
    color: var(--as-text);
    margin-bottom: 0.22rem;
}

.autoschedule-page .autoschedule-run-status-body {
    color: var(--as-muted);
    font-size: 0.9rem;
    line-height: 1.45;
}

.autoschedule-page .autoschedule-run-status-meta {
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-end;
    gap: 0.4rem;
}

.autoschedule-page .autoschedule-run-status-meta span {
    display: inline-flex;
    align-items: center;
    min-height: 1.85rem;
    padding: 0.35rem 0.65rem;
    border-radius: 999px;
    background: rgba(var(--bs-primary-rgb), 0.1);
    color: var(--as-accent);
    font-size: 0.75rem;
    font-weight: 700;
}

[data-theme="dark"] .autoschedule-page .autoschedule-run-status-meta span {
    background: rgba(139, 182, 255, 0.14);
    color: #cfe0ff;
}

.autoschedule-page .autoschedule-run-progress {
    padding: 0.8rem 0.9rem;
    border-radius: 1rem;
    background: rgba(255, 255, 255, 0.4);
    border: 1px solid rgba(var(--bs-primary-rgb), 0.14);
}

[data-theme="dark"] .autoschedule-page .autoschedule-run-progress {
    background: rgba(255, 255, 255, 0.04);
    border-color: rgba(139, 182, 255, 0.18);
}

.autoschedule-page .autoschedule-run-progress-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    margin-bottom: 0.45rem;
    color: var(--as-text);
    font-size: 0.84rem;
    font-weight: 700;
}

.autoschedule-page .autoschedule-run-progress-track {
    width: 100%;
    height: 0.8rem;
    overflow: hidden;
    border-radius: 999px;
    background: rgba(15, 23, 42, 0.08);
}

[data-theme="dark"] .autoschedule-page .autoschedule-run-progress-track {
    background: rgba(255, 255, 255, 0.08);
}

.autoschedule-page .autoschedule-run-progress-bar {
    height: 100%;
    width: 0;
    border-radius: inherit;
    background: linear-gradient(90deg, #4f8cff 0%, #76b8ff 45%, #8ff0b1 100%);
    box-shadow: 0 8px 18px rgba(79, 140, 255, 0.24);
    transition: width 0.45s ease;
}

.autoschedule-page .autoschedule-run-status.is-failed .autoschedule-run-progress-bar {
    background: linear-gradient(90deg, #ff8aa1 0%, #ffb8c2 100%);
    box-shadow: 0 8px 18px rgba(255, 102, 131, 0.2);
}

.autoschedule-page .autoschedule-run-progress-note {
    margin-top: 0.45rem;
    color: var(--as-muted);
    font-size: 0.8rem;
    line-height: 1.4;
}

.autoschedule-page .autoschedule-run-lock-note {
    font-size: 0.83rem;
    font-weight: 600;
    color: var(--as-text);
    padding: 0.72rem 0.82rem;
    border-radius: 0.9rem;
    background: rgba(var(--bs-primary-rgb), 0.08);
    border: 1px dashed rgba(var(--bs-primary-rgb), 0.2);
}

[data-theme="dark"] .autoschedule-page .autoschedule-run-lock-note {
    background: rgba(139, 182, 255, 0.08);
    border-color: rgba(139, 182, 255, 0.22);
    color: rgba(241, 245, 255, 0.94);
}

.autoschedule-page .autoschedule-rescue-section-badge {
    display: inline-flex;
    align-items: center;
    min-height: 1.9rem;
    padding: 0.28rem 0.65rem;
    border-radius: 0.7rem;
    background: rgba(15, 23, 42, 0.06);
    color: var(--as-text);
    border: 1px solid rgba(15, 23, 42, 0.08);
    font-size: 0.72rem;
    font-weight: 700;
}

.autoschedule-page .autoschedule-score-pill {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    align-self: flex-start;
    min-height: 1.8rem;
    padding: 0.18rem 0.55rem;
    border-radius: 0.55rem;
    font-size: 0.72rem;
    font-weight: 800;
    line-height: 1;
    white-space: nowrap;
    border: 1px solid transparent;
}

.autoschedule-page .autoschedule-score-pill-success {
    background: rgba(25, 135, 84, 0.14);
    color: #0f6b43;
    border-color: rgba(25, 135, 84, 0.18);
}

.autoschedule-page .autoschedule-score-pill-warning {
    background: rgba(255, 193, 7, 0.18);
    color: #8a5a00;
    border-color: rgba(255, 193, 7, 0.24);
}

.autoschedule-page .autoschedule-rescue-alert {
    border-radius: 0.95rem;
    border-width: 1px;
    color: var(--as-text);
}

.autoschedule-page .autoschedule-rescue-alert-warning {
    background: rgba(255, 193, 7, 0.12);
    border-color: rgba(255, 193, 7, 0.2);
    color: #7a5600;
}

.autoschedule-page .autoschedule-rescue-alert-secondary {
    background: rgba(15, 23, 42, 0.045);
    border-color: rgba(15, 23, 42, 0.08);
    color: var(--as-muted);
}

.autoschedule-page .autoschedule-rescue-alert-danger {
    background: rgba(220, 53, 69, 0.1);
    border-color: rgba(220, 53, 69, 0.18);
    color: #8f1f2d;
}

.autoschedule-page .autoschedule-panel .border.rounded-3 {
    border-color: var(--as-border) !important;
    background: color-mix(in srgb, var(--as-surface) 92%, transparent);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.02);
}

.autoschedule-page .compare-calendar-header,
.autoschedule-page .compare-calendar-body,
.autoschedule-page .compare-time-col,
.autoschedule-page .compare-day-col,
.autoschedule-page .compare-time-spacer,
.autoschedule-page .compare-day-label {
    border-color: var(--as-border) !important;
}

.autoschedule-page .compare-grid-line,
.autoschedule-page .compare-time-label {
    border-color: color-mix(in srgb, var(--as-border) 82%, transparent) !important;
}

[data-theme="dark"] .autoschedule-page .autoschedule-rescue-section-badge {
    background: rgba(255, 255, 255, 0.08);
    color: rgba(255, 255, 255, 0.96);
    border-color: rgba(255, 255, 255, 0.12);
}

[data-theme="dark"] .autoschedule-page .autoschedule-score-pill-success {
    background: rgba(79, 217, 145, 0.18);
    color: #d9ffe8;
    border-color: rgba(79, 217, 145, 0.24);
}

[data-theme="dark"] .autoschedule-page .autoschedule-score-pill-warning {
    background: rgba(255, 183, 134, 0.18);
    color: #ffe6d2;
    border-color: rgba(255, 183, 134, 0.24);
}

[data-theme="dark"] .autoschedule-page .autoschedule-rescue-alert-warning {
    background: rgba(255, 183, 134, 0.12);
    border-color: rgba(255, 183, 134, 0.2);
    color: #ffe3c5;
}

[data-theme="dark"] .autoschedule-page .autoschedule-rescue-alert-secondary {
    background: rgba(255, 255, 255, 0.05);
    border-color: rgba(255, 255, 255, 0.1);
    color: rgba(255, 255, 255, 0.78);
}

[data-theme="dark"] .autoschedule-page .autoschedule-rescue-alert-danger {
    background: rgba(255, 126, 145, 0.12);
    border-color: rgba(255, 126, 145, 0.22);
    color: #ffd4db;
}

[data-theme="dark"] .autoschedule-page .autoschedule-panel .border.rounded-3 {
    background: rgba(255, 255, 255, 0.025);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.03);
}

.autoschedule-page .autoschedule-shell {
    display: grid;
    grid-template-columns: 1fr;
    gap: 1.5rem;
    align-items: start;
    min-width: 0;
    width: 100%;
}

.autoschedule-page .autoschedule-progress {
    position: sticky;
    top: -0.4rem;
    z-index: 30;
    margin-bottom: 0.65rem;
    padding: 0.7rem 0.85rem;
    background: color-mix(in srgb, var(--as-surface) 90%, transparent);
    border: 1px solid var(--as-border);
    border-radius: 1.1rem;
    box-shadow: 0 10px 24px rgba(17, 24, 39, 0.08);
    backdrop-filter: blur(8px);
}

.autoschedule-page .autoschedule-progress-head {
    display: flex;
    align-items: end;
    justify-content: space-between;
    gap: 1rem;
    margin-bottom: 0.55rem;
}

.autoschedule-page .autoschedule-help-btn {
    width: 2.25rem;
    height: 2.25rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 999px;
    border: 1px solid rgba(var(--bs-primary-rgb), 0.16);
    background: rgba(var(--bs-primary-rgb), 0.08);
    color: var(--as-accent);
    box-shadow: 0 0.35rem 0.8rem rgba(13, 110, 253, 0.12);
}

.autoschedule-page .autoschedule-help-btn:hover,
.autoschedule-page .autoschedule-help-btn:focus {
    background: rgba(var(--bs-primary-rgb), 0.14);
    border-color: rgba(var(--bs-primary-rgb), 0.22);
    color: var(--as-accent);
}

.autoschedule-page .autoschedule-help-btn .material-symbols-outlined {
    font-size: 1.05rem;
    font-variation-settings: "FILL" 1;
}

.autoschedule-page .autoschedule-progress-title {
    font-size: 0.95rem;
    font-weight: 800;
    color: var(--as-text);
}

.autoschedule-page .autoschedule-progress-copy {
    max-width: 36rem;
    color: var(--as-muted);
    font-size: 0.84rem;
    line-height: 1.45;
}

.autoschedule-page .autoschedule-progress-track {
    display: grid;
    grid-template-columns: repeat(5, minmax(180px, 1fr));
    gap: 0.55rem;
    overflow-x: auto;
    overscroll-behavior-x: contain;
    padding-bottom: 0.1rem;
    scrollbar-width: thin;
}

.autoschedule-welcome-modal {
    overflow: hidden;
    border-radius: 1rem;
    border: 1px solid rgba(var(--bs-primary-rgb), 0.14);
    box-shadow: 0 1.25rem 2.75rem rgba(15, 23, 42, 0.18);
}

.autoschedule-welcome-modal__hero {
    position: relative;
    min-height: 8.5rem;
    padding: 1.5rem 1.75rem;
    background: linear-gradient(135deg, rgba(var(--bs-primary-rgb), 0.18) 0%, rgba(var(--bs-primary-rgb), 0.04) 100%);
    border-bottom: 1px solid rgba(var(--bs-primary-rgb), 0.12);
}

.autoschedule-welcome-modal__hero-pattern {
    position: absolute;
    inset: 0;
    background-image: radial-gradient(circle at 2px 2px, rgba(13, 110, 253, 0.35) 1px, transparent 0);
    background-size: 24px 24px;
    opacity: 0.35;
}

.autoschedule-welcome-modal__hero-icon {
    position: relative;
    z-index: 1;
    width: 4.25rem;
    height: 4.25rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 1rem;
    background: rgba(var(--bs-primary-rgb), 0.12);
    border: 1px solid rgba(var(--bs-primary-rgb), 0.18);
    color: var(--as-accent);
}

.autoschedule-welcome-modal__hero-icon .material-symbols-outlined {
    font-size: 2rem;
    font-variation-settings: "FILL" 1;
}

.autoschedule-welcome-modal__body {
    padding: 1.75rem;
    display: grid;
    gap: 1.5rem;
}

.autoschedule-welcome-modal__intro {
    display: grid;
    gap: 0.65rem;
}

.autoschedule-welcome-modal__title {
    margin: 0;
    font-size: clamp(2rem, 3.4vw, 2.7rem);
    font-weight: 800;
    letter-spacing: -0.04em;
    color: var(--as-text);
}

.autoschedule-welcome-modal__copy {
    margin: 0;
    max-width: 42rem;
    color: var(--as-muted);
    line-height: 1.7;
}

.autoschedule-welcome-modal__suggestion {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr);
    gap: 0.8rem;
    align-items: start;
    padding: 0.9rem 1rem;
    border-radius: 0.95rem;
    background: rgba(var(--bs-primary-rgb), 0.06);
    border: 1px solid rgba(var(--bs-primary-rgb), 0.12);
}

.autoschedule-welcome-modal__suggestion .material-symbols-outlined {
    color: var(--as-accent);
    font-size: 1.15rem;
    margin-top: 0.05rem;
}

.autoschedule-welcome-modal__suggestion strong,
.autoschedule-welcome-feature strong,
.autoschedule-welcome-step strong {
    display: block;
    margin-bottom: 0.15rem;
    font-size: 0.96rem;
    color: var(--as-text);
}

.autoschedule-welcome-modal__suggestion p,
.autoschedule-welcome-feature p,
.autoschedule-welcome-step p {
    margin: 0;
    color: var(--as-muted);
    font-size: 0.84rem;
    line-height: 1.55;
}

.autoschedule-welcome-modal__features {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.9rem;
}

.autoschedule-welcome-feature {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr);
    gap: 0.85rem;
    align-items: flex-start;
    padding: 1rem;
    border-radius: 0.95rem;
    background: rgba(255, 255, 255, 0.66);
    border: 1px solid rgba(15, 23, 42, 0.08);
}

.autoschedule-welcome-feature .material-symbols-outlined {
    color: var(--as-accent);
    font-size: 1.25rem;
}

.autoschedule-welcome-modal__journey {
    padding: 1.25rem;
    border-radius: 1rem;
    background: rgba(var(--bs-primary-rgb), 0.04);
    border: 1px solid rgba(var(--bs-primary-rgb), 0.1);
}

.autoschedule-welcome-modal__journey-label {
    margin-bottom: 1rem;
    font-size: 0.75rem;
    font-weight: 700;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: rgba(var(--bs-primary-rgb), 0.82);
}

.autoschedule-welcome-step {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr);
    gap: 0.9rem;
    align-items: center;
}

.autoschedule-welcome-step + .autoschedule-welcome-step {
    margin-top: 1rem;
}

.autoschedule-welcome-step__index {
    width: 2rem;
    height: 2rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 999px;
    font-size: 0.82rem;
    font-weight: 800;
    background: rgba(15, 23, 42, 0.06);
    border: 1px solid rgba(15, 23, 42, 0.08);
    color: var(--as-muted);
}

.autoschedule-welcome-step.is-active .autoschedule-welcome-step__index {
    background: rgba(var(--bs-primary-rgb), 0.1);
    border-color: rgba(var(--bs-primary-rgb), 0.2);
    color: var(--as-accent);
}

.autoschedule-welcome-modal__footer {
    display: flex;
    justify-content: center;
    gap: 1rem;
    padding: 0 1.75rem 1.5rem;
    border-top: 0;
}

.autoschedule-welcome-modal__start {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.45rem;
    min-width: 11rem;
    padding-inline: 1.25rem;
}

.autoschedule-welcome-modal__accent {
    height: 0.2rem;
    background: linear-gradient(90deg, transparent 0%, rgba(var(--bs-primary-rgb), 0.32) 50%, transparent 100%);
}

.autoschedule-tour-open {
    overflow: hidden;
}

.autoschedule-tour-open .autoschedule-page {
    pointer-events: none;
    user-select: none;
}

.autoschedule-page [data-tour-anchor] {
    position: relative;
}

.autoschedule-page .is-tour-active-column,
.autoschedule-page .is-tour-active-parent {
    position: relative;
}

.autoschedule-page .is-tour-active-column {
    z-index: 1081;
}

.autoschedule-page .is-tour-active-parent {
    z-index: 1082;
}

.autoschedule-page [data-tour-anchor].is-tour-active {
    z-index: 1083;
    isolation: isolate;
    border-radius: 1.2rem;
    box-shadow: 0 0 0 2px rgba(var(--bs-primary-rgb), 0.22), 0 0 0 10px rgba(255, 255, 255, 0.82), 0 1rem 2rem rgba(15, 23, 42, 0.14);
}

.autoschedule-page [data-tour-anchor].is-tour-active::after {
    content: "";
    position: absolute;
    inset: -0.35rem;
    border-radius: 1.45rem;
    border: 1px solid rgba(var(--bs-primary-rgb), 0.24);
    pointer-events: none;
}

.autoschedule-tour-backdrop {
    position: fixed;
    inset: 0;
    background: rgba(8, 11, 24, 0.62);
    backdrop-filter: blur(4px);
    z-index: 1080;
    pointer-events: auto;
}

.autoschedule-tour-card {
    position: fixed;
    max-width: min(380px, calc(100vw - 32px));
    padding: 1.15rem;
    border-radius: 1rem;
    background: #ffffff;
    border: 1px solid rgba(var(--bs-primary-rgb), 0.12);
    box-shadow: 0 1rem 2.5rem rgba(15, 23, 42, 0.24);
    z-index: 1083;
    pointer-events: auto;
}

.autoschedule-tour-card__eyebrow {
    font-size: 0.76rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--as-accent);
    margin-bottom: 0.45rem;
}

.autoschedule-tour-card__title {
    font-size: 1.15rem;
    font-weight: 800;
    letter-spacing: -0.03em;
    color: var(--as-text);
}

.autoschedule-tour-card__copy {
    color: var(--as-muted);
    line-height: 1.55;
}

.autoschedule-tour-card__actions {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
    margin-top: 1rem;
}

.autoschedule-page .autoschedule-config {
    position: static;
    display: flex;
    flex-direction: column;
    gap: 1rem;
    min-width: 0;
    width: 100%;
}

.autoschedule-page .autoschedule-config--full {
    max-width: 100%;
}

.autoschedule-page .autoschedule-panel,
.autoschedule-page .autoschedule-results-panel,
.autoschedule-page .autoschedule-proposal,
.autoschedule-page .autoschedule-empty {
    background: var(--as-surface);
    border: 1px solid var(--as-border);
    border-radius: 1.65rem;
    box-shadow: var(--as-shadow);
    width: 100%;
    max-width: 100%;
    min-width: 0;
    box-sizing: border-box;
}

.autoschedule-page .autoschedule-flash-success {
    border-radius: 1rem;
    border-color: rgba(25, 135, 84, 0.14) !important;
    background: rgba(25, 135, 84, 0.08);
    color: #17643b;
}

.autoschedule-page .autoschedule-brand {
    padding: 1.4rem;
    display: flex;
    align-items: center;
    gap: 0.95rem;
}

.autoschedule-page .autoschedule-brand-mark {
    width: 3.25rem;
    height: 3.25rem;
    border-radius: 1rem;
    background: var(--as-accent-soft);
    color: var(--as-accent);
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

.autoschedule-page .autoschedule-brand-kicker,
.autoschedule-page .autoschedule-kicker {
    font-size: 0.74rem;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.11em;
    color: var(--as-accent);
}

.autoschedule-page .autoschedule-brand-title {
    font-size: 1.05rem;
    font-weight: 800;
    color: var(--as-text);
}

.autoschedule-page .autoschedule-brand-copy {
    font-size: 0.75rem;
    text-transform: uppercase;
    letter-spacing: 0.16em;
    color: var(--as-muted);
}

.autoschedule-page .autoschedule-panel {
    padding: 1.6rem;
}

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

.autoschedule-page .autoschedule-flow-grid {
    display: grid;
    grid-template-columns: minmax(0, 0.8fr) minmax(0, 1.2fr);
    gap: 1rem;
}

.autoschedule-page .autoschedule-stage + .autoschedule-stage {
    margin-top: 1rem;
}

.autoschedule-page .autoschedule-stage {
    border-radius: 1.25rem;
    border: 1px solid var(--as-border);
    background: var(--as-surface-soft);
    overflow: hidden;
}

.autoschedule-page .autoschedule-stage-header {
    width: 100%;
    display: flex;
    align-items: center;
    gap: 0.9rem;
    padding: 1rem 1.1rem;
    text-align: left;
    border: 0;
    background: transparent;
    color: inherit;
}

.autoschedule-page .autoschedule-stage-copy {
    display: grid;
    gap: 0.18rem;
    min-width: 0;
    flex: 1 1 auto;
}

.autoschedule-page .autoschedule-stage-copy strong {
    color: var(--as-text);
    font-size: 0.98rem;
}

.autoschedule-page .autoschedule-stage-copy small {
    color: var(--as-muted);
    font-size: 0.8rem;
    line-height: 1.4;
}

.autoschedule-page .autoschedule-stage-state {
    flex: 0 0 auto;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 2rem;
    padding: 0.35rem 0.75rem;
    border-radius: 999px;
    background: rgba(var(--bs-primary-rgb), 0.1);
    border: 1px solid rgba(var(--bs-primary-rgb), 0.14);
    color: var(--as-accent);
    font-size: 0.71rem;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.autoschedule-page .autoschedule-stage-body {
    display: none;
    padding: 1.1rem 1.1rem 1.1rem;
    border-top: 1px solid var(--as-border);
}

.autoschedule-page .autoschedule-stage-body .autoschedule-flow-grid,
.autoschedule-page .autoschedule-stage-body .autoschedule-form-section:first-child {
    margin-top: 0.2rem;
}

.autoschedule-page .autoschedule-stage.is-open .autoschedule-stage-body {
    display: block;
}

.autoschedule-page .autoschedule-stage.is-complete .autoschedule-stage-state {
    background: rgba(25, 135, 84, 0.12);
    border-color: rgba(25, 135, 84, 0.18);
    color: #198754;
}

.autoschedule-page .autoschedule-stage-actions {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    margin-top: 1rem;
}

.autoschedule-page .autoschedule-stage-hint {
    color: var(--as-muted);
    font-size: 0.82rem;
    line-height: 1.45;
}

.autoschedule-page .autoschedule-context-card {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr);
    gap: 0.8rem;
    padding: 0.9rem 1rem;
    border-radius: 1rem;
    background: rgba(var(--bs-primary-rgb), 0.06);
    border: 1px solid rgba(var(--bs-primary-rgb), 0.12);
}

.autoschedule-page .autoschedule-context-card .material-symbols-outlined {
    color: var(--as-accent);
}

.autoschedule-page .autoschedule-context-card strong {
    display: block;
    color: var(--as-text);
    font-size: 0.9rem;
}

.autoschedule-page .autoschedule-context-card span:last-child {
    color: var(--as-muted);
    font-size: 0.8rem;
    line-height: 1.45;
}

.autoschedule-page .autoschedule-form {
    position: relative;
}

.autoschedule-page .autoschedule-form.is-locked > *:not(.autoschedule-form-lock) {
    opacity: 0.52;
    pointer-events: none;
    user-select: none;
}

.autoschedule-page .autoschedule-form-lock {
    position: absolute;
    inset: 0;
    z-index: 6;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 1.2rem;
    border-radius: 1.4rem;
    background: rgba(255, 255, 255, 0.28);
    backdrop-filter: blur(2px);
    cursor: wait;
}

[data-theme="dark"] .autoschedule-page .autoschedule-form-lock {
    background: rgba(6, 10, 28, 0.34);
}

.autoschedule-page .autoschedule-form-lock-card {
    max-width: 22rem;
    text-align: center;
    padding: 1rem 1.1rem;
    border-radius: 1rem;
    border: 1px solid rgba(var(--bs-primary-rgb), 0.18);
    background: linear-gradient(180deg, rgba(var(--bs-primary-rgb), 0.12), rgba(var(--bs-primary-rgb), 0.05));
    box-shadow: 0 18px 34px rgba(17, 24, 39, 0.14);
    color: var(--as-text);
}

[data-theme="dark"] .autoschedule-page .autoschedule-form-lock-card {
    border-color: rgba(139, 182, 255, 0.24);
    background: linear-gradient(180deg, rgba(139, 182, 255, 0.16), rgba(139, 182, 255, 0.06));
}

.autoschedule-page .autoschedule-form-lock-card .material-symbols-outlined {
    display: block;
    margin-bottom: 0.45rem;
    font-size: 2rem;
    color: var(--as-accent);
}

.autoschedule-page .autoschedule-form-lock-card strong {
    display: block;
    margin-bottom: 0.35rem;
    font-size: 0.98rem;
}

.autoschedule-page .autoschedule-form-lock-card p {
    color: var(--as-muted);
    font-size: 0.85rem;
    line-height: 1.45;
}

.autoschedule-page .autoschedule-stepper {
    display: grid;
    gap: 0.75rem;
}

.autoschedule-page .autoschedule-step {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr);
    gap: 0.6rem;
    align-items: start;
    padding: 0.65rem 0.75rem;
    border-radius: 0.9rem;
    background: var(--as-surface-soft);
    border: 1px solid var(--as-border);
    min-width: 0;
}

.autoschedule-page .autoschedule-step.is-current {
    background: var(--as-surface);
    border-color: rgba(var(--bs-primary-rgb), 0.24);
    box-shadow: 0 0 0 1px rgba(var(--bs-primary-rgb), 0.08);
}

.autoschedule-page .autoschedule-step-index {
    width: 1.55rem;
    height: 1.55rem;
    border-radius: 999px;
    border: 1px solid rgba(var(--bs-primary-rgb), 0.22);
    color: var(--as-accent);
    background: var(--as-accent-soft);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 0.72rem;
    font-weight: 800;
}

.autoschedule-page .autoschedule-step.is-complete .autoschedule-step-index {
    background: var(--as-accent);
    border-color: var(--as-accent);
    color: #fff;
}

.autoschedule-page .autoschedule-step-copy {
    display: grid;
    gap: 0.15rem;
    min-width: 0;
}

.autoschedule-page .autoschedule-step-copy strong {
    color: var(--as-text);
    font-size: 0.82rem;
    line-height: 1.25;
}

.autoschedule-page .autoschedule-step-copy small {
    color: var(--as-muted);
    font-size: 0.72rem;
    line-height: 1.3;
}

.autoschedule-page .autoschedule-form-section {
    padding: 1.1rem;
    border-radius: 1.2rem;
    background: var(--as-surface-soft);
    border: 1px solid var(--as-border);
}

.autoschedule-page .autoschedule-form-section-head {
    display: flex;
    align-items: end;
    justify-content: space-between;
    gap: 1rem;
    margin-bottom: 1rem;
}

.autoschedule-page .autoschedule-form-section-title {
    font-size: 1.05rem;
    font-weight: 800;
    color: var(--as-text);
}

.autoschedule-page .autoschedule-form-section-copy {
    max-width: 18rem;
    color: var(--as-muted);
    font-size: 0.83rem;
    line-height: 1.45;
}

.autoschedule-page .autoschedule-panel h1 {
    font-size: clamp(2.2rem, 3.6vw, 3.6rem);
    line-height: 0.95;
    margin-bottom: 0.55rem;
    color: var(--as-text);
    max-width: 100%;
    overflow-wrap: anywhere;
    word-break: break-word;
    hyphens: auto;
}

.autoschedule-page .autoschedule-panel p,
.autoschedule-page .autoschedule-results-lead,
.autoschedule-page .autoschedule-hero-copy,
.autoschedule-page .autoschedule-panel .form-text {
    color: var(--as-muted);
}

.autoschedule-page .autoschedule-cta.is-loading {
    opacity: 0.92;
}

.autoschedule-page .autoschedule-recent-run,
.autoschedule-page .autoschedule-limit-note {
    padding: 0.9rem 1rem;
    border-radius: 1rem;
    background: var(--as-surface-soft);
    border: 1px solid var(--as-border);
}

.autoschedule-page .autoschedule-recent-run-title,
.autoschedule-page .autoschedule-limit-note-title {
    font-size: 0.78rem;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--as-accent);
    margin-bottom: 0.3rem;
}

.autoschedule-page .autoschedule-recent-run-copy {
    color: var(--as-muted);
    font-size: 0.86rem;
}

.autoschedule-page .autoschedule-limit-note-list {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
}

.autoschedule-page .autoschedule-limit-chip {
    display: inline-flex;
    align-items: center;
    min-height: 1.9rem;
    padding: 0.35rem 0.75rem;
    border-radius: 999px;
    background: var(--as-accent-soft);
    color: var(--as-accent);
    font-size: 0.76rem;
    font-weight: 700;
}

.autoschedule-page .autoschedule-grid-two {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1rem;
}

.autoschedule-page .autoschedule-grid-two > * {
    min-width: 0;
}

.autoschedule-page .autoschedule-grid-two-wide {
    grid-template-columns: minmax(0, 1.35fr) minmax(0, 0.65fr);
}

.autoschedule-page .autoschedule-wide-field {
    grid-column: 1 / 2;
}

.autoschedule-page .autoschedule-panel .form-label,
.autoschedule-page .autoschedule-preferences-title {
    font-size: 0.72rem;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    font-weight: 800;
    color: var(--as-muted);
}

.autoschedule-page .autoschedule-preferences-title {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
}

.autoschedule-page .autoschedule-preferences-meta {
    color: var(--as-muted);
    font-size: 0.67rem;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    text-align: right;
}

.autoschedule-page .autoschedule-pricing-banner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    padding: 1rem 1.05rem;
    border-radius: 1rem;
    background: linear-gradient(180deg, rgba(var(--bs-primary-rgb), 0.1), rgba(var(--bs-primary-rgb), 0.04));
    border: 1px solid rgba(var(--bs-primary-rgb), 0.16);
}

.autoschedule-page .autoschedule-pricing-banner-copy {
    display: flex;
    flex-direction: column;
    gap: 0.2rem;
}

.autoschedule-page .autoschedule-pricing-banner-copy strong {
    color: var(--as-text);
    font-size: 0.95rem;
}

.autoschedule-page .autoschedule-pricing-banner-copy span {
    color: var(--as-muted);
    font-size: 0.82rem;
    line-height: 1.4;
}

.autoschedule-page .autoschedule-pricing-banner-meta {
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-end;
    gap: 0.45rem;
}

.autoschedule-page .autoschedule-preferences-level {
    padding: 1rem 1.05rem;
    border-radius: 1.15rem;
    background: linear-gradient(180deg, rgba(var(--bs-primary-rgb), 0.07), rgba(var(--bs-primary-rgb), 0.02));
    border: 1px solid rgba(var(--bs-primary-rgb), 0.12);
}

.autoschedule-page .autoschedule-preferences-level-head {
    display: flex;
    align-items: end;
    justify-content: space-between;
    gap: 1rem;
    margin-bottom: 0.95rem;
}

.autoschedule-page .autoschedule-preferences-level-kicker,
.autoschedule-page .autoschedule-preferences-panel-kicker {
    font-size: 0.7rem;
    font-weight: 800;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--as-accent);
}

.autoschedule-page .autoschedule-preferences-level-title {
    font-size: 1rem;
    font-weight: 800;
    color: var(--as-text);
}

.autoschedule-page .autoschedule-preferences-grid--quick .autoschedule-check .form-check-label {
    min-height: 7rem;
}

.autoschedule-page .autoschedule-quick-card--field {
    padding: 0.9rem;
    border-radius: 1rem;
    background: var(--as-surface);
    border: 1px solid var(--as-border);
}

.autoschedule-page .autoschedule-preferences-panel {
    border: 1px solid var(--as-border);
    border-radius: 1.15rem;
    background: var(--as-surface-soft);
    overflow: hidden;
}

.autoschedule-page .autoschedule-preferences-panel summary {
    list-style: none;
}

.autoschedule-page .autoschedule-preferences-panel summary::-webkit-details-marker {
    display: none;
}

.autoschedule-page .autoschedule-preferences-panel-summary {
    display: flex;
    align-items: end;
    justify-content: space-between;
    gap: 1rem;
    padding: 1rem 1.05rem;
    cursor: pointer;
}

.autoschedule-page .autoschedule-preferences-panel-copy {
    display: grid;
    gap: 0.18rem;
}

.autoschedule-page .autoschedule-preferences-panel-copy strong {
    color: var(--as-text);
    font-size: 0.98rem;
}

.autoschedule-page .autoschedule-preferences-panel-copy small {
    color: var(--as-muted);
    font-size: 0.82rem;
    line-height: 1.45;
}

.autoschedule-page .autoschedule-preferences-panel-body {
    padding: 0 1.05rem 1.05rem;
    border-top: 1px solid var(--as-border);
}

.autoschedule-page .autoschedule-preferences-group + .autoschedule-preferences-group {
    margin-top: 1rem;
}

.autoschedule-page .autoschedule-day-chip-group + .autoschedule-day-chip-group {
    margin-top: 0.85rem;
}

.autoschedule-page .autoschedule-day-chip-group-label {
    margin-bottom: 0.5rem;
    color: var(--as-text);
    font-size: 0.84rem;
    font-weight: 700;
}

.autoschedule-page .autoschedule-day-chip-row {
    display: flex;
    flex-wrap: wrap;
    gap: 0.65rem;
}

.autoschedule-page .autoschedule-day-chip {
    margin: 0;
}

.autoschedule-page .autoschedule-day-chip .form-check-input {
    display: none;
}

.autoschedule-page .autoschedule-day-chip .form-check-label {
    position: relative;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 3.35rem;
    min-height: 3.1rem;
    padding: 0.55rem 0.8rem;
    border-radius: 1rem;
    background: var(--as-surface);
    border: 1px solid var(--as-border);
    color: var(--as-text);
    font-size: 0.9rem;
    font-weight: 800;
    cursor: pointer;
    transition: border-color 0.18s ease, background-color 0.18s ease, transform 0.18s ease;
}

.autoschedule-page .autoschedule-day-chip .form-check-input:checked + .form-check-label {
    border-color: rgba(var(--bs-primary-rgb), 0.32);
    background: rgba(var(--bs-primary-rgb), 0.08);
}

.autoschedule-page .autoschedule-professors-panel {
    padding: 1rem 1.05rem;
    border-radius: 1.15rem;
    background: var(--as-surface-soft);
    border: 1px solid var(--as-border);
}

.autoschedule-page .autoschedule-professors-summary {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    padding: 1rem;
    border-radius: 1rem;
    background: var(--as-surface);
    border: 1px solid rgba(var(--bs-primary-rgb), 0.1);
}

.autoschedule-page .autoschedule-professors-summary strong {
    display: block;
    color: var(--as-text);
    font-size: 0.98rem;
}

.autoschedule-page .autoschedule-professors-summary span {
    color: var(--as-muted);
    font-size: 0.82rem;
    line-height: 1.45;
}

.autoschedule-instructor-modal {
    --as-instructor-modal-bg: #ffffff;
    --as-instructor-modal-bg-soft: #f6f8ff;
    --as-instructor-modal-bg-strong: #eef3ff;
    background: var(--as-instructor-modal-bg);
    background-color: var(--as-instructor-modal-bg);
    border: 1px solid rgba(var(--bs-primary-rgb), 0.12);
    border-radius: 1.5rem;
    overflow: hidden;
    box-shadow: 0 2rem 4rem rgba(15, 23, 42, 0.34);
    isolation: isolate;
}

.autoschedule-instructor-modal .modal-header,
.autoschedule-instructor-modal .modal-footer {
    border-color: var(--as-border);
}

.autoschedule-instructor-modal .modal-body {
    background: var(--as-instructor-modal-bg);
    background-color: var(--as-instructor-modal-bg);
    padding: 1.5rem;
}

.autoschedule-instructor-modal__eyebrow {
    margin-bottom: 0.38rem;
    font-size: 0.72rem;
    font-weight: 800;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    color: var(--as-accent);
}

.autoschedule-instructor-modal__title {
    color: var(--as-text);
    font-weight: 800;
    font-size: 2.25rem;
    letter-spacing: -0.03em;
    line-height: 1.02;
}

.autoschedule-instructor-modal__copy {
    color: var(--as-muted);
    font-size: 0.92rem;
    line-height: 1.5;
}

.autoschedule-instructor-modal .modal-header {
    padding: 1.8rem 1.8rem 1.35rem;
    background: linear-gradient(180deg, #f4f7ff 0%, #edf3ff 100%);
}

.autoschedule-instructor-modal .modal-footer {
    padding: 1.2rem 1.8rem 1.35rem;
    background: var(--as-instructor-modal-bg);
    background-color: var(--as-instructor-modal-bg);
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
}

.autoschedule-instructor-modal__slots {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1.2rem;
    margin-bottom: 1.4rem;
}

.autoschedule-instructor-modal .autoschedule-selected-subjects,
.autoschedule-instructor-modal__catalog {
    padding: 1.1rem 1.15rem;
    border-radius: 1.15rem;
    background: var(--as-instructor-modal-bg-soft);
    border: 1px solid var(--as-border);
}

.autoschedule-instructor-modal__catalog {
    padding: 1.2rem 1.2rem 1.1rem;
    background: var(--as-instructor-modal-bg-strong);
    border-color: rgba(var(--bs-primary-rgb), 0.08);
}

.autoschedule-instructor-modal__catalog-head {
    display: flex;
    align-items: end;
    justify-content: space-between;
    gap: 1rem;
    margin-bottom: 1.2rem;
}

.autoschedule-instructor-modal__catalog-kicker {
    margin-bottom: 0.24rem;
    font-size: 0.7rem;
    font-weight: 800;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--as-accent);
}

.autoschedule-instructor-modal__catalog-head strong {
    display: block;
    color: var(--as-text);
    font-size: 1.25rem;
    font-weight: 800;
}

.autoschedule-instructor-modal__catalog-head span {
    color: var(--as-muted);
    font-size: 0.84rem;
    line-height: 1.45;
}

.autoschedule-instructor-modal .autoschedule-selected-subjects-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
    margin-bottom: 0.7rem;
    font-size: 0.78rem;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.16em;
    color: var(--as-accent);
}

.autoschedule-instructor-modal .autoschedule-selected-subjects-list {
    display: grid;
    gap: 0.65rem;
    min-width: 0;
}

.autoschedule-instructor-modal .autoschedule-selected-empty {
    min-height: 5rem;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 1rem;
    border-radius: 1rem;
    border: 2px dashed rgba(118, 132, 176, 0.22);
    background: #ffffff;
    color: rgba(120, 130, 164, 0.72);
    font-size: 0.84rem;
    font-style: italic;
    text-align: center;
}

.autoschedule-instructor-modal .autoschedule-selected-empty span {
    max-width: 18rem;
}

.autoschedule-instructor-modal .autoschedule-selected-chip {
    display: grid;
    grid-template-columns: auto 1fr auto;
    align-items: center;
    gap: 0.7rem;
    width: 100%;
    border: 1px solid rgba(var(--bs-primary-rgb), 0.1);
    background: #ffffff;
    color: var(--as-text);
    border-radius: 1rem;
    padding: 0.7rem 0.8rem;
    min-width: 0;
    text-align: left;
}

.autoschedule-instructor-modal .autoschedule-selected-chip-code {
    padding: 0;
    border-radius: 0;
    background: none;
    color: rgba(var(--bs-primary-rgb), 0.72);
    font-size: 0.68rem;
    font-weight: 800;
    letter-spacing: 0.14em;
    text-transform: uppercase;
}

.autoschedule-instructor-modal .autoschedule-selected-chip-label {
    max-width: none;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    font-size: 0.9rem;
    font-weight: 800;
}

.autoschedule-instructor-modal .autoschedule-selected-chip .material-symbols-outlined {
    font-size: 1rem;
    color: var(--as-muted);
}

.autoschedule-instructor-modal .autoschedule-instructor-groups {
    max-height: 380px;
    border: 0;
    border-radius: 0;
    background: transparent;
    padding: 0;
    overflow: auto;
    scrollbar-width: thin;
}

.autoschedule-instructor-modal .autoschedule-instructor-groups::-webkit-scrollbar {
    width: 8px;
}

.autoschedule-instructor-modal .autoschedule-instructor-groups::-webkit-scrollbar-thumb {
    background: rgba(105, 118, 171, 0.34);
    border-radius: 999px;
}

.autoschedule-instructor-modal .autoschedule-instructor-group + .autoschedule-instructor-group {
    margin-top: 1.35rem;
    padding-top: 1.15rem;
    border-top: 1px solid rgba(118, 132, 176, 0.12);
}

.autoschedule-instructor-modal .autoschedule-instructor-group-title {
    display: flex;
    align-items: center;
    gap: 0.55rem;
    margin-bottom: 0.9rem;
    font-size: 1.18rem;
    font-weight: 800;
    letter-spacing: -0.02em;
    color: var(--as-text);
}

.autoschedule-instructor-modal .autoschedule-instructor-group-title .material-symbols-outlined {
    font-size: 1.05rem;
    color: var(--as-muted);
}

.autoschedule-instructor-modal .autoschedule-instructor-item {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    padding: 1.15rem 1.05rem;
    border-radius: 1rem;
    background: #ffffff;
    border: 1px solid rgba(118, 132, 176, 0.12);
    transition: background-color 0.18s ease, border-color 0.18s ease, transform 0.18s ease, box-shadow 0.18s ease;
}

.autoschedule-instructor-modal .autoschedule-instructor-item + .autoschedule-instructor-item {
    margin-top: 0.85rem;
}

.autoschedule-instructor-modal .autoschedule-instructor-item:hover {
    background: #f8faff;
    border-color: rgba(var(--bs-primary-rgb), 0.18);
    box-shadow: 0 0.8rem 1.8rem rgba(7, 13, 31, 0.12);
}

.autoschedule-instructor-modal .autoschedule-instructor-item.is-preferred {
    border-color: rgba(25, 135, 84, 0.32);
    background: rgba(25, 135, 84, 0.05);
}

.autoschedule-instructor-modal .autoschedule-instructor-item.is-avoided {
    border-color: rgba(220, 53, 69, 0.3);
    background: rgba(220, 53, 69, 0.05);
}

.autoschedule-instructor-modal .autoschedule-instructor-card__identity {
    display: flex;
    align-items: flex-start;
    gap: 0.95rem;
    min-width: 0;
    flex: 1 1 auto;
}

.autoschedule-instructor-modal .autoschedule-instructor-card__code {
    flex: 0 0 auto;
    min-width: 4.9rem;
    color: rgba(var(--bs-primary-rgb), 0.72);
    font-size: 0.68rem;
    font-weight: 800;
    letter-spacing: 0.14em;
    text-transform: uppercase;
}

.autoschedule-instructor-modal .autoschedule-instructor-card__copy {
    min-width: 0;
    display: flex;
    flex-direction: column;
    gap: 0.35rem;
}

.autoschedule-instructor-modal .autoschedule-instructor-card__name {
    display: block;
    font-size: 1.05rem;
    font-weight: 800;
    line-height: 1.2;
    color: var(--as-text);
}

.autoschedule-instructor-modal .autoschedule-instructor-card__meta {
    display: flex;
    flex-wrap: wrap;
    gap: 0.85rem;
}

.autoschedule-instructor-modal .autoschedule-instructor-card__meta-item {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    font-size: 0.82rem;
    color: var(--as-muted);
    line-height: 1.45;
}

.autoschedule-instructor-modal .autoschedule-instructor-card__meta-item .material-symbols-outlined {
    font-size: 0.95rem;
}

.autoschedule-instructor-modal .autoschedule-instructor-card__actions {
    display: inline-flex;
    align-items: center;
    gap: 0.55rem;
    flex: 0 0 auto;
}

.autoschedule-instructor-modal .autoschedule-instructor-action {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    border: 1px solid rgba(var(--bs-primary-rgb), 0.12);
    background: #ffffff;
    color: var(--as-text);
    border-radius: 0.8rem;
    min-height: 2.55rem;
    padding: 0.62rem 0.95rem;
    font-size: 0.78rem;
    font-weight: 800;
    line-height: 1.1;
}

.autoschedule-instructor-modal .autoschedule-instructor-action .material-symbols-outlined {
    font-size: 0.95rem;
}

.autoschedule-instructor-modal .autoschedule-instructor-action:hover {
    background: #f3f7ff;
    border-color: rgba(var(--bs-primary-rgb), 0.18);
}

.autoschedule-instructor-modal .autoschedule-instructor-action.is-active {
    background: rgba(var(--bs-primary-rgb), 0.16);
    color: var(--as-accent);
    border-color: rgba(var(--bs-primary-rgb), 0.26);
}

.autoschedule-instructor-modal .autoschedule-instructor-action.is-danger.is-active {
    background: rgba(220, 53, 69, 0.12);
    color: #dc3545;
    border-color: rgba(220, 53, 69, 0.26);
}

.autoschedule-instructor-modal .autoschedule-clear-btn {
    border: 0;
    background: transparent;
    color: var(--as-muted);
    font-size: 0.76rem;
    font-weight: 700;
}

.autoschedule-instructor-modal__footer-note {
    color: var(--as-muted);
    font-size: 0.82rem;
    font-style: italic;
    line-height: 1.45;
}

.autoschedule-instructor-modal__done {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 7rem;
    min-height: 3rem;
    padding: 0.7rem 1.25rem;
    border: 1px solid rgba(var(--bs-primary-rgb), 0.16);
    border-radius: 0.9rem;
    background: linear-gradient(135deg, rgba(var(--bs-primary-rgb), 0.92), rgba(var(--bs-primary-rgb), 0.68));
    color: #fff;
    font-size: 0.92rem;
    font-weight: 800;
    box-shadow: 0 1rem 2rem rgba(var(--bs-primary-rgb), 0.18);
    transition: transform 0.18s ease, box-shadow 0.18s ease, opacity 0.18s ease;
}

.autoschedule-instructor-modal__done:hover {
    transform: translateY(-1px);
    box-shadow: 0 1.15rem 2.2rem rgba(var(--bs-primary-rgb), 0.22);
}

.autoschedule-page .is-disabled,
.autoschedule-page .autoschedule-day-chip .form-check-input:disabled + .form-check-label,
.autoschedule-page .autoschedule-check .form-check-input:disabled + .form-check-label {
    opacity: 0.48;
    pointer-events: none;
    filter: grayscale(0.1);
}

.autoschedule-page .autoschedule-panel .form-select,
.autoschedule-page .autoschedule-panel .form-control {
    min-height: 3.3rem;
    border-radius: 1rem;
    border-color: var(--as-border);
    background: var(--as-surface-soft);
    color: var(--as-text);
}

.autoschedule-page .autoschedule-panel .form-select:focus,
.autoschedule-page .autoschedule-panel .form-control:focus {
    border-color: rgba(var(--bs-primary-rgb), 0.45);
    box-shadow: 0 0 0 0.2rem rgba(var(--bs-primary-rgb), 0.12);
}

.autoschedule-page .autoschedule-subjects {
    border: 1px solid var(--as-border);
    border-radius: 1.15rem;
    background: var(--as-surface-soft);
    padding: 0.75rem;
    max-height: 330px;
    overflow: auto;
    overflow-x: hidden;
    padding-right: 0.3rem;
    scrollbar-width: thin;
}

.autoschedule-page .autoschedule-subjects::-webkit-scrollbar {
    width: 8px;
}

.autoschedule-page .autoschedule-subjects::-webkit-scrollbar-track {
    background: transparent;
}

.autoschedule-page .autoschedule-subjects::-webkit-scrollbar-thumb {
    background: rgba(105, 118, 171, 0.34);
    border-radius: 999px;
}

.autoschedule-page .autoschedule-subjects::-webkit-scrollbar-thumb:hover {
    background: rgba(105, 118, 171, 0.52);
}

.autoschedule-page .autoschedule-subject-search-wrap {
    position: relative;
}

.autoschedule-page .autoschedule-selected-subjects {
    padding: 0.9rem 1rem;
    border-radius: 1rem;
    background: var(--as-surface-soft);
    border: 1px solid var(--as-border);
}

.autoschedule-page .autoschedule-selected-subjects-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
    margin-bottom: 0.7rem;
    font-size: 0.78rem;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--as-accent);
}

.autoschedule-page .autoschedule-selected-subjects-list {
    display: flex;
    flex-wrap: wrap;
    gap: 0.55rem;
    min-width: 0;
}

.autoschedule-page .autoschedule-selected-empty {
    color: var(--as-muted);
    font-size: 0.83rem;
}

.autoschedule-page .autoschedule-selected-chip {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    border: 1px solid rgba(var(--bs-primary-rgb), 0.2);
    background: var(--as-surface);
    color: var(--as-text);
    border-radius: 999px;
    padding: 0.45rem 0.7rem;
    max-width: 100%;
    min-width: 0;
}

.autoschedule-page .autoschedule-selected-chip-code {
    padding: 0.22rem 0.5rem;
    border-radius: 999px;
    background: var(--as-accent-soft);
    color: var(--as-accent);
    font-size: 0.72rem;
    font-weight: 800;
}

.autoschedule-page .autoschedule-selected-chip-label {
    max-width: min(180px, 42vw);
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    font-size: 0.82rem;
    font-weight: 700;
}

.autoschedule-page .autoschedule-selected-chip .material-symbols-outlined {
    font-size: 1rem;
    color: var(--as-muted);
}

.autoschedule-page .autoschedule-instructor-groups {
    max-height: 360px;
}

.autoschedule-page .autoschedule-instructor-group + .autoschedule-instructor-group {
    margin-top: 0.95rem;
    padding-top: 0.95rem;
    border-top: 1px solid var(--as-border);
}

.autoschedule-page .autoschedule-instructor-group-title {
    margin-bottom: 0.55rem;
    font-size: 0.78rem;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--as-accent);
}

.autoschedule-page .autoschedule-instructor-item {
    align-items: flex-start;
}

.autoschedule-page .autoschedule-instructor-item.is-preferred {
    border-color: rgba(25, 135, 84, 0.35);
}

.autoschedule-page .autoschedule-instructor-item.is-avoided {
    border-color: rgba(220, 53, 69, 0.35);
}

.autoschedule-page .autoschedule-instructor-item .autoschedule-subject-code {
    flex: 0 0 auto;
}

.autoschedule-page .autoschedule-instructor-item .autoschedule-subject-copy {
    flex: 1 1 auto;
    min-width: 0;
}

.autoschedule-page .autoschedule-instructor-topline {
    display: flex;
    align-items: flex-start;
    gap: 0.6rem;
    width: 100%;
}

.autoschedule-page .autoschedule-instructor-item .autoschedule-subject-name {
    flex: 1 1 auto;
    min-width: 0;
}

.autoschedule-page .autoschedule-instructor-item .autoschedule-subject-note {
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    margin-top: 0.18rem;
}

.autoschedule-page .autoschedule-instructor-actions {
    display: inline-flex;
    gap: 0.4rem;
    flex: 0 0 auto;
    white-space: nowrap;
}

.autoschedule-page .autoschedule-instructor-action {
    border: 1px solid rgba(var(--bs-primary-rgb), 0.22);
    background: var(--as-surface);
    color: var(--as-muted);
    border-radius: 999px;
    padding: 0.32rem 0.58rem;
    font-size: 0.72rem;
    font-weight: 800;
    line-height: 1;
}

.autoschedule-page .autoschedule-instructor-action.is-active {
    background: var(--as-accent-soft);
    color: var(--as-accent);
    border-color: rgba(var(--bs-primary-rgb), 0.35);
}

.autoschedule-page .autoschedule-instructor-action.is-danger.is-active {
    background: rgba(220, 53, 69, 0.12);
    color: #dc3545;
    border-color: rgba(220, 53, 69, 0.35);
}

.autoschedule-page .autoschedule-clear-btn {
    border: 0;
    background: transparent;
    color: var(--as-muted);
    font-size: 0.76rem;
    font-weight: 700;
}

.autoschedule-page .autoschedule-subject-search-icon {
    position: absolute;
    left: 1rem;
    top: 50%;
    transform: translateY(-50%);
    color: var(--as-muted);
    font-size: 1.1rem;
    pointer-events: none;
}

.autoschedule-page .autoschedule-subject-search {
    padding-left: 2.9rem;
}

.autoschedule-page .autoschedule-subject-search::placeholder {
    color: var(--as-muted);
    opacity: 1;
}

.autoschedule-page .autoschedule-subject-item {
    display: flex;
    gap: 0.8rem;
    align-items: flex-start;
    padding: 0.8rem 0.85rem;
    border-radius: 1rem;
    background: transparent;
    border: 1px solid transparent;
    transition: background-color 0.18s ease, border-color 0.18s ease, transform 0.18s ease;
    cursor: pointer;
}

.autoschedule-page .autoschedule-subject-item:hover {
    background: var(--as-surface);
    border-color: rgba(var(--bs-primary-rgb), 0.18);
    transform: translateY(-1px);
}

.autoschedule-page .autoschedule-subject-item + .autoschedule-subject-item {
    margin-top: 0.5rem;
}

.autoschedule-page .autoschedule-subject-item.is-selected {
    background: var(--as-surface);
    border-color: rgba(var(--bs-primary-rgb), 0.28);
    box-shadow: 0 0 0 1px rgba(var(--bs-primary-rgb), 0.08);
}

.autoschedule-page .autoschedule-subject-toggle {
    width: 1.35rem;
    height: 1.35rem;
    border-radius: 0.45rem;
    border: 1.5px solid rgba(var(--bs-primary-rgb), 0.38);
    background: transparent;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex: 0 0 auto;
    margin-top: 0.18rem;
    transition: background-color 0.18s ease, border-color 0.18s ease, transform 0.18s ease;
}

.autoschedule-page .autoschedule-subject-toggle .material-symbols-outlined {
    font-size: 0.95rem;
    color: #fff;
    opacity: 0;
    transform: scale(0.6);
    transition: opacity 0.18s ease, transform 0.18s ease;
}

.autoschedule-page .autoschedule-subject-item.is-selected .autoschedule-subject-toggle {
    background: var(--as-accent);
    border-color: var(--as-accent);
}

.autoschedule-page .autoschedule-subject-item.is-selected .autoschedule-subject-toggle .material-symbols-outlined {
    opacity: 1;
    transform: scale(1);
}

.autoschedule-page .autoschedule-subject-code {
    min-width: 4.4rem;
    padding: 0.35rem 0.7rem;
    border-radius: 0.85rem;
    background: var(--as-accent-soft);
    color: var(--as-accent);
    font-size: 0.78rem;
    font-weight: 800;
    text-align: center;
}

.autoschedule-page .autoschedule-subject-name {
    font-size: 0.94rem;
    font-weight: 700;
    line-height: 1.25;
    color: var(--as-text);
}

.autoschedule-page .autoschedule-subject-note {
    font-size: 0.78rem;
    color: var(--as-muted);
}

.autoschedule-page .autoschedule-preferences {
    margin-top: 1.25rem;
}

.autoschedule-page .autoschedule-preferences:first-of-type {
    margin-top: 0;
}

.autoschedule-page .autoschedule-preferences-subtitle {
    margin-bottom: 0.75rem;
    color: var(--as-muted);
    font-size: 0.72rem;
    font-weight: 800;
    letter-spacing: 0.1em;
    text-transform: uppercase;
}

.autoschedule-page .autoschedule-preferences-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.85rem;
}

.autoschedule-page .autoschedule-check {
    margin: 0;
    display: flex;
}

.autoschedule-page .autoschedule-check .form-check-input {
    display: none;
}

.autoschedule-page .autoschedule-check .form-check-label {
    width: 100%;
    display: block;
    position: relative;
    min-height: 8.4rem;
    padding: 1rem 3.65rem 1rem 1rem;
    border-radius: 1rem;
    background: var(--as-surface-soft);
    border: 1px solid var(--as-border);
    color: var(--as-text);
    font-size: 0.92rem;
    font-weight: 600;
    cursor: pointer;
    transition: border-color 0.18s ease, background-color 0.18s ease, transform 0.18s ease;
    overflow: hidden;
}

.autoschedule-page .autoschedule-check-copy {
    display: flex;
    flex-direction: column;
    gap: 0.24rem;
    min-width: 0;
}

.autoschedule-page .autoschedule-check-copy strong {
    font-size: 0.95rem;
    line-height: 1.2;
    color: var(--as-text);
}

.autoschedule-page .autoschedule-check-copy small {
    font-size: 0.76rem;
    line-height: 1.35;
    color: var(--as-muted);
}

.autoschedule-page .autoschedule-price-pill {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 1.75rem;
    padding: 0.3rem 0.6rem;
    border-radius: 999px;
    background: rgba(var(--bs-primary-rgb), 0.1);
    border: 1px solid rgba(var(--bs-primary-rgb), 0.14);
    color: var(--as-accent);
    font-size: 0.69rem;
    font-weight: 800;
    letter-spacing: 0.05em;
    text-transform: uppercase;
    white-space: nowrap;
}

.autoschedule-page .autoschedule-price-pill.is-free {
    background: rgba(25, 135, 84, 0.12);
    border-color: rgba(25, 135, 84, 0.18);
    color: #198754;
}

.autoschedule-page .autoschedule-credit-dot {
    position: absolute;
    top: 0.8rem;
    right: 0.8rem;
    width: 2.1rem;
    height: 2.1rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 999px;
    font-size: 0.74rem;
    font-weight: 900;
    letter-spacing: -0.03em;
    color: #7a5200;
    background: linear-gradient(180deg, #ffe7a3 0%, #f6c857 100%);
    border: 1px solid rgba(186, 129, 0, 0.28);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.55), 0 8px 16px rgba(186, 129, 0, 0.12);
}

.autoschedule-page .autoschedule-credit-dot.is-free {
    color: #13653b;
    background: linear-gradient(180deg, #daf8e8 0%, #a9ecc6 100%);
    border-color: rgba(19, 101, 59, 0.18);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.65), 0 8px 16px rgba(37, 138, 85, 0.12);
}

[data-theme="dark"] .autoschedule-page .autoschedule-credit-dot {
    color: #e7efff;
    background: linear-gradient(180deg, #3557a8 0%, #233a77 100%);
    border-color: rgba(139, 182, 255, 0.24);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.12), 0 8px 18px rgba(16, 34, 84, 0.32);
}

[data-theme="dark"] .autoschedule-page .autoschedule-credit-dot.is-free {
    color: #e7fff4;
    background: linear-gradient(180deg, #278a60 0%, #176345 100%);
    border-color: rgba(145, 255, 203, 0.2);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.1), 0 8px 18px rgba(12, 44, 30, 0.32);
}

.autoschedule-page .autoschedule-credit-dot--mini {
    position: absolute;
    top: -0.35rem;
    right: -0.35rem;
    width: 1.45rem;
    height: 1.45rem;
    font-size: 0.58rem;
}

[data-theme="dark"] .autoschedule-page .autoschedule-preferences-level,
[data-theme="dark"] .autoschedule-page .autoschedule-preferences-panel,
[data-theme="dark"] .autoschedule-page .autoschedule-professors-panel {
    background: rgba(18, 28, 62, 0.72);
    border-color: rgba(132, 154, 255, 0.12);
}

[data-theme="dark"] .autoschedule-page .autoschedule-quick-card--field,
[data-theme="dark"] .autoschedule-page .autoschedule-day-chip .form-check-label,
[data-theme="dark"] .autoschedule-page .autoschedule-professors-summary,
[data-theme="dark"] .autoschedule-instructor-modal .modal-body {
    background: rgba(11, 19, 38, 0.9);
    border-color: rgba(132, 154, 255, 0.12);
}

[data-theme="dark"] .autoschedule-instructor-modal .modal-header,
[data-theme="dark"] .autoschedule-instructor-modal .modal-footer,
[data-theme="dark"] .autoschedule-instructor-modal .autoschedule-selected-subjects,
[data-theme="dark"] .autoschedule-instructor-modal .autoschedule-instructor-groups,
[data-theme="dark"] .autoschedule-instructor-modal .autoschedule-instructor-modal__catalog {
    background: #18244f;
    border-color: rgba(132, 154, 255, 0.12);
}

[data-theme="dark"] .autoschedule-instructor-modal {
    --as-instructor-modal-bg: #121a3a;
    --as-instructor-modal-bg-soft: #18244f;
    --as-instructor-modal-bg-strong: #1d2b5d;
    background: var(--as-instructor-modal-bg);
    background-color: var(--as-instructor-modal-bg);
}

[data-theme="dark"] .autoschedule-instructor-modal .modal-header {
    background: linear-gradient(180deg, #1b2756 0%, #162047 100%);
}

[data-theme="dark"] .autoschedule-instructor-modal .modal-body,
[data-theme="dark"] .autoschedule-instructor-modal .modal-footer {
    background: var(--as-instructor-modal-bg);
    background-color: var(--as-instructor-modal-bg);
}

[data-theme="dark"] .autoschedule-instructor-modal .autoschedule-selected-chip,
[data-theme="dark"] .autoschedule-instructor-modal .autoschedule-instructor-action {
    background: #101833;
    border-color: rgba(132, 154, 255, 0.14);
}

[data-theme="dark"] .autoschedule-instructor-modal .autoschedule-instructor-item:hover {
    background: #1d2a59;
}

[data-theme="dark"] .autoschedule-instructor-modal .autoschedule-instructor-item {
    background: #162047;
}

[data-theme="dark"] .autoschedule-instructor-modal .autoschedule-selected-empty {
    border-color: rgba(132, 154, 255, 0.14);
    background: #101833;
    color: rgba(194, 198, 214, 0.5);
}

[data-theme="dark"] .autoschedule-instructor-modal__done {
    color: #0b1326;
    background: linear-gradient(135deg, #adc6ff 0%, #6e98ff 100%);
    border-color: rgba(173, 198, 255, 0.22);
    box-shadow: 0 1rem 2.2rem rgba(77, 142, 255, 0.22);
}

@media (max-width: 991.98px) {
    .autoschedule-instructor-modal__slots {
        grid-template-columns: 1fr;
    }

    .autoschedule-instructor-modal__catalog-head,
    .autoschedule-instructor-modal .modal-footer,
    .autoschedule-instructor-modal .autoschedule-instructor-item {
        flex-direction: column;
        align-items: stretch;
    }

    .autoschedule-instructor-modal .autoschedule-instructor-card__actions {
        width: 100%;
        justify-content: flex-start;
        flex-wrap: wrap;
    }
}

@media (max-width: 767.98px) {
    .autoschedule-instructor-modal .modal-header,
    .autoschedule-instructor-modal .modal-body,
    .autoschedule-instructor-modal .modal-footer {
        padding-left: 1rem;
        padding-right: 1rem;
    }

    .autoschedule-instructor-modal__title {
        font-size: 1.8rem;
    }

    .autoschedule-instructor-modal .autoschedule-instructor-card__identity {
        flex-direction: column;
        gap: 0.5rem;
    }

    .autoschedule-instructor-modal .autoschedule-instructor-card__code {
        min-width: 0;
    }
}

.autoschedule-page .autoschedule-check .form-check-label::after {
    content: "";
    position: absolute;
    right: 0.95rem;
    bottom: 0.95rem;
    width: 1.2rem;
    height: 1.2rem;
    border-radius: 999px;
    border: 2px solid rgba(var(--bs-primary-rgb), 0.4);
    background: transparent;
    box-shadow: 0 0 0 4px rgba(255, 255, 255, 0.28);
}

.autoschedule-page .autoschedule-check .form-check-input:checked + .form-check-label {
    background: var(--as-surface);
    border-color: rgba(var(--bs-primary-rgb), 0.3);
}

.autoschedule-page .autoschedule-check .form-check-input:checked + .form-check-label::after {
    background: var(--as-accent);
    border-color: var(--as-accent);
    box-shadow: inset 0 0 0 3px var(--as-surface);
}

.autoschedule-page .autoschedule-cta {
    min-height: 3.6rem;
    border-radius: 1rem;
    font-weight: 800;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex-wrap: wrap;
}

.autoschedule-page .autoschedule-cta-price {
    display: block;
    width: 100%;
    margin-top: 0.15rem;
    font-size: 0.72rem;
    font-weight: 700;
    opacity: 0.9;
}

.autoschedule-page .autoschedule-powered {
    text-align: center;
    font-size: 0.7rem;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--as-muted);
    margin-top: 0.9rem;
}

@media (max-width: 991.98px) {
    .autoschedule-page .autoschedule-pricing-banner,
    .autoschedule-page .autoschedule-preferences-title {
        flex-direction: column;
        align-items: flex-start;
    }

    .autoschedule-page .autoschedule-pricing-banner-meta {
        justify-content: flex-start;
    }

    .autoschedule-page .autoschedule-preferences-meta {
        text-align: left;
    }
}

.autoschedule-page .autoschedule-results-panel {
    padding: 1.75rem;
}

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

.autoschedule-page .autoschedule-results-title {
    font-size: clamp(1.7rem, 2.2vw, 2.4rem);
    font-weight: 800;
    color: var(--as-text);
    margin-bottom: 0.25rem;
}

.autoschedule-page .autoschedule-refresh {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 2rem;
    padding: 0.4rem 0.8rem;
    border-radius: 0.85rem;
    background: var(--as-surface-soft);
    color: var(--as-accent);
    border: 1px solid rgba(var(--bs-primary-rgb), 0.18);
    font-size: 0.72rem;
    font-weight: 800;
    letter-spacing: 0.1em;
    text-transform: uppercase;
}

.autoschedule-page .autoschedule-proposals-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 1rem;
}

.autoschedule-page .autoschedule-compare-toolbar {
    background: var(--as-surface);
    border: 1px solid var(--as-border);
    border-radius: 1.35rem;
    box-shadow: var(--as-shadow);
}

.autoschedule-page .autoschedule-compare-count {
    background: rgba(15, 23, 42, 0.06);
    border-color: rgba(15, 23, 42, 0.1) !important;
    color: var(--as-text);
    font-weight: 700;
}

.autoschedule-page .autoschedule-proposal {
    padding: 1.45rem;
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

.autoschedule-page .autoschedule-proposal.is-featured {
    grid-column: 1 / -1;
    padding: 1.85rem;
}

.autoschedule-page .autoschedule-proposal-head {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 1rem;
}

.autoschedule-page .autoschedule-proposal-kicker {
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
    flex-wrap: wrap;
    margin-bottom: 0.55rem;
}

.autoschedule-page .autoschedule-proposal-tag {
    display: inline-flex;
    align-items: center;
    min-height: 1.85rem;
    padding: 0.2rem 0.65rem;
    border-radius: 999px;
    font-size: 0.72rem;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.autoschedule-page .autoschedule-proposal-tag.primary {
    background: var(--as-accent-soft);
    color: var(--as-accent);
}

.autoschedule-page .autoschedule-proposal-tag.warning {
    background: var(--as-warning-soft);
    color: #b15c00;
}

[data-theme="dark"] .autoschedule-page .autoschedule-proposal-tag.warning {
    color: #ffb786;
}

.autoschedule-page .autoschedule-proposal-score {
    text-align: right;
}

.autoschedule-page .autoschedule-proposal-score strong {
    display: block;
    font-size: clamp(2.3rem, 3vw, 4rem);
    line-height: 0.9;
    color: var(--as-text);
}

.autoschedule-page .autoschedule-proposal-score span {
    color: var(--as-muted);
    font-size: 0.88rem;
}

.autoschedule-page .autoschedule-proposal-title {
    font-size: 1.2rem;
    font-weight: 800;
    color: var(--as-text);
    margin-bottom: 0.2rem;
}

.autoschedule-page .autoschedule-proposal-meta {
    color: var(--as-muted);
    font-size: 0.92rem;
}

.autoschedule-page .autoschedule-highlights {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
}

.autoschedule-page .autoschedule-highlight {
    padding: 0.5rem 0.8rem;
    border-radius: 999px;
    background: var(--as-accent-soft);
    color: var(--as-accent);
    font-size: 0.76rem;
    font-weight: 700;
}

.autoschedule-page .autoschedule-proposal-body {
    display: none;
    flex-direction: column;
    gap: 1rem;
}

.autoschedule-page .autoschedule-proposal-body.is-expanded {
    display: flex;
}

.autoschedule-page .autoschedule-proposal-locked {
    position: relative;
    overflow: hidden;
    background:
        radial-gradient(circle at top left, rgba(var(--bs-primary-rgb), 0.08), transparent 42%),
        var(--as-surface);
    border: 1px dashed rgba(var(--bs-primary-rgb), 0.2);
}

.autoschedule-page .autoschedule-proposal-locked::after {
    content: "";
    position: absolute;
    inset: 0;
    pointer-events: none;
    background: linear-gradient(135deg, rgba(255, 255, 255, 0.06), transparent 42%);
}

.autoschedule-page .autoschedule-proposal.is-secondary {
    padding-top: 1.7rem;
}

.autoschedule-page .autoschedule-proposal-head--locked {
    align-items: center;
}

.autoschedule-page .autoschedule-proposal-tag.locked {
    background: rgba(15, 23, 42, 0.08);
    color: var(--as-muted);
}

.autoschedule-page .autoschedule-proposal-lock-icon {
    width: 3rem;
    height: 3rem;
    flex: 0 0 auto;
    border-radius: 1rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: rgba(var(--bs-primary-rgb), 0.1);
    color: var(--as-accent);
    border: 1px solid rgba(var(--bs-primary-rgb), 0.16);
}

.autoschedule-page .autoschedule-proposal-lock-icon .material-symbols-outlined {
    font-size: 1.3rem;
}

.autoschedule-page .autoschedule-proposal-locked-preview {
    display: grid;
    gap: 1rem;
    padding: 1rem 1.05rem;
    border-radius: 1.1rem;
    background: linear-gradient(180deg, rgba(15, 23, 42, 0.03), rgba(15, 23, 42, 0.015));
    border: 1px solid var(--as-border);
}

.autoschedule-page .autoschedule-proposal-locked-score {
    display: flex;
    align-items: end;
    justify-content: space-between;
    gap: 1rem;
}

.autoschedule-page .autoschedule-proposal-locked-score span {
    color: var(--as-muted);
    font-size: 0.82rem;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    font-weight: 800;
}

.autoschedule-page .autoschedule-proposal-locked-score strong {
    color: var(--as-text);
    font-size: clamp(1.9rem, 2.4vw, 2.8rem);
    line-height: 1;
    letter-spacing: -0.04em;
}

.autoschedule-page .autoschedule-proposal-locked-metrics {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 0.85rem;
}

.autoschedule-page .autoschedule-proposal-locked-metrics span,
.autoschedule-page .autoschedule-proposal-locked-mini-lines span {
    height: 4.9rem;
    border-radius: 1rem;
    background: linear-gradient(90deg, rgba(124, 141, 181, 0.2), rgba(124, 141, 181, 0.42), rgba(124, 141, 181, 0.2));
    background-size: 220% 100%;
    animation: autoscheduleLockedShimmer 2.6s linear infinite;
}

.autoschedule-page .autoschedule-proposal-locked-stat {
    display: flex;
    flex-direction: column;
    justify-content: center;
    gap: 0.2rem;
    padding: 0.9rem 1rem;
    min-height: 4.9rem;
    border-radius: 1rem;
    background: linear-gradient(180deg, rgba(15, 23, 42, 0.04), rgba(15, 23, 42, 0.02));
    border: 1px solid var(--as-border);
}

.autoschedule-page .autoschedule-proposal-locked-stat small {
    color: var(--as-muted);
    font-size: 0.7rem;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.autoschedule-page .autoschedule-proposal-locked-stat strong {
    color: var(--as-text);
    font-size: 1rem;
    line-height: 1.2;
}

.autoschedule-page .autoschedule-proposal-locked-bars {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 0.6rem;
}

.autoschedule-page .autoschedule-proposal-locked-bars span {
    height: 0.38rem;
    border-radius: 999px;
    background: rgba(124, 141, 181, 0.22);
}

.autoschedule-page .autoschedule-proposal-locked-bars span.is-active {
    background: rgba(var(--bs-primary-rgb), 0.38);
}

.autoschedule-page .autoschedule-proposal-locked-note {
    display: flex;
    flex-direction: column;
    gap: 0.24rem;
}

.autoschedule-page .autoschedule-proposal-locked-note strong {
    color: var(--as-text);
    font-size: 0.96rem;
}

.autoschedule-page .autoschedule-proposal-locked-note span {
    color: var(--as-muted);
    font-size: 0.84rem;
    line-height: 1.45;
}

.autoschedule-page .autoschedule-locked-cta {
    display: flex;
    justify-content: flex-start;
    margin-top: 1.15rem;
    margin-bottom: 0.35rem;
}

.autoschedule-page .autoschedule-unlock-button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.58rem;
    min-height: 3.8rem;
    padding: 1.08rem 1.28rem;
    border-radius: 1rem;
    border: 1px solid transparent;
    font-size: 0.9rem;
    font-weight: 800;
    letter-spacing: 0.01em;
    text-decoration: none;
    transition: transform 0.18s ease, box-shadow 0.18s ease, border-color 0.18s ease, background-color 0.18s ease, color 0.18s ease;
}

.autoschedule-page .autoschedule-unlock-button:hover {
    transform: translateY(-1px);
}

.autoschedule-page .autoschedule-unlock-button .material-symbols-outlined {
    font-size: 1.1rem;
}

.autoschedule-page .autoschedule-unlock-button--primary {
    color: #0f2d63;
    background: linear-gradient(135deg, #c6d9ff 0%, #8bb6ff 100%);
    border-color: rgba(74, 111, 180, 0.24);
    box-shadow: 0 14px 28px rgba(74, 111, 180, 0.18);
}

.autoschedule-page .autoschedule-unlock-button--primary:hover {
    color: #0b234f;
    box-shadow: 0 18px 32px rgba(74, 111, 180, 0.24);
}

.autoschedule-page .autoschedule-unlock-button--secondary {
    color: #534000;
    background: linear-gradient(135deg, #fff0be 0%, #f5cc66 100%);
    border-color: rgba(185, 142, 20, 0.26);
    box-shadow: 0 14px 28px rgba(185, 142, 20, 0.16);
}

.autoschedule-page .autoschedule-unlock-button--secondary:hover {
    color: #443400;
    box-shadow: 0 18px 32px rgba(185, 142, 20, 0.22);
}

.autoschedule-page .autoschedule-proposal-locked-stack {
    display: grid;
    gap: 0.8rem;
}

.autoschedule-page .autoschedule-proposal-locked-mini {
    display: flex;
    align-items: center;
    gap: 0.85rem;
    padding: 0.9rem 1rem;
    border-radius: 1rem;
    background: linear-gradient(180deg, rgba(15, 23, 42, 0.03), rgba(15, 23, 42, 0.015));
    border: 1px solid var(--as-border);
}

.autoschedule-page .autoschedule-proposal-locked-mini-tag {
    min-width: 3rem;
    text-align: center;
    padding: 0.4rem 0.6rem;
    border-radius: 999px;
    background: var(--as-accent-soft);
    color: var(--as-accent);
    font-size: 0.72rem;
    font-weight: 800;
    letter-spacing: 0.08em;
}

.autoschedule-page .autoschedule-proposal-locked-mini-lines {
    flex: 1 1 auto;
    display: grid;
    grid-template-columns: 1fr 0.72fr;
    gap: 0.7rem;
}

.autoschedule-page .autoschedule-proposal-locked-mini-lines span {
    height: 2.7rem;
}

.autoschedule-page .autoschedule-proposal-locked-mini-lines.is-content {
    display: flex;
    flex-direction: column;
    gap: 0.18rem;
}

.autoschedule-page .autoschedule-proposal-locked-mini-lines.is-content strong,
.autoschedule-page .autoschedule-proposal-locked-mini-lines.is-content span {
    height: auto;
    border-radius: 0;
    background: none;
    animation: none;
}

.autoschedule-page .autoschedule-proposal-locked-mini-lines.is-content strong {
    color: var(--as-text);
    font-size: 0.94rem;
    line-height: 1.3;
}

.autoschedule-page .autoschedule-proposal-locked-mini-lines.is-content span {
    color: var(--as-muted);
    font-size: 0.8rem;
    line-height: 1.4;
}

@keyframes autoscheduleLockedShimmer {
    0% {
        background-position: 200% 0;
    }
    100% {
        background-position: -20% 0;
    }
}

.autoschedule-page .autoschedule-recommended-note {
    display: grid;
    gap: 0.2rem;
    padding: 0.95rem 1rem;
    border-radius: 1rem;
    background: var(--as-accent-soft);
    border: 1px solid rgba(var(--bs-primary-rgb), 0.16);
}

.autoschedule-page .autoschedule-recommended-note strong {
    color: var(--as-accent);
    font-size: 0.86rem;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.08em;
}

.autoschedule-page .autoschedule-recommended-note span {
    color: var(--as-text);
    font-size: 0.88rem;
}

.autoschedule-page .autoschedule-explanations {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0.85rem;
}

.autoschedule-page .autoschedule-explanation-block {
    padding: 0.9rem 1rem;
    border-radius: 1rem;
    background: var(--as-surface-soft);
    border: 1px solid var(--as-border);
}

.autoschedule-page .autoschedule-explanation-block.is-warning {
    background: var(--as-warning-soft);
}

.autoschedule-page .autoschedule-explanation-block.is-neutral {
    background: var(--as-surface-strong);
}

.autoschedule-page .autoschedule-explanation-title {
    font-size: 0.78rem;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--as-muted);
    margin-bottom: 0.45rem;
}

.autoschedule-page .autoschedule-explanation-list {
    margin: 0;
    padding-left: 1rem;
    display: grid;
    gap: 0.35rem;
    color: var(--as-text);
    font-size: 0.88rem;
}

.autoschedule-page .autoschedule-explanation-list li.is-positive::marker {
    color: #198754;
}

.autoschedule-page .autoschedule-explanation-list li.is-muted {
    color: var(--as-muted);
}

.autoschedule-page .autoschedule-score-breakdown {
    display: grid;
    gap: 0.55rem;
}

.autoschedule-page .autoschedule-score-breakdown-list {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
}

.autoschedule-page .autoschedule-score-chip {
    display: inline-flex;
    align-items: center;
    min-height: 1.9rem;
    padding: 0.35rem 0.75rem;
    border-radius: 999px;
    font-size: 0.76rem;
    font-weight: 700;
    background: var(--as-surface-soft);
    border: 1px solid var(--as-border);
    color: var(--as-text);
}

.autoschedule-page .autoschedule-score-chip.is-positive {
    color: #198754;
}

.autoschedule-page .autoschedule-score-chip.is-negative {
    color: #c33d4f;
}

.autoschedule-page .autoschedule-metrics-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 0.9rem;
}

.autoschedule-page .autoschedule-metric-card {
    padding: 1rem;
    border-radius: 1rem;
    background: var(--as-surface-soft);
    border: 1px solid var(--as-border);
}

.autoschedule-page .autoschedule-metric-card span {
    display: block;
    font-size: 0.7rem;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--as-muted);
    margin-bottom: 0.25rem;
}

.autoschedule-page .autoschedule-metric-card strong {
    font-size: 1.2rem;
    color: var(--as-text);
}

.autoschedule-page .autoschedule-mini-preview {
    border-radius: 1.2rem;
    background: var(--as-surface-soft);
    border: 1px solid var(--as-border);
    padding: 0.85rem;
}

.autoschedule-page .autoschedule-mini-preview-track {
    height: 3.6rem;
    border-radius: 1rem;
    background: var(--as-surface);
    display: grid;
    grid-template-columns: repeat(7, minmax(0, 1fr));
    gap: 0.35rem;
    padding: 0.55rem;
    margin-bottom: 0.7rem;
}

.autoschedule-page .autoschedule-mini-preview-bar {
    border-radius: 0.55rem;
    background: rgba(var(--bs-primary-rgb), 0.1);
}

.autoschedule-page .autoschedule-mini-preview-bar.active {
    background: rgba(var(--bs-primary-rgb), 0.45);
}

.autoschedule-page .autoschedule-mini-preview-note {
    display: flex;
    justify-content: space-between;
    gap: 1rem;
    color: var(--as-muted);
    font-size: 0.78rem;
}

.autoschedule-page .autoschedule-section-list {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
    gap: 0.75rem;
}

.autoschedule-page .autoschedule-section-pill {
    display: flex;
    gap: 0.75rem;
    align-items: flex-start;
    padding: 0.85rem 0.95rem;
    border-radius: 1rem;
    background: var(--as-surface-soft);
    border: 1px solid var(--as-border);
}

.autoschedule-page .autoschedule-section-text {
    display: flex;
    flex-direction: column;
    gap: 0.18rem;
    min-width: 0;
    color: var(--as-text);
    font-size: 0.92rem;
    font-weight: 700;
    line-height: 1.3;
}

.autoschedule-page .autoschedule-section-text span {
    color: var(--as-muted);
    font-size: 0.78rem;
    font-weight: 500;
}

.autoschedule-page .autoschedule-section-text .autoschedule-section-instructor {
    color: var(--as-text);
    font-weight: 600;
}

.autoschedule-page .autoschedule-actions {
    display: flex;
    gap: 0.75rem;
    align-items: center;
    flex-wrap: wrap;
}

.autoschedule-page .autoschedule-actions-top .btn,
.autoschedule-page .autoschedule-actions-top .autoschedule-store-form {
    flex: 1 1 0;
}

.autoschedule-page .autoschedule-actions-top .btn {
    min-height: 3rem;
    border-radius: 1rem;
    font-weight: 800;
}

.autoschedule-page .autoschedule-compare-toggle.is-active {
    background: var(--as-accent-soft);
    border-color: rgba(var(--bs-primary-rgb), 0.24);
    color: var(--as-accent);
}

.autoschedule-page .autoschedule-detail-toggle[aria-expanded="true"] {
    background: var(--as-accent-soft);
    border-color: rgba(var(--bs-primary-rgb), 0.24);
    color: var(--as-accent);
}

.autoschedule-page .autoschedule-store-form {
    flex: 1 1 auto;
}

.autoschedule-page .autoschedule-store-form .btn {
    width: 100%;
    min-height: 3rem;
    border-radius: 1rem;
    font-weight: 800;
}

.autoschedule-page .autoschedule-icon-button {
    width: 3rem;
    height: 3rem;
    border-radius: 1rem;
    border: 1px solid var(--as-border);
    background: var(--as-surface-soft);
    color: var(--as-muted);
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

.autoschedule-page .autoschedule-credit-estimator {
    margin-top: 1rem;
    padding: 1rem 1.05rem;
    border-radius: 1rem;
    background: var(--as-surface-soft);
    border: 1px solid var(--as-border);
}

.autoschedule-page .autoschedule-credit-estimator-head {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 1rem;
}

.autoschedule-page .autoschedule-credit-estimator-head strong {
    display: block;
    color: var(--as-text);
    font-size: 0.96rem;
}

.autoschedule-page .autoschedule-credit-estimator-total {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 4.9rem;
    min-height: 2.2rem;
    padding: 0.35rem 0.75rem;
    border-radius: 999px;
    background: rgba(var(--bs-primary-rgb), 0.12);
    color: var(--as-accent);
    border: 1px solid rgba(var(--bs-primary-rgb), 0.14);
    font-size: 0.82rem;
    font-weight: 900;
    letter-spacing: 0.02em;
}

.autoschedule-page .autoschedule-credit-estimator-total.is-free {
    background: rgba(25, 135, 84, 0.12);
    border-color: rgba(25, 135, 84, 0.18);
    color: #198754;
}

.autoschedule-page .autoschedule-credit-estimator-body {
    margin-top: 0.9rem;
    display: flex;
    flex-direction: column;
    gap: 0.45rem;
    color: var(--as-muted);
    font-size: 0.82rem;
    line-height: 1.45;
}

.autoschedule-page .autoschedule-credit-estimator-line {
    display: block;
    padding: 0.55rem 0.7rem;
    border-radius: 0.8rem;
    background: rgba(var(--bs-primary-rgb), 0.06);
    color: var(--as-text);
}

.autoschedule-page .autoschedule-warnings .alert {
    border-radius: 1rem;
}

.autoschedule-page .autoschedule-help-links {
    display: flex;
    justify-content: center;
    gap: 2rem;
    flex-wrap: wrap;
    padding-top: 1.5rem;
    margin-top: 1.75rem;
    border-top: 1px solid var(--as-border);
}

.autoschedule-page .autoschedule-help-link {
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
    color: var(--as-muted);
    text-decoration: none;
    font-weight: 600;
}

.autoschedule-page .autoschedule-help-link:hover {
    color: var(--as-text);
}

.autoschedule-page .autoschedule-empty {
    padding: 2rem;
}

[data-theme="dark"] .autoschedule-page .autoschedule-panel .form-select,
[data-theme="dark"] .autoschedule-page .autoschedule-panel .form-control {
    color: var(--as-text);
}

[data-theme="dark"] .autoschedule-page .autoschedule-subject-search::placeholder {
    color: rgba(255, 255, 255, 0.56);
}

[data-theme="dark"] .autoschedule-page .autoschedule-panel .form-select,
[data-theme="dark"] .autoschedule-page .autoschedule-panel .form-control,
[data-theme="dark"] .autoschedule-page .autoschedule-check .form-check-label,
[data-theme="dark"] .autoschedule-page .autoschedule-mini-preview-track {
    background: #171c49;
    border-color: rgba(255, 255, 255, 0.12);
}

[data-theme="dark"] .autoschedule-page .autoschedule-subject-item:hover,
[data-theme="dark"] .autoschedule-page .autoschedule-check .form-check-input:checked + .form-check-label,
[data-theme="dark"] .autoschedule-page .autoschedule-mini-preview {
    background: #232860;
}

[data-theme="dark"] .autoschedule-page .autoschedule-check .form-check-label::after {
    box-shadow: 0 0 0 4px rgba(15, 20, 53, 0.72);
}

[data-theme="dark"] .autoschedule-page .autoschedule-explanation-block.is-warning {
    background: rgba(255, 183, 134, 0.12);
}

[data-theme="dark"] .autoschedule-page .autoschedule-explanation-block.is-neutral,
[data-theme="dark"] .autoschedule-page .autoschedule-recent-run,
[data-theme="dark"] .autoschedule-page .autoschedule-limit-note {
    background: rgba(255, 255, 255, 0.04);
}

[data-theme="dark"] .autoschedule-page .autoschedule-subject-item.is-selected {
    background: #232860;
    border-color: rgba(157, 195, 255, 0.26);
}

[data-theme="dark"] .autoschedule-page .autoschedule-form-section,
[data-theme="dark"] .autoschedule-page .autoschedule-step.is-current,
[data-theme="dark"] .autoschedule-page .autoschedule-recommended-note {
    background: rgba(255, 255, 255, 0.04);
}

[data-theme="dark"] .autoschedule-page .autoschedule-metric-card,
[data-theme="dark"] .autoschedule-page .autoschedule-results-panel,
[data-theme="dark"] .autoschedule-page .autoschedule-icon-button,
[data-theme="dark"] .autoschedule-page .autoschedule-compare-toolbar {
    background: rgba(255, 255, 255, 0.04);
}

[data-theme="dark"] .autoschedule-page .autoschedule-compare-count {
    background: rgba(157, 195, 255, 0.12);
    border-color: rgba(157, 195, 255, 0.22) !important;
    color: rgba(244, 248, 255, 0.96);
}

[data-theme="dark"] .autoschedule-page .autoschedule-kicker,
[data-theme="dark"] .autoschedule-page .autoschedule-brand-kicker,
[data-theme="dark"] .autoschedule-page .autoschedule-refresh,
[data-theme="dark"] .autoschedule-page .autoschedule-highlight {
    color: #9dc3ff;
}

[data-theme="dark"] .autoschedule-page .autoschedule-proposal-tag.primary {
    color: #9dc3ff;
}

[data-theme="dark"] .autoschedule-page .autoschedule-proposal-tag.locked {
    background: rgba(255, 255, 255, 0.08);
    color: rgba(255, 255, 255, 0.72);
}

[data-theme="dark"] .autoschedule-page .autoschedule-proposal-locked {
    background:
        radial-gradient(circle at top left, rgba(139, 182, 255, 0.12), transparent 42%),
        rgba(255, 255, 255, 0.04);
    border-color: rgba(157, 195, 255, 0.22);
}

[data-theme="dark"] .autoschedule-page .autoschedule-proposal-lock-icon,
[data-theme="dark"] .autoschedule-page .autoschedule-proposal-locked-mini {
    background: rgba(255, 255, 255, 0.04);
    border-color: rgba(157, 195, 255, 0.16);
}

[data-theme="dark"] .autoschedule-page .autoschedule-proposal-locked-preview {
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.045), rgba(255, 255, 255, 0.025));
}

[data-theme="dark"] .autoschedule-page .autoschedule-proposal-locked-stat {
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.045), rgba(255, 255, 255, 0.025));
    border-color: rgba(157, 195, 255, 0.14);
}

[data-theme="dark"] .autoschedule-page .autoschedule-proposal-locked-metrics span,
[data-theme="dark"] .autoschedule-page .autoschedule-proposal-locked-mini-lines span {
    background: linear-gradient(90deg, rgba(103, 120, 168, 0.22), rgba(157, 195, 255, 0.32), rgba(103, 120, 168, 0.22));
    background-size: 220% 100%;
}

[data-theme="dark"] .autoschedule-page .autoschedule-proposal-locked-bars span {
    background: rgba(255, 255, 255, 0.08);
}

[data-theme="dark"] .autoschedule-page .autoschedule-proposal-locked-bars span.is-active {
    background: rgba(157, 195, 255, 0.46);
}

[data-theme="dark"] .autoschedule-page .autoschedule-unlock-button--primary {
    color: #f4f8ff;
    background: linear-gradient(135deg, #2f4d97 0%, #4268bf 100%);
    border-color: rgba(157, 195, 255, 0.24);
    box-shadow: 0 16px 30px rgba(9, 18, 56, 0.34);
}

[data-theme="dark"] .autoschedule-page .autoschedule-unlock-button--primary:hover {
    color: #ffffff;
    box-shadow: 0 18px 34px rgba(9, 18, 56, 0.42);
}

[data-theme="dark"] .autoschedule-page .autoschedule-unlock-button--secondary {
    color: #fff4d7;
    background: linear-gradient(135deg, #7b6020 0%, #a27a25 100%);
    border-color: rgba(255, 215, 133, 0.2);
    box-shadow: 0 16px 30px rgba(49, 33, 4, 0.34);
}

[data-theme="dark"] .autoschedule-page .autoschedule-unlock-button--secondary:hover {
    color: #fff8e8;
    box-shadow: 0 18px 34px rgba(49, 33, 4, 0.42);
}

[data-theme="dark"] .autoschedule-page .autoschedule-help-link {
    color: rgba(255, 255, 255, 0.68);
}

[data-theme="dark"] .autoschedule-page .autoschedule-help-link:hover {
    color: rgba(255, 255, 255, 0.96);
}

@media (max-width: 1399.98px) {
    .autoschedule-page .autoschedule-metrics-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .autoschedule-page .autoschedule-explanations {
        grid-template-columns: 1fr;
    }

    .autoschedule-page .autoschedule-proposal-locked-metrics {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 1199.98px) {
    .autoschedule-page .autoschedule-shell {
        grid-template-columns: 1fr;
        min-width: 0;
        width: 100%;
    }

    .autoschedule-page .autoschedule-config {
        position: static;
        min-width: 0;
        width: 100%;
    }

    .autoschedule-page .autoschedule-proposals-grid {
        grid-template-columns: 1fr;
    }

    .autoschedule-page .autoschedule-flow-grid {
        grid-template-columns: 1fr;
    }

    .autoschedule-page .autoschedule-proposal-head--locked,
    .autoschedule-page .autoschedule-proposal-locked-score {
        flex-direction: column;
        align-items: flex-start;
    }

    .autoschedule-page .autoschedule-proposal-locked-mini-lines {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 767.98px) {
    .autoschedule-page {
        padding-left: 0.2rem;
        padding-right: 0.2rem;
    }

    .autoschedule-page .autoschedule-run-status {
        flex-direction: column;
        align-items: flex-start;
    }

    .autoschedule-page .autoschedule-run-status-meta {
        justify-content: flex-start;
    }

    .autoschedule-page .autoschedule-grid-two,
    .autoschedule-page .autoschedule-preferences-grid,
    .autoschedule-page .autoschedule-metrics-grid {
        grid-template-columns: 1fr;
    }

    .autoschedule-page .autoschedule-grid-two-wide {
        grid-template-columns: 1fr;
    }

    .autoschedule-page .autoschedule-wide-field {
        grid-column: auto;
    }

    .autoschedule-page .autoschedule-results-head,
    .autoschedule-page .autoschedule-proposal-head,
    .autoschedule-page .autoschedule-actions,
    .autoschedule-page .autoschedule-mini-preview-note,
    .autoschedule-page .autoschedule-preferences-level-head,
    .autoschedule-page .autoschedule-preferences-panel-summary,
    .autoschedule-page .autoschedule-professors-summary,
    .autoschedule-page .autoschedule-form-section-head,
    .autoschedule-page .autoschedule-setup-head,
    .autoschedule-page .autoschedule-stage-actions,
    .autoschedule-page .autoschedule-stage-header {
        flex-direction: column;
        align-items: stretch;
    }

    .autoschedule-page .autoschedule-form-section-copy {
        max-width: none;
    }

    .autoschedule-page .autoschedule-progress {
        top: -0.3rem;
        padding: 0.75rem;
    }

    .autoschedule-page .autoschedule-progress-head {
        flex-direction: column;
        align-items: stretch;
        margin-bottom: 0.55rem;
    }

    .autoschedule-page .autoschedule-progress-copy {
        max-width: none;
    }

    .autoschedule-page .autoschedule-progress-track {
        grid-template-columns: repeat(5, minmax(150px, 1fr));
    }

    .autoschedule-page .autoschedule-step {
        padding: 0.6rem 0.65rem;
    }

    .autoschedule-page .autoschedule-panel {
        padding: 1rem;
    }

    .autoschedule-page .autoschedule-stage-body {
        padding: 0 0.8rem 0.8rem;
    }

    .autoschedule-page .autoschedule-results-panel,
    .autoschedule-page .autoschedule-proposal,
    .autoschedule-page .autoschedule-empty {
        padding-left: 1rem;
        padding-right: 1rem;
    }

    .autoschedule-page .autoschedule-panel h1 {
        font-size: clamp(1.9rem, 8vw, 2.4rem);
        line-height: 0.98;
    }

    .autoschedule-page .autoschedule-panel,
    .autoschedule-page .autoschedule-results-panel,
    .autoschedule-page .autoschedule-proposal,
    .autoschedule-page .autoschedule-empty {
        border-radius: 1.25rem;
    }

    .autoschedule-page .autoschedule-selected-chip {
        max-width: 100%;
    }

    .autoschedule-page .autoschedule-selected-chip-label {
        max-width: 26vw;
    }

    .autoschedule-page .autoschedule-day-chip-row {
        display: grid;
        grid-template-columns: repeat(5, minmax(0, 1fr));
    }

    .autoschedule-page .autoschedule-professors-summary .btn,
    .autoschedule-page .autoschedule-stage-actions .btn {
        width: 100%;
    }
}

[data-theme="dark"] .autoschedule-page .autoschedule-help-btn {
    background: rgba(139, 182, 255, 0.12);
    border-color: rgba(139, 182, 255, 0.2);
    color: #dbe8ff;
    box-shadow: 0 0.35rem 1rem rgba(8, 10, 31, 0.26);
}

[data-theme="dark"] .autoschedule-page .autoschedule-help-btn:hover,
[data-theme="dark"] .autoschedule-page .autoschedule-help-btn:focus {
    background: rgba(139, 182, 255, 0.18);
    border-color: rgba(139, 182, 255, 0.28);
    color: #ffffff;
}

[data-theme="dark"] .autoschedule-welcome-modal {
    background: #1f245f;
    border-color: rgba(139, 182, 255, 0.16);
    color: rgba(255, 255, 255, 0.92);
}

[data-theme="dark"] .autoschedule-welcome-modal__hero {
    background: linear-gradient(135deg, rgba(139, 182, 255, 0.16) 0%, rgba(139, 182, 255, 0.05) 100%);
    border-bottom-color: rgba(139, 182, 255, 0.12);
}

[data-theme="dark"] .autoschedule-welcome-modal__hero-pattern {
    background-image: radial-gradient(circle at 2px 2px, rgba(173, 198, 255, 0.45) 1px, transparent 0);
}

[data-theme="dark"] .autoschedule-welcome-modal__hero-icon {
    background: rgba(139, 182, 255, 0.12);
    border-color: rgba(139, 182, 255, 0.18);
    color: #dbe8ff;
}

[data-theme="dark"] .autoschedule-welcome-modal__copy,
[data-theme="dark"] .autoschedule-welcome-modal__suggestion p,
[data-theme="dark"] .autoschedule-welcome-feature p,
[data-theme="dark"] .autoschedule-welcome-step p {
    color: rgba(255, 255, 255, 0.72);
}

[data-theme="dark"] .autoschedule-welcome-modal__suggestion {
    background: rgba(139, 182, 255, 0.08);
    border-color: rgba(139, 182, 255, 0.14);
}

[data-theme="dark"] .autoschedule-welcome-modal__suggestion .material-symbols-outlined,
[data-theme="dark"] .autoschedule-welcome-feature .material-symbols-outlined {
    color: #dbe8ff;
}

[data-theme="dark"] .autoschedule-welcome-feature {
    background: rgba(255, 255, 255, 0.04);
    border-color: rgba(255, 255, 255, 0.08);
}

[data-theme="dark"] .autoschedule-welcome-step__index {
    background: rgba(255, 255, 255, 0.06);
    border-color: rgba(255, 255, 255, 0.1);
    color: rgba(255, 255, 255, 0.7);
}

[data-theme="dark"] .autoschedule-welcome-step.is-active .autoschedule-welcome-step__index {
    background: rgba(139, 182, 255, 0.18);
    border-color: rgba(139, 182, 255, 0.24);
    color: #dbe8ff;
}

[data-theme="dark"] .autoschedule-welcome-modal__journey {
    background: rgba(8, 10, 31, 0.34);
    border-color: rgba(139, 182, 255, 0.12);
}

[data-theme="dark"] .autoschedule-welcome-modal__journey-label {
    color: rgba(173, 198, 255, 0.82);
}

[data-theme="dark"] .autoschedule-tour-card {
    background: #1f245f;
    border-color: rgba(255, 255, 255, 0.12);
    color: rgba(255, 255, 255, 0.92);
}

[data-theme="dark"] .autoschedule-tour-card__copy {
    color: rgba(255, 255, 255, 0.72);
}

[data-theme="dark"] .autoschedule-page [data-tour-anchor].is-tour-active {
    box-shadow: 0 0 0 2px rgba(139, 182, 255, 0.24), 0 0 0 10px rgba(15, 23, 42, 0.72), 0 1rem 2rem rgba(0, 0, 0, 0.28);
}

[data-theme="dark"] .autoschedule-page [data-tour-anchor].is-tour-active::after {
    border-color: rgba(139, 182, 255, 0.28);
}

@media (max-width: 991.98px) {
    .autoschedule-welcome-modal__features {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 575.98px) {
    .autoschedule-page .dropdown-select-wrapper,
    .autoschedule-page .dropdown-select-button,
    .autoschedule-page .dropdown-select-menu {
        max-width: 100%;
    }

    .autoschedule-page .dropdown-select-menu {
        inset-inline: 0 !important;
    }

    .autoschedule-welcome-modal__hero,
    .autoschedule-welcome-modal__body,
    .autoschedule-welcome-modal__footer {
        padding-inline: 1rem;
    }

    .autoschedule-welcome-modal__body {
        padding-block: 1.1rem;
    }

    .autoschedule-welcome-modal__start {
        width: 100%;
    }

    .autoschedule-tour-card {
        left: 16px !important;
        right: 16px;
        top: auto !important;
        bottom: 16px;
        max-width: none;
    }

    .autoschedule-tour-card__actions {
        flex-direction: column;
        align-items: stretch;
    }

    .autoschedule-tour-card__actions > div {
        display: grid !important;
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

.autoschedule-page .autoschedule-page-title {
    font-size: clamp(2rem, 3vw, 3rem);
    line-height: 1.02;
    letter-spacing: -0.04em;
}

.autoschedule-page .autoschedule-credit-pill {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 3rem;
    padding: 0.42rem 0.8rem;
    border-radius: 999px;
    background: rgba(59, 116, 255, 0.12);
    border: 1px solid rgba(59, 116, 255, 0.16);
    color: #2658c9;
    font-size: 0.83rem;
    font-weight: 800;
    letter-spacing: 0.01em;
}

.autoschedule-page .autoschedule-credit-pill--free {
    background: rgba(34, 197, 94, 0.12);
    border-color: rgba(34, 197, 94, 0.18);
    color: #15803d;
}

.autoschedule-page .autoschedule-credit-pill--premium {
    background: rgba(217, 119, 6, 0.12);
    border-color: rgba(217, 119, 6, 0.16);
    color: #b45309;
}

.autoschedule-page .autoschedule-credit-pill--emphasis {
    min-width: 4.75rem;
}

.autoschedule-page .autoschedule-credit-summary {
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    gap: 0.2rem;
}

.autoschedule-page .rescue-credit-summary-inline {
    align-items: center;
    justify-content: center;
}

.autoschedule-page .autoschedule-credit-summary-label {
    font-size: 0.72rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: rgba(73, 93, 166, 0.72);
}

.autoschedule-page .autoschedule-credit-summary-value {
    font-size: 1.1rem;
    font-weight: 800;
    color: #21325b;
}

.autoschedule-page .rescue-hero-copy {
    max-width: 62rem;
}

.autoschedule-page.rescue-assistant-page {
    padding-bottom: 0.5rem;
}

.autoschedule-page.rescue-assistant-page > :last-child {
    margin-bottom: 0 !important;
}

.autoschedule-page .rescue-config-grid {
    display: grid;
    grid-template-columns: minmax(18rem, 24rem) minmax(0, 1fr);
    gap: 1.25rem;
    margin-top: 1.5rem;
}

.autoschedule-page .rescue-config-column {
    display: grid;
    gap: 1rem;
}

.autoschedule-page .rescue-config-card {
    padding: 1.25rem;
    border-radius: 1.2rem;
    background: rgba(255, 255, 255, 0.72);
    border: 1px solid rgba(123, 141, 196, 0.18);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.35);
}

.autoschedule-page .rescue-config-label {
    margin-bottom: 0.45rem;
    font-size: 0.74rem;
    font-weight: 800;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: rgba(59, 92, 183, 0.78);
}

.autoschedule-page .rescue-config-title {
    margin: 0;
    font-size: 1.18rem;
    font-weight: 800;
    line-height: 1.2;
    color: #1d2d54;
}

.autoschedule-page .rescue-pricing-stack,
.autoschedule-page .rescue-estimator-list {
    display: grid;
    gap: 0.85rem;
}

.autoschedule-page .rescue-pricing-item,
.autoschedule-page .rescue-estimator-item,
.autoschedule-page .rescue-status-card {
    display: flex;
    justify-content: space-between;
    gap: 1rem;
    align-items: flex-start;
    padding: 0.95rem 1rem;
    border-radius: 1rem;
    background: rgba(82, 109, 194, 0.06);
    border: 1px solid rgba(82, 109, 194, 0.11);
}

.autoschedule-page .rescue-status-list {
    display: grid;
    gap: 0.9rem;
}

.autoschedule-page .rescue-status-copy {
    min-width: 0;
}

.autoschedule-page .rescue-status-actions {
    display: grid;
    gap: 0.6rem;
    min-width: 13rem;
}

.autoschedule-page .rescue-tight-highlights {
    gap: 0.6rem;
}

.autoschedule-page .rescue-estimator-card .btn {
    min-height: 3.45rem;
}

.autoschedule-page .autoschedule-locked-panel {
    padding: 1.2rem;
    border-radius: 1.25rem;
    background: linear-gradient(135deg, rgba(237, 243, 255, 0.9), rgba(246, 248, 255, 0.94));
    border: 1px solid rgba(85, 116, 197, 0.16);
}

.autoschedule-page .autoschedule-locked-panel--secondary {
    background: linear-gradient(135deg, rgba(255, 247, 233, 0.9), rgba(255, 251, 243, 0.95));
    border-color: rgba(217, 119, 6, 0.18);
}

.autoschedule-page .autoschedule-locked-panel-header {
    display: flex;
    justify-content: space-between;
    gap: 1rem;
    align-items: flex-start;
}

.autoschedule-page .autoschedule-locked-mini-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0.85rem;
}

.autoschedule-page .autoschedule-locked-mini-card {
    padding: 0.95rem;
    border-radius: 1rem;
    background: rgba(255, 255, 255, 0.78);
    border: 1px solid rgba(88, 117, 195, 0.12);
}

.autoschedule-page .autoschedule-locked-mini-card--premium {
    border-color: rgba(217, 119, 6, 0.14);
    background: rgba(255, 255, 255, 0.86);
}

.autoschedule-page .autoschedule-locked-mini-header {
    display: flex;
    justify-content: space-between;
    gap: 0.75rem;
    margin-bottom: 0.45rem;
    font-size: 0.72rem;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: rgba(52, 73, 143, 0.72);
}

.autoschedule-page .autoschedule-locked-mini-title {
    font-size: 0.96rem;
    font-weight: 800;
    color: #1e2e59;
}

.autoschedule-page .autoschedule-locked-mini-meta {
    margin-top: 0.3rem;
    font-size: 0.88rem;
    line-height: 1.45;
    color: rgba(37, 49, 92, 0.74);
}

[data-theme="dark"] .autoschedule-page .autoschedule-credit-pill {
    background: rgba(102, 144, 255, 0.18);
    border-color: rgba(132, 170, 255, 0.22);
    color: #dce7ff;
}

[data-theme="dark"] .autoschedule-page .autoschedule-credit-pill--free {
    background: rgba(34, 197, 94, 0.15);
    border-color: rgba(74, 222, 128, 0.18);
    color: #c9f7d7;
}

[data-theme="dark"] .autoschedule-page .autoschedule-credit-pill--premium {
    background: rgba(245, 158, 11, 0.18);
    border-color: rgba(251, 191, 36, 0.2);
    color: #ffe4a8;
}

[data-theme="dark"] .autoschedule-page .autoschedule-credit-summary-label {
    color: rgba(173, 198, 255, 0.7);
}

[data-theme="dark"] .autoschedule-page .autoschedule-credit-summary-value,
[data-theme="dark"] .autoschedule-page .rescue-config-title,
[data-theme="dark"] .autoschedule-page .autoschedule-locked-mini-title {
    color: #f4f7ff;
}

[data-theme="dark"] .autoschedule-page .rescue-config-card,
[data-theme="dark"] .autoschedule-page .autoschedule-locked-mini-card {
    background: rgba(15, 20, 54, 0.72);
    border-color: rgba(126, 148, 222, 0.16);
    box-shadow: none;
}

[data-theme="dark"] .autoschedule-page .rescue-config-label,
[data-theme="dark"] .autoschedule-page .autoschedule-locked-mini-header {
    color: rgba(173, 198, 255, 0.74);
}

[data-theme="dark"] .autoschedule-page .rescue-pricing-item,
[data-theme="dark"] .autoschedule-page .rescue-estimator-item,
[data-theme="dark"] .autoschedule-page .rescue-status-card {
    background: rgba(55, 72, 134, 0.18);
    border-color: rgba(106, 130, 213, 0.16);
}

[data-theme="dark"] .autoschedule-page .autoschedule-locked-panel {
    background: linear-gradient(135deg, rgba(17, 25, 60, 0.92), rgba(13, 18, 48, 0.95));
    border-color: rgba(110, 142, 228, 0.16);
}

[data-theme="dark"] .autoschedule-page .autoschedule-locked-panel--secondary {
    background: linear-gradient(135deg, rgba(46, 30, 6, 0.92), rgba(28, 19, 4, 0.95));
    border-color: rgba(245, 158, 11, 0.16);
}

[data-theme="dark"] .autoschedule-page .autoschedule-locked-mini-meta {
    color: rgba(226, 233, 255, 0.72);
}

@media (max-width: 991.98px) {
    .autoschedule-page .rescue-config-grid {
        grid-template-columns: 1fr;
    }

    .autoschedule-page .autoschedule-locked-mini-grid {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 767.98px) {
    .autoschedule-page .rescue-status-card,
    .autoschedule-page .rescue-pricing-item,
    .autoschedule-page .rescue-estimator-item,
    .autoschedule-page .autoschedule-locked-panel-header {
        flex-direction: column;
    }

    .autoschedule-page .rescue-status-actions {
        min-width: 0;
        width: 100%;
    }

    .autoschedule-page .autoschedule-credit-summary {
        align-items: flex-start;
    }

    .autoschedule-page .rescue-credit-summary-inline {
        align-items: flex-start;
        justify-content: flex-start;
    }
}
