/* ========== WARM PRO — Admin-only theme overlay ========== */
/* Scoped entirely to body.admin-mode — does not affect user or support roles */

/* 1. Font import */
@import url('https://fonts.googleapis.com/css2?family=Manrope:wght@400;500;600;700;800&display=swap');

/* ============================================================
   2. CSS variable overrides — light theme (default)
   ============================================================ */
body.admin-mode {
    /* Warm Pro tokens */
    --wp-bg:           #faf4ec;
    --wp-surface:      #ffffff;
    --wp-card:         #ffffff;
    --wp-sidebar:      #f3eadf;
    --wp-inset:        #f6efe5;
    --wp-hover:        #f3ebde;
    --wp-border:       #ebe0d0;
    --wp-line:         #f0e8dc;
    --wp-text:         #2a241d;
    --wp-muted:        #857667;
    --wp-subtle:       #a89a89;
    --wp-teal:         #0e9c95;
    --wp-tealD:        #0a7a74;
    --wp-tealSoft:     #d6f1ee;
    --wp-peach:        #f08a52;
    --wp-peachD:       #dd7038;
    --wp-peachSoft:    #fce3d2;
    --wp-violet:       #8a6fd6;
    --wp-violetSoft:   #ece5fa;
    --wp-good:         #3da06f;
    --wp-goodSoft:     #dcf0e4;
    --wp-warn:         #dd9b34;
    --wp-warnSoft:     #fbedd2;
    --wp-danger:       #e0664f;
    --wp-dangerSoft:   #fbe1da;
    --wp-shadow:       0 1px 2px rgba(90,60,30,.04), 0 10px 30px rgba(90,60,30,.07);
    --wp-shadowS:      0 1px 2px rgba(90,60,30,.05);
    --wp-glow:         0 8px 20px rgba(14,156,149,.28);
    --wp-gradient:     linear-gradient(135deg, #0e9c95, #f08a52);

    /* Override existing CRM variables to Warm Pro palette */
    --dark-bg:           var(--wp-bg);
    --dark-card:         var(--wp-card);
    --dark-card-hover:   var(--wp-hover);
    --text-primary:      var(--wp-text);
    --text-secondary:    var(--wp-muted);
    --accent:            var(--wp-teal);
    --success:           var(--wp-good);
    --danger:            var(--wp-danger);
    --warning:           var(--wp-warn);
    --border:            var(--wp-border);
    --border-accent:     var(--wp-tealSoft);
    --page-bg:           var(--wp-bg);
    --shell-surface:     var(--wp-surface);
    --sidebar-surface:   var(--wp-sidebar);
    --header-surface:    var(--wp-surface);
    --main-surface:      var(--wp-bg);
    --nav-muted:         var(--wp-muted);
    --nav-hover-bg:      var(--wp-hover);
    --nav-active-bg:     var(--wp-tealSoft);
    --pill-bg:           var(--wp-inset);
    --input-bg:          var(--wp-inset);
    --muted-surface:     var(--wp-inset);
    --table-header-bg:   var(--wp-inset);
    --table-row-hover:   var(--wp-hover);
    --table-total-bg:    var(--wp-tealSoft);
    --chip-bg:           var(--wp-inset);
    --primary-gradient:  var(--wp-gradient);

    background: var(--wp-bg);
    color: var(--wp-text);
}

/* ============================================================
   3. Dark theme overrides
   ============================================================ */
html[data-theme="dark"] body.admin-mode {
    --wp-bg:           #191410;
    --wp-surface:      #241e17;
    --wp-card:         #272016;
    --wp-sidebar:      #1f1912;
    --wp-inset:        #221c14;
    --wp-hover:        #2e2619;
    --wp-border:       #372f24;
    --wp-line:         #2e2719;
    --wp-text:         #f4ecdd;
    --wp-muted:        #a99b87;
    --wp-subtle:       #7c6e5b;
    --wp-teal:         #2fc4bd;
    --wp-tealD:        #27a8a2;
    --wp-tealSoft:     #0e3a38;
    --wp-peach:        #f2965f;
    --wp-peachD:       #e07a40;
    --wp-peachSoft:    #3c2a1c;
    --wp-violet:       #a98fe8;
    --wp-violetSoft:   #2a2342;
    --wp-good:         #5fc488;
    --wp-goodSoft:     #1b3527;
    --wp-warn:         #e8b75a;
    --wp-warnSoft:     #3a2e16;
    --wp-danger:       #ef8068;
    --wp-dangerSoft:   #3a201a;
    --wp-shadow:       0 2px 14px rgba(0,0,0,.35);
    --wp-shadowS:      0 1px 4px rgba(0,0,0,.28);
    --wp-glow:         0 8px 20px rgba(47,196,189,.22);
    --wp-gradient:     linear-gradient(135deg, #2fc4bd, #f2965f);
}

/* ============================================================
   4. App shell
   ============================================================ */
body.admin-mode .screen.active .app-shell {
    border: 1px solid var(--wp-border);
    border-radius: 16px;
    box-shadow: var(--wp-shadow);
    background: var(--wp-surface);
    overflow: hidden;
}

html[data-theme="dark"] body.admin-mode .screen.active .app-shell {
    box-shadow: var(--wp-shadow);
}

/* ============================================================
   5. Sidebar — admin only
   ============================================================ */
body.admin-mode .sidebar-admin {
    width: 236px;
    min-width: 236px;
    background: var(--wp-sidebar);
    border-right: 1px solid var(--wp-border);
    flex-direction: column;
}

/* Logo area */
body.admin-mode .sidebar-admin .sidebar-logo {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 18px 16px;
    border-bottom: 1px solid var(--wp-border);
    font-family: 'Manrope', 'Inter', sans-serif;
    font-weight: 800;
    font-size: 1rem;
    letter-spacing: -0.4px;
    color: var(--wp-text);
}

body.admin-mode .sidebar-admin .sidebar-logo::before {
    content: '⚡';
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 36px;
    height: 36px;
    border-radius: 12px;
    background: var(--wp-gradient);
    font-size: 18px;
    flex-shrink: 0;
    box-shadow: var(--wp-glow);
}

body.admin-mode .sidebar-admin .sidebar-logo span {
    color: var(--wp-teal);
}

/* Nav container — white card wrapping nav items */
body.admin-mode .sidebar-admin .sidebar-nav {
    flex: 1;
    padding: 12px 10px;
    overflow-y: auto;
}

body.admin-mode .sidebar-admin .nav-section {
    background: var(--wp-surface);
    border: 1px solid var(--wp-border);
    border-radius: 16px;
    padding: 8px;
    margin-bottom: 10px;
    box-shadow: var(--wp-shadowS);
}

/* Nav section title */
body.admin-mode .sidebar-admin .nav-section-title {
    font-size: 10px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 1.4px;
    color: var(--wp-subtle);
    padding: 4px 10px 6px;
    margin-bottom: 2px;
}

/* Nav items */
body.admin-mode .sidebar-admin .nav-item {
    font-size: 13.5px;
    font-weight: 500;
    border-radius: 11px;
    padding: 9px 12px;
    gap: 11px;
    color: var(--wp-muted);
    transition: background 0.15s, color 0.15s, box-shadow 0.15s;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    margin-bottom: 1px;
}

body.admin-mode .sidebar-admin .nav-item:hover {
    background: var(--wp-hover);
    color: var(--wp-text);
    box-shadow: none;
}

body.admin-mode .sidebar-admin .nav-item.active {
    background: var(--wp-gradient);
    color: #ffffff;
    font-weight: 700;
    box-shadow: var(--wp-glow);
}

body.admin-mode .sidebar-admin .nav-item .icon {
    font-size: 1.1rem;
    opacity: 1;
}

/* Sidebar footer */
body.admin-mode .sidebar-admin .sidebar-footer {
    padding: 12px 10px;
    border-top: 1px solid var(--wp-border);
}

body.admin-mode .sidebar-admin .sidebar-footer .user-pill {
    background: var(--wp-surface);
    border: 1px solid var(--wp-border);
    border-radius: 14px;
    padding: 11px 13px;
    box-shadow: var(--wp-shadowS);
    gap: 10px;
    color: var(--wp-muted);
    font-size: 13px;
}

body.admin-mode .sidebar-admin .sidebar-footer .user-pill .avatar {
    width: 34px;
    height: 34px;
    border-radius: 11px;
    background: linear-gradient(135deg, #f08a52, #0e9c95);
    color: #ffffff;
    font-weight: 800;
    font-size: 13px;
    font-family: 'Manrope', 'Inter', sans-serif;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}

body.admin-mode .sidebar-admin .sidebar-footer .user-pill .logout-link {
    color: var(--wp-danger);
    font-weight: 600;
    font-size: 12px;
}

body.admin-mode .sidebar-admin .sidebar-footer .user-pill .logout-link:hover {
    text-decoration: underline;
    color: var(--wp-dangerSoft);
}

/* Fix hardcoded color on admin name text */
body.admin-mode .sidebar-admin .sidebar-footer .user-pill div div[style] {
    color: var(--wp-text) !important;
}

/* ============================================================
   6. Main content area (next to admin sidebar)
   ============================================================ */
body.admin-mode .sidebar-admin ~ .main {
    background: var(--wp-bg);
}

/* Main header */
body.admin-mode .sidebar-admin ~ .main .main-header {
    background: var(--wp-surface);
    border-bottom: 1px solid var(--wp-border);
    padding: 20px 28px;
}

body.admin-mode .sidebar-admin ~ .main .main-header h1,
body.admin-mode .sidebar-admin ~ .main .main-header h2 {
    font-family: 'Manrope', 'Inter', sans-serif;
    font-size: 23px;
    font-weight: 800;
    letter-spacing: -0.5px;
    color: var(--wp-text);
}

body.admin-mode .sidebar-admin ~ .main .main-header p {
    font-size: 13px;
    color: var(--wp-muted);
    margin-top: 3px;
}

/* Content section title */
body.admin-mode .sidebar-admin ~ .main .content-section-title {
    font-family: 'Manrope', 'Inter', sans-serif;
    font-size: 12px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.8px;
    color: var(--wp-teal);
    margin-bottom: 14px;
}

/* ============================================================
   7. Stat cards
   ============================================================ */
body.admin-mode .sidebar-admin ~ .main .stat-card {
    background: var(--wp-card);
    border: 1px solid var(--wp-border);
    border-radius: 18px;
    box-shadow: var(--wp-shadowS);
    padding: 16px 18px;
    transition: border-color 0.2s, box-shadow 0.2s;
    position: relative;
}

body.admin-mode .sidebar-admin ~ .main .stat-card:hover {
    border-color: var(--wp-teal);
    box-shadow: var(--wp-shadow);
    transform: none;
}

/* Hide the left accent bar */
body.admin-mode .stat-card::before {
    display: none !important;
}

/* Stat icon badge */
body.admin-mode .sidebar-admin ~ .main .stat-card .stat-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 38px;
    height: 38px;
    border-radius: 12px;
    background: var(--wp-tealSoft);
    font-size: 1.2rem;
    margin-bottom: 10px;
}

/* Stat value */
body.admin-mode .sidebar-admin ~ .main .stat-card .stat-value {
    font-family: 'Manrope', 'Inter', sans-serif;
    font-size: 27px;
    font-weight: 800;
    letter-spacing: -0.6px;
    font-variant-numeric: tabular-nums;
    color: var(--wp-text);
    line-height: 1.1;
    margin-bottom: 4px;
}

/* Stat label */
body.admin-mode .sidebar-admin ~ .main .stat-card .stat-label {
    font-size: 12.5px;
    color: var(--wp-muted);
    font-weight: 500;
}

/* ============================================================
   8. Buttons
   ============================================================ */
/* Primary button */
body.admin-mode .sidebar-admin ~ .main .btn-primary,
body.admin-mode .sidebar-admin ~ .main .admin-form-section .btn-primary {
    background: var(--wp-gradient);
    color: #ffffff;
    border-radius: 12px;
    border: none;
    box-shadow: var(--wp-glow);
    width: auto;
    padding: 11px 22px;
    font-weight: 700;
    font-size: 13.5px;
    transition: opacity 0.2s, box-shadow 0.2s;
}

body.admin-mode .sidebar-admin ~ .main .btn-primary:hover,
body.admin-mode .sidebar-admin ~ .main .admin-form-section .btn-primary:hover {
    opacity: 0.88;
    box-shadow: 0 12px 28px rgba(14,156,149,.35);
    background: var(--wp-gradient);
}

/* Secondary button */
body.admin-mode .sidebar-admin ~ .main .btn-secondary {
    background: var(--wp-inset);
    color: var(--wp-text);
    border: 1px solid var(--wp-border);
    border-radius: 12px;
    width: auto;
    font-weight: 600;
    font-size: 13.5px;
}

body.admin-mode .sidebar-admin ~ .main .btn-secondary:hover {
    background: var(--wp-hover);
    border-color: var(--wp-teal);
    box-shadow: none;
}

/* Back / Logout buttons */
body.admin-mode .sidebar-admin ~ .main .btn-back,
body.admin-mode .sidebar-admin ~ .main .btn-logout {
    background: var(--wp-dangerSoft);
    color: var(--wp-danger);
    border: 1px solid transparent;
    border-radius: 12px;
    width: auto;
    font-weight: 700;
    padding: 10px 20px;
    box-shadow: none;
}

body.admin-mode .sidebar-admin ~ .main .btn-back:hover,
body.admin-mode .sidebar-admin ~ .main .btn-logout:hover {
    background: var(--wp-danger);
    color: #ffffff;
    box-shadow: none;
}

/* Search button */
body.admin-mode .sidebar-admin ~ .main .btn-search {
    background: var(--wp-gradient);
    color: #ffffff;
    border-radius: 12px;
    border: none;
    box-shadow: var(--wp-glow);
    font-weight: 700;
    font-size: 13.5px;
    transition: opacity 0.2s, box-shadow 0.2s;
}

body.admin-mode .sidebar-admin ~ .main .btn-search:hover {
    opacity: 0.88;
    box-shadow: 0 12px 28px rgba(14,156,149,.35);
}

/* ============================================================
   9. Form inputs and selects
   ============================================================ */
body.admin-mode .sidebar-admin ~ .main .form-group input,
body.admin-mode .sidebar-admin ~ .main .form-group select {
    background: var(--wp-inset);
    border: 1.5px solid var(--wp-border);
    border-radius: 11px;
    color: var(--wp-text);
    font-size: 13.5px;
    transition: border-color 0.2s, box-shadow 0.2s;
}

body.admin-mode .sidebar-admin ~ .main .form-group input::placeholder {
    color: var(--wp-subtle);
    opacity: 1;
}

body.admin-mode .sidebar-admin ~ .main .form-group input:focus,
body.admin-mode .sidebar-admin ~ .main .form-group select:focus {
    outline: none;
    border-color: var(--wp-teal);
    box-shadow: 0 0 0 3px rgba(14,156,149,.14);
}

body.admin-mode .sidebar-admin ~ .main .form-group select option {
    background: var(--wp-inset);
    color: var(--wp-text);
}

/* Form-group labels */
body.admin-mode .sidebar-admin ~ .main .form-group label {
    font-size: 12.5px;
    font-weight: 600;
    color: var(--wp-text);
    opacity: 1;
}

/* ============================================================
   10. Data tables (.data-table)
   ============================================================ */
body.admin-mode .sidebar-admin ~ .main .data-table {
    border-collapse: collapse;
    width: 100%;
    font-size: 13px;
}

body.admin-mode .sidebar-admin ~ .main .data-table thead th {
    background: var(--wp-inset);
    text-transform: uppercase;
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.4px;
    color: var(--wp-subtle);
    border-bottom: 1px solid var(--wp-line);
    padding: 10px 16px;
}

body.admin-mode .sidebar-admin ~ .main .data-table tbody tr {
    border-bottom: 1px solid var(--wp-line);
    transition: background 0.15s;
}

body.admin-mode .sidebar-admin ~ .main .data-table tbody tr:nth-child(even) {
    background: transparent;
}

body.admin-mode .sidebar-admin ~ .main .data-table tbody tr:hover {
    background: var(--wp-hover);
}

body.admin-mode .sidebar-admin ~ .main .data-table tbody td {
    padding: 12px 16px;
    color: var(--wp-text);
    border: none;
    border-bottom: 1px solid var(--wp-line);
    vertical-align: middle;
}

body.admin-mode .sidebar-admin ~ .main .data-table tfoot tr,
body.admin-mode .sidebar-admin ~ .main .data-table .table-total {
    background: var(--wp-tealSoft);
    font-weight: 700;
}

/* ============================================================
   11. Contract items (.contract-item)
   ============================================================ */
body.admin-mode .sidebar-admin ~ .main .contract-item {
    border-radius: 18px;
    border: 1px solid var(--wp-border);
    border-left: 1px solid var(--wp-border);
    box-shadow: var(--wp-shadowS);
    background: var(--wp-card);
    margin-bottom: 10px;
    transition: border-color 0.2s, box-shadow 0.2s;
}

body.admin-mode .sidebar-admin ~ .main .contract-item:hover {
    border-color: var(--wp-teal);
    box-shadow: var(--wp-shadow);
}

/* Remove the left colored bar on contract items */
body.admin-mode .sidebar-admin ~ .main .contract-item::before,
body.admin-mode .sidebar-admin ~ .main .contract-item > *:first-child::before {
    display: none !important;
    border-left: none !important;
}

/* ============================================================
   12. Partner stat cards (.partner-stat-card, .partner-card)
   ============================================================ */
body.admin-mode .sidebar-admin ~ .main .partner-stat-card,
body.admin-mode .sidebar-admin ~ .main .partner-card {
    background: var(--wp-card);
    border: 1px solid var(--wp-border);
    border-radius: 18px;
    box-shadow: var(--wp-shadowS);
    transition: border-color 0.2s, box-shadow 0.2s;
}

body.admin-mode .sidebar-admin ~ .main .partner-stat-card:hover,
body.admin-mode .sidebar-admin ~ .main .partner-card:hover {
    border-color: var(--wp-teal);
    box-shadow: var(--wp-shadow);
}

/* ============================================================
   13. Admin users list (.user-item)
   ============================================================ */
body.admin-mode .sidebar-admin ~ .main .user-item {
    background: var(--wp-inset);
    border-radius: 13px;
    border: none;
    margin-bottom: 8px;
    transition: background 0.15s;
}

body.admin-mode .sidebar-admin ~ .main .user-item:hover {
    background: var(--wp-hover);
}

/* ============================================================
   14. Weekly settlement table (inside admin context)
   ============================================================ */
body.admin-mode .sidebar-admin ~ .main .settlement-table thead th,
body.admin-mode .sidebar-admin ~ .main table.weekly-table thead th {
    background: var(--wp-inset);
    text-transform: uppercase;
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.4px;
    color: var(--wp-subtle);
    border-bottom: 1px solid var(--wp-line);
}

body.admin-mode .sidebar-admin ~ .main .settlement-table tbody tr,
body.admin-mode .sidebar-admin ~ .main table.weekly-table tbody tr {
    border-bottom: 1px solid var(--wp-line);
}

body.admin-mode .sidebar-admin ~ .main .settlement-table tbody tr:hover,
body.admin-mode .sidebar-admin ~ .main table.weekly-table tbody tr:hover {
    background: var(--wp-hover);
}

/* ============================================================
   15. Admin form sections
   ============================================================ */
body.admin-mode .sidebar-admin ~ .main .admin-form-section {
    background: var(--wp-card);
    border: 1px solid var(--wp-border);
    border-radius: 18px;
    box-shadow: var(--wp-shadowS);
    padding: 24px;
    margin-bottom: 20px;
}

body.admin-mode .sidebar-admin ~ .main .admin-form-section h3 {
    font-family: 'Manrope', 'Inter', sans-serif;
    font-size: 15px;
    font-weight: 700;
    color: var(--wp-text);
    letter-spacing: -0.3px;
    margin-bottom: 18px;
}

body.admin-mode .sidebar-admin ~ .main .admin-list-section {
    background: var(--wp-card);
    border: 1px solid var(--wp-border);
    border-radius: 18px;
    box-shadow: var(--wp-shadowS);
    padding: 24px;
    margin-bottom: 20px;
}

body.admin-mode .sidebar-admin ~ .main .admin-list-section h3 {
    font-family: 'Manrope', 'Inter', sans-serif;
    font-size: 15px;
    font-weight: 700;
    color: var(--wp-text);
    letter-spacing: -0.3px;
    margin-bottom: 18px;
}

/* ============================================================
   16. Status chips / pills
   ============================================================ */
body.admin-mode .sidebar-admin ~ .main .status-chip,
body.admin-mode .sidebar-admin ~ .main .status-badge,
body.admin-mode .sidebar-admin ~ .main [class*="chip-"],
body.admin-mode .sidebar-admin ~ .main [class*="badge-"] {
    border-radius: 99px;
    padding: 3px 10px;
    font-size: 12px;
    font-weight: 600;
}

/* ============================================================
   17. Stats grid layout
   ============================================================ */
body.admin-mode .sidebar-admin ~ .main .stats-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
    gap: 14px;
    margin-bottom: 24px;
}

/* ============================================================
   18. Menu buttons (dashboard quick actions)
   ============================================================ */
body.admin-mode .sidebar-admin ~ .main .menu-btn {
    background: var(--wp-card);
    border: 1px solid var(--wp-border);
    border-radius: 14px;
    color: var(--wp-text);
    box-shadow: var(--wp-shadowS);
    transition: border-color 0.2s, box-shadow 0.2s, background 0.2s;
}

body.admin-mode .sidebar-admin ~ .main .menu-btn:hover {
    background: var(--wp-hover);
    border-color: var(--wp-teal);
    box-shadow: var(--wp-shadow);
}

/* ============================================================
   19. Load-from-sheets status box and similar info boxes
   ============================================================ */
body.admin-mode .sidebar-admin ~ .main #load-from-sheets-status {
    background: var(--wp-inset);
    border: 1px solid var(--wp-border);
    border-radius: 12px;
}

