:root {
  --bg:#0e0f11; --surface:#16181c; --surface2:#1e2127; --border:#2a2d35;
  --accent:#e84b2a; --accent2:#f97316; --gold:#f5c542;
  --text:#e8eaf0; --muted:#6b7280; --green:#22c55e; --blue:#3b82f6;
  --mono:'DM Mono',monospace; --head:'Syne',sans-serif; --body:'DM Sans',sans-serif;
  --radius:10px; --sidebar:240px;
}
*{margin:0;padding:0;box-sizing:border-box;}
body{background:var(--bg);color:var(--text);font-family:var(--body);min-height:100vh;}
a{text-decoration:none;color:inherit;}
input,select,textarea,button{font-family:var(--body);}

/* ── LAYOUT ─────────────────────────────────────────────── */
.app-layout{display:flex;min-height:100vh;}
.sidebar{width:var(--sidebar);min-width:var(--sidebar);background:var(--surface);border-right:1px solid var(--border);display:flex;flex-direction:column;height:100vh;position:sticky;top:0;z-index:50;}
.main{flex:1;overflow-y:auto;height:100vh;}

/* ── LOGO ───────────────────────────────────────────────── */
.logo-area{padding:24px 20px 20px;border-bottom:1px solid var(--border);}
.logo-mark{display:flex;align-items:center;gap:10px;margin-bottom:4px;}
.logo-icon{width:32px;height:32px;background:var(--accent);border-radius:6px;display:flex;align-items:center;justify-content:center;font-family:var(--head);font-weight:800;font-size:16px;color:white;letter-spacing:-1px;flex-shrink:0;}
.logo-text{font-family:var(--head);font-weight:800;font-size:18px;letter-spacing:-0.5px;}
.logo-sub{font-family:var(--mono);font-size:10px;color:var(--muted);letter-spacing:2px;text-transform:uppercase;margin-left:42px;}

/* ── NAV ────────────────────────────────────────────────── */
nav{padding:16px 12px;flex:1;overflow-y:auto;}
.nav-section{margin-bottom:24px;}
.nav-label{font-family:var(--mono);font-size:10px;color:var(--muted);letter-spacing:2px;text-transform:uppercase;padding:0 8px;margin-bottom:6px;}
.nav-item{display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:8px;cursor:pointer;transition:all .15s;color:var(--muted);font-size:14px;margin-bottom:2px;position:relative;text-decoration:none;}
.nav-item:hover{background:var(--surface2);color:var(--text);}
.nav-item.active{background:rgba(232,75,42,.12);color:var(--accent);font-weight:500;}
.nav-item.active::before{content:'';position:absolute;left:0;top:6px;bottom:6px;width:3px;background:var(--accent);border-radius:0 3px 3px 0;}
.nav-icon{width:18px;height:18px;flex-shrink:0;opacity:.7;}
.nav-item.active .nav-icon,.nav-item:hover .nav-icon{opacity:1;}
.nav-badge{margin-left:auto;background:var(--accent);color:white;font-family:var(--mono);font-size:10px;padding:2px 6px;border-radius:10px;}
.nav-job-title{font-family:var(--head);font-size:12px;font-weight:700;color:var(--text);padding:8px 12px;background:rgba(232,75,42,.08);border:1px solid rgba(232,75,42,.2);border-radius:8px;margin-bottom:6px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}

/* ── SIDEBAR FOOTER ─────────────────────────────────────── */
.sidebar-footer{padding:16px 12px;border-top:1px solid var(--border);}
.user-card{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:8px;cursor:pointer;transition:background .15s;}
.user-card:hover{background:var(--surface2);}
.avatar{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,var(--accent),var(--accent2));display:flex;align-items:center;justify-content:center;font-family:var(--head);font-weight:700;font-size:12px;color:white;flex-shrink:0;}
.user-info{flex:1;min-width:0;}
.user-name{font-size:13px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.user-role{font-family:var(--mono);font-size:10px;color:var(--accent);letter-spacing:1px;text-transform:uppercase;}

/* ── MOBILE TOPBAR ──────────────────────────────────────── */
.mobile-topbar{display:none;position:fixed;top:0;left:0;right:0;height:56px;background:var(--surface);border-bottom:1px solid var(--border);z-index:200;padding:0 16px;align-items:center;justify-content:space-between;}
.mobile-menu-btn{background:none;border:none;cursor:pointer;padding:8px;display:flex;flex-direction:column;gap:5px;}
.mobile-menu-btn span{display:block;width:22px;height:2px;background:var(--text);border-radius:2px;transition:all .3s;}
.sidebar-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.6);z-index:149;}

