/**
 * Ditio Modern Design System - Legacy Bootstrap Override
 *
 * This stylesheet modernizes Bootstrap 3 components to match the Ditio web-ui design system.
 * It should be included AFTER bootstrap.css and ditio.css
 *
 * IMPORTANT: Styles only apply when body has class "ditio-modern-enabled"
 * Toggle via localStorage key "ditio-modern-style-enabled"
 */

/* ==========================================================================
   CSS Variables (always available)
   ========================================================================== */

:root {
    /* Ditio Design System Colors */
    --ditio-primary-600: #017eff;
    --ditio-sand-100: #fdfdfc;
    --ditio-sand-200: #f9f9f8;
    --ditio-sand-300: #f3f3f2;
    --ditio-sand-400: #eeeeec;
    --ditio-sand-500: #e9e9e6;
    --ditio-sand-600: #e3e3e0;
    --ditio-sand-700: #dbdbd7;
    --ditio-sand-800: #c8c7c1;
    --ditio-sand-900: #90908c;
    --ditio-sand-1000: #868682;
    --ditio-sand-1100: #706f6c;
    --ditio-sand-1200: #1b1b18;

    --ditio-red-800: #ea555a;
    --ditio-red-1000: #cd2b31;
    --ditio-green-700: #46a758;

    /* Input height */
    --ditio-input-height: 2.5rem;

    /* Border radius */
    --ditio-radius-sm: 0.125rem;
    --ditio-radius-md: 0.25rem;

    /* Typography */
    --ditio-body-xs: 0.875rem;
    --ditio-label-xs: 0.875rem;
    --ditio-label-xxs: 0.75rem;
}

/* ==========================================================================
   Modern Style Toggle Banner
   ========================================================================== */

.ditio-modern-toggle-banner {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 12px 16px;
    background-color: var(--ditio-sand-200);
    border: 1px solid var(--ditio-sand-400);
    font-size: 14px;
    border-radius: 6px;
    margin-bottom: 15px;
}

.ditio-modern-toggle-banner i.fa-magic {
    color: var(--ditio-primary-600);
    font-size: 16px;
}

.ditio-modern-toggle-banner .toggle-label {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    margin: 0;
    color: var(--ditio-sand-1200);
    font-weight: 500;
    cursor: pointer;
    font-family: 'Aeonik', sans-serif;
}

.ditio-modern-toggle-banner .toggle-label-text {
    user-select: none;
}

/* Hide the actual checkbox */
.ditio-modern-toggle-banner input[type="checkbox"] {
    position: absolute;
    opacity: 0;
    width: 0;
    height: 0;
    pointer-events: none;
}

/* Ditio Switch Track */
.ditio-modern-toggle-banner .ditio-switch {
    position: relative;
    display: inline-block;
    width: 40px;
    height: 20px;
    background-color: var(--ditio-sand-600);
    border-radius: 9999px;
    cursor: pointer;
    transition: background-color 0.15s ease;
    flex-shrink: 0;
}

.ditio-modern-toggle-banner .ditio-switch:hover {
    background-color: var(--ditio-sand-700);
}

/* Ditio Switch Thumb */
.ditio-modern-toggle-banner .ditio-switch::after {
    content: '';
    position: absolute;
    top: 2px;
    left: 2px;
    width: 16px;
    height: 16px;
    background-color: var(--ditio-sand-100);
    border-radius: 9999px;
    transition: transform 0.15s ease;
    box-shadow: 0 1px 2px rgba(0, 0, 0, 0.1);
}

/* Checked state - track */
.ditio-modern-toggle-banner input[type="checkbox"]:checked + .ditio-switch {
    background-color: var(--ditio-primary-600);
}

.ditio-modern-toggle-banner input[type="checkbox"]:checked + .ditio-switch:hover {
    background-color: #0165cc;
}

/* Checked state - thumb */
.ditio-modern-toggle-banner input[type="checkbox"]:checked + .ditio-switch::after {
    transform: translateX(20px);
}

/* Focus state */
.ditio-modern-toggle-banner input[type="checkbox"]:focus-visible + .ditio-switch {
    outline: 2px solid var(--ditio-primary-600);
    outline-offset: 2px;
}

.ditio-modern-toggle-banner .toggle-text {
    color: var(--ditio-sand-1000);
    font-size: 13px;
}

/* ==========================================================================
   All styles below only apply when .ditio-modern-enabled
   ========================================================================== */

/* ==========================================================================
   Buttons
   ========================================================================== */

/* Base button styles */
.ditio-modern-enabled .btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    min-height: 2rem;
    padding: 0.375rem 0.75rem;
    font-family: 'Aeonik', sans-serif;
    font-size: var(--ditio-label-xs);
    font-weight: 500;
    line-height: 1;
    text-decoration: none;
    border: none;
    border-radius: var(--ditio-radius-sm);
    cursor: pointer;
    transition: background-color 0.15s ease, box-shadow 0.15s ease;
    outline: none;
}

.ditio-modern-enabled .btn:focus,
.ditio-modern-enabled .btn:focus-visible {
    outline: none;
    box-shadow: none;
}

/* Preserve Bootstrap 3 btn-group-justified table layout */
.ditio-modern-enabled .btn-group-justified > .btn,
.ditio-modern-enabled .btn-group-justified > .btn-group > .btn {
    display: table-cell;
    width: 1%;
}

/* Primary button - dark background (Ditio primary style) */
.ditio-modern-enabled .btn-primary {
    background-color: var(--ditio-sand-1200);
    color: var(--ditio-sand-100);
    border: none;
}

.ditio-modern-enabled .btn-primary:hover,
.ditio-modern-enabled .btn-primary:focus {
    background-color: var(--ditio-sand-1100);
    color: var(--ditio-sand-100);
}

.ditio-modern-enabled .btn-primary:active,
.ditio-modern-enabled .btn-primary.active {
    background-color: var(--ditio-sand-1000);
    color: var(--ditio-sand-100);
}

.ditio-modern-enabled .btn-primary:disabled,
.ditio-modern-enabled .btn-primary.disabled {
    background-color: var(--ditio-sand-1200);
    opacity: 0.4;
    cursor: not-allowed;
}

/* Default/Secondary button - outline style */
.ditio-modern-enabled .btn-default {
    background-color: var(--ditio-sand-100);
    color: var(--ditio-sand-1200);
    border: 1px solid var(--ditio-sand-600);
}

.ditio-modern-enabled .btn-default:hover,
.ditio-modern-enabled .btn-default:focus {
    background-color: var(--ditio-sand-300);
    color: var(--ditio-sand-1200);
}

.ditio-modern-enabled .btn-default:active,
.ditio-modern-enabled .btn-default.active {
    background-color: var(--ditio-sand-400);
    color: var(--ditio-sand-1200);
}

/* Info button - azure/primary blue */
.ditio-modern-enabled .btn-info {
    background-color: var(--ditio-primary-600);
    color: var(--ditio-sand-100);
    border: none;
}

.ditio-modern-enabled .btn-info:hover,
.ditio-modern-enabled .btn-info:focus {
    background-color: #0165cc;
    color: var(--ditio-sand-100);
}

/* Danger button */
.ditio-modern-enabled .btn-danger {
    background-color: var(--ditio-red-1000);
    color: var(--ditio-sand-100);
    border: none;
}

.ditio-modern-enabled .btn-danger:hover,
.ditio-modern-enabled .btn-danger:focus {
    background-color: var(--ditio-red-800);
    color: var(--ditio-sand-100);
}

/* Success button */
.ditio-modern-enabled .btn-success {
    background-color: var(--ditio-green-700);
    color: var(--ditio-sand-100);
    border: none;
}

.ditio-modern-enabled .btn-success:hover,
.ditio-modern-enabled .btn-success:focus {
    background-color: #3d9a50;
    color: var(--ditio-sand-100);
}

/* Link button */
.ditio-modern-enabled .btn-link {
    background-color: transparent;
    color: var(--ditio-primary-600);
    border: none;
    text-decoration: none;
}

.ditio-modern-enabled .btn-link:hover,
.ditio-modern-enabled .btn-link:focus {
    background-color: #e6f2ff;
    color: var(--ditio-primary-600);
    text-decoration: none;
}