/* ============================================================
   20. Checkbox select-all row
   ============================================================ */
body.admin-mode .sidebar-admin ~ .main #select-all-contracts,
body.admin-mode .sidebar-admin ~ .main [id="select-all-contracts"] {
    accent-color: var(--wp-teal);
}

body.admin-mode .sidebar-admin ~ .main div:has(#select-all-contracts) {
    background: var(--wp-inset);
    border: 1px solid var(--wp-border);
    border-radius: 11px;
}

/* ============================================================
   21. Dark mode — specific component overrides
   ============================================================ */
html[data-theme="dark"] body.admin-mode .sidebar-admin ~ .main .admin-form-section,
html[data-theme="dark"] body.admin-mode .sidebar-admin ~ .main .admin-list-section {
    background: var(--wp-card);
    border-color: var(--wp-border);
}

html[data-theme="dark"] body.admin-mode .sidebar-admin ~ .main .stat-card {
    background: var(--wp-card);
    border-color: var(--wp-border);
}

html[data-theme="dark"] body.admin-mode .sidebar-admin ~ .main .contract-item {
    background: var(--wp-card);
    border-color: var(--wp-border);
}

html[data-theme="dark"] body.admin-mode .sidebar-admin ~ .main .menu-btn {
    background: var(--wp-card);
    border-color: var(--wp-border);
}

