/* TendaSasa — Main Stylesheet — Dark + Light mode */
/* System fonts only — zero network requests */

:root {
    --navy:       #1a2332;
    --navy-l:     #243044;
    --border:     #2e3d52;
    --accent:     #9EB200;
    --accent-d:   #7a8c00;
    --accent-bg:  rgba(158,178,0,0.12);
    --danger:     #e53935;
    --success:    #43a047;
    --info:       #2196f3;
    --warning:    #f59e0b;
    --text:       #e8ecf0;
    --muted:      #8a9ab0;
    --bg:         #111827;
    --card:       #1a2332;
    --row:        #1e2d40;
    --row2:       #1a2738;
    --sw:         240px;
    --r:          7px;
    --font:       -apple-system, BlinkMacSystemFont, 'Segoe UI', system-ui, sans-serif;
    --mono:       'Consolas', 'Courier New', monospace;
    --shadow:     0 2px 10px rgba(0,0,0,0.35);
}

html.light, body.light {
    --navy:    #f0f4ff; --navy-l: #e4eaf8; --border: #c8d4e8;
    --accent:  #6d8c00; --accent-d: #557000; --accent-bg: rgba(109,140,0,0.1);
    --danger:  #c62828; --success: #2e7d32; --info: #1565c0; --warning: #e65100;
    --text:    #1a2332; --muted: #5a6a80;
    --bg:      #f5f7fc; --card: #ffffff; --row: #f0f4ff; --row2: #f8faff;
    --shadow:  0 2px 10px rgba(0,0,0,0.07);
}