/* Button sizes */
.ditio-modern-enabled .btn-lg {
    min-height: 2.75rem;
    padding: 0.75rem 1rem;
    font-size: var(--ditio-label-xs);
}

.ditio-modern-enabled .btn-sm {
    min-height: 1.75rem;
    padding: 0.25rem 0.5rem;
    font-size: var(--ditio-label-xxs);
}

.ditio-modern-enabled .btn-xs {
    min-height: 1.5rem;
    padding: 0.25rem 0.5rem;
    font-size: var(--ditio-label-xxs);
}

/* Button groups - radio filter style */
.ditio-modern-enabled .btn-group.horizontal-radio-filter .btn {
    border-radius: 0;
    border: 1px solid var(--ditio-sand-600);
    background-color: var(--ditio-sand-100);
    color: var(--ditio-sand-1200);
}

.ditio-modern-enabled .btn-group.horizontal-radio-filter .btn:first-child {
    border-radius: var(--ditio-radius-sm) 0 0 var(--ditio-radius-sm);
}

.ditio-modern-enabled .btn-group.horizontal-radio-filter .btn:last-child {
    border-radius: 0 var(--ditio-radius-sm) var(--ditio-radius-sm) 0;
}

.ditio-modern-enabled .btn-group.horizontal-radio-filter .btn.active,
.ditio-modern-enabled .btn-group.horizontal-radio-filter .btn:active {
    background-color: var(--ditio-sand-1200);
    color: var(--ditio-sand-100);
    border-color: var(--ditio-sand-1200);
}

.ditio-modern-enabled .btn-group.horizontal-radio-filter .btn:hover:not(.active) {
    background-color: var(--ditio-sand-300);
}

/* Hide radio inputs inside button groups */
.ditio-modern-enabled .btn-group input[type="radio"] {
    position: absolute;
    opacity: 0;
    pointer-events: none;
}

/* ==========================================================================
   Form Controls (Inputs, Selects, Textareas)
   ========================================================================== */

/* Text inputs */
.ditio-modern-enabled .form-control {
    display: block;
    width: 100%;
    min-height: var(--ditio-input-height);
    padding: 0.625rem 0.75rem;
    font-family: 'Aeonik', sans-serif;
    font-size: var(--ditio-body-xs);
    line-height: 1.125rem;
    color: var(--ditio-sand-1200);
    background-color: var(--ditio-sand-300);
    border: none;
    border-radius: 0;
    box-shadow: none;
    transition: box-shadow 0.15s ease;
}

.ditio-modern-enabled .form-control::placeholder {
    color: var(--ditio-sand-1000);
}

.ditio-modern-enabled .form-control:focus {
    background-color: var(--ditio-sand-300);
    border: none;
    box-shadow: inset 0 -2px 0 var(--ditio-sand-1100);
    outline: none;
}

.ditio-modern-enabled .form-control:disabled,
.ditio-modern-enabled .form-control[readonly] {
    background-color: var(--ditio-sand-300);
    color: var(--ditio-sand-1000);
    cursor: not-allowed;
    opacity: 0.7;
}

/* Select elements */
.ditio-modern-enabled select.form-control {
    appearance: none;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 16 16' fill='%231b1b18'%3E%3Cpath d='M4.646 6.646a.5.5 0 0 1 .708 0L8 9.293l2.646-2.647a.5.5 0 0 1 .708.708l-3 3a.5.5 0 0 1-.708 0l-3-3a.5.5 0 0 1 0-.708z'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 0.75rem center;
    background-size: 1rem;
    padding-right: 2.25rem;
}

.ditio-modern-enabled select.form-control:focus {
    box-shadow: inset 0 -2px 0 var(--ditio-sand-1100);
}

/* Textarea */
.ditio-modern-enabled textarea.form-control {
    min-height: 5rem;
    resize: vertical;
}

/* Checkboxes */
.ditio-modern-enabled input[type="checkbox"].form-control,
.ditio-modern-enabled .form-group input[type="checkbox"] {
    width: 1rem;
    height: 1rem;
    min-height: auto;
    padding: 0;
    margin: 0.125rem 0;
    appearance: none;
    background-color: var(--ditio-sand-100);
    border: 1px solid var(--ditio-sand-1200);
    border-radius: 0.125rem;
    cursor: pointer;
    position: relative;
}

.ditio-modern-enabled input[type="checkbox"].form-control:checked,
.ditio-modern-enabled .form-group input[type="checkbox"]:checked {
    background-color: var(--ditio-sand-1200);
    border-color: var(--ditio-sand-1200);
}

.ditio-modern-enabled input[type="checkbox"].form-control:checked::after,
.ditio-modern-enabled .form-group input[type="checkbox"]:checked::after {
    content: '';
    position: absolute;
    left: 0.25rem;
    top: 0.0625rem;
    width: 0.375rem;
    height: 0.625rem;
    border: solid var(--ditio-sand-100);
    border-width: 0 2px 2px 0;
    transform: rotate(45deg);
}

.ditio-modern-enabled input[type="checkbox"].form-control:disabled,
.ditio-modern-enabled .form-group input[type="checkbox"]:disabled {
    background-color: var(--ditio-sand-300);
    border-color: var(--ditio-sand-800);
    cursor: not-allowed;
}

.ditio-modern-enabled input[type="checkbox"].form-control:disabled:checked,
.ditio-modern-enabled .form-group input[type="checkbox"]:disabled:checked {
    background-color: var(--ditio-sand-800);
}

/* Form labels */
.ditio-modern-enabled .form-group label,
.ditio-modern-enabled label {
    display: block;
    margin-bottom: 0.375rem;
    font-family: 'Aeonik', sans-serif;
    font-size: var(--ditio-label-xs);
    font-weight: 500;
    line-height: 1;
    color: var(--ditio-sand-1100);
}

/* Label above checkbox modifier */
.ditio-modern-enabled .mtd-above-checkbox {
    color: var(--ditio-sand-1100);
}

/* Error states */
.ditio-modern-enabled .form-control.notValid,
.ditio-modern-enabled .form-control.has-error,
.ditio-modern-enabled .has-error .form-control {
    box-shadow: inset 0 -2px 0 var(--ditio-red-1000);
}

/* ==========================================================================
   Panels / Cards
   ========================================================================== */

.ditio-modern-enabled .panel {
    background-color: var(--ditio-sand-100);
    border: none;
    border-radius: var(--ditio-radius-md);
    box-shadow: 0 0 15px 0 rgba(0, 0, 0, 0.07);
    margin-bottom: 1.25rem;
}

.ditio-modern-enabled .panel-default {
    border: none;
}

.ditio-modern-enabled .panel-default > .panel-heading {
    background-color: var(--ditio-sand-100);
    border-bottom: 1px solid var(--ditio-sand-400);
    border-radius: var(--ditio-radius-md) var(--ditio-radius-md) 0 0;
    padding: 1rem 1.25rem;
}

.ditio-modern-enabled .panel-title {
    font-family: 'Aeonik', sans-serif;
    font-size: 1.125rem;
    font-weight: 500;
    line-height: 1.25rem;
    color: var(--ditio-sand-1200);
    margin: 0;
}

.ditio-modern-enabled .panel-title a {
    color: var(--ditio-sand-1200);
    text-decoration: none;
}

.ditio-modern-enabled .panel-title a:hover {
    color: var(--ditio-sand-1200);
    text-decoration: none;
}

.ditio-modern-enabled .panel-body {
    padding: 1.25rem;
}

/* Panel group / Accordion */
.ditio-modern-enabled .panel-group {
    margin-bottom: 1.25rem;
}

.ditio-modern-enabled .panel-group .panel {
    margin-bottom: 0;
    border-radius: 0;
}

.ditio-modern-enabled .panel-group .panel:first-child {
    border-radius: var(--ditio-radius-md) var(--ditio-radius-md) 0 0;
}

.ditio-modern-enabled .panel-group .panel:last-child {
    border-radius: 0 0 var(--ditio-radius-md) var(--ditio-radius-md);
}

.ditio-modern-enabled .panel-group .panel + .panel {
    margin-top: 0;
    border-top: 1px solid var(--ditio-sand-400);
}

.ditio-modern-enabled .panel-group .panel-heading {
    border-bottom: none;
}

