* {
    box-sizing:border-box;
    margin:0;
    padding:0;
}

html,body {
    background:#f5f5f2;
    color:#1a1a1a;
    font-family:system-ui,-apple-system,sans-serif;
    min-height:100vh;
}

html.dark,html.dark body {
    background:#0f0f0f;
    color:#e8e8e8;
}

:root {
    --bg:#ffffff;
    --bg2:#f5f5f2;
    --bg3:#ebebeb;
    --border:rgba(0,0,0,.1);
    --border2:rgba(0,0,0,.18);
    --txt:#1a1a1a;
    --txt2:#555;
    --txt3:#999;
    --accent:#2563eb;
    --accent-bg:#dbeafe;
    --accent-txt:#1d4ed8;
    --sidebar-bg:#ffffff;
    --topbar-bg:#ffffff;
    --hover:#f0f0ed;
    --success-bg:#dcfce7;
    --success-txt:#166534;
    --warn-bg:#fef3c7;
    --warn-txt:#92400e;
    --danger-bg:#fee2e2;
    --danger-txt:#991b1b;
    --gray-bg:#f0f0ed;
    --gray-txt:#555;
    --row-hover:#fafaf8;
    --mov-bg:#fffbeb;
    --mov-border:#fde68a;
}

html.dark {
    --bg:#1c1c1e;
    --bg2:#111;
    --bg3:#252525;
    --border:rgba(255,255,255,.09);
    --border2:rgba(255,255,255,.18);
    --txt:#e8e8e8;
    --txt2:#aaa;
    --txt3:#666;
    --sidebar-bg:#161618;
    --topbar-bg:#1c1c1e;
    --hover:#2a2a2d;
    --success-bg:#14532d;
    --success-txt:#86efac;
    --warn-bg:#451a03;
    --warn-txt:#fbbf24;
    --danger-bg:#450a0a;
    --danger-txt:#f87171;
    --gray-bg:#2a2a2d;
    --gray-txt:#aaa;
    --row-hover:#212124;
    --accent-bg:#1e3a8a;
    --accent-txt:#93c5fd;
    --mov-bg:#2a2200;
    --mov-border:#92400e;
}

.app {
    display:flex;
    height:100vh;
    overflow:hidden;
}

.sidebar {
    width:210px;
    background:var(--sidebar-bg);
    border-right:1px solid var(--border);
    display:flex;
    flex-direction:column;
    flex-shrink:0;
    transition:background .2s;
}

.sidebar-logo {
    padding:1rem 1.25rem;
    font-size:15px;
    font-weight:600;
    letter-spacing:-.3px;
    border-bottom:1px solid var(--border);
    display:flex;
    align-items:center;
    gap:8px;
    color:var(--txt);
}

.sidebar-logo .logo-icon {
    width:28px;
    height:28px;
    background:var(--accent);
    border-radius:7px;
    display:flex;
    align-items:center;
    justify-content:center;
    color:#fff;
    font-size:15px;
}

.nav-group {
    padding:8px 0;
}

.nav-label {
    padding:4px 1.25rem;
    font-size:10.5px;
    font-weight:600;
    color:var(--txt3);
    text-transform:uppercase;
    letter-spacing:.08em;
}

.nav-item {
    display:flex;
    align-items:center;
    gap:9px;
    padding:7px 1rem;
    margin:1px .5rem;
    border-radius:7px;
    font-size:13.5px;
    color:var(--txt2);
    cursor:pointer;
    transition:background .12s,color .12s;
}

.nav-item i {
    font-size:17px;
    flex-shrink:0;
}

.nav-item:hover {
    background:var(--hover);
    color:var(--txt);
}

.nav-item.active {
    background:var(--accent-bg);
    color:var(--accent-txt);
    font-weight:500;
}

.sidebar-footer {
    margin-top:auto;
    padding:.75rem .5rem;
    border-top:1px solid var(--border);
}

.dark-toggle {
    display:flex;
    align-items:center;
    justify-content:space-between;
    padding:7px 1rem;
    border-radius:7px;
    cursor:pointer;
    font-size:13px;
    color:var(--txt2);
}

.dark-toggle:hover {
    background:var(--hover);
}

.toggle-track {
    width:36px;
    height:20px;
    border-radius:10px;
    background:var(--border2);
    position:relative;
    transition:background .2s;
    flex-shrink:0;
}

html.dark .toggle-track {
    background:var(--accent);
}

