:root{
  --bg:#0f172a; --panel:#1e293b; --panel2:#273449; --line:#334155;
  --txt:#e2e8f0; --muted:#94a3b8; --accent:#3b82f6; --accent2:#2563eb;
  --ok:#22c55e; --warn:#f59e0b; --bad:#ef4444; --chip:#0b1220;
}
*{box-sizing:border-box}
body{margin:0;font-family:Segoe UI,Roboto,Arial,sans-serif;background:var(--bg);color:var(--txt);font-size:14px}
button{cursor:pointer;font-family:inherit}
input,select,textarea{font-family:inherit;font-size:14px}
.hidden{display:none !important}

/* Login */
#login{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px}
.login-card{background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:32px;width:360px;max-width:100%}
.login-card h1{margin:0 0 4px;font-size:22px}
.login-card p{margin:0 0 20px;color:var(--muted);font-size:13px}

/* Header */
header{display:flex;align-items:center;gap:14px;padding:12px 18px;background:var(--panel);border-bottom:1px solid var(--line);position:sticky;top:0;z-index:5;flex-wrap:wrap}
header .brand{font-weight:700;font-size:17px;color:#fff}
header .spacer{flex:1}
header select{min-width:220px}
header .who{color:var(--muted);font-size:13px}

/* Tabs */
nav.tabs{display:flex;gap:6px;padding:10px 18px;background:var(--panel2);border-bottom:1px solid var(--line);flex-wrap:wrap}
nav.tabs button{background:transparent;border:1px solid transparent;color:var(--muted);padding:8px 16px;border-radius:8px;font-size:14px}
nav.tabs button.active{background:var(--accent);color:#fff}

main{padding:18px;max-width:1100px;margin:0 auto}
section.page{display:none}
section.page.active{display:block}

/* Form controls */
label{display:block;margin:10px 0 4px;color:var(--muted);font-size:13px}
input,select,textarea{width:100%;padding:10px;background:var(--chip);border:1px solid var(--line);border-radius:8px;color:var(--txt)}
input:disabled,select:disabled{opacity:.5}
textarea{resize:vertical;min-height:64px}
.btn{background:var(--accent);color:#fff;border:none;padding:11px 18px;border-radius:8px;font-size:14px;font-weight:600}
.btn:hover{background:var(--accent2)}
.btn.sec{background:var(--panel2);border:1px solid var(--line);color:var(--txt)}
.btn.sm{padding:6px 12px;font-size:13px}
.row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.row3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:12px}
.card{background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:18px;margin-bottom:16px}
.card h2{margin:0 0 14px;font-size:16px}

/* Dashboard cards */
.stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:12px}
.stat{background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:16px}
.stat .n{font-size:28px;font-weight:700}
.stat .l{color:var(--muted);font-size:13px;margin-top:2px}
.stat.ok .n{color:var(--ok)} .stat.warn .n{color:var(--warn)} .stat.bad .n{color:var(--bad)}

/* Table */
table{width:100%;border-collapse:collapse;font-size:13px}
th,td{text-align:left;padding:9px 10px;border-bottom:1px solid var(--line)}
th{color:var(--muted);font-weight:600;font-size:12px;text-transform:uppercase;letter-spacing:.3px}
tr:hover td{background:var(--panel2)}
.tableScroll{overflow:auto;border:1px solid var(--line);border-radius:12px}

/* Progress bar */
.bar{height:8px;background:var(--chip);border-radius:6px;overflow:hidden;min-width:90px}
.bar > i{display:block;height:100%;background:var(--accent)}
.badge{padding:3px 9px;border-radius:20px;font-size:12px;font-weight:600;white-space:nowrap}
.badge.b0{background:#3f3f46;color:#d4d4d8}        /* Başlamadı */
.badge.b1{background:rgba(245,158,11,.18);color:#fbbf24}  /* Devam */
.badge.b2{background:rgba(34,197,94,.18);color:#4ade80}   /* Tamamlandı */
.badge.late{background:rgba(239,68,68,.18);color:#f87171}

.msg{margin-top:10px;font-size:13px;min-height:18px}
.msg.err{color:var(--bad)} .msg.ok{color:var(--ok)}
.hint{color:var(--muted);font-size:12px;margin-top:4px}

/* Modal */
.modal-bg{position:fixed;inset:0;background:rgba(0,0,0,.6);display:flex;align-items:center;justify-content:center;padding:18px;z-index:20}
.modal{background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:22px;width:520px;max-width:100%;max-height:90vh;overflow:auto}
.modal h2{margin:0 0 6px}
.modal .sub{color:var(--muted);font-size:13px;margin-bottom:14px}
.modal-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:16px}
@media(max-width:640px){.row,.row3{grid-template-columns:1fr}}