.ditio-modern-enabled .panel-group .panel-heading + .panel-collapse > .panel-body {
    border-top: 1px solid var(--ditio-sand-400);
}

/* Accordion toggle styling */
.ditio-modern-enabled .accordion-toggle {
    display: flex;
    justify-content: space-between;
    align-items: center;
    width: 100%;
    padding: 0;
    text-decoration: none;
}

.ditio-modern-enabled .accordion-toggle:hover {
    text-decoration: none;
}

.ditio-modern-enabled .accordion-toggle .indicator {
    transition: transform 0.2s ease;
}

.ditio-modern-enabled .accordion-toggle.collapsed .indicator {
    transform: rotate(-90deg);
}

/* ==========================================================================
   Tables
   ========================================================================== */

.ditio-modern-enabled .table {
    background-color: transparent;
    border-collapse: collapse;
    font-family: 'Aeonik', sans-serif;
    font-size: var(--ditio-body-xs);
}

.ditio-modern-enabled .table > thead > tr > th {
    font-weight: 500;
    color: var(--ditio-sand-1100);
    background-color: var(--ditio-sand-200);
    border-bottom: 1px solid var(--ditio-sand-600);
    padding: 0.75rem 1rem;
    text-transform: none;
    letter-spacing: normal;
}

.ditio-modern-enabled .table > tbody > tr > td {
    padding: 0.75rem 1rem;
    border-top: 1px solid var(--ditio-sand-400);
    color: var(--ditio-sand-1200);
    vertical-align: middle;
}

/* Striped table */
.ditio-modern-enabled .table-striped > tbody > tr:nth-of-type(odd) {
    background-color: transparent;
}

.ditio-modern-enabled .table-striped > tbody > tr:nth-of-type(even) {
    background-color: var(--ditio-sand-200);
}

/* Hover table */
.ditio-modern-enabled .table-hover > tbody > tr:hover {
    background-color: var(--ditio-sand-300);
}

/* Condensed table */
.ditio-modern-enabled .table-condensed > thead > tr > th,
.ditio-modern-enabled .table-condensed > tbody > tr > td {
    padding: 0.5rem 0.75rem;
}

/* Table links */
.ditio-modern-enabled .table a {
    color: var(--ditio-primary-600);
    text-decoration: none;
}

.ditio-modern-enabled .table a:hover {
    color: #0165cc;
    text-decoration: underline;
}

/* Sortable headers */
.ditio-modern-enabled .table th.header {
    cursor: pointer;
    user-select: none;
}

.ditio-modern-enabled .table th.header:hover {
    background-color: var(--ditio-sand-300);
}

/* Info row highlight - subtle blue tint with left accent */
.ditio-modern-enabled .table > thead > tr > td.info,
.ditio-modern-enabled .table > thead > tr > th.info,
.ditio-modern-enabled .table > thead > tr.info > td,
.ditio-modern-enabled .table > thead > tr.info > th,
.ditio-modern-enabled .table > tbody > tr > td.info,
.ditio-modern-enabled .table > tbody > tr > th.info,
.ditio-modern-enabled .table > tbody > tr.info > td,
.ditio-modern-enabled .table > tbody > tr.info > th,
.ditio-modern-enabled .table > tfoot > tr > td.info,
.ditio-modern-enabled .table > tfoot > tr > th.info,
.ditio-modern-enabled .table > tfoot > tr.info > td,
.ditio-modern-enabled .table > tfoot > tr.info > th {
    background-color: #e6f2ff;
}

/* ==========================================================================
   Dropdown Menus
   ========================================================================== */

.ditio-modern-enabled .dropdown-menu {
    background-color: var(--ditio-sand-100);
    border: none;
    border-radius: var(--ditio-radius-md);
    box-shadow: 0 4px 15px 0 rgba(0, 0, 0, 0.07);
    padding: 0.5rem 0;
    min-width: 10rem;
}

.ditio-modern-enabled .dropdown-menu > li > a {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.5rem 1.5rem;
    font-family: 'Aeonik', sans-serif;
    font-size: var(--ditio-body-xs);
    color: var(--ditio-sand-1200);
    text-decoration: none;
}

.ditio-modern-enabled .dropdown-menu > li > a:hover,
.ditio-modern-enabled .dropdown-menu > li > a:focus {
    background-color: var(--ditio-sand-300);
    color: var(--ditio-sand-1200);
}

.ditio-modern-enabled .dropdown-menu > li > a:active {
    background-color: var(--ditio-sand-400);
    color: var(--ditio-sand-1200);
}

.ditio-modern-enabled .dropdown-menu .divider {
    height: 1px;
    margin: 0.5rem 0;
    background-color: var(--ditio-sand-400);
    border: none;
}

/* Dropdown toggle */
.ditio-modern-enabled .dropdown-toggle {
    cursor: pointer;
}

.ditio-modern-enabled .dropdown-toggle .fa-ellipsis-v {
    color: var(--ditio-sand-1000);
    transition: color 0.15s ease;
}

.ditio-modern-enabled .dropdown-toggle:hover .fa-ellipsis-v {
    color: var(--ditio-sand-1200);
}

/* ==========================================================================
   Alerts and Messages
   ========================================================================== */

.ditio-modern-enabled .alert {
    padding: 1rem 1.25rem;
    border: none;
    border-radius: var(--ditio-radius-md);
    font-family: 'Aeonik', sans-serif;
    font-size: var(--ditio-body-xs);
}

.ditio-modern-enabled .alert-info {
    background-color: #e6f2ff;
    color: #003266;
}

.ditio-modern-enabled .alert-success {
    background-color: #ebf9eb;
    color: #1b311e;
}

.ditio-modern-enabled .alert-warning {
    background-color: #fef0e8;
    color: #311505;
}

.ditio-modern-enabled .alert-danger {
    background-color: #fff8f8;
    color: #381316;
}

/* ==========================================================================
   Text Utilities
   ========================================================================== */

.ditio-modern-enabled .text-info {
    color: var(--ditio-primary-600) !important;
}

.ditio-modern-enabled .text-success {
    color: var(--ditio-green-700) !important;
}

.ditio-modern-enabled .text-warning {
    color: #f3671b !important;
}

.ditio-modern-enabled .text-danger {
    color: var(--ditio-red-1000) !important;
}

.ditio-modern-enabled .text-muted,
.ditio-modern-enabled .text-light-black {
    color: var(--ditio-sand-1000) !important;
}

/* ==========================================================================
   Icons (Font Awesome)
   ========================================================================== */

.ditio-modern-enabled .fa {
    color: var(--ditio-sand-1000);
}

.ditio-modern-enabled .btn .fa,
.ditio-modern-enabled .dropdown-menu .fa {
    color: inherit;
}

.ditio-modern-enabled a .fa {
    color: inherit;
}

/* ==========================================================================
   Search Input
   ========================================================================== */

.ditio-modern-enabled #ProjectSearchFilter,
.ditio-modern-enabled .search-input {
    padding-right: 2rem;
}

/* ==========================================================================
   Form Actions Bar
   ========================================================================== */

.ditio-modern-enabled .form-actions {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    padding: 0.75rem 0;
    flex-wrap: wrap;
}

/* ==========================================================================
   Thumbnails
   ========================================================================== */

.ditio-modern-enabled .img-thumbnail {
    border: 1px solid var(--ditio-sand-400);
    border-radius: var(--ditio-radius-md);
    padding: 0.25rem;
    background-color: var(--ditio-sand-100);
}

.ditio-modern-enabled .map-thumbnail-free,
.ditio-modern-enabled .qrcode-thumbnail-free {
    cursor: pointer;
    border-radius: var(--ditio-radius-md);
    transition: opacity 0.15s ease;
}

.ditio-modern-enabled .map-thumbnail-free:hover,
.ditio-modern-enabled .qrcode-thumbnail-free:hover {
    opacity: 0.8;
}

/* ==========================================================================
   Helper Classes
   ========================================================================== */

/* Financial end date passed state */
.ditio-modern-enabled .financial-end-date-passed {
    background-color: #fff8f8 !important;
    color: var(--ditio-red-1000) !important;
}

/* Not valid state */
.ditio-modern-enabled .notValid {
    box-shadow: inset 0 -2px 0 var(--ditio-red-1000) !important;
}

