﻿/*
 * ScheduleToQuoteModal.css
 * ========================
 * Layout and custom styles for the STQ modal.  Prefix: stq-
 *
 * Hand-rolled button, table, input, progress-bar, and popover rules have been
 * removed because those elements are now rendered by Telerik UI for Blazor.
 * Telerik-specific overrides (scoped to .stq-* classes) follow the layout rules.
 *
 * Paste into wwwroot/css/ and reference from index.html / _Host.cshtml,
 * or rename to ScheduleToQuoteModal.razor.css for Blazor CSS isolation
 * (keep :root variables in site.css so they are globally available).
 */

/* ── Design tokens ────────────────────────────────────────────────────────── */
:root {
    --stq-bg-card: #ffffff;
    --stq-bg-subtle: #f8fafc;
    --stq-bg-rail: #f6f9fc;
    --stq-bg-row-hover: #f1f5f9;
    --stq-bg-row-selected: #eff6ff;
    --stq-bg-banner-ok: #ecfdf5;
    --stq-bg-banner-warn: #fffbeb;
    --stq-bg-banner-err: #fef2f2;
    --stq-border: #e2e8f0;
    --stq-border-strong: #cbd5e1;
    --stq-text: #0f172a;
    --stq-text-soft: #334155;
    --stq-text-muted: #64748b;
    --stq-text-faint: #94a3b8;
    --stq-primary: #2563eb;
    --stq-primary-hover: #1d4ed8;
    --stq-primary-soft: #dbeafe;
    --stq-success: #16a34a;
    --stq-success-soft: #d1fae5;
    --stq-danger: #dc2626;
    --stq-danger-soft: #fee2e2;
    --stq-warn: #d97706;
    --stq-radius-sm: 4px;
    --stq-radius: 6px;
    --stq-radius-lg: 10px;
    --stq-font: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
    --stq-font-mono: ui-monospace, SFMono-Regular, "SF Mono", Menlo, Consolas, monospace;
}

/* ── TelerikWindow shell overrides ───────────────────────────────────────── */

/*
 * .stq-window scopes all overrides to this modal only, avoiding conflicts
 * with other TelerikWindows in the application.
 */
.stq-window.k-window {
    border-radius: var(--stq-radius-lg);
    box-shadow: 0 24px 80px rgba(15,23,42,.18), 0 1px 4px rgba(15,23,42,.08);
    overflow: hidden;
    font-family: var(--stq-font);
    font-size: 14px;
    color: var(--stq-text);
}

/* Title bar */
.stq-window .k-window-titlebar {
    padding: 14px 20px;
    border-bottom: 1px solid var(--stq-border);
    background: var(--stq-bg-card);
}

/* Content area: remove default Telerik padding — the grid/log panels manage their own */
.stq-window .k-window-content {
    padding: 0;
    overflow: hidden;
    display: flex;
    flex-direction: column;
}

/* Footer bar */
.stq-window .k-window-footer,
.stq-window .k-actions {
    padding: 0;
    border-top: 1px solid var(--stq-border);
    background: var(--stq-bg-subtle);
}

/* Title text + badge */
.stq-window-title {
    font-size: 17px;
    font-weight: 600;
    letter-spacing: -0.01em;
    display: flex;
    align-items: center;
    gap: 10px;
}

.stq-badge {
    font-size: 11px;
    font-weight: 600;
    padding: 2px 8px;
    border-radius: 999px;
    background: var(--stq-primary-soft);
    color: var(--stq-primary);
}

/* ── Modal body layout ───────────────────────────────────────────────────── */
.stq-modal-body {
    flex: 1;
    min-height: 0;
    display: grid;
    grid-template-columns: 320px 1fr;
    overflow: hidden;
    height: 100%;
}

/* ── Modal footer ────────────────────────────────────────────────────────── */
.stq-modal-footer {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 12px 20px;
    gap: 12px;
    width: 100%;
}

.stq-footer-meta {
    color: var(--stq-text-muted);
    font-size: 13px;
}

.stq-footer-actions {
    display: flex;
    gap: 8px;
    align-items: center;
}

/* ── Left rail ───────────────────────────────────────────────────────────── */
.stq-rail {
    background: var(--stq-bg-rail);
    border-right: 1px solid var(--stq-border);
    padding: 18px;
    overflow-y: auto;
    display: flex;
    flex-direction: column;
    gap: 18px;
}