/* Sidebar stays dark in light mode */
body.light .sidebar { background:#1a2332; border-right-color:#2e3d52; }
body.light .sidebar a, body.light .sidebar .drop-btn,
body.light .sidebar .sec-label { color:#8a9ab0; }
body.light .sidebar a:hover, body.light .sidebar .drop-btn:hover { background:#243044; color:#e8ecf0; }
body.light .sidebar a.on { color:#9EB200; background:rgba(158,178,0,0.15); }
body.light .sidebar-badge { background:#9EB200; color:#1a2332; }
body.light .sidebar-logo span { color:#9EB200; }
body.light .sidebar-logo small, body.light .sidebar-foot { color:#8a9ab0; }
body.light .sidebar-foot a { color:#e53935 !important; }
body.light .drop-list { background:rgba(0,0,0,0.2); }

*, *::before, *::after { box-sizing:border-box; }
html, body { margin:0; padding:0; background:var(--bg); color:var(--text); font-family:var(--font); font-size:14px; line-height:1.6; min-height:100vh; }

/* ── SIDEBAR ─────────────────────── */
.sidebar {
    position:fixed; top:0; left:0; width:var(--sw); height:100vh;
    background:var(--navy); border-right:1px solid var(--border);
    display:flex; flex-direction:column; overflow-y:auto; z-index:100;
}
.sidebar-logo { padding:18px 20px 14px; border-bottom:1px solid var(--border); }
.sidebar-logo span { font-size:19px; font-weight:700; color:var(--accent); }
.sidebar-logo small { display:block; font-size:10px; color:var(--muted); font-family:var(--mono); letter-spacing:1px; text-transform:uppercase; margin-top:2px; }
.sidebar nav { flex:1; padding:6px 0; }
.sidebar a, .sidebar .drop-btn {
    display:flex; align-items:center; gap:9px; padding:9px 18px;
    color:var(--muted); text-decoration:none; font-size:13px; font-weight:500;
    transition:all 0.13s; border:none; background:none; width:100%;
    text-align:left; cursor:pointer; border-left:3px solid transparent;
}
.sidebar a:hover, .sidebar .drop-btn:hover { color:var(--text); background:var(--navy-l); border-left-color:var(--accent); }
.sidebar a.on { color:var(--accent); background:var(--accent-bg); border-left-color:var(--accent); }
.sec-label { padding:12px 18px 3px; font-size:10px; font-weight:600; letter-spacing:1.5px; text-transform:uppercase; color:var(--muted); font-family:var(--mono); }
.drop-list { display:none; background:rgba(0,0,0,0.12); }
.drop-list a { padding-left:34px; font-size:12.5px; }
.drop-list.open { display:block; }
.sidebar-badge { margin-left:auto; background:var(--accent); color:#111; font-size:10px; font-weight:700; padding:1px 7px; border-radius:20px; font-family:var(--mono); }
.sidebar-foot { padding:12px 18px; border-top:1px solid var(--border); font-size:12px; color:var(--muted); }
.sidebar-foot a { color:var(--danger) !important; font-size:12px; display:inline !important; background:none !important; border:none !important; padding:0 !important; }

/* Theme toggle */
.theme-btn {
    display:flex; align-items:center; gap:8px; padding:9px 18px;
    color:var(--muted); font-size:12px; font-family:var(--mono); cursor:pointer;
    border:none; background:none; width:100%; text-align:left;
    border-left:3px solid transparent; transition:all 0.13s;
}
.theme-btn:hover { color:var(--text); background:var(--navy-l); border-left-color:var(--accent); }
.t-track { width:30px; height:16px; background:var(--border); border-radius:20px; position:relative; margin-left:auto; transition:background 0.2s; flex-shrink:0; }
.t-track.on { background:var(--accent); }
.t-thumb { width:11px; height:11px; background:#fff; border-radius:50%; position:absolute; top:2.5px; left:2.5px; transition:transform 0.18s; }
.t-track.on .t-thumb { transform:translateX(14px); }

/* ── MAIN ────────────────────────── */
.main { margin-left:var(--sw); padding:26px 30px; min-height:100vh; }
.pg-header { display:flex; align-items:center; justify-content:space-between; margin-bottom:24px; padding-bottom:16px; border-bottom:1px solid var(--border); }
.pg-header h1 { margin:0; font-size:20px; font-weight:700; }
.pg-header h1 span { color:var(--accent); }

/* ── STATS GRID ──────────────────── */
.stats-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(150px,1fr)); gap:14px; margin-bottom:26px; }
.stat-card { background:var(--card); border:1px solid var(--border); border-radius:var(--r); padding:16px 18px; position:relative; overflow:hidden; box-shadow:var(--shadow); transition:border-color 0.15s; }
.stat-card::before { content:''; position:absolute; top:0; left:0; width:3px; height:100%; background:var(--accent); }
.stat-card.d::before { background:var(--danger); }
.stat-card.s::before { background:var(--success); }
.stat-card.i::before { background:var(--info); }
.stat-card:hover { border-color:var(--accent); }
.stat-lbl { font-size:10px; font-weight:600; letter-spacing:1px; text-transform:uppercase; color:var(--muted); font-family:var(--mono); }
.stat-num { font-size:30px; font-weight:700; color:var(--text); line-height:1.2; margin-top:5px; font-family:var(--mono); }
.stat-sub { font-size:11px; color:var(--muted); margin-top:3px; }

/* ── SOURCE GRID ─────────────────── */
.src-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(170px,1fr)); gap:12px; }
.src-card { background:var(--card); border:1px solid var(--border); border-radius:var(--r); padding:18px; text-align:center; text-decoration:none; transition:all 0.15s; display:block; box-shadow:var(--shadow); }
.src-card:hover { border-color:var(--accent); background:var(--navy-l); transform:translateY(-2px); }
.src-icon { font-size:24px; margin-bottom:8px; display:block; }
.src-name { font-size:13px; font-weight:600; color:var(--text); }
.src-cnt  { font-size:11px; color:var(--muted); font-family:var(--mono); margin-top:3px; }

/* ── SECTION HEADER ──────────────── */
.sec-head { font-size:11px; font-weight:700; color:var(--accent); font-family:var(--mono); letter-spacing:1px; text-transform:uppercase; padding:16px 0 8px; border-bottom:1px solid var(--border); margin-bottom:14px; }

/* ── FILTERS BAR ─────────────────── */
.filters { display:flex; align-items:center; gap:8px; flex-wrap:wrap; margin-bottom:14px; padding:12px 14px; background:var(--card); border:1px solid var(--border); border-radius:var(--r); }
.filters label { font-size:12px; color:var(--muted); font-family:var(--mono); }
.filters input[type=text], .filters input[type=date], .filters select {
    background:var(--bg); border:1px solid var(--border); color:var(--text);
    padding:6px 10px; border-radius:4px; font-size:13px; font-family:var(--font); outline:none;
}
.filters input:focus, .filters select:focus { border-color:var(--accent); }

/* ── BULK BAR ────────────────────── */
.bulk-bar { display:flex; align-items:center; gap:8px; margin-bottom:12px; }
.bulk-bar select { background:var(--bg); border:1px solid var(--border); color:var(--text); padding:6px 10px; border-radius:4px; font-size:13px; outline:none; }

/* ── PAGINATION ──────────────────── */
.pages { display:flex; align-items:center; gap:5px; margin-top:16px; flex-wrap:wrap; }
.pages a, .pages span { display:inline-flex; align-items:center; justify-content:center; width:32px; height:32px; border-radius:4px; font-size:12px; font-family:var(--mono); text-decoration:none; border:1px solid var(--border); color:var(--muted); background:var(--card); transition:all 0.13s; }
.pages a:hover { border-color:var(--accent); color:var(--accent); }
.pages span.cur { background:var(--accent); border-color:var(--accent); color:#111; font-weight:700; }
.pages .pg-info { width:auto; padding:0 10px; font-size:11px; color:var(--muted); border:none; background:none; }

/* ── TABLE ───────────────────────── */
.tbl-wrap { overflow-x:auto; }
.tbl { width:100%; border-collapse:collapse; font-size:13px; min-width:600px; }
.tbl thead tr { background:var(--navy-l); border-bottom:2px solid var(--accent); }
.tbl th { padding:10px 13px; text-align:left; font-size:10.5px; font-weight:600; letter-spacing:0.7px; text-transform:uppercase; color:var(--muted); font-family:var(--mono); white-space:nowrap; position:sticky; top:0; background:var(--navy-l); z-index:2; }
.tbl tbody tr { border-bottom:1px solid var(--border); transition:background 0.1s; }
.tbl tbody tr:hover { background:var(--row); }
.tbl tbody tr:nth-child(even) { background:var(--row2); }
.tbl tbody tr:nth-child(even):hover { background:var(--row); }
.tbl td { padding:9px 13px; color:var(--text); vertical-align:middle; max-width:280px; word-break:break-word; }
.tbl td.td-title { max-width:420px; }
.tbl td.td-title a { color:var(--accent); text-decoration:none; font-weight:500; }
.tbl td.td-title a:hover { text-decoration:underline; }
.tbl td a { color:var(--accent); text-decoration:none; font-weight:500; }
.tbl td a:hover { text-decoration:underline; }
.tbl input[type=checkbox] { accent-color:var(--accent); width:14px; height:14px; cursor:pointer; }

/* ── TABLE SECTION TITLE ─────────── */
.tbl-title { font-size:13px; font-weight:600; color:var(--text); font-family:var(--mono); margin:24px 0 10px; padding-bottom:7px; border-bottom:1px solid var(--border); display:flex; align-items:center; gap:7px; }
.tbl-title::before { content:''; display:inline-block; width:7px; height:7px; border-radius:50%; background:var(--accent); }

/* ── BADGES ──────────────────────── */
.badge { display:inline-block; padding:2px 9px; border-radius:20px; font-size:10.5px; font-weight:600; font-family:var(--mono); text-transform:uppercase; white-space:nowrap; }
.b-q { background:rgba(158,178,0,.13); color:#c6d600; border:1px solid rgba(158,178,0,.3); }
.b-a { background:rgba(33,150,243,.13); color:#64b5f6; border:1px solid rgba(33,150,243,.3); }
.b-w { background:rgba(67,160,71,.13); color:#81c784; border:1px solid rgba(67,160,71,.3); }
.b-l { background:rgba(229,57,53,.13); color:#ef9a9a; border:1px solid rgba(229,57,53,.3); }
.b-d { background:rgba(120,120,120,.1); color:#9e9e9e; border:1px solid rgba(120,120,120,.2); }
.b-warn { background:rgba(245,158,11,.1); color:#fbbf24; border:1px solid rgba(245,158,11,.3); }
body.light .b-q { color:#5a7a00; } body.light .b-a { color:#1565c0; }
body.light .b-w { color:#2e7d32; } body.light .b-l { color:#c62828; } body.light .b-warn { color:#b45309; }

/* ── BUTTONS ─────────────────────── */
.btn { display:inline-flex; align-items:center; gap:5px; padding:7px 13px; border-radius:4px; font-size:12px; font-weight:600; font-family:var(--font); cursor:pointer; border:none; transition:all 0.13s; text-decoration:none; white-space:nowrap; }
.btn-p  { background:var(--accent); color:#111; }
.btn-p:hover { background:var(--accent-d); }
.btn-d  { background:rgba(229,57,53,.12); color:#ef9a9a; border:1px solid rgba(229,57,53,.3); }
.btn-d:hover  { background:var(--danger); color:#fff; border-color:var(--danger); }
.btn-s  { background:rgba(67,160,71,.12); color:#81c784; border:1px solid rgba(67,160,71,.3); }
.btn-s:hover  { background:var(--success); color:#fff; border-color:var(--success); }
.btn-i  { background:rgba(33,150,243,.12); color:#64b5f6; border:1px solid rgba(33,150,243,.3); }
.btn-i:hover  { background:var(--info); color:#fff; border-color:var(--info); }
.btn-g  { background:transparent; color:var(--muted); border:1px solid var(--border); }
.btn-g:hover  { color:var(--text); border-color:var(--muted); }
.btn-sm { padding:4px 9px; font-size:11px; }
body.light .btn-d { color:#c62828; } body.light .btn-s { color:#2e7d32; } body.light .btn-i { color:#1565c0; }

/* ── ALERTS ──────────────────────── */
.alert { padding:10px 14px; border-radius:var(--r); font-size:13px; margin-bottom:14px; }
.alert-s { background:rgba(67,160,71,.1); color:#81c784; border:1px solid rgba(67,160,71,.3); }
.alert-d { background:rgba(229,57,53,.1); color:#ef9a9a; border:1px solid rgba(229,57,53,.3); }
.alert-i { background:rgba(33,150,243,.1); color:#64b5f6; border:1px solid rgba(33,150,243,.3); }
body.light .alert-s { color:#2e7d32; } body.light .alert-d { color:#c62828; } body.light .alert-i { color:#1565c0; }

/* ── FORMS ───────────────────────── */
.form-g { margin-bottom:14px; }
.form-g label { display:block; font-size:11px; font-weight:600; color:var(--muted); font-family:var(--mono); letter-spacing:.5px; text-transform:uppercase; margin-bottom:5px; }
.form-g input, .form-g select, .form-g textarea { width:100%; background:var(--bg); border:1px solid var(--border); color:var(--text); padding:9px 12px; border-radius:4px; font-size:14px; font-family:var(--font); outline:none; }
.form-g input:focus, .form-g select:focus, .form-g textarea:focus { border-color:var(--accent); }

/* ── EMPTY STATE ─────────────────── */
.empty { text-align:center; padding:50px 20px; color:var(--muted); }
.empty .ei { font-size:44px; margin-bottom:14px; display:block; }
.empty h3 { color:var(--text); margin:0 0 6px; font-size:15px; }
.empty p { font-size:13px; margin:0; }

/* ── KEYPHRASES ──────────────────── */
.kp-tag { display:inline-flex; align-items:center; gap:5px; background:var(--accent-bg); border:1px solid rgba(158,178,0,.3); color:var(--accent); padding:3px 10px; border-radius:20px; font-size:11.5px; font-family:var(--mono); margin:3px; }
.kp-tag button { background:none; border:none; color:var(--accent); cursor:pointer; padding:0; font-size:13px; line-height:1; opacity:.6; }
.kp-tag button:hover { opacity:1; color:var(--danger); }

/* ── NO TENDERS ──────────────────── */
.no-data { color:var(--muted); font-size:13px; padding:14px; text-align:center; background:var(--card); border:1px dashed var(--border); border-radius:var(--r); }

/* ── LOGIN ───────────────────────── */
.login-wrap { min-height:100vh; display:flex; align-items:center; justify-content:center; background:var(--bg); }
.login-box { width:360px; background:var(--card); border:1px solid var(--border); border-radius:10px; padding:36px; box-shadow:var(--shadow); }
.login-logo { text-align:center; margin-bottom:28px; }
.login-logo h1 { font-size:26px; font-weight:700; color:var(--accent); margin:0; }
.login-logo p { font-size:11px; color:var(--muted); font-family:var(--mono); letter-spacing:1px; margin:3px 0 0; }

/* ── UTILS ───────────────────────── */
.txt-m  { color:var(--muted); }
.txt-a  { color:var(--accent); }
.mono   { font-family:var(--mono); }
.ml-a   { margin-left:auto; }
.flex   { display:flex; align-items:center; }
.gap-2  { gap:8px; }
