﻿*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --ink:#1a1a2e;--ink2:#2d2d4a;--paper:#f5f3ee;--paper2:#ede9e1;
  --gold:#c9973a;--gold-light:#e8c97a;--sage:#4a7c59;--sage-light:#7aab89;
  --rust:#b85c38;--rust-light:#e07d5a;--slate:#5a6a7e;
  --border:rgba(26,26,46,0.12);--shadow:0 2px 12px rgba(26,26,46,0.08);
  --shadow-lg:0 8px 32px rgba(26,26,46,0.14);
}
body{font-family:'Segoe UI',Tahoma,Geneva,Verdana,sans-serif;background:var(--paper);color:var(--ink);min-height:100vh;font-size:14px}

/* â”€â”€ ACCESS CONTROL TABLE â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
#access-control-table tbody tr:nth-child(odd){background:var(--paper2)}
#access-control-table tbody tr:nth-child(even){background:white}
#access-control-table td{padding:8px 12px;border-bottom:1px solid var(--border)}
.access-select{padding:4px 8px;border:1.5px solid var(--border);border-radius:4px;font-size:12px;background:white;cursor:pointer;min-width:120px;transition:border-color .15s,background .15s}
.access-select.level-full{border-color:var(--sage);color:#2a5c38;background:#f0f7f2}
.access-select.level-view{border-color:var(--gold);color:#7a5c00;background:#fffbf0}
.access-select.level-none{border-color:var(--rust);color:var(--rust);background:#fff5f5}
html.dark-mode #access-control-table tbody tr:nth-child(odd){background:#1e2035}
html.dark-mode #access-control-table tbody tr:nth-child(even){background:#1a1c2e}
html.dark-mode .access-select{background:#252740;color:#dde1f0;border-color:rgba(255,255,255,.15)}
html.dark-mode .access-select.level-full{background:#1a2e20;color:#7aab89;border-color:#4a7c59}
html.dark-mode .access-select.level-view{background:#2e2810;color:#c9973a;border-color:#c9973a}
html.dark-mode .access-select.level-none{background:#2e1a1a;color:#e07d5a;border-color:#b85c38}

/* â”€â”€ DARK MODE â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
html.dark-mode body{background:#0f1019;color:#dde1f0}
html.dark-mode .main-content{background:#0f1019}
html.dark-mode .card,.dark-mode .stat-card{background:#1a1c2e!important;border-color:rgba(255,255,255,.08)!important}
html.dark-mode .stat-num{color:#dde1f0}
html.dark-mode .stat-label{color:#8b92b8}
html.dark-mode .page-title{color:#dde1f0}
html.dark-mode .page-sub{color:#8b92b8}
html.dark-mode h2,html.dark-mode h3,html.dark-mode h4{color:#dde1f0}
html.dark-mode table{background:#1a1c2e}
html.dark-mode th{background:#0f1019!important;color:#aab0d0!important;border-color:rgba(255,255,255,.08)!important}
html.dark-mode td{border-color:rgba(255,255,255,.06)!important;color:#dde1f0!important}
html.dark-mode tr:hover td{background:rgba(255,255,255,.04)!important}
html.dark-mode .task-row-overdue td{background:rgba(198,40,40,.25)!important}
html.dark-mode .task-row-today td{background:rgba(249,168,37,.2)!important}
html.dark-mode .task-row-week td{background:rgba(13,71,161,.2)!important}
html.dark-mode .modal-overlay{background:rgba(0,0,0,.75)}
html.dark-mode .modal-panel{background:#1a1c2e!important;border-color:rgba(255,255,255,.1)}
html.dark-mode .form-input,html.dark-mode .form-select,html.dark-mode .form-textarea,
html.dark-mode .filter-input,html.dark-mode .filter-select{background:#252740!important;border-color:rgba(255,255,255,.15)!important;color:#dde1f0!important}
html.dark-mode .filter-row{background:transparent}
html.dark-mode .btn-ghost{border-color:rgba(255,255,255,.2);color:#dde1f0}
html.dark-mode .btn-ghost:hover:not(:disabled){background:rgba(255,255,255,.07)}
html.dark-mode .badge{background:rgba(255,255,255,.1)}
html.dark-mode .notes-section{border-color:rgba(255,255,255,.1)}
html.dark-mode .note-item{background:#252740;border-color:rgba(255,255,255,.1)}
html.dark-mode .add-note-form textarea{background:#252740;border-color:rgba(255,255,255,.15);color:#dde1f0}
/* pipeline dark */
html.dark-mode .pipeline-step{background:transparent}
html.dark-mode .pipeline-dot{background:#252740;border-color:rgba(255,255,255,.2);color:#aab0d0}
html.dark-mode .pipeline-label{color:#6b7294}
html.dark-mode .pipeline-label.current{color:#dde1f0;font-weight:700}
html.dark-mode .pipeline-connector{background:rgba(255,255,255,.12)}
html.dark-mode .pipeline-connector.done{background:var(--sage)}
/* modal dark */
html.dark-mode .modal{background:#1a1c2e;border-color:rgba(255,255,255,.1)}
html.dark-mode .modal-header{background:#151728!important;border-color:rgba(255,255,255,.1)!important}
html.dark-mode .modal-title{color:#dde1f0}
html.dark-mode .modal-close{color:#8b92b8}
html.dark-mode .modal-box{background:#1a1c2e;color:#dde1f0}
/* activity items dark */
html.dark-mode .activity-item{background:#252740!important;border-color:rgba(255,255,255,.1)!important}
html.dark-mode .activity-item.done-item{background:#1e2035!important;opacity:.8}
html.dark-mode .activity-title-text{color:#dde1f0}
html.dark-mode .activity-row input,html.dark-mode .activity-row select{background:#252740!important;border-color:rgba(255,255,255,.15)!important;color:#dde1f0!important}
/* multi-select dark */
html.dark-mode .ms-box{background:#252740;border-color:rgba(255,255,255,.15);color:#dde1f0}
html.dark-mode .ms-placeholder{color:#6b7294}
html.dark-mode .ms-dropdown{background:#1a1c2e;border-color:rgba(255,255,255,.15)}
html.dark-mode .ms-item{color:#dde1f0}
html.dark-mode .ms-item:hover{background:#252740}
/* searchable select dark */
html.dark-mode .ss-list{background:#1a1c2e;border-color:rgba(255,255,255,.15)}
html.dark-mode .ss-item{color:#dde1f0}
html.dark-mode .ss-item:hover,html.dark-mode .ss-item.active{background:#252740}
/* reject panel dark */
html.dark-mode .reject-panel{background:#2e1a1a!important;border-color:#b85c38}
html.dark-mode .reject-panel-title{color:#e07d5a}
html.dark-mode .note-item.rejection-note{background:#2e1a1a!important}
/* notes section dark */
html.dark-mode .notes-section-title{color:#dde1f0}
html.dark-mode .note-author{color:#dde1f0}
html.dark-mode .note-text{color:#dde1f0}
html.dark-mode .note-time{color:#8b93b5}
html.dark-mode .note-role-badge{background:#1e2042;color:#8b93b5;border-color:rgba(255,255,255,.1)}
html.dark-mode .audit-entry{color:#8b92b8;border-color:rgba(255,255,255,.06)}
html.dark-mode .audit-from{color:#dde1f0}
/* bulk modal dark */
html.dark-mode .bulk-section{background:#151728;border-color:rgba(255,255,255,.08)}
html.dark-mode .bulk-section-label{color:#8b92b8}
html.dark-mode .bulk-section-label::before{background:var(--gold)}
html.dark-mode .bulk-mode-tab{background:#252740;color:#8b92b8;border-color:rgba(255,255,255,.1)}
html.dark-mode .bulk-mode-tab.active{background:#1e3a5f;color:#7eb8f7;border-color:#4a8cc0}
html.dark-mode .bulk-mode-tab:hover:not(.active){background:#1e2035}
html.dark-mode label,.dark-mode .form-label{color:#aab0d0!important}
html.dark-mode .sidebar-logout{color:rgba(255,255,255,.5)}
html.dark-mode select option{background:#1a1c2e;color:#dde1f0}
/* quick tasks */
.qt-row{display:flex;align-items:flex-start;gap:12px;padding:13px 20px;border-bottom:1px solid var(--border)}
.qt-row:last-child{border-bottom:none}
.qt-row.qt-overdue{background:rgba(198,40,40,.05)}
.qt-title{font-size:14px;font-weight:500;margin-bottom:5px}
.qt-title.done{text-decoration:line-through;color:var(--slate)}
.qt-badge-client{font-size:11px;background:rgba(201,151,58,.13);color:#7a5c00;padding:2px 8px;border-radius:10px}
.qt-badge-overdue{font-size:11px;background:#fde8e8;color:var(--rust);padding:2px 7px;border-radius:10px;font-weight:600}
.qt-badge-today{font-size:11px;background:#fff8e1;color:#b45309;padding:2px 7px;border-radius:10px;font-weight:600}
.qt-badge-date{font-size:11px;color:var(--slate)}
.qt-meta{font-size:11px;color:var(--slate)}
.qt-actions{display:flex;gap:2px;flex-shrink:0;align-items:flex-start}
.qt-icon-btn{background:none;border:none;cursor:pointer;color:var(--slate);font-size:15px;padding:3px 5px;opacity:.5;transition:opacity .15s,color .15s;line-height:1}
.qt-icon-btn:hover{opacity:1}
.qt-icon-btn.edit:hover{color:var(--gold)}
.qt-icon-btn.del:hover{color:var(--rust)}
.qt-edit-form{padding:10px 20px 14px 52px;border-bottom:1px solid var(--border);background:var(--paper2)}
.qt-dot{width:20px;height:20px;border-radius:50%;border:2px solid rgba(100,110,130,.4);background:transparent;cursor:pointer;flex-shrink:0;margin-top:2px;display:flex;align-items:center;justify-content:center;color:white;font-size:11px;font-weight:700;transition:all .15s}
.qt-dot:hover{border-color:var(--sage);opacity:.8}
.qt-dot.is-done{background:var(--sage);border-color:var(--sage)}
.qt-dot.is-overdue{border-color:var(--rust)}
/* quick tasks dark */
html.dark-mode .qt-dot{border-color:rgba(255,255,255,.4)}
html.dark-mode .qt-dot.is-done{background:var(--sage);border-color:var(--sage)}
html.dark-mode .qt-dot.is-overdue{border-color:var(--rust)}
html.dark-mode .qt-row{border-color:rgba(255,255,255,.06)}
html.dark-mode .qt-row.qt-overdue{background:rgba(198,40,40,.14)}
html.dark-mode .qt-badge-client{background:rgba(201,151,58,.2);color:#c9973a}
html.dark-mode .qt-badge-overdue{background:rgba(198,40,40,.3);color:#ff9898}
html.dark-mode .qt-badge-today{background:rgba(180,83,9,.25);color:#fbbf24}
html.dark-mode .qt-edit-form{background:#151728}
html.dark-mode #qt-list-tabs button{color:#6b7294!important}
html.dark-mode #qt-list-tabs button.qt-tab-active{color:#dde1f0!important}
/* calendar dark */
html.dark-mode .cal-cell{background:#1a1c2e!important;border-color:rgba(255,255,255,.08)!important}
html.dark-mode .cal-cell-today{background:rgba(201,151,58,.15)!important;border-color:var(--gold)!important}
html.dark-mode .cal-day-num{color:#aab0d0}

/* AUDIT LOG */
#al-table th{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--slate);background:var(--paper2)}
#al-table td{vertical-align:top;padding:10px 12px;border-bottom:1px solid var(--border)}
#al-table tr:last-child td{border-bottom:none}
#al-table tr:hover td{background:var(--paper2)}
html.dark-mode #al-table th{background:#151728}
html.dark-mode #al-table tr:hover td{background:#252740}
html.dark-mode #al-summary{color:#6b7294;border-color:rgba(255,255,255,.06)}
html.dark-mode #al-pagination{border-color:rgba(255,255,255,.06)}
.tour-menu-item{display:flex;align-items:center;gap:10px;padding:8px 14px;font-size:12px;cursor:pointer;color:var(--ink);transition:background .15s}
.tour-menu-item:hover{background:var(--paper2)}
.tour-menu-item .tour-icon{font-size:15px;width:20px;text-align:center}
.tour-menu-item .tour-label{font-weight:500}
.tour-menu-item .tour-steps{font-size:10px;color:var(--slate);margin-left:auto}
html.dark-mode #tour-menu{background:#1a1c2e;border-color:#3a3d5c}
html.dark-mode .tour-menu-item:hover{background:#252740}

/* BULK CREATE MODAL */
.bulk-section{background:var(--paper2);border:1px solid var(--border);border-radius:8px;padding:16px 18px;margin-bottom:14px}
.bulk-section-label{font-size:10px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--slate);margin-bottom:12px;display:flex;align-items:center;gap:6px}
.bulk-section-label::before{content:'';display:inline-block;width:3px;height:12px;background:var(--gold);border-radius:2px;flex-shrink:0}
.bulk-mode-tab{flex:1;padding:10px 14px;font-size:13px;font-weight:600;border:1.5px solid var(--border);cursor:pointer;background:var(--paper2);color:var(--slate);transition:all .15s;display:flex;align-items:center;justify-content:center;gap:7px}
.bulk-mode-tab:first-child{border-radius:8px 0 0 8px;border-right:none}
.bulk-mode-tab:last-child{border-radius:0 8px 8px 0}
.bulk-mode-tab.active{background:#1e293b;color:#fff;border-color:#1e293b}
.bulk-mode-tab:hover:not(.active){background:var(--cream)}
.bulk-list-box{max-height:220px;overflow-y:auto;border:1px solid var(--border);border-radius:6px;background:var(--paper)}
.bulk-list-row{display:flex;align-items:center;gap:10px;padding:9px 12px;border-bottom:1px solid var(--border);cursor:pointer;transition:background .1s;font-size:13px}
.bulk-list-row:last-child{border-bottom:none}
.bulk-list-row:hover{background:var(--cream)}
.bulk-list-row input[type=checkbox]{width:15px;height:15px;accent-color:var(--ink);flex-shrink:0;cursor:pointer}
.bulk-list-row .brow-name{font-weight:500;flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.bulk-list-row .brow-sub{font-size:11px;color:var(--slate);white-space:nowrap}
html.dark-mode .bulk-list-box{background:#1a1c2e}
html.dark-mode .bulk-list-row{border-color:rgba(255,255,255,.06);color:#dde1f0}
html.dark-mode .bulk-list-row:hover{background:#252740}

/* LOGIN */
.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--ink);background-image:radial-gradient(ellipse at 20% 50%,rgba(201,151,58,.15) 0%,transparent 60%)}
.login-card{background:var(--paper);border-radius:4px;padding:48px 40px;width:380px;box-shadow:var(--shadow-lg)}
.login-brand{font-size:28px;color:var(--ink);margin-bottom:2px;line-height:1;font-weight:700;letter-spacing:-.3px}
.login-company{font-size:15px;color:var(--ink);font-weight:500;margin-bottom:2px;opacity:.75}
.login-sub{font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);margin-bottom:36px}
.login-label{font-size:11px;font-weight:500;letter-spacing:.08em;text-transform:uppercase;color:var(--slate);margin-bottom:6px;display:block}
.login-input{width:100%;padding:10px 14px;border:1.5px solid var(--border);border-radius:2px;background:white;font-size:14px;color:var(--ink);margin-bottom:16px}
.login-input:focus{outline:none;border-color:var(--gold)}
.btn-primary{width:100%;padding:12px;background:var(--ink);color:var(--gold-light);border:none;border-radius:2px;font-size:12px;letter-spacing:.15em;text-transform:uppercase;cursor:pointer;transition:all .2s;font-weight:500}
.btn-primary:hover{background:var(--ink2)}
.error-msg{color:var(--rust);font-size:12px;margin-top:-12px;margin-bottom:12px}

/* LAYOUT */
.app-layout{display:flex;min-height:100vh}
.sidebar{width:220px;background:var(--ink);display:flex;flex-direction:column;flex-shrink:0}
.sidebar-brand{padding:24px 20px 20px;border-bottom:1px solid rgba(255,255,255,.06)}
.sidebar-title{font-size:20px;color:white;line-height:1;font-weight:700;letter-spacing:-.3px}
.sidebar-company{font-size:11px;color:rgba(255,255,255,.65);margin-top:6px;font-weight:500;line-height:1.3}
.sidebar-tagline{font-size:10px;color:rgba(255,255,255,.35);margin-top:2px;line-height:1.3;font-style:italic}
.sidebar-role{font-size:9px;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);margin-top:8px}
.sidebar-nav{padding:16px 0;flex:1}
.nav-section{padding:8px 20px;font-size:9px;letter-spacing:.15em;text-transform:uppercase;color:rgba(255,255,255,.3);margin-top:12px}
.nav-item{display:flex;align-items:center;gap:10px;padding:10px 20px;color:rgba(255,255,255,.5);cursor:pointer;font-size:13px;transition:all .15s;border-left:2px solid transparent}
.nav-item:hover{color:rgba(255,255,255,.85);background:rgba(255,255,255,.04)}
.nav-item.active{color:var(--gold-light);border-left-color:var(--gold);background:rgba(201,151,58,.08)}
.sidebar-logout{padding:16px 20px;border-top:1px solid rgba(255,255,255,.06);color:rgba(255,255,255,.3);font-size:12px;cursor:pointer;transition:color .15s}
.sidebar-logout:hover{color:rgba(255,255,255,.6)}
.main-content{flex:1;padding:32px 36px;overflow-y:auto;max-height:100vh}

/* PAGE */
.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:28px}
.page-title{font-size:28px;color:var(--ink);font-weight:600}
.page-sub{font-size:12px;color:var(--slate);margin-top:2px}

/* BUTTONS */
.btn{padding:8px 18px;border:none;border-radius:2px;font-size:13px;font-weight:500;cursor:pointer;transition:all .15s;display:inline-flex;align-items:center;gap:6px}
.btn:disabled{opacity:.45;cursor:not-allowed}
.btn-dark{background:var(--ink);color:var(--gold-light)}
.btn-dark:hover:not(:disabled){background:var(--ink2)}
.btn-sage{background:var(--sage);color:white}
.btn-sage:hover:not(:disabled){background:var(--sage-light)}
.btn-rust{background:var(--rust);color:white}
.btn-rust:hover:not(:disabled){background:var(--rust-light)}
.btn-sm{padding:5px 12px;font-size:12px}
.btn-ghost{background:transparent;border:1.5px solid var(--border);color:var(--ink)}
.btn-ghost:hover:not(:disabled){background:var(--paper2)}

/* FORM */
.form-group{margin-bottom:16px}
.form-label{font-size:11px;font-weight:500;letter-spacing:.08em;text-transform:uppercase;color:var(--slate);margin-bottom:6px;display:block}
.form-input,.form-select,.form-textarea{width:100%;padding:9px 12px;border:1.5px solid var(--border);border-radius:2px;font-size:13px;color:var(--ink);background:white}
.form-input:focus,.form-select:focus,.form-textarea:focus{outline:none;border-color:var(--gold)}
.form-textarea{resize:vertical;min-height:70px;font-family:inherit}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}

/* CARDS */
.card{background:white;border-radius:2px;border:1px solid var(--border);box-shadow:var(--shadow);margin-bottom:20px}
.card-header{padding:18px 22px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}
.card-title{font-weight:600;font-size:14px;color:var(--ink)}
.card-body{padding:22px}

/* STATS */
.stats-row{display:grid;grid-template-columns:repeat(6,1fr);gap:12px;margin-bottom:28px}
@media(max-width:1200px){.stats-row{grid-template-columns:repeat(3,1fr)}}
@media(max-width:700px){.stats-row{grid-template-columns:repeat(2,1fr)}}
.stat-card{background:white;border:1px solid var(--border);border-radius:2px;padding:18px 20px;box-shadow:var(--shadow)}
.stat-num{font-size:36px;line-height:1;color:var(--ink);font-weight:600}
.stat-label{font-size:9px;letter-spacing:.15em;text-transform:uppercase;color:var(--slate);margin-top:6px}
.stat-accent{border-top:3px solid var(--gold)}
.stat-accent-rust{border-top:3px solid var(--rust)}
.stat-accent-sage{border-top:3px solid var(--sage)}
.stat-accent-orange{border-top:3px solid #f57c00}
.stat-accent-blue{border-top:3px solid #0288d1}

/* TABLE */
#clients-list,#services-list,#users-list,#periods-list,#recurring-list,#billing-list,#tasks-list{overflow-x:auto}
.task-table{min-width:100%;border-collapse:collapse}
.task-table td[style*="white-space:nowrap"]{white-space:nowrap;width:1px}
.task-table th{font-size:9px;letter-spacing:.15em;text-transform:uppercase;color:var(--slate);text-align:left;padding:7px 10px;border-bottom:1.5px solid var(--border);background:var(--paper)}
.task-table td{padding:8px 10px;border-bottom:1px solid var(--border);color:var(--ink);font-size:13px}
.task-table tr:last-child td{border-bottom:none}
.task-table tbody tr:hover td{background:rgba(245,243,238,.6);cursor:pointer}

/* BADGES */
.badge{font-size:9px;letter-spacing:.12em;text-transform:uppercase;padding:3px 8px;border-radius:2px;font-weight:500;white-space:nowrap}
.badge-assigned{background:#e8f0fe;color:#3c5a9a}
.badge-inprogress{background:#fff3e0;color:#a05a00}
.badge-underreview{background:#f3e8ff;color:#7b3f9e}
.badge-approved{background:#e6f4ea;color:#1e6e38}
.badge-delivered{background:#e8f5e9;color:#2e7d32}
.badge-billed{background:#e3f2fd;color:#1565c0}
.badge-closed{background:#f5f5f5;color:#616161}
.badge-active{background:#e6f4ea;color:#1e6e38}
.badge-inactive{background:#f5f5f5;color:#616161}

/* MODAL */
.modal-overlay{position:fixed;inset:0;background:rgba(26,26,46,.65);display:flex;align-items:center;justify-content:center;z-index:1000;backdrop-filter:blur(2px)}
.modal{background:var(--paper);border-radius:2px;width:600px;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-lg)}
.modal-header{padding:22px 26px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;background:white;position:sticky;top:0;z-index:10}
.modal-title{font-size:20px;font-weight:600}
.modal-close{background:none;border:none;color:var(--slate);font-size:22px;cursor:pointer;line-height:1;padding:2px}
.modal-close:hover{color:var(--ink)}
.modal-body{padding:26px}

/* TABS */
.tabs{display:flex;gap:0;border-bottom:1.5px solid var(--border);margin-bottom:20px}
.tab{padding:10px 20px;font-size:13px;cursor:pointer;color:var(--slate);border-bottom:2px solid transparent;margin-bottom:-1.5px;font-weight:400;transition:all .15s}
.tab.active{color:var(--ink);border-bottom-color:var(--gold);font-weight:600}
.tab:hover:not(.active){color:var(--ink)}

/* FILTERS */
.filter-row{display:flex;gap:10px;margin-bottom:18px;flex-wrap:wrap}
.filter-select{padding:7px 12px;border:1.5px solid var(--border);border-radius:2px;font-size:12px;color:var(--ink);background:white;cursor:pointer}
.filter-input{padding:7px 12px;border:1.5px solid var(--border);border-radius:2px;font-size:12px;color:var(--ink);background:white;outline:none}
.filter-input:focus{border-color:var(--ink)}
/* Searchable filter dropdown */
.fsearch-wrap{position:relative;display:inline-block}
.fsearch-input{padding:7px 28px 7px 12px;border:1.5px solid var(--border);border-radius:2px;font-size:12px;color:var(--ink);background:white;outline:none;cursor:pointer;min-width:130px}
.fsearch-input:focus{border-color:var(--ink)}
.fsearch-input.has-value{border-color:var(--ink);font-weight:500}
.fsearch-clear{position:absolute;right:6px;top:50%;transform:translateY(-50%);cursor:pointer;color:var(--slate);font-size:14px;line-height:1;padding:2px;display:none}
.fsearch-wrap.has-value .fsearch-clear{display:block}
.fsearch-list{position:absolute;top:100%;left:0;min-width:100%;max-height:220px;overflow-y:auto;background:white;border:1.5px solid var(--ink);border-radius:2px;z-index:200;box-shadow:0 4px 12px rgba(0,0,0,.12);display:none}
.fsearch-list.open{display:block}
.fsearch-item{padding:7px 12px;font-size:12px;cursor:pointer;white-space:nowrap}
.fsearch-item:hover,.fsearch-item.active{background:var(--paper2)}
.fsearch-item.placeholder{color:var(--slate)}
html.dark-mode .fsearch-input{background:#252740;border-color:rgba(255,255,255,.15);color:#dde1f0}
html.dark-mode .fsearch-list{background:#1a1c2e;border-color:#3a3d5c}
html.dark-mode .fsearch-item:hover,html.dark-mode .fsearch-item.active{background:#252740}

/* MISC */
.loading{text-align:center;padding:40px;color:var(--slate)}
.hidden{display:none !important}
.success-msg{background:#e6f4ea;border:1px solid #7aab89;color:#1e6e38;padding:12px;border-radius:2px;margin-bottom:16px}

/* PIPELINE INDICATOR */
.pipeline{display:flex;align-items:flex-start;margin-bottom:24px;overflow-x:auto;padding-bottom:4px;gap:0}
.pipeline-step{display:flex;flex-direction:column;align-items:center;flex-shrink:0;min-width:56px}
.pipeline-dot{width:24px;height:24px;border-radius:50%;background:var(--paper2);border:2px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:600;position:relative;z-index:1;transition:all .2s}
.pipeline-dot.done{background:var(--sage);border-color:var(--sage);color:white}
.pipeline-dot.current{background:var(--gold);border-color:var(--gold);color:white;box-shadow:0 0 0 4px rgba(201,151,58,.2)}
.pipeline-label{font-size:9px;letter-spacing:.05em;text-transform:uppercase;color:var(--slate);margin-top:5px;text-align:center;max-width:56px;line-height:1.3}
.pipeline-label.current{color:var(--ink);font-weight:600}
.pipeline-connector{flex:1;height:2px;background:var(--border);min-width:12px;margin-top:12px;flex-shrink:1}
.pipeline-connector.done{background:var(--sage)}

/* INTERACTIVE ACTIVITY LIST */
.activity-item{display:flex;align-items:flex-start;gap:12px;padding:12px;border:1px solid var(--border);border-radius:2px;margin-bottom:8px;background:white}
.activity-item.done-item{opacity:.7;background:var(--paper2)}
.activity-check{width:20px;height:20px;border-radius:50%;border:2px solid var(--border);flex-shrink:0;margin-top:1px;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700}
.activity-check.done{background:var(--sage);border-color:var(--sage);color:white}
.activity-check.inprogress{background:var(--gold);border-color:var(--gold);color:white}
.activity-body{flex:1;min-width:0}
.activity-title-text{font-weight:500;font-size:13px;margin-bottom:4px}
.activity-meta-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.activity-actions{display:flex;gap:6px;flex-shrink:0;align-items:flex-start;padding-top:1px}

/* CREATE FORM ACTIVITIES EDITOR */
.activities-editor{margin-top:16px;padding-top:16px;border-top:1px solid var(--border)}
.activities-editor-title{font-size:11px;font-weight:500;letter-spacing:.08em;text-transform:uppercase;color:var(--slate);margin-bottom:10px}
.activity-row{display:grid;grid-template-columns:1fr 180px 130px 32px;gap:8px;align-items:center;margin-bottom:8px}
.activity-row input,.activity-row select{padding:7px 10px;border:1.5px solid var(--border);border-radius:2px;font-size:12px;color:var(--ink);background:white;width:100%}
.activity-row input:focus,.activity-row select:focus{outline:none;border-color:var(--gold)}
.activity-row .ms-wrap{width:100%}
.activity-row .ms-box{min-height:34px;padding:3px 8px;font-size:12px}
.activity-row .ms-dropdown{font-size:12px}
.activity-row .ms-item{padding:6px 10px;font-size:12px}
.activity-row .ms-tag{font-size:10px;padding:1px 5px}
.activity-row .ms-placeholder{font-size:12px;line-height:26px}

/* SEARCHABLE SELECT (Client / Service) */
.ss-wrap{position:relative}
.ss-input{width:100%;cursor:pointer}
.ss-list{position:absolute;top:100%;left:0;right:0;background:#fff;border:1.5px solid var(--gold);border-top:none;border-radius:0 0 4px 4px;max-height:220px;overflow-y:auto;z-index:200;box-shadow:0 4px 12px rgba(0,0,0,.12)}
.ss-item{padding:8px 12px;font-size:13px;cursor:pointer;color:var(--ink)}
.ss-item:hover,.ss-item.active{background:var(--cream)}
.ss-item.no-match{color:var(--slate);cursor:default;font-style:italic}

/* MULTI-SELECT WITH CHECKBOXES (Assign To) */
.ms-wrap{position:relative}
.ms-box{min-height:40px;padding:6px 10px;border:1.5px solid var(--border);border-radius:2px;background:#fff;cursor:pointer;display:flex;align-items:flex-start;gap:6px;flex-wrap:wrap;user-select:none}
.ms-box:focus,.ms-box.open{outline:none;border-color:var(--gold)}
.ms-tag{background:var(--ink);color:#fff;font-size:11px;padding:2px 6px;border-radius:2px;display:flex;align-items:center;gap:4px;white-space:nowrap}
.ms-tag-x{cursor:pointer;opacity:.7;font-size:10px}
.ms-tag-x:hover{opacity:1}
.ms-placeholder{color:#9ca3af;font-size:13px;line-height:28px}
.ms-arrow{margin-left:auto;color:var(--slate);font-size:11px;padding-top:6px;flex-shrink:0}
.ms-dropdown{position:absolute;top:100%;left:0;right:0;background:#fff;border:1.5px solid var(--gold);border-top:none;border-radius:0 0 4px 4px;max-height:220px;overflow-y:auto;z-index:200;box-shadow:0 4px 12px rgba(0,0,0,.12)}
.ms-item{display:flex;align-items:center;gap:8px;padding:8px 12px;font-size:13px;cursor:pointer;color:var(--ink)}
.ms-item:hover{background:var(--cream)}
.ms-item input[type=checkbox]{width:14px;height:14px;accent-color:var(--ink);cursor:pointer;flex-shrink:0}

/* PROGRESS NOTES */
.notes-section{margin-top:20px;padding-top:16px;border-top:1px solid var(--border)}
.notes-section-title{font-size:13px;font-weight:600;color:var(--ink);margin-bottom:12px}
.note-item{padding:12px;border-radius:2px;margin-bottom:8px;background:var(--paper2);border-left:3px solid var(--border)}
.note-item.rejection-note{border-left-color:var(--rust);background:#fff5f5}
.note-meta{display:flex;align-items:center;gap:8px;margin-bottom:6px;flex-wrap:wrap}
.note-author{font-size:12px;font-weight:600;color:var(--ink)}
.note-role-badge{font-size:9px;letter-spacing:.1em;text-transform:uppercase;padding:2px 6px;border-radius:2px;background:var(--paper);color:var(--slate);border:1px solid var(--border)}
.note-time{font-size:11px;color:var(--slate);margin-left:auto}
.note-text{font-size:13px;color:var(--ink);line-height:1.6}
.add-note-form{margin-top:12px;padding-top:12px;border-top:1px solid var(--border)}

/* AUDIT TRAIL */
.audit-toggle{display:flex;align-items:center;gap:8px;cursor:pointer;color:var(--slate);font-size:12px;padding:10px 0;border-top:1px solid var(--border);margin-top:16px;user-select:none}
.audit-toggle:hover{color:var(--ink)}
.audit-arrow{transition:transform .2s;font-style:normal;font-size:10px}
.audit-list{display:none;margin-top:8px;margin-bottom:8px}
.audit-list.open{display:block}
.audit-entry{font-size:12px;color:var(--slate);padding:6px 0;border-bottom:1px solid var(--border);line-height:1.5}
.audit-entry:last-child{border-bottom:none}
.audit-from{color:var(--ink);font-weight:500}
.audit-to{color:var(--sage);font-weight:500}

/* REJECTION PANEL */
.reject-panel{background:#fff5f5;border:1.5px solid var(--rust);border-radius:2px;padding:16px;margin-top:4px}
.reject-panel-title{font-size:11px;font-weight:600;color:var(--rust);margin-bottom:10px;text-transform:uppercase;letter-spacing:.08em}

/* CLICKABLE STAT CARDS */
.stat-card[onclick]{cursor:pointer;transition:box-shadow .15s,transform .1s}
.stat-card[onclick]:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}

/* OVERDUE ROW HIGHLIGHT */
/* Task row colour coding: overdue=red, today=yellow, next 7 days=blue */
.task-row-overdue td:first-child{border-left:4px solid #c62828}
.task-row-overdue td{background:rgba(198,40,40,0.18) !important}
.task-row-overdue td small,.task-row-overdue td{color:#7f0000 !important}
.task-row-today td:first-child{border-left:4px solid #f9a825}
.task-row-today td{background:rgba(249,168,37,0.30) !important}
.task-row-today td small,.task-row-today td{color:#7a5800 !important}
.task-row-soon td:first-child{border-left:4px solid #0d47a1}
.task-row-soon td{background:rgba(13,71,161,0.15) !important}
.task-row-soon td small,.task-row-soon td{color:#0d47a1 !important}
/* Archived task rows */
.task-row-archived td{background:rgba(0,0,0,0.04) !important;opacity:0.7}
.task-row-archived td:first-child{border-left:4px solid #9e9e9e}

/* RECURRING PANEL */
.recurring-panel{margin-top:12px;padding:16px;background:var(--paper2);border-left:3px solid var(--gold);border-radius:0 2px 2px 0}
.recurring-info{background:white;border:1px solid var(--border);border-radius:2px;padding:10px 12px;font-size:12px;color:var(--slate);margin-top:10px;line-height:1.5}

/* TEMPLATE STATUS BADGES */
.badge-active{background:#e6f4ea;color:#1e6e38}
.badge-paused{background:#fff3e0;color:#a05a00}
.badge-stopped{background:#f5f5f5;color:#616161}

/* RECURRING VIEW TABLE */
.progress-bar-wrap{width:80px;height:6px;background:var(--paper2);border-radius:3px;display:inline-block;vertical-align:middle;margin-left:6px}
.progress-bar-fill{height:100%;background:var(--sage);border-radius:3px;transition:width .3s}

/* ===== MOBILE / RESPONSIVE ===== */
/* Mobile top bar (hamburger) â€” hidden on desktop */
.mobile-topbar{display:none;align-items:center;gap:12px;padding:12px 16px;background:var(--ink);position:sticky;top:0;z-index:200}
.mobile-topbar-title{color:white;font-size:15px;font-weight:600;flex:1}
.hamburger-btn{background:none;border:none;color:rgba(255,255,255,.7);font-size:22px;cursor:pointer;line-height:1;padding:2px 4px}
.hamburger-btn:hover{color:white}
/* Sidebar backdrop overlay on mobile */
.sidebar-backdrop{display:none;position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:299}
.sidebar-backdrop.open{display:block}

@media(max-width:768px){
  /* Show hamburger bar, hide inline sidebar brand */
  .mobile-topbar{display:flex}
  /* App layout stacks vertically so topbar sits above content */
  .app-layout{flex-direction:column}
  /* Sidebar becomes off-canvas (fixed, outside flow) */
  .sidebar{position:fixed;top:0;left:-240px;width:240px;height:100%;z-index:300;transition:left .25s ease;overflow-y:auto}
  .sidebar.open{left:0}
  /* Main content spans full width */
  .main-content{max-height:none;min-height:calc(100vh - 50px);padding:20px 16px}
  /* Modals fit screen */
  .modal{width:95vw!important;max-width:95vw!important}
  /* Form grids go single-column */
  .form-grid{grid-template-columns:1fr!important}
  /* Page header stacks on small screens */
  .page-header{flex-direction:column;align-items:flex-start;gap:10px}
  .page-title{font-size:22px}
  /* Tables: containers scroll, table itself has min-width so columns don't squish */
  #tasks-list,#billing-list,#clients-list,#services-list,#users-list,#periods-list,#recurring-list{overflow-x:auto;-webkit-overflow-scrolling:touch}
  .task-table{min-width:580px}
  #al-table-wrap{overflow-x:auto}
  /* Stats row */
  .stats-row{grid-template-columns:repeat(2,1fr)!important}
  /* Bulk modal section rows */
  .bulk-list-box{max-height:160px}
  /* Quick tasks row padding */
  .qt-row{padding:12px 14px}
  /* Pipeline dots row */
  .pipeline{overflow-x:auto;padding-bottom:8px}
}

@media(max-width:480px){
  .main-content{padding:14px 10px}
  .modal{width:99vw!important;max-width:99vw!important}
  .page-title{font-size:18px}
  .btn{padding:9px 14px;font-size:12px}
  .stats-row{grid-template-columns:1fr 1fr!important}
}

/* Dark mode mobile topbar */
html.dark-mode .mobile-topbar{background:#0f1019}
html.dark-mode .sidebar-backdrop{background:rgba(0,0,0,.7)}
</style>