/* ── TOPBAR ─────────────────────────────────────────────── */
.topbar{padding:20px 32px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:16px;background:var(--bg);position:sticky;top:0;z-index:10;}
.page-title{font-family:var(--head);font-weight:700;font-size:20px;letter-spacing:-0.5px;}
.page-breadcrumb{font-family:var(--mono);font-size:11px;color:var(--muted);}
.topbar-actions{margin-left:auto;display:flex;align-items:center;gap:10px;flex-wrap:wrap;}

/* ── CONTENT ────────────────────────────────────────────── */
.content{padding:28px 32px;}

/* ── BUTTONS ────────────────────────────────────────────── */
.btn{padding:9px 18px;border-radius:8px;font-size:13px;font-weight:500;cursor:pointer;border:none;transition:all .15s;display:inline-flex;align-items:center;gap:7px;text-decoration:none;}
.btn-primary{background:var(--accent);color:white;}
.btn-primary:hover{background:#d4401f;transform:translateY(-1px);box-shadow:0 4px 16px rgba(232,75,42,.35);}
.btn-ghost{background:transparent;color:var(--muted);border:1px solid var(--border);}
.btn-ghost:hover{background:var(--surface2);color:var(--text);}
.btn-danger{background:rgba(232,75,42,.1);color:var(--accent);border:1px solid rgba(232,75,42,.3);}
.btn-danger:hover{background:var(--accent);color:white;}
.btn-green{background:rgba(34,197,94,.1);color:var(--green);border:1px solid rgba(34,197,94,.3);}
.btn-green:hover{background:var(--green);color:white;}
.btn-sm{padding:6px 12px;font-size:12px;}
.w-full{width:100%;}

/* ── CARDS ──────────────────────────────────────────────── */
.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;margin-bottom:20px;}
.card-header{padding:16px 20px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:10px;}
.card-title{font-family:var(--head);font-weight:700;font-size:14px;letter-spacing:-0.3px;}
.card-actions{margin-left:auto;display:flex;gap:8px;align-items:center;}
.card-body{padding:20px;}

/* ── STATS ──────────────────────────────────────────────── */
.stats-row{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:28px;}
.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:20px;transition:border-color .2s,transform .2s;position:relative;overflow:hidden;}
.stat-card:hover{border-color:var(--accent);transform:translateY(-2px);}
.stat-card::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:var(--accent);opacity:0;transition:opacity .2s;}
.stat-card:hover::before{opacity:1;}
.stat-label{font-family:var(--mono);font-size:10px;color:var(--muted);letter-spacing:2px;text-transform:uppercase;margin-bottom:12px;}
.stat-value{font-family:var(--head);font-size:32px;font-weight:800;letter-spacing:-1px;line-height:1;margin-bottom:8px;}
.stat-sub{font-size:12px;color:var(--muted);display:flex;align-items:center;gap:5px;}
.stat-dot{width:6px;height:6px;border-radius:50%;}

/* ── TABLES ─────────────────────────────────────────────── */
.data-table{width:100%;border-collapse:collapse;}
.data-table th{font-family:var(--mono);font-size:10px;letter-spacing:1.5px;text-transform:uppercase;color:var(--muted);text-align:left;padding:0 16px 12px;font-weight:400;}
.data-table td{padding:12px 16px;font-size:13px;border-top:1px solid var(--border);vertical-align:middle;}
.data-table tr:hover td{background:rgba(255,255,255,.02);}
.data-table th:first-child,.data-table td:first-child{padding-left:20px;}