.toggle-thumb {
    width:16px;
    height:16px;
    border-radius:50%;
    background:#fff;
    position:absolute;
    top:2px;
    left:2px;
    transition:transform .2s;
    box-shadow:0 1px 3px rgba(0,0,0,.3);
}

html.dark .toggle-thumb {
    transform:translateX(16px);
}

.main {
    flex:1;
    display:flex;
    flex-direction:column;
    overflow:hidden;
    background:var(--bg2);
}

.topbar {
    background:var(--topbar-bg);
    border-bottom:1px solid var(--border);
    padding:0 1.25rem;
    height:52px;
    display:flex;
    align-items:center;
    justify-content:space-between;
    flex-shrink:0;
}

.topbar-title {
    font-size:15px;
    font-weight:600;
    color:var(--txt);
    letter-spacing:-.2px;
}

.topbar-actions {
    display:flex;
    gap:6px;
    align-items:center;
}

.btn {
    display:inline-flex;
    align-items:center;
    gap:5px;
    padding:6px 13px;
    border-radius:7px;
    font-size:13px;
    font-weight:500;
    cursor:pointer;
    border:1px solid var(--border2);
    background:var(--bg);
    color:var(--txt);
    transition:background .12s;
    white-space:nowrap;
}

.btn:hover {
    background:var(--hover);
}

.btn-primary {
    background:var(--accent);
    border-color:var(--accent);
    color:#fff;
}

.btn-primary:hover {
    background:#1d4ed8;
}

.btn-success {
    background:#059669;
    border-color:#059669;
    color:#fff;
}

.btn-success:hover {
    background:#047857;
}

.btn-warn {
    background:#d97706;
    border-color:#d97706;
    color:#fff;
}

.btn-warn:hover {
    background:#b45309;
}

.btn-sm {
    padding:4px 10px;
    font-size:12px;
}

.btn-ghost {
    border-color:transparent;
    background:transparent;
    color:var(--txt2);
}

.btn-ghost:hover {
    background:var(--hover);
    border-color:var(--border);
}

.content {
    flex:1;
    overflow-y:auto;
    padding:1.25rem;
}

.page {
    display:none;
}

.page.active {
    display:block;
}

.card {
    background:var(--bg);
    border:1px solid var(--border);
    border-radius:12px;
}

.card-header {
    padding:.85rem 1.25rem;
    border-bottom:1px solid var(--border);
    display:flex;
    align-items:center;
    justify-content:space-between;
}

.card-title {
    font-size:13.5px;
    font-weight:600;
    color:var(--txt);
}

.stats-row {
    display:grid;
    grid-template-columns:repeat(4,1fr);
    gap:10px;
    margin-bottom:1.25rem;
}

.stat {
    background:var(--bg);
    border:1px solid var(--border);
    border-radius:12px;
    padding:1rem 1.25rem;
}

.stat-label {
    font-size:11.5px;
    color:var(--txt3);
    margin-bottom:3px;
    font-weight:500;
}

.stat-val {
    font-size:26px;
    font-weight:600;
    letter-spacing:-.5px;
    color:var(--txt);
}

.stat-sub {
    font-size:11px;
    color:var(--txt3);
    margin-top:1px;
}

.table-wrap {
    overflow-x:auto;
}

table {
    width:100%;
    border-collapse:collapse;
    font-size:13px;
}

th {
    padding:9px 1rem;
    text-align:left;
    font-size:11px;
    font-weight:600;
    color:var(--txt3);
    text-transform:uppercase;
    letter-spacing:.07em;
    border-bottom:1px solid var(--border);
    background:var(--bg2);
}

td {
    padding:9px 1rem;
    border-bottom:1px solid var(--border);
    color:var(--txt);
    vertical-align:middle;
}

tr:last-child td {
    border-bottom:none;
}

tbody tr:hover td {
    background:var(--row-hover);
}

.badge {
    display:inline-flex;
    align-items:center;
    padding:2px 8px;
    border-radius:20px;
    font-size:11.5px;
    font-weight:500;
}

.b-success {
    background:var(--success-bg);
    color:var(--success-txt);
}

.b-warn {
    background:var(--warn-bg);
    color:var(--warn-txt);
}

.b-gray {
    background:var(--gray-bg);
    color:var(--gray-txt);
}

.cat-pill {
    display:inline-flex;
    align-items:center;
    padding:2px 7px;
    border-radius:20px;
    font-size:11px;
    font-weight:500;
    margin:1px;
}