/* ==========================================================================
   Responsive Utilities
   ========================================================================== */

.ditio-modern-enabled .table-responsive {
    border: none;
}

/* ==========================================================================
   Legacy Overrides for Specific Pages
   ========================================================================== */

/* Project list page specific */
.ditio-modern-enabled .horizontal-radio-filter {
    margin-left: 0.5rem;
}

/* Avatar controls */
.ditio-modern-enabled .mtd-avatar-control {
    display: inline-flex;
    align-items: center;
}

.ditio-modern-enabled .mtd-avatar-control img {
    width: 2.5rem;
    height: 2.5rem;
    object-fit: cover;
    border-radius: 50%;
}

/* ==========================================================================
   Invoice Detail Sticky Footer
   ========================================================================== */

.ditio-modern-enabled .invoice-detail-footer {
    position: fixed;
    bottom: 0;
    left: 0;
    right: 0;
    z-index: 50;
    height: 80px;
    display: flex;
    flex-direction: column;
    justify-content: center;
    background-color: var(--ditio-sand-100);
    border-top: 1px solid var(--ditio-sand-400);
    padding: 0 1.5rem;
    box-shadow: 0 -2px 10px rgba(0, 0, 0, 0.08);
}

/* Offset footer from left menu when menu is visible (>= 1280px) */
@media (min-width: 1280px) {
    .ditio-modern-enabled .invoice-detail-footer {
        left: 14rem; /* Match #r-navigation-menu min-width */
    }
}

/* Reset footer position when menu is closed (child div is empty) */
@media (min-width: 1280px) {
    body:has(#r-navigation-menu > :empty) .ditio-modern-enabled .invoice-detail-footer,
    body.ditio-modern-enabled:has(#r-navigation-menu > :empty) .invoice-detail-footer {
        left: 0;
    }
}

.ditio-modern-enabled .invoice-detail-footer .btn-toolbar {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    align-items: center;
    width: 100%;
}

.ditio-modern-enabled .invoice-detail-footer .btn-group.pull-right {
    margin-left: auto;
}

.ditio-modern-enabled .invoice-detail-footer .alert {
    margin-bottom: 0.75rem;
    padding: 0.5rem 0.75rem;
}

/* Add bottom padding to content area to prevent footer overlap */
.ditio-modern-enabled .invoice-detail-content {
    padding-bottom: 100px; /* 80px footer + 20px breathing room */
}

/* Summary section inset within the invoice detail panel */
.ditio-modern-enabled .invoice-summary-inset {
    background-color: var(--ditio-sand-200);
    border-radius: var(--ditio-radius-md);
    padding: 1rem 1.25rem;
}

/* ==========================================================================
   Invoice Lines Table - Inline Edit Position Stability
   ========================================================================== */

.ditio-modern-enabled .invoice-lines-table > tbody > tr > td {
    padding: 0.5rem 0.75rem;
    vertical-align: middle;
}

/* Reset form-control styles for inline editing to prevent position shift */
.ditio-modern-enabled .invoice-lines-table td .form-control.input-sm {
    min-height: auto;
    height: 1.5rem;
    padding: 0.125rem 0.375rem;
    margin: 0;
    font-size: inherit;
    line-height: 1.25;
    background-color: var(--ditio-sand-200);
}

/* Ensure spans take same vertical space as inputs */
.ditio-modern-enabled .invoice-lines-table td > span,
.ditio-modern-enabled .invoice-lines-table td > strong {
    display: inline-block;
    min-height: 1.5rem;
    line-height: 1.5rem;
    vertical-align: middle;
}

/* Right-aligned number inputs */
.ditio-modern-enabled .invoice-lines-table td .form-control.input-sm[type="number"] {
    text-align: right;
}

/* ==========================================================================
   Invoice Edit Side Panel
   ========================================================================== */

/* Side panel overlay */
.ditio-modern-enabled .invoice-edit-panel-overlay {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background-color: rgba(0, 0, 0, 0.3);
    z-index: 1040;
    opacity: 0;
    visibility: hidden;
    transition: opacity 0.3s ease, visibility 0.3s ease;
}

.ditio-modern-enabled .invoice-edit-panel-overlay.active {
    opacity: 1;
    visibility: visible;
}

/* Side panel */
.ditio-modern-enabled .invoice-edit-panel {
    position: fixed;
    top: 0;
    right: 0;
    bottom: 0;
    width: 420px;
    max-width: 100%;
    background-color: var(--ditio-sand-100);
    box-shadow: -4px 0 15px rgba(0, 0, 0, 0.1);
    z-index: 1050;
    transform: translateX(100%);
    transition: transform 0.3s ease;
    display: flex;
    flex-direction: column;
}

.ditio-modern-enabled .invoice-edit-panel.active {
    transform: translateX(0);
}

/* Panel header */
.ditio-modern-enabled .invoice-edit-panel-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 1rem 1.25rem;
    border-bottom: 1px solid var(--ditio-sand-400);
    background-color: var(--ditio-sand-100);
}

.ditio-modern-enabled .invoice-edit-panel-header h4 {
    margin: 0;
    font-family: 'Aeonik', sans-serif;
    font-size: 1.125rem;
    font-weight: 500;
    color: var(--ditio-sand-1200);
}

.ditio-modern-enabled .invoice-edit-panel-close {
    background: none;
    border: none;
    font-size: 1.5rem;
    line-height: 1;
    color: var(--ditio-sand-1000);
    cursor: pointer;
    padding: 0;
    width: 2rem;
    height: 2rem;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: var(--ditio-radius-sm);
    transition: background-color 0.15s ease, color 0.15s ease;
}

.ditio-modern-enabled .invoice-edit-panel-close:hover {
    background-color: var(--ditio-sand-300);
    color: var(--ditio-sand-1200);
}

/* Panel body */
.ditio-modern-enabled .invoice-edit-panel-body {
    flex: 1;
    overflow-y: auto;
    padding: 1.25rem;
}

/* Panel footer */
.ditio-modern-enabled .invoice-edit-panel-footer {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 0.75rem;
    padding: 1rem 1.25rem;
    border-top: 1px solid var(--ditio-sand-400);
    background-color: var(--ditio-sand-100);
}

/* Line info section at top of panel */
.ditio-modern-enabled .invoice-edit-panel-line-info {
    background-color: var(--ditio-sand-200);
    border-radius: var(--ditio-radius-md);
    padding: 0.75rem 1rem;
    margin-bottom: 1.25rem;
    font-size: var(--ditio-body-xs);
    color: var(--ditio-sand-1100);
}

.ditio-modern-enabled .invoice-edit-panel-line-info > div {
    margin-bottom: 0.25rem;
}

.ditio-modern-enabled .invoice-edit-panel-line-info > div:last-child {
    margin-bottom: 0;
}

.ditio-modern-enabled .invoice-edit-panel-line-info span {
    font-weight: 500;
    color: var(--ditio-sand-1200);
}

/* Form groups in panel */
.ditio-modern-enabled .invoice-edit-panel-body .form-group {
    margin-bottom: 1rem;
}

.ditio-modern-enabled .invoice-edit-panel-body .form-group:last-child {
    margin-bottom: 0;
}

.ditio-modern-enabled .invoice-edit-panel-body .row {
    margin-bottom: 1rem;
}

.ditio-modern-enabled .invoice-edit-panel-body .row:last-child {
    margin-bottom: 0;
}

/* Apply-to-all section */
.ditio-modern-enabled .invoice-edit-apply-all-section {
    background-color: #e6f2ff;
    border-radius: var(--ditio-radius-sm);
    padding: 0.625rem 0.75rem;
    margin-top: 0.5rem;
    font-size: var(--ditio-label-xxs);
}

.ditio-modern-enabled .invoice-edit-apply-all-section label {
    display: flex;
    align-items: flex-start;
    gap: 0.375rem;
    margin: 0;
    font-weight: 400;
    color: var(--ditio-sand-1200);
    cursor: pointer;
    min-width: 0;
}

.ditio-modern-enabled .invoice-edit-apply-all-section label > span {
    min-width: 0;
    word-wrap: break-word;
    overflow-wrap: break-word;
}

.ditio-modern-enabled .invoice-edit-apply-all-section input[type="checkbox"] {
    width: 0.875rem;
    height: 0.875rem;
    min-height: auto;
    margin: 0;
    margin-top: 0.125rem;
    flex-shrink: 0;
}