/* ── BADGES ─────────────────────────────────────────────── */
.badge{display:inline-flex;align-items:center;gap:5px;padding:4px 10px;border-radius:20px;font-family:var(--mono);font-size:10px;letter-spacing:.5px;font-weight:500;text-transform:uppercase;}
.badge-dot{width:5px;height:5px;border-radius:50%;background:currentColor;}
.badge-active{background:rgba(34,197,94,.12);color:var(--green);}
.badge-pending{background:rgba(245,197,66,.12);color:var(--gold);}
.badge-review{background:rgba(59,130,246,.12);color:var(--blue);}
.badge-complete{background:rgba(107,114,128,.12);color:var(--muted);}
.badge-cancelled{background:rgba(232,75,42,.12);color:var(--accent);}
.badge-draft{background:rgba(107,114,128,.12);color:var(--muted);}
.badge-submitted{background:rgba(59,130,246,.12);color:var(--blue);}
.badge-approved{background:rgba(34,197,94,.12);color:var(--green);}
.badge-admin{background:rgba(232,75,42,.12);color:var(--accent);}

/* ── PRIORITY ────────────────────────────────────────────── */
.priority-tag{display:inline-flex;padding:3px 8px;border-radius:4px;font-family:var(--mono);font-size:10px;letter-spacing:.5px;border:1px solid var(--border);color:var(--muted);text-transform:uppercase;}
.priority-high{border-color:rgba(232,75,42,.4);color:var(--accent);}
.priority-medium{border-color:rgba(245,197,66,.4);color:var(--gold);}
.priority-low{border-color:var(--border);color:var(--muted);}

/* ── PROGRESS ────────────────────────────────────────────── */
.progress-bar{height:4px;background:var(--border);border-radius:2px;overflow:hidden;}
.progress-fill{height:100%;border-radius:2px;background:var(--accent);transition:width .7s ease;}
.progress-fill.green{background:var(--green);}
.progress-fill.blue{background:var(--blue);}
.progress-fill.gold{background:var(--gold);}

/* ── FORMS ──────────────────────────────────────────────── */
.form-group{margin-bottom:18px;}
.form-label{display:block;font-family:var(--mono);font-size:11px;letter-spacing:1px;text-transform:uppercase;color:var(--muted);margin-bottom:8px;}
.form-control{width:100%;padding:10px 14px;background:var(--surface2);border:1px solid var(--border);border-radius:8px;color:var(--text);font-size:14px;transition:border-color .15s;}
.form-control:focus{outline:none;border-color:var(--accent);}
.form-control::placeholder{color:var(--muted);}
select.form-control option{background:var(--surface2);}
textarea.form-control{resize:vertical;min-height:100px;}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;}
.form-row-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:16px;}
.form-hint{font-size:11px;color:var(--muted);margin-top:5px;}

/* ── ALERTS ─────────────────────────────────────────────── */
.alert{padding:12px 16px;border-radius:8px;font-size:13px;margin-bottom:16px;display:flex;align-items:center;gap:10px;}
.alert-success{background:rgba(34,197,94,.1);border:1px solid rgba(34,197,94,.3);color:var(--green);}
.alert-error{background:rgba(232,75,42,.1);border:1px solid rgba(232,75,42,.3);color:var(--accent);}
.alert-info{background:rgba(59,130,246,.1);border:1px solid rgba(59,130,246,.3);color:var(--blue);}

/* ── GRIDS ──────────────────────────────────────────────── */
.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:16px;}
.grid-main-side{display:grid;grid-template-columns:2fr 1fr;gap:20px;}

/* ── JOB CARDS ──────────────────────────────────────────── */
.job-card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px;}
.job-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:20px;cursor:pointer;transition:border-color .15s,transform .15s;text-decoration:none;color:var(--text);display:block;overflow:hidden;}
.job-card:hover{border-color:var(--accent);transform:translateY(-2px);}
.job-card-num{font-family:var(--mono);font-size:10px;color:var(--muted);letter-spacing:1.5px;margin-bottom:6px;}
.job-card-name{font-family:var(--head);font-weight:700;font-size:16px;margin-bottom:4px;letter-spacing:-0.3px;}
.job-card-client{font-size:12px;color:var(--muted);margin-bottom:6px;}
.job-card-addr{font-size:11px;color:var(--muted);margin-bottom:10px;}
.job-card-meta{display:flex;align-items:center;gap:6px;flex-wrap:wrap;margin-bottom:12px;}
.job-card-divider{border:none;border-top:1px solid var(--border);margin:12px 0;}
.job-card-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;}
.job-stat{text-align:center;}
.job-stat-val{font-family:var(--head);font-size:16px;font-weight:700;}
.job-stat-label{font-family:var(--mono);font-size:9px;color:var(--muted);text-transform:uppercase;letter-spacing:1px;margin-top:2px;}

