/* Redesign module: Clinic daily operations */

.k-daily-ops-page {
    width: min(1180px, 100%);
    margin: 0 auto;
}

.k-daily-ops-header {
    margin-bottom: 12px;
}

.k-daily-op-nav {
    display: grid;
    grid-template-columns: repeat(5, minmax(0, 1fr));
    gap: 10px;
    margin-bottom: 20px;
}

.k-daily-op-nav .nav-op {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    min-height: 44px;
    font-weight: 700;
}

.k-daily-op-nav .nav-op .material-icons {
    font-size: 1.05rem;
}

.k-daily-op-nav .nav-op:hover {
    transform: translateY(-1px);
}

.k-stepper {
    display: flex;
    gap: 6px;
    margin-bottom: 16px;
}

.k-step-dot {
    height: 8px;
    flex: 1;
    border-radius: 999px;
    background: var(--border-subtle);
    transition: all 0.2s ease;
}

.k-step-dot.active {
    background: var(--accent-primary);
    box-shadow: var(--shadow-glow);
}

.k-step-dot.done {
    background: var(--accent-primary);
    opacity: 0.5;
}

.k-daily-max-800 {
    max-width: 800px;
    margin: 0 auto;
}

.k-daily-grid-two {
    display: grid;
    grid-template-columns: 1.2fr 0.8fr;
    gap: 20px;
}

.k-daily-grid-single {
    display: grid;
    grid-template-columns: 1fr;
    gap: 20px;
}

.k-daily-grid-two-tight {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px;
}

.k-daily-title {
    margin: 0 0 18px;
    display: flex;
    align-items: center;
    gap: 8px;
}

.k-daily-title-cyan {
    color: var(--accent-primary);
}

.k-daily-title-red {
    color: #ef4444;
}

.k-daily-row {
    margin-bottom: 14px;
}

.k-daily-inline-top {
    display: flex;
    gap: 10px;
    align-items: flex-start;
}

.k-daily-inline-top > .k-grow {
    flex: 1;
}

.k-daily-search-btn {
    min-height: 40px;
    min-width: 44px;
    padding: 0 12px;
}

.k-daily-mt-10 {
    margin-top: 10px;
}

.k-daily-mt-15 {
    margin-top: 15px;
}

.k-daily-mt-20 {
    margin-top: 20px;
}

.k-daily-muted-box {
    margin-top: 20px;
    padding: 15px;
    border-radius: 10px;
    border: 1px solid var(--border-subtle);
    background: var(--bg-surface-soft);
}

.k-daily-toggle-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 10px;
}

.k-daily-toggle-left {
    display: inline-flex;
    align-items: center;
    gap: 10px;
}

.k-daily-toggle-label {
    color: var(--text-primary);
}

.k-daily-amount-input {
    font-size: 1.4rem;
    font-weight: 700;
}

.k-daily-actions-block {
    margin-top: 15px;
}

.k-daily-locked-panel {
    padding: 40px;
    text-align: center;
    border: 1px dashed var(--border-medium);
    border-radius: 14px;
    opacity: 0.72;
}

.k-daily-lock-icon {
    font-size: 3rem;
    color: var(--text-secondary);
}

.k-daily-lock-text {
    margin-top: 10px;
    color: var(--text-secondary);
}

.k-daily-summary-card {
    padding: 20px;
}

.k-daily-summary-head {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 10px;
}

.k-daily-summary-name {
    font-weight: 700;
}

.k-daily-summary-rif {
    color: var(--text-secondary);
}

.k-daily-summary-total {
    font-weight: 700;
    font-size: 1.18rem;
    color: var(--accent-primary);
}

.k-daily-dashed-placeholder {
    margin-top: 20px;
    border: 1px dashed var(--border-medium);
    border-radius: 10px;
    padding: 20px;
    text-align: center;
    color: var(--text-secondary);
}

.k-daily-spec-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 10px;
    border-bottom: 1px solid var(--border-subtle);
    padding: 8px 0;
}

.k-daily-remove-btn {
    border: 0;
    background: transparent;
    color: #ef4444;
    cursor: pointer;
    font-size: 0.9rem;
}

.k-daily-spec-input-row,
.k-daily-payment-input-row {
    display: flex;
    gap: 8px;
    margin-bottom: 15px;
    flex-wrap: wrap;
}

.k-daily-spec-input-row .form-control,
.k-daily-payment-input-row .form-control {
    flex: 1;
    min-width: 140px;
}

.k-daily-spec-percent {
    max-width: 90px;
}

.k-daily-payment-method {
    max-width: 190px;
}

.k-daily-payment-bank,
.k-daily-payment-amount {
    max-width: 150px;
}

.k-daily-payment-list {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin-bottom: 20px;
}

