
:root{
  --bg:#f6f8fc;
  --panel:#ffffff;
  --ink:#0f172a;
  --muted:#64748b;
  --line:#e2e8f0;
  --blue:#2563eb;
  --blue2:#1d4ed8;
  --nav:#07111f;
  --nav-soft:#102033;
  --green:#10b981;
  --orange:#f59e0b;
  --red:#ef4444;
}
*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  background:var(--bg);
  color:var(--ink);
  font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Arial,sans-serif;
  font-size:var(--base-font-size);
}
a{text-decoration:none}
.app-shell{display:flex;min-height:100vh;background:var(--bg)}
.sidebar{
  width:var(--sidebar-width);min-height:100vh;position:fixed;left:0;top:0;bottom:0;z-index:1000;
  background:linear-gradient(180deg,var(--nav) 0%,var(--nav-soft) 100%);
  color:#e5eefb;padding:22px 16px;overflow-y:auto;box-shadow:12px 0 30px rgba(2,8,23,.12)
}
.brand{display:flex;gap:12px;align-items:center;padding:8px 8px 18px;border-bottom:1px solid rgba(255,255,255,.08);margin-bottom:14px}
.brand-icon{width:42px;height:42px;border-radius:14px;background:linear-gradient(135deg,#2dd4bf,#2563eb);display:flex;align-items:center;justify-content:center;font-weight:900;color:white;font-size:20px;box-shadow:0 12px 24px rgba(37,99,235,.32)}
.brand-title{font-size:16px;font-weight:800;letter-spacing:-.01em;color:#fff;line-height:1.1}.brand-sub{font-size:12px;color:#9fb1c8;margin-top:2px}
.sidebar-section{font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.08em;color:#7186a1;margin:17px 10px 8px}
.sidebar a{display:flex;align-items:center;gap:12px;padding:11px 12px;margin:4px 0;border-radius:var(--button-radius);color:#c8d6e8;font-weight:650;font-size:14px;transition:.15s ease}
.sidebar a .nav-ico{width:22px;height:22px;border-radius:8px;display:inline-flex;align-items:center;justify-content:center;color:#93c5fd;background:rgba(37,99,235,.10);font-size:12px;flex:0 0 22px}
.sidebar a:hover{background:rgba(255,255,255,.075);color:white;transform:translateX(2px)}
.sidebar a.active{background:var(--blue2);color:white;box-shadow:0 10px 24px rgba(37,99,235,.30)}
.sidebar a.active .nav-ico{background:rgba(255,255,255,.18);color:white}
.main{margin-left:var(--sidebar-width);min-height:100vh;width:calc(100% - var(--sidebar-width));padding:28px 30px 40px}
.topbar{display:flex;justify-content:space-between;align-items:center;gap:20px;margin-bottom:24px}
.page-title{font-size:34px;font-weight:850;letter-spacing:-.04em;line-height:1.05;margin:0}.page-subtitle{color:var(--muted);margin:7px 0 0;font-size:15px}
.user-pill{display:flex;align-items:center;gap:12px;background:#fff;border:1px solid var(--line);border-radius:999px;padding:8px 12px 8px 16px;box-shadow:0 8px 24px rgba(15,23,42,.05)}
.avatar{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,#dbeafe,#bfdbfe);color:#1d4ed8;display:flex;align-items:center;justify-content:center;font-weight:900}
.card{background:#fff;border:1px solid var(--line);border-radius:var(--card-radius);box-shadow:0 14px 34px rgba(15,23,42,.055)}
.metric-card{min-height:132px;padding:20px;overflow:hidden;position:relative}.metric-card:before{content:"";position:absolute;right:-32px;top:-34px;width:112px;height:112px;border-radius:50%;background:linear-gradient(135deg,rgba(37,99,235,.14),rgba(45,212,191,.10))}.metric-label{font-size:12px;color:var(--muted);font-weight:800;text-transform:uppercase;letter-spacing:.05em}.metric-value{font-size:30px;font-weight:850;letter-spacing:-.035em;margin-top:8px}.metric-icon{width:44px;height:44px;border-radius:15px;background:#eff6ff;color:#2563eb;display:flex;align-items:center;justify-content:center;font-weight:900;position:relative;z-index:1}.metric-note{font-size:12px;color:#94a3b8;margin-top:4px}
.section-card{padding:22px}.section-title{font-size:20px;font-weight:800;letter-spacing:-.02em;margin:0}.section-sub{font-size:13px;color:var(--muted);margin-top:3px}.btn{font-weight:700;border-radius:var(--button-radius)}.btn-primary{background:var(--blue);border-color:var(--blue)}.btn-primary:hover{background:var(--blue2);border-color:var(--blue2)}.btn-outline-primary{border-color:#bfdbfe;color:#1d4ed8;background:#fff}.btn-outline-primary:hover{background:#eff6ff;color:#1d4ed8;border-color:#93c5fd}.table{margin:0}.table th{font-size:12px;text-transform:uppercase;letter-spacing:.05em;color:#64748b;border-top:0;background:#f8fafc}.table td,.table th{padding:15px 14px;vertical-align:middle;border-color:#eef2f7}.empty-row{padding:28px;text-align:center;color:#94a3b8}.status{display:inline-flex;align-items:center;gap:6px;padding:6px 10px;border-radius:999px;font-size:12px;font-weight:800;text-transform:capitalize;background:#eef2ff;color:#3730a3}.status:before{content:"";width:7px;height:7px;border-radius:50%;background:currentColor}.status.pending,.status.draft,.status.new{background:#fff7ed;color:#c2410c}.status.assigned,.status.sent{background:#eff6ff;color:#1d4ed8}.status.in_progress,.status.on_my_way,.status.arrived{background:#ecfeff;color:#0e7490}.status.completed_pending_review,.status.pending_admin_approval{background:#fef3c7;color:#92400e}.status.completed_approved,.status.paid,.status.approved,.status.completed{background:#ecfdf5;color:#047857}.status.cancelled,.status.failed,.status.overdue{background:#fef2f2;color:#b91c1c}
.quick-actions .btn{height:44px;display:flex;align-items:center;justify-content:center;gap:8px}.team-card{padding:16px;border:1px solid var(--line);border-radius:18px;background:linear-gradient(180deg,#fff,#fbfdff);margin-bottom:12px}.team-dot{width:12px;height:12px;border-radius:50%;background:#10b981;box-shadow:0 0 0 4px rgba(16,185,129,.12)}.workflow{display:grid;grid-template-columns:repeat(5,1fr);gap:12px}.workflow-step{border:1px solid var(--line);background:#fff;border-radius:18px;padding:18px 12px;text-align:center;font-weight:750;color:#334155;position:relative}.workflow-step:not(:last-child):after{content:"→";position:absolute;right:-12px;top:50%;transform:translateY(-50%);color:#94a3b8;font-weight:900}.workflow-num{width:28px;height:28px;margin:0 auto 9px;border-radius:10px;background:#eff6ff;color:#2563eb;display:flex;align-items:center;justify-content:center;font-weight:900}.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px;background:radial-gradient(circle at top left,#2563eb 0,#0f172a 40%,#07111f 100%)}.login-card{max-width:430px;width:100%;border-radius:24px}.public-hero{padding:85px 0;background:linear-gradient(135deg,#2563eb,#0f1b2d);color:#fff}.btn-round{border-radius:999px}.mobile-shell{max-width:540px;margin:auto;background:#fff;min-height:100vh}.job-card{border-left:5px solid var(--blue)}
@media(max-width:1100px){.workflow{grid-template-columns:1fr}.workflow-step:not(:last-child):after{display:none}}
@media(max-width:992px){.sidebar{position:relative;width:100%;min-height:auto}.main{margin-left:0;width:100%;padding:22px}.app-shell{display:block}.topbar{align-items:flex-start}.page-title{font-size:28px}}
.form-control,.form-select{border-color:var(--line);border-radius:var(--button-radius);background:var(--panel);color:var(--ink);min-height:44px}.form-control:focus,.form-select:focus{border-color:var(--blue);box-shadow:0 0 0 .22rem rgba(37,99,235,.13)}.form-label{color:var(--ink)}.color-row .form-control-color{max-width:62px;padding:7px}.theme-preview{display:grid;grid-template-columns:145px 1fr;min-height:310px;border:1px solid var(--line);border-radius:var(--card-radius);overflow:hidden;background:var(--bg)}.preview-sidebar{background:linear-gradient(180deg,var(--nav),var(--nav-soft));color:white;padding:16px}.preview-logo{font-weight:900;margin-bottom:18px}.preview-link{padding:10px;border-radius:var(--button-radius);font-size:13px;margin-bottom:8px;color:#cbd5e1}.preview-link.active{background:var(--blue2);color:white}.preview-main{padding:16px}.preview-card{background:var(--panel);border:1px solid var(--line);border-radius:var(--card-radius);padding:16px;color:var(--ink)}
.sidebar-submenu{padding:4px 0 8px 28px;margin-top:-4px}.sidebar-submenu a{font-size:14px;padding:8px 12px;border-radius:12px;margin:2px 10px 2px 0;color:rgba(255,255,255,.72);background:transparent}.sidebar-submenu a.active,.sidebar-submenu a:hover{background:rgba(255,255,255,.12);color:#fff}.settings-tabs .list-group-item{border:0;border-radius:14px;margin-bottom:8px}.settings-tabs .list-group-item.active{background:var(--blue);color:#fff}.sensitive-note{font-size:12px;color:var(--muted)}

/* v1.5 Premium Dashboard */
.dashboard-premium{position:relative}
.kpi-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:18px;margin-bottom:22px}
.kpi-card{position:relative;overflow:hidden;background:var(--panel);border:1px solid var(--line);border-radius:var(--card-radius);padding:20px;min-height:145px;box-shadow:0 18px 38px rgba(15,23,42,.06)}
.kpi-card:after{content:"";position:absolute;right:-34px;top:-38px;width:118px;height:118px;border-radius:50%;background:rgba(37,99,235,.10)}
.kpi-topline{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;position:relative;z-index:1}
.kpi-title{font-size:12px;font-weight:900;text-transform:uppercase;letter-spacing:.06em;color:var(--muted)}
.kpi-icon{width:42px;height:42px;border-radius:15px;background:#eff6ff;color:var(--blue);display:flex;align-items:center;justify-content:center;font-weight:900;box-shadow:inset 0 0 0 1px rgba(37,99,235,.08)}
.kpi-number{font-size:31px;font-weight:900;letter-spacing:-.045em;margin-top:14px;position:relative;z-index:1;color:var(--ink)}
.kpi-caption{font-size:12px;color:var(--muted);margin-top:5px;position:relative;z-index:1}
.kpi-money .kpi-icon{background:#ecfdf5;color:#047857}.kpi-money:after{background:rgba(16,185,129,.11)}
.kpi-work .kpi-icon{background:#ecfeff;color:#0e7490}.kpi-work:after{background:rgba(14,116,144,.10)}
.kpi-pending .kpi-icon,.kpi-invoice .kpi-icon{background:#fff7ed;color:#c2410c}.kpi-pending:after,.kpi-invoice:after{background:rgba(245,158,11,.12)}
.kpi-payroll .kpi-icon{background:#f5f3ff;color:#6d28d9}.kpi-payroll:after{background:rgba(109,40,217,.10)}
.ops-panel{background:var(--panel);border:1px solid var(--line);border-radius:var(--card-radius);box-shadow:0 18px 42px rgba(15,23,42,.055);padding:24px}
.ops-header{display:flex;align-items:flex-start;justify-content:space-between;gap:18px;margin-bottom:22px}
.ops-header h3{margin:2px 0 0;font-size:24px;font-weight:900;letter-spacing:-.03em}.ops-header p{margin:4px 0 0;color:var(--muted);font-size:13px}.ops-header.compact{margin-bottom:16px}.ops-header.compact h3{font-size:21px}.eyebrow{font-size:11px;text-transform:uppercase;letter-spacing:.10em;color:var(--blue);font-weight:900}.ops-date{border:1px solid var(--line);background:linear-gradient(180deg,#fff,#f8fafc);padding:9px 12px;border-radius:999px;font-size:13px;font-weight:800;color:var(--muted);white-space:nowrap}.daily-timeline{display:flex;flex-direction:column;gap:4px}.timeline-job{display:grid;grid-template-columns:86px 24px 1fr;gap:14px;min-height:92px}.timeline-time{padding-top:14px;text-align:right}.timeline-time strong{display:block;font-size:14px}.timeline-time span{display:block;font-size:12px;color:var(--muted);margin-top:3px}.timeline-line{position:relative;display:flex;justify-content:center}.timeline-line:before{content:"";position:absolute;top:0;bottom:0;width:2px;background:var(--line)}.timeline-line span{position:relative;z-index:1;margin-top:18px;width:15px;height:15px;border-radius:50%;background:var(--blue);box-shadow:0 0 0 5px rgba(37,99,235,.12)}.timeline-pending .timeline-line span{background:var(--orange);box-shadow:0 0 0 5px rgba(245,158,11,.12)}.timeline-working .timeline-line span{background:#0e7490;box-shadow:0 0 0 5px rgba(14,116,144,.12)}.timeline-done .timeline-line span{background:var(--green);box-shadow:0 0 0 5px rgba(16,185,129,.12)}.timeline-danger .timeline-line span{background:var(--red);box-shadow:0 0 0 5px rgba(239,68,68,.12)}.timeline-body{background:linear-gradient(180deg,#fff,#fbfdff);border:1px solid var(--line);border-radius:20px;padding:16px;margin-bottom:12px}.job-title{font-size:16px;font-weight:900;color:var(--ink)}.job-meta{font-size:13px;color:var(--muted);margin-top:3px}.job-footer{display:flex;align-items:center;gap:10px;margin-top:14px;flex-wrap:wrap}.team-pill{display:inline-flex;align-items:center;gap:6px;border:1px solid var(--line);background:#f8fafc;border-radius:999px;padding:6px 10px;font-size:12px;font-weight:800;color:#334155}.progress-mini{height:9px;background:#e2e8f0;border-radius:99px;overflow:hidden;flex:1;min-width:110px}.progress-mini div,.team-progress div{height:100%;background:linear-gradient(90deg,var(--blue),#2dd4bf);border-radius:99px}.progress-value,.team-progress-label{font-size:12px;color:var(--muted);font-weight:800}.team-stack{display:flex;flex-direction:column;gap:14px}.premium-team-card{border:1px solid var(--line);border-radius:22px;padding:16px;background:linear-gradient(180deg,#fff,#fbfdff)}.team-card-head{display:flex;justify-content:space-between;gap:12px;align-items:flex-start}.team-status-line{display:flex;align-items:center;gap:9px;font-size:16px}.live-dot{width:11px;height:11px;border-radius:50%;background:var(--green);box-shadow:0 0 0 5px rgba(16,185,129,.12);display:inline-block}.live-dot.pending{background:var(--orange);box-shadow:0 0 0 5px rgba(245,158,11,.12)}.live-dot.working{background:#0e7490;box-shadow:0 0 0 5px rgba(14,116,144,.12)}.live-dot.assigned{background:var(--blue);box-shadow:0 0 0 5px rgba(37,99,235,.12)}.live-dot.danger{background:var(--red);box-shadow:0 0 0 5px rgba(239,68,68,.12)}.live-dot.available{background:var(--green)}.team-current-job{font-size:13px;color:var(--muted);margin-top:4px}.team-count{font-size:11px;text-transform:uppercase;letter-spacing:.05em;font-weight:900;color:var(--muted);border:1px solid var(--line);border-radius:999px;padding:5px 8px}.team-members{display:grid;gap:5px;margin-top:12px;font-size:13px;color:#334155}.muted-small{font-size:13px;color:var(--muted)}.team-schedule{font-size:13px;font-weight:800;margin-top:12px}.team-progress{height:10px;background:#e2e8f0;border-radius:999px;margin-top:10px;overflow:hidden}.activity-list{display:grid;gap:12px}.activity-item{display:flex;gap:12px;align-items:flex-start;border:1px solid var(--line);border-radius:18px;padding:13px;background:#fff}.activity-check{width:30px;height:30px;border-radius:12px;background:#eff6ff;color:var(--blue);display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:900;flex:0 0 30px}.activity-check.done{background:#ecfdf5;color:#047857}.activity-check.working{background:#ecfeff;color:#0e7490}.activity-check.pending{background:#fff7ed;color:#c2410c}.activity-check.danger{background:#fef2f2;color:#b91c1c}.activity-text{font-weight:850;color:var(--ink)}.activity-time{font-size:12px;color:var(--muted);margin-top:3px}.quick-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.quick-grid a{border:1px solid var(--line);border-radius:18px;padding:16px;background:linear-gradient(180deg,#fff,#fbfdff);font-weight:900;color:var(--ink);display:flex;align-items:center;gap:10px;transition:.15s ease}.quick-grid a:hover{transform:translateY(-2px);border-color:#bfdbfe;box-shadow:0 16px 30px rgba(37,99,235,.10)}.quick-grid span{width:34px;height:34px;border-radius:13px;background:var(--blue);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:900}.empty-premium{text-align:center;padding:44px 20px;border:1px dashed var(--line);border-radius:22px;background:#fbfdff}.empty-icon{width:54px;height:54px;border-radius:18px;background:#ecfdf5;color:#047857;display:flex;align-items:center;justify-content:center;margin:0 auto 12px;font-weight:900;font-size:22px}
@media(max-width:1400px){.kpi-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media(max-width:768px){.kpi-grid{grid-template-columns:1fr}.timeline-job{grid-template-columns:1fr}.timeline-time{text-align:left;padding-top:0}.timeline-line{display:none}.quick-grid{grid-template-columns:1fr}.ops-header{display:block}.ops-date{display:inline-block;margin-top:12px}.ops-panel{padding:18px}}

/* v1.6 Premium CRM */
.crm-hero{padding:28px;display:flex;align-items:center;justify-content:space-between;gap:22px;background:linear-gradient(135deg,var(--blue),#0f172a);color:#fff;overflow:hidden;position:relative}
.crm-hero:after{content:"";position:absolute;right:-60px;top:-80px;width:240px;height:240px;border-radius:50%;background:rgba(255,255,255,.12)}
.crm-hero h2{font-size:34px;font-weight:900;letter-spacing:-.04em;margin:4px 0 4px}.crm-hero p{margin:0;color:rgba(255,255,255,.78);max-width:680px}.crm-hero .eyebrow{color:#bfdbfe}.crm-hero>*{position:relative;z-index:1}.crm-stat-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:16px}.crm-stat{background:var(--panel);border:1px solid var(--line);border-radius:var(--card-radius);padding:18px;box-shadow:0 14px 34px rgba(15,23,42,.045)}.crm-stat span{display:block;font-size:12px;text-transform:uppercase;letter-spacing:.06em;font-weight:900;color:var(--muted)}.crm-stat strong{display:block;font-size:29px;font-weight:900;letter-spacing:-.04em;margin-top:6px}.crm-toolbar{display:grid;grid-template-columns:1fr 210px auto;gap:12px}.crm-search{position:relative}.crm-search span{position:absolute;left:14px;top:50%;transform:translateY(-50%);color:var(--muted);font-weight:900}.crm-search input{padding-left:42px}.customer-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:18px}.customer-card{padding:20px;color:var(--ink);transition:.16s ease}.customer-card:hover{transform:translateY(-3px);border-color:#bfdbfe;box-shadow:0 22px 42px rgba(37,99,235,.11)}.customer-card-top{display:flex;gap:13px;align-items:flex-start}.customer-avatar,.profile-avatar-xl{border-radius:19px;background:linear-gradient(135deg,#dbeafe,#bfdbfe);color:#1d4ed8;font-weight:900;display:flex;align-items:center;justify-content:center;box-shadow:inset 0 0 0 1px rgba(37,99,235,.08)}.customer-avatar{width:52px;height:52px;font-size:16px;flex:0 0 52px}.customer-card h4{font-size:17px;font-weight:900;margin:2px 0 2px;letter-spacing:-.02em}.customer-card p{font-size:13px;color:var(--muted);margin:0}.customer-tag{font-size:11px;text-transform:uppercase;letter-spacing:.06em;font-weight:900;color:#047857;background:#ecfdf5;border-radius:999px;padding:6px 9px;white-space:nowrap}.customer-address{margin-top:16px;padding:12px;border:1px solid var(--line);border-radius:16px;background:#f8fafc;color:#475569;font-size:13px;min-height:46px}.customer-card-metrics{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-top:14px}.customer-card-metrics div{border:1px solid var(--line);border-radius:15px;padding:10px;background:#fff}.customer-card-metrics span{display:block;color:var(--muted);font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.05em}.customer-card-metrics strong{font-size:14px;font-weight:900}.customer-profile-hero{padding:26px;display:flex;align-items:center;justify-content:space-between;gap:22px;background:linear-gradient(135deg,#fff,#eef6ff)}.customer-profile-main{display:flex;align-items:center;gap:18px}.profile-avatar-xl{width:90px;height:90px;font-size:27px;flex:0 0 90px;border-radius:30px}.customer-profile-hero h2{font-size:35px;font-weight:900;letter-spacing:-.04em;margin:4px 0}.profile-meta,.profile-contact{display:flex;gap:12px;flex-wrap:wrap;color:var(--muted);font-size:13px}.profile-meta span{background:#fff;border:1px solid var(--line);padding:6px 10px;border-radius:999px;font-weight:800}.profile-contact{margin-top:10px}.profile-actions{display:flex;gap:9px;flex-wrap:wrap;justify-content:flex-end}.crm-tabs-card{overflow:hidden}.crm-tabs{display:flex;gap:4px;overflow-x:auto;padding:14px 16px;border-bottom:1px solid var(--line);background:#fbfdff}.crm-tabs a{color:#475569;font-weight:850;font-size:13px;padding:10px 13px;border-radius:999px;white-space:nowrap}.crm-tabs a.active,.crm-tabs a:hover{background:var(--blue);color:#fff}.crm-tab-content{padding:24px}.crm-block-title{font-size:18px;font-weight:900;letter-spacing:-.025em;margin-bottom:14px}.info-list{display:grid;gap:10px}.info-list div,.side-metric{display:flex;justify-content:space-between;gap:14px;border:1px solid var(--line);background:#fff;border-radius:16px;padding:13px}.info-list span,.side-metric span{color:var(--muted);font-size:12px;font-weight:850;text-transform:uppercase;letter-spacing:.05em}.info-list strong,.side-metric strong{font-size:14px;text-align:right}.map-placeholder{min-height:235px;border:1px dashed #bfdbfe;border-radius:22px;background:linear-gradient(135deg,#eff6ff,#fff);display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:20px;color:var(--muted)}.map-placeholder div{font-size:42px}.map-placeholder strong{display:block;color:var(--ink);margin:8px 0 4px}.notes-box{border:1px solid var(--line);background:#fff;border-radius:20px;padding:18px;min-height:110px;color:#334155}.profile-side{padding:18px;position:sticky;top:24px}.profile-side .side-metric{display:block;margin-bottom:10px}.profile-side .side-metric strong{text-align:left;display:block;font-size:19px;margin-top:5px;letter-spacing:-.02em}.customer-timeline{position:relative;display:grid;gap:15px}.customer-timeline-item{display:grid;grid-template-columns:42px 1fr;gap:13px;border:1px solid var(--line);border-radius:20px;padding:15px;background:#fff}.timeline-bubble{width:42px;height:42px;border-radius:16px;background:#eff6ff;display:flex;align-items:center;justify-content:center}.timeline-title{font-weight:900;color:var(--ink)}.timeline-date{font-size:12px;color:var(--muted);margin:2px 0 6px}.customer-timeline p{margin:0;color:#475569;font-size:13px}
@media(max-width:1400px){.customer-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.crm-stat-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media(max-width:900px){.customer-grid,.crm-stat-grid{grid-template-columns:1fr}.crm-toolbar{grid-template-columns:1fr}.customer-profile-hero{display:block}.profile-actions{justify-content:flex-start;margin-top:18px}.customer-profile-main{align-items:flex-start}.profile-avatar-xl{width:70px;height:70px;border-radius:23px}.customer-profile-hero h2{font-size:28px}}
/* v1.7 Premium Bookings */
.eyebrow{font-size:.76rem;text-transform:uppercase;letter-spacing:.12em;color:var(--muted);font-weight:800}.section-title{font-size:1.7rem;font-weight:850;color:var(--ink)}.premium-panel{background:var(--panel);border:1px solid var(--line);border-radius:var(--card-radius);box-shadow:0 18px 55px rgba(15,23,42,.06)}.premium-table thead th{background:rgba(37,99,235,.05);color:var(--muted);font-size:.78rem;text-transform:uppercase;letter-spacing:.06em;border-bottom:1px solid var(--line);padding:1rem}.premium-table td{padding:1rem;border-color:var(--line)}.metric-card.mini{background:var(--panel);border:1px solid var(--line);border-radius:18px;padding:1.1rem;box-shadow:0 12px 30px rgba(15,23,42,.05)}.metric-card.mini span{display:block;color:var(--muted);font-size:.82rem;font-weight:700}.metric-card.mini strong{display:block;font-size:1.85rem;line-height:1;margin-top:.55rem;color:var(--ink)}.soft-warning{background:rgba(245,158,11,.14);color:#9a5b00}.soft-info{background:rgba(14,165,233,.14);color:#075985}.soft-primary,.soft-blue{background:rgba(37,99,235,.13);color:var(--blue2)}.soft-success{background:rgba(16,185,129,.14);color:#047857}.soft-danger{background:rgba(239,68,68,.13);color:#b91c1c}.soft-muted{background:rgba(100,116,139,.14);color:var(--muted)}.premium-modal{border:0;border-radius:22px;overflow:hidden}.timeline{position:relative}.timeline:before{content:"";position:absolute;left:10px;top:6px;bottom:6px;width:2px;background:var(--line)}.timeline-item{position:relative;display:flex;gap:16px;margin:0 0 22px}.timeline-dot{width:22px;height:22px;border-radius:999px;background:var(--blue);box-shadow:0 0 0 5px rgba(37,99,235,.12);position:relative;z-index:1;flex:0 0 22px}.checklist{display:grid;gap:.8rem}.checklist label{display:flex;gap:.65rem;align-items:center;padding:.75rem .85rem;border:1px solid var(--line);border-radius:14px;background:rgba(248,250,252,.65)}.map-placeholder{height:260px;border:1px dashed var(--line);border-radius:18px;background:linear-gradient(135deg,rgba(37,99,235,.08),rgba(16,185,129,.06));display:flex;align-items:center;justify-content:center;text-align:center;flex-direction:column;padding:1.5rem;color:var(--ink)}.map-placeholder div{font-size:2.2rem}.map-placeholder small{color:var(--muted);max-width:270px}.profile-mini{display:flex;align-items:center;gap:1rem}.profile-avatar{width:54px;height:54px;border-radius:18px;background:var(--blue);color:white;display:grid;place-items:center;font-size:1.4rem;font-weight:800}.team-member-line{display:flex;justify-content:space-between;align-items:center;gap:1rem;border-bottom:1px solid var(--line);padding:.75rem 0}.team-member-line:last-child{border-bottom:0}.btn-success{background:var(--green);border-color:var(--green);border-radius:var(--button-radius)}

/* v1.8 Properties */
.property-card{border:1px solid var(--line);border-radius:var(--card-radius);padding:22px;background:var(--panel);box-shadow:0 18px 45px rgba(15,23,42,.06)}
.property-card h4{font-size:20px;margin:8px 0 2px;font-weight:800;color:var(--ink)}
.property-icon{width:44px;height:44px;border-radius:16px;display:flex;align-items:center;justify-content:center;background:rgba(37,99,235,.10);font-size:24px}
.property-address{font-weight:700;color:var(--ink);line-height:1.35}
.property-info-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}
.property-info-grid div{background:var(--bg);border:1px solid var(--line);border-radius:14px;padding:10px}
.property-info-grid span{display:block;color:var(--muted);font-size:12px;text-transform:uppercase;letter-spacing:.04em}
.property-info-grid strong{display:block;margin-top:2px;color:var(--ink);font-size:14px}
.property-notes{min-height:44px;line-height:1.45}

/* v1.9 Staff App */
.staff-login-body{min-height:100vh;background:linear-gradient(135deg,#eaf2ff,#f8fafc);display:flex;align-items:center;justify-content:center;font-family:Inter,system-ui,-apple-system,Segoe UI,sans-serif}
.staff-login-wrap{width:100%;max-width:460px;padding:22px}.staff-login-card{background:#fff;border:1px solid #e5e7eb;border-radius:28px;padding:34px;box-shadow:0 22px 70px rgba(15,23,42,.12)}.staff-logo{width:62px;height:62px;border-radius:20px;background:#2563eb;color:#fff;display:flex;align-items:center;justify-content:center;font-size:28px;margin-bottom:16px}
.staff-app{background:#f4f7fb;min-height:100vh;color:#0f172a}.staff-top{position:sticky;top:0;z-index:20;background:rgba(255,255,255,.92);backdrop-filter:blur(14px);border-bottom:1px solid #e2e8f0}.staff-container{max-width:980px;margin:0 auto;padding:18px}.staff-card{background:#fff;border:1px solid #dde6f0;border-radius:24px;box-shadow:0 16px 40px rgba(15,23,42,.06)}.staff-job-card{padding:20px;margin-bottom:16px}.staff-badge{display:inline-flex;align-items:center;gap:6px;border-radius:999px;padding:6px 10px;font-size:12px;font-weight:700;text-transform:capitalize}.staff-badge.pending{background:#fef3c7;color:#92400e}.staff-badge.assigned{background:#dbeafe;color:#1d4ed8}.staff-badge.on_my_way{background:#ede9fe;color:#6d28d9}.staff-badge.arrived{background:#cffafe;color:#0e7490}.staff-badge.in_progress{background:#dcfce7;color:#15803d}.staff-badge.completed_pending_review,.staff-badge.completed_approved{background:#d1fae5;color:#047857}.staff-badge.cancelled{background:#fee2e2;color:#b91c1c}.staff-kpi{background:#fff;border:1px solid #e2e8f0;border-radius:20px;padding:16px}.staff-kpi span{font-size:13px;color:#64748b}.staff-kpi strong{display:block;font-size:24px}.property-box{border:1px solid #e2e8f0;border-radius:20px;padding:16px;background:#fbfdff}.property-row{display:flex;gap:12px;padding:10px 0;border-bottom:1px solid #eef2f7}.property-row:last-child{border-bottom:0}.property-row .ico{width:30px}.timeline-dot{width:12px;height:12px;border-radius:50%;background:#2563eb;margin-top:5px}.timeline-item{display:flex;gap:12px;padding:12px 0}.checklist-box textarea{min-height:170px}.action-bar{position:sticky;bottom:0;background:rgba(255,255,255,.96);border-top:1px solid #e2e8f0;padding:12px;z-index:20}.action-bar .btn{border-radius:14px;font-weight:800}.upload-box{border:1px dashed #94a3b8;border-radius:16px;padding:16px;background:#f8fafc}
@media(max-width:768px){.staff-container{padding:14px}.staff-card{border-radius:18px}.action-bar .btn{width:100%;margin-bottom:8px}}

/* v1.9.1 Staff portal aligned with Admin UI */
.user-panel-mini{display:flex;align-items:center;gap:12px;padding:12px 10px 16px;border-bottom:1px solid rgba(255,255,255,.08);margin-bottom:12px}
.booking-list{display:grid;gap:12px}.booking-row{display:flex;align-items:center;gap:16px;border:1px solid var(--line);border-radius:20px;padding:16px;background:linear-gradient(180deg,#fff,#fbfdff);color:var(--ink);transition:.15s ease}.booking-row:hover{transform:translateY(-2px);border-color:#bfdbfe;box-shadow:0 18px 34px rgba(37,99,235,.10)}.booking-date{width:88px;min-width:88px;border-radius:16px;background:#eff6ff;color:#1d4ed8;text-align:center;padding:10px}.booking-date strong{display:block;font-size:18px;line-height:1}.booking-date span{display:block;font-size:12px;margin-top:6px;font-weight:800;color:#2563eb}.property-summary-box{border:1px solid var(--line);border-radius:22px;background:#fff;padding:22px;display:flex;gap:18px;align-items:flex-start}.property-icon-lg{width:64px;height:64px;border-radius:22px;background:#eff6ff;color:#2563eb;display:flex;align-items:center;justify-content:center;font-size:30px;flex:0 0 64px}.property-summary-box h3{font-size:24px;font-weight:900;letter-spacing:-.035em;margin:0}.two-col-info{grid-template-columns:repeat(2,minmax(0,1fr))}.progress-steps{display:grid;gap:14px}.progress-step{display:flex;gap:12px;align-items:flex-start;padding:12px;border:1px solid var(--line);border-radius:18px;background:#fff}.progress-step-num{width:34px;height:34px;border-radius:50%;background:#e2e8f0;color:#64748b;display:flex;align-items:center;justify-content:center;font-weight:900;flex:0 0 34px}.progress-step.done .progress-step-num{background:var(--blue);color:white;box-shadow:0 0 0 5px rgba(37,99,235,.10)}.staff-admin-actionbar{position:sticky;bottom:14px;z-index:50;display:flex;gap:10px;justify-content:flex-end;align-items:center;background:rgba(255,255,255,.92);backdrop-filter:blur(14px);border:1px solid var(--line);border-radius:22px;padding:12px;margin-top:22px;box-shadow:0 18px 44px rgba(15,23,42,.12)}.staff-admin-actionbar .btn{min-width:150px}.checklist-box textarea{min-height:180px}.map-placeholder{min-height:220px}.premium-kpi-icon{width:48px;height:48px;border-radius:16px;background:#eff6ff;color:var(--blue);display:flex;align-items:center;justify-content:center;font-weight:900;font-size:18px}
@media(max-width:900px){.booking-row{align-items:flex-start}.two-col-info{grid-template-columns:1fr}.staff-admin-actionbar{display:grid;grid-template-columns:1fr;bottom:0;border-radius:18px 18px 0 0;margin-left:-6px;margin-right:-6px}.staff-admin-actionbar .btn{min-width:0;width:100%}.property-summary-box{display:block}.property-icon-lg{margin-bottom:14px}}

/* v1.9.2 Staff UI polish */
.staff-login-v2{min-height:100vh;margin:0;background:#f6f8fc;color:#0f172a;font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Arial,sans-serif}.staff-login-shell{min-height:100vh;display:grid;grid-template-columns:minmax(420px,1.05fr) minmax(420px,.95fr)}.staff-login-hero{position:relative;overflow:hidden;background:radial-gradient(circle at 20% 10%,rgba(45,212,191,.38),transparent 28%),radial-gradient(circle at 80% 75%,rgba(37,99,235,.35),transparent 30%),linear-gradient(135deg,#07111f,#0b2a5b 55%,#123b88);color:#fff;padding:54px;display:flex;flex-direction:column;justify-content:space-between}.staff-login-hero:after{content:"";position:absolute;inset:0;background:linear-gradient(135deg,rgba(255,255,255,.12),transparent 35%);pointer-events:none}.brand-block{position:relative;z-index:1;display:flex;gap:14px;align-items:center}.brand-mark{width:48px;height:48px;border-radius:18px;background:linear-gradient(135deg,#2dd4bf,#2563eb);display:flex;align-items:center;justify-content:center;font-weight:900;color:white;font-size:24px;box-shadow:0 18px 36px rgba(37,99,235,.34)}.brand-name{font-size:22px;font-weight:900;letter-spacing:-.03em}.brand-caption{font-size:13px;color:#b9c9e4;margin-top:2px}.hero-copy{position:relative;z-index:1;max-width:620px}.hero-badge{display:inline-flex;border:1px solid rgba(255,255,255,.22);background:rgba(255,255,255,.10);border-radius:999px;padding:8px 13px;font-size:12px;font-weight:900;letter-spacing:.08em;text-transform:uppercase;margin-bottom:18px}.hero-copy h1{font-size:52px;line-height:1.02;font-weight:950;letter-spacing:-.06em;margin:0 0 18px}.hero-copy p{font-size:18px;line-height:1.55;color:#d8e5fb;margin:0}.hero-stats{position:relative;z-index:1;display:grid;grid-template-columns:repeat(3,1fr);gap:14px}.hero-stats div{border:1px solid rgba(255,255,255,.14);background:rgba(255,255,255,.08);backdrop-filter:blur(12px);border-radius:20px;padding:16px}.hero-stats strong{display:block;font-size:18px}.hero-stats span{font-size:13px;color:#c3d2ea}.staff-login-panel{display:flex;align-items:center;justify-content:center;padding:40px}.login-panel-card{width:100%;max-width:460px;background:#fff;border:1px solid #e2e8f0;border-radius:30px;padding:34px;box-shadow:0 24px 80px rgba(15,23,42,.12)}.login-panel-card h2{font-size:34px;font-weight:950;letter-spacing:-.05em;margin:18px 0 6px}.login-panel-card .form-label{font-size:13px;font-weight:850;color:#334155;margin-bottom:8px}.login-panel-card .form-control{border-radius:16px;border-color:#dbe4ef;min-height:54px;font-size:15px}.login-panel-card .btn{border-radius:16px;font-weight:900;min-height:54px}.login-links{display:flex;justify-content:center;gap:10px;margin-top:18px;font-weight:800}.mobile-brand{display:none;align-items:center;gap:12px}.mobile-brand small{display:block;color:#64748b}.staff-login-body{background:#f6f8fc}.kpi-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:18px}.premium-kpi.card{min-height:126px;padding:20px;display:flex;align-items:center;justify-content:space-between;gap:16px;overflow:hidden}.premium-kpi-label{font-size:12px;text-transform:uppercase;letter-spacing:.06em;font-weight:900;color:var(--muted);white-space:nowrap}.premium-kpi-value{font-size:34px;line-height:1;font-weight:950;letter-spacing:-.04em;color:var(--ink);margin:8px 0}.premium-kpi-note{font-size:13px;color:var(--muted);line-height:1.25}.section-card{overflow:hidden}.booking-row{min-height:116px}.booking-row .status{white-space:nowrap}.team-pill{display:inline-flex;align-items:center;gap:6px;border:1px solid var(--line);background:#f8fafc;border-radius:999px;padding:7px 10px;font-weight:850;color:#334155}.quick-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.quick-grid a{display:flex;align-items:center;gap:12px;min-height:68px;padding:16px;border:1px solid var(--line);border-radius:18px;background:#fff;color:var(--ink);font-weight:900;transition:.15s ease}.quick-grid a:hover{border-color:#bfdbfe;background:#f8fbff;transform:translateY(-1px)}.quick-grid a span{width:34px;height:34px;border-radius:13px;background:var(--blue);color:#fff;display:inline-flex;align-items:center;justify-content:center}.info-list{display:grid;gap:0}.info-list>div{display:flex;justify-content:space-between;gap:18px;padding:13px 0;border-bottom:1px solid var(--line)}.info-list>div:last-child{border-bottom:0}.info-list span{color:var(--muted);font-size:13px}.info-list strong{text-align:right;color:var(--ink)}.property-summary-box,.progress-step,.booking-row,.quick-grid a{box-shadow:0 10px 28px rgba(15,23,42,.04)}.checklist-box .form-control{border-radius:18px;background:#fbfdff}.customer-avatar{width:54px;height:54px;border-radius:18px;background:var(--blue);color:white;display:flex;align-items:center;justify-content:center;font-weight:950;font-size:20px;flex:0 0 54px}@media(max-width:1200px){.kpi-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.staff-login-shell{grid-template-columns:1fr}.staff-login-hero{display:none}.mobile-brand{display:flex}}@media(max-width:768px){.kpi-grid,.quick-grid{grid-template-columns:1fr}.premium-kpi.card{min-height:auto}.staff-login-panel{padding:22px}.login-panel-card{border-radius:24px;padding:24px}.login-panel-card h2{font-size:28px}.booking-row{display:block}.booking-date{margin-bottom:12px}.user-pill{display:none}}

/* v1.9.4 Staff dashboard layout polish */
.staff-dashboard-page .staff-kpi-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:18px;margin-bottom:26px;align-items:stretch}
.staff-dashboard-page .staff-kpi-card{background:linear-gradient(180deg,#fff,#fbfdff);border:1px solid var(--line);border-radius:24px;box-shadow:0 18px 40px rgba(15,23,42,.06);padding:22px;min-height:132px;display:flex;align-items:center;justify-content:space-between;gap:18px;overflow:hidden}
.staff-dashboard-page .staff-kpi-label{font-size:12px;text-transform:uppercase;letter-spacing:.07em;font-weight:900;color:var(--muted);margin-bottom:8px;line-height:1}
.staff-dashboard-page .staff-kpi-value{font-size:36px;line-height:1;font-weight:950;letter-spacing:-.05em;color:var(--ink);margin-bottom:8px}
.staff-dashboard-page .staff-kpi-note{font-size:13px;color:var(--muted);font-weight:650;line-height:1.35}
.staff-dashboard-page .staff-kpi-icon{width:50px;height:50px;border-radius:18px;background:#eff6ff;color:var(--blue);display:flex;align-items:center;justify-content:center;font-weight:950;font-size:20px;flex:0 0 50px}
.staff-dashboard-page .staff-main-grid{display:grid;grid-template-columns:minmax(0,2fr) minmax(330px,.95fr);gap:26px;align-items:start}
.staff-dashboard-page .staff-section-card{background:#fff;border:1px solid var(--line);border-radius:26px;box-shadow:0 20px 48px rgba(15,23,42,.06);padding:26px}
.staff-dashboard-page .staff-section-title{font-size:26px;font-weight:950;letter-spacing:-.04em;margin:0;color:var(--ink)}
.staff-dashboard-page .staff-section-sub{font-size:13px;color:var(--muted);margin-top:4px}
.staff-dashboard-page .staff-booking-list{display:grid;gap:14px;margin-top:18px}
.staff-dashboard-page .staff-booking-row{display:flex;align-items:center;gap:18px;min-height:120px;border:1px solid var(--line);border-radius:24px;background:linear-gradient(180deg,#fff,#fbfdff);padding:18px;color:var(--ink);text-decoration:none;box-shadow:0 12px 30px rgba(15,23,42,.04);transition:.15s ease}
.staff-dashboard-page .staff-booking-row:hover{transform:translateY(-1px);border-color:#bfdbfe;box-shadow:0 20px 40px rgba(37,99,235,.10);color:var(--ink)}
.staff-dashboard-page .staff-booking-date{width:90px;min-height:86px;border-radius:20px;background:#eff6ff;color:var(--blue);display:flex;flex-direction:column;align-items:center;justify-content:center;line-height:1;text-align:center;flex:0 0 90px}
.staff-dashboard-page .staff-booking-date strong{font-size:20px;font-weight:950;letter-spacing:-.03em;line-height:1.03}
.staff-dashboard-page .staff-booking-date span{font-size:12px;font-weight:900;margin-top:8px;text-transform:uppercase}
.staff-dashboard-page .staff-booking-title{font-weight:950;font-size:17px;letter-spacing:-.02em;color:var(--ink)}
.staff-dashboard-page .staff-booking-meta{font-size:13px;color:var(--muted);margin-top:6px}
.staff-dashboard-page .staff-booking-address{font-size:13px;color:var(--ink);margin-top:10px;display:flex;align-items:center;gap:6px}
.staff-dashboard-page .staff-status-pill{display:inline-flex;align-items:center;gap:7px;border-radius:999px;padding:6px 10px;font-size:12px;font-weight:900;text-transform:capitalize;background:#eff6ff;color:var(--blue)}
.staff-dashboard-page .staff-status-pill:before{content:"";width:7px;height:7px;border-radius:50%;background:currentColor}.staff-dashboard-page .staff-status-pill.in_progress{background:#ecfeff;color:#0e7490}.staff-dashboard-page .staff-status-pill.completed_approved,.staff-dashboard-page .staff-status-pill.completed_pending_review{background:#ecfdf5;color:#047857}.staff-dashboard-page .staff-status-pill.cancelled{background:#fef2f2;color:#b91c1c}
.staff-dashboard-page .staff-team-pill{display:inline-flex;align-items:center;gap:7px;border:1px solid var(--line);background:#f8fafc;border-radius:999px;padding:8px 12px;font-size:12px;font-weight:900;color:#334155;white-space:nowrap}
.staff-dashboard-page .staff-open-job{font-size:13px;font-weight:800;color:var(--muted);margin-top:10px}
.staff-dashboard-page .staff-quick-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin-top:18px}
.staff-dashboard-page .staff-quick-grid a{min-height:72px;border:1px solid var(--line);border-radius:20px;background:linear-gradient(180deg,#fff,#fbfdff);padding:16px;display:flex;align-items:center;gap:13px;color:var(--ink);font-weight:950;text-decoration:none;box-shadow:0 10px 26px rgba(15,23,42,.04)}
.staff-dashboard-page .staff-quick-grid a span{width:38px;height:38px;border-radius:14px;background:var(--blue);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:950;flex:0 0 38px}
.staff-dashboard-page .staff-info-list{display:grid;margin-top:16px}.staff-dashboard-page .staff-info-list>div{display:flex;justify-content:space-between;gap:16px;padding:14px 0;border-bottom:1px solid var(--line)}.staff-dashboard-page .staff-info-list>div:last-child{border-bottom:0}.staff-dashboard-page .staff-info-list span{font-size:13px;color:var(--muted);font-weight:700}.staff-dashboard-page .staff-info-list strong{text-align:right;color:var(--ink)}
@media(max-width:1200px){.staff-dashboard-page .staff-kpi-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.staff-dashboard-page .staff-main-grid{grid-template-columns:1fr}}
@media(max-width:768px){.staff-dashboard-page .staff-kpi-grid,.staff-dashboard-page .staff-quick-grid{grid-template-columns:1fr}.staff-dashboard-page .staff-booking-row{align-items:flex-start}.staff-dashboard-page .staff-booking-date{width:72px;flex-basis:72px}.staff-dashboard-page .staff-booking-date strong{font-size:16px}.staff-dashboard-page .staff-section-card{padding:20px;border-radius:22px}.staff-dashboard-page .staff-section-title{font-size:23px}}
/* v1.9.5 Staff portal menus */
.calendar-day-card{border:1px solid var(--line);border-radius:22px;background:#fff;padding:16px;box-shadow:0 12px 30px rgba(15,23,42,.04)}
.calendar-day-head{display:flex;align-items:center;justify-content:space-between;gap:12px;border-bottom:1px solid var(--line);padding-bottom:12px;margin-bottom:12px}.calendar-day-head strong{font-size:18px}.calendar-day-head span{font-size:13px;color:var(--muted);font-weight:800}.staff-booking-row.compact{min-height:92px;margin-bottom:10px}.activity-list{display:grid;gap:12px}.activity-item{display:flex;gap:14px;align-items:flex-start;border:1px solid var(--line);border-radius:18px;background:linear-gradient(180deg,#fff,#fbfdff);padding:16px}.activity-icon{width:38px;height:38px;border-radius:14px;background:#eff6ff;color:var(--blue);display:flex;align-items:center;justify-content:center;font-weight:950;flex:0 0 38px}.chat-card .chat-window{min-height:420px;max-height:560px;overflow:auto;border:1px solid var(--line);border-radius:22px;background:#f8fafc;padding:18px}.chat-message{display:flex;margin-bottom:12px}.chat-message.mine{justify-content:flex-end}.chat-bubble{max-width:74%;border:1px solid var(--line);background:#fff;border-radius:18px;padding:12px 14px;box-shadow:0 8px 20px rgba(15,23,42,.04)}.chat-message.mine .chat-bubble{background:#2563eb;color:#fff;border-color:#2563eb}.chat-bubble p{margin:4px 0 6px}.chat-bubble small{opacity:.75}.settings-list{display:grid;gap:12px}.settings-row{display:flex;align-items:center;justify-content:space-between;gap:18px;border:1px solid var(--line);background:#fff;border-radius:18px;padding:18px}.settings-row p{margin:4px 0 0;color:var(--muted)}@media(max-width:768px){.chat-bubble{max-width:92%}.settings-row{display:block}.settings-row .badge{margin-top:10px}.calendar-day-head{display:block}.calendar-day-head span{display:block;margin-top:4px}}

/* v1.9.6 Staff portal menu/pages polish */
.staff-page{display:block}.staff-page .staff-kpi-grid,.staff-kpi-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:18px;margin-bottom:24px}.staff-page .staff-kpi-card,.staff-kpi-card{background:linear-gradient(180deg,#fff,#fbfdff);border:1px solid var(--line);border-radius:24px;box-shadow:0 18px 40px rgba(15,23,42,.06);padding:22px;min-height:126px;display:flex;align-items:center;justify-content:space-between;gap:18px;overflow:hidden}.staff-page .staff-kpi-label,.staff-kpi-label{font-size:12px;text-transform:uppercase;letter-spacing:.07em;font-weight:900;color:var(--muted);margin-bottom:8px}.staff-page .staff-kpi-value,.staff-kpi-value{font-size:34px;line-height:1;font-weight:950;letter-spacing:-.05em;color:var(--ink);margin-bottom:8px}.staff-page .staff-kpi-note,.staff-kpi-note{font-size:13px;color:var(--muted);font-weight:650;line-height:1.35}.staff-page .staff-kpi-icon,.staff-kpi-icon{width:50px;height:50px;border-radius:18px;background:#eff6ff;color:var(--blue);display:flex;align-items:center;justify-content:center;font-weight:950;font-size:20px;flex:0 0 50px}.staff-page .staff-section-card,.staff-section-card{background:#fff;border:1px solid var(--line);border-radius:26px;box-shadow:0 20px 48px rgba(15,23,42,.06);padding:26px}.staff-page .staff-section-title,.staff-section-title{font-size:26px;font-weight:950;letter-spacing:-.04em;margin:0;color:var(--ink)}.staff-page .staff-section-sub,.staff-section-sub{font-size:13px;color:var(--muted);margin-top:4px}.staff-booking-list-full{display:grid;gap:14px}.staff-page .staff-booking-row,.staff-booking-row.wide{display:flex;align-items:center;gap:18px;min-height:112px;border:1px solid var(--line);border-radius:24px;background:linear-gradient(180deg,#fff,#fbfdff);padding:18px;color:var(--ink);text-decoration:none;box-shadow:0 12px 30px rgba(15,23,42,.04);transition:.15s ease;margin-bottom:0}.staff-page .staff-booking-row:hover,.staff-booking-row.wide:hover{transform:translateY(-1px);border-color:#bfdbfe;box-shadow:0 20px 40px rgba(37,99,235,.10);color:var(--ink)}.staff-page .staff-booking-date,.staff-booking-date{width:90px;min-height:86px;border-radius:20px;background:#eff6ff;color:var(--blue);display:flex;flex-direction:column;align-items:center;justify-content:center;line-height:1;text-align:center;flex:0 0 90px}.staff-page .staff-booking-date strong,.staff-booking-date strong{font-size:20px;font-weight:950;letter-spacing:-.03em;line-height:1.03}.staff-page .staff-booking-date span,.staff-booking-date span{font-size:12px;font-weight:900;margin-top:8px;text-transform:uppercase}.staff-page .staff-booking-title,.staff-booking-title{font-weight:950;font-size:17px;letter-spacing:-.02em;color:var(--ink)}.staff-page .staff-booking-meta,.staff-booking-meta{font-size:13px;color:var(--muted);margin-top:6px}.staff-page .staff-booking-address,.staff-booking-address{font-size:13px;color:var(--ink);margin-top:10px;display:flex;align-items:center;gap:6px}.staff-page .staff-status-pill,.staff-status-pill{display:inline-flex;align-items:center;gap:7px;border-radius:999px;padding:6px 10px;font-size:12px;font-weight:900;text-transform:capitalize;background:#eff6ff;color:var(--blue)}.staff-page .staff-status-pill:before,.staff-status-pill:before{content:"";width:7px;height:7px;border-radius:50%;background:currentColor}.staff-page .staff-open-job,.staff-open-job{font-size:13px;font-weight:800;color:var(--muted);white-space:nowrap}.staff-filter-tabs{display:flex;gap:8px;flex-wrap:wrap}.staff-filter-tabs a{border:1px solid var(--line);background:#fff;color:#475569;border-radius:999px;padding:10px 15px;font-weight:900;font-size:13px;text-decoration:none}.staff-filter-tabs a.active,.staff-filter-tabs a:hover{background:var(--blue);border-color:var(--blue);color:#fff}.calendar-week-grid{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));gap:14px}.calendar-day-card{border:1px solid var(--line);border-radius:22px;background:#fff;padding:16px;min-height:180px;box-shadow:0 10px 26px rgba(15,23,42,.04)}.calendar-day-card.today{border-color:#bfdbfe;background:linear-gradient(180deg,#eff6ff,#fff)}.calendar-job-chip{display:block;border:1px solid var(--line);border-radius:16px;padding:12px;margin-top:10px;text-decoration:none;color:var(--ink);background:#fbfdff}.calendar-job-chip:hover{border-color:#bfdbfe;color:var(--ink)}.calendar-job-time{font-weight:950;color:var(--blue);font-size:13px}.calendar-job-title{font-weight:900;margin-top:3px}.calendar-job-meta{font-size:12px;color:var(--muted);margin-top:3px}.activity-list{display:grid;gap:12px}.activity-item{display:flex;gap:14px;align-items:flex-start;border:1px solid var(--line);border-radius:18px;background:linear-gradient(180deg,#fff,#fbfdff);padding:16px}.activity-icon{width:38px;height:38px;border-radius:14px;background:#eff6ff;color:var(--blue);display:flex;align-items:center;justify-content:center;font-weight:950;flex:0 0 38px}.chat-card .chat-window{min-height:420px;max-height:560px;overflow:auto;border:1px solid var(--line);border-radius:22px;background:#f8fafc;padding:18px}.chat-message{display:flex;margin-bottom:12px}.chat-message.mine{justify-content:flex-end}.chat-bubble{max-width:74%;border:1px solid var(--line);background:#fff;border-radius:18px;padding:12px 14px;box-shadow:0 8px 20px rgba(15,23,42,.04)}.chat-message.mine .chat-bubble{background:var(--blue);color:#fff;border-color:var(--blue)}.chat-bubble p{margin:4px 0 6px}.chat-bubble small{opacity:.75}.settings-list{display:grid;gap:12px}.settings-row{display:flex;align-items:center;justify-content:space-between;gap:18px;border:1px solid var(--line);background:#fff;border-radius:18px;padding:18px}.settings-row p{margin:4px 0 0;color:var(--muted)}.staff-table-card table{margin:0}.staff-table-card thead th{background:#f8fafc;font-size:12px;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);border-bottom:1px solid var(--line)}.staff-table-card td{vertical-align:middle}.empty-premium{border:1px dashed #cbd5e1;border-radius:22px;background:#f8fafc;padding:36px;text-align:center}.empty-icon{width:52px;height:52px;margin:0 auto 12px;border-radius:18px;background:#eff6ff;color:var(--blue);display:flex;align-items:center;justify-content:center;font-weight:950;font-size:22px}@media(max-width:1200px){.staff-page .staff-kpi-grid,.staff-kpi-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.calendar-week-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(max-width:768px){.staff-page .staff-kpi-grid,.staff-kpi-grid,.calendar-week-grid{grid-template-columns:1fr}.staff-page .staff-booking-row,.staff-booking-row.wide{align-items:flex-start}.staff-page .staff-booking-date,.staff-booking-date{width:72px;flex-basis:72px}.staff-section-card{padding:20px;border-radius:22px}.staff-section-title{font-size:23px}.chat-bubble{max-width:92%}.settings-row{display:block}.settings-row .badge{margin-top:10px}}

/* v1.9.7 Staff GPS */
.gps-card{border:1px solid rgba(37,99,235,.16);background:linear-gradient(180deg,#fff 0%,#f8fbff 100%)}
.gps-status-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px}
.gps-status-grid>div{border:1px solid var(--line,#e2e8f0);border-radius:16px;background:#fff;padding:14px}
.gps-status-grid span{display:block;font-size:.78rem;color:var(--muted,#64748b);font-weight:700;text-transform:uppercase;letter-spacing:.04em;margin-bottom:4px}
.gps-status-grid strong{display:block;color:var(--ink,#0f172a);font-size:.95rem;word-break:break-word}
.gps-actionbar{gap:10px;flex-wrap:wrap}
.gps-actionbar .btn{min-width:150px}
@media(max-width:992px){.gps-status-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.gps-actionbar .btn{flex:1 1 45%}}
@media(max-width:576px){.gps-status-grid{grid-template-columns:1fr}.gps-actionbar .btn{flex:1 1 100%}}

/* v1.11 Operations Center unified dashboard */
.operations-center-v111 .ops-hero-panel{border:1px solid rgba(37,99,235,.12);background:linear-gradient(135deg,rgba(37,99,235,.10),rgba(255,255,255,.96) 46%,rgba(16,185,129,.10));border-radius:calc(var(--card-radius,22px) + 6px);box-shadow:0 22px 55px rgba(15,23,42,.08);padding:26px 28px;display:flex;justify-content:space-between;align-items:center;gap:20px;overflow:hidden;position:relative}.operations-center-v111 .ops-hero-panel:after{content:"";position:absolute;right:-80px;top:-80px;width:260px;height:260px;background:radial-gradient(circle,rgba(37,99,235,.18),transparent 68%);pointer-events:none}.operations-center-v111 .ops-hero-panel h2{font-size:34px;font-weight:950;color:var(--ink);letter-spacing:-.04em;margin:2px 0 6px}.operations-center-v111 .ops-hero-panel p{margin:0;color:var(--muted);max-width:780px}.ops-hero-actions{display:flex;gap:10px;flex-wrap:wrap;position:relative;z-index:1}.premium-scroll{max-height:640px;overflow:auto;padding-right:4px}.premium-scroll.shorter{max-height:520px}.premium-scroll::-webkit-scrollbar{width:8px}.premium-scroll::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:10px}.operations-center-v111 .timeline-job{color:inherit}.operations-center-v111 .timeline-job:hover .timeline-body{transform:translateY(-1px);box-shadow:0 16px 36px rgba(15,23,42,.08)}.ops-team-card{position:relative;overflow:hidden}.ops-team-card:before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--blue)}.live-dot.available{background:#94a3b8}.live-dot.done{background:var(--green)}.live-dot.working{background:var(--orange)}.live-dot.assigned{background:var(--blue)}.live-dot.danger{background:var(--red)}.live-dot.pending{background:#a855f7}.ops-map-shell{height:360px;border:1px solid var(--line);border-radius:26px;background:linear-gradient(135deg,#f8fafc,#eef6ff);position:relative;overflow:hidden;box-shadow:inset 0 0 0 1px rgba(255,255,255,.6)}.map-grid-bg{position:absolute;inset:0;background-image:linear-gradient(rgba(37,99,235,.06) 1px,transparent 1px),linear-gradient(90deg,rgba(37,99,235,.06) 1px,transparent 1px);background-size:42px 42px}.map-grid-bg:after{content:"";position:absolute;inset:0;background:radial-gradient(circle at 25% 30%,rgba(37,99,235,.12),transparent 20%),radial-gradient(circle at 70% 60%,rgba(16,185,129,.12),transparent 24%)}.ops-map-pin{width:42px;height:42px;border-radius:18px;display:flex;align-items:center;justify-content:center;background:var(--blue);color:#fff;font-weight:950;position:absolute;transform:translate(-50%,-50%);box-shadow:0 15px 30px rgba(15,23,42,.25);border:3px solid #fff;z-index:2;text-decoration:none}.ops-map-pin:after{content:"";position:absolute;bottom:-8px;left:50%;transform:translateX(-50%) rotate(45deg);width:14px;height:14px;background:inherit;border-right:3px solid #fff;border-bottom:3px solid #fff}.ops-map-pin.pin-working{background:var(--orange)}.ops-map-pin.pin-done{background:var(--green)}.ops-map-pin.pin-danger{background:var(--red)}.ops-map-pin.pin-pending{background:#a855f7}.map-empty-note{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);background:rgba(255,255,255,.9);border:1px dashed #cbd5e1;border-radius:18px;padding:18px 22px;text-align:center;color:var(--muted);font-weight:700}.map-job-list{display:grid;gap:9px}.map-job-row{display:grid;grid-template-columns:auto auto 1fr;gap:10px;align-items:center;border:1px solid var(--line);background:#fff;border-radius:15px;padding:10px 12px}.map-job-row small{grid-column:3;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.capacity-stack{display:grid;gap:14px}.capacity-row{border:1px solid var(--line);border-radius:20px;background:#fff;padding:16px;box-shadow:0 10px 25px rgba(15,23,42,.04)}.capacity-label{font-size:11px;font-weight:900;border-radius:999px;padding:5px 9px;background:#eff6ff;color:var(--blue);letter-spacing:.05em}.capacity-label.full{background:#fee2e2;color:#b91c1c}.capacity-label.busy{background:#fef3c7;color:#92400e}.capacity-label.open{background:#dcfce7;color:#166534}.capacity-bar{height:11px;background:#eef2f7;border-radius:999px;overflow:hidden;margin:12px 0 8px}.capacity-bar>div{height:100%;background:linear-gradient(90deg,var(--blue),var(--green));border-radius:999px}.capacity-meta{display:flex;justify-content:space-between;color:var(--muted);font-size:13px;font-weight:700}.mini-list{display:grid;gap:10px}.mini-list-row{display:flex;gap:12px;align-items:center;border:1px solid var(--line);background:#fff;border-radius:18px;padding:12px;color:var(--ink);transition:.18s}.mini-list-row:hover{transform:translateY(-1px);box-shadow:0 12px 28px rgba(15,23,42,.08)}.mini-avatar{width:42px;height:42px;border-radius:16px;background:linear-gradient(135deg,var(--blue),var(--blue2));color:#fff;display:flex;align-items:center;justify-content:center;font-weight:950}.mini-list-row strong{display:block}.mini-list-row span{display:block;color:var(--muted);font-size:13px}.quick-grid.enhanced{grid-template-columns:repeat(2,minmax(0,1fr))}.quick-grid.enhanced a{min-height:70px}.ops-table thead th{font-size:12px;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);background:#f8fafc;border-bottom:1px solid var(--line)}.ops-table td{border-color:var(--line)}@media(max-width:992px){.operations-center-v111 .ops-hero-panel{align-items:flex-start;flex-direction:column}.operations-center-v111 .ops-hero-panel h2{font-size:28px}.ops-map-shell{height:300px}.quick-grid.enhanced{grid-template-columns:1fr}.premium-scroll,.premium-scroll.shorter{max-height:none}}


/* v1.11.1 Operations Center rename + portal switcher */
.topbar-actions{display:flex;align-items:center;gap:10px;flex-wrap:wrap;justify-content:flex-end}
.portal-chip{align-items:center;gap:6px;border:1px solid var(--line);background:#fff;color:var(--ink);border-radius:999px;padding:10px 13px;font-weight:900;font-size:13px;box-shadow:0 8px 22px rgba(15,23,42,.05)}
.portal-chip:hover{border-color:#bfdbfe;background:#f8fbff;color:var(--blue);transform:translateY(-1px)}
.portal-switcher{border:1px solid var(--line);border-radius:999px;font-weight:900;padding:10px 14px;background:#fff;color:var(--ink);box-shadow:0 8px 22px rgba(15,23,42,.05)}
.portal-menu{border:1px solid var(--line);border-radius:18px;padding:10px;box-shadow:0 20px 55px rgba(15,23,42,.14)}
.portal-menu .dropdown-item{border-radius:12px;font-weight:800;padding:10px 12px}
.module-toggle-row{display:flex;align-items:center;justify-content:space-between;gap:16px;border:1px solid var(--line);border-radius:18px;background:#fff;padding:14px 16px;margin-bottom:10px}
.module-toggle-row small{display:block;color:var(--muted);font-size:12px;margin-top:2px}
.module-toggle-row .form-switch .form-check-input{width:3rem;height:1.55rem}
@media(max-width:768px){.topbar-actions{width:100%;justify-content:flex-start}.portal-switcher{width:100%}.topbar{align-items:flex-start;flex-direction:column}.user-pill{display:flex}}

/* v1.12.2 Sidebar UI Polish + Collapsible Menu */
.sidebar{transition:width .22s ease, padding .22s ease;overflow-y:auto;overflow-x:hidden;scrollbar-width:thin;}
.brand{position:relative;gap:12px;padding-bottom:16px;border-bottom:1px solid rgba(255,255,255,.08);margin-bottom:10px;}
.brand-copy{min-width:0;transition:opacity .18s ease;}
.sidebar-collapse-btn{margin-left:auto;width:34px;height:34px;border:0;border-radius:12px;background:rgba(255,255,255,.08);color:#dbeafe;display:inline-flex;align-items:center;justify-content:center;font-weight:900;transition:.15s ease;}
.sidebar-collapse-btn:hover{background:rgba(255,255,255,.14);color:#fff;transform:translateY(-1px)}
.sidebar-section{margin-top:22px;margin-bottom:9px;transition:opacity .16s ease;}
.sidebar a{position:relative;min-height:44px;}
.sidebar a .nav-label{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.sidebar a .nav-ico{width:28px;height:28px;flex:0 0 28px;border-radius:11px;font-size:14px;color:#fff !important;box-shadow:inset 0 0 0 1px rgba(255,255,255,.10),0 8px 16px rgba(0,0,0,.12);}
.sidebar a:hover .nav-ico{transform:scale(1.04);}
.sidebar a.active .nav-ico{background:rgba(255,255,255,.22) !important;box-shadow:0 8px 22px rgba(37,99,235,.30), inset 0 0 0 1px rgba(255,255,255,.22);}
.ico-operations{background:linear-gradient(135deg,#2563eb,#38bdf8)!important;}
.ico-dispatch{background:linear-gradient(135deg,#f97316,#facc15)!important;}
.ico-customers{background:linear-gradient(135deg,#7c3aed,#a855f7)!important;}
.ico-properties{background:linear-gradient(135deg,#059669,#34d399)!important;}
.ico-leads{background:linear-gradient(135deg,#06b6d4,#60a5fa)!important;}
.ico-quotes{background:linear-gradient(135deg,#f59e0b,#f97316)!important;}
.ico-calendar{background:linear-gradient(135deg,#0ea5e9,#2563eb)!important;}
.ico-bookings{background:linear-gradient(135deg,#10b981,#22c55e)!important;}
.ico-teams,.ico-staff-portal{background:linear-gradient(135deg,#4f46e5,#8b5cf6)!important;}
.ico-payroll{background:linear-gradient(135deg,#16a34a,#65a30d)!important;}
.ico-invoices{background:linear-gradient(135deg,#64748b,#3b82f6)!important;}
.ico-payments{background:linear-gradient(135deg,#14b8a6,#06b6d4)!important;}
.ico-reports{background:linear-gradient(135deg,#9333ea,#ec4899)!important;}
.ico-customer-portal{background:linear-gradient(135deg,#8b5cf6,#6366f1)!important;}
.ico-website{background:linear-gradient(135deg,#0ea5e9,#22c55e)!important;}
.ico-settings{background:linear-gradient(135deg,#475569,#94a3b8)!important;}
.ico-logout{background:linear-gradient(135deg,#ef4444,#fb7185)!important;}
body.sidebar-collapsed{--sidebar-width:86px;}
body.sidebar-collapsed .sidebar{padding-left:14px;padding-right:14px;}
body.sidebar-collapsed .brand{justify-content:center;padding-bottom:12px;}
body.sidebar-collapsed .brand-copy{display:none;}
body.sidebar-collapsed .brand-icon{margin:0;}
body.sidebar-collapsed .sidebar-collapse-btn{position:absolute;right:4px;top:2px;width:28px;height:28px;font-size:12px;}
body.sidebar-collapsed .sidebar-section{font-size:0;height:8px;margin:16px 0 4px;opacity:.45;border-top:1px solid rgba(255,255,255,.10);}
body.sidebar-collapsed .sidebar a{justify-content:center;padding:10px;margin:6px 0;gap:0;}
body.sidebar-collapsed .sidebar a .nav-label,body.sidebar-collapsed .sidebar a .nav-caret{display:none!important;}
body.sidebar-collapsed .sidebar a .nav-ico{width:34px;height:34px;flex-basis:34px;border-radius:13px;}
body.sidebar-collapsed .sidebar-submenu{display:none!important;}
@media(max-width:992px){body.sidebar-collapsed{--sidebar-width:100%;}.sidebar-collapse-btn{display:none}.brand-copy{display:block!important}.sidebar a .nav-label{display:inline!important}.sidebar-section{font-size:11px!important;height:auto!important;border:0!important}.sidebar-submenu{display:block!important}}
