@font-face{font-family:'Helvetica Now Text';src:local('Helvetica Now Text'),local('HelveticaNowText'),local('Helvetica Now Text Regular'),local('HelveticaNowText-Regular');font-weight:100 900;font-display:swap}

/* VARS design tokens — synced to apps/supervisor design system
   (packages/ui-web/src/tokens.ts in the first app). Warm beige
   page + white cards + slate ink + slate-deep primary. */
:root{
  --bg-primary:#ffffff;
  --bg-warm:#DBC5AE;            /* sand — accent fills */
  --bg-warm-light:#E6D8C5;       /* soft sand — hover/chip bg */
  --bg-warm-dark:#3E4C59;        /* slate-deep — PRIMARY button + active accent */
  --bg-surface:#FFFFFF;          /* topbar / strips */
  --bg-card:#FFFFFF;
  --bg-page:#F4EEE4;             /* warm beige canvas */
  --text-dark:#131F23;           /* ink — slightly cool near-black */
  --text-secondary:#61707D;      /* muted slate */
  --text-muted:#8A98A2;          /* subtle slate */
  --border-light:#E6EAE9;
  --border-medium:#D0D6D5;
  --accent-warm:#61707D;         /* slate — secondary accent */
  --accent-warm-light:#E6EAE9;   /* light slate-tinted hover bg */
  --accent-warm-dark:#3E4C59;    /* slate-deep */
  --gradient-warm:linear-gradient(135deg,#DBC5AE 0%,#61707D 60%,#3E4C59 100%);
  --gradient-warm-soft:linear-gradient(135deg,#DBC5AE 0%,#3E4C59 100%);
  --shadow-sm:0 1px 3px rgba(19,31,35,0.05);
  --shadow-md:0 4px 16px rgba(19,31,35,0.08);
  --shadow-lg:0 8px 32px rgba(19,31,35,0.12);
  --radius-sm:6px;
  --radius-md:12px;
  --radius-lg:16px;
}
*{margin:0;padding:0;box-sizing:border-box}
body{font-family:'Anek Odia','Google Sans Flex','Inter','Helvetica Neue',-apple-system,system-ui,sans-serif;background:var(--bg-page);color:var(--text-dark);font-size:15px;font-weight:400;line-height:1.5;-webkit-font-smoothing:antialiased;letter-spacing:-0.003em}
.page-header h1,.modal-header h2{font-family:'Google Sans Flex','Inter','Helvetica Neue',system-ui,-apple-system,sans-serif;font-weight:500;letter-spacing:-0.02em}
::-webkit-scrollbar{width:6px;height:6px}
::-webkit-scrollbar-thumb{background:var(--border-medium);border-radius:3px}
::-webkit-scrollbar-track{background:transparent}

/* Login */
.login-page{display:flex;align-items:center;justify-content:center;min-height:100vh;background:var(--bg-page)}
.login-card{background:#fff;border-radius:var(--radius-lg);padding:48px;width:420px;box-shadow:var(--shadow-lg);border:1px solid var(--border-light)}
.login-card h1{font-size:22px;font-weight:500;letter-spacing:-0.03em;margin-bottom:8px;color:var(--text-dark)}
.login-card p{color:var(--text-muted);margin-bottom:32px;font-size:13px;letter-spacing:-0.01em}
.login-card .logo{display:flex;align-items:center;gap:10px;margin-bottom:32px}
.login-card .logo .v-badge{width:36px;height:36px;background:var(--text-dark);color:#fff;border-radius:6px;display:flex;align-items:center;justify-content:center;font-weight:500;font-size:18px}

/* Layout */
.app-layout{display:flex;min-height:100vh}
.sidebar{width:200px;background:#fff;color:var(--text-dark);display:flex;flex-direction:column;position:fixed;top:0;left:0;bottom:0;z-index:100;transition:width .2s;border-right:1px solid var(--border-light)}
.sidebar.collapsed{width:60px}
.sidebar-header{height:60px;padding:0 20px;display:flex;align-items:center;gap:10px;border-bottom:1px solid var(--border-light);box-sizing:border-box}
.sidebar-header .v-badge{width:28px;height:28px;background:var(--text-dark);color:#fff;border-radius:6px;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:14px;flex-shrink:0}
.sidebar-header span{font-weight:600;font-size:14px;letter-spacing:-0.02em;color:var(--text-dark);font-family:'Google Sans Flex','Inter',system-ui,sans-serif}
.sidebar-nav{flex:1;padding:12px 0;overflow-y:auto}
.sidebar-item{display:flex;align-items:center;gap:10px;padding:10px 20px;cursor:pointer;color:var(--text-secondary);font-size:14px;font-weight:400;line-height:1;transition:background .12s,color .12s;position:relative;text-decoration:none;border-left:2px solid transparent;letter-spacing:-0.005em}
.sidebar-item svg{flex-shrink:0;display:block;transform:translateY(-1px)}
.sidebar-item:hover{background:var(--bg-page);color:var(--text-dark)}
.sidebar-item.active{background:var(--bg-page);color:var(--text-dark);font-weight:500;border-left-color:var(--accent-warm-dark)}
.sidebar-item .badge{background:var(--accent-warm-light);color:var(--text-secondary);font-size:10px;padding:2px 6px;border-radius:3px;margin-left:auto;font-weight:500}
.sidebar-item.active .badge{background:var(--accent-warm-dark);color:#fff}
.sidebar-bottom{padding:14px 20px;border-top:1px solid var(--border-light)}
.sidebar-bottom a{color:var(--text-secondary);font-size:11px;text-decoration:none;display:flex;align-items:center;gap:6px}

/* RTL layout overrides for Arabic */
html[dir="rtl"] .sidebar{left:auto;right:0;box-shadow:-2px 0 8px rgba(0,0,0,0.06)}
html[dir="rtl"] .sidebar-item{border-left:2px solid transparent;border-right:2px solid transparent}
html[dir="rtl"] .sidebar-item.active{border-left-color:transparent;border-right-color:#928989}
html[dir="rtl"] .sidebar-item .badge{margin-left:0;margin-right:auto}
html[dir="rtl"] .topbar{left:0;right:200px}
html[dir="rtl"] .topbar-right{margin-left:0;margin-right:auto}
html[dir="rtl"] .main-content{margin-left:0;margin-right:200px}
html[dir="rtl"] .res-header{direction:rtl}
html[dir="rtl"] .sec-header{direction:rtl}
html[dir="rtl"] body{font-family:'Helvetica Now Text','Tahoma','Arial',-apple-system,sans-serif}
html[dir="rtl"] .property-select{direction:rtl}
html[dir="rtl"] .topbar-right{direction:rtl}
/* RTL dropdown positioning - flip to right side */
html[dir="rtl"] div[style*="position:absolute"][style*="left:0"] { left:auto !important; right:0 !important; }

/* Top bar */
.topbar{height:56px;background:var(--bg-page);border-bottom:1px solid var(--border-light);display:flex;align-items:center;padding:0 20px;gap:16px;position:fixed;top:0;left:200px;right:0;z-index:90;backdrop-filter:blur(8px)}
/* Asset pill matches the sidebar item rhythm exactly: 14px / weight 400 /
   line-height 1 / 10px gap. The SVG icon gets the same translateY(-1px)
   optical-centering nudge as .sidebar-item svg so the house sits flush
   with the text baseline. */
.topbar .property-select{display:inline-flex;align-items:center;gap:10px;padding:10px 20px;min-width:200px;height:40px;border:1px solid var(--border-light);border-radius:var(--radius-sm);font-size:14px;cursor:pointer;background:#fff;font-weight:400;letter-spacing:-0.005em;color:var(--text-dark);line-height:1;box-sizing:border-box}
.topbar .property-select svg{display:block;flex-shrink:0;transform:translateY(-1px)}
.topbar .property-select:hover{border-color:var(--border-medium)}
.topbar-right{margin-left:auto;display:flex;align-items:center;gap:12px}
.btn-create{background:var(--accent-warm-dark);color:#fff;border:none;padding:8px 18px;border-radius:var(--radius-sm);font-size:12px;font-weight:500;cursor:pointer;display:flex;align-items:center;gap:6px;letter-spacing:-0.01em}
.btn-create:hover{opacity:.92}
.topbar-icon{width:36px;height:36px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--text-secondary);font-size:16px}
.topbar-icon:hover{background:var(--accent-warm-light)}
.avatar{width:32px;height:32px;background:var(--accent-warm-light);border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:13px;color:var(--text-dark)}

/* Main content */
.main-content{flex:1;margin-left:200px;margin-top:56px;padding:24px 24px;min-height:calc(100vh - 56px);background:var(--bg-page);min-width:0}
.page-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:28px;gap:16px;flex-wrap:wrap}
.page-header h1{font-size:30px;font-weight:500;letter-spacing:-0.022em;color:var(--text-dark);line-height:1.08}
.page-header .eyebrow{font-size:11px;letter-spacing:0.1em;text-transform:uppercase;color:var(--text-secondary);font-weight:600;margin-bottom:6px}
.page-header .subtitle{color:var(--text-secondary);font-size:13px;margin-top:6px;letter-spacing:-0.005em}

/* Cards & KPIs */
.kpi-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:16px;margin-bottom:32px}
.kpi-card{background:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius-md);padding:20px 24px;box-shadow:var(--shadow-sm);transition:border-color .15s,box-shadow .15s,transform .15s}
.kpi-card .label{font-size:11px;color:var(--text-secondary);margin-bottom:8px;letter-spacing:0.08em;text-transform:uppercase;font-weight:500}
.kpi-card .value{font-size:26px;font-weight:500;color:var(--text-dark);letter-spacing:-0.028em;font-family:'Google Sans Flex','Inter',system-ui,sans-serif;line-height:1.1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.kpi-card .change{font-size:11px;color:var(--text-muted);margin-left:8px}
.kpi-card .sparkline{height:20px;margin-top:8px}
.kpi-card .link{font-size:11px;color:var(--accent-warm-dark);margin-top:10px;cursor:pointer;text-decoration:none}
.kpi-card .link:hover{opacity:.8}

.card{background:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius-md);padding:24px;margin-bottom:20px;box-shadow:var(--shadow-sm)}
.card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;border-bottom:1px solid var(--border-light);padding-bottom:16px}
.card-header h2{font-size:16px;font-weight:500;color:var(--text-dark);letter-spacing:-0.02em}
.card-header h3{font-size:16px;font-weight:500;color:var(--text-dark);letter-spacing:-0.02em}

@keyframes pulse{0%,100%{transform:scale(1);opacity:0.25}50%{transform:scale(1.4);opacity:0.05}}

/* Tables */
.data-table{width:100%;border-collapse:collapse;table-layout:fixed}
.data-table th{text-align:left;padding:12px;font-size:11px;font-weight:500;color:var(--text-secondary);border-bottom:1px solid var(--border-light);white-space:nowrap;letter-spacing:0.06em;text-transform:uppercase}
.data-table td{padding:13px 12px;border-bottom:1px solid var(--border-light);font-size:14px;letter-spacing:-0.01em}
.data-table tr:hover{background:var(--bg-page)}
.data-table .name-cell{font-weight:500}
.data-table .sub{font-size:11px;color:var(--text-secondary);display:block;margin-top:2px}

/* Scrollable table wrapper — for tables with many columns (e.g. Profile
   Creation Summary tables) where the user prefers horizontal scrolling
   over cramming everything in. Wrap the <table> in
   <div class="data-table-scroll"> and the inner table sheds the fixed
   layout so columns size to content, while the wrapper provides the
   horizontal scrollbar. */
.data-table-scroll{overflow-x:auto;-webkit-overflow-scrolling:touch;width:100%}
.data-table-scroll .data-table{table-layout:auto;width:auto;min-width:100%}
.data-table-scroll .data-table th,.data-table-scroll .data-table td{white-space:nowrap}

/* Status badges */
.status{display:inline-block;padding:4px 10px;border-radius:4px;font-size:10px;font-weight:600;border:1px solid transparent;letter-spacing:0.02em}
.status.inside{background:var(--bg-warm-dark);color:#fff}
.status.pending{background:#fff;color:var(--accent-warm-dark);border:1px solid var(--border-medium)}
.status.paid{background:var(--bg-warm-dark);color:#fff}
.status.unpaid{background:#fff;color:var(--accent-warm-dark);border:1px solid var(--border-medium)}
.status.scheduled{background:var(--bg-warm-dark);color:#fff}
.status.pre-approved{background:linear-gradient(135deg,#e0ddd8 0%,#ccc8c1 50%,#b8b3ab 100%);color:#4a4540;border:none}
.status.completed{background:var(--accent-warm-light);color:var(--accent-warm-dark);border:1px solid var(--border-medium)}
.status.checked-out{background:var(--accent-warm-light);color:var(--accent-warm-dark);border:1px solid var(--border-medium)}
.status.on-duty{background:var(--bg-warm-dark);color:#fff}
.status.off-duty{background:var(--accent-warm-light);color:var(--accent-warm-dark);border:1px solid var(--border-medium)}
.status.verified{color:var(--accent-warm-dark);font-size:11px}
.status.critical{background:var(--bg-warm-dark);color:#fff}
.status.high{background:#fff;color:var(--text-dark);border:1px solid var(--text-dark)}
.status.unresolved{background:#fff;color:var(--accent-warm-dark);border:1px solid var(--border-medium)}
.status.in-review{background:#fff;color:var(--accent-warm-dark);border:1px solid var(--border-medium)}
.status.resolved{background:var(--accent-warm-light);color:var(--accent-warm-dark);border:1px solid var(--border-medium)}
.status.live{background:var(--bg-warm-dark);color:#fff}
.status.sent{background:var(--accent-warm-light);color:var(--accent-warm-dark);border:1px solid var(--border-medium)}
.status.draft{background:#fff;color:var(--text-secondary);border:1px solid var(--border-medium)}
.status.vendor{background:#fff;color:var(--text-secondary);border:1px solid var(--border-medium)}
.status.contractor{background:#fff;color:var(--text-secondary);border:1px solid var(--border-medium)}
.status.guest{background:#fff;color:var(--text-secondary);border:1px solid var(--border-medium)}
.status.pending-approval{background:#fff;color:var(--accent-warm-dark);border:1px solid var(--border-medium)}

/* Buttons */
.btn{padding:10px 18px;border-radius:var(--radius-sm);font-size:12px;font-weight:500;cursor:pointer;border:1px solid var(--border-medium);background:#fff;color:var(--text-secondary);display:inline-flex;align-items:center;gap:6px;transition:all .2s cubic-bezier(0.16,1,0.3,1);letter-spacing:-0.01em}
.btn:hover{background:var(--bg-surface);border-color:var(--accent-warm)}
.btn-primary{background:var(--bg-warm-dark);color:#fff;border-color:var(--bg-warm-dark);letter-spacing:-0.01em}
.btn-primary:hover{background:var(--accent-warm);border-color:var(--accent-warm)}
.btn-sm{padding:6px 12px;font-size:11px}
.btn-danger{background:#8b4a42;color:#fff;border-color:#8b4a42}
.btn-danger:hover{background:#6d3832}
.btn-outline{background:transparent;border:1px solid var(--border-medium)}
.btn-group{display:flex;gap:8px}
.btn.approve{background:#5a6b4f;color:#fff;border-color:#5a6b4f}
.btn.approve:hover{background:#4a5b40}
.btn.reject{background:#8b4a42;color:#fff;border-color:#8b4a42}
.btn.hold{background:#7a6040;color:#fff;border-color:#7a6040}
.btn.hold:hover{background:#6a5030}

/* Forms */
.form-group{margin-bottom:16px}
.form-group label{display:block;font-size:11px;font-weight:500;color:var(--text-secondary);margin-bottom:8px;letter-spacing:0.04em;text-transform:uppercase}
.form-input{width:100%;padding:10px 12px;border:1px solid var(--border-light);border-radius:var(--radius-sm);font-size:13px;outline:none;font-family:inherit;background:var(--bg-surface);transition:border-color .2s}
.form-input:focus{border-color:var(--accent-warm);background:#fff}
.form-input::placeholder{color:var(--text-muted)}

/* Toggle */
.toggle{width:44px;height:24px;background:var(--border-medium);border-radius:12px;position:relative;cursor:pointer;transition:background .2s}
.toggle.on{background:var(--bg-warm-dark)}
.toggle .knob{width:20px;height:20px;background:#fff;border-radius:50%;position:absolute;top:2px;left:2px;transition:left .2s}
.toggle.on .knob{left:22px}

/* Modals */
.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(26,26,26,0.4);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000}
.modal{background:#fff;border-radius:var(--radius-lg);padding:32px;width:90%;max-width:560px;max-height:85vh;overflow-y:auto;position:relative;border:1px solid var(--border-light);box-shadow:var(--shadow-lg)}
.modal-wide{max-width:720px}
.modal-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:24px}
.modal-header h2{font-size:19px;font-weight:500;color:var(--text-dark);letter-spacing:-0.022em}
.modal-header .modal-sub{font-size:12px;color:var(--text-secondary);margin-top:4px}
.modal-close{width:32px;height:32px;border:none;background:transparent;border-radius:var(--radius-sm);cursor:pointer;font-size:18px;display:flex;align-items:center;justify-content:center;color:var(--text-muted)}
.modal-close:hover{background:var(--accent-warm-light);color:var(--text-dark)}

/* Wizard steps */
.wizard-steps{display:flex;gap:8px;margin-bottom:24px;align-items:center}
.wizard-step{display:flex;align-items:center;gap:6px;font-size:12px;color:#8a8a8a}
.wizard-step.active{color:var(--text-dark);font-weight:500;background:var(--accent-warm-light);padding:8px 14px;border-radius:var(--radius-sm)}
.wizard-step.completed{color:#4d4d4f}
.wizard-sep{color:#d0d0d0}

/* Filter chips */
.filter-row{display:flex;gap:8px;margin-bottom:16px;align-items:center;flex-wrap:wrap}
.chip{padding:8px 14px;border-radius:var(--radius-sm);font-size:11px;font-weight:500;cursor:pointer;border:1px solid var(--border-light);background:#fff;color:var(--text-secondary);letter-spacing:-0.01em;transition:all .2s}
.chip.active{background:var(--bg-warm-dark);color:#fff;border-color:var(--bg-warm-dark)}
.chip:hover:not(.active){background:var(--accent-warm-light)}

/* Pagination */
.pagination{display:flex;align-items:center;justify-content:space-between;margin-top:16px;font-size:11px;color:#8a8a8a}
.pagination .page-sizes{display:flex;gap:4px}
.pagination .page-size{width:28px;height:28px;border-radius:4px;border:1px solid #d0d0d0;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:11px;background:#fff}
.pagination .page-size.active{background:var(--bg-warm-dark);color:#fff;border-color:var(--bg-warm-dark)}
.page-nav{display:flex;gap:4px}
.page-nav button{width:28px;height:28px;border-radius:4px;border:1px solid #d0d0d0;background:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:12px}

/* Grid layouts */
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.grid-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:20px}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.flex-between{display:flex;justify-content:space-between;align-items:center}

/* Activity feed */
.feed-item{display:flex;gap:10px;padding:12px 0;border-bottom:1px solid #f0f0f0;font-size:13px}
.feed-item:last-child{border-bottom:none}
.feed-dot{width:6px;height:6px;border-radius:50%;background:#d0d0d0;margin-top:6px;flex-shrink:0}
.feed-dot.red{background:#8b2500}
.feed-dot.green{background:#2d6a4f}
.feed-dot.yellow{background:#b8860b}
.feed-dot.blue{background:#4d6d8a}
.feed-dot.gray{background:#8a8a8a}
.feed-time{font-size:10px;color:#8a8a8a;margin-top:2px}

/* Calendar mini */
.mini-cal{width:100%}
.mini-cal .cal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}
.mini-cal .cal-header h3{font-size:15px;font-weight:600;color:#1a1a1a}
.mini-cal .cal-nav{display:flex;gap:4px}
.mini-cal .cal-nav button{width:28px;height:28px;border-radius:4px;border:1px solid #d0d0d0;background:#fff;cursor:pointer;font-size:14px}
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:2px;text-align:center}
.cal-day-header{font-size:10px;font-weight:500;color:#8a8a8a;padding:4px}
.cal-day{padding:8px;font-size:12px;border-radius:4px;cursor:pointer}
.cal-day:hover{background:#f8f8f8}
.cal-day.today{background:var(--bg-warm-dark);color:#fff}
.cal-day.selected{background:#e8e3de;color:#1a1a1a;font-weight:600;border-radius:4px}
.cal-day.has-event{font-weight:600;color:#1a1a1a}
.cal-day.other-month{color:#d0d0d0}

/* Chart placeholder */
.chart-placeholder{height:200px;background:var(--bg-surface);border-radius:var(--radius-sm);display:flex;align-items:flex-end;padding:16px;gap:8px}
.chart-bar{background:var(--bg-warm-dark);border-radius:2px 2px 0 0;flex:1;min-width:20px;transition:height .3s}
.chart-bar.light{background:var(--bg-warm-light)}

/* Announcement cards */
.announcement-card{background:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius-md);padding:24px;margin-bottom:16px;box-shadow:var(--shadow-sm)}
.announcement-card .tags{display:flex;gap:6px;margin-bottom:12px}
.announcement-card h3{font-size:15px;font-weight:500;margin-bottom:4px}
.announcement-card .meta{font-size:11px;color:#8a8a8a;margin-bottom:12px}
.announcement-card .stats{display:flex;gap:24px;font-size:12px}
.announcement-card .stats .stat-label{font-size:10px;color:#8a8a8a}
.announcement-card .stats .stat-value{font-weight:600}
.progress-bar{height:4px;background:var(--border-medium);border-radius:2px;overflow:hidden;flex:1}
.progress-bar .fill{height:100%;background:var(--bg-warm-dark);border-radius:2px}

/* Right panel */
.page-with-panel{display:grid;grid-template-columns:1fr 320px;gap:24px}
.right-panel{display:flex;flex-direction:column;gap:20px}

/* Today schedule */
.schedule-item{display:flex;gap:12px;padding:10px 0;border-bottom:1px solid #f0f0f0;font-size:12px}
.schedule-item:last-child{border-bottom:none}
.schedule-time{font-weight:600;color:#4d4d4f;min-width:40px}

/* Guard carousel */
.guard-carousel{display:flex;gap:12px;overflow-x:auto;padding:4px 0}
.guard-chip{min-width:200px;padding:12px 16px;border:1px solid var(--border-light);border-radius:var(--radius-sm);background:var(--bg-card);display:flex;align-items:center;gap:10px;box-shadow:var(--shadow-sm)}
.guard-chip .avatar-sm{width:36px;height:36px;background:#e0e0e0;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px}

/* Escalation items */
.escalation-item{border:1px solid var(--border-light);border-radius:var(--radius-md);padding:16px;margin-bottom:12px;cursor:pointer;transition:all .2s;box-shadow:var(--shadow-sm)}
.escalation-item:hover{border-color:var(--accent-warm);box-shadow:var(--shadow-md)}

/* Settings nav */
.settings-layout{display:grid;grid-template-columns:260px 1fr;gap:32px}
.settings-nav{background:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius-md);padding:8px;height:fit-content;box-shadow:var(--shadow-sm)}
.settings-nav-item{display:flex;align-items:center;gap:10px;padding:10px 14px;border-radius:4px;cursor:pointer;font-size:12px;font-weight:400;color:#8a8a8a}
.settings-nav-item:hover{background:#f8f8f8}
.settings-nav-item.active{background:var(--bg-warm-dark);color:#fff}
.settings-contacts{padding:16px;border-top:1px solid #e8e8e8;margin-top:8px}
.settings-contacts h4{font-size:10px;color:#8a8a8a;margin-bottom:12px;letter-spacing:0.04em;text-transform:uppercase}
.settings-contact{margin-bottom:12px}
.settings-contact .role{font-size:10px;color:#8a8a8a}
.settings-contact .name{font-size:12px;font-weight:600}
.settings-contact .phone{font-size:11px;color:#8a8a8a}

/* Dropdown */
.dropdown{position:relative}
.dropdown-menu{position:absolute;top:100%;right:0;background:#fff;border:1px solid #d0d0d0;border-radius:4px;box-shadow:0 2px 8px rgba(0,0,0,0.08);min-width:180px;z-index:200;padding:4px}
.dropdown-item{padding:8px 12px;font-size:12px;cursor:pointer;border-radius:3px}
.dropdown-item:hover{background:#f8f8f8}

/* Upload area */
.upload-area{border:2px dashed var(--border-medium);border-radius:var(--radius-md);padding:32px;text-align:center;color:var(--text-muted);cursor:pointer;transition:all .2s}
.upload-area:hover{border-color:var(--accent-warm);background:var(--bg-surface)}

/* SLA tracker */
.sla-item{display:flex;align-items:center;gap:12px;padding:10px 0;font-size:12px}
.sla-bar{flex:1;height:4px;background:#d0d0d0;border-radius:2px;overflow:hidden}
.sla-bar .sla-fill{height:100%;background:var(--bg-warm-dark);border-radius:2px}

/* Type selector buttons */
.type-selector{display:flex;gap:8px}
.type-btn{flex:1;padding:12px;border:1px solid #d0d0d0;border-radius:4px;text-align:center;cursor:pointer;font-size:12px;font-weight:500;background:#fff;color:#4d4d4f}
.type-btn.active{background:var(--bg-warm-dark);color:#fff;border-color:var(--bg-warm-dark)}
.type-btn:hover:not(.active){background:#f8f8f8}

/* Service personnel list */
.personnel-item{display:flex;align-items:center;gap:12px;padding:12px;border:1px solid #d0d0d0;border-radius:4px;margin-bottom:8px;cursor:pointer;box-shadow:0 1px 3px rgba(0,0,0,0.04)}
.personnel-item:hover{border-color:#8a8a8a}
.personnel-item.selected{border-color:var(--bg-warm-dark);border-width:2px}

/* Toast */
.toast{position:fixed;bottom:24px;right:24px;background:var(--bg-warm-dark);color:#fff;padding:12px 24px;border-radius:var(--radius-sm);font-size:12px;z-index:2000;animation:slideUp .3s ease;box-shadow:var(--shadow-md)}
@keyframes slideUp{from{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}
@keyframes spin{from{transform:rotate(0deg)}to{transform:rotate(360deg)}}

/* Mobile bottom nav */
.mobile-bottom-nav{display:none;position:fixed;bottom:0;left:0;right:0;background:#fff;border-top:1px solid #d0d0d0;z-index:100;padding:4px 0 env(safe-area-inset-bottom,4px) 0}
.mobile-bottom-nav .nav-items{display:flex;justify-content:space-around}
.mobile-bottom-nav .nav-item{display:flex;flex-direction:column;align-items:center;gap:2px;padding:6px 4px;font-size:9px;color:#8a8a8a;cursor:pointer;min-width:0;flex:1}
.mobile-bottom-nav .nav-item.active{color:var(--accent-warm-dark)}
.mobile-bottom-nav .nav-item .nav-badge{position:absolute;top:-2px;right:-6px;background:#8b2500;color:#fff;font-size:9px;padding:0 4px;border-radius:3px;min-width:14px;text-align:center}

/* Mobile sidebar overlay */
.sidebar-overlay{display:none;position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,0.5);z-index:99}

/* Hamburger */
.hamburger{display:none;width:36px;height:36px;border:none;background:none;cursor:pointer;padding:6px;flex-shrink:0}
.hamburger span{display:block;width:20px;height:2px;background:#4d4d4f;margin:4px auto;border-radius:1px}

/* Responsive */
@media(max-width:768px){
  .sidebar{width:240px;transform:translateX(-100%);transition:transform .25s ease;z-index:200}
  .sidebar.open{transform:translateX(0)}
  .sidebar-overlay.show{display:block;z-index:150}
  .main-content{margin-left:0;margin-top:56px;padding:20px;padding-bottom:72px}
  .topbar{left:0;padding:0 12px;gap:8px}
  .topbar .property-select span:nth-child(2){max-width:100px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
  .topbar .search-bar{display:none}
  .hamburger{display:block}
  .page-with-panel{grid-template-columns:1fr}
  .page-header{flex-direction:column;gap:12px}
  .page-header .btn-group{flex-wrap:wrap}
  .kpi-row{grid-template-columns:repeat(2,1fr)!important;gap:8px}
  .grid-2{grid-template-columns:1fr}
  .grid-3{grid-template-columns:1fr}
  .grid-4{grid-template-columns:repeat(2,1fr)}
  .card{padding:14px;margin-bottom:12px}
  .data-table{display:block;overflow-x:auto;white-space:nowrap;-webkit-overflow-scrolling:touch}
  .data-table th,.data-table td{padding:8px 10px;font-size:12px}
  .filter-row{overflow-x:auto;flex-wrap:nowrap;-webkit-overflow-scrolling:touch;padding-bottom:4px}
  .chip{white-space:nowrap;flex-shrink:0}
  .modal-overlay{align-items:flex-end;padding:0}
  .modal{max-width:100%;width:100%;border-radius:16px 16px 0 0;max-height:90vh;padding:20px 16px}
  .modal-wide{max-width:100%}
  .settings-layout{grid-template-columns:1fr}
  .settings-contacts{display:none}
  .btn{padding:10px 14px;font-size:13px}
  .btn-sm{padding:7px 10px}
  .btn-create span:last-child{display:none}
  .btn-group{width:100%}
  .btn-group .btn{flex:1;justify-content:center}
  .type-selector{flex-direction:column}
  .type-btn{padding:12px}
  .sidebar-bottom{display:none}
  .mobile-bottom-nav{display:block}
  .topbar-right .topbar-icon,.topbar-right .avatar{display:none}
  .guard-carousel{overflow-x:auto;-webkit-overflow-scrolling:touch}
  .announcement-card .stats{flex-wrap:wrap;gap:12px}
  .toast{bottom:72px;left:16px;right:16px;text-align:center}
  .personnel-item{padding:14px 12px}
  .schedule-item{font-size:12px}
  .form-input{padding:12px;font-size:14px}
  .escalation-item{padding:12px}
  .right-panel{display:none}
  .wizard-steps{overflow-x:auto;flex-wrap:nowrap;-webkit-overflow-scrolling:touch}
  .wizard-step{white-space:nowrap;flex-shrink:0;font-size:12px}
  .login-card{width:calc(100% - 32px);padding:32px 24px}
  .pagination{flex-wrap:wrap;gap:8px}
  /* Service requests calendar layout */
  div[style*="grid-template-columns: 280px"]{grid-template-columns:1fr!important}
  div[style*="grid-template-columns:280px"]{grid-template-columns:1fr!important}
  /* Settings layout */
  div[style*="grid-template-columns: 260px"]{grid-template-columns:1fr!important}
  div[style*="grid-template-columns:260px"]{grid-template-columns:1fr!important}
  /* Reports layout */
  div[style*="grid-template-columns: 200px"]{grid-template-columns:1fr!important}
  div[style*="grid-template-columns:200px"]{grid-template-columns:1fr!important}
}

@media(max-width:380px){
  .kpi-row{grid-template-columns:1fr!important}
  .grid-4{grid-template-columns:1fr}
  .topbar .property-select{padding:4px 8px;font-size:12px}
  .topbar .property-select span:nth-child(2){max-width:80px}
}
