
    :root {
      --dark:       #13544E;
      --heading:    #095D40;
      --accent:     #6C9A40;
      --cta:        #008060;
      --lime:       #D3E162;
      --lime-light: #E4F577;
      --bg:         #FBF7ED;
      --alt:        #E0EDD4;
      --text:       #212B36;
      --muted:      #5a6a75;
      --text-muted: #5a6a75;
      --white:      #ffffff;
      --card:       #ffffff;
      --border:     rgba(9,93,64,0.12);
      --danger:     #dc2626;
      --warning:    #f59e0b;
      --info:       #3b82f6;
      --radius:     12px;
      --radius-lg:  20px;
      --shadow:     0 4px 24px rgba(9,93,64,0.09);
      --shadow-lg:  0 8px 40px rgba(9,93,64,0.14);
      --transition: all 0.25s ease;
    }

    *, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
    html { scroll-behavior: smooth; }
    body { font-family: 'Inter', sans-serif; background: var(--bg); color: var(--text); line-height: 1.65; -webkit-font-smoothing: antialiased; }
    a { text-decoration: none; color: inherit; }
    img { max-width: 100%; display: block; }
    button { font-family: inherit; cursor: pointer; }

    /* ══════════════ SCREEN MANAGEMENT ══════════════ */
    .screen { display: none; }
    .screen.active { display: block; }

    /* ══════════════ LOGIN PAGE ══════════════ */
    #screen-login {
      min-height: 100vh;
      background: linear-gradient(135deg, var(--dark) 0%, #0d6b62 52%, var(--heading) 100%);
      display: none;
      align-items: center;
      justify-content: center;
      padding: 24px;
      position: relative;
      overflow: hidden;
    }
    #screen-login.active { display: flex; }
    #screen-login::before {
      content: '';
      position: absolute; inset: 0;
      background: url("data:image/svg+xml,%3Csvg width='80' height='80' viewBox='0 0 80 80' xmlns='http://www.w3.org/2000/svg'%3E%3Ccircle cx='40' cy='40' r='2' fill='%23ffffff' fill-opacity='0.022'/%3E%3C/svg%3E");
      pointer-events: none;
    }
    .login-card {
      background: var(--white);
      border-radius: var(--radius-lg);
      box-shadow: 0 24px 80px rgba(0,0,0,0.28);
      width: 100%;
      max-width: 440px;
      overflow: hidden;
      position: relative;
      z-index: 1;
    }
    .login-head {
      background: var(--heading);
      padding: 32px 36px 28px;
      text-align: center;
      position: relative;
    }
    .login-head::after {
      content: '';
      position: absolute;
      bottom: -1px; left: 0; right: 0;
      height: 3px;
      background: linear-gradient(90deg, var(--lime), var(--accent), var(--lime));
    }
    .login-logo { font-size: 1.3rem; font-weight: 900; color: var(--white); margin-bottom: 6px; }
    .login-logo .acc { color: var(--lime); }
    .login-head p { font-size: 0.84rem; color: rgba(255,255,255,0.70); }
    .login-portal-badge {
      display: inline-flex; align-items: center; gap: 6px;
      background: rgba(211,225,98,0.16); border: 1px solid rgba(211,225,98,0.35);
      color: var(--lime); font-size: 0.72rem; font-weight: 800;
      padding: 4px 12px; border-radius: 100px; margin-bottom: 12px;
      text-transform: uppercase; letter-spacing: 0.07em;
    }
    .login-body { padding: 32px 36px; }
    .login-form-group { display: flex; flex-direction: column; gap: 5px; margin-bottom: 18px; }
    .login-form-group label { font-size: 0.82rem; font-weight: 800; color: var(--heading); }
    .login-form-group input {
      width: 100%; padding: 12px 14px;
      border: 1.5px solid rgba(9,93,64,0.15); border-radius: var(--radius);
      background: var(--bg); color: var(--text); font-family: inherit; font-size: 0.92rem; outline: none;
      transition: var(--transition);
    }
    .login-form-group input:focus { border-color: var(--cta); background: var(--white); box-shadow: 0 0 0 3px rgba(0,128,96,0.10); }
    .login-form-group input::placeholder { color: #aab3bb; }
    .login-input-wrap { position: relative; }
    .login-input-wrap input { padding-right: 42px; }
    .login-eye { position: absolute; right: 12px; top: 50%; transform: translateY(-50%); background: none; border: none; color: var(--muted); font-size: 0.88rem; cursor: pointer; }
    .login-btn {
      display: flex; align-items: center; justify-content: center; gap: 8px;
      background: var(--cta); color: var(--white); font-size: 0.96rem; font-weight: 900;
      padding: 14px; border-radius: var(--radius); width: 100%; border: none;
      transition: var(--transition); box-shadow: 0 6px 20px rgba(0,128,96,0.28);
      margin-bottom: 14px;
    }
    .login-btn:hover { background: var(--heading); transform: translateY(-2px); }
    .login-error {
      display: none; background: rgba(220,38,38,0.09); border: 1px solid rgba(220,38,38,0.22);
      border-radius: var(--radius); padding: 10px 14px; margin-bottom: 14px;
      font-size: 0.84rem; color: var(--danger); align-items: center; gap: 8px;
    }
    .login-error.show { display: flex; }
    .login-demo-accounts {
      background: var(--alt); border-radius: var(--radius); padding: 14px 16px; margin-top: 16px;
    }
    .lda-label { font-size: 0.72rem; font-weight: 900; color: var(--muted); text-transform: uppercase; letter-spacing: 0.06em; margin-bottom: 10px; }
    .lda-row { display: flex; align-items: center; justify-content: space-between; padding: 6px 0; border-bottom: 1px solid rgba(9,93,64,0.10); font-size: 0.78rem; }
    .lda-row:last-child { border-bottom: none; }
    .lda-role { font-weight: 800; color: var(--heading); }
    .lda-creds { color: var(--muted); }
    .lda-fill { font-size: 0.70rem; font-weight: 800; color: var(--cta); cursor: pointer; padding: 2px 8px; background: rgba(0,128,96,0.09); border-radius: 100px; border: none; }
    .lda-fill:hover { background: var(--cta); color: var(--white); }

    /* ══════════════ APP LAYOUT ══════════════ */
    #screen-app {
      min-height: 100vh;
      display: none;
      flex-direction: column;
    }
    #screen-app.active { display: flex; }

    /* ══════════════ TOP NAV ══════════════ */
    .app-nav {
      background: var(--white); border-bottom: 1px solid rgba(9,93,64,0.10);
      box-shadow: 0 2px 12px rgba(9,93,64,0.06); position: sticky; top: 0; z-index: 100;
      height: 64px; display: flex; align-items: center;
    }
    .app-nav-inner {
      max-width: 1400px; margin: 0 auto; padding: 0 24px;
      width: 100%; display: flex; align-items: center; justify-content: space-between; gap: 16px;
    }
    .app-nav-logo { font-size: 1.1rem; font-weight: 900; color: var(--heading); }
    .app-nav-logo .acc { color: var(--accent); }
    .app-nav-logo span { font-size: 0.82rem; font-weight: 700; color: var(--muted); margin-left: 6px; }
    .app-nav-right { display: flex; align-items: center; gap: 12px; }
    .app-nav-user { display: flex; align-items: center; gap: 9px; }
    .app-nav-avatar {
      width: 36px; height: 36px; border-radius: 50%; background: var(--cta);
      color: var(--white); display: flex; align-items: center; justify-content: center;
      font-size: 0.82rem; font-weight: 900; flex-shrink: 0;
    }
    .app-nav-name { font-size: 0.84rem; font-weight: 800; color: var(--heading); }
    .app-nav-role { font-size: 0.68rem; color: var(--muted); }
    .app-nav-logout {
      display: flex; align-items: center; gap: 6px;
      font-size: 0.82rem; font-weight: 700; color: var(--muted);
      background: none; border: 1.5px solid rgba(9,93,64,0.14); padding: 7px 14px;
      border-radius: 8px; transition: var(--transition);
    }
    .app-nav-logout:hover { border-color: var(--danger); color: var(--danger); }
    .app-nav-period-select {
      display: flex; align-items: center; gap: 7px; font-size: 0.82rem; font-weight: 700;
      color: var(--heading); background: var(--alt); border: none; padding: 7px 12px;
      border-radius: 8px; cursor: pointer; transition: var(--transition);
    }
    .app-nav-period-select select {
      background: none; border: none; font-family: inherit; font-size: 0.82rem;
      font-weight: 700; color: var(--heading); cursor: pointer; outline: none;
    }

    /* ══════════════ APP BODY ══════════════ */
    .app-body { display: flex; flex: 1; }

    /* ══════════════ SIDEBAR ══════════════ */
    .app-sidebar {
      width: 240px; flex-shrink: 0; background: var(--dark); padding: 20px 0;
      display: flex; flex-direction: column; min-height: calc(100vh - 64px);
      position: sticky; top: 64px; height: calc(100vh - 64px); overflow-y: auto;
    }
    .sidebar-section-label {
      font-size: 0.68rem; font-weight: 900; color: rgba(255,255,255,0.40);
      text-transform: uppercase; letter-spacing: 0.09em; padding: 14px 20px 6px;
    }
    .sidebar-nav { list-style: none; display: flex; flex-direction: column; gap: 2px; padding: 0 10px; }
    .sidebar-nav li a, .sidebar-nav li button {
      display: flex; align-items: center; gap: 10px;
      font-size: 0.86rem; font-weight: 700; color: rgba(255,255,255,0.65);
      padding: 10px 12px; border-radius: 9px; transition: var(--transition);
      width: 100%; background: none; border: none; text-align: left;
    }
    .sidebar-nav li a:hover, .sidebar-nav li button:hover { background: rgba(255,255,255,0.09); color: var(--white); }
    .sidebar-nav li a.active, .sidebar-nav li button.active { background: var(--cta); color: var(--white); }
    .sidebar-nav li a i, .sidebar-nav li button i { width: 16px; text-align: center; font-size: 0.80rem; }
    .sidebar-service-badge {
      font-size: 0.58rem; font-weight: 900; padding: 2px 6px; border-radius: 100px;
      background: rgba(211,225,98,0.18); color: var(--lime); margin-left: auto;
    }
    .sidebar-divider { height: 1px; background: rgba(255,255,255,0.08); margin: 10px 20px; }
    .sidebar-client-info { padding: 16px 20px; margin-top: auto; }
    .sci-label { font-size: 0.68rem; font-weight: 900; color: rgba(255,255,255,0.40); text-transform: uppercase; letter-spacing: 0.06em; margin-bottom: 8px; }
    .sci-plan {
      background: rgba(211,225,98,0.12); border: 1px solid rgba(211,225,98,0.25);
      border-radius: var(--radius); padding: 10px 12px;
    }
    .sci-plan strong { display: block; font-size: 0.82rem; color: var(--lime); margin-bottom: 2px; }
    .sci-plan span { font-size: 0.70rem; color: rgba(255,255,255,0.55); }

    /* ══════════════ MAIN CONTENT ══════════════ */
    .app-main { flex: 1; padding: 28px; overflow-x: hidden; }
    .view { display: none; }
    .view.active { display: block; }

    /* ══════════════ PAGE HEADER ══════════════ */
    .page-header { display: flex; align-items: center; justify-content: space-between; margin-bottom: 28px; flex-wrap: wrap; gap: 14px; }
    .ph-left {}
    .ph-label { font-size: 0.72rem; font-weight: 900; color: var(--muted); text-transform: uppercase; letter-spacing: 0.07em; margin-bottom: 4px; }
    .ph-title { font-size: 1.6rem; font-weight: 900; color: var(--heading); letter-spacing: -0.02em; }
    .ph-sub { font-size: 0.86rem; color: var(--muted); margin-top: 4px; }
    .ph-right { display: flex; align-items: center; gap: 10px; }

    /* ══════════════ KPI CARDS ══════════════ */
    .kpi-grid { display: grid; grid-template-columns: repeat(4,1fr); gap: 16px; margin-bottom: 28px; }
    .kpi-card {
      background: var(--white); border-radius: var(--radius-lg); border: 1.5px solid rgba(9,93,64,0.09);
      box-shadow: var(--shadow); padding: 20px; transition: var(--transition); position: relative; overflow: hidden;
    }
    .kpi-card:hover { transform: translateY(-3px); box-shadow: var(--shadow-lg); }
    .kpi-card::before {
      content: ''; position: absolute; top: 0; left: 0; right: 0; height: 3px;
    }
    .kpi-card.green::before  { background: linear-gradient(90deg, var(--cta), var(--accent)); }
    .kpi-card.blue::before   { background: linear-gradient(90deg, #3b82f6, #1d4ed8); }
    .kpi-card.lime::before   { background: linear-gradient(90deg, var(--lime), var(--lime-light)); }
    .kpi-card.orange::before { background: linear-gradient(90deg, #f59e0b, #d97706); }
    .kpi-card.red::before    { background: linear-gradient(90deg, #ef4444, #dc2626); }
    .kpi-card.purple::before { background: linear-gradient(90deg, #7c3aed, #5b21b6); }
    .kpi-icon {
      width: 40px; height: 40px; border-radius: 11px; display: flex; align-items: center;
      justify-content: center; font-size: 0.95rem; margin-bottom: 12px; flex-shrink: 0;
    }
    .kpi-icon.green  { background: rgba(0,128,96,0.12); color: var(--cta); }
    .kpi-icon.blue   { background: rgba(59,130,246,0.12); color: #3b82f6; }
    .kpi-icon.lime   { background: rgba(211,225,98,0.22); color: var(--accent); }
    .kpi-icon.orange { background: rgba(245,158,11,0.12); color: #d97706; }
    .kpi-icon.red    { background: rgba(239,68,68,0.10); color: #dc2626; }
    .kpi-icon.purple { background: rgba(124,58,237,0.10); color: #7c3aed; }
    .kpi-label { font-size: 0.72rem; font-weight: 700; color: var(--muted); text-transform: uppercase; letter-spacing: 0.06em; margin-bottom: 6px; }
    .kpi-value { font-size: 1.8rem; font-weight: 900; color: var(--heading); letter-spacing: -0.02em; line-height: 1; margin-bottom: 8px; }
    .kpi-change { display: flex; align-items: center; gap: 5px; font-size: 0.78rem; font-weight: 700; }
    .kpi-change.up   { color: #16a34a; }
    .kpi-change.down { color: var(--danger); }
    .kpi-change.neutral { color: var(--muted); }
    .kpi-change i { font-size: 0.65rem; }

    /* ══════════════ CHART CARDS ══════════════ */
    .chart-grid-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; margin-bottom: 24px; }
    .chart-grid-3 { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 20px; margin-bottom: 24px; }
    .chart-grid-full { margin-bottom: 24px; }
    .chart-card {
      background: var(--white); border-radius: var(--radius-lg); border: 1.5px solid rgba(9,93,64,0.09);
      box-shadow: var(--shadow); overflow: hidden;
    }
    .chart-head {
      padding: 18px 22px 14px; border-bottom: 1px solid var(--alt);
      display: flex; align-items: center; justify-content: space-between;
    }
    .chart-title { font-size: 0.92rem; font-weight: 900; color: var(--heading); }
    .chart-sub { font-size: 0.76rem; color: var(--muted); margin-top: 2px; }
    .chart-badge {
      font-size: 0.70rem; font-weight: 900; padding: 4px 10px; border-radius: 100px;
    }
    .chart-badge.green { background: #dcfce7; color: #16a34a; }
    .chart-badge.blue  { background: #eff6ff; color: #2563eb; }
    .chart-badge.lime  { background: rgba(211,225,98,0.28); color: var(--accent); }
    .chart-badge.orange { background: #fef3c7; color: #d97706; }
    .chart-body { padding: 20px; }

    /* ══════════════ SERVICE TAG ══════════════ */
    .service-header-band {
      background: var(--heading); border-radius: var(--radius-lg); padding: 20px 26px;
      margin-bottom: 24px; display: flex; align-items: center; justify-content: space-between;
      flex-wrap: wrap; gap: 12px;
    }
    .shb-left { display: flex; align-items: center; gap: 14px; }
    .shb-icon {
      width: 48px; height: 48px; border-radius: 13px; background: rgba(211,225,98,0.16);
      border: 1px solid rgba(211,225,98,0.28); display: flex; align-items: center;
      justify-content: center; font-size: 1.1rem; color: var(--lime); flex-shrink: 0;
    }
    .shb-name { font-size: 1.1rem; font-weight: 900; color: var(--white); margin-bottom: 3px; }
    .shb-meta { font-size: 0.78rem; color: rgba(255,255,255,0.65); display: flex; align-items: center; gap: 10px; }
    .shb-meta span { display: flex; align-items: center; gap: 5px; }
    .shb-right { display: flex; align-items: center; gap: 10px; }
    .shb-status {
      display: flex; align-items: center; gap: 6px; font-size: 0.80rem; font-weight: 800;
      padding: 6px 14px; border-radius: 100px;
    }
    .shb-status.active { background: rgba(22,163,74,0.22); color: #4ade80; }
    .shb-status.active::before { content: ''; width: 7px; height: 7px; border-radius: 50%; background: #4ade80; display: inline-block; animation: pulse 1.5s infinite; }
    @keyframes pulse { 0%,100% { opacity:1; } 50% { opacity:0.4; } }

    /* ══════════════ TABLE ══════════════ */
    .data-table-wrap { overflow-x: auto; }
    .data-table { width: 100%; border-collapse: collapse; font-size: 0.84rem; }
    .data-table th {
      text-align: left; padding: 11px 14px; font-size: 0.70rem; font-weight: 900;
      color: var(--muted); text-transform: uppercase; letter-spacing: 0.06em;
      background: var(--alt); border-bottom: 2px solid rgba(9,93,64,0.10);
    }
    .data-table td { padding: 12px 14px; border-bottom: 1px solid var(--alt); color: var(--text); vertical-align: middle; }
    .data-table tr:last-child td { border-bottom: none; }
    .data-table tr:hover td { background: rgba(0,128,96,0.03); }
    .td-badge { font-size: 0.70rem; font-weight: 900; padding: 3px 8px; border-radius: 100px; }
    .td-badge.green  { background: #dcfce7; color: #16a34a; }
    .td-badge.blue   { background: #eff6ff; color: #2563eb; }
    .td-badge.yellow { background: #fef3c7; color: #d97706; }
    .td-badge.red    { background: #fee2e2; color: #dc2626; }
    .td-bold { font-weight: 800; color: var(--heading); }

    /* ══════════════ ADMIN FORMS ══════════════ */
    .admin-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 22px; margin-bottom: 24px; }
    .form-card {
      background: var(--white); border-radius: var(--radius-lg); border: 1.5px solid rgba(9,93,64,0.09);
      box-shadow: var(--shadow); overflow: hidden;
    }
    .form-card-head { background: var(--heading); padding: 16px 22px; display: flex; align-items: center; gap: 10px; }
    .form-card-head i { color: var(--lime); }
    .form-card-head h3 { font-size: 0.92rem; font-weight: 900; color: var(--white); }
    .form-card-body { padding: 22px; }
    .form-group { display: flex; flex-direction: column; gap: 5px; margin-bottom: 14px; }
    .form-group label { font-size: 0.80rem; font-weight: 800; color: var(--heading); }
    .form-group input, .form-group select, .form-group textarea {
      width: 100%; padding: 10px 13px; border: 1.5px solid rgba(9,93,64,0.15);
      border-radius: var(--radius); background: var(--bg); color: var(--text);
      font-family: inherit; font-size: 0.88rem; outline: none; transition: var(--transition);
    }
    .form-group input:focus, .form-group select:focus, .form-group textarea:focus {
      border-color: var(--cta); background: var(--white); box-shadow: 0 0 0 3px rgba(0,128,96,0.10);
    }
    .form-group select { appearance: none; cursor: pointer; background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='7' viewBox='0 0 10 7'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%235a6a75' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E"); background-repeat: no-repeat; background-position: right 12px center; background-size: 10px; padding-right: 32px; }
    .form-row-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
    .form-row-3 { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 12px; }
    .btn-primary {
      display: inline-flex; align-items: center; justify-content: center; gap: 7px;
      background: var(--cta); color: var(--white); font-size: 0.88rem; font-weight: 900;
      padding: 11px 20px; border-radius: var(--radius); border: none; transition: var(--transition);
    }
    .btn-primary:hover { background: var(--heading); }
    .btn-secondary {
      display: inline-flex; align-items: center; justify-content: center; gap: 7px;
      background: var(--white); color: var(--heading); border: 2px solid rgba(9,93,64,0.18);
      font-size: 0.88rem; font-weight: 800; padding: 10px 18px; border-radius: var(--radius);
      transition: var(--transition);
    }
    .btn-secondary:hover { border-color: var(--cta); color: var(--cta); }
    .btn-danger {
      display: inline-flex; align-items: center; justify-content: center; gap: 7px;
      background: var(--white); color: var(--danger); border: 2px solid rgba(220,38,38,0.22);
      font-size: 0.82rem; font-weight: 800; padding: 8px 14px; border-radius: var(--radius);
      transition: var(--transition);
    }
    .btn-danger:hover { background: var(--danger); color: var(--white); }

    /* ══════════════ OVERVIEW CARDS ══════════════ */
    .overview-services-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 18px; margin-bottom: 28px; }
    .overview-svc-card {
      background: var(--white); border-radius: var(--radius-lg); border: 1.5px solid rgba(9,93,64,0.09);
      box-shadow: var(--shadow); padding: 22px; cursor: pointer; transition: var(--transition);
      position: relative; overflow: hidden;
    }
    .overview-svc-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-lg); border-color: var(--cta); }
    .osc-icon { font-size: 1.4rem; margin-bottom: 12px; display: block; }
    .osc-name { font-size: 0.92rem; font-weight: 900; color: var(--heading); margin-bottom: 6px; }
    .osc-kpis { display: flex; flex-direction: column; gap: 4px; margin-bottom: 14px; }
    .osc-kpi-row { display: flex; align-items: center; justify-content: space-between; font-size: 0.78rem; }
    .osc-kpi-label { color: var(--muted); font-weight: 600; }
    .osc-kpi-value { font-weight: 900; color: var(--heading); }
    .osc-view-btn {
      display: flex; align-items: center; justify-content: center; gap: 6px;
      font-size: 0.78rem; font-weight: 800; color: var(--cta); background: rgba(0,128,96,0.08);
      border: none; padding: 7px; border-radius: 8px; width: 100%; transition: var(--transition);
    }
    .osc-view-btn:hover { background: var(--cta); color: var(--white); }
    .osc-active-dot {
      position: absolute; top: 16px; right: 16px; width: 9px; height: 9px;
      border-radius: 50%; background: #22c55e;
      box-shadow: 0 0 0 3px rgba(34,197,94,0.20);
    }

    /* ══════════════ WELCOME BANNER ══════════════ */
    .welcome-banner {
      background: linear-gradient(135deg, var(--dark), var(--heading));
      border-radius: var(--radius-lg); padding: 28px 32px; margin-bottom: 28px;
      display: flex; align-items: center; justify-content: space-between;
      position: relative; overflow: hidden; flex-wrap: wrap; gap: 18px;
    }
    .welcome-banner::before {
      content: ''; position: absolute; inset: 0;
      background: url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Ccircle cx='30' cy='30' r='2' fill='%23ffffff' fill-opacity='0.025'/%3E%3C/svg%3E");
      pointer-events: none;
    }
    .wb-left { position: relative; z-index: 1; }
    .wb-greeting { font-size: 0.78rem; font-weight: 700; color: rgba(255,255,255,0.65); margin-bottom: 5px; }
    .wb-name { font-size: 1.5rem; font-weight: 900; color: var(--white); margin-bottom: 6px; letter-spacing: -0.02em; }
    .wb-sub { font-size: 0.88rem; color: rgba(255,255,255,0.75); }
    .wb-right { position: relative; z-index: 1; display: flex; gap: 18px; }
    .wb-stat { text-align: center; }
    .wb-stat strong { display: block; font-size: 1.4rem; font-weight: 900; color: var(--lime); letter-spacing: -0.02em; }
    .wb-stat span { font-size: 0.70rem; color: rgba(255,255,255,0.60); font-weight: 600; }

    /* ══════════════ REPORT HISTORY ══════════════ */
    .report-history { display: flex; flex-direction: column; gap: 10px; }
    .rh-item {
      display: flex; align-items: center; gap: 14px; padding: 14px 18px;
      background: var(--white); border-radius: var(--radius); border: 1.5px solid rgba(9,93,64,0.09);
      transition: var(--transition);
    }
    .rh-item:hover { border-color: rgba(0,128,96,0.20); }
    .rh-icon { width: 38px; height: 38px; border-radius: 10px; flex-shrink: 0; display: flex; align-items: center; justify-content: center; font-size: 0.88rem; }
    .rh-info { flex: 1; }
    .rh-title { font-size: 0.86rem; font-weight: 800; color: var(--heading); }
    .rh-date  { font-size: 0.72rem; color: var(--muted); }
    .rh-badge { font-size: 0.68rem; font-weight: 900; padding: 3px 9px; border-radius: 100px; }

    /* ══════════════ TOAST ══════════════ */
    .toast-container { position: fixed; bottom: 24px; right: 24px; z-index: 9999; display: flex; flex-direction: column; gap: 8px; }
    .toast {
      background: var(--heading); color: var(--white); padding: 13px 20px;
      border-radius: 12px; font-size: 0.88rem; font-weight: 700;
      box-shadow: var(--shadow-lg); display: flex; align-items: center; gap: 9px;
      animation: slideInRight 0.3s ease;
    }
    .toast.success { background: #16a34a; }
    .toast.error   { background: var(--danger); }
    @keyframes slideInRight { from { opacity:0; transform:translateX(20px); } to { opacity:1; transform:translateX(0); } }

    /* ══════════════ NPS SURVEY MODAL ══════════════ */
    .nps-overlay {
      position: fixed; inset: 0; background: rgba(0,0,0,0.55); z-index: 10000;
      display: flex; align-items: center; justify-content: center; padding: 20px;
      animation: fadeIn .2s ease;
    }
    @keyframes fadeIn { from { opacity:0; } to { opacity:1; } }
    .nps-modal {
      background: var(--white); border-radius: 20px; padding: 36px 32px 28px;
      max-width: 520px; width: 100%; box-shadow: 0 20px 60px rgba(0,0,0,.22);
      animation: slideUp .25s ease;
    }
    @keyframes slideUp { from { opacity:0; transform:translateY(20px); } to { opacity:1; transform:translateY(0); } }
    .nps-modal-badge { font-size:0.68rem; font-weight:900; text-transform:uppercase; letter-spacing:.08em; color:var(--cta); background:rgba(9,93,64,.08); border-radius:100px; padding:4px 12px; display:inline-block; margin-bottom:14px; }
    .nps-modal h2 { font-size:1.25rem; font-weight:900; color:var(--heading); margin-bottom:6px; }
    .nps-modal p { font-size:0.84rem; color:var(--muted); margin-bottom:22px; }
    .nps-scale { display:flex; gap:5px; margin-bottom:20px; flex-wrap:wrap; }
    .nps-btn {
      width: 42px; height: 42px; border-radius: 10px; border: 2px solid var(--alt);
      background: var(--white); font-size: 0.84rem; font-weight: 800; cursor: pointer;
      color: var(--heading); transition: all .15s; flex-shrink:0;
    }
    .nps-btn:hover { border-color: var(--cta); color: var(--cta); background: rgba(9,93,64,.06); }
    .nps-btn.selected { color: var(--white); border-color: transparent; }
    .nps-btn.det { background:#dc2626; }
    .nps-btn.pas { background:#d97706; }
    .nps-btn.pro { background:#16a34a; }
    .nps-scale-labels { display:flex; justify-content:space-between; font-size:0.68rem; color:var(--muted); font-weight:700; margin-bottom:20px; }
    .nps-comment { width:100%; box-sizing:border-box; padding:11px 14px; border:1.5px solid var(--alt); border-radius:10px; font-size:0.84rem; resize:vertical; min-height:76px; font-family:inherit; color:var(--heading); margin-bottom:20px; }
    .nps-comment:focus { outline:none; border-color:var(--cta); }
    .nps-actions { display:flex; gap:10px; justify-content:flex-end; }
    .nps-score-pill { display:inline-flex; align-items:center; gap:5px; padding:3px 11px; border-radius:100px; font-size:0.72rem; font-weight:900; }
    .nps-det { background:#fee2e2; color:#dc2626; }
    .nps-pas { background:#fef3c7; color:#d97706; }
    .nps-pro { background:#dcfce7; color:#16a34a; }
    .nps-client-row { display:flex; align-items:center; gap:12px; padding:12px 16px; border-radius:12px; border:1.5px solid var(--alt); margin-bottom:8px; }
    .nps-client-av { width:36px; height:36px; border-radius:50%; background:var(--cta); color:#fff; display:flex; align-items:center; justify-content:center; font-size:0.75rem; font-weight:900; flex-shrink:0; }
    .nps-trend-dots { display:flex; gap:4px; align-items:center; }
    .nps-trend-dot { width:28px; height:28px; border-radius:8px; display:flex; align-items:center; justify-content:center; font-size:0.72rem; font-weight:900; }
    .nps-stat-card { background:var(--white); border:1.5px solid var(--alt); border-radius:14px; padding:18px 20px; }
    .nps-stat-num { font-size:2rem; font-weight:900; color:var(--heading); line-height:1; }
    .nps-stat-label { font-size:0.72rem; color:var(--muted); font-weight:700; text-transform:uppercase; letter-spacing:.05em; margin-top:4px; }
    .nps-history-row { display:flex; align-items:center; gap:10px; padding:9px 0; border-bottom:1px solid var(--alt); font-size:0.82rem; }
    .nps-history-row:last-child { border-bottom:none; }
    .at-risk-pulse { display:inline-block; width:8px; height:8px; border-radius:50%; background:#dc2626; animation:pulse 1.4s infinite; }
    @keyframes pulse { 0%,100%{opacity:1;} 50%{opacity:.3;} }

    /* ══════════════ ADMIN CLIENT LIST ══════════════ */
    .client-card-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 16px; margin-bottom: 24px; }
    .client-card {
      background: var(--white); border-radius: var(--radius-lg); border: 1.5px solid rgba(9,93,64,0.09);
      box-shadow: var(--shadow); padding: 20px; transition: var(--transition);
    }
    .client-card:hover { box-shadow: var(--shadow-lg); }
    .cc-top { display: flex; align-items: center; gap: 12px; margin-bottom: 14px; }
    .cc-avatar { width: 42px; height: 42px; border-radius: 12px; background: var(--cta); color: var(--white); display: flex; align-items: center; justify-content: center; font-size: 0.92rem; font-weight: 900; flex-shrink: 0; }
    .cc-name { font-size: 0.92rem; font-weight: 900; color: var(--heading); }
    .cc-store { font-size: 0.74rem; color: var(--muted); }
    .cc-services { display: flex; flex-wrap: wrap; gap: 5px; margin-bottom: 14px; }
    .cc-svc-tag { font-size: 0.68rem; font-weight: 800; padding: 3px 9px; background: var(--alt); color: var(--heading); border-radius: 100px; }
    .cc-actions { display: flex; gap: 8px; }

    /* ══════════════ UPLOAD RESULTS PANEL ══════════════ */
    .upload-service-tabs { display: flex; gap: 6px; flex-wrap: wrap; margin-bottom: 24px; }
    .upload-svc-tab {
      display: inline-flex; align-items: center; gap: 6px; font-size: 0.78rem; font-weight: 800;
      padding: 7px 14px; border-radius: 100px; cursor: pointer; transition: var(--transition);
      background: var(--white); color: var(--muted); border: 1.5px solid rgba(9,93,64,0.12);
    }
    .upload-svc-tab:hover { border-color: var(--cta); color: var(--cta); }
    .upload-svc-tab.active { background: var(--cta); color: var(--white); border-color: var(--cta); }
    .upload-panel { display: none; }
    .upload-panel.active { display: block; }

    /* ══════════════ PROGRESS BAR ══════════════ */
    .progress-wrap { height: 8px; background: var(--alt); border-radius: 100px; overflow: hidden; }
    .progress-fill { height: 100%; border-radius: 100px; transition: width 1s ease; }
    .progress-fill.green  { background: linear-gradient(90deg, var(--cta), var(--accent)); }
    .progress-fill.blue   { background: linear-gradient(90deg, #3b82f6, #1d4ed8); }
    .progress-fill.orange { background: linear-gradient(90deg, #f59e0b, #d97706); }

    /* ══════════════ SECTION LABEL ══════════════ */
    .section-label {
      display: inline-flex; align-items: center; gap: 7px; background: var(--lime);
      color: var(--heading); font-size: 0.70rem; font-weight: 900; letter-spacing: 0.08em;
      text-transform: uppercase; padding: 5px 12px; border-radius: 100px; margin-bottom: 12px;
    }

    /* ══════════════ RESPONSIVE ══════════════ */
    @media (max-width: 1100px) {
      .kpi-grid { grid-template-columns: 1fr 1fr; }
      .chart-grid-3 { grid-template-columns: 1fr 1fr; }
      .overview-services-grid { grid-template-columns: 1fr 1fr; }
      .client-card-grid { grid-template-columns: 1fr 1fr; }
    }
    @media (max-width: 900px) {
      .app-sidebar { display: none; }
      .chart-grid-2 { grid-template-columns: 1fr; }
      .admin-grid { grid-template-columns: 1fr; }
    }
    @media (max-width: 640px) {
      .kpi-grid { grid-template-columns: 1fr 1fr; }
      .overview-services-grid { grid-template-columns: 1fr; }
      .client-card-grid { grid-template-columns: 1fr; }
      .app-main { padding: 16px; }
    }
    @media (max-width: 460px) {
      .kpi-grid { grid-template-columns: 1fr; }
    }

    /* ══════════════ PROJECT DASHBOARD ══════════════ */
    .project-header-bar { display: grid; grid-template-columns: repeat(4,1fr); gap: 14px; margin-bottom: 24px; }
    .phb-stat { background: var(--white); border-radius: var(--radius-lg); padding: 18px 20px; border: 1.5px solid rgba(9,93,64,0.09); box-shadow: var(--shadow); text-align: center; }
    .phb-stat strong { display: block; font-size: 1.6rem; font-weight: 900; color: var(--heading); letter-spacing: -0.02em; }
    .phb-stat span { font-size: 0.72rem; color: var(--muted); font-weight: 600; }
    .project-phase { background: var(--white); border-radius: var(--radius-lg); border: 1.5px solid rgba(9,93,64,0.09); box-shadow: var(--shadow); margin-bottom: 14px; overflow: hidden; }
    .project-phase-head { padding: 14px 20px; display: flex; align-items: center; gap: 12px; cursor: pointer; transition: var(--transition); user-select: none; }
    .project-phase-head:hover { background: rgba(0,128,96,0.03); }
    .pp-icon { width: 34px; height: 34px; border-radius: 9px; display: flex; align-items: center; justify-content: center; font-size: 0.80rem; flex-shrink: 0; }
    .pp-title { font-size: 0.92rem; font-weight: 900; color: var(--heading); flex: 1; }
    .pp-progress { font-size: 0.72rem; font-weight: 800; color: var(--muted); margin-right: 8px; }
    .pp-bar-wrap { width: 80px; height: 5px; background: var(--alt); border-radius: 100px; overflow: hidden; margin-right: 10px; }
    .pp-bar-fill { height: 100%; border-radius: 100px; background: var(--cta); }
    .pp-chevron { font-size: 0.70rem; color: var(--muted); transition: transform 0.2s; }
    .project-phase.open .pp-chevron { transform: rotate(180deg); }
    .project-phase-body { display: none; border-top: 1px solid var(--alt); }
    .project-phase.open .project-phase-body { display: block; }
    .task-item { display: flex; align-items: center; gap: 12px; padding: 11px 20px; border-bottom: 1px solid rgba(9,93,64,0.05); transition: var(--transition); }
    .task-item:last-child { border-bottom: none; }
    .task-item:hover { background: rgba(0,128,96,0.03); }
    .task-check { width: 20px; height: 20px; border-radius: 6px; flex-shrink: 0; display: flex; align-items: center; justify-content: center; font-size: 0.68rem; }
    .task-check.done     { background: #dcfce7; color: #16a34a; }
    .task-check.progress { background: #fef3c7; color: #d97706; }
    .task-check.todo     { background: var(--alt); color: var(--muted); }
    .task-check.review   { background: #eff6ff; color: #2563eb; }
    .task-label { flex: 1; font-size: 0.86rem; font-weight: 700; color: var(--text); }
    .task-label.done-text { color: var(--muted); text-decoration: line-through; }
    .task-assignee { font-size: 0.72rem; color: var(--muted); }
    .task-due { font-size: 0.70rem; font-weight: 800; padding: 2px 9px; border-radius: 100px; white-space: nowrap; }
    .task-due.upcoming { background: var(--alt); color: var(--muted); }
    .task-due.today    { background: #fef3c7; color: #d97706; }
    .task-due.overdue  { background: #fee2e2; color: #dc2626; }
    .task-due.done     { background: #dcfce7; color: #16a34a; }
    @media (max-width: 768px) { .project-header-bar { grid-template-columns: 1fr 1fr; } }

    /* ══════════════ DIRECT MESSAGING ══════════════ */
    .msg-layout { display: grid; grid-template-columns: 260px 1fr; gap: 20px; height: calc(100vh - 160px); min-height: 500px; }
    .msg-sidebar { background: var(--white); border-radius: var(--radius-lg); border: 1.5px solid rgba(9,93,64,0.09); box-shadow: var(--shadow); overflow: hidden; display: flex; flex-direction: column; }
    .msg-sidebar-head { padding: 16px 18px; background: var(--heading); }
    .msg-sidebar-head h3 { font-size: 0.90rem; font-weight: 900; color: var(--white); margin-bottom: 2px; }
    .msg-sidebar-head p { font-size: 0.72rem; color: rgba(255,255,255,0.60); }
    .msg-thread-list { flex: 1; overflow-y: auto; }
    .msg-thread { display: flex; align-items: center; gap: 11px; padding: 13px 16px; border-bottom: 1px solid var(--alt); cursor: pointer; transition: var(--transition); }
    .msg-thread:hover, .msg-thread.active { background: rgba(0,128,96,0.06); }
    .msg-thread.active { border-left: 3px solid var(--cta); }
    .msg-av { width: 36px; height: 36px; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 0.78rem; font-weight: 900; color: var(--white); flex-shrink: 0; }
    .msg-thread-info { flex: 1; min-width: 0; }
    .msg-thread-name { font-size: 0.84rem; font-weight: 800; color: var(--heading); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
    .msg-thread-prev { font-size: 0.72rem; color: var(--muted); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
    .msg-unread { width: 18px; height: 18px; background: var(--cta); color: var(--white); border-radius: 50%; font-size: 0.60rem; font-weight: 900; display: flex; align-items: center; justify-content: center; }
    .msg-main { background: var(--white); border-radius: var(--radius-lg); border: 1.5px solid rgba(9,93,64,0.09); box-shadow: var(--shadow); overflow: hidden; display: flex; flex-direction: column; }
    .msg-main-head { padding: 14px 20px; border-bottom: 1px solid var(--alt); display: flex; align-items: center; gap: 12px; }
    .msg-main-name { font-size: 0.92rem; font-weight: 900; color: var(--heading); }
    .msg-main-role { font-size: 0.74rem; color: var(--muted); }
    .msg-online { width: 8px; height: 8px; border-radius: 50%; background: #22c55e; display: inline-block; margin-left: 6px; }
    .msg-body { flex: 1; overflow-y: auto; padding: 20px; display: flex; flex-direction: column; gap: 14px; background: var(--bg); }
    .msg-bwrap { display: flex; gap: 10px; align-items: flex-end; }
    .msg-bwrap.mine { flex-direction: row-reverse; }
    .msg-bav { width: 28px; height: 28px; border-radius: 50%; background: var(--cta); color: var(--white); display: flex; align-items: center; justify-content: center; font-size: 0.60rem; font-weight: 900; flex-shrink: 0; }
    .msg-bubble { max-width: 68%; padding: 11px 15px; border-radius: 16px; font-size: 0.86rem; line-height: 1.5; }
    .msg-bubble.them { background: var(--white); border: 1.5px solid rgba(9,93,64,0.10); color: var(--text); border-bottom-left-radius: 4px; }
    .msg-bubble.mine { background: var(--cta); color: var(--white); border-bottom-right-radius: 4px; }
    .msg-btime { font-size: 0.64rem; color: var(--muted); margin-top: 4px; }
    .msg-bubble.mine .msg-btime { color: rgba(255,255,255,0.65); }
    .msg-compose { padding: 14px 18px; border-top: 1px solid var(--alt); display: flex; gap: 10px; align-items: flex-end; }
    .msg-compose textarea { flex: 1; padding: 11px 14px; border: 1.5px solid rgba(9,93,64,0.15); border-radius: var(--radius); font-family: inherit; font-size: 0.88rem; resize: none; min-height: 42px; max-height: 110px; background: var(--bg); outline: none; transition: var(--transition); color: var(--text); }
    .msg-compose textarea:focus { border-color: var(--cta); background: var(--white); box-shadow: 0 0 0 3px rgba(0,128,96,0.09); }
    .msg-send-btn { width: 42px; height: 42px; border-radius: var(--radius); background: var(--cta); color: var(--white); border: none; display: flex; align-items: center; justify-content: center; font-size: 0.88rem; flex-shrink: 0; transition: var(--transition); }
    .msg-send-btn:hover { background: var(--heading); }
    @media (max-width: 768px) { .msg-layout { grid-template-columns: 1fr; } }

    /* ══════════════ FILES & DELIVERABLES ══════════════ */
    .files-folder-grid { display: grid; grid-template-columns: repeat(4,1fr); gap: 14px; margin-bottom: 24px; }
    .files-folder { background: var(--white); border-radius: var(--radius-lg); border: 1.5px solid rgba(9,93,64,0.09); padding: 18px; cursor: pointer; transition: var(--transition); text-align: center; box-shadow: var(--shadow); }
    .files-folder:hover { border-color: var(--cta); transform: translateY(-2px); box-shadow: var(--shadow-lg); }
    .files-folder.active { border-color: var(--cta); background: rgba(0,128,96,0.04); }
    .ff-icon { font-size: 1.8rem; margin-bottom: 8px; }
    .ff-name { font-size: 0.84rem; font-weight: 900; color: var(--heading); margin-bottom: 3px; }
    .ff-count { font-size: 0.72rem; color: var(--muted); }
    .file-item { display: flex; align-items: center; gap: 14px; padding: 13px 18px; background: var(--white); border-radius: var(--radius); border: 1.5px solid rgba(9,93,64,0.09); margin-bottom: 8px; transition: var(--transition); }
    .file-item:hover { border-color: rgba(0,128,96,0.20); box-shadow: var(--shadow); }
    .file-icon { width: 40px; height: 40px; border-radius: 10px; display: flex; align-items: center; justify-content: center; font-size: 1rem; flex-shrink: 0; }
    .file-info { flex: 1; }
    .file-name { font-size: 0.88rem; font-weight: 800; color: var(--heading); margin-bottom: 2px; }
    .file-meta-row { font-size: 0.72rem; color: var(--muted); display: flex; gap: 12px; }
    .file-dl-btn { display: flex; align-items: center; gap: 5px; font-size: 0.78rem; font-weight: 800; padding: 7px 14px; border-radius: 8px; background: rgba(0,128,96,0.08); color: var(--cta); border: none; transition: var(--transition); }
    .file-dl-btn:hover { background: var(--cta); color: var(--white); }
    @media (max-width: 768px) { .files-folder-grid { grid-template-columns: 1fr 1fr; } }

    /* ══════════════ INVOICES ══════════════ */
    .invoice-summary-row { display: grid; grid-template-columns: repeat(3,1fr); gap: 16px; margin-bottom: 24px; }
    .inv-sum-card { background: var(--white); border-radius: var(--radius-lg); padding: 20px; border: 1.5px solid rgba(9,93,64,0.09); box-shadow: var(--shadow); }
    .inv-sum-card .isc-label { font-size: 0.72rem; font-weight: 700; color: var(--muted); text-transform: uppercase; letter-spacing: .06em; margin-bottom: 6px; }
    .inv-sum-card .isc-value { font-size: 1.6rem; font-weight: 900; color: var(--heading); letter-spacing: -0.02em; }
    .inv-sum-card .isc-note  { font-size: 0.74rem; color: var(--muted); margin-top: 4px; }
    .invoice-item { display: flex; align-items: center; gap: 16px; padding: 16px 20px; background: var(--white); border-radius: var(--radius-lg); border: 1.5px solid rgba(9,93,64,0.09); box-shadow: var(--shadow); margin-bottom: 10px; flex-wrap: wrap; }
    .inv-number { font-size: 0.78rem; font-weight: 900; color: var(--heading); min-width: 100px; }
    .inv-desc   { flex: 1; font-size: 0.86rem; font-weight: 700; color: var(--text); min-width: 160px; }
    .inv-date   { font-size: 0.80rem; color: var(--muted); min-width: 90px; }
    .inv-amount { font-size: 1rem; font-weight: 900; color: var(--heading); min-width: 80px; text-align: right; }
    .inv-badge  { font-size: 0.70rem; font-weight: 900; padding: 4px 10px; border-radius: 100px; }
    .inv-badge.paid    { background: #dcfce7; color: #16a34a; }
    .inv-badge.pending { background: #fef3c7; color: #d97706; }
    .inv-badge.overdue { background: #fee2e2; color: #dc2626; }
    @media (max-width: 640px) { .invoice-summary-row { grid-template-columns: 1fr; } }

    /* ══════════════ INVOICE PAYMENTS ══════════════ */
    .inv-pay-btn {
      display: inline-flex; align-items: center; gap: 7px;
      background: var(--cta); color: var(--white); border: none;
      padding: 9px 16px; border-radius: 100px; font-size: 0.78rem;
      font-weight: 800; cursor: pointer; transition: var(--transition);
      white-space: nowrap; text-decoration: none;
    }
    .inv-pay-btn:hover { background: var(--dark); transform: translateY(-1px); }
    .inv-pay-btn.paypal { background: #003087; }
    .inv-pay-btn.paypal:hover { background: #001f5b; }
    .inv-pay-btn.payoneer { background: #FF4800; }
    .inv-pay-btn.payoneer:hover { background: #d63d00; }
    .inv-pay-btn.overdue { background: var(--danger); animation: pulse-pay 2s infinite; }
    @keyframes pulse-pay {
      0%, 100% { box-shadow: 0 0 0 0 rgba(220,38,38,0.4); }
      50%       { box-shadow: 0 0 0 6px rgba(220,38,38,0); }
    }
    .inv-pay-badge {
      display: inline-flex; align-items: center; gap: 5px;
      font-size: 0.68rem; font-weight: 800; padding: 3px 10px;
      border-radius: 100px; white-space: nowrap;
    }
    .inv-pay-badge.stripe   { background: #ede9fe; color: #5b21b6; }
    .inv-pay-badge.paypal   { background: #dbeafe; color: #1d4ed8; }
    .inv-pay-badge.payoneer { background: #fff0eb; color: #FF4800; }
    .inv-outstanding-cta {
      display: flex; align-items: center; justify-content: space-between;
      gap: 14px; background: linear-gradient(135deg, #fffbeb, #fef3c7);
      border: 2px solid #fcd34d; border-radius: var(--radius-lg);
      padding: 16px 20px; margin-bottom: 20px; flex-wrap: wrap;
    }
    .inv-outstanding-cta-left { display: flex; align-items: center; gap: 12px; }
    .inv-outstanding-cta-icon {
      width: 40px; height: 40px; flex-shrink: 0; border-radius: 10px;
      background: #fef3c7; border: 2px solid #fcd34d;
      display: flex; align-items: center; justify-content: center;
      font-size: 1.1rem; color: #d97706;
    }
    .inv-outstanding-cta strong { font-size: 0.96rem; font-weight: 900; color: #92400e; display: block; margin-bottom: 3px; }
    .inv-outstanding-cta span  { font-size: 0.80rem; color: #b45309; }

    /* Admin invoice manager */
    .admin-inv-client-block { background: var(--white); border-radius: var(--radius-lg); border: 1.5px solid rgba(9,93,64,0.09); margin-bottom: 20px; overflow: hidden; }
    .admin-inv-client-head  { display: flex; align-items: center; gap: 12px; padding: 16px 20px; background: var(--bg); border-bottom: 1.5px solid rgba(9,93,64,0.09); }
    .admin-inv-client-meta  { flex: 1; }
    .admin-inv-client-name  { font-size: 0.92rem; font-weight: 900; color: var(--heading); }
    .admin-inv-client-store { font-size: 0.78rem; color: var(--muted); }
    .admin-inv-client-stats { display: flex; gap: 20px; }
    .admin-inv-stat         { text-align: right; }
    .admin-inv-stat strong  { display: block; font-size: 1rem; font-weight: 900; color: var(--heading); }
    .admin-inv-stat span    { font-size: 0.72rem; color: var(--muted); }
    .admin-inv-table        { width: 100%; border-collapse: collapse; }
    .admin-inv-table th     { font-size: 0.68rem; font-weight: 900; text-transform: uppercase; letter-spacing: 0.08em; color: var(--muted); padding: 10px 20px; text-align: left; border-bottom: 1px solid rgba(9,93,64,0.08); background: rgba(9,93,64,0.02); }
    .admin-inv-table td     { padding: 12px 20px; border-bottom: 1px solid rgba(9,93,64,0.05); font-size: 0.82rem; vertical-align: middle; }
    .admin-inv-table tr:last-child td { border-bottom: none; }
    .admin-inv-table tr:hover td { background: rgba(9,93,64,0.02); }
    .admin-inv-link-cell    { display: flex; align-items: center; gap: 8px; }
    .admin-inv-link-input   {
      flex: 1; border: 1.5px solid rgba(9,93,64,0.15); border-radius: 8px;
      padding: 7px 12px; font-size: 0.76rem; color: var(--text);
      background: var(--bg); transition: var(--transition); min-width: 0;
      font-family: inherit;
    }
    .admin-inv-link-input:focus { outline: none; border-color: var(--cta); background: var(--white); }
    .admin-inv-link-input::placeholder { color: #aab4bc; }
    .admin-inv-save-btn     {
      flex-shrink: 0; padding: 7px 14px; border-radius: 8px; border: none;
      background: var(--cta); color: var(--white); font-size: 0.74rem;
      font-weight: 800; cursor: pointer; transition: var(--transition); white-space: nowrap;
    }
    .admin-inv-save-btn:hover { background: var(--dark); }
    .admin-inv-save-btn.saved { background: #16a34a; }
    .inv-provider-icon { font-size: 0.80rem; margin-right: 3px; }


    /* ══════════════ STRATEGY CALLS ══════════════ */
    .calls-layout { display: grid; grid-template-columns: 1fr 340px; gap: 22px; }
    .call-slot-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; margin-bottom: 20px; }
    .call-slot { padding: 13px 16px; border-radius: var(--radius); border: 1.5px solid rgba(9,93,64,0.12); background: var(--white); cursor: pointer; transition: var(--transition); text-align: center; }
    .call-slot:hover { border-color: var(--cta); }
    .call-slot.selected { border-color: var(--cta); background: rgba(0,128,96,0.06); }
    .call-slot.booked { border-color: #22c55e; background: rgba(34,197,94,0.06); cursor: default; pointer-events: none; }
    .cs-day  { font-size: 0.68rem; font-weight: 900; color: var(--muted); text-transform: uppercase; letter-spacing: .06em; margin-bottom: 3px; }
    .cs-time { font-size: 0.90rem; font-weight: 900; color: var(--heading); }
    .past-call-item { display: flex; align-items: flex-start; gap: 14px; padding: 16px 18px; background: var(--white); border-radius: var(--radius-lg); border: 1.5px solid rgba(9,93,64,0.09); margin-bottom: 10px; box-shadow: var(--shadow); }
    .pci-icon { width: 36px; height: 36px; border-radius: 10px; display: flex; align-items: center; justify-content: center; font-size: 0.80rem; flex-shrink: 0; }
    .pci-date { font-size: 0.78rem; font-weight: 900; color: var(--muted); margin-bottom: 4px; }
    .pci-title { font-size: 0.90rem; font-weight: 900; color: var(--heading); margin-bottom: 6px; }
    .pci-tags { display: flex; gap: 4px; flex-wrap: wrap; }
    .pci-tag { font-size: 0.70rem; font-weight: 800; padding: 3px 9px; background: var(--alt); color: var(--heading); border-radius: 100px; }
    @media (max-width: 860px) { .calls-layout { grid-template-columns: 1fr; } }

    /* ══════════════ MONTHLY REPORTS ══════════════ */
    .monthly-report-card { background: var(--white); border-radius: var(--radius-lg); border: 1.5px solid rgba(9,93,64,0.09); box-shadow: var(--shadow); margin-bottom: 14px; overflow: hidden; }
    .mrc-head { padding: 18px 22px; display: flex; align-items: center; gap: 16px; flex-wrap: wrap; }
    .mrc-month-badge { width: 52px; height: 52px; border-radius: 14px; background: var(--heading); color: var(--lime); display: flex; flex-direction: column; align-items: center; justify-content: center; flex-shrink: 0; }
    .mrc-month-badge .mrc-mo { font-size: 0.64rem; font-weight: 900; text-transform: uppercase; }
    .mrc-month-badge .mrc-yr { font-size: 0.78rem; font-weight: 900; }
    .mrc-info { flex: 1; }
    .mrc-title { font-size: 0.94rem; font-weight: 900; color: var(--heading); margin-bottom: 3px; }
    .mrc-meta  { font-size: 0.76rem; color: var(--muted); display: flex; gap: 12px; flex-wrap: wrap; }
    .mrc-highlights { display: flex; gap: 8px; flex-wrap: wrap; margin-top: 6px; }
    .mrc-hl { font-size: 0.70rem; font-weight: 900; padding: 3px 10px; border-radius: 100px; }
    .mrc-hl.up      { background: #dcfce7; color: #16a34a; }
    .mrc-hl.down    { background: #fee2e2; color: #dc2626; }
    .mrc-hl.neutral { background: var(--alt);  color: var(--muted); }
    .mrc-actions { display: flex; gap: 8px; align-items: center; }
    .mrc-body { border-top: 1px solid var(--alt); padding: 18px 22px; display: none; }
    .monthly-report-card.open .mrc-body { display: block; }
    .mrc-kpi-grid { display: grid; grid-template-columns: repeat(4,1fr); gap: 12px; margin-bottom: 14px; }
    .mrc-kpi { text-align: center; padding: 12px 10px; background: var(--bg); border-radius: var(--radius); }
    .mrc-kpi strong { display: block; font-size: 1.3rem; font-weight: 900; color: var(--heading); }
    .mrc-kpi span   { font-size: 0.70rem; color: var(--muted); }
    .mrc-kpi .mrc-diff { font-size: 0.74rem; font-weight: 800; }
    .mrc-diff.up   { color: #16a34a; }
    .mrc-diff.down { color: #dc2626; }
    @media (max-width: 640px) { .mrc-kpi-grid { grid-template-columns: 1fr 1fr; } }

    /* ══════════════ ADMIN PERMISSIONS ══════════════ */
    .card { background: var(--white); border-radius: var(--radius-lg); border: 1.5px solid rgba(9,93,64,0.09); box-shadow: var(--shadow); }
    .view-header { display: flex; align-items: flex-start; justify-content: space-between; margin-bottom: 22px; flex-wrap: wrap; gap: 12px; }
    .view-title  { font-size: 1.3rem; font-weight: 900; color: var(--heading); letter-spacing: -0.02em; line-height: 1.2; }
    .view-sub    { font-size: 0.84rem; color: var(--muted); margin-top: 4px; max-width: 560px; }
    .perm-client-tabs { display: flex; gap: 6px; flex-wrap: wrap; margin-bottom: 22px; }
    .perm-client-tab { display: flex; align-items: center; gap: 7px; font-size: 0.80rem; font-weight: 800; padding: 7px 14px; border-radius: 100px; border: 1.5px solid rgba(9,93,64,0.12); background: var(--white); color: var(--muted); cursor: pointer; transition: var(--transition); }
    .perm-client-tab.active { background: var(--cta); color: var(--white); border-color: var(--cta); }
    .perm-row { display: flex; align-items: center; justify-content: space-between; padding: 14px 18px; background: var(--white); border-radius: var(--radius); border: 1.5px solid rgba(9,93,64,0.09); margin-bottom: 8px; flex-wrap: wrap; gap: 10px; }
    .perm-label { font-size: 0.86rem; font-weight: 800; color: var(--heading); }
    .perm-desc  { font-size: 0.74rem; color: var(--muted); margin-top: 2px; }
    .toggle-switch { position: relative; width: 44px; height: 24px; flex-shrink: 0; }
    .toggle-switch input { opacity: 0; width: 0; height: 0; }
    .toggle-slider { position: absolute; cursor: pointer; inset: 0; background: #d1d5db; border-radius: 100px; transition: .25s; }
    .toggle-slider:before { content: ''; position: absolute; width: 18px; height: 18px; left: 3px; bottom: 3px; background: var(--white); border-radius: 50%; transition: .25s; }
    input:checked + .toggle-slider { background: var(--cta); }
    input:checked + .toggle-slider:before { transform: translateX(20px); }

    /* ══════════════ CREATE INVOICE MODAL ══════════════ */
    .ci-overlay {
      position: fixed; inset: 0; background: rgba(9,30,40,0.55);
      backdrop-filter: blur(4px); z-index: 9000;
      display: flex; align-items: center; justify-content: center; padding: 20px;
      opacity: 0; pointer-events: none; transition: opacity 0.22s ease;
    }
    .ci-overlay.open { opacity: 1; pointer-events: all; }
    .ci-modal {
      background: var(--white); border-radius: var(--radius-lg);
      box-shadow: 0 24px 60px rgba(9,30,40,0.28);
      width: 100%; max-width: 560px; max-height: 92vh;
      overflow-y: auto; transform: translateY(16px) scale(0.97);
      transition: transform 0.22s ease;
    }
    .ci-overlay.open .ci-modal { transform: translateY(0) scale(1); }
    .ci-modal-head {
      display: flex; align-items: center; justify-content: space-between;
      padding: 20px 24px 16px; border-bottom: 1.5px solid rgba(9,93,64,0.09);
    }
    .ci-modal-head h3 {
      font-size: 1.05rem; font-weight: 900; color: var(--heading);
      display: flex; align-items: center; gap: 8px;
    }
    .ci-close {
      width: 32px; height: 32px; border-radius: 50%; border: none;
      background: rgba(9,93,64,0.07); color: var(--muted); font-size: 0.9rem;
      cursor: pointer; display: flex; align-items: center; justify-content: center;
      transition: var(--transition);
    }
    .ci-close:hover { background: #fee2e2; color: var(--danger); }
    .ci-modal-body { padding: 22px 24px; }
    .ci-field { margin-bottom: 16px; }
    .ci-field label {
      display: block; font-size: 0.76rem; font-weight: 800;
      color: var(--muted); text-transform: uppercase; letter-spacing: 0.07em;
      margin-bottom: 6px;
    }
    .ci-field label span { color: var(--danger); margin-left: 2px; }
    .ci-input, .ci-select {
      width: 100%; padding: 10px 14px; border-radius: 10px;
      border: 1.5px solid rgba(9,93,64,0.15); background: var(--bg);
      font-size: 0.86rem; color: var(--text); font-family: inherit;
      transition: var(--transition); box-sizing: border-box;
    }
    .ci-input:focus, .ci-select:focus {
      outline: none; border-color: var(--cta); background: var(--white);
      box-shadow: 0 0 0 3px rgba(0,128,96,0.10);
    }
    .ci-input::placeholder { color: #aab4bc; }
    .ci-row { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
    .ci-divider {
      border: none; border-top: 1.5px dashed rgba(9,93,64,0.10);
      margin: 18px 0 14px;
    }
    .ci-optional-label {
      font-size: 0.72rem; font-weight: 700; color: var(--muted);
      text-transform: uppercase; letter-spacing: 0.07em; margin-bottom: 10px;
      display: flex; align-items: center; gap: 6px;
    }
    .ci-optional-label::after {
      content: ''; flex: 1; height: 1px; background: rgba(9,93,64,0.10);
    }
    .ci-paylink-row {
      display: flex; gap: 8px; align-items: stretch;
    }
    .ci-paylink-row .ci-input { flex: 1; }
    .ci-gen-link-btn {
      display: inline-flex; align-items: center; gap: 6px;
      background: var(--cta); color: #fff; border: none; border-radius: 8px;
      padding: 0 16px; font-size: 0.82rem; font-weight: 600;
      cursor: pointer; white-space: nowrap; transition: background 0.18s, transform 0.12s;
      flex-shrink: 0;
    }
    .ci-gen-link-btn:hover { background: #005a43; }
    .ci-gen-link-btn:active { transform: scale(0.97); }
    .ci-provider-hint {
      font-size: 0.74rem; color: var(--muted); margin-top: 5px;
      display: flex; align-items: center; gap: 6px;
    }
    .ci-provider-hint i { font-size: 0.85rem; }
    .ci-genlink-hint {
      font-size: 0.74rem; color: #008060; margin-top: 5px;
      display: flex; align-items: center; gap: 6px; font-weight: 500;
    }
    .ci-modal-foot {
      padding: 14px 24px 20px; border-top: 1.5px solid rgba(9,93,64,0.09);
      display: flex; align-items: center; justify-content: flex-end; gap: 10px;
    }
    .ci-amount-prefix {
      position: relative;
    }
    .ci-amount-prefix .ci-input { padding-left: 30px; }
    .ci-amount-prefix::before {
      content: '£'; position: absolute; left: 12px; top: 50%;
      transform: translateY(-50%); font-size: 0.88rem; color: var(--muted);
      pointer-events: none; z-index: 1;
    }
    .ci-inv-preview {
      display: inline-flex; align-items: center; gap: 6px;
      background: var(--alt); padding: 6px 12px; border-radius: 8px;
      font-size: 0.78rem; font-weight: 800; color: var(--cta); margin-top: 4px;
    }


    /* ══════════════ ONBOARDING / WELCOME FLOW ══════════════ */

    /* Sidebar badge */
    .sidebar-onb-badge {
      display: inline-flex; align-items: center; justify-content: center;
      background: var(--lime); color: var(--heading);
      font-size: 0.60rem; font-weight: 900; padding: 2px 7px;
      border-radius: 100px; margin-left: auto; letter-spacing: 0.02em;
    }
    .sidebar-onb-badge.done { background: rgba(22,163,74,0.25); color: #4ade80; }

    /* Overview dismissible onboarding banner */
    .onboarding-nudge {
      display: flex; align-items: center; justify-content: space-between;
      gap: 16px; background: var(--white);
      border: 2px solid var(--lime); border-radius: var(--radius-lg);
      padding: 18px 22px; margin-bottom: 22px; flex-wrap: wrap;
    }
    .on-left { display: flex; align-items: center; gap: 14px; flex: 1; min-width: 220px; }
    .on-icon {
      width: 44px; height: 44px; flex-shrink: 0;
      background: var(--lime); border-radius: 10px;
      display: flex; align-items: center; justify-content: center;
      font-size: 1.1rem; color: var(--heading);
    }
    .on-title { font-size: 0.96rem; font-weight: 900; color: var(--heading); margin-bottom: 4px; }
    .on-sub { font-size: 0.80rem; color: var(--muted); margin-bottom: 8px; }
    .on-bar { height: 6px; background: #e2e8f0; border-radius: 100px; width: 100%; max-width: 260px; overflow: hidden; }
    .on-bar-fill { height: 100%; background: var(--cta); border-radius: 100px; transition: width 0.5s ease; }
    .on-right { display: flex; align-items: center; gap: 10px; flex-shrink: 0; }
    .on-dismiss {
      width: 28px; height: 28px; border-radius: 50%; border: none;
      background: rgba(9,93,64,0.08); color: var(--muted); font-size: 0.80rem;
      display: flex; align-items: center; justify-content: center; cursor: pointer;
      transition: var(--transition);
    }
    .on-dismiss:hover { background: rgba(220,38,38,0.10); color: var(--danger); }

    /* Onboarding full view */
    .ob-header {
      display: flex; align-items: flex-start; justify-content: space-between;
      gap: 24px; margin-bottom: 28px; flex-wrap: wrap;
    }
    .ob-header-eyebrow {
      display: inline-flex; align-items: center; gap: 6px;
      font-size: 0.72rem; font-weight: 900; text-transform: uppercase;
      letter-spacing: 0.12em; color: var(--cta);
      background: rgba(0,128,96,0.08); padding: 5px 12px; border-radius: 100px;
      margin-bottom: 10px;
    }
    .ob-header h2 {
      font-family: 'Nunito', sans-serif; font-size: 1.55rem;
      font-weight: 900; color: var(--heading); margin-bottom: 8px;
    }
    .ob-header p { font-size: 0.88rem; color: var(--muted); max-width: 500px; line-height: 1.6; }
    .ob-circle-wrap { text-align: center; }
    .ob-circle-pct {
      position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%);
      font-size: 1.05rem; font-weight: 900; color: var(--heading);
    }
    .ob-circle-outer { position: relative; width: 90px; height: 90px; }
    .ob-circle-outer svg { filter: drop-shadow(0 4px 12px rgba(0,128,96,0.2)); }
    .ob-circle-label { font-size: 0.78rem; color: var(--muted); font-weight: 600; margin-top: 6px; text-align: center; }

    .ob-complete-banner {
      display: flex; align-items: center; gap: 18px;
      background: linear-gradient(135deg, #f0fdf4, #dcfce7);
      border: 2px solid #bbf7d0; border-radius: var(--radius-lg);
      padding: 20px 24px; margin-bottom: 28px;
    }
    .ob-complete-banner strong { font-size: 1.05rem; font-weight: 900; color: #15803d; display: block; margin-bottom: 4px; }
    .ob-complete-banner p { font-size: 0.84rem; color: #166534; }

    .ob-sections { display: grid; grid-template-columns: 1fr 1fr; gap: 22px; margin-bottom: 22px; }
    @media (max-width: 900px) { .ob-sections { grid-template-columns: 1fr; } }

    .ob-section {
      background: var(--white); border-radius: var(--radius-lg);
      border: 1.5px solid rgba(9,93,64,0.09); padding: 22px;
    }
    .ob-section-title {
      display: flex; align-items: center; gap: 8px;
      font-size: 0.80rem; font-weight: 900; text-transform: uppercase;
      letter-spacing: 0.08em; color: var(--muted); margin-bottom: 16px;
    }
    .ob-section-count {
      margin-left: auto; background: var(--alt);
      padding: 2px 10px; border-radius: 100px;
      font-size: 0.72rem; font-weight: 800; color: var(--cta);
    }

    .ob-step {
      display: flex; align-items: flex-start; gap: 14px;
      padding: 14px; border-radius: var(--radius);
      border: 1.5px solid rgba(9,93,64,0.08);
      margin-bottom: 10px; transition: var(--transition);
      background: var(--bg);
    }
    .ob-step.done { border-color: #bbf7d0; background: #f0fdf4; }
    .ob-step-icon {
      width: 38px; height: 38px; flex-shrink: 0; border-radius: 9px;
      display: flex; align-items: center; justify-content: center; font-size: 0.90rem;
    }
    .ob-step-body { flex: 1; min-width: 0; }
    .ob-step-title { font-size: 0.84rem; font-weight: 800; color: var(--heading); margin-bottom: 3px; }
    .ob-step-desc { font-size: 0.76rem; color: var(--muted); line-height: 1.5; }
    .ob-step-desc a { color: var(--cta); text-decoration: underline; }
    .ob-step-action { flex-shrink: 0; margin-top: 2px; }
    .ob-step-done-badge {
      display: inline-flex; align-items: center; gap: 5px;
      background: #dcfce7; color: #15803d; font-size: 0.72rem; font-weight: 800;
      padding: 4px 10px; border-radius: 100px;
    }
    .ob-step-pending-badge {
      display: inline-flex; align-items: center; gap: 5px;
      background: #fef3c7; color: #d97706; font-size: 0.72rem; font-weight: 800;
      padding: 4px 10px; border-radius: 100px;
    }

    .ob-help-bar {
      display: flex; align-items: center; gap: 12px;
      background: rgba(0,128,96,0.06); border: 1px solid rgba(0,128,96,0.14);
      border-radius: var(--radius); padding: 14px 18px;
      font-size: 0.84rem; color: var(--muted);
    }
    .ob-help-bar i { color: var(--cta); font-size: 1rem; flex-shrink: 0; }
    .ob-help-bar a { color: var(--cta); font-weight: 700; text-decoration: underline; }

    /* Admin onboarding grid */
    .admin-ob-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(340px, 1fr)); gap: 20px; }
    .admin-ob-card {
      background: var(--white); border-radius: var(--radius-lg);
      border: 1.5px solid rgba(9,93,64,0.09); padding: 20px;
    }
    .admin-ob-card-head {
      display: flex; align-items: center; gap: 12px; margin-bottom: 14px;
    }
    .admin-ob-pct {
      margin-left: auto; font-size: 1.1rem; font-weight: 900;
      color: var(--cta);
    }
    .admin-ob-pct.complete { color: #16a34a; }
    .admin-ob-progress {
      display: flex; align-items: center; gap: 10px; margin-bottom: 16px;
      font-size: 0.76rem; color: var(--muted); font-weight: 600;
    }
    .admin-ob-bar { flex: 1; height: 6px; background: #e2e8f0; border-radius: 100px; overflow: hidden; }
    .admin-ob-fill { height: 100%; border-radius: 100px; transition: width 0.4s ease; }
    .admin-ob-steps-head {
      font-size: 0.70rem; font-weight: 900; text-transform: uppercase;
      letter-spacing: 0.08em; color: var(--muted); margin-bottom: 8px;
      display: flex; align-items: center; gap: 6px;
    }
    .admin-ob-step {
      display: flex; align-items: center; gap: 10px;
      padding: 8px 0; border-bottom: 1px solid rgba(9,93,64,0.06);
    }
    .admin-ob-step:last-child { border-bottom: none; }
    .admin-ob-step-icon {
      width: 26px; height: 26px; flex-shrink: 0; border-radius: 6px;
      background: #f1f5f9; display: flex; align-items: center; justify-content: center;
      font-size: 0.68rem; color: var(--muted);
    }
    .admin-ob-step-icon.done { background: #dcfce7; color: #16a34a; }
    .admin-ob-step-label { flex: 1; font-size: 0.76rem; font-weight: 600; color: var(--text); }
    .admin-ob-toggle {
      font-size: 0.68rem; font-weight: 800; padding: 4px 10px;
      border-radius: 100px; border: 1.5px solid rgba(9,93,64,0.15);
      background: var(--bg); color: var(--cta); cursor: pointer; transition: var(--transition);
      white-space: nowrap;
    }
    .admin-ob-toggle:hover { background: var(--cta); color: var(--white); border-color: var(--cta); }
    .admin-ob-toggle.done { background: #dcfce7; color: #15803d; border-color: #bbf7d0; }
    .admin-ob-toggle.done:hover { background: #fee2e2; color: var(--danger); border-color: #fca5a5; }

    /* ══ CONTRACTS ══ */
    .contracts-list { display: flex; flex-direction: column; gap: 14px; }
    .contract-item {
      background: var(--white); border-radius: var(--radius-lg);
      border: 1.5px solid rgba(9,93,64,0.09);
      padding: 20px 22px; display: flex; align-items: center;
      gap: 16px; flex-wrap: wrap; transition: var(--transition);
    }
    .contract-item:hover { border-color: rgba(9,93,64,0.22); box-shadow: 0 4px 18px rgba(9,30,40,0.07); }
    .contract-icon {
      width: 46px; height: 46px; border-radius: 12px; flex-shrink: 0;
      display: flex; align-items: center; justify-content: center;
      font-size: 1.15rem; background: rgba(9,93,64,0.08); color: var(--cta);
    }
    .contract-icon.pending { background: #fff8e1; color: #d97706; }
    .contract-icon.signed  { background: #dcfce7; color: #16a34a; }
    .contract-icon.expired { background: #fee2e2; color: var(--danger); }
    .contract-meta { flex: 1; min-width: 160px; }
    .contract-title { font-size: 0.95rem; font-weight: 800; color: var(--heading); margin-bottom: 4px; }
    .contract-sub   { font-size: 0.77rem; color: var(--muted); display: flex; align-items: center; gap: 10px; flex-wrap: wrap; }
    .contract-sub i { font-size: 0.65rem; }
    .ctr-badge {
      display: inline-flex; align-items: center; gap: 5px;
      padding: 4px 10px; border-radius: 20px; font-size: 0.72rem; font-weight: 800;
      text-transform: uppercase; letter-spacing: 0.05em;
    }
    .ctr-badge.pending  { background: #fff8e1; color: #92400e; border: 1px solid #fcd34d; }
    .ctr-badge.signed   { background: #dcfce7; color: #15803d; border: 1px solid #86efac; }
    .ctr-badge.expired  { background: #fee2e2; color: #b91c1c; border: 1px solid #fca5a5; }
    .ctr-badge.awaiting { background: #ede9fe; color: #6d28d9; border: 1px solid #c4b5fd; }
    .contract-actions { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
    .ctr-sign-btn {
      display: inline-flex; align-items: center; gap: 7px; padding: 9px 18px;
      background: var(--cta); color: var(--white); border: none; border-radius: 10px;
      font-size: 0.82rem; font-weight: 800; cursor: pointer; transition: var(--transition);
      text-decoration: none;
    }
    .ctr-sign-btn:hover { background: var(--cta-dark); transform: translateY(-1px); }
    .ctr-view-btn {
      display: inline-flex; align-items: center; gap: 7px; padding: 9px 16px;
      background: transparent; color: var(--cta); border: 1.5px solid var(--cta);
      border-radius: 10px; font-size: 0.82rem; font-weight: 700; cursor: pointer;
      transition: var(--transition);
    }
    .ctr-view-btn:hover { background: rgba(9,93,64,0.07); }
    .signed-info {
      font-size: 0.74rem; color: #15803d; display: flex; align-items: center; gap: 5px;
      background: #dcfce7; padding: 6px 12px; border-radius: 8px; font-weight: 700;
    }
    .ctr-ref { font-size: 0.68rem; color: var(--muted); margin-top: 3px; }

    /* Contracts sidebar badge */
    .sidebar-ctr-badge {
      display: inline-flex; align-items: center; justify-content: center;
      background: #d97706; color: var(--white); font-size: 0.58rem; font-weight: 900;
      min-width: 16px; height: 16px; border-radius: 20px; padding: 0 4px;
      margin-left: auto;
    }

    /* Admin contracts */
    .admin-ctr-client-block {
      background: var(--white); border-radius: var(--radius-lg);
      border: 1.5px solid rgba(9,93,64,0.09); margin-bottom: 20px; overflow: hidden;
    }
    .admin-ctr-client-head {
      display: flex; align-items: center; justify-content: space-between;
      padding: 14px 20px; background: rgba(9,93,64,0.04);
      border-bottom: 1.5px solid rgba(9,93,64,0.07);
    }
    .admin-ctr-client-name { font-size: 0.88rem; font-weight: 800; color: var(--heading); }
    .admin-ctr-client-name span { font-weight: 500; color: var(--muted); font-size: 0.78rem; margin-left: 6px; }
    .admin-ctr-table { width: 100%; border-collapse: collapse; }
    .admin-ctr-table th {
      font-size: 0.68rem; font-weight: 800; color: var(--muted); text-transform: uppercase;
      letter-spacing: 0.07em; padding: 10px 16px; text-align: left;
      border-bottom: 1.5px solid rgba(9,93,64,0.07); background: rgba(9,93,64,0.02);
    }
    .admin-ctr-table td { padding: 12px 16px; border-bottom: 1px solid rgba(9,93,64,0.05); font-size: 0.83rem; vertical-align: middle; }
    .admin-ctr-table tr:last-child td { border-bottom: none; }
    .admin-ctr-table tr:hover td { background: rgba(9,93,64,0.02); }
    .admin-ctr-del-btn {
      background: transparent; border: 1.5px solid #fca5a5; color: var(--danger);
      border-radius: 8px; padding: 5px 11px; font-size: 0.74rem; font-weight: 700;
      cursor: pointer; transition: var(--transition);
    }
    .admin-ctr-del-btn:hover { background: #fee2e2; }

    /* Sign modal */
    .sign-overlay {
      position: fixed; inset: 0; background: rgba(9,30,40,0.60);
      backdrop-filter: blur(5px); z-index: 9100;
      display: flex; align-items: center; justify-content: center; padding: 20px;
      opacity: 0; pointer-events: none; transition: opacity 0.22s ease;
    }
    .sign-overlay.open { opacity: 1; pointer-events: all; }
    .sign-modal {
      background: var(--white); border-radius: var(--radius-lg);
      box-shadow: 0 28px 70px rgba(9,30,40,0.32);
      width: 100%; max-width: 680px; max-height: 90vh;
      overflow: hidden; display: flex; flex-direction: column;
      transform: translateY(18px) scale(0.97); transition: transform 0.22s ease;
    }
    .sign-overlay.open .sign-modal { transform: translateY(0) scale(1); }
    .sign-modal-head {
      display: flex; align-items: center; justify-content: space-between;
      padding: 18px 24px 14px; border-bottom: 1.5px solid rgba(9,93,64,0.09); flex-shrink: 0;
    }
    .sign-modal-head h3 { font-size: 1rem; font-weight: 900; color: var(--heading); display: flex; align-items: center; gap: 8px; }
    .sign-modal-body { padding: 0; overflow-y: auto; flex: 1; }
    .sign-contract-scroll {
      max-height: 320px; overflow-y: auto; padding: 20px 24px;
      background: #f8fafc; border-bottom: 1.5px solid rgba(9,93,64,0.07);
      font-size: 0.82rem; line-height: 1.75; color: var(--text);
    }
    .sign-contract-scroll h4 { color: var(--heading); font-size: 0.93rem; margin: 0 0 12px; }
    .sign-contract-scroll p { margin: 0 0 10px; }
    .sign-contract-scroll ul { padding-left: 20px; margin: 0 0 10px; }
    .sign-contract-scroll li { margin-bottom: 5px; }
    .sign-form { padding: 20px 24px; }
    .sign-agree-row {
      display: flex; align-items: flex-start; gap: 10px;
      background: rgba(9,93,64,0.04); border-radius: 10px; padding: 14px;
      margin-bottom: 16px; border: 1.5px solid rgba(9,93,64,0.10);
    }
    .sign-agree-row input[type=checkbox] { margin-top: 2px; width: 16px; height: 16px; accent-color: var(--cta); cursor: pointer; flex-shrink: 0; }
    .sign-agree-row label { font-size: 0.83rem; color: var(--text); cursor: pointer; line-height: 1.5; font-weight: 600; }
    .sign-name-field { margin-bottom: 16px; }
    .sign-name-field label { display: block; font-size: 0.72rem; font-weight: 800; color: var(--muted); text-transform: uppercase; letter-spacing: 0.07em; margin-bottom: 6px; }
    .sign-name-input {
      width: 100%; padding: 10px 14px; border-radius: 10px;
      border: 1.5px solid rgba(9,93,64,0.15); background: var(--bg);
      font-size: 0.88rem; color: var(--text); font-family: inherit; box-sizing: border-box;
      transition: var(--transition);
    }
    .sign-name-input:focus { outline: none; border-color: var(--cta); box-shadow: 0 0 0 3px rgba(0,128,96,0.10); }
    .sign-submit-btn {
      width: 100%; padding: 12px; background: var(--cta); color: var(--white);
      border: none; border-radius: 10px; font-size: 0.92rem; font-weight: 900;
      cursor: pointer; transition: var(--transition); display: flex; align-items: center;
      justify-content: center; gap: 8px;
    }
    .sign-submit-btn:hover:not(:disabled) { background: var(--cta-dark); transform: translateY(-1px); }
    .sign-submit-btn:disabled { opacity: 0.45; cursor: not-allowed; transform: none; }
    .sign-legal-note { font-size: 0.68rem; color: var(--muted); text-align: center; margin-top: 10px; line-height: 1.5; }

    /* Create contract modal */
    .cc-overlay {
      position: fixed; inset: 0; background: rgba(9,30,40,0.55);
      backdrop-filter: blur(4px); z-index: 9050;
      display: flex; align-items: center; justify-content: center; padding: 20px;
      opacity: 0; pointer-events: none; transition: opacity 0.22s ease;
    }
    .cc-overlay.open { opacity: 1; pointer-events: all; }
    .cc-modal {
      background: var(--white); border-radius: var(--radius-lg);
      box-shadow: 0 24px 60px rgba(9,30,40,0.28);
      width: 100%; max-width: 640px; max-height: 92vh;
      overflow-y: auto; transform: translateY(16px) scale(0.97); transition: transform 0.22s ease;
    }
    .cc-overlay.open .cc-modal { transform: translateY(0) scale(1); }
    .cc-modal-head {
      display: flex; align-items: center; justify-content: space-between;
      padding: 20px 24px 16px; border-bottom: 1.5px solid rgba(9,93,64,0.09);
    }
    .cc-modal-head h3 { font-size: 1.05rem; font-weight: 900; color: var(--heading); display: flex; align-items: center; gap: 8px; }
    .cc-body { padding: 22px 24px; }
    .cc-field { margin-bottom: 16px; }
    .cc-field label { display: block; font-size: 0.72rem; font-weight: 800; color: var(--muted); text-transform: uppercase; letter-spacing: 0.07em; margin-bottom: 6px; }
    .cc-field label span { color: var(--danger); margin-left: 2px; }
    .cc-input, .cc-select, .cc-textarea {
      width: 100%; padding: 10px 14px; border-radius: 10px;
      border: 1.5px solid rgba(9,93,64,0.15); background: var(--bg);
      font-size: 0.86rem; color: var(--text); font-family: inherit;
      transition: var(--transition); box-sizing: border-box;
    }
    .cc-textarea { resize: vertical; min-height: 160px; line-height: 1.6; }
    .cc-input:focus, .cc-select:focus, .cc-textarea:focus {
      outline: none; border-color: var(--cta); background: var(--white);
      box-shadow: 0 0 0 3px rgba(0,128,96,0.10);
    }
    .cc-row { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
    .cc-footer { display: flex; gap: 10px; justify-content: flex-end; padding: 16px 24px; border-top: 1.5px solid rgba(9,93,64,0.09); }

    /* ══ APPROVAL WORKFLOW ══ */
    .approvals-list { display: flex; flex-direction: column; gap: 14px; }
    .approval-item {
      background: var(--white); border-radius: var(--radius-lg);
      border: 1.5px solid rgba(9,93,64,0.09);
      padding: 0; overflow: hidden; transition: var(--transition);
    }
    .approval-item:hover { border-color: rgba(9,93,64,0.22); box-shadow: 0 4px 18px rgba(9,30,40,0.07); }
    .approval-item-head {
      display: flex; align-items: center; gap: 14px; padding: 16px 20px;
      cursor: pointer; user-select: none;
    }
    .appr-icon {
      width: 44px; height: 44px; border-radius: 12px; flex-shrink: 0;
      display: flex; align-items: center; justify-content: center; font-size: 1.1rem;
    }
    .appr-icon.pending   { background: #fff8e1; color: #d97706; }
    .appr-icon.approved  { background: #dcfce7; color: #16a34a; }
    .appr-icon.changes   { background: #fce7f3; color: #9d174d; }
    .appr-icon.resolved  { background: #eff6ff; color: #2563eb; }
    .appr-meta { flex: 1; min-width: 0; }
    .appr-title { font-size: 0.92rem; font-weight: 800; color: var(--heading); margin-bottom: 3px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
    .appr-sub   { font-size: 0.76rem; color: var(--muted); display: flex; align-items: center; gap: 10px; flex-wrap: wrap; }
    .appr-badge {
      display: inline-flex; align-items: center; gap: 5px;
      padding: 4px 10px; border-radius: 20px; font-size: 0.70rem; font-weight: 800;
      text-transform: uppercase; letter-spacing: 0.05em; flex-shrink: 0;
    }
    .appr-badge.pending  { background: #fff8e1; color: #92400e; border: 1px solid #fcd34d; }
    .appr-badge.approved { background: #dcfce7; color: #15803d; border: 1px solid #86efac; }
    .appr-badge.changes  { background: #fce7f3; color: #9d174d; border: 1px solid #f9a8d4; }
    .appr-badge.resolved { background: #eff6ff; color: #1e40af; border: 1px solid #93c5fd; }
    .appr-deadline { font-size: 0.72rem; font-weight: 700; color: var(--danger); background: #fee2e2; padding: 3px 9px; border-radius: 6px; flex-shrink: 0; }
    .appr-deadline.ok { color: #15803d; background: #dcfce7; }

    /* ═══════════════════ MILESTONES ═══════════════════ */
    .ms-timeline { position:relative; padding-left:32px; }
    .ms-timeline::before { content:''; position:absolute; left:11px; top:8px; bottom:8px; width:2px; background:rgba(9,93,64,0.12); border-radius:2px; }
    .ms-item { position:relative; margin-bottom:20px; }
    .ms-dot { position:absolute; left:-26px; top:14px; width:14px; height:14px; border-radius:50%; border:2.5px solid #fff; box-shadow:0 0 0 2px rgba(9,93,64,0.18); flex-shrink:0; }
    .ms-dot.done     { background:#16a34a; box-shadow:0 0 0 2px #16a34a40; }
    .ms-dot.progress { background:#2563eb; box-shadow:0 0 0 2px #2563eb40; }
    .ms-dot.upcoming { background:#d97706; box-shadow:0 0 0 2px #d9770640; }
    .ms-dot.overdue  { background:#dc2626; box-shadow:0 0 0 2px #dc262640; }
    .ms-dot.future   { background:#94a3b8; box-shadow:0 0 0 2px #94a3b840; }
    .ms-card { background:var(--white); border:1.5px solid rgba(9,93,64,0.09); border-radius:12px; padding:14px 18px; box-shadow:0 1px 4px rgba(9,93,64,0.06); transition:box-shadow .15s; }
    .ms-card:hover { box-shadow:0 4px 16px rgba(9,93,64,0.10); }
    .ms-card.done     { border-left:4px solid #16a34a; }
    .ms-card.progress { border-left:4px solid #2563eb; }
    .ms-card.upcoming { border-left:4px solid #d97706; }
    .ms-card.overdue  { border-left:4px solid #dc2626; }
    .ms-card.future   { border-left:4px solid #94a3b8; }
    .ms-pill { display:inline-flex; align-items:center; gap:4px; font-size:0.68rem; font-weight:800; padding:2px 9px; border-radius:20px; text-transform:uppercase; letter-spacing:.04em; }
    .ms-pill.done     { background:#dcfce7; color:#16a34a; }
    .ms-pill.progress { background:#dbeafe; color:#1d4ed8; }
    .ms-pill.upcoming { background:#fef3c7; color:#b45309; }
    .ms-pill.overdue  { background:#fee2e2; color:#dc2626; }
    .ms-pill.future   { background:#f1f5f9; color:#64748b; }
    .ms-summary-bar { display:flex; gap:10px; flex-wrap:wrap; margin-bottom:24px; }
    .ms-sum-card { flex:1; min-width:110px; background:var(--white); border:1.5px solid rgba(9,93,64,0.09); border-radius:10px; padding:12px 16px; text-align:center; }
    .ms-sum-val  { font-size:1.5rem; font-weight:900; line-height:1; }
    .ms-sum-lbl  { font-size:0.7rem; color:var(--muted); margin-top:3px; }
    .ms-overall-bar { height:8px; background:var(--alt); border-radius:100px; overflow:hidden; margin:6px 0 2px; }
    .ms-overall-fill { height:100%; border-radius:100px; background:linear-gradient(90deg,var(--cta),#4ade80); transition:width .5s; }
    /* Admin milestone form */
    .ms-form-grid { display:grid; grid-template-columns:1fr 1fr; gap:12px; }
    @media(max-width:640px){ .ms-form-grid { grid-template-columns:1fr; } }
    .ms-input, .ms-select, .ms-textarea { width:100%; padding:8px 11px; border:1.5px solid rgba(9,93,64,0.18); border-radius:8px; font-family:inherit; font-size:0.83rem; color:var(--heading); background:var(--white); transition:border-color .15s; box-sizing:border-box; }
    .ms-input:focus, .ms-select:focus, .ms-textarea:focus { outline:none; border-color:var(--cta); }
    .ms-label { display:block; font-size:0.73rem; font-weight:800; color:var(--heading); margin-bottom:4px; }
    .approval-body {
      padding: 0 20px 18px; border-top: 1.5px solid rgba(9,93,64,0.07);
      display: none;
    }
    .approval-item.open .approval-body { display: block; }
    .approval-item.open .appr-chevron { transform: rotate(180deg); }
    .appr-chevron { color: var(--muted); font-size: 0.75rem; transition: transform 0.2s ease; flex-shrink: 0; }
    .appr-description {
      font-size: 0.84rem; color: var(--text); line-height: 1.7;
      padding: 14px 0 10px; border-bottom: 1px dashed rgba(9,93,64,0.10);
      margin-bottom: 14px;
    }
    .appr-description p { margin: 0 0 8px; }
    .appr-description ul { padding-left: 20px; margin: 0 0 8px; }
    .appr-description li { margin-bottom: 4px; }
    .appr-attachments { display: flex; gap: 8px; flex-wrap: wrap; margin-bottom: 14px; }
    .appr-file-chip {
      display: inline-flex; align-items: center; gap: 6px;
      padding: 6px 12px; border-radius: 8px; font-size: 0.76rem; font-weight: 700;
      background: rgba(9,93,64,0.06); color: var(--cta); border: 1px solid rgba(9,93,64,0.15);
      cursor: pointer; transition: var(--transition);
    }
    .appr-file-chip:hover { background: rgba(9,93,64,0.12); }
    .appr-actions { display: flex; gap: 10px; flex-wrap: wrap; align-items: center; }
    .appr-approve-btn {
      display: inline-flex; align-items: center; gap: 7px; padding: 9px 20px;
      background: var(--cta); color: var(--white); border: none; border-radius: 10px;
      font-size: 0.84rem; font-weight: 800; cursor: pointer; transition: var(--transition);
    }
    .appr-approve-btn:hover { background: var(--cta-dark); transform: translateY(-1px); }
    .appr-changes-btn {
      display: inline-flex; align-items: center; gap: 7px; padding: 9px 18px;
      background: transparent; color: #9d174d; border: 1.5px solid #f9a8d4;
      border-radius: 10px; font-size: 0.84rem; font-weight: 700; cursor: pointer;
      transition: var(--transition);
    }
    .appr-changes-btn:hover { background: #fce7f3; }
    .appr-feedback-box {
      background: #f8fafc; border-radius: 10px; padding: 14px; margin-top: 12px;
      border-left: 3px solid #f9a8d4;
    }
    .appr-feedback-box .fb-label { font-size: 0.70rem; font-weight: 800; color: #9d174d; text-transform: uppercase; letter-spacing: 0.07em; margin-bottom: 5px; }
    .appr-feedback-box .fb-text { font-size: 0.82rem; color: var(--text); line-height: 1.6; }
    .appr-approved-note {
      display: flex; align-items: center; gap: 8px; font-size: 0.82rem;
      color: #15803d; font-weight: 700; background: #dcfce7;
      padding: 8px 14px; border-radius: 8px;
    }

    /* Approval sidebar badge */
    .sidebar-appr-badge {
      display: inline-flex; align-items: center; justify-content: center;
      background: #d97706; color: var(--white); font-size: 0.58rem; font-weight: 900;
      min-width: 16px; height: 16px; border-radius: 20px; padding: 0 4px;
      margin-left: auto;
    }

    /* Admin approvals */
    .admin-appr-block {
      background: var(--white); border-radius: var(--radius-lg);
      border: 1.5px solid rgba(9,93,64,0.09); margin-bottom: 20px; overflow: hidden;
    }
    .admin-appr-head {
      display: flex; align-items: center; justify-content: space-between;
      padding: 14px 20px; background: rgba(9,93,64,0.04);
      border-bottom: 1.5px solid rgba(9,93,64,0.07);
    }
    .admin-appr-client-name { font-size: 0.88rem; font-weight: 800; color: var(--heading); }
    .admin-appr-client-name span { font-weight: 500; color: var(--muted); font-size: 0.78rem; margin-left: 6px; }
    .admin-appr-table { width: 100%; border-collapse: collapse; }
    .admin-appr-table th {
      font-size: 0.68rem; font-weight: 800; color: var(--muted); text-transform: uppercase;
      letter-spacing: 0.07em; padding: 10px 16px; text-align: left;
      border-bottom: 1.5px solid rgba(9,93,64,0.07); background: rgba(9,93,64,0.02);
    }
    .admin-appr-table td { padding: 12px 16px; border-bottom: 1px solid rgba(9,93,64,0.05); font-size: 0.83rem; vertical-align: middle; }
    .admin-appr-table tr:last-child td { border-bottom: none; }
    .admin-appr-table tr:hover td { background: rgba(9,93,64,0.02); }

    /* Request changes modal */
    .rc-overlay {
      position: fixed; inset: 0; background: rgba(9,30,40,0.55);
      backdrop-filter: blur(4px); z-index: 9200;
      display: flex; align-items: center; justify-content: center; padding: 20px;
      opacity: 0; pointer-events: none; transition: opacity 0.22s ease;
    }
    .rc-overlay.open { opacity: 1; pointer-events: all; }
    .rc-modal {
      background: var(--white); border-radius: var(--radius-lg);
      box-shadow: 0 24px 60px rgba(9,30,40,0.28);
      width: 100%; max-width: 500px;
      transform: translateY(16px) scale(0.97); transition: transform 0.22s ease;
    }
    .rc-overlay.open .rc-modal { transform: translateY(0) scale(1); }
    .rc-modal-head {
      display: flex; align-items: center; justify-content: space-between;
      padding: 18px 22px 14px; border-bottom: 1.5px solid rgba(9,93,64,0.09);
    }
    .rc-modal-head h3 { font-size: 1rem; font-weight: 900; color: var(--heading); display: flex; align-items: center; gap: 8px; }
    .rc-body { padding: 20px 22px; }
    .rc-label { font-size: 0.72rem; font-weight: 800; color: var(--muted); text-transform: uppercase; letter-spacing: 0.07em; margin-bottom: 8px; }
    .rc-textarea {
      width: 100%; padding: 11px 14px; border-radius: 10px;
      border: 1.5px solid rgba(9,93,64,0.15); background: var(--bg);
      font-size: 0.86rem; color: var(--text); font-family: inherit;
      resize: vertical; min-height: 120px; line-height: 1.6; box-sizing: border-box;
      transition: var(--transition);
    }
    .rc-textarea:focus { outline: none; border-color: var(--cta); box-shadow: 0 0 0 3px rgba(0,128,96,0.10); }
    .rc-footer { display: flex; gap: 10px; justify-content: flex-end; padding: 14px 22px; border-top: 1.5px solid rgba(9,93,64,0.09); }

    /* Create approval modal (admin) */
    .ca-overlay {
      position: fixed; inset: 0; background: rgba(9,30,40,0.55);
      backdrop-filter: blur(4px); z-index: 9150;
      display: flex; align-items: center; justify-content: center; padding: 20px;
      opacity: 0; pointer-events: none; transition: opacity 0.22s ease;
    }
    .ca-overlay.open { opacity: 1; pointer-events: all; }
    .ca-modal {
      background: var(--white); border-radius: var(--radius-lg);
      box-shadow: 0 24px 60px rgba(9,30,40,0.28);
      width: 100%; max-width: 600px; max-height: 92vh; overflow-y: auto;
      transform: translateY(16px) scale(0.97); transition: transform 0.22s ease;
    }
    .ca-overlay.open .ca-modal { transform: translateY(0) scale(1); }
    .ca-modal-head {
      display: flex; align-items: center; justify-content: space-between;
      padding: 20px 24px 16px; border-bottom: 1.5px solid rgba(9,93,64,0.09);
    }
    .ca-modal-head h3 { font-size: 1.05rem; font-weight: 900; color: var(--heading); display: flex; align-items: center; gap: 8px; }
    .ca-body { padding: 22px 24px; }
    .ca-field { margin-bottom: 16px; }
    .ca-field label { display: block; font-size: 0.72rem; font-weight: 800; color: var(--muted); text-transform: uppercase; letter-spacing: 0.07em; margin-bottom: 6px; }
    .ca-field label span { color: var(--danger); margin-left: 2px; }
    .ca-input, .ca-select, .ca-textarea {
      width: 100%; padding: 10px 14px; border-radius: 10px;
      border: 1.5px solid rgba(9,93,64,0.15); background: var(--bg);
      font-size: 0.86rem; color: var(--text); font-family: inherit;
      transition: var(--transition); box-sizing: border-box;
    }
    .ca-textarea { resize: vertical; min-height: 140px; line-height: 1.6; }
    .ca-input:focus, .ca-select:focus, .ca-textarea:focus {
      outline: none; border-color: var(--cta); background: var(--white);
      box-shadow: 0 0 0 3px rgba(0,128,96,0.10);
    }
    .ca-row { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
    .ca-footer { display: flex; gap: 10px; justify-content: flex-end; padding: 16px 24px; border-top: 1.5px solid rgba(9,93,64,0.09); }

    /* ══════════════ NOTIFICATIONS ══════════════ */
    /* Bell button in top nav */
    .notif-bell-btn {
      position: relative; background: none; border: 1.5px solid rgba(9,93,64,0.14);
      border-radius: 10px; width: 38px; height: 38px; display: flex; align-items: center;
      justify-content: center; cursor: pointer; transition: var(--transition); color: var(--heading);
      font-size: 1rem; flex-shrink: 0;
    }
    .notif-bell-btn:hover { border-color: var(--cta); color: var(--cta); background: rgba(9,93,64,0.05); }
    .notif-bell-badge {
      position: absolute; top: -5px; right: -5px; background: #ef4444; color: #fff;
      font-size: 0.6rem; font-weight: 900; min-width: 16px; height: 16px; border-radius: 100px;
      display: flex; align-items: center; justify-content: center; padding: 0 4px;
      border: 2px solid var(--white); line-height: 1; pointer-events: none;
    }
    .notif-bell-badge.hidden { display: none; }

    /* Dropdown panel */
    .notif-dropdown {
      position: absolute; top: calc(100% + 10px); right: 0; width: 380px; max-width: calc(100vw - 24px);
      background: var(--white); border: 1.5px solid rgba(9,93,64,0.12);
      border-radius: 16px; box-shadow: 0 12px 40px rgba(9,93,64,0.13);
      z-index: 2000; overflow: hidden;
      opacity: 0; transform: translateY(-8px) scale(0.98);
      transition: opacity 0.18s, transform 0.18s; pointer-events: none;
    }
    .notif-dropdown.open { opacity: 1; transform: translateY(0) scale(1); pointer-events: auto; }
    .notif-dropdown-head {
      display: flex; align-items: center; justify-content: space-between;
      padding: 14px 18px 12px; border-bottom: 1.5px solid rgba(9,93,64,0.08);
    }
    .notif-dropdown-title { font-size: 0.9rem; font-weight: 800; color: var(--heading); }
    .notif-mark-all-btn {
      font-size: 0.72rem; font-weight: 700; color: var(--cta); background: none; border: none;
      cursor: pointer; padding: 4px 8px; border-radius: 6px; transition: var(--transition);
    }
    .notif-mark-all-btn:hover { background: rgba(9,93,64,0.08); }
    .notif-list { max-height: 380px; overflow-y: auto; }
    .notif-item {
      display: flex; align-items: flex-start; gap: 12px; padding: 13px 18px;
      border-bottom: 1px solid rgba(9,93,64,0.06); cursor: pointer;
      transition: background 0.15s; position: relative;
    }
    .notif-item:last-child { border-bottom: none; }
    .notif-item:hover { background: rgba(9,93,64,0.04); }
    .notif-item.unread { background: rgba(9,93,64,0.035); }
    .notif-item.unread::before {
      content: ''; position: absolute; left: 0; top: 0; bottom: 0; width: 3px;
      background: var(--cta); border-radius: 0 2px 2px 0;
    }
    .notif-icon {
      width: 34px; height: 34px; border-radius: 10px; display: flex; align-items: center;
      justify-content: center; font-size: 0.82rem; flex-shrink: 0; margin-top: 1px;
    }
    .notif-icon.invoice  { background: #ede9fe; color: #7c3aed; }
    .notif-icon.approval { background: #dcfce7; color: #16a34a; }
    .notif-icon.contract { background: #eff6ff; color: #2563eb; }
    .notif-icon.message  { background: #fef3c7; color: #d97706; }
    .notif-icon.report   { background: rgba(211,225,98,0.28); color: var(--accent); }
    .notif-icon.system   { background: rgba(9,93,64,0.1); color: var(--cta); }
    .notif-icon.payment  { background: #fce7f3; color: #db2777; }
    .notif-content { flex: 1; min-width: 0; }
    .notif-text { font-size: 0.82rem; font-weight: 600; color: var(--heading); line-height: 1.4; }
    .notif-item.unread .notif-text { font-weight: 700; }
    .notif-sub  { font-size: 0.74rem; color: var(--text-muted); margin-top: 2px; line-height: 1.35; }
    .notif-time { font-size: 0.68rem; color: var(--muted); margin-top: 4px; display: flex; align-items: center; gap: 4px; }
    .notif-unread-dot {
      width: 7px; height: 7px; border-radius: 50%; background: var(--cta);
      flex-shrink: 0; margin-top: 6px;
    }
    .notif-empty {
      text-align: center; padding: 40px 20px; color: var(--text-muted);
    }
    .notif-empty i { font-size: 2rem; opacity: 0.2; display: block; margin-bottom: 10px; }
    .notif-dropdown-footer {
      padding: 10px 18px; border-top: 1.5px solid rgba(9,93,64,0.08);
      text-align: center;
    }
    .notif-view-all-btn {
      font-size: 0.78rem; font-weight: 700; color: var(--cta); background: none; border: none;
      cursor: pointer; padding: 5px 12px; border-radius: 8px; transition: var(--transition);
      width: 100%;
    }
    .notif-view-all-btn:hover { background: rgba(9,93,64,0.07); }

    /* Full notifications page */
    .notif-page-list { display: flex; flex-direction: column; gap: 0; border: 1.5px solid rgba(9,93,64,0.1); border-radius: 14px; overflow: hidden; background: var(--white); }
    .notif-page-item {
      display: flex; align-items: flex-start; gap: 14px; padding: 16px 20px;
      border-bottom: 1px solid rgba(9,93,64,0.07); cursor: pointer; transition: background 0.15s;
      position: relative;
    }
    .notif-page-item:last-child { border-bottom: none; }
    .notif-page-item:hover { background: rgba(9,93,64,0.03); }
    .notif-page-item.unread { background: rgba(9,93,64,0.04); }
    .notif-page-item.unread::before {
      content: ''; position: absolute; left: 0; top: 0; bottom: 0; width: 4px;
      background: var(--cta); border-radius: 0 2px 2px 0;
    }

    /* Admin Notification Manager */
    .admin-notif-table { width: 100%; border-collapse: collapse; font-size: 0.84rem; }
    .admin-notif-table th { text-align: left; padding: 10px 14px; font-size: 0.72rem; font-weight: 800; text-transform: uppercase; letter-spacing: .06em; color: var(--text-muted); border-bottom: 1.5px solid rgba(9,93,64,0.1); }
    .admin-notif-table td { padding: 12px 14px; border-bottom: 1px solid rgba(9,93,64,0.06); vertical-align: top; }
    .admin-notif-table tr:last-child td { border-bottom: none; }

    /* Send Notification modal */
    .sn-overlay {
      position: fixed; inset: 0; background: rgba(9,30,22,0.45); backdrop-filter: blur(4px);
      z-index: 3000; display: flex; align-items: center; justify-content: center;
      opacity: 0; pointer-events: none; transition: opacity 0.2s;
    }
    .sn-overlay.open { opacity: 1; pointer-events: auto; }
    .sn-modal {
      background: var(--white); border-radius: 18px; width: 100%; max-width: 500px;
      box-shadow: 0 20px 60px rgba(9,93,64,0.18); margin: 16px;
      transform: translateY(18px); transition: transform 0.22s;
    }
    .sn-overlay.open .sn-modal { transform: translateY(0); }
    .sn-modal-head {
      display: flex; align-items: center; justify-content: space-between;
      padding: 20px 24px 16px; border-bottom: 1.5px solid rgba(9,93,64,0.09);
    }
    .sn-modal-head h3 { font-size: 1rem; font-weight: 800; color: var(--heading); }
    .sn-body { padding: 20px 24px; display: flex; flex-direction: column; gap: 14px; }
    .sn-field label { display: block; font-size: 0.78rem; font-weight: 700; color: var(--heading); margin-bottom: 5px; }
    .sn-field label span { color: #ef4444; }
    .sn-input, .sn-select, .sn-textarea {
      width: 100%; padding: 9px 12px; border: 1.5px solid rgba(9,93,64,0.18); border-radius: 9px;
      font-family: inherit; font-size: 0.84rem; color: var(--heading); background: var(--white);
      transition: var(--transition); box-sizing: border-box;
    }
    .sn-input:focus, .sn-select:focus, .sn-textarea:focus { outline: none; border-color: var(--cta); }
    .sn-textarea { resize: vertical; min-height: 80px; }
    .sn-footer { display: flex; gap: 10px; justify-content: flex-end; padding: 16px 24px; border-top: 1.5px solid rgba(9,93,64,0.09); }

    /* ── Ads Data Sync ── */
    .sync-platform-card { background:var(--card); border:1.5px solid var(--border); border-radius:16px; padding:20px; transition:box-shadow .2s,border-color .2s; }
    .sync-platform-card:hover { box-shadow:0 4px 20px rgba(0,0,0,0.07); }
    .sync-platform-card.connected { border-color:rgba(22,163,74,0.35); }
    .sync-platform-card.error     { border-color:rgba(239,68,68,0.35); }
    .sync-platform-icon { width:44px;height:44px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:1.2rem;flex-shrink:0; }
    .sync-status-dot { width:9px;height:9px;border-radius:50%;flex-shrink:0; }
    .sync-status-dot.connected { background:#16a34a; box-shadow:0 0 0 3px rgba(22,163,74,0.2); animation:syncPulse 2s infinite; }
    .sync-status-dot.disconnected { background:#94a3b8; }
    .sync-status-dot.syncing { background:#d97706; animation:syncPulse 0.6s infinite; }
    @keyframes syncPulse { 0%,100% { box-shadow:0 0 0 3px rgba(22,163,74,0.2); } 50% { box-shadow:0 0 0 6px rgba(22,163,74,0.05); } }
    .sync-progress { height:3px;background:var(--border);border-radius:2px;overflow:hidden;margin-top:10px; }
    .sync-progress-bar { height:100%;background:linear-gradient(90deg,var(--cta),#10b981);border-radius:2px;transition:width 0.4s ease;width:0%; }
    .sync-progress-bar.running { animation:syncBar 1.5s ease-in-out forwards; }
    @keyframes syncBar { 0%{width:0%} 30%{width:45%} 70%{width:80%} 100%{width:100%} }
    .sync-badge-live { display:inline-flex;align-items:center;gap:5px;background:#dcfce7;color:#16a34a;font-size:0.68rem;font-weight:800;padding:2px 10px;border-radius:20px;letter-spacing:.02em; }
    .sync-badge-live::before { content:''; width:6px;height:6px;border-radius:50%;background:#16a34a;animation:syncPulse 2s infinite; }
    .sync-badge-disconnected { display:inline-flex;align-items:center;gap:5px;background:#f1f5f9;color:#64748b;font-size:0.68rem;font-weight:700;padding:2px 10px;border-radius:20px; }
    .sync-summary-card { background:var(--card);border:1.5px solid var(--border);border-radius:13px;padding:14px 20px;flex:1;min-width:130px; }
    .sync-summary-card .val { font-size:1.7rem;font-weight:900;color:var(--heading);line-height:1; }
    .sync-summary-card .lbl { font-size:0.73rem;color:var(--text-muted);margin-top:3px; }
    .oauth-overlay { position:fixed;inset:0;background:rgba(0,0,0,0.45);backdrop-filter:blur(4px);z-index:2000;display:none;align-items:center;justify-content:center; }
    .oauth-overlay.open { display:flex; }
    .oauth-modal { background:var(--card);border-radius:20px;padding:32px;width:100%;max-width:440px;box-shadow:0 20px 60px rgba(0,0,0,0.2);text-align:center; }
    .oauth-platform-icon { width:64px;height:64px;border-radius:18px;display:flex;align-items:center;justify-content:center;font-size:1.8rem;margin:0 auto 16px; }
    .oauth-steps { display:flex;flex-direction:column;gap:8px;margin:20px 0; }
    .oauth-step { display:flex;align-items:center;gap:10px;padding:10px 14px;border-radius:10px;background:var(--sidebar-active-bg,rgba(9,93,64,0.06));font-size:0.82rem;color:var(--text-muted); }
    .oauth-step.done { color:#16a34a; }
    .oauth-step.done .oauth-step-icon { color:#16a34a; }
    .oauth-step-icon { width:22px;text-align:center;font-size:0.82rem; }
    .oauth-input { width:100%;padding:10px 14px;border:1.5px solid var(--border);border-radius:10px;font-size:0.85rem;background:var(--bg);color:var(--text);margin-bottom:10px;box-sizing:border-box; }
    .oauth-input:focus { outline:none;border-color:var(--cta); }
    .sync-client-block { background:var(--card);border:1.5px solid var(--border);border-radius:16px;padding:20px;margin-bottom:18px; }
    .sync-client-head { display:flex;align-items:center;gap:12px;margin-bottom:16px;padding-bottom:14px;border-bottom:1.5px solid var(--border); }
    .sync-platforms-grid { display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:12px; }

  
    /* ── Offboarding ── */
    .ob-client-card { background:var(--card); border-radius:var(--radius-lg); border:1.5px solid var(--border); padding:20px; margin-bottom:16px; }
    .ob-client-card.in-progress { border-color:rgba(245,158,11,0.4); background:rgba(245,158,11,0.03); }
    .ob-client-card.completed   { border-color:rgba(16,185,129,0.4); background:rgba(16,185,129,0.03); }
    .ob-client-card.archived    { border-color:rgba(148,163,184,0.3); opacity:0.7; }
    .ob-badge { display:inline-flex;align-items:center;gap:5px;padding:3px 10px;border-radius:20px;font-size:0.7rem;font-weight:800; }
    .ob-badge.not-started  { background:rgba(148,163,184,0.12);color:#64748b; }
    .ob-badge.in-progress  { background:rgba(245,158,11,0.12);color:#d97706; }
    .ob-badge.completed    { background:rgba(16,185,129,0.12);color:#059669; }
    .ob-badge.archived     { background:rgba(148,163,184,0.12);color:#94a3b8; }
    .ob-checklist { list-style:none;padding:0;margin:14px 0 0;display:flex;flex-direction:column;gap:7px; }
    .ob-checklist li { display:flex;align-items:flex-start;gap:10px;font-size:0.82rem;color:var(--heading); }
    .ob-checklist li.done { color:var(--text-muted);text-decoration:line-through; }
    .ob-check-btn { width:20px;height:20px;border-radius:6px;border:2px solid var(--border);background:var(--card);cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all 0.15s; }
    .ob-check-btn.done { background:#059669;border-color:#059669;color:#fff; }
    .ob-progress-bar-wrap { height:6px;background:var(--alt);border-radius:3px;margin:10px 0 4px;overflow:hidden; }
    .ob-progress-fill { height:100%;border-radius:3px;background:linear-gradient(90deg,var(--cta),#7c3aed);transition:width 0.4s; }
    .ob-reason-select { padding:9px 12px;border-radius:8px;border:1.5px solid var(--border);background:var(--card);color:var(--heading);font-size:0.83rem;width:100%; }
    .ob-summary-grid { display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:20px; }
    @media(max-width:600px) { .ob-summary-grid { grid-template-columns:1fr 1fr; } }

        /* ── Analytics Hub ── */
    .ah-tab-bar { display:flex;gap:6px;margin-bottom:20px;background:var(--alt);padding:5px;border-radius:12px;width:fit-content; }
    .ah-tab { padding:8px 18px;border:none;background:none;border-radius:8px;font-size:0.82rem;font-weight:700;color:var(--text-muted);cursor:pointer;transition:all 0.15s; }
    .ah-tab.active { background:var(--card);color:var(--heading);box-shadow:0 1px 4px rgba(0,0,0,0.1); }
    .ah-panel { display:none; }
    .ah-panel.active { display:block; }
    .ah-source-row { display:flex;align-items:center;gap:10px;font-size:0.8rem;margin-bottom:6px; }
    .ah-source-label { width:130px;font-weight:700;color:var(--heading);flex-shrink:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis; }
    .ah-source-val { width:54px;text-align:right;color:var(--text-muted);flex-shrink:0; }
    .ah-connect-prompt { text-align:center;padding:40px 20px;background:var(--alt);border-radius:16px;border:2px dashed var(--border); }
    