/* ── PHOTOS ─────────────────────────────────────────────── */
.photo-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:10px;}
.photo-thumb{border-radius:8px;border:1px solid var(--border);overflow:hidden;position:relative;cursor:pointer;transition:border-color .15s;aspect-ratio:1;}
.photo-thumb:hover{border-color:var(--accent);}
.photo-thumb img{width:100%;height:100%;object-fit:cover;}
.photo-thumb .overlay{position:absolute;inset:0;background:rgba(0,0,0,.6);opacity:0;transition:opacity .2s;display:flex;align-items:center;justify-content:center;gap:8px;}
.photo-thumb:hover .overlay{opacity:1;}
.photo-upload-box{border:2px dashed var(--border);border-radius:8px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;cursor:pointer;transition:all .15s;padding:32px;text-align:center;color:var(--muted);}
.photo-upload-box:hover{border-color:var(--accent);color:var(--accent);background:rgba(232,75,42,.04);}
.photo-timeline-date{font-family:var(--mono);font-size:11px;color:var(--muted);letter-spacing:1px;text-transform:uppercase;margin:20px 0 10px;padding-bottom:6px;border-bottom:1px solid var(--border);}
.photo-timeline-date:first-child{margin-top:0;}

/* ── WIRE TABLE ─────────────────────────────────────────── */
.wire-table-wrap{overflow-x:auto;}
.wire-table{width:100%;border-collapse:collapse;font-family:var(--mono);font-size:12px;table-layout:fixed;}
.wire-table th{background:var(--surface2);padding:8px 10px;text-align:left;font-size:10px;letter-spacing:1.5px;text-transform:uppercase;color:var(--muted);font-weight:400;border-bottom:1px solid var(--border);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.wire-table td{padding:6px 8px;border-bottom:1px solid var(--border);vertical-align:middle;overflow:hidden;}
.wire-table textarea{background:transparent;border:1px solid transparent;border-radius:4px;color:var(--text);padding:4px 8px;width:100%;font-family:var(--mono);font-size:12px;resize:none;overflow:hidden;line-height:1.4;}
.wire-table textarea:focus{outline:none;border-color:var(--accent);background:var(--surface2);}
.wire-table tr:hover td{background:rgba(255,255,255,.02);}
.wire-table input[type=text],.wire-table input[type=number]{background:transparent;border:1px solid transparent;border-radius:4px;color:var(--text);padding:4px 6px;width:100%;font-family:var(--mono);font-size:12px;box-sizing:border-box;}
.wire-table input:focus{outline:none;border-color:var(--accent);background:var(--surface2);}
.wire-table .check-cell{text-align:center;}
.wire-table input[type=checkbox]{width:16px;height:16px;cursor:pointer;accent-color:var(--accent);}

/* ── VAULT ──────────────────────────────────────────────── */
.vault-item{display:flex;align-items:center;gap:14px;padding:14px;background:var(--surface2);border-radius:8px;border:1px solid transparent;transition:border-color .15s;margin-bottom:8px;}
.vault-item:hover{border-color:var(--border);}
.vault-icon-wrap{width:36px;height:36px;border-radius:8px;background:rgba(232,75,42,.1);border:1px solid rgba(232,75,42,.2);display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0;}
.vault-masked{font-family:var(--mono);font-size:13px;letter-spacing:3px;color:var(--muted);}
.vault-copy-btn{background:transparent;border:1px solid var(--border);border-radius:6px;color:var(--muted);padding:4px 10px;font-size:11px;cursor:pointer;transition:all .15s;font-family:var(--mono);}
.vault-copy-btn:hover{background:var(--accent);color:white;border-color:var(--accent);}
.vault-copy-btn.copied{background:var(--green);color:white;border-color:var(--green);}

/* ── ACTIVITY ────────────────────────────────────────────── */
.activity-item{display:flex;gap:12px;padding:14px 0;border-bottom:1px solid var(--border);}
.activity-item:last-child{border-bottom:none;}
.activity-dot{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:12px;}
.activity-text{flex:1;}
.activity-main{font-size:13px;line-height:1.4;}
.activity-time{font-family:var(--mono);font-size:10px;color:var(--muted);margin-top:3px;}

/* ── MODAL ──────────────────────────────────────────────── */
.modal-backdrop{position:fixed;inset:0;background:rgba(0,0,0,.7);z-index:100;display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .2s;}
.modal-backdrop.open{opacity:1;pointer-events:all;}
.modal{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);width:100%;max-width:560px;max-height:90vh;overflow-y:auto;transform:translateY(16px);transition:transform .2s;}
.modal-backdrop.open .modal{transform:translateY(0);}
.modal-header{padding:20px 24px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;}
.modal-title{font-family:var(--head);font-weight:700;font-size:16px;}
.modal-body{padding:24px;}
.modal-close{background:none;border:none;color:var(--muted);cursor:pointer;font-size:20px;padding:4px;}
.modal-close:hover{color:var(--text);}
.modal-footer{padding:16px 24px;border-top:1px solid var(--border);display:flex;gap:10px;justify-content:flex-end;}

