/* Warsaw Stage Academy — design tokens + Syncfusion Material 3 overrides */
:root {
    --wsa-yellow: #f9b036;
    --wsa-yellow-dark: #e09a18;
    --wsa-yellow-soft: #fff8ed;
    --wsa-black: #111111;
    --wsa-white: #ffffff;
    --wsa-gray-50: #f8f9fb;
    --wsa-gray-100: #f1f3f6;
    --wsa-gray-200: #e4e8ee;
    --wsa-gray-400: #9aa3b2;
    --wsa-gray-600: #5c6575;
    --wsa-gray-800: #2b3140;
    --wsa-success-soft: #ecfdf3;
    --wsa-success: #15803d;
    --wsa-info-soft: #eff6ff;
    --wsa-info: #1d4ed8;
    --wsa-danger-soft: #fef2f2;
    --wsa-danger: #b91c1c;
    --wsa-warning-soft: #fffbeb;
    --wsa-warning: #b45309;
    --wsa-radius-sm: 8px;
    --wsa-radius-md: 12px;
    --wsa-radius-lg: 16px;
    --wsa-shadow-sm: 0 1px 2px rgba(17, 17, 17, 0.06);
    --wsa-shadow-md: 0 4px 16px rgba(17, 17, 17, 0.08);
    --wsa-shadow-lg: 0 12px 40px rgba(17, 17, 17, 0.1);
    --wsa-font-display: "Bebas Neue", "Arial Narrow", sans-serif;
    --wsa-font-body: "DM Sans", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
    --wsa-sidebar-width: 260px;
    --wsa-sidebar-collapsed: 76px;
    --wsa-header-height: 64px;

    /* Syncfusion Material 3 — brand primary */
    --color-sf-primary: 249, 176, 54;
    --color-sf-primary-container: 255, 248, 237;
    --color-sf-on-primary: 17, 17, 17;
    --color-sf-on-primary-container: 17, 17, 17;
    --color-sf-surface: 248, 249, 251;
    --color-sf-surface-variant: 241, 243, 246;
}

/* ── Syncfusion: buttons ── */
.e-btn {
    border-radius: var(--wsa-radius-sm) !important;
    font-weight: 600 !important;
    letter-spacing: 0.01em;
    transition: background 0.15s ease, box-shadow 0.15s ease, transform 0.1s ease;
}