.k-daily-payment-chip {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    padding: 8px 10px;
    border-radius: 12px;
    border: 1px solid var(--border-subtle);
    background: var(--bg-surface-soft);
}

.k-daily-payment-chip-method {
    font-weight: 700;
}

.k-daily-payment-chip-method.is-cashea {
    color: #f59e0b;
}

.k-daily-payment-chip-method:not(.is-cashea) {
    color: #22c55e;
}

.k-daily-calc-box {
    border-radius: 12px;
    padding: 14px;
    border: 1px solid var(--border-medium);
    background: var(--bg-surface-soft);
}

.k-daily-calc-row {
    display: flex;
    justify-content: space-between;
    gap: 12px;
}

.k-daily-calc-row + .k-daily-calc-row {
    margin-top: 6px;
}

.k-daily-calc-row.is-paid {
    color: var(--accent-primary);
}

.k-daily-calc-row.is-remaining {
    color: #ef4444;
    font-weight: 700;
    font-size: 1.08rem;
    border-top: 1px solid var(--border-subtle);
    padding-top: 6px;
}

.k-daily-submit-xl {
    margin-top: 20px;
    min-height: 52px;
    font-size: 1.04rem;
}

.k-daily-prefill-banner {
    margin-bottom: 12px;
    padding: 8px 10px;
    border-radius: 8px;
    border: 1px solid rgba(0, 229, 255, 0.26);
    background: rgba(0, 229, 255, 0.08);
    color: #8fe8ff;
    font-size: 0.85rem;
}

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

.k-daily-line-list {
    margin-top: 12px;
}

.k-daily-line-item {
    display: flex;
    justify-content: space-between;
    gap: 12px;
    border-bottom: 1px solid var(--border-subtle);
    padding: 10px 0;
}

.k-daily-metrics-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 10px;
    margin-bottom: 20px;
}

.k-daily-metric-card {
    border: 1px solid var(--border-subtle);
    border-radius: 12px;
    padding: 10px;
    background: var(--bg-surface-soft);
}

.k-daily-metric-caption {
    font-size: 0.8rem;
    color: var(--text-secondary);
}

.k-daily-metric-value {
    font-size: 1.2rem;
    font-weight: 700;
}

.k-daily-metric-card.is-expense {
    border-color: rgba(239, 68, 68, 0.35);
}

.k-daily-metric-card.is-expense .k-daily-metric-caption,
.k-daily-metric-card.is-expense .k-daily-metric-value {
    color: #ef4444;
}

.k-daily-metric-card.is-net {
    border-color: rgba(0, 229, 255, 0.35);
}

.k-daily-metric-card.is-net .k-daily-metric-caption,
.k-daily-metric-card.is-net .k-daily-metric-value {
    color: var(--accent-primary);
}

.k-daily-card-pad-20 {
    padding: 20px;
}