/* ── PERMISSION MATRIX ───────────────────────────────────── */
.perm-table{width:100%;border-collapse:collapse;font-size:12px;}
.perm-table th{font-family:var(--mono);font-size:9px;letter-spacing:1px;text-transform:uppercase;color:var(--muted);padding:8px 10px;text-align:center;border-bottom:1px solid var(--border);white-space:nowrap;}
.perm-table th:first-child{text-align:left;}
.perm-table td{padding:8px 10px;border-bottom:1px solid var(--border);text-align:center;vertical-align:middle;}
.perm-table td:first-child{text-align:left;font-weight:500;font-size:12px;}
.perm-table tr:hover td{background:rgba(255,255,255,.02);}
.perm-table .perm-section td{background:var(--surface2);font-family:var(--mono);font-size:10px;color:var(--muted);letter-spacing:2px;text-transform:uppercase;padding:6px 10px;}
.perm-check{color:var(--green);font-size:14px;}
.perm-cross{color:var(--border);font-size:14px;}

/* ── MISC ───────────────────────────────────────────────── */
.tag{display:inline-flex;padding:3px 8px;border-radius:4px;font-family:var(--mono);font-size:10px;letter-spacing:.5px;border:1px solid var(--border);color:var(--muted);text-transform:uppercase;}
.divider{height:1px;background:var(--border);margin:12px 0;}
.empty-state{text-align:center;padding:48px 24px;color:var(--muted);}
.empty-state .empty-icon{font-size:40px;margin-bottom:12px;}
.empty-state h3{font-family:var(--head);font-size:16px;color:var(--text);margin-bottom:6px;}
.empty-state p{font-size:13px;}
.text-muted{color:var(--muted);}
.text-accent{color:var(--accent);}
.mt-4{margin-top:16px;}.mb-4{margin-bottom:16px;}
.pdf-viewer-frame{width:100%;height:80vh;border:none;border-radius:var(--radius);background:var(--surface2);}

/* ── SCROLLBAR ───────────────────────────────────────────── */
::-webkit-scrollbar{width:4px;height:4px;}
::-webkit-scrollbar-track{background:transparent;}
::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px;}
::-webkit-scrollbar-thumb:hover{background:var(--muted);}

/* ── MOBILE ─────────────────────────────────────────────── */
@media(max-width:768px){
  .mobile-topbar{display:flex;}
  .app-layout{padding-top:56px;}
  .sidebar{
    position:fixed;top:0;left:0;bottom:0;
    z-index:150;
    transform:translateX(-100%);
    transition:transform .3s ease;
    width:280px;
    min-width:280px;
  }
  .sidebar.open{transform:translateX(0);}
  .sidebar-overlay.open{display:block;}
  .main{height:auto;overflow-y:visible;}
  .content{padding:16px;}
  .topbar{padding:16px;flex-wrap:wrap;gap:10px;}
  .stats-row{grid-template-columns:1fr 1fr;}
  .grid-2,.grid-3,.grid-4,.grid-main-side{grid-template-columns:1fr;}
  .job-card-grid{grid-template-columns:1fr;}
  .form-row,.form-row-3{grid-template-columns:1fr;}
  .data-table{font-size:12px;}
  .data-table th,.data-table td{padding:8px 10px;}
  .perm-table th,.perm-table td{padding:5px 4px;font-size:10px;}
}