.filter-bar {
    display:flex;
    gap:8px;
    margin-bottom:1rem;
    flex-wrap:wrap;
    align-items:center;
}

.f-input {
    padding:7px 10px;
    border-radius:7px;
    border:1px solid var(--border2);
    background:var(--bg);
    color:var(--txt);
    font-size:13px;
    font-family:inherit;
}

.f-input:focus {
    outline:none;
    border-color:var(--accent);
    box-shadow:0 0 0 3px rgba(37,99,235,.15);
}

.form-grid {
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:1rem;
}

.fg {
    display:flex;
    flex-direction:column;
    gap:5px;
}

.fg.full {
    grid-column:1/-1;
}

.flabel {
    font-size:12.5px;
    font-weight:500;
    color:var(--txt2);
}

.flabel .req {
    color:#dc2626;
    margin-left:2px;
}

.finput {
    padding:8px 10px;
    border-radius:7px;
    border:1px solid var(--border2);
    background:var(--bg);
    color:var(--txt);
    font-size:13.5px;
    font-family:inherit;
    transition:border-color .12s;
}

.finput:focus {
    outline:none;
    border-color:var(--accent);
    box-shadow:0 0 0 3px rgba(37,99,235,.15);
}

html.dark input[type="date"]::-webkit-calendar-picker-indicator {
    filter:invert(1);
    opacity:.7;
}

html.dark input[type="date"]::-webkit-calendar-picker-indicator:hover {
    opacity:1;
}

.ms-wrap {
    border:1px solid var(--border2);
    border-radius:7px;
    background:var(--bg);
    min-height:38px;
    padding:3px;
    display:flex;
    flex-wrap:wrap;
    gap:3px;
    cursor:pointer;
    transition:border-color .12s;
    position:relative;
}

.ms-wrap:focus-within {
    border-color:var(--accent);
    box-shadow:0 0 0 3px rgba(37,99,235,.15);
}

.chip {
    display:inline-flex;
    align-items:center;
    gap:4px;
    background:var(--accent-bg);
    color:var(--accent-txt);
    padding:2px 8px;
    border-radius:20px;
    font-size:12px;
    font-weight:500;
}

.chip-x {
    cursor:pointer;
    font-size:15px;
    line-height:1;
    opacity:.65;
}

.chip-x:hover {
    opacity:1;
}

.ms-placeholder {
    font-size:13px;
    color:var(--txt3);
    padding:3px 5px;
    pointer-events:none;
    align-self:center;
}

.ms-dropdown {
    position:absolute;
    top:calc(100% + 4px);
    left:0;
    right:0;
    background:var(--bg);
    border:1px solid var(--border2);
    border-radius:8px;
    z-index:200;
    max-height:180px;
    overflow-y:auto;
    box-shadow:0 8px 24px rgba(0,0,0,.12);
    display:none;
}

html.dark .ms-dropdown {
    box-shadow:0 8px 24px rgba(0,0,0,.4);
}

.ms-dropdown.open {
    display:block;
}

.ms-opt {
    padding:8px 12px;
    font-size:13px;
    cursor:pointer;
    display:flex;
    align-items:center;
    gap:8px;
    color:var(--txt);
}

.ms-opt:hover {
    background:var(--hover);
}

.ms-opt.sel {
    background:var(--accent-bg);
    color:var(--accent-txt);
}

.ms-opt input {
    accent-color:var(--accent);
    pointer-events:none;
}

.scard {
    background:var(--bg);
    border:1px solid var(--border);
    border-radius:12px;
    padding:1.25rem;
    margin-bottom:1rem;
}

.scard-title {
    font-size:13px;
    font-weight:600;
    color:var(--txt2);
    margin-bottom:1rem;
    padding-bottom:.75rem;
    border-bottom:1px solid var(--border);
    display:flex;
    align-items:center;
    gap:7px;
    flex-wrap:wrap;
}

.mov-card {
    background:var(--mov-bg);
    border:1.5px solid var(--mov-border);
    border-radius:12px;
    padding:1.25rem;
    margin-bottom:1rem;
}

.mov-card .scard-title {
    border-bottom-color:var(--mov-border);
    color:#92400e;
}

html.dark .mov-card .scard-title {
    color:#fbbf24;
}

.hist-card {
    background:var(--bg);
    border:1px solid var(--border);
    border-radius:12px;
    padding:1.25rem;
    margin-bottom:1rem;
}