html[data-theme="dark"] body.admin-mode .sidebar-admin .nav-section {
    background: var(--wp-card);
    border-color: var(--wp-border);
}

html[data-theme="dark"] body.admin-mode .sidebar-admin .sidebar-footer .user-pill {
    background: var(--wp-card);
    border-color: var(--wp-border);
}

html[data-theme="dark"] body.admin-mode .screen.active .app-shell {
    border-color: var(--wp-border);
}

/* ============================================================
   22. Scrollbar styling (admin sidebar nav)
   ============================================================ */
body.admin-mode .sidebar-admin .sidebar-nav::-webkit-scrollbar {
    width: 4px;
}
body.admin-mode .sidebar-admin .sidebar-nav::-webkit-scrollbar-track {
    background: transparent;
}
body.admin-mode .sidebar-admin .sidebar-nav::-webkit-scrollbar-thumb {
    background: var(--wp-border);
    border-radius: 99px;
}
body.admin-mode .sidebar-admin .sidebar-nav::-webkit-scrollbar-thumb:hover {
    background: var(--wp-muted);
}

/* ============================================================
   DASHBOARD — Warm Pro layout components
   ============================================================ */

/* Header */
body.admin-mode .sidebar-admin ~ .main .wp-main-header {
    padding: 20px 28px 12px;
    border-bottom: none;
    background: transparent;
}
body.admin-mode .sidebar-admin ~ .main .wp-main-header h1 {
    font-family: 'Manrope', sans-serif;
    font-size: 23px;
    font-weight: 800;
    letter-spacing: -0.5px;
    color: var(--wp-text);
    margin-bottom: 0;
}
body.admin-mode .sidebar-admin ~ .main .wp-main-header p {
    font-size: 13px;
    color: var(--wp-muted);
    margin-top: 3px;
}

/* Dashboard content area */
body.admin-mode .sidebar-admin ~ .main .wp-dashboard-content {
    padding: 0 28px 28px;
    display: flex;
    flex-direction: column;
    gap: 16px;
}

/* KPI row — 4 cards */
body.admin-mode .sidebar-admin ~ .main .wp-kpi-row {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 14px;
}

body.admin-mode .sidebar-admin ~ .main .wp-kpi-card {
    background: var(--wp-card);
    border: 1px solid var(--wp-border);
    border-radius: 18px;
    box-shadow: var(--wp-shadowS);
    padding: 16px 18px;
    display: flex;
    flex-direction: column;
    transition: box-shadow 0.2s, border-color 0.2s;
}
body.admin-mode .sidebar-admin ~ .main .wp-kpi-card:hover {
    box-shadow: var(--wp-shadow);
    border-color: var(--wp-border);
}

body.admin-mode .sidebar-admin ~ .main .wp-kpi-top {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 10px;
}

body.admin-mode .sidebar-admin ~ .main .wp-kpi-badge {
    width: 38px;
    height: 38px;
    border-radius: 12px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 18px;
    flex-shrink: 0;
}

body.admin-mode .sidebar-admin ~ .main .wp-kpi-num {
    font-family: 'Manrope', sans-serif;
    font-size: 27px;
    font-weight: 800;
    letter-spacing: -0.6px;
    font-variant-numeric: tabular-nums;
    color: var(--wp-text);
    line-height: 1.1;
    margin-bottom: 3px;
}

body.admin-mode .sidebar-admin ~ .main .wp-kpi-lbl {
    font-size: 12.5px;
    color: var(--wp-muted);
    font-weight: 500;
}

/* Sparkline SVG in KPI card */
body.admin-mode .sidebar-admin ~ .main .wp-spark {
    display: block;
    width: 100%;
    height: 30px;
    margin-top: 8px;
    overflow: visible;
}

/* Mid row: chart + events (1.7fr 1fr) */
body.admin-mode .sidebar-admin ~ .main .wp-mid-row {
    display: grid;
    grid-template-columns: 1.7fr 1fr;
    gap: 16px;
}

/* Bot row: partners + quick actions (1fr 1fr) */
body.admin-mode .sidebar-admin ~ .main .wp-bot-row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 16px;
}

/* Generic card */
body.admin-mode .sidebar-admin ~ .main .wp-card {
    background: var(--wp-card);
    border: 1px solid var(--wp-border);
    border-radius: 18px;
    box-shadow: var(--wp-shadowS);
    overflow: hidden;
}

body.admin-mode .sidebar-admin ~ .main .wp-card-head {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    padding: 18px 20px 12px;
}

body.admin-mode .sidebar-admin ~ .main .wp-card-title {
    font-family: 'Manrope', sans-serif;
    font-size: 15px;
    font-weight: 700;
    color: var(--wp-text);
    padding: 18px 20px 0;
}

body.admin-mode .sidebar-admin ~ .main .wp-card-sub {
    font-size: 12.5px;
    color: var(--wp-muted);
    margin-top: 3px;
}

body.admin-mode .sidebar-admin ~ .main .wp-link {
    font-size: 12px;
    color: var(--wp-tealD);
    font-weight: 700;
    cursor: pointer;
    white-space: nowrap;
    padding: 18px 20px 0;
}

/* Main sparkline chart */
body.admin-mode .sidebar-admin ~ .main .wp-main-spark {
    display: block;
    width: calc(100% - 40px);
    height: 120px;
    margin: 10px 20px 0;
    overflow: visible;
}

body.admin-mode .sidebar-admin ~ .main .wp-spark-labels {
    display: flex;
    justify-content: space-between;
    padding: 6px 20px 16px;
    font-size: 11px;
    color: var(--wp-subtle);
}

/* Recent events list */
body.admin-mode .sidebar-admin ~ .main .wp-events-list {
    display: flex;
    flex-direction: column;
    gap: 0;
    padding: 4px 0 4px;
}

body.admin-mode .sidebar-admin ~ .main .wp-event-row {
    display: flex;
    align-items: center;
    gap: 11px;
    padding: 10px 18px;
    transition: background 0.15s;
}

body.admin-mode .sidebar-admin ~ .main .wp-event-row:hover {
    background: var(--wp-hover);
}

body.admin-mode .sidebar-admin ~ .main .wp-event-icon {
    width: 34px;
    height: 34px;
    border-radius: 11px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 15px;
    flex-shrink: 0;
}