/* ── MOBILE ENHANCEMENTS ─────────────────────────────────── */
@media(max-width:768px){
  .wire-table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch;}
  .wire-table{min-width:700px;}
  .grid-4{grid-template-columns:1fr 1fr;}
  .modal{margin:8px;max-width:calc(100vw - 16px)!important;}
  #report-editor{padding:16px!important;font-size:13px!important;}
  .ctrl-inner{gap:6px;}
  .tog-btn{font-size:11px;padding:4px 8px;}
  .page-title{font-size:18px;}
}
@media(max-width:480px){
  .grid-4{grid-template-columns:1fr;}
  .stats-row{grid-template-columns:1fr 1fr;}
}

/* ── LIGHT THEME ─────────────────────────────────────────── */
[data-theme="light"] {
  --bg:#f0f2f5; --surface:#ffffff; --surface2:#f8f9fa; --border:#dee2e6;
  --text:#1a1d23; --muted:#6c757d; --accent:#e84b2a; --accent2:#f97316;
  --green:#198754; --blue:#0d6efd; --gold:#d4a017;
}
[data-theme="light"] .sidebar { background:#ffffff; border-color:#dee2e6; }
[data-theme="light"] .nav-item { color:#6c757d; }
[data-theme="light"] .nav-item:hover { background:#f0f2f5; color:#1a1d23; }
[data-theme="light"] .nav-item.active { background:rgba(232,75,42,.08); color:var(--accent); }
[data-theme="light"] .topbar { background:#f8f9fa; border-color:#dee2e6; }
[data-theme="light"] .mobile-topbar { background:#ffffff; border-color:#dee2e6; }
[data-theme="light"] .stat-card { background:#ffffff; border-color:#dee2e6; }
[data-theme="light"] .card { background:#ffffff; border-color:#dee2e6; }
[data-theme="light"] .form-control { background:#f8f9fa; border-color:#dee2e6; color:#1a1d23; }
[data-theme="light"] .form-control:focus { border-color:var(--accent); background:#fff; }
[data-theme="light"] .btn-ghost { color:#6c757d; border-color:#dee2e6; }
[data-theme="light"] .btn-ghost:hover { background:#f0f2f5; color:#1a1d23; }
[data-theme="light"] .data-table td { border-color:#dee2e6; }
[data-theme="light"] .data-table tr:hover td { background:rgba(0,0,0,.02); }
[data-theme="light"] .wire-table th { background:#f8f9fa; }
[data-theme="light"] .wire-table td { border-color:#dee2e6; }
[data-theme="light"] .wire-table input[type=text],
[data-theme="light"] .wire-table input[type=number] { color:#1a1d23; }
[data-theme="light"] .vault-item { background:#f8f9fa; }
[data-theme="light"] .modal { background:#ffffff; border-color:#dee2e6; }
[data-theme="light"] .job-card { background:#ffffff; border-color:#dee2e6; }
[data-theme="light"] .alert-info { background:rgba(13,110,253,.08); border-color:rgba(13,110,253,.3); color:var(--blue); }
[data-theme="light"] .badge-complete { background:rgba(108,117,125,.1); color:#6c757d; }
[data-theme="light"] ::-webkit-scrollbar-thumb { background:#dee2e6; }
[data-theme="light"] body { background:var(--bg); color:var(--text); }

/* ── MOBILE ENHANCEMENTS ─────────────────────────── */
@media(max-width:768px){
  .wire-table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch;}
  .wire-table{min-width:700px;}
  .grid-4{grid-template-columns:1fr 1fr;}
  .modal{margin:8px;max-width:calc(100vw - 16px)!important;}
  .page-title{font-size:18px;}
}
@media(max-width:480px){
  .grid-4{grid-template-columns:1fr;}
}

/* Mobile enhancements */
@media(max-width:768px){
  .wire-table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch;}
  .wire-table{min-width:700px;}
  .grid-4{grid-template-columns:1fr 1fr;}
  .modal{margin:8px;max-width:calc(100vw - 16px)!important;}
}
@media(max-width:480px){.grid-4{grid-template-columns:1fr;}}