/* Apply-to-all warning */
.ditio-modern-enabled .invoice-edit-apply-all-warning {
    background-color: #fef0e8;
    color: #311505;
    border-radius: var(--ditio-radius-sm);
    padding: 0.5rem 0.75rem;
    margin-top: 0.5rem;
    font-size: var(--ditio-label-xxs);
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

.ditio-modern-enabled .invoice-edit-apply-all-warning .fa {
    color: #f3671b;
}

/* Live total display */
.ditio-modern-enabled .invoice-edit-panel-total {
    display: flex;
    align-items: center;
    justify-content: space-between;
    background-color: var(--ditio-sand-200);
    border-radius: var(--ditio-radius-md);
    padding: 1rem;
    margin-top: 1.25rem;
    font-size: var(--ditio-body-xs);
}

.ditio-modern-enabled .invoice-edit-panel-total strong {
    font-size: 1.125rem;
    color: var(--ditio-sand-1200);
}

/* Clickable table row indicator */
.ditio-modern-enabled .invoice-lines-table > tbody > tr[data-bind*="startEditLine"] {
    cursor: pointer;
}

/* ==========================================================================
   Invoice Lines - Flash Animation for New Lines
   ========================================================================== */

@keyframes invoice-line-flash {
    0%, 50% { background-color: #d4edda; }
    100% { background-color: transparent; }
}

.ditio-modern-enabled .invoice-lines-table > tbody > tr.invoice-line-flash {
    animation: invoice-line-flash 1.5s ease-out forwards;
}

/* ==========================================================================
   Invoice Lines - Sticky Header and Total
   ========================================================================== */

.ditio-modern-enabled .invoice-lines-sticky-heading {
    position: sticky;
    top: -20px;
    z-index: 48;
    background-color: var(--ditio-sand-100);
    border-radius: 0;
}

.ditio-modern-enabled .invoice-lines-sticky-thead > tr > th {
    position: sticky;
    top: 38px; /* panel-heading height (with flex container) */
    z-index: 49;
    background-color: var(--ditio-sand-200);
    box-shadow: inset 0 -2px 0 var(--ditio-sand-400);
}

/* Sticky total display in header */
.ditio-modern-enabled .invoice-sticky-total {
    font-size: var(--ditio-body-xs);
    color: var(--ditio-sand-1100);
    white-space: nowrap;
}

.ditio-modern-enabled .invoice-sticky-total strong {
    color: var(--ditio-sand-1200);
    font-size: 1rem;
}

/* Badge pulse animation for line type badges */
@keyframes badge-pulse-animation {
    0% { 
        transform: scale(1); 
        box-shadow: 0 0 0 0 rgba(76, 175, 80, 0.7); 
    }
    30% { 
        transform: scale(1.15); 
        box-shadow: 0 0 12px 4px rgba(76, 175, 80, 0.5); 
    }
    60% { 
        transform: scale(1.08); 
        box-shadow: 0 0 8px 2px rgba(76, 175, 80, 0.3); 
    }
    100% { 
        transform: scale(1); 
        box-shadow: 0 0 0 0 rgba(76, 175, 80, 0); 
    }
}

.badge-pulse {
    animation: badge-pulse-animation 0.6s ease-out;
    background: #4CAF50 !important;
    color: #fff !important;
}

/* Softer table warning colors for invoiced transactions */
.ditio-modern-enabled .table > tbody > tr.warning > td,
.ditio-modern-enabled .table > tbody > tr.warning > th,
.ditio-modern-enabled .table > tbody > tr > td.warning {
    background-color: #fef0e8;
    color: #311505;
}

.ditio-modern-enabled .table-hover > tbody > tr.warning:hover > td,
.ditio-modern-enabled .table-hover > tbody > tr.warning:hover > th,
.ditio-modern-enabled .table-hover > tbody > tr > td.warning:hover,
.ditio-modern-enabled .table-hover > tbody > tr:hover > .warning {
    background-color: #fde5d8;
}

/* ==========================================================================
   Toastr Notifications (Modern Dark Style)
   ========================================================================== */

/* Container positioning - bottom center like Sonner */
body.ditio-modern-enabled #toast-container,
body:has(.ditio-modern-enabled) #toast-container {
    top: auto !important;
    right: auto !important;
    bottom: 24px;
    left: 50%;
    transform: translateX(-50%);
    width: auto;
    max-width: 420px;
}

/* Base toast styling - dark theme */
body.ditio-modern-enabled #toast-container > div,
body:has(.ditio-modern-enabled) #toast-container > div {
    background-color: #1b1b18;
    border: 1px solid hsl(0, 0%, 20%);
    border-radius: 8px;
    padding: 16px;
    padding-left: 48px;
    width: auto;
    min-width: 300px;
    max-width: 420px;
    box-shadow: 0px 4px 12px rgba(0, 0, 0, 0.15);
    opacity: 1;
    filter: none;
    -ms-filter: none;
    font-family: 'Aeonik', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
    font-size: 13px;
    line-height: 1.4;
    color: #FFFFFF;
}

body.ditio-modern-enabled #toast-container > div:hover,
body:has(.ditio-modern-enabled) #toast-container > div:hover {
    box-shadow: 0px 6px 16px rgba(0, 0, 0, 0.2);
    opacity: 1;
}

/* Toast title */
body.ditio-modern-enabled .toast-title,
body:has(.ditio-modern-enabled) .toast-title {
    font-weight: 500;
    font-size: 14px;
    margin-bottom: 4px;
}

/* Toast message */
body.ditio-modern-enabled .toast-message,
body:has(.ditio-modern-enabled) .toast-message {
    font-weight: 400;
    opacity: 0.9;
}

/* Success toast - dark green theme */
body.ditio-modern-enabled #toast-container > .toast-success,
body:has(.ditio-modern-enabled) #toast-container > .toast-success {
    background-color: hsl(150, 100%, 6%);
    border-color: hsl(147, 100%, 12%);
    color: #FFFFFF;
}

/* Error toast - dark red theme */
body.ditio-modern-enabled #toast-container > .toast-error,
body:has(.ditio-modern-enabled) #toast-container > .toast-error {
    background-color: hsl(358, 76%, 10%);
    border-color: hsl(357, 89%, 16%);
    color: #FFFFFF;
}

/* Info toast - dark blue theme */
body.ditio-modern-enabled #toast-container > .toast-info,
body:has(.ditio-modern-enabled) #toast-container > .toast-info {
    background-color: hsl(215, 100%, 6%);
    border-color: hsl(223, 43%, 17%);
    color: #FFFFFF;
}

/* Warning toast - dark orange theme */
body.ditio-modern-enabled #toast-container > .toast-warning,
body:has(.ditio-modern-enabled) #toast-container > .toast-warning {
    background-color: hsl(30, 100%, 6%);
    border-color: hsl(30, 80%, 15%);
    color: #FFFFFF;
}

/* Icon positioning and styling */
body.ditio-modern-enabled #toast-container > .toast-success,
body:has(.ditio-modern-enabled) #toast-container > .toast-success,
body.ditio-modern-enabled #toast-container > .toast-error,
body:has(.ditio-modern-enabled) #toast-container > .toast-error,
body.ditio-modern-enabled #toast-container > .toast-info,
body:has(.ditio-modern-enabled) #toast-container > .toast-info,
body.ditio-modern-enabled #toast-container > .toast-warning,
body:has(.ditio-modern-enabled) #toast-container > .toast-warning {
    background-position: 16px center;
    background-size: 18px 18px;
}

/* Links in toasts */
body.ditio-modern-enabled .toast-message a,
body:has(.ditio-modern-enabled) .toast-message a,
body.ditio-modern-enabled .toast-message label,
body:has(.ditio-modern-enabled) .toast-message label {
    color: inherit;
    text-decoration: underline;
    opacity: 0.9;
}

body.ditio-modern-enabled .toast-message a:hover,
body:has(.ditio-modern-enabled) .toast-message a:hover {
    opacity: 1;
    text-decoration: none;
}