@media (max-width: 1200px) {
    .k-daily-op-nav {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }

    .k-daily-grid-two {
        grid-template-columns: 1fr;
    }

    .k-daily-metrics-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 820px) {
    .k-daily-op-nav {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .k-daily-grid-two-tight,
    .k-daily-account-grid {
        grid-template-columns: 1fr;
    }

    .k-daily-metrics-grid {
        grid-template-columns: 1fr;
    }
}

/* Clinical income redesign (new_op only) */
.k-ci-wrap {
    display: grid;
    gap: 14px;
}

.k-ci-stepper {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 8px;
}

.k-ci-step-btn {
    min-height: 42px;
    border: 1px solid var(--border-subtle);
    background: var(--bg-surface-soft);
    color: var(--text-secondary);
    border-radius: 999px;
    font-weight: 700;
    cursor: pointer;
}

.k-ci-step-btn.is-active {
    color: #fff;
    border-color: rgba(0, 168, 255, 0.5);
    background: linear-gradient(120deg, #1d4ed8, #0ea5e9);
}

.k-ci-step-hint {
    color: var(--text-secondary);
    font-size: 0.88rem;
}

.k-ci-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 16px;
}

.k-ci-grid.k-ci-focus-right {
    grid-template-columns: minmax(300px, 0.78fr) minmax(420px, 1.22fr);
}

.k-ci-card {
    padding: 16px;
}

.k-ci-card .form-control {
    min-height: 44px;
}

.k-ci-card .k-split-input-group {
    height: 44px;
}

.k-ci-card.is-locked {
    opacity: 0.86;
    pointer-events: none;
    position: relative;
}

.k-ci-card.is-locked::after {
    content: "";
    position: absolute;
    inset: 0;
    border-radius: 14px;
    background: linear-gradient(180deg, rgba(13, 24, 41, 0.02), rgba(13, 24, 41, 0.16));
}

.k-ci-card.is-subdued {
    opacity: 0.72;
}

.k-ci-title-row {
    display: flex;
    justify-content: space-between;
    gap: 10px;
    align-items: center;
    margin-bottom: 12px;
}

.k-ci-title {
    margin: 0;
}

.k-ci-id-fieldset {
    border: 0;
    padding: 0;
    margin: 0;
    min-width: 0;
}

.k-ci-id-fieldset:disabled {
    opacity: 0.88;
}

.k-ci-rif-row {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-bottom: 12px;
}

.k-ci-grow {
    flex: 1;
}

.k-ci-search-btn {
    min-height: 40px;
    min-width: 90px;
}

.k-ci-3col {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 10px;
}

.k-ci-contact-row {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
    gap: 10px;
}

.k-ci-contact-name {
    min-width: 0;
}

.k-ci-contact-email {
    min-width: 0;
}

.k-ci-phone-amount-row {
    margin-top: 10px;
    display: grid;
    grid-template-columns: minmax(0, 1.35fr) minmax(0, 0.65fr);
    gap: 10px;
}

.k-ci-contact-phone,
.k-ci-total-col {
    min-width: 0;
}

.k-ci-desc-row {
    margin-top: 10px;
}

.k-ci-mt-16 {
    margin-top: 16px;
}

.k-ci-spec-add-row {
    display: grid;
    grid-template-columns: 1fr 130px 46px;
    gap: 8px;
    margin-bottom: 10px;
}

.k-ci-pct-input {
    text-align: right;
}

.k-ci-money-field {
    position: relative;
}

.k-ci-money-prefix {
    position: absolute;
    left: 12px;
    top: 50%;
    transform: translateY(-50%);
    padding: 2px 8px;
    border: 1px solid var(--border-subtle);
    border-radius: 999px;
    background: rgba(59, 130, 246, 0.1);
    color: var(--text-primary);
    font-size: 0.78rem;
    font-weight: 700;
    line-height: 1;
    pointer-events: none;
}

.k-ci-money-prefix.is-switchable {
    pointer-events: auto;
    cursor: pointer;
}

.k-ci-amount-input {
    padding-left: 66px;
    text-align: right;
    font-variant-numeric: tabular-nums;
    font-weight: 700;
    letter-spacing: 0.02em;
}

.k-ci-amount-input::-webkit-outer-spin-button,
.k-ci-amount-input::-webkit-inner-spin-button {
    -webkit-appearance: none;
    margin: 0;
}

.k-ci-amount-input[type=number] {
    -moz-appearance: textfield;
}

.k-ci-spec-pill {
    display: flex;
    justify-content: space-between;
    gap: 10px;
    align-items: center;
    border: 1px solid var(--border-subtle);
    border-radius: 10px;
    padding: 8px 10px;
    background: var(--bg-surface-soft);
}

.k-ci-spec-pill + .k-ci-spec-pill {
    margin-top: 8px;
}

.k-ci-spec-pill-name {
    font-weight: 700;
}

.k-ci-spec-pill-sub {
    color: var(--text-secondary);
    font-size: 0.85rem;
}

.k-ci-spec-pill-actions {
    display: inline-flex;
    gap: 8px;
    align-items: center;
}

.k-ci-pct-inline {
    max-width: 106px;
    text-align: right;
}

.k-ci-icon-btn {
    border: 1px solid var(--border-subtle);
    border-radius: 8px;
    min-width: 32px;
    height: 32px;
    background: transparent;
    cursor: pointer;
}

.k-ci-icon-btn-danger {
    color: #ef4444;
    border-color: rgba(239, 68, 68, 0.35);
}

.k-ci-toggle-row {
    margin-top: 14px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    flex-wrap: wrap;
}

.k-ci-toggle-label {
    font-weight: 700;
}

.k-ci-toggle-item {
    display: inline-flex;
    align-items: center;
    gap: 8px;
}

.k-ci-step-actions {
    margin-top: 16px;
    display: flex;
    justify-content: flex-end;
    gap: 8px;
}

.k-ci-mt-10 {
    margin-top: 10px;
}

.k-ci-subtitle {
    margin-top: 12px;
    margin-bottom: 8px;
    font-weight: 700;
}

.k-ci-summary-title-row {
    display: flex;
    align-items: baseline;
    justify-content: space-between;
    gap: 10px;
    margin-bottom: 8px;
}

.k-ci-subtitle-inline {
    margin: 0;
}

.k-ci-table-wrap {
    border: 1px solid var(--border-subtle);
    border-radius: 10px;
    overflow: hidden;
    background: var(--bg-surface-soft);
}

.k-ci-table {
    width: 100%;
    border-collapse: collapse;
    font-size: 0.9rem;
}

.k-ci-table thead th {
    text-align: left;
    background: rgba(59, 130, 246, 0.12);
    color: var(--text-primary);
    padding: 8px;
}

.k-ci-table tbody td {
    border-top: 1px solid var(--border-subtle);
    padding: 8px;
}

.k-ci-table.is-compact th:nth-child(2),
.k-ci-table.is-compact td:nth-child(2) {
    width: 72px;
    text-align: center;
}

.k-ci-table.is-compact th:nth-child(3),
.k-ci-table.is-compact td:nth-child(3) {
    text-align: right;
}

.k-ci-table-empty {
    text-align: center;
    color: var(--text-secondary);
}

.k-ci-clinic-row {
    display: flex;
    justify-content: space-between;
    gap: 8px;
    border-top: 1px solid var(--border-subtle);
    padding: 8px;
    font-weight: 700;
}

.k-ci-clinic-row.is-compact {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 72px minmax(0, 1fr);
    align-items: center;
    gap: 0;
}

.k-ci-clinic-row.is-compact span:first-child {
    grid-column: 1 / 2;
}

.k-ci-clinic-row.is-compact span:last-child {
    grid-column: 3 / 4;
    text-align: right;
}

.k-ci-green {
    color: #16a34a;
    font-weight: 700;
}

.k-ci-method-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 8px;
}