body.admin-mode .sidebar-admin ~ .main .wp-event-main {
    font-size: 12.5px;
    font-weight: 600;
    color: var(--wp-text);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

body.admin-mode .sidebar-admin ~ .main .wp-event-sub {
    font-size: 11.5px;
    color: var(--wp-muted);
    margin-top: 1px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

body.admin-mode .sidebar-admin ~ .main .wp-event-time {
    font-size: 11px;
    color: var(--wp-subtle);
    font-weight: 600;
    white-space: nowrap;
    margin-left: auto;
    flex-shrink: 0;
}

/* Top partners list */
body.admin-mode .sidebar-admin ~ .main .wp-partners-list {
    padding: 0 20px 18px;
    display: flex;
    flex-direction: column;
    gap: 13px;
}

body.admin-mode .sidebar-admin ~ .main .wp-partner-row {
    display: flex;
    align-items: center;
    gap: 12px;
}

body.admin-mode .sidebar-admin ~ .main .wp-partner-avatar {
    width: 36px;
    height: 36px;
    border-radius: 11px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 11.5px;
    font-weight: 800;
    font-family: 'Manrope', sans-serif;
    color: #fff;
    flex-shrink: 0;
    background: var(--wp-gradient);
}

body.admin-mode .sidebar-admin ~ .main .wp-partner-info {
    flex: 1;
    min-width: 0;
}

body.admin-mode .sidebar-admin ~ .main .wp-partner-name {
    font-size: 12.5px;
    font-weight: 600;
    color: var(--wp-text);
    display: flex;
    justify-content: space-between;
    margin-bottom: 4px;
}

body.admin-mode .sidebar-admin ~ .main .wp-partner-bar-bg {
    height: 6px;
    background: var(--wp-hover);
    border-radius: 99px;
    overflow: hidden;
}

body.admin-mode .sidebar-admin ~ .main .wp-partner-bar-fill {
    height: 100%;
    border-radius: 99px;
    background: var(--wp-gradient);
}

/* Quick actions */
body.admin-mode .sidebar-admin ~ .main .wp-qa-card {
    padding: 18px 20px;
}

body.admin-mode .sidebar-admin ~ .main .wp-qa-card .wp-card-title {
    padding: 0;
    margin-bottom: 14px;
}

body.admin-mode .sidebar-admin ~ .main .wp-qa-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 10px;
}

body.admin-mode .sidebar-admin ~ .main .wp-qa-btn {
    all: unset;
    cursor: pointer;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 7px;
    padding: 14px 6px;
    border-radius: 14px;
    background: var(--wp-inset);
    transition: background 0.15s;
    text-align: center;
}

body.admin-mode .sidebar-admin ~ .main .wp-qa-btn:hover {
    background: var(--wp-hover);
}

body.admin-mode .sidebar-admin ~ .main .wp-qa-icon {
    width: 40px;
    height: 40px;
    border-radius: 12px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 18px;
}

body.admin-mode .sidebar-admin ~ .main .wp-qa-btn span {
    font-size: 11.5px;
    color: var(--wp-text);
    font-weight: 600;
}

/* Sidebar footer — Warm Pro user card */
body.admin-mode .sidebar-admin .wp-sidebar-user-card {
    display: flex;
    align-items: center;
    gap: 10px;
    background: var(--wp-surface);
    border: 1px solid var(--wp-border);
    border-radius: 14px;
    padding: 11px 13px;
    box-shadow: var(--wp-shadowS);
}

body.admin-mode .sidebar-admin .wp-sidebar-avatar {
    width: 34px;
    height: 34px;
    border-radius: 11px;
    background: linear-gradient(135deg, var(--wp-peach), var(--wp-teal));
    color: #fff;
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 800;
    font-size: 13px;
    font-family: 'Manrope', sans-serif;
    flex-shrink: 0;
}

body.admin-mode .sidebar-admin .wp-sidebar-info {
    flex: 1;
    min-width: 0;
}

body.admin-mode .sidebar-admin .wp-sidebar-name {
    font-size: 13px;
    font-weight: 700;
    color: var(--wp-text);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

body.admin-mode .sidebar-admin .wp-sidebar-role {
    font-size: 11px;
    color: var(--wp-muted);
    margin-top: 1px;
}

body.admin-mode .sidebar-admin .wp-theme-toggle {
    all: unset;
    cursor: pointer;
    width: 30px;
    height: 30px;
    border-radius: 9px;
    background: var(--wp-hover);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 14px;
    flex-shrink: 0;
    transition: background 0.15s;
}

body.admin-mode .sidebar-admin .wp-theme-toggle:hover {
    background: var(--wp-border);
}

/* Dark mode adjustments for new components */
html[data-theme="dark"] body.admin-mode .sidebar-admin ~ .main .wp-kpi-card,
html[data-theme="dark"] body.admin-mode .sidebar-admin ~ .main .wp-card {
    background: var(--wp-card);
    border-color: var(--wp-border);
}

html[data-theme="dark"] body.admin-mode .sidebar-admin .wp-sidebar-user-card {
    background: var(--wp-card);
    border-color: var(--wp-border);
}

/* Global filter bar */
body.admin-mode .sidebar-admin ~ .main .wp-filter-bar {
    display: flex;
    align-items: center;
    gap: 10px;
    background: var(--wp-card);
    border: 1px solid var(--wp-border);
    border-radius: 14px;
    padding: 10px 16px;
    box-shadow: var(--wp-shadowS);
}

body.admin-mode .sidebar-admin ~ .main .wp-filter-label {
    font-size: 12px;
    font-weight: 700;
    color: var(--wp-muted);
    text-transform: uppercase;
    letter-spacing: 0.5px;
    white-space: nowrap;
    padding-right: 4px;
}

body.admin-mode .sidebar-admin ~ .main .wp-filter-select {
    background: var(--wp-inset);
    border: 1px solid var(--wp-border);
    border-radius: 9px;
    color: var(--wp-text);
    font-size: 13px;
    font-weight: 600;
    padding: 6px 10px;
    cursor: pointer;
    outline: none;
    transition: border-color 0.15s;
    font-family: inherit;
}

body.admin-mode .sidebar-admin ~ .main .wp-filter-select:focus {
    border-color: var(--wp-teal);
}

body.admin-mode .sidebar-admin ~ .main .wp-type-pills {
    display: flex;
    gap: 4px;
    background: var(--wp-inset);
    border-radius: 10px;
    padding: 3px;
}

body.admin-mode .sidebar-admin ~ .main .wp-type-pill {
    all: unset;
    cursor: pointer;
    font-size: 12.5px;
    font-weight: 600;
    color: var(--wp-muted);
    padding: 5px 14px;
    border-radius: 8px;
    transition: background 0.15s, color 0.15s;
}

body.admin-mode .sidebar-admin ~ .main .wp-type-pill:hover {
    color: var(--wp-text);
}

body.admin-mode .sidebar-admin ~ .main .wp-type-pill.active {
    background: var(--wp-gradient);
    color: #fff;
    box-shadow: 0 2px 6px rgba(14,156,149,.25);
}

body.admin-mode .sidebar-admin ~ .main .wp-filter-reset {
    font-size: 12px;
    font-weight: 600;
    color: var(--wp-muted);
    cursor: pointer;
    margin-left: auto;
    padding: 4px 8px;
    border-radius: 7px;
    transition: color 0.15s, background 0.15s;
}

body.admin-mode .sidebar-admin ~ .main .wp-filter-reset:hover {
    color: var(--wp-danger);
    background: var(--wp-dangerSoft);
}

/* Period tabs */
body.admin-mode .sidebar-admin ~ .main .wp-period-tabs {
    display: flex;
    gap: 4px;
    background: var(--wp-inset);
    border-radius: 10px;
    padding: 3px;
}

body.admin-mode .sidebar-admin ~ .main .wp-period-tab {
    all: unset;
    cursor: pointer;
    font-size: 12px;
    font-weight: 600;
    color: var(--wp-muted);
    padding: 5px 12px;
    border-radius: 8px;
    transition: background 0.15s, color 0.15s;
    white-space: nowrap;
}

body.admin-mode .sidebar-admin ~ .main .wp-period-tab:hover {
    color: var(--wp-text);
}

body.admin-mode .sidebar-admin ~ .main .wp-period-tab.active {
    background: var(--wp-card);
    color: var(--wp-tealD);
    box-shadow: 0 1px 3px rgba(90,60,30,.1);
}

/* Chart wrap — for tooltip positioning */
body.admin-mode .sidebar-admin ~ .main .wp-chart-wrap {
    position: relative;
    margin: 10px 20px 0;
}

body.admin-mode .sidebar-admin ~ .main .wp-chart-wrap .wp-main-spark {
    display: block;
    width: 100%;
    height: 130px;
    margin: 0;
    overflow: visible;
}

/* Tooltip */
body.admin-mode .sidebar-admin ~ .main .wp-chart-tooltip {
    position: absolute;
    top: 0;
    left: 0;
    display: none;
    background: var(--wp-text);
    color: var(--wp-bg);
    font-size: 12px;
    font-weight: 600;
    padding: 6px 10px;
    border-radius: 8px;
    pointer-events: none;
    white-space: nowrap;
    line-height: 1.5;
    box-shadow: 0 4px 12px rgba(0,0,0,.18);
    transform: translate(-50%, -110%);
    z-index: 10;
}

body.admin-mode .sidebar-admin ~ .main .wp-chart-tooltip::after {
    content: '';
    position: absolute;
    bottom: -4px;
    left: 50%;
    transform: translateX(-50%);
    width: 8px;
    height: 8px;
    background: var(--wp-text);
    clip-path: polygon(0 0, 100% 0, 50% 100%);
}

body.admin-mode .sidebar-admin .wp-logout-link {
    display: block;
    margin-top: 8px;
    text-align: center;
    font-size: 12px;
    font-weight: 600;
    color: var(--wp-muted);
    text-decoration: none;
    padding: 6px;
    border-radius: 9px;
    transition: background 0.15s, color 0.15s;
}

body.admin-mode .sidebar-admin .wp-logout-link:hover {
    background: var(--wp-dangerSoft);
    color: var(--wp-danger);
}

/* ============================================================
   ADMIN CONTRACTS — Two-panel layout
   ============================================================ */

body.admin-mode .sidebar-admin ~ .main .wp-contracts-content {
    padding: 0 28px 28px;
    display: flex;
    flex-direction: column;
    gap: 12px;
    height: calc(100vh - 80px);
    overflow: hidden;
}

/* Toolbar */
body.admin-mode .sidebar-admin ~ .main .wp-contracts-toolbar {
    display: flex;
    align-items: center;
    gap: 10px;
    background: var(--wp-card);
    border: 1px solid var(--wp-border);
    border-radius: 14px;
    padding: 10px 14px;
    box-shadow: var(--wp-shadowS);
    flex-shrink: 0;
}

body.admin-mode .sidebar-admin ~ .main .wp-contracts-search-wrap {
    display: flex;
    align-items: center;
    gap: 8px;
    background: var(--wp-inset);
    border: 1px solid var(--wp-border);
    border-radius: 10px;
    padding: 6px 12px;
    flex: 1;
    max-width: 340px;
    transition: border-color 0.15s;
}

body.admin-mode .sidebar-admin ~ .main .wp-contracts-search-wrap:focus-within {
    border-color: var(--wp-teal);
}

body.admin-mode .sidebar-admin ~ .main .wp-search-icon {
    font-size: 13px;
    flex-shrink: 0;
}

body.admin-mode .sidebar-admin ~ .main .wp-contracts-search {
    all: unset;
    font-size: 13px;
    color: var(--wp-text);
    width: 100%;
    font-family: inherit;
}

body.admin-mode .sidebar-admin ~ .main .wp-contracts-search::placeholder {
    color: var(--wp-subtle);
}

body.admin-mode .sidebar-admin ~ .main .wp-contracts-pills {
    flex-shrink: 0;
}

body.admin-mode .sidebar-admin ~ .main .wp-select-all-label {
    display: flex;
    align-items: center;
    gap: 7px;
    font-size: 12.5px;
    color: var(--wp-muted);
    cursor: pointer;
    font-weight: 600;
    margin-left: auto;
    white-space: nowrap;
}

/* Two-panel body */
body.admin-mode .sidebar-admin ~ .main .wp-contracts-panels {
    display: flex;
    gap: 16px;
    flex: 1;
    min-height: 0;
    overflow: hidden;
}

body.admin-mode .sidebar-admin ~ .main .wp-contracts-list-wrap {
    flex: 1;
    overflow-y: auto;
    background: var(--wp-card);
    border: 1px solid var(--wp-border);
    border-radius: 18px;
    box-shadow: var(--wp-shadowS);
}

/* Contract row */
body.admin-mode .sidebar-admin ~ .main .wp-contracts-list .wp-contract-row {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 11px 16px;
    border-bottom: 1px solid var(--wp-line);
    cursor: pointer;
    transition: background 0.12s;
    position: relative;
}

body.admin-mode .sidebar-admin ~ .main .wp-contracts-list .wp-contract-row:last-child {
    border-bottom: none;
}

body.admin-mode .sidebar-admin ~ .main .wp-contracts-list .wp-contract-row:hover {
    background: var(--wp-hover);
}

body.admin-mode .sidebar-admin ~ .main .wp-contracts-list .wp-contract-row.selected {
    background: var(--wp-tealSoft);
}

body.admin-mode .sidebar-admin ~ .main .wp-contracts-list .wp-contract-row.selected::before {
    content: '';
    position: absolute;
    left: 0;
    top: 0;
    bottom: 0;
    width: 3px;
    background: var(--wp-teal);
    border-radius: 0 3px 3px 0;
}

body.admin-mode .sidebar-admin ~ .main .wp-row-avatar {
    width: 36px;
    height: 36px;
    border-radius: 11px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 12px;
    font-weight: 800;
    font-family: 'Manrope', sans-serif;
    color: #fff;
    flex-shrink: 0;
    background: var(--wp-gradient);
}

body.admin-mode .sidebar-admin ~ .main .wp-row-main {
    flex: 1;
    min-width: 0;
}

body.admin-mode .sidebar-admin ~ .main .wp-row-name {
    font-size: 13px;
    font-weight: 700;
    color: var(--wp-text);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

body.admin-mode .sidebar-admin ~ .main .wp-row-sub {
    font-size: 11.5px;
    color: var(--wp-muted);
    margin-top: 2px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

body.admin-mode .sidebar-admin ~ .main .wp-row-right {
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    gap: 4px;
    flex-shrink: 0;
}

body.admin-mode .sidebar-admin ~ .main .wp-row-date {
    font-size: 11px;
    color: var(--wp-subtle);
    font-weight: 600;
}

body.admin-mode .sidebar-admin ~ .main .wp-type-badge {
    font-size: 10.5px;
    font-weight: 700;
    padding: 2px 8px;
    border-radius: 99px;
}

body.admin-mode .sidebar-admin ~ .main .wp-type-badge.buyout {
    background: var(--wp-peachSoft);
    color: var(--wp-peach);
}

body.admin-mode .sidebar-admin ~ .main .wp-type-badge.rent {
    background: var(--wp-tealSoft);
    color: var(--wp-tealD);
}

/* Detail panel */
body.admin-mode .sidebar-admin ~ .main .wp-contract-detail {
    width: 360px;
    flex-shrink: 0;
    background: var(--wp-card);
    border: 1px solid var(--wp-border);
    border-radius: 18px;
    box-shadow: var(--wp-shadowS);
    overflow-y: auto;
    display: flex;
    flex-direction: column;
}

body.admin-mode .sidebar-admin ~ .main .wp-detail-empty {
    flex: 1;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    text-align: center;
    padding: 40px 20px;
}

body.admin-mode .sidebar-admin ~ .main .wp-detail-header {
    padding: 20px 20px 16px;
    display: flex;
    align-items: center;
    gap: 14px;
    border-radius: 18px 18px 0 0;
}

body.admin-mode .sidebar-admin ~ .main .wp-detail-avatar {
    width: 48px;
    height: 48px;
    border-radius: 15px;
    background: var(--wp-gradient);
    color: #fff;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 17px;
    font-weight: 800;
    font-family: 'Manrope', sans-serif;
    flex-shrink: 0;
    box-shadow: 0 4px 12px rgba(14,156,149,.25);
}

body.admin-mode .sidebar-admin ~ .main .wp-detail-name {
    font-size: 16px;
    font-weight: 800;
    font-family: 'Manrope', sans-serif;
    color: var(--wp-text);
    letter-spacing: -0.3px;
}

body.admin-mode .sidebar-admin ~ .main .wp-detail-phone {
    font-size: 12.5px;
    color: var(--wp-muted);
    margin-top: 2px;
}

body.admin-mode .sidebar-admin ~ .main .wp-detail-id {
    font-size: 11.5px;
    font-weight: 700;
    color: var(--wp-tealD);
    margin-top: 2px;
}

/* Fields grid */
body.admin-mode .sidebar-admin ~ .main .wp-detail-fields {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 8px;
    padding: 0 16px 16px;
}

body.admin-mode .sidebar-admin ~ .main .wp-detail-field {
    background: var(--wp-inset);
    border-radius: 11px;
    padding: 9px 12px;
    display: flex;
    flex-direction: column;
    gap: 3px;
}

body.admin-mode .sidebar-admin ~ .main .wp-detail-field span {
    font-size: 10.5px;
    color: var(--wp-subtle);
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.4px;
}

body.admin-mode .sidebar-admin ~ .main .wp-detail-field strong {
    font-size: 12.5px;
    font-weight: 700;
    color: var(--wp-text);
}

/* Payment schedule */
body.admin-mode .sidebar-admin ~ .main .wp-detail-payments {
    padding: 0 16px 16px;
}

body.admin-mode .sidebar-admin ~ .main .wp-detail-section-title {
    font-size: 12px;
    font-weight: 700;
    color: var(--wp-muted);
    text-transform: uppercase;
    letter-spacing: 0.5px;
    margin-bottom: 10px;
    display: flex;
    justify-content: space-between;
    align-items: center;
}

body.admin-mode .sidebar-admin ~ .main .wp-detail-section-title span {
    font-size: 12px;
    font-weight: 700;
    color: var(--wp-tealD);
    text-transform: none;
    letter-spacing: 0;
}

body.admin-mode .sidebar-admin ~ .main .wp-pay-grid {
    display: grid;
    grid-template-columns: repeat(9, 1fr);
    gap: 5px;
}

body.admin-mode .sidebar-admin ~ .main .wp-pay-seg {
    aspect-ratio: 1;
    border-radius: 6px;
    transition: transform 0.1s;
    cursor: default;
    position: relative;
}

body.admin-mode .sidebar-admin ~ .main .wp-pay-seg:hover {
    transform: scale(1.15);
    z-index: 1;
}

body.admin-mode .sidebar-admin ~ .main .wp-pay-seg.paid {
    background: var(--wp-teal);
    box-shadow: 0 2px 6px rgba(14,156,149,.3);
}

body.admin-mode .sidebar-admin ~ .main .wp-pay-seg.current {
    background: var(--wp-warn);
    box-shadow: 0 2px 6px rgba(221,155,52,.3);
    animation: wp-pulse 1.5s ease-in-out infinite;
}

body.admin-mode .sidebar-admin ~ .main .wp-pay-seg.future {
    background: var(--wp-hover);
    border: 1px solid var(--wp-border);
}

@keyframes wp-pulse {
    0%, 100% { opacity: 1; }
    50% { opacity: 0.6; }
}

/* Detail actions */
body.admin-mode .sidebar-admin ~ .main .wp-detail-actions {
    display: flex;
    gap: 10px;
    padding: 12px 16px 16px;
    margin-top: auto;
    border-top: 1px solid var(--wp-line);
}

body.admin-mode .sidebar-admin ~ .main .wp-detail-actions .btn-primary {
    flex: 1;
}

body.admin-mode .sidebar-admin ~ .main .wp-detail-actions .wp-btn-danger-soft {
    all: unset;
    cursor: pointer;
    flex: 1;
    text-align: center;
    background: var(--wp-dangerSoft);
    color: var(--wp-danger);
    font-size: 13px;
    font-weight: 700;
    padding: 10px;
    border-radius: 11px;
    transition: background 0.15s;
    font-family: inherit;
}

body.admin-mode .sidebar-admin ~ .main .wp-detail-actions .wp-btn-danger-soft:hover {
    background: var(--wp-danger);
    color: #fff;
}

/* ================================================================
   SECTION: LOGIN SCREEN — Warm Pro redesign
   ================================================================ */

#login-screen.screen.active {
    display: flex !important;
    align-items: center;
    justify-content: center;
    min-height: 100vh;
    background: linear-gradient(145deg, #0a7a74 0%, #0e9c95 35%, #c97840 100%);
    padding: 0;
}

#login-screen .container { display: none; }

.wp-login-wrap {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    min-height: 100vh;
    padding: 24px;
    box-sizing: border-box;
}

.wp-login-card {
    background: #ffffff;
    border-radius: 24px;
    padding: 44px 40px;
    width: 100%;
    max-width: 400px;
    box-shadow: 0 24px 64px rgba(10, 60, 58, 0.28), 0 4px 16px rgba(0,0,0,.1);
    animation: wp-login-in 0.4s cubic-bezier(0.4,0,0.2,1);
}

@keyframes wp-login-in {
    from { opacity: 0; transform: translateY(24px) scale(0.97); }
    to   { opacity: 1; transform: translateY(0) scale(1); }
}

.wp-login-logo-row {
    text-align: center;
    margin-bottom: 28px;
}

.wp-login-logo-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 60px;
    height: 60px;
    border-radius: 20px;
    background: linear-gradient(135deg, #0e9c95, #f08a52);
    font-size: 28px;
    margin-bottom: 14px;
    box-shadow: 0 8px 24px rgba(14,156,149,.38);
}

.wp-login-brand {
    font-size: 23px;
    font-weight: 800;
    letter-spacing: -0.5px;
    color: #1a1510;
    font-family: 'Manrope', 'Inter', sans-serif;
}

.wp-login-brand span { color: #0e9c95; }

.wp-login-sub-title {
    font-size: 12.5px;
    color: #94a3b8;
    margin-top: 4px;
    letter-spacing: 0.2px;
}

.wp-login-field { margin-bottom: 16px; }

.wp-login-field label {
    display: block;
    font-size: 12.5px;
    font-weight: 700;
    color: #475569;
    margin-bottom: 6px;
    letter-spacing: 0.2px;
}

.wp-login-field input[type=text],
.wp-login-field input[type=password] {
    width: 100%;
    padding: 12px 14px;
    border: 1.5px solid #e2e8f0;
    border-radius: 11px;
    font-size: 14px;
    outline: none;
    transition: border-color 0.2s, box-shadow 0.2s;
    box-sizing: border-box;
    color: #1e293b;
    background: #f8fafc;
    font-family: inherit;
}

.wp-login-field input[type=text]:focus,
.wp-login-field input[type=password]:focus {
    border-color: #0e9c95;
    box-shadow: 0 0 0 3px rgba(14,156,149,0.12);
    background: #fff;
}

.wp-login-remember {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-bottom: 22px;
    font-size: 13px;
    color: #64748b;
    cursor: pointer;
}

.wp-login-remember input[type=checkbox] {
    width: 16px;
    height: 16px;
    accent-color: #0e9c95;
    cursor: pointer;
    flex-shrink: 0;
}

.wp-login-submit {
    width: 100%;
    padding: 13px;
    background: linear-gradient(135deg, #0e9c95, #0b8880);
    color: #fff;
    border: none;
    border-radius: 11px;
    font-size: 15px;
    font-weight: 700;
    cursor: pointer;
    transition: all 0.2s;
    letter-spacing: 0.3px;
    font-family: 'Manrope', 'Inter', sans-serif;
}

.wp-login-submit:hover {
    background: linear-gradient(135deg, #0b8880, #097874);
    transform: translateY(-1px);
    box-shadow: 0 6px 22px rgba(14,156,149,.4);
}

.wp-login-submit:active { transform: translateY(0); }

.wp-login-error {
    color: #dc2626;
    font-size: 13px;
    text-align: center;
    margin-top: 12px;
    min-height: 18px;
    font-weight: 500;
}

html[data-theme="dark"] #login-screen.screen.active {
    background: linear-gradient(145deg, #052e2b 0%, #0a5a55 40%, #5a3010 100%);
}

html[data-theme="dark"] .wp-login-card {
    background: #1a1410;
    box-shadow: 0 24px 64px rgba(0,0,0,.6);
}

html[data-theme="dark"] .wp-login-brand { color: #f4ecdd; }
html[data-theme="dark"] .wp-login-brand span { color: #2fc4bd; }
html[data-theme="dark"] .wp-login-field label { color: #a99b87; }

html[data-theme="dark"] .wp-login-field input[type=text],
html[data-theme="dark"] .wp-login-field input[type=password] {
    background: #221c14;
    border-color: #372f24;
    color: #f4ecdd;
}

html[data-theme="dark"] .wp-login-field input[type=text]:focus,
html[data-theme="dark"] .wp-login-field input[type=password]:focus {
    border-color: #2fc4bd;
    background: #1e1912;
    box-shadow: 0 0 0 3px rgba(47,196,189,.14);
}

html[data-theme="dark"] .wp-login-remember { color: #7c6e5b; }
html[data-theme="dark"] .wp-login-sub-title { color: #7c6e5b; }

/* ================================================================
   SECTION: PARTNER MODE — Warm Pro for partner/user role
   ================================================================ */

body.partner-mode {
    --wp-bg:         #faf4ec;
    --wp-surface:    #ffffff;
    --wp-card:       #ffffff;
    --wp-sidebar:    #f3eadf;
    --wp-inset:      #f6efe5;
    --wp-hover:      #f3ebde;
    --wp-border:     #ebe0d0;
    --wp-line:       #f0e8dc;
    --wp-text:       #2a241d;
    --wp-muted:      #857667;
    --wp-subtle:     #a89a89;
    --wp-teal:       #0e9c95;
    --wp-tealD:      #0a7a74;
    --wp-tealSoft:   #d6f1ee;
    --wp-peach:      #f08a52;
    --wp-peachD:     #dd7038;
    --wp-peachSoft:  #fce3d2;
    --wp-violet:     #8a6fd6;
    --wp-violetSoft: #ece5fa;
    --wp-good:       #3da06f;
    --wp-goodSoft:   #dcf0e4;
    --wp-warn:       #dd9b34;
    --wp-shadow:     0 1px 2px rgba(90,60,30,.04), 0 10px 30px rgba(90,60,30,.07);
    --wp-shadowS:    0 1px 2px rgba(90,60,30,.05);
    --wp-glow:       0 8px 20px rgba(14,156,149,.28);
    --wp-gradient:   linear-gradient(135deg, #0e9c95, #f08a52);
    --border:        var(--wp-border);
    --text-primary:  var(--wp-text);
    --text-secondary:var(--wp-muted);
    background: var(--wp-bg);
    color: var(--wp-text);
}

/* Hide floating theme switch when partner is logged in — use sidebar button instead */
body.partner-mode .theme-switch-bar { display: none !important; }

html[data-theme="dark"] body.partner-mode {
    --wp-bg:         #191410;
    --wp-surface:    #241e17;
    --wp-card:       #272016;
    --wp-sidebar:    #1f1912;
    --wp-inset:      #221c14;
    --wp-hover:      #2e2619;
    --wp-border:     #372f24;
    --wp-line:       #2e2719;
    --wp-text:       #f4ecdd;
    --wp-muted:      #a99b87;
    --wp-subtle:     #7c6e5b;
    --wp-teal:       #2fc4bd;
    --wp-tealD:      #27a8a2;
    --wp-tealSoft:   #0e3a38;
    --wp-peach:      #f2965f;
    --wp-peachSoft:  #3c2a1c;
    --wp-violet:     #a98fe8;
    --wp-violetSoft: #2a2342;
    --wp-good:       #5fc488;
    --wp-goodSoft:   #1b3527;
    --wp-shadow:     0 2px 14px rgba(0,0,0,.35);
    --wp-shadowS:    0 1px 4px rgba(0,0,0,.28);
    --wp-glow:       0 8px 20px rgba(47,196,189,.22);
    --wp-gradient:   linear-gradient(135deg, #2fc4bd, #f2965f);
    --border:        var(--wp-border);
    --text-primary:  var(--wp-text);
    --text-secondary:var(--wp-muted);
    background: var(--wp-bg);
    color: var(--wp-text);
}

body.partner-mode .screen.active .app-shell {
    border: 1px solid var(--wp-border);
    border-radius: 16px;
    box-shadow: var(--wp-shadow);
    background: var(--wp-surface);
    overflow: hidden;
}

body.partner-mode .sidebar-user {
    width: 236px;
    min-width: 236px;
    background: var(--wp-sidebar);
    border-right: 1px solid var(--wp-border);
    flex-direction: column;
}

body.partner-mode .sidebar-user .sidebar-logo {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 18px 16px;
    border-bottom: 1px solid var(--wp-border);
    font-family: 'Manrope','Inter',sans-serif;
    font-weight: 800;
    font-size: 1rem;
    letter-spacing: -0.4px;
    color: var(--wp-text);
}

body.partner-mode .sidebar-user .sidebar-logo::before {
    content: '🚲';
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 36px;
    height: 36px;
    border-radius: 12px;
    background: var(--wp-gradient);
    font-size: 18px;
    flex-shrink: 0;
    box-shadow: var(--wp-glow);
}

body.partner-mode .sidebar-user .sidebar-logo span { color: var(--wp-teal); }

body.partner-mode .sidebar-user .sidebar-nav {
    flex: 1;
    padding: 12px 10px;
    overflow-y: auto;
}

body.partner-mode .sidebar-user .nav-section {
    background: var(--wp-surface);
    border: 1px solid var(--wp-border);
    border-radius: 16px;
    padding: 8px;
    margin-bottom: 10px;
    box-shadow: var(--wp-shadowS);
}

body.partner-mode .sidebar-user .nav-section-title {
    font-size: 10px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 1.4px;
    color: var(--wp-subtle);
    padding: 4px 10px 6px;
    margin-bottom: 2px;
}

body.partner-mode .sidebar-user .nav-item {
    font-size: 13.5px;
    font-weight: 500;
    border-radius: 11px;
    padding: 9px 12px;
    gap: 11px;
    color: var(--wp-muted);
    transition: background .15s, color .15s;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    margin-bottom: 1px;
}

body.partner-mode .sidebar-user .nav-item:hover {
    background: var(--wp-hover);
    color: var(--wp-text);
}

body.partner-mode .sidebar-user .nav-item.active {
    background: var(--wp-gradient);
    color: #ffffff;
    font-weight: 700;
    box-shadow: var(--wp-glow);
}

body.partner-mode .sidebar-user .nav-item .icon { font-size: 1.1rem; }

body.partner-mode .sidebar-user .sidebar-footer {
    padding: 12px 10px;
    border-top: 1px solid var(--wp-border);
}

body.partner-mode .sidebar-user .sidebar-footer .user-pill {
    background: var(--wp-surface);
    border: 1px solid var(--wp-border);
    border-radius: 14px;
    padding: 10px 12px;
    box-shadow: var(--wp-shadowS);
    gap: 10px;
    color: var(--wp-muted);
    font-size: 13px;
}

body.partner-mode .sidebar-user .sidebar-footer .user-pill .avatar {
    width: 34px;
    height: 34px;
    border-radius: 11px;
    background: linear-gradient(135deg, #0e9c95, #f08a52);
    color: #fff;
    font-weight: 800;
    font-size: 13px;
    font-family: 'Manrope','Inter',sans-serif;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}

body.partner-mode .sidebar-user .sidebar-footer .user-pill div div[style] {
    color: var(--wp-text) !important;
}

body.partner-mode .sidebar-user .sidebar-footer .logout-link {
    color: var(--wp-teal);
    font-weight: 600;
    font-size: 12px;
}

body.partner-mode .sidebar-user .sidebar-footer .logout-link:hover { text-decoration: underline; }

body.partner-mode .sidebar-user .sidebar-footer .wp-sidebar-user-card {
    display: flex;
    align-items: center;
    gap: 10px;
    background: var(--wp-surface);
    border: 1px solid var(--wp-border);
    border-radius: 14px;
    padding: 10px 12px;
    box-shadow: var(--wp-shadowS);
    margin-bottom: 8px;
}

body.partner-mode .sidebar-user .sidebar-footer .wp-sidebar-avatar {
    width: 34px;
    height: 34px;
    border-radius: 11px;
    background: linear-gradient(135deg, #0e9c95, #f08a52);
    color: #fff;
    font-weight: 800;
    font-size: 13px;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}

body.partner-mode .sidebar-user .sidebar-footer .wp-sidebar-info { flex: 1; }
body.partner-mode .sidebar-user .sidebar-footer .wp-sidebar-name { font-size: 13px; font-weight: 700; color: var(--wp-text); }
body.partner-mode .sidebar-user .sidebar-footer .wp-sidebar-role { font-size: 11px; color: var(--wp-muted); }

body.partner-mode .sidebar-user .sidebar-footer .wp-logout-link {
    display: block;
    text-align: center;
    font-size: 12.5px;
    font-weight: 600;
    color: var(--wp-muted);
    padding: 7px;
    border-radius: 10px;
    transition: background .15s, color .15s;
}

body.partner-mode .sidebar-user .sidebar-footer .wp-logout-link:hover {
    background: var(--wp-hover);
    color: var(--wp-text);
}

body.partner-mode .sidebar-user ~ .main { background: var(--wp-bg); }

body.partner-mode .sidebar-user ~ .main .main-header {
    background: var(--wp-surface);
    border-bottom: 1px solid var(--wp-border);
    padding: 20px 28px;
}

body.partner-mode .sidebar-user ~ .main .wp-main-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
}

body.partner-mode .sidebar-user ~ .main .main-header h1 {
    font-family: 'Manrope','Inter',sans-serif;
    font-size: 22px;
    font-weight: 800;
    letter-spacing: -0.4px;
    color: var(--wp-text);
}

body.partner-mode .sidebar-user ~ .main .main-header p {
    font-size: 13px;
    color: var(--wp-muted);
    margin-top: 3px;
}

body.partner-mode .sidebar-user ~ .main .wp-dashboard-content {
    padding: 20px 24px;
    display: flex;
    flex-direction: column;
}

body.partner-mode .sidebar-user ~ .main .wp-kpi-row {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 14px;
    margin-bottom: 20px;
}

body.partner-mode .sidebar-user ~ .main .wp-kpi-card {
    background: var(--wp-card);
    border: 1px solid var(--wp-border);
    border-radius: 18px;
    box-shadow: var(--wp-shadowS);
    padding: 18px 18px 12px;
    display: flex;
    flex-direction: column;
    gap: 4px;
    transition: box-shadow .2s, border-color .2s;
    overflow: hidden;
}

body.partner-mode .sidebar-user ~ .main .wp-kpi-card:hover {
    box-shadow: var(--wp-shadow);
    border-color: var(--wp-tealSoft);
}

body.partner-mode .sidebar-user ~ .main .wp-kpi-top {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 8px;
}

body.partner-mode .sidebar-user ~ .main .wp-kpi-badge {
    width: 36px;
    height: 36px;
    border-radius: 11px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 18px;
}

body.partner-mode .sidebar-user ~ .main .wp-kpi-num {
    font-family: 'Manrope','Inter',sans-serif;
    font-size: 30px;
    font-weight: 800;
    letter-spacing: -1px;
    color: var(--wp-text);
    line-height: 1;
}

body.partner-mode .sidebar-user ~ .main .wp-kpi-lbl {
    font-size: 12px;
    color: var(--wp-muted);
    font-weight: 500;
}

body.partner-mode .sidebar-user ~ .main .wp-spark {
    width: 100%;
    height: 28px;
    margin-top: 8px;
    overflow: visible;
}

body.partner-mode .sidebar-user ~ .main .wp-chart-card {
    background: var(--wp-card);
    border: 1px solid var(--wp-border);
    border-radius: 18px;
    box-shadow: var(--wp-shadowS);
    padding: 18px 20px 12px;
    margin-bottom: 20px;
    overflow: hidden;
}

body.partner-mode .sidebar-user ~ .main .wp-card-head {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 12px;
    margin-bottom: 14px;
}

body.partner-mode .sidebar-user ~ .main .wp-card-title {
    font-family: 'Manrope','Inter',sans-serif;
    font-size: 14px;
    font-weight: 700;
    color: var(--wp-text);
}

body.partner-mode .sidebar-user ~ .main .wp-card-sub {
    font-size: 12px;
    color: var(--wp-muted);
    margin-top: 2px;
}

body.partner-mode .sidebar-user ~ .main .wp-period-tabs {
    display: flex;
    gap: 4px;
    background: var(--wp-inset);
    border-radius: 10px;
    padding: 3px;
    flex-shrink: 0;
}

body.partner-mode .sidebar-user ~ .main .wp-period-tab {
    all: unset;
    cursor: pointer;
    font-size: 12px;
    font-weight: 600;
    padding: 5px 10px;
    border-radius: 8px;
    color: var(--wp-muted);
    transition: all .15s;
    font-family: inherit;
}

body.partner-mode .sidebar-user ~ .main .wp-period-tab.active {
    background: var(--wp-card);
    color: var(--wp-teal);
    box-shadow: var(--wp-shadowS);
}

body.partner-mode .sidebar-user ~ .main .wp-chart-wrap { position: relative; width: 100%; }

body.partner-mode .sidebar-user ~ .main .wp-main-spark {
    width: 100%;
    height: 130px;
    display: block;
    overflow: visible;
}

body.partner-mode .sidebar-user ~ .main .wp-chart-tooltip {
    position: absolute;
    background: var(--wp-card);
    border: 1px solid var(--wp-border);
    border-radius: 8px;
    padding: 6px 10px;
    font-size: 13px;
    font-weight: 600;
    color: var(--wp-text);
    pointer-events: none;
    display: none;
    white-space: nowrap;
    box-shadow: var(--wp-shadow);
    transform: translate(-50%, calc(-100% - 8px));
    z-index: 10;
}

body.partner-mode .sidebar-user ~ .main .wp-spark-labels {
    display: flex;
    justify-content: space-between;
    padding: 4px 4px 0;
    margin-top: 2px;
}

body.partner-mode .sidebar-user ~ .main .wp-spark-labels span {
    font-size: 10px;
    color: var(--wp-subtle);
    flex: 1;
    text-align: center;
}

body.partner-mode .sidebar-user ~ .main .wp-qa-card {
    background: var(--wp-card);
    border: 1px solid var(--wp-border);
    border-radius: 18px;
    box-shadow: var(--wp-shadowS);
    padding: 18px 20px;
    overflow: hidden;
}

body.partner-mode .sidebar-user ~ .main .wp-qa-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(90px, 1fr));
    gap: 10px;
}

body.partner-mode .sidebar-user ~ .main .wp-qa-btn {
    all: unset;
    cursor: pointer;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 7px;
    padding: 14px 8px;
    border-radius: 14px;
    border: 1px solid var(--wp-border);
    background: var(--wp-inset);
    transition: all .15s;
    font-size: 12px;
    font-weight: 600;
    color: var(--wp-muted);
    text-align: center;
    font-family: inherit;
}

body.partner-mode .sidebar-user ~ .main .wp-qa-btn:hover {
    background: var(--wp-hover);
    border-color: var(--wp-tealSoft);
    color: var(--wp-text);
    box-shadow: var(--wp-shadowS);
}

body.partner-mode .sidebar-user ~ .main .wp-qa-icon {
    width: 40px;
    height: 40px;
    border-radius: 12px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 20px;
}

body.partner-mode .sidebar-user ~ .main .stat-card {
    background: var(--wp-card);
    border: 1px solid var(--wp-border);
    border-radius: 16px;
    box-shadow: var(--wp-shadowS);
}

body.partner-mode .sidebar-user ~ .main .contract-card {
    background: var(--wp-card);
    border: 1px solid var(--wp-border);
    border-radius: 14px;
}

body.partner-mode .sidebar-user ~ .main .form-group input,
body.partner-mode .sidebar-user ~ .main .form-group select,
body.partner-mode .sidebar-user ~ .main .form-group textarea {
    background: var(--wp-inset);
    border-color: var(--wp-border);
    color: var(--wp-text);
}

body.partner-mode .sidebar-user ~ .main .form-group input:focus,
body.partner-mode .sidebar-user ~ .main .form-group select:focus {
    border-color: var(--wp-teal);
    outline: none;
    box-shadow: 0 0 0 3px var(--wp-tealSoft);
}

/* ── Partner sidebar theme toggle button ─────────────────────── */
body.partner-mode .sidebar-user .wp-sidebar-user-card .wp-theme-toggle {
    all: unset;
    cursor: pointer;
    width: 32px;
    height: 32px;
    border-radius: 10px;
    background: var(--wp-tealSoft);
    border: 1.5px solid rgba(14,156,149,.25);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 15px;
    flex-shrink: 0;
    transition: background .15s, border-color .15s, transform .15s;
}
body.partner-mode .sidebar-user .wp-sidebar-user-card .wp-theme-toggle:hover {
    background: rgba(14,156,149,.22);
    border-color: var(--wp-teal);
    transform: scale(1.08);
}
html[data-theme="dark"] body.partner-mode .sidebar-user .wp-sidebar-user-card .wp-theme-toggle {
    background: rgba(14,156,149,.15);
    border-color: rgba(14,156,149,.3);
}

/* ── Form card (issue / payment screens) ─────────────────────── */
body.partner-mode .sidebar-user ~ .main .wp-form-card {
    background: var(--wp-card);
    border: 1px solid var(--wp-border);
    border-radius: 20px;
    padding: 0;
    box-shadow: var(--wp-shadow);
    max-width: 600px;
    width: 100%;
    overflow: hidden;
    margin: 0 auto;
}

/* Form groups — section padding model */
body.partner-mode .sidebar-user ~ .main .wp-form-card .form-group {
    padding: 18px 28px;
    margin: 0;
    border-bottom: 1px solid var(--wp-line);
    display: flex;
    flex-direction: column;
    gap: 8px;
}
body.partner-mode .sidebar-user ~ .main .wp-form-card .form-group:last-of-type {
    border-bottom: none;
}

/* Label */
body.partner-mode .sidebar-user ~ .main .wp-form-card .form-group label {
    font-size: 11px;
    font-weight: 700;
    letter-spacing: .6px;
    text-transform: uppercase;
    color: var(--wp-subtle);
    margin: 0;
}

/* Editable inputs / selects */
body.partner-mode .sidebar-user ~ .main .wp-form-card .form-group input:not([readonly]),
body.partner-mode .sidebar-user ~ .main .wp-form-card .form-group select,
body.partner-mode .sidebar-user ~ .main .wp-form-card .form-group textarea {
    border-radius: 12px;
    border: 1.5px solid var(--wp-border);
    padding: 12px 16px;
    font-size: 14px;
    font-weight: 500;
    background: var(--wp-surface);
    color: var(--wp-text);
    width: 100%;
    box-sizing: border-box;
    transition: border-color .18s, box-shadow .18s;
    font-family: inherit;
}
body.partner-mode .sidebar-user ~ .main .wp-form-card .form-group input:not([readonly]):focus,
body.partner-mode .sidebar-user ~ .main .wp-form-card .form-group select:focus {
    border-color: var(--wp-teal);
    outline: none;
    box-shadow: 0 0 0 3px var(--wp-tealSoft);
}

/* Readonly inputs — look like data display, not form fields */
body.partner-mode .sidebar-user ~ .main .wp-form-card .form-group input[readonly] {
    border: none;
    border-radius: 10px;
    background: var(--wp-inset);
    color: var(--wp-text);
    font-size: 15px;
    font-weight: 700;
    padding: 10px 14px;
    width: 100%;
    box-sizing: border-box;
    cursor: default;
    letter-spacing: -.2px;
}

/* Search row: label full-width, input + button inline */
body.partner-mode .sidebar-user ~ .main .wp-form-card .form-group:has(.btn-search) {
    background: var(--wp-inset);
    border-bottom: 2px solid var(--wp-border);
    padding: 20px 28px;
    flex-direction: column;
}
body.partner-mode .sidebar-user ~ .main .wp-form-card .form-group:has(.btn-search) > label {
    font-size: 12px;
    color: var(--wp-muted);
}
body.partner-mode .sidebar-user ~ .main .wp-form-card .form-group:has(.btn-search) > input,
body.partner-mode .sidebar-user ~ .main .wp-form-card .form-group:has(.btn-search) > select {
    flex: 1;
}
.wp-form-search-row {
    display: flex;
    gap: 10px;
    align-items: center;
}
/* Fallback: make input+button appear inline if no wrapper */
body.partner-mode .sidebar-user ~ .main .wp-form-card .form-group:has(.btn-search) {
    flex-direction: column;
}

/* Search / action button */
body.partner-mode .sidebar-user ~ .main .wp-form-card .btn-search {
    background: var(--wp-teal);
    color: #fff;
    border: none;
    border-radius: 12px;
    padding: 12px 22px;
    font-size: 14px;
    font-weight: 700;
    cursor: pointer;
    transition: background .18s, box-shadow .18s;
    white-space: nowrap;
    align-self: flex-start;
    font-family: inherit;
}
body.partner-mode .sidebar-user ~ .main .wp-form-card .btn-search:hover {
    background: var(--wp-tealD);
    box-shadow: var(--wp-glow);
}

/* Submit button */
body.partner-mode .sidebar-user ~ .main .wp-form-card .btn-primary {
    background: var(--wp-gradient);
    color: #fff;
    border: none;
    border-radius: 14px;
    padding: 16px;
    font-size: 15px;
    font-weight: 800;
    cursor: pointer;
    transition: box-shadow .18s, opacity .18s;
    width: 100%;
    letter-spacing: .3px;
    font-family: inherit;
}
body.partner-mode .sidebar-user ~ .main .wp-form-card .btn-primary:hover {
    box-shadow: var(--wp-glow);
    opacity: .92;
}

/* Courier info card */
body.partner-mode .sidebar-user ~ .main .wp-form-card .courier-info {
    margin: 0;
    padding: 18px 28px;
    border-bottom: 1px solid var(--wp-line);
    background: linear-gradient(135deg, rgba(14,156,149,.06) 0%, rgba(240,138,82,.04) 100%);
}
body.partner-mode .sidebar-user ~ .main .wp-form-card .courier-info h3 {
    font-size: 12px;
    font-weight: 700;
    letter-spacing: .6px;
    text-transform: uppercase;
    color: var(--wp-teal);
    margin: 0 0 12px;
    padding-bottom: 10px;
    border-bottom: 1px solid var(--wp-border);
}
body.partner-mode .sidebar-user ~ .main .wp-form-card .courier-info p {
    margin: 0;
    font-size: 13px;
    color: var(--wp-text);
    padding: 3px 0;
    display: flex;
    align-items: center;
    gap: 6px;
    line-height: 1.5;
}
body.partner-mode .sidebar-user ~ .main .wp-form-card .courier-info p strong {
    color: var(--wp-muted);
    font-weight: 600;
}

/* Payment info */
body.partner-mode .sidebar-user ~ .main .wp-form-card .payment-info {
    background: linear-gradient(135deg, rgba(14,156,149,.06) 0%, rgba(240,138,82,.04) 100%);
    border-bottom: 1px solid var(--wp-line);
    padding: 18px 28px;
    font-size: 14px;
    color: var(--wp-text);
    margin: 0;
}

/* Success / error */
body.partner-mode .sidebar-user ~ .main .wp-form-card .success-message {
    background: var(--wp-goodSoft);
    border-top: 2px solid var(--wp-good);
    color: var(--wp-good);
    padding: 16px 28px;
    font-weight: 700;
    font-size: 14px;
}
body.partner-mode .sidebar-user ~ .main .wp-form-card .error-message {
    background: #fef0f0;
    border-top: 2px solid #e74c3c;
    color: #c0392b;
    padding: 16px 28px;
    font-weight: 600;
    font-size: 14px;
}
html[data-theme="dark"] body.partner-mode .sidebar-user ~ .main .wp-form-card .error-message {
    background: #3a1a1a;
    border-color: #c0392b;
    color: #f08a8a;
}
html[data-theme="dark"] body.partner-mode .sidebar-user ~ .main .wp-form-card .success-message {
    background: #1a3a2a;
    border-color: var(--wp-good);
    color: #5edb9a;
}

/* Submit button — direct child of form (outside form-group) */
body.partner-mode .sidebar-user ~ .main .wp-form-card form > .btn-primary {
    margin: 20px 28px;
    width: calc(100% - 56px);
    display: block;
    box-sizing: border-box;
}

/* Bike type radio labels */
body.partner-mode .sidebar-user ~ .main .wp-form-card label[for^="issue-bike"] {
    background: var(--wp-surface) !important;
    border: 1.5px solid var(--wp-border) !important;
    color: var(--wp-text) !important;
    border-radius: 12px !important;
    font-size: 14px !important;
    font-weight: 500 !important;
    letter-spacing: 0 !important;
    text-transform: none !important;
    padding: 12px 8px !important;
    transition: border-color .18s, background .18s !important;
}
body.partner-mode .sidebar-user ~ .main .wp-form-card label[for^="issue-bike"].active-bike-type {
    border-color: var(--wp-teal) !important;
    background: var(--wp-tealSoft) !important;
    color: var(--wp-tealD) !important;
    font-weight: 700 !important;
}

/* ══════════════════════════════════════════════════════════════
   USER CONTRACT CARDS (.uc-card) — partner contracts list
   ══════════════════════════════════════════════════════════════ */

body.partner-mode .sidebar-user ~ .main #user-contracts-list {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(272px, 1fr));
    gap: 16px;
    padding: 0;
}

.uc-empty {
    text-align: center;
    padding: 48px;
    color: var(--wp-muted, #857667);
    font-size: 15px;
    font-weight: 600;
    grid-column: 1/-1;
}

.uc-card {
    background: var(--wp-card, #fff);
    border: 1px solid var(--wp-border, #ebe0d0);
    border-radius: 18px;
    box-shadow: var(--wp-shadowS, 0 1px 2px rgba(90,60,30,.05));
    overflow: hidden;
    display: flex;
    flex-direction: column;
    transition: box-shadow .2s, transform .2s;
}
.uc-card:hover {
    box-shadow: var(--wp-shadow, 0 10px 30px rgba(90,60,30,.09));
    transform: translateY(-2px);
}

/* Head */
.uc-head {
    display: flex;
    align-items: flex-start;
    gap: 11px;
    padding: 16px 16px 13px;
    border-bottom: 1px solid var(--wp-line, #f0e8dc);
}
.uc-avatar {
    width: 42px;
    height: 42px;
    border-radius: 13px;
    background: var(--wp-gradient, linear-gradient(135deg,#0e9c95,#f08a52));
    color: #fff;
    font-size: 17px;
    font-weight: 800;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    font-family: 'Manrope','Inter',sans-serif;
}
.uc-info { flex: 1; min-width: 0; }
.uc-name {
    font-size: 14px;
    font-weight: 700;
    color: var(--wp-text, #2a241d);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.uc-phone {
    font-size: 12px;
    color: var(--wp-muted, #857667);
    margin-top: 2px;
    font-weight: 500;
}
.uc-meta {
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    gap: 5px;
    flex-shrink: 0;
}
.uc-badge {
    font-size: 11px;
    font-weight: 700;
    padding: 3px 9px;
    border-radius: 20px;
    letter-spacing: .3px;
}
.uc-badge-buyout { background: var(--wp-tealSoft, #d6f1ee); color: var(--wp-tealD, #0a7a74); }
.uc-badge-rent   { background: var(--wp-peachSoft, #fce3d2); color: var(--wp-peachD, #dd7038); }
.uc-date {
    font-size: 11px;
    color: var(--wp-subtle, #a89a89);
    font-weight: 600;
}

/* Chips row */
.uc-chips {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    padding: 11px 16px;
    border-bottom: 1px solid var(--wp-line, #f0e8dc);
}
.uc-chip {
    background: var(--wp-inset, #f6efe5);
    border: 1px solid var(--wp-line, #f0e8dc);
    border-radius: 20px;
    padding: 4px 10px;
    font-size: 12px;
    font-weight: 600;
    color: var(--wp-text, #2a241d);
    white-space: nowrap;
}

/* Amounts/details */
.uc-amounts {
    display: flex;
    flex-direction: column;
    gap: 0;
    border-bottom: 1px solid var(--wp-line, #f0e8dc);
}
.uc-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 8px 16px;
    border-bottom: 1px solid var(--wp-line, #f0e8dc);
}
.uc-row:last-child { border-bottom: none; }
.uc-row-lbl {
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .5px;
    color: var(--wp-subtle, #a89a89);
}
.uc-row-val {
    font-size: 13px;
    font-weight: 700;
    color: var(--wp-text, #2a241d);
}
.uc-val-good { color: var(--wp-good, #3da06f); }

/* Footer */
.uc-foot {
    padding: 12px 16px;
    display: flex;
    flex-direction: column;
    gap: 8px;
    margin-top: auto;
}
.uc-history-btn {
    all: unset;
    cursor: pointer;
    display: block;
    width: 100%;
    box-sizing: border-box;
    text-align: center;
    padding: 10px;
    background: var(--wp-inset, #f6efe5);
    border: 1.5px solid var(--wp-border, #ebe0d0);
    border-radius: 11px;
    font-size: 13px;
    font-weight: 700;
    color: var(--wp-teal, #0e9c95);
    transition: background .15s, border-color .15s;
    font-family: 'Manrope','Inter',sans-serif;
}
.uc-history-btn:hover {
    background: var(--wp-tealSoft, #d6f1ee);
    border-color: var(--wp-teal, #0e9c95);
}

/* Bike type editor */
.uc-bike-edit { display: flex; flex-direction: column; gap: 6px; }
.uc-bike-current { font-size: 12px; font-weight: 600; color: var(--wp-muted); }
.uc-bike-warn { font-size: 12px; font-weight: 600; color: var(--wp-warn, #dd9b34); }
.uc-bike-btns { display: flex; gap: 6px; }
.uc-bike-btn {
    all: unset;
    cursor: pointer;
    flex: 1;
    text-align: center;
    padding: 7px 4px;
    background: var(--wp-inset);
    border: 1.5px solid var(--wp-border);
    border-radius: 9px;
    font-size: 12px;
    font-weight: 700;
    color: var(--wp-text);
    transition: all .15s;
    font-family: inherit;
}
.uc-bike-btn.active {
    background: var(--wp-gradient);
    border-color: transparent;
    color: #fff;
}
.uc-bike-btn:hover:not(.active) {
    border-color: var(--wp-teal);
    background: var(--wp-tealSoft);
}

/* Dark mode */
html[data-theme="dark"] .uc-card {
    background: var(--wp-card);
    border-color: var(--wp-border);
}
html[data-theme="dark"] .uc-chip { background: var(--wp-inset); border-color: var(--wp-line); }
html[data-theme="dark"] .uc-history-btn { background: var(--wp-inset); border-color: var(--wp-border); }

/* ══════════════════════════════════════════════════════════════
   FLATPICKR — Warm Pro calendar theme (global, all roles)
   ══════════════════════════════════════════════════════════════ */

/* Hide native date input, keep only Flatpickr alt-input */
input.flatpickr-input:not(.flatpickr-alt-input) { opacity: 0; position: absolute; pointer-events: none; width: 0; }

/* Alt input (visible display field) inherits form-group styles automatically */
.flatpickr-input.flatpickr-alt-input {
    cursor: pointer;
}

/* Calendar popup */
.flatpickr-calendar {
    background: var(--wp-card, #ffffff);
    border: 1px solid var(--wp-border, #ebe0d0);
    border-radius: 18px;
    box-shadow: 0 8px 40px rgba(60,40,20,.14), 0 2px 8px rgba(0,0,0,.06);
    font-family: 'Manrope','Inter',sans-serif;
    padding: 8px 8px 12px;
    width: 290px;
    margin-top: 6px;
}
.flatpickr-calendar::before,
.flatpickr-calendar::after { display: none; } /* remove triangle arrow */

/* Month/year header */
.flatpickr-months {
    padding: 4px 2px 10px;
    align-items: center;
}
.flatpickr-month {
    height: 32px;
    color: var(--wp-text, #2a241d);
}
.flatpickr-current-month {
    font-size: 15px;
    font-weight: 800;
    color: var(--wp-text, #2a241d);
    padding-top: 0;
    letter-spacing: -.3px;
}
.flatpickr-current-month .cur-month { font-weight: 800; }
.flatpickr-current-month input.cur-year {
    font-weight: 800;
    color: var(--wp-text, #2a241d);
    font-size: 15px;
}
.flatpickr-current-month .numInputWrapper:hover { background: transparent; }
.flatpickr-current-month .numInputWrapper span { display: none; } /* hide year spinners */

/* Prev/next arrows */
.flatpickr-prev-month,
.flatpickr-next-month {
    fill: var(--wp-muted, #857667) !important;
    color: var(--wp-muted, #857667) !important;
    padding: 6px !important;
    border-radius: 9px;
    transition: background .15s, fill .15s;
    top: 7px !important;
    height: 30px !important;
    display: flex !important;
    align-items: center;
    justify-content: center;
}
.flatpickr-prev-month:hover,
.flatpickr-next-month:hover {
    background: var(--wp-hover, #f3ebde) !important;
    fill: var(--wp-text, #2a241d) !important;
}
.flatpickr-prev-month svg,
.flatpickr-next-month svg { fill: inherit; }

/* Weekday row */
.flatpickr-weekdays { margin-bottom: 2px; }
.flatpickr-weekday {
    color: var(--wp-subtle, #a89a89);
    font-size: 11px;
    font-weight: 700;
    letter-spacing: .5px;
}

/* Day cells */
.flatpickr-day {
    border-radius: 10px;
    color: var(--wp-text, #2a241d);
    font-size: 13px;
    font-weight: 500;
    height: 36px;
    line-height: 36px;
    max-width: 36px;
    border: none;
    transition: background .15s, color .15s;
}
.flatpickr-day:hover,
.flatpickr-day:focus {
    background: var(--wp-hover, #f3ebde);
    border: none;
    color: var(--wp-text, #2a241d);
}

/* Today */
.flatpickr-day.today {
    border: 2px solid var(--wp-teal, #0e9c95) !important;
    color: var(--wp-teal, #0e9c95);
    font-weight: 700;
    background: transparent;
}
.flatpickr-day.today:hover {
    background: var(--wp-tealSoft, #d6f1ee);
    color: var(--wp-tealD, #0a7a74);
}

/* Selected */
.flatpickr-day.selected,
.flatpickr-day.selected:hover,
.flatpickr-day.startRange,
.flatpickr-day.endRange {
    background: var(--wp-teal, #0e9c95) !important;
    border-color: var(--wp-teal, #0e9c95) !important;
    color: #ffffff !important;
    font-weight: 800;
    box-shadow: 0 4px 14px rgba(14,156,149,.38);
}

/* Disabled / out-of-month */
.flatpickr-day.flatpickr-disabled,
.flatpickr-day.flatpickr-disabled:hover,
.flatpickr-day.nextMonthDay,
.flatpickr-day.prevMonthDay {
    color: var(--wp-subtle, #a89a89);
    background: transparent;
    border: none;
}
.flatpickr-day.flatpickr-disabled { opacity: .4; cursor: not-allowed; }

/* Week number column (weekNumbers: true) */
.flatpickr-weekwrapper { display: flex; flex-direction: column; }
.flatpickr-weekwrapper .flatpickr-weeks { padding: 0 4px 0 0; }
.flatpickr-weekwrapper .flatpickr-weeknumber,
.flatpickr-weekwrapper span.flatpickr-day {
    font-size: 10px;
    font-weight: 700;
    color: var(--wp-teal, #0e9c95);
    background: var(--wp-tealSoft, rgba(14,156,149,.08));
    border-radius: 8px;
    cursor: default;
    opacity: 1;
}
.flatpickr-weekwrapper .flatpickr-weekday { font-size: 10px; color: var(--wp-teal, #0e9c95); }

/* "Сегодня" / "Закрыть" buttons */
.flatpickr-confirm, .flatpickr-clear,
.flatpickr-button {
    background: var(--wp-teal, #0e9c95);
    color: #fff;
    border-radius: 10px;
    font-weight: 700;
}

/* ── Dark mode overrides ── */
html[data-theme="dark"] .flatpickr-calendar {
    background: var(--wp-card, #272016);
    border-color: var(--wp-border, #3a3020);
    box-shadow: 0 8px 40px rgba(0,0,0,.45), 0 2px 8px rgba(0,0,0,.3);
}
html[data-theme="dark"] .flatpickr-current-month,
html[data-theme="dark"] .flatpickr-current-month input.cur-year,
html[data-theme="dark"] .flatpickr-day {
    color: var(--wp-text, #f0e8dc);
}
html[data-theme="dark"] .flatpickr-day:hover {
    background: var(--wp-hover, #2e2618);
}
html[data-theme="dark"] .flatpickr-prev-month,
html[data-theme="dark"] .flatpickr-next-month {
    fill: var(--wp-muted, #9a8a76) !important;
}
html[data-theme="dark"] .flatpickr-prev-month:hover,
html[data-theme="dark"] .flatpickr-next-month:hover {
    background: var(--wp-hover, #2e2618) !important;
    fill: var(--wp-text, #f0e8dc) !important;
}
html[data-theme="dark"] .flatpickr-weekday { color: var(--wp-subtle, #6a5e50); }
html[data-theme="dark"] .flatpickr-day.today { border-color: var(--wp-teal, #0e9c95) !important; color: var(--wp-teal, #0e9c95); }
html[data-theme="dark"] .flatpickr-day.today:hover { background: rgba(14,156,149,.18); }

/* ══════════════════════════════════════════════════════════════
   FINANCE MODE — только договоры и недельная сверка
   ══════════════════════════════════════════════════════════════ */

/* Скрываем все nav-items кроме разрешённых */
body.finance-mode .sidebar-admin .nav-item[data-section="dashboard"],
body.finance-mode .sidebar-admin .nav-item[data-section="admin-users"],
body.finance-mode .sidebar-admin .nav-item[data-section="admin-partners"],
body.finance-mode .sidebar-admin .nav-item[data-section="admin-types"],
body.finance-mode .sidebar-admin .nav-item[data-section="admin-import"],
body.finance-mode .sidebar-admin .nav-item[data-section="termination"],
body.finance-mode .sidebar-admin .nav-item[data-section="terminated-list"],
body.finance-mode .sidebar-admin .nav-item[data-section="admin-repair"],
body.finance-mode .sidebar-admin .nav-item[data-section="admin-virtual-orders"] {
    display: none !important;
}

/* Скрываем nav-section-title "Данные" если рядом нет видимых ссылок */
body.finance-mode .sidebar-admin .nav-section { gap: 2px; }

/* Скрываем деструктивные кнопки в admin-contracts для finance */
body.finance-mode #delete-selected-btn,
body.finance-mode [onclick*="deleteAllContracts"],
body.finance-mode [onclick*="deleteSelectedContracts"],
body.finance-mode #select-all-contracts,
body.finance-mode .btn-add-contract,
body.finance-mode [onclick*="showSection('issue')"],
body.finance-mode [onclick*="showSection(\"issue\")"] {
    display: none !important;
}

/* Бейдж роли в сайдбаре для finance */
body.finance-mode #admin-sidebar-name-wp::after {
    content: ' · Финансы';
    font-size: 10px;
    font-weight: 600;
    color: var(--wp-peach);
    letter-spacing: 0.3px;
}