.stq-rail-section {
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.stq-rail-label {
    font-size: 11px;
    font-weight: 600;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: var(--stq-text-muted);
}

/* Destination mode toggle — wraps two TelerikButtons side by side */
.stq-dest-mode {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 6px;
    padding: 3px;
    background: var(--stq-bg-card);
    border: 1px solid var(--stq-border);
    border-radius: var(--stq-radius);
}

    .stq-dest-mode .k-button {
        border-radius: 4px;
        font-size: 13px;
    }

/* Client row */
.stq-client-row {
    display: flex;
    flex-direction: column;
    gap: 4px;
    padding: 10px 12px;
    background: var(--stq-bg-card);
    border: 1px solid var(--stq-border);
    border-radius: var(--stq-radius);
    position: relative;
}

    .stq-client-row .name {
        font-weight: 600;
    }

    .stq-client-row .id {
        color: var(--stq-text-muted);
        font-size: 12px;
    }

    .stq-client-row .change {
        color: var(--stq-primary);
        cursor: pointer;
        font-size: 12px;
        align-self: flex-start;
        margin-top: 2px;
        user-select: none;
    }

        .stq-client-row .change:hover {
            text-decoration: underline;
        }

/* Field label above Telerik inputs */
.stq-field {
    display: flex;
    flex-direction: column;
    gap: 4px;
}

    .stq-field > label {
        font-size: 12px;
        color: var(--stq-text-muted);
    }

/* TelerikTextBox overrides (new quote name) */
.stq-textbox.k-input {
    border-radius: var(--stq-radius);
    font-size: 14px;
}

/* TelerikDropDownList overrides (existing quote picker + family filter) */
.stq-ddl.k-dropdownlist,
.stq-ddl-sm.k-dropdownlist {
    border-radius: var(--stq-radius);
    font-size: 13px;
}

.stq-ddl-sm.k-dropdownlist {
    width: 160px;
}

/* Summary card */
.stq-summary {
    background: var(--stq-bg-card);
    border: 1px solid var(--stq-border);
    border-radius: var(--stq-radius);
    padding: 12px;
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.stq-summary-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
}

    .stq-summary-row .k {
        color: var(--stq-text-muted);
        font-size: 13px;
    }

    .stq-summary-row .v {
        font-weight: 600;
    }

/* Donut */
.stq-donut-wrap {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 8px;
    padding: 8px 0;
}

.stq-donut-cap {
    font-size: 12px;
    color: var(--stq-text-muted);
    text-align: center;
}

/* ── Right pane shared ───────────────────────────────────────────────────── */
.stq-pane {
    display: flex;
    flex-direction: column;
    min-height: 0;
    overflow: hidden;
    height: 100%;
}

/* Toolbar above grids / log */
.stq-toolbar {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 10px 16px;
    border-bottom: 1px solid var(--stq-border);
    background: var(--stq-bg-card);
    flex-wrap: wrap;
    row-gap: 8px;
    flex-shrink: 0;
}

.stq-toolbar-left {
    display: flex;
    align-items: center;
    gap: 8px;
    flex: 1 1 240px;
    min-width: 0;
    flex-wrap: wrap;
    row-gap: 6px;
}

.stq-toolbar-right {
    display: flex;
    align-items: center;
    gap: 8px;
    flex: 0 1 auto;
    flex-wrap: wrap;
    row-gap: 6px;
    margin-left: auto;
}

.stq-toolbar .count {
    font-size: 13px;
    font-weight: 600;
}

    .stq-toolbar .count .muted {
        color: var(--stq-text-muted);
        font-weight: 400;
    }

.stq-link {
    color: var(--stq-primary);
    cursor: pointer;
    font-size: 13px;
    user-select: none;
}

    .stq-link:hover {
        text-decoration: underline;
    }

    .stq-link.disabled {
        color: var(--stq-text-faint);
        cursor: default;
        text-decoration: none;
    }

/* TelerikTextBox search field */
.stq-search-input.k-input {
    border-radius: var(--stq-radius);
    font-size: 13px;
    width: 210px;
}

/* ── TelerikGrid overrides ───────────────────────────────────────────────── */

/*
 * Container that stretches the grid to fill the remaining pane height.
 * The grid itself must have Height="100%" to use virtual scrolling.
 */
.stq-grid-wrap {
    flex: 1;
    min-height: 0;
    overflow: hidden;
}

.stq-grid.k-grid {
    border: 0;
    font-size: 13px;
    font-family: var(--stq-font);
}

/* Header */
.stq-grid .k-grid-header th.k-header {
    background: var(--stq-bg-subtle);
    color: var(--stq-text-muted);
    font-size: 12px;
    font-weight: 600;
    border-color: var(--stq-border);
    padding: 8px 12px;
}

/* Rows */
.stq-grid .k-grid-table tr {
    border-bottom: 1px solid var(--stq-border);
    transition: background 80ms;
}

    .stq-grid .k-grid-table tr:hover td {
        background: var(--stq-bg-row-hover);
    }

    .stq-grid .k-grid-table tr.k-selected td {
        background: var(--stq-bg-row-selected);
    }

.stq-grid .k-grid-table td {
    padding: 9px 12px;
    vertical-align: middle;
    border-color: var(--stq-border);
}

/* Column helpers */
.stq-grid .stq-col-line {
    color: var(--stq-text-muted);
    font-size: 12px;
}

.stq-grid .stq-col-model {
    font-weight: 600;
    font-variant-numeric: tabular-nums;
}

/* Description two-line cells */
.stq-grid .desc-title {
    font-weight: 500;
}

.stq-grid .desc-config {
    font-size: 12px;
    color: var(--stq-text-muted);
    margin-top: 2px;
}

/* Group header rows */
.stq-grid .k-grouping-row td {
    background: var(--stq-bg-subtle);
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.05em;
    text-transform: uppercase;
    color: var(--stq-text-muted);
    border-top: 1px solid var(--stq-border);
}

/* ── TelerikProgressBar overrides ────────────────────────────────────────── */

.stq-progress-bar-telerik.k-progressbar {
    height: 10px;
    border-radius: 999px;
    background: #e5e9f0;
    overflow: hidden;
    width: 100%;
}

.stq-progress-bar-telerik .k-selected {
    background: var(--stq-primary);
    border-radius: 999px;
    position: relative;
    overflow: hidden;
    transition: width 250ms ease-out;
}

    /* Sheen animation on the filled portion */
    .stq-progress-bar-telerik .k-selected::after {
        content: "";
        position: absolute;
        inset: 0;
        background: linear-gradient(90deg, transparent, rgba(255,255,255,.35), transparent);
        animation: stq-sheen 1.4s linear infinite;
    }

@keyframes stq-sheen {
    from {
        transform: translateX(-100%);
    }

    to {
        transform: translateX(100%);
    }
}

/* ── Progress card (wraps TelerikProgressBar) ────────────────────────────── */
.stq-progress-card {
    margin: 14px 16px 0;
    padding: 14px 16px;
    border: 1px solid var(--stq-border);
    border-radius: var(--stq-radius);
    background: var(--stq-bg-card);
    display: flex;
    flex-direction: column;
    gap: 8px;
    flex-shrink: 0;
}

.stq-current-item {
    display: flex;
    align-items: center;
    gap: 10px;
    font-size: 13px;
    flex-wrap: wrap;
}

    .stq-current-item .model {
        font-weight: 600;
    }

    .stq-current-item .desc {
        color: var(--stq-text-muted);
    }

/* ── Log panel ───────────────────────────────────────────────────────────── */
.stq-log-wrap {
    flex: 1;
    min-height: 0;
    margin: 12px 16px 16px;
    display: flex;
    flex-direction: column;
    border: 1px solid var(--stq-border);
    border-radius: var(--stq-radius);
    overflow: hidden;
    background: var(--stq-bg-card);
}

.stq-log-head {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 8px 12px;
    border-bottom: 1px solid var(--stq-border);
    background: var(--stq-bg-subtle);
    font-size: 12px;
    flex-shrink: 0;
}

    .stq-log-head .dot {
        width: 8px;
        height: 8px;
        border-radius: 50%;
        background: var(--stq-primary);
        box-shadow: 0 0 0 4px rgba(37,99,235,.18);
        animation: stq-pulse 1.2s ease-in-out infinite;
        flex-shrink: 0;
    }

@keyframes stq-pulse {
    50% {
        box-shadow: 0 0 0 8px rgba(37,99,235,0);
    }
}

.stq-log-stats {
    display: flex;
    gap: 10px;
    margin-left: auto;
}

.stq-log-body {
    flex: 1;
    min-height: 0;
    overflow-y: auto;
    padding: 10px 14px;
    font-family: var(--stq-font-mono);
    font-size: 12.5px;
    line-height: 1.55;
    font-variant-numeric: tabular-nums;
}

.stq-log-line {
    white-space: pre-wrap;
}

    .stq-log-line.ok {
        color: var(--stq-success);
    }

    .stq-log-line.err {
        color: var(--stq-danger);
    }

    .stq-log-line.info {
        color: var(--stq-text-soft);
    }

    .stq-log-line.dim {
        color: var(--stq-text-faint);
    }

    .stq-log-line.note {
        color: var(--stq-primary);
    }

    .stq-log-line .ts {
        color: var(--stq-text-faint);
        margin-right: 6px;
    }

/* Dark log variant */
.stq-log-wrap.dark {
    background: #0f172a;
    color: #e2e8f0;
    border-color: #1e293b;
}

    .stq-log-wrap.dark .stq-log-head {
        background: #0b1220;
        border-color: #1e293b;
        color: #cbd5e1;
    }

    .stq-log-wrap.dark .stq-log-line.info {
        color: #93c5fd;
    }

    .stq-log-wrap.dark .stq-log-line.ok {
        color: #4ade80;
    }

    .stq-log-wrap.dark .stq-log-line.err {
        color: #fca5a5;
    }

    .stq-log-wrap.dark .stq-log-line.dim {
        color: #64748b;
    }

    .stq-log-wrap.dark .stq-log-line.note {
        color: #93c5fd;
    }

    .stq-log-wrap.dark .stq-log-line .ts {
        color: #475569;
    }

/* ── Complete state banners ──────────────────────────────────────────────── */
.stq-complete-banner {
    margin: 14px 16px 0;
    padding: 14px 16px;
    border: 1px solid var(--stq-success-soft);
    background: var(--stq-bg-banner-ok);
    border-radius: var(--stq-radius);
    display: flex;
    align-items: center;
    gap: 14px;
    flex-shrink: 0;
}

    .stq-complete-banner.has-failures {
        border-color: #fde68a;
        background: var(--stq-bg-banner-warn);
    }

    .stq-complete-banner .icon {
        width: 36px;
        height: 36px;
        border-radius: 50%;
        background: var(--stq-success);
        color: #fff;
        display: flex;
        align-items: center;
        justify-content: center;
        font-weight: 700;
        flex-shrink: 0;
    }

    .stq-complete-banner.has-failures .icon {
        background: var(--stq-warn);
    }

    .stq-complete-banner .text {
        display: flex;
        flex-direction: column;
        gap: 2px;
        flex: 1;
        min-width: 0;
    }

        .stq-complete-banner .text strong {
            font-size: 15px;
        }

        .stq-complete-banner .text .sub {
            color: var(--stq-text-muted);
            font-size: 13px;
        }

.stq-failure-detail {
    margin: 12px 16px 0;
    padding: 12px 14px;
    background: var(--stq-bg-banner-err);
    border: 1px solid var(--stq-danger-soft);
    border-left: 3px solid var(--stq-danger);
    border-radius: var(--stq-radius);
    font-size: 13px;
    color: var(--stq-text);
    flex-shrink: 0;
}

    .stq-failure-detail strong {
        color: var(--stq-danger);
    }

/* Status pills (result table) */
.stq-status-pill {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 2px 8px;
    border-radius: 999px;
    font-size: 12px;
    font-weight: 600;
    white-space: nowrap;
}

    .stq-status-pill.ok {
        background: var(--stq-success-soft);
        color: var(--stq-success);
    }

    .stq-status-pill.err {
        background: var(--stq-danger-soft);
        color: var(--stq-danger);
    }

/* ── TelerikComboBox (client picker) overrides ───────────────────────────── */
.stq-client-picker-wrap {
    margin-top: 4px;
}

.stq-client-combobox.k-combobox {
    width: 100%;
    border-radius: var(--stq-radius);
    font-size: 13px;
}

/* Item template inside the dropdown list */
.stq-client-combobox .stq-popover-item {
    display: flex;
    flex-direction: column;
    gap: 1px;
    padding: 6px 4px;
}

    .stq-client-combobox .stq-popover-item .name {
        font-weight: 500;
    }

    .stq-client-combobox .stq-popover-item .id {
        color: var(--stq-text-muted);
        font-size: 12px;
    }

    .stq-client-combobox .stq-popover-item.current .name::after {
        content: " · current";
        color: var(--stq-primary);
        font-size: 11px;
        font-weight: 500;
    }