.k-ci-method-btn {
    min-height: 42px;
    border: 1px solid var(--border-subtle);
    border-radius: 10px;
    background: var(--bg-surface-soft);
    cursor: pointer;
    font-weight: 700;
    color: var(--text-primary);
}

.k-ci-method-btn.is-active {
    border-color: rgba(14, 165, 233, 0.8);
    box-shadow: 0 0 0 1px rgba(14, 165, 233, 0.35) inset;
}

.k-ci-pay-editor {
    margin-top: 10px;
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 8px;
    align-items: end;
}

.k-ci-pay-editor-action {
    display: flex;
    justify-content: flex-end;
    grid-column: 1 / -1;
}

.k-ci-pay-editor-optional {
    grid-column: 1 / -1;
}

.k-ci-pay-line {
    margin-top: 8px;
    display: flex;
    justify-content: space-between;
    gap: 10px;
    align-items: center;
    border: 1px solid var(--border-subtle);
    border-radius: 10px;
    padding: 8px 10px;
    background: var(--bg-surface-soft);
}

.k-ci-pay-line-main {
    font-weight: 700;
}

.k-ci-pay-line-sub {
    color: var(--text-secondary);
    font-size: 0.84rem;
}

.k-ci-calc-box {
    margin-top: 12px;
    border: 1px solid var(--border-subtle);
    border-radius: 10px;
    padding: 10px;
    background: var(--bg-surface-soft);
}

.k-ci-calc-row {
    display: flex;
    justify-content: space-between;
    gap: 8px;
}

.k-ci-calc-row + .k-ci-calc-row {
    margin-top: 6px;
}

.k-ci-calc-diff {
    border-top: 1px solid var(--border-subtle);
    padding-top: 8px;
}

.k-ci-calc-box .k-ci-calc-diff:first-child {
    border-top: 0;
    padding-top: 0;
}

.k-ci-diff-ok {
    color: #16a34a;
}

.k-ci-diff-bad {
    color: #ef4444;
}

.k-ci-warn {
    margin-top: 8px;
    color: #ef4444;
    font-size: 0.85rem;
    font-weight: 700;
}

.k-ci-empty {
    border: 1px dashed var(--border-medium);
    border-radius: 10px;
    padding: 10px;
    color: var(--text-secondary);
}

.k-ci-process-btn {
    margin-top: 12px;
    min-height: 46px;
}

@media (max-width: 1120px) {
    .k-ci-grid {
        grid-template-columns: 1fr;
    }

    .k-ci-grid.k-ci-focus-right {
        grid-template-columns: 1fr;
    }

    .k-ci-contact-row {
        grid-template-columns: 1fr;
    }

    .k-ci-3col {
        grid-template-columns: 1fr 1fr;
    }
}

@media (max-width: 820px) {
    .k-ci-stepper {
        grid-template-columns: 1fr;
    }

    .k-ci-3col,
    .k-ci-contact-row,
    .k-ci-phone-amount-row,
    .k-ci-spec-add-row,
    .k-ci-pay-editor,
    .k-ci-method-grid {
        grid-template-columns: 1fr;
    }

    .k-ci-summary-title-row {
        flex-direction: column;
        align-items: flex-start;
        gap: 2px;
    }

    .k-ci-toggle-row {
        flex-direction: column;
        align-items: flex-start;
        gap: 10px;
    }
}