.hist-card-title {
    font-size:13px;
    font-weight:600;
    color:var(--txt2);
    margin-bottom:.75rem;
    display:flex;
    align-items:center;
    gap:7px;
}

.hist-item {
    border-left:3px solid var(--accent);
    padding:.6rem .8rem;
    margin-bottom:.5rem;
    background:var(--bg2);
    border-radius:0 6px 6px 0;
    font-size:12.5px;
}

.hist-item:last-child {
    margin-bottom:0;
}

.hist-meta {
    font-size:11px;
    color:var(--txt3);
    margin-bottom:3px;
}

.hist-detail {
    color:var(--txt);
    line-height:1.6;
}

.tab-bar {
    display:flex;
    border-bottom:1px solid var(--border);
    margin-bottom:1.25rem;
}

.stab {
    padding:8px 16px;
    font-size:13px;
    cursor:pointer;
    border-bottom:2px solid transparent;
    color:var(--txt2);
    margin-bottom:-1px;
    font-weight:500;
}

.stab:hover {
    color:var(--txt);
}

.stab.active {
    color:var(--accent);
    border-bottom-color:var(--accent);
}

.tag-cloud {
    display:flex;
    flex-wrap:wrap;
    gap:6px;
    margin-bottom:.75rem;
}

.tag {
    display:inline-flex;
    align-items:center;
    gap:5px;
    padding:4px 10px;
    border-radius:20px;
    font-size:12.5px;
    font-weight:500;
    background:var(--bg3);
    color:var(--txt);
    border:1px solid var(--border);
}

.tag .tdel {
    cursor:pointer;
    color:var(--txt3);
    font-size:15px;
}

.tag .tdel:hover {
    color:#dc2626;
}

.add-row {
    display:flex;
    gap:7px;
    align-items:center;
    flex-wrap:wrap;
}

.field-row {
    display:flex;
    align-items:center;
    justify-content:space-between;
    padding:10px 0;
    border-bottom:1px solid var(--border);
}

.field-row:last-child {
    border-bottom:none;
}

.alert {
    padding:9px 14px;
    border-radius:8px;
    font-size:13px;
    margin-bottom:1rem;
    display:none;
    align-items:center;
    gap:8px;
}

.alert-ok {
    background:var(--success-bg);
    color:var(--success-txt);
}

.modal-overlay {
    position:fixed;
    inset:0;
    background:rgba(0,0,0,.45);
    z-index:500;
    display:flex;
    align-items:center;
    justify-content:center;
}

.modal {
    background:var(--bg);
    border:1px solid var(--border);
    border-radius:14px;
    padding:1.5rem;
    width:420px;
    box-shadow:0 20px 60px rgba(0,0,0,.2);
}

html.dark .modal {
    box-shadow:0 20px 60px rgba(0,0,0,.6);
}

.modal-title {
    font-size:16px;
    font-weight:600;
    margin-bottom:4px;
    color:var(--txt);
}

.modal-sub {
    font-size:13px;
    color:var(--txt2);
    margin-bottom:1.25rem;
}

.modal-opts {
    display:flex;
    flex-direction:column;
    gap:8px;
    margin-bottom:1.25rem;
}

.exp-opt {
    display:flex;
    align-items:center;
    gap:10px;
    padding:10px 12px;
    border:1px solid var(--border);
    border-radius:8px;
    cursor:pointer;
    transition:border-color .12s,background .12s;
}

.exp-opt:hover {
    border-color:var(--accent);
    background:var(--accent-bg);
}

.exp-opt input[type=radio] {
    accent-color:var(--accent);
}

.exp-opt-info {
    flex:1;
}

.exp-opt-label {
    font-size:13.5px;
    font-weight:500;
    color:var(--txt);
}

.exp-opt-desc {
    font-size:12px;
    color:var(--txt3);
    margin-top:1px;
}

.modal-footer {
    display:flex;
    gap:8px;
    justify-content:flex-end;
}

.actions-cell {
    display:flex;
    gap:4px;
}

.empty-row td {
    text-align:center;
    padding:2.5rem;
    color:var(--txt3);
}

.page-header {
    display:flex;
    align-items:center;
    justify-content:space-between;
    margin-bottom:1.25rem;
}

.ph-title {
    font-size:17px;
    font-weight:600;
    letter-spacing:-.3px;
    color:var(--txt);
}