/* Mobile responsive */
@media (max-width: 600px) {
    body.ditio-modern-enabled #toast-container,
    body:has(.ditio-modern-enabled) #toast-container {
        left: 16px;
        right: 16px;
        transform: none;
        max-width: none;
    }

    body.ditio-modern-enabled #toast-container > div,
    body:has(.ditio-modern-enabled) #toast-container > div {
        width: 100%;
        min-width: auto;
        max-width: none;
    }
}

/* ==========================================================================
   jQuery UI Datepicker (Modern Ditio Style)
   ========================================================================== */

/* Main datepicker container */
body.ditio-modern-enabled .ui-datepicker,
body:has(.ditio-modern-enabled) .ui-datepicker {
    background-color: var(--ditio-sand-100);
    border: none;
    border-radius: var(--ditio-radius-md);
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.15);
    padding: 12px;
    width: 280px;
    font-family: 'Aeonik', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
    font-size: 14px;
}

/* Header with month/year navigation */
body.ditio-modern-enabled .ui-datepicker .ui-datepicker-header,
body:has(.ditio-modern-enabled) .ui-datepicker .ui-datepicker-header {
    background: none;
    border: none;
    padding: 8px 4px 12px;
    border-radius: 0;
}

/* Month/Year title */
body.ditio-modern-enabled .ui-datepicker .ui-datepicker-title,
body:has(.ditio-modern-enabled) .ui-datepicker .ui-datepicker-title {
    font-weight: 500;
    font-size: 15px;
    color: var(--ditio-sand-1200);
}

/* Month/Year dropdowns */
body.ditio-modern-enabled .ui-datepicker select.ui-datepicker-month,
body:has(.ditio-modern-enabled) .ui-datepicker select.ui-datepicker-month,
body.ditio-modern-enabled .ui-datepicker select.ui-datepicker-year,
body:has(.ditio-modern-enabled) .ui-datepicker select.ui-datepicker-year {
    background-color: var(--ditio-sand-300);
    border: none;
    border-radius: var(--ditio-radius-sm);
    padding: 4px 8px;
    font-size: 14px;
    font-weight: 500;
    color: var(--ditio-sand-1200);
    cursor: pointer;
}

body.ditio-modern-enabled .ui-datepicker select.ui-datepicker-month:hover,
body:has(.ditio-modern-enabled) .ui-datepicker select.ui-datepicker-month:hover,
body.ditio-modern-enabled .ui-datepicker select.ui-datepicker-year:hover,
body:has(.ditio-modern-enabled) .ui-datepicker select.ui-datepicker-year:hover {
    background-color: var(--ditio-sand-400);
}

/* Prev/Next navigation buttons */
body.ditio-modern-enabled .ui-datepicker .ui-datepicker-prev,
body:has(.ditio-modern-enabled) .ui-datepicker .ui-datepicker-prev,
body.ditio-modern-enabled .ui-datepicker .ui-datepicker-next,
body:has(.ditio-modern-enabled) .ui-datepicker .ui-datepicker-next {
    width: 32px;
    height: 32px;
    top: 6px;
    border-radius: var(--ditio-radius-sm);
    cursor: pointer;
    background: none;
    border: none;
}

body.ditio-modern-enabled .ui-datepicker .ui-datepicker-prev:hover,
body:has(.ditio-modern-enabled) .ui-datepicker .ui-datepicker-prev:hover,
body.ditio-modern-enabled .ui-datepicker .ui-datepicker-next:hover,
body:has(.ditio-modern-enabled) .ui-datepicker .ui-datepicker-next:hover {
    background-color: var(--ditio-sand-300);
    top: 6px;
}

body.ditio-modern-enabled .ui-datepicker .ui-datepicker-prev,
body:has(.ditio-modern-enabled) .ui-datepicker .ui-datepicker-prev {
    left: 4px;
}

body.ditio-modern-enabled .ui-datepicker .ui-datepicker-next,
body:has(.ditio-modern-enabled) .ui-datepicker .ui-datepicker-next {
    right: 4px;
}

/* Hide default jQuery UI icons, use custom */
body.ditio-modern-enabled .ui-datepicker .ui-datepicker-prev span,
body:has(.ditio-modern-enabled) .ui-datepicker .ui-datepicker-prev span,
body.ditio-modern-enabled .ui-datepicker .ui-datepicker-next span,
body:has(.ditio-modern-enabled) .ui-datepicker .ui-datepicker-next span {
    background-image: none !important;
}

body.ditio-modern-enabled .ui-datepicker .ui-datepicker-prev::after,
body:has(.ditio-modern-enabled) .ui-datepicker .ui-datepicker-prev::after,
body.ditio-modern-enabled .ui-datepicker .ui-datepicker-next::after,
body:has(.ditio-modern-enabled) .ui-datepicker .ui-datepicker-next::after {
    content: '';
    display: block;
    width: 8px;
    height: 8px;
    border-left: 2px solid var(--ditio-sand-1000);
    border-bottom: 2px solid var(--ditio-sand-1000);
    position: absolute;
    top: 50%;
    left: 50%;
}

body.ditio-modern-enabled .ui-datepicker .ui-datepicker-prev::after,
body:has(.ditio-modern-enabled) .ui-datepicker .ui-datepicker-prev::after {
    transform: translate(-30%, -50%) rotate(45deg);
}

body.ditio-modern-enabled .ui-datepicker .ui-datepicker-next::after,
body:has(.ditio-modern-enabled) .ui-datepicker .ui-datepicker-next::after {
    transform: translate(-70%, -50%) rotate(-135deg);
}

/* Calendar table */
body.ditio-modern-enabled .ui-datepicker table,
body:has(.ditio-modern-enabled) .ui-datepicker table {
    margin: 0;
    font-size: 13px;
}