.e-btn.e-primary,
.e-css.e-btn.e-primary,
.btn-wsa-primary,
.e-btn.btn-wsa-primary {
    background: linear-gradient(180deg, var(--wsa-yellow) 0%, #f5a623 100%) !important;
    border: 1px solid rgba(17, 17, 17, 0.08) !important;
    color: var(--wsa-black) !important;
    box-shadow: var(--wsa-shadow-sm);
}

.e-btn.e-primary:hover,
.e-css.e-btn.e-primary:hover,
.btn-wsa-primary:hover,
.e-btn.btn-wsa-primary:hover {
    background: linear-gradient(180deg, var(--wsa-yellow-dark) 0%, #d48e12 100%) !important;
    box-shadow: var(--wsa-shadow-md);
}

.e-btn.e-outline,
.e-btn.btn-wsa-outline,
.btn-wsa-outline {
    background: var(--wsa-white) !important;
    border: 1px solid var(--wsa-gray-200) !important;
    color: var(--wsa-gray-800) !important;
}

.e-btn.e-outline:hover,
.e-btn.btn-wsa-outline:hover,
.btn-wsa-outline:hover {
    background: var(--wsa-gray-50) !important;
    border-color: var(--wsa-gray-400) !important;
}

.e-btn.e-flat,
.e-btn.e-flat:hover {
    background: transparent !important;
}

.e-btn.e-danger {
    border-radius: var(--wsa-radius-sm) !important;
}

.e-btn.e-outline.e-danger {
    background: var(--wsa-white) !important;
    border-color: rgba(185, 28, 28, 0.35) !important;
    color: var(--wsa-danger) !important;
}

.e-btn.e-outline.e-danger:hover {
    background: var(--wsa-danger-soft) !important;
    border-color: var(--wsa-danger) !important;
    color: var(--wsa-danger) !important;
}

.e-btn.e-small,
.e-btn.e-small.e-primary {
    padding: 0.25rem 0.65rem !important;
    font-size: 0.8125rem !important;
}

/* Bootstrap btn aliases */
.btn-wsa-primary {
    border-radius: var(--wsa-radius-sm);
    padding: 0.45rem 1rem;
    text-decoration: none;
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
}

.btn-wsa-outline {
    border-radius: var(--wsa-radius-sm);
    padding: 0.45rem 1rem;
    text-decoration: none;
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    background: var(--wsa-white);
    border: 1px solid var(--wsa-gray-200);
    color: var(--wsa-gray-800);
    font-weight: 600;
}

.btn-wsa-outline:hover {
    background: var(--wsa-gray-50);
    color: var(--wsa-gray-800);
}

/* ── Syncfusion: inputs ── */
.e-input-group,
.e-control-wrapper,
.e-float-input,
.e-multi-line-input {
    border-radius: var(--wsa-radius-sm) !important;
}

.e-input-group:not(.e-disabled):hover,
.e-input-group.e-control-wrapper:not(.e-disabled):hover {
    border-color: var(--wsa-gray-400) !important;
}

.e-input-group.e-input-focus,
.e-input-group.e-control-wrapper.e-input-focus {
    box-shadow: 0 0 0 3px rgba(249, 176, 54, 0.25) !important;
}

/* ── Syncfusion: grid ── */
.e-grid {
    border: 1px solid var(--wsa-gray-200) !important;
    border-radius: var(--wsa-radius-md) !important;
    overflow: hidden;
    box-shadow: var(--wsa-shadow-sm);
}

.e-grid .e-gridheader {
    border-bottom: 1px solid var(--wsa-gray-200) !important;
}

.e-grid .e-headercell {
    background: var(--wsa-gray-50) !important;
    color: var(--wsa-gray-800) !important;
    font-weight: 600 !important;
    font-size: 0.8125rem !important;
    text-transform: none !important;
    letter-spacing: 0.01em;
}

.e-grid .e-rowcell {
    font-family: var(--wsa-font-body);
    color: var(--wsa-gray-800);
    font-size: 0.875rem;
}

.e-grid .e-row:hover .e-rowcell {
    background: var(--wsa-yellow-soft) !important;
}

.e-grid .e-pager {
    border-top: 1px solid var(--wsa-gray-200) !important;
    background: var(--wsa-white) !important;
}

/* ── Syncfusion: dialog ── */
.e-dialog {
    border-radius: var(--wsa-radius-lg) !important;
    box-shadow: var(--wsa-shadow-lg) !important;
    border: 1px solid var(--wsa-gray-200) !important;
    overflow: hidden;
}

.e-dialog .e-dlg-header-content {
    background: var(--wsa-white) !important;
    border-bottom: 1px solid var(--wsa-gray-200) !important;
    padding: 1rem 1.25rem !important;
}

.e-dialog .e-dlg-header {
    font-weight: 700 !important;
    font-size: 1.05rem !important;
    color: var(--wsa-black) !important;
}

.e-dialog .e-dlg-content {
    padding: 1.25rem !important;
}

.e-dialog .e-footer-content {
    border-top: 1px solid var(--wsa-gray-200) !important;
    padding: 0.85rem 1.25rem !important;
    background: var(--wsa-gray-50) !important;
}

.wsa-dialog-footer {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    align-items: center;
    gap: 0.75rem;
    width: 100%;
}

.wsa-dialog-footer--stacked {
    flex-direction: column;
    align-items: stretch;
    gap: 0.65rem;
}

.wsa-dialog-footer-row {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    align-items: center;
}

.wsa-dialog-footer-row--primary {
    width: 100%;
}

.wsa-dialog-btn-full {
    width: 100%;
}

.wsa-dialog-footer-start,
.wsa-dialog-footer-end {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    align-items: center;
}

.wsa-dialog-footer-end {
    margin-left: auto;
}

@media (max-width: 520px) {
    .wsa-dialog-footer:not(.wsa-dialog-footer--stacked) {
        flex-direction: column;
        align-items: stretch;
    }

    .wsa-dialog-footer-start,
    .wsa-dialog-footer-end {
        width: 100%;
        justify-content: stretch;
    }

    .wsa-dialog-footer-end {
        margin-left: 0;
    }

    .wsa-dialog-footer-end .e-btn,
    .wsa-dialog-footer-start .e-btn {
        flex: 1 1 auto;
    }
}

/* ── Syncfusion: tabs ── */
.e-tab .e-tab-header {
    background: transparent !important;
    border-bottom: 1px solid var(--wsa-gray-200) !important;
}

.e-tab .e-tab-header .e-toolbar-item.e-active .e-tab-text {
    color: var(--wsa-black) !important;
    font-weight: 700 !important;
}

.e-tab .e-tab-header .e-indicator {
    background: var(--wsa-yellow) !important;
    height: 3px !important;
    border-radius: 3px 3px 0 0;
}

.e-tab .e-tab-header .e-toolbar-item .e-tab-text {
    color: var(--wsa-gray-600) !important;
    font-weight: 600;
    text-transform: none;
}

/* ── Syncfusion: schedule ── */
.e-schedule {
    border-radius: var(--wsa-radius-md) !important;
    border: 1px solid var(--wsa-gray-200) !important;
    overflow: hidden;
    box-shadow: var(--wsa-shadow-sm);
}

.e-schedule .e-appointment {
    border-radius: 6px !important;
    color: #fff !important;
    font-weight: 600;
}

.wsa-schedule-legend-chip {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    padding: 0.25rem 0.65rem;
    border-radius: 999px;
    background: var(--wsa-white);
    border: 1px solid var(--wsa-gray-200);
    font-size: 0.8125rem;
    font-weight: 600;
    color: var(--wsa-gray-800);
    box-shadow: var(--wsa-shadow-sm);
}

.wsa-schedule-legend-chip::before {
    content: "";
    width: 0.55rem;
    height: 0.55rem;
    border-radius: 50%;
    background: var(--chip-color);
}

/* ── Typography ── */
.wsa-page-title {
    font-family: var(--wsa-font-body);
    font-size: 1.75rem;
    font-weight: 700;
    letter-spacing: -0.02em;
    color: var(--wsa-black);
    margin: 0;
    line-height: 1.2;
}

.wsa-page-lead {
    color: var(--wsa-gray-600);
    margin: 0.35rem 0 0;
    font-size: 0.9375rem;
    line-height: 1.5;
    max-width: 60ch;
}

.wsa-card-title {
    font-size: 1.05rem;
    font-weight: 700;
    margin: 0;
    color: var(--wsa-black);
}

.wsa-card-subtitle {
    margin: 0.25rem 0 0;
    font-size: 0.875rem;
    color: var(--wsa-gray-600);
}

/* Admin / section nav (Bootstrap pills — modernized) */
.admin-section-nav .nav-link,
.nav-tabs .nav-link {
    border-radius: var(--wsa-radius-sm) !important;
    font-weight: 600;
    font-size: 0.875rem;
    color: var(--wsa-gray-600);
    border: 1px solid transparent;
    padding: 0.45rem 0.85rem;
}

.admin-section-nav .nav-link.active,
.nav-tabs .nav-link.active {
    background: var(--wsa-yellow-soft) !important;
    color: var(--wsa-black) !important;
    border-color: rgba(249, 176, 54, 0.35) !important;
}

.nav-tabs {
    border-bottom: 1px solid var(--wsa-gray-200) !important;
    gap: 0.25rem;
}

.nav-tabs .nav-link:hover {
    border-color: var(--wsa-gray-200);
    color: var(--wsa-black);
}

/* Bootstrap alerts — softer */
.alert {
    border-radius: var(--wsa-radius-sm);
    border-width: 1px;
    font-size: 0.875rem;
}

.alert-success {
    background: var(--wsa-success-soft);
    border-color: rgba(21, 128, 61, 0.2);
    color: var(--wsa-success);
}

.alert-danger {
    background: var(--wsa-danger-soft);
    border-color: rgba(185, 28, 28, 0.2);
    color: var(--wsa-danger);
}

.alert-info {
    background: var(--wsa-info-soft);
    border-color: rgba(29, 78, 216, 0.2);
    color: var(--wsa-info);
}

.form-label {
    font-size: 0.8125rem;
    font-weight: 600;
    color: var(--wsa-gray-800);
    margin-bottom: 0.35rem;
}

.text-muted {
    color: var(--wsa-gray-600) !important;
}

.border.rounded.p-2.bg-light {
    background: var(--wsa-gray-50) !important;
    border-color: var(--wsa-gray-200) !important;
    border-radius: var(--wsa-radius-sm) !important;
}

.wsa-email-preview-panel {
    border: 1px solid var(--wsa-gray-200);
    border-radius: var(--wsa-radius-md);
    overflow: hidden;
    background: var(--wsa-gray-50);
    min-height: 420px;
}

.wsa-email-preview-panel__header {
    display: flex;
    flex-direction: column;
    gap: 0.25rem;
    padding: 0.75rem 1rem;
    background: var(--wsa-white);
    border-bottom: 1px solid var(--wsa-gray-200);
    font-size: 0.8125rem;
    font-weight: 600;
    color: var(--wsa-gray-800);
}

.wsa-email-preview-panel__frame {
    display: block;
    width: 100%;
    min-height: 480px;
    border: 0;
    background: var(--wsa-gray-50);
}

.wsa-color-field {
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

.wsa-color-field__picker {
    width: 2.5rem;
    height: 2.5rem;
    padding: 0.15rem;
    border: 1px solid var(--wsa-gray-200);
    border-radius: var(--wsa-radius-sm);
    background: var(--wsa-white);
    cursor: pointer;
}

.wsa-color-field__text {
    flex: 1;
    min-width: 0;
    font-family: ui-monospace, SFMono-Regular, Menlo, monospace;
}