/* Day headers (Mon, Tue, etc.) */
body.ditio-modern-enabled .ui-datepicker th,
body:has(.ditio-modern-enabled) .ui-datepicker th {
    padding: 8px 0;
    font-weight: 500;
    font-size: 12px;
    color: var(--ditio-sand-1000);
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

/* Day cells */
body.ditio-modern-enabled .ui-datepicker td,
body:has(.ditio-modern-enabled) .ui-datepicker td {
    padding: 2px;
}

body.ditio-modern-enabled .ui-datepicker td span,
body:has(.ditio-modern-enabled) .ui-datepicker td span,
body.ditio-modern-enabled .ui-datepicker td a,
body:has(.ditio-modern-enabled) .ui-datepicker td a {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 32px;
    height: 32px;
    padding: 0;
    text-align: center;
    border-radius: var(--ditio-radius-sm);
    color: var(--ditio-sand-1200);
    transition: background-color 0.15s ease;
}

/* Hover state */
body.ditio-modern-enabled .ui-datepicker td a:hover,
body:has(.ditio-modern-enabled) .ui-datepicker td a:hover {
    background-color: var(--ditio-sand-300);
    color: var(--ditio-sand-1200);
}

/* Today - accent border */
body.ditio-modern-enabled .ui-datepicker td.ui-datepicker-today a,
body:has(.ditio-modern-enabled) .ui-datepicker td.ui-datepicker-today a {
    border: 1px solid #F3671B;
    color: #F3671B;
    font-weight: 500;
}

body.ditio-modern-enabled .ui-datepicker td.ui-datepicker-today a:hover,
body:has(.ditio-modern-enabled) .ui-datepicker td.ui-datepicker-today a:hover {
    background-color: rgba(243, 103, 27, 0.1);
}

/* Selected/Active date - accent background */
body.ditio-modern-enabled .ui-datepicker td.ui-datepicker-current-day a,
body:has(.ditio-modern-enabled) .ui-datepicker td.ui-datepicker-current-day a,
body.ditio-modern-enabled .ui-datepicker td.ui-state-active a,
body:has(.ditio-modern-enabled) .ui-datepicker td.ui-state-active a {
    background-color: #F3671B !important;
    color: #FFFFFF !important;
    border: none;
    font-weight: 500;
    background: none;
}

/* Highlighted dates */
body.ditio-modern-enabled .ui-datepicker td a.ui-state-highlight,
body:has(.ditio-modern-enabled) .ui-datepicker td a.ui-state-highlight {
    background-color: var(--ditio-sand-400);
}

/* Disabled dates */
body.ditio-modern-enabled .ui-datepicker td.ui-datepicker-unselectable span,
body:has(.ditio-modern-enabled) .ui-datepicker td.ui-datepicker-unselectable span {
    color: var(--ditio-sand-800);
}

/* Other month dates (faded) */
body.ditio-modern-enabled .ui-datepicker td.ui-datepicker-other-month span,
body:has(.ditio-modern-enabled) .ui-datepicker td.ui-datepicker-other-month span,
body.ditio-modern-enabled .ui-datepicker td.ui-datepicker-other-month a,
body:has(.ditio-modern-enabled) .ui-datepicker td.ui-datepicker-other-month a {
    color: var(--ditio-sand-800);
    opacity: 0.5;
}

/* Button pane (if used) */
body.ditio-modern-enabled .ui-datepicker .ui-datepicker-buttonpane,
body:has(.ditio-modern-enabled) .ui-datepicker .ui-datepicker-buttonpane {
    border-top: 1px solid var(--ditio-sand-400);
    margin-top: 8px;
    padding-top: 8px;
}

body.ditio-modern-enabled .ui-datepicker .ui-datepicker-buttonpane button,
body:has(.ditio-modern-enabled) .ui-datepicker .ui-datepicker-buttonpane button {
    background-color: var(--ditio-sand-1200);
    color: var(--ditio-sand-100);
    border: none;
    border-radius: var(--ditio-radius-sm);
    padding: 6px 12px;
    font-size: 13px;
    font-weight: 500;
    cursor: pointer;
}

body.ditio-modern-enabled .ui-datepicker .ui-datepicker-buttonpane button:hover,
body:has(.ditio-modern-enabled) .ui-datepicker .ui-datepicker-buttonpane button:hover {
    background-color: var(--ditio-sand-1100);
}

/* Week column (if shown) */
body.ditio-modern-enabled .ui-datepicker td.ui-datepicker-week-col,
body:has(.ditio-modern-enabled) .ui-datepicker td.ui-datepicker-week-col {
    color: var(--ditio-sand-900);
    font-size: 11px;
}

/* ==========================================================================
   Invoice Guide Cards - Simplified Design
   ========================================================================== */

/* Cards Container */
.ditio-modern-enabled .guide-cards {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
    gap: 12px;
    max-height: 500px;
    overflow-y: auto;
    padding: 2px;
}

/* Individual Card - clean, minimal */
.ditio-modern-enabled .guide-card {
    background: var(--ditio-sand-100);
    border: 1px solid var(--ditio-sand-400);
    border-radius: 4px;
    padding: 16px;
    position: relative;
    transition: background-color 0.15s ease;
    display: flex;
    flex-direction: column;
}

.ditio-modern-enabled .guide-card:hover {
    background: var(--ditio-sand-200);
}

/* Menu - top right, hidden until hover */
.ditio-modern-enabled .guide-card-menu {
    position: absolute;
    top: 12px;
    right: 12px;
    opacity: 0;
    transition: opacity 0.15s ease;
}

.ditio-modern-enabled .guide-card:hover .guide-card-menu {
    opacity: 1;
}

/* Menu icon - no button styling */
.ditio-modern-enabled .guide-card-menu-icon {
    cursor: pointer;
    padding: 4px 6px;
    color: var(--ditio-sand-900);
    border-radius: 2px;
}

.ditio-modern-enabled .guide-card-menu-icon:hover {
    color: var(--ditio-sand-1200);
    background: var(--ditio-sand-300);
}

/* Card Header */
.ditio-modern-enabled .guide-card-header {
    display: flex;
    align-items: flex-start;
    gap: 12px;
    margin-bottom: 12px;
    padding-right: 32px; /* Space for menu */
    min-height: 72px; /* Reserve consistent space for project info (up to 3 lines) */
}

/* Project Number - subtle background, no gradient */
.ditio-modern-enabled .guide-card-proj-number {
    font-family: 'Courier New', Courier, monospace;
    font-size: 13px;
    font-weight: 600;
    color: var(--ditio-sand-1200);
    background: var(--ditio-sand-300);
    padding: 4px 8px;
    border-radius: 2px;
    white-space: nowrap;
    flex-shrink: 0;
}

/* Card Title Section */
.ditio-modern-enabled .guide-card-title {
    flex: 1;
    min-width: 0;
}

.ditio-modern-enabled .guide-card-name {
    display: block;
    font-weight: 600;
    color: var(--ditio-sand-1200);
    font-size: 14px;
    line-height: 1.3;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.ditio-modern-enabled .guide-card-description {
    display: block;
    color: var(--ditio-sand-1000);
    font-size: 13px;
    margin-top: 2px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

/* External Label - subtle */
.ditio-modern-enabled .guide-card-external {
    font-size: 11px;
    color: var(--ditio-sand-1000);
    background: var(--ditio-sand-300);
    padding: 2px 6px;
    border-radius: 2px;
    flex-shrink: 0;
    white-space: nowrap;
}

/* Stats - 2x2 grid of tiles */
.ditio-modern-enabled .guide-card-stats-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 8px;
    margin: 12px 0;
}

/* Individual stat tile */
.ditio-modern-enabled .guide-card-stat-tile {
    background: var(--ditio-sand-200);
    border-radius: 4px;
    padding: 10px 12px;
    display: flex;
    flex-direction: column;
}

.ditio-modern-enabled .guide-card-stat-tile strong {
    font-size: 18px;
    font-weight: 700;
    color: var(--ditio-primary-600);
    line-height: 1.2;
}

.ditio-modern-enabled .guide-card-stat-tile span {
    font-size: 12px;
    color: var(--ditio-sand-1000);
    margin-top: 2px;
}

/* Secondary tile (previous period) - medium prominence */
.ditio-modern-enabled .guide-card-stat-tile.secondary strong {
    font-size: 15px;
    font-weight: 600;
    color: var(--ditio-sand-1100);
}

/* Muted tile (draft) - least prominent */
.ditio-modern-enabled .guide-card-stat-tile.muted strong {
    font-size: 14px;
    font-weight: 500;
    color: var(--ditio-sand-900);
}

.ditio-modern-enabled .guide-card-stat-tile.muted span {
    color: var(--ditio-sand-800);
}

/* Zero-value tiles */
.ditio-modern-enabled .guide-card-stat-tile.is-zero {
    background: var(--ditio-sand-200);
}

.ditio-modern-enabled .guide-card-stat-tile.is-zero strong {
    color: var(--ditio-sand-800);
    font-weight: 500;
    font-size: 14px;
}

.ditio-modern-enabled .guide-card-stat-tile.is-zero span {
    color: var(--ditio-sand-700);
}

/* Card Actions */
.ditio-modern-enabled .guide-card-actions {
    display: flex;
    justify-content: flex-end;
    margin-top: auto;
    padding-top: 12px;
}

/* Button - outline by default, primary on card hover */
.ditio-modern-enabled .guide-card-btn {
    padding: 6px 12px;
    font-size: 13px;
    border-color: var(--ditio-sand-600);
    color: var(--ditio-sand-1100);
    background: transparent;
    transition: all 0.15s ease;
}

.ditio-modern-enabled .guide-card-btn:hover {
    border-color: var(--ditio-sand-800);
    color: var(--ditio-sand-1200);
    background: var(--ditio-sand-200);
}

.ditio-modern-enabled .guide-card:hover .guide-card-btn {
    background-color: var(--ditio-sand-1200);
    color: var(--ditio-sand-100);
    border-color: var(--ditio-sand-1200);
}

.ditio-modern-enabled .guide-card:hover .guide-card-btn:hover {
    background-color: var(--ditio-sand-1100);
    border-color: var(--ditio-sand-1100);
}

/* Progress header - subtle styling */
.ditio-modern-enabled .guide-progress-header {
    background: var(--ditio-sand-200);
    border: 1px solid var(--ditio-sand-400);
    border-radius: 4px;
    padding: 16px 20px;
    margin-bottom: 16px;
}

.ditio-modern-enabled .guide-progress-header i.fa {
    color: var(--ditio-sand-900);
    margin-right: 4px;
}

/* Responsive adjustments */
@media (max-width: 768px) {
    .ditio-modern-enabled .guide-cards {
        grid-template-columns: 1fr;
        max-height: 400px;
    }

    .ditio-modern-enabled .guide-card {
        padding: 14px;
    }

    .ditio-modern-enabled .guide-card-proj-number {
        font-size: 12px;
    }

    .ditio-modern-enabled .guide-card-stats {
        font-size: 12px;
    }
}

/* ==========================================================================
   Invoice Redesign - Guide Table
   ========================================================================== */

.ditio-modern-enabled .guide-table { width: 100%; border-collapse: separate; border-spacing: 0; }
.ditio-modern-enabled .guide-table th {
    font-size: 11px; text-transform: uppercase; color: var(--ditio-sand-1000);
    letter-spacing: 0.5px; padding: 8px 12px; border-bottom: 2px solid var(--ditio-sand-400);
    background: var(--ditio-sand-200); position: sticky; top: 0; z-index: 1;
}
.ditio-modern-enabled .guide-table td { padding: 10px 12px; border-bottom: 1px solid var(--ditio-sand-300); font-size: 13px; }
.ditio-modern-enabled .guide-table tbody tr { cursor: pointer; transition: background 0.1s; }
.ditio-modern-enabled .guide-table tbody tr:hover { background: var(--ditio-sand-200); }
.ditio-modern-enabled .guide-table .zero-value { color: var(--ditio-sand-800); }
.ditio-modern-enabled .guide-table .guide-action-cell { opacity: 0; transition: opacity 0.15s; }
.ditio-modern-enabled .guide-table .guide-action-cell .btn-group { display: inline-flex; white-space: nowrap; }
.ditio-modern-enabled .guide-table tbody tr:hover .guide-action-cell { opacity: 1; }
.ditio-modern-enabled .guide-table-proj-number {
    font-family: 'Courier New', Courier, monospace; font-size: 12px; font-weight: 600;
    color: var(--ditio-sand-1200); background: var(--ditio-sand-300);
    padding: 2px 6px; border-radius: 2px; white-space: nowrap;
}

/* ==========================================================================
   Invoice Redesign - Creation Wizard
   ========================================================================== */

.wizard-steps { display: flex; gap: 0; margin-bottom: 24px; border-bottom: 2px solid var(--ditio-sand-300); }
.wizard-step { flex: 1; text-align: center; padding: 12px 8px; position: relative; cursor: default; }
.wizard-step-number {
    width: 28px; height: 28px; border-radius: 50%; display: inline-flex;
    align-items: center; justify-content: center; border: 2px solid var(--ditio-sand-400);
    font-size: 13px; font-weight: 600; color: var(--ditio-sand-900); margin-bottom: 4px;
}
.wizard-step.active .wizard-step-number { background: var(--ditio-green-700); color: #fff; border-color: var(--ditio-green-700); }
.wizard-step.completed .wizard-step-number { background: var(--ditio-green-700); color: #fff; border-color: var(--ditio-green-700); }
.wizard-step-label { display: block; font-size: 11px; color: var(--ditio-sand-900); text-transform: uppercase; letter-spacing: 0.3px; }
.wizard-step.active .wizard-step-label { color: var(--ditio-sand-1200); font-weight: 600; }
.wizard-step.completed .wizard-step-label { color: var(--ditio-green-700); }

/* Wizard review card */
.wizard-review-card { background: var(--ditio-sand-100); border: 1px solid var(--ditio-sand-400); border-radius: 4px; padding: 16px; }
.wizard-review-item { display: flex; justify-content: space-between; padding: 8px 0; border-bottom: 1px solid var(--ditio-sand-300); }
.wizard-review-item:last-child { border-bottom: none; }
.wizard-review-label { font-size: 12px; color: var(--ditio-sand-900); text-transform: uppercase; }
.wizard-review-value { font-size: 13px; color: var(--ditio-sand-1200); font-weight: 500; }

/* ==========================================================================
   Invoice Redesign - Detail Page Zones
   ========================================================================== */

.invoice-identity-bar {
    display: flex; justify-content: space-between; align-items: center;
    padding: 12px 16px; background: #fff; border: 1px solid var(--ditio-sand-300);
    border-radius: 4px; margin-bottom: 16px;
}
.invoice-identity-left { display: flex; align-items: center; gap: 12px; }
.invoice-number { font-size: 18px; font-weight: 700; color: var(--ditio-sand-1200); }
.invoice-title-inline {
    border: none; border-bottom: 1px dashed var(--ditio-sand-400);
    background: transparent; font-size: 16px; font-weight: 600;
    padding: 2px 4px; width: 300px;
}
.invoice-title-inline:focus { border-bottom-color: var(--ditio-green-700); outline: none; }
.invoice-title-inline:disabled { border-bottom: none; color: var(--ditio-sand-1200); }

.invoice-setup-card {
    background: var(--ditio-sand-100);
    border: 1px solid var(--ditio-sand-300); border-left: 3px solid var(--ditio-green-700);
    border-radius: 4px; padding: 16px 20px; margin-bottom: 16px;
}
.invoice-setup-header { display: flex; justify-content: space-between; align-items: center; margin-bottom: 12px; }
.invoice-setup-header h5 { margin: 0; font-size: 14px; font-weight: 600; color: var(--ditio-sand-1200); }
.invoice-setup-body { display: grid; grid-template-columns: repeat(auto-fill, minmax(200px, 1fr)); gap: 12px 24px; }
.setup-item { display: flex; flex-direction: column; gap: 2px; }
.setup-label { font-size: 11px; text-transform: uppercase; color: var(--ditio-sand-900); letter-spacing: 0.5px; }
.setup-value { font-size: 13px; color: var(--ditio-sand-1200); font-weight: 500; }
.setup-value a { color: var(--ditio-primary-600); }

/* Lookback period badge in invoice list */
.ditio-modern-enabled .invoice-lookback-badge {
    display: inline-block;
    margin-left: 4px;
    padding: 1px 5px;
    font-size: 10px;
    font-weight: 600;
    line-height: 1.4;
    color: var(--ditio-sand-900);
    background-color: var(--ditio-sand-300);
    border-radius: var(--ditio-radius-sm);
    vertical-align: middle;
}

/* Collapsed datasource summary text */
.ditio-modern-enabled .invoice-datasource-summary {
    font-size: 12px;
    color: var(--ditio-sand-900);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    max-width: 500px;
}

/* Setup Wizard Modal */
.ditio-modern-enabled .setup-wizard-steps {
    display: flex;
    justify-content: center;
    gap: 8px;
    margin-bottom: 20px;
}

.ditio-modern-enabled .setup-wizard-steps .step-dot {
    width: 10px;
    height: 10px;
    border-radius: 50%;
    background: var(--ditio-sand-600);
    transition: background 0.2s;
}

.ditio-modern-enabled .setup-wizard-steps .step-dot.active {
    background: var(--ditio-primary-600);
}

.ditio-modern-enabled .setup-wizard-step-panel .form-group {
    margin-bottom: 15px;
}

.ditio-modern-enabled .setup-wizard-project-list .label {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    margin-right: 4px;
    margin-bottom: 4px;
    padding: 5px 10px;
    font-weight: normal;
}

.ditio-modern-enabled .setup-wizard-project-list .label .fa-times {
    cursor: pointer;
    opacity: 0.6;
}

.ditio-modern-enabled .setup-wizard-project-list .label .fa-times:hover {
    opacity: 1;
}

/* ==========================================================================
   Checkbox Label Styles — reusable across invoice templates
   ========================================================================== */

/* Shared base — flex layout, pointer, consistent input sizing */
label.cb-label {
    display: flex;
    align-items: center;
    gap: 6px;
    cursor: pointer;
}
label.cb-label input[type="checkbox"] {
    margin: 0;
    width: 16px;
    height: 16px;
}

/* Normal / toned-down checkbox — gray background */
label.cb-normal {
    padding: 8px 14px;
    background: #f8f9fa;
    border-radius: 6px;
    font-weight: 500;
    color: #495057;
    border: 1px solid #e9ecef;
}

/* Standout / prominent checkbox — blue background */
label.cb-standout {
    padding: 10px 14px;
    background: #e7f3ff;
    border-radius: 6px;
    font-weight: 500;
    color: #0066cc;
    border: 1px solid #b3d7ff;
}

/* Invoice metadata zone */
.invoice-metadata-zone { padding: 16px 0; }
.invoice-metadata-zone .form-group { margin-bottom: 12px; }