/* ============================================================
   SITOP – Main Stylesheet
   assets/css/style.css
============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Merriweather:wght@400;700;900&family=Source+Sans+3:wght@400;500;600;700&family=JetBrains+Mono:wght@400;600&display=swap');

:root {
  --navy:      #0C2340;
  --navy2:     #1A56A0;
  --blue:      #1A56A0;
  --blue-lt:   #2E7DD1;
  --gold:      #E8C04C;
  --logo-grad: linear-gradient(135deg, #2E7DD1 0%, #1A56A0 55%, #0C2340 100%);
  --red:       #C0392B;
  --green:     #1A7A4A;
  --amber:     #D4700A;
  --white:     #FFFFFF;
  --off:       #F5F7FA;
  --bg:        #EEF1F6;
  --text:      #1A2535;
  --muted:     #5A6A80;
  --border:    #D0D8E8;
  --sidebar-w: 230px;
  --header-h:  60px;
}

* { box-sizing: border-box; margin: 0; padding: 0; }
html, body { height: 100%; }
body { font-family: 'Source Sans 3', sans-serif; background: var(--bg); color: var(--text); font-size: 14px; }

/* ── LOGIN PAGE (white card style) ── */
.login-page  { min-height:100vh; display:flex; align-items:center; justify-content:center;
  background: var(--logo-grad); padding:24px; }

.login-card   { width:440px; max-width:100%; background:#fff; border-radius:24px;
  box-shadow:0 25px 60px rgba(0,0,0,.3); padding:40px 36px 32px; text-align:center; }
.login-emblem { width:84px; height:84px; margin:0 auto 18px; }
.login-title  { color:var(--navy); font-weight:800; font-size:26px; letter-spacing:.5px; margin-bottom:6px; }
.login-org    { color:var(--muted); font-size:13px; margin-bottom:26px; }

.login-card .alert { text-align:left; }

.login-field  { text-align:left; margin-bottom:18px; }
.login-field label { display:block; font-weight:700; font-size:13.5px; color:var(--text); margin-bottom:7px; }
.bordered-input { display:flex; align-items:center; border:1px solid var(--border); border-radius:10px;
  padding:0 14px; background:#fff; transition:.15s; }
.bordered-input:focus-within { border-color: var(--blue-lt); }
.bordered-input .field-icon { color:#9aa6b8; display:flex; align-items:center; flex-shrink:0; }
.bordered-input input { flex:1; border:none; outline:none; padding:13px 10px; font-size:14px;
  font-family:inherit; color:var(--text); min-width:0; }
.bordered-input input::placeholder { color:#aab4c4; }
.toggle-pw    { cursor:pointer; color:#9aa6b8; display:flex; align-items:center; flex-shrink:0; }

.btn-login    { width:100%; background:linear-gradient(135deg, #2E7DD1 0%, #1A56A0 100%); color:#fff; border:none; border-radius:10px;
  padding:14px; font-weight:700; font-size:15px; cursor:pointer; margin-top:6px; font-family:inherit;
  display:flex; align-items:center; justify-content:center; gap:8px; transition:.2s;
  box-shadow:0 6px 16px rgba(26,86,160,.35); }
.btn-login:hover { background:linear-gradient(135deg, #1A56A0 0%, #0C2340 100%); }

.login-footer { margin-top:22px; font-size:11.5px; color:#aab4c4; }

/* ── APP LAYOUT ── */
.app-header  { height:var(--header-h); background:linear-gradient(135deg, #1A56A0 0%, #0C2340 85%); display:flex; align-items:center;
  padding:0 20px; gap:14px; position:sticky; top:0; z-index:200; box-shadow:0 2px 8px rgba(0,0,0,.25); }
.app-body    { display:flex; height:calc(100vh - var(--header-h)); }
.sidebar     { width:var(--sidebar-w); background:var(--navy); flex-shrink:0; overflow-y:auto;
  border-right:1px solid rgba(255,255,255,.06); display:flex; flex-direction:column; }
.main        { flex:1; overflow-y:auto; }
.page        { padding:24px 28px; }

/* ── HEADER ELEMENTS ── */
.header-logo       { display:flex; align-items:center; gap:10px; text-decoration:none; }
.header-logo-icon  { width:34px; height:34px; flex-shrink:0; }
.header-logo-text  { font-family:'Merriweather',serif; font-size:16px; font-weight:600; letter-spacing:0.3px; color:#fff; }
.header-logo-sub   { font-size:9.5px; color:rgba(255,255,255,.5); text-transform:uppercase; letter-spacing:1px; }
.header-divider    { width:1px; height:28px; background:rgba(255,255,255,.15); }
.header-org        { font-size:12px; color:rgba(255,255,255,.6); }
.header-spacer     { flex:1; }
.header-user       { display:flex; align-items:center; gap:9px; }
.header-avatar     { width:32px; height:32px; border-radius:50%; background:var(--gold);
  display:flex; align-items:center; justify-content:center;
  font-size:13px; font-weight:700; color:var(--navy); }
.header-user-name  { font-size:13px; font-weight:600; color:#fff; }
.header-user-role  { font-size:10.5px; color:rgba(255,255,255,.5); }
.btn-logout        { padding:7px 14px; background:rgba(255,255,255,.1); border:1px solid rgba(255,255,255,.2);
  border-radius:7px; color:rgba(255,255,255,.8); font-size:12px; font-family:inherit;
  cursor:pointer; font-weight:600; text-decoration:none; transition:.2s; }
.btn-logout:hover  { background:rgba(200,50,50,.3); color:#fff; }

/* ── SIDEBAR NAV ── */
.nav-section-label { font-size:10px; font-weight:700; color:rgba(255,255,255,.3);
  letter-spacing:1.5px; text-transform:uppercase; padding:16px 16px 5px; }
.nav-item  { display:flex; align-items:center; gap:10px; padding:10px 16px; cursor:pointer; text-decoration:none;
  font-size:13px; font-weight:500; color:rgba(255,255,255,.6); transition:.15s;
  border-left:3px solid transparent; }
.nav-item:hover  { background:rgba(255,255,255,.06); color:#fff; }
.nav-item.active { background:rgba(255,255,255,.1); color:#fff; border-left-color:var(--gold); font-weight:700; }
.nav-icon  { font-size:15px; width:20px; text-align:center; }
.sidebar-footer { margin-top:auto; padding:12px 16px; border-top:1px solid rgba(255,255,255,.08);
  font-size:10.5px; color:rgba(255,255,255,.28); text-align:center; line-height:1.6; }

/* ── PAGE TITLES ── */
.page-title { font-family:'Merriweather',serif; font-size:22px; font-weight:700; color:var(--navy); margin-bottom:4px; }
.page-sub   { font-size:13px; color:var(--muted); margin-bottom:20px; }

/* ── STATS GRID ── */
.stats-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:14px; margin-bottom:18px; }
.stat-card  { background:#fff; border-radius:10px; border:1px solid var(--border);
  padding:16px 18px; border-top:3px solid transparent; box-shadow:0 1px 4px rgba(0,0,0,.06); transition:.2s; }
.stat-card:hover { box-shadow:0 4px 14px rgba(0,0,0,.1); transform:translateY(-2px); }
.stat-card.blue   { border-top-color:var(--blue); }
.stat-card.amber  { border-top-color:var(--amber); }
.stat-card.green  { border-top-color:var(--green); }
.stat-card.red    { border-top-color:var(--red); }
.stat-label { font-size:11px; font-weight:700; color:var(--muted); text-transform:uppercase; letter-spacing:.7px; margin-bottom:7px; }
.stat-value { font-family:'Merriweather',serif; font-size:32px; font-weight:700; color:var(--navy); line-height:1; }
.stat-sub   { font-size:11.5px; color:var(--muted); margin-top:5px; }

/* ── CARD ── */
.card       { background:#fff; border-radius:10px; border:1px solid var(--border); box-shadow:0 1px 4px rgba(0,0,0,.06); }
.card-head  { padding:13px 18px; border-bottom:1px solid var(--border); display:flex; align-items:center; gap:10px; }
.card-head h3 { font-size:14px; font-weight:700; color:var(--navy); flex:1; }
.card-body  { padding:18px; }
.card-body.p0 { padding:0; }
.mb-16 { margin-bottom:16px; }

/* ── TABLE ── */
.tbl-wrap { overflow-x:auto; }
table { width:100%; border-collapse:collapse; }
thead th { background:var(--off); padding:10px 14px; font-size:11.5px; font-weight:700;
  color:var(--navy); text-align:left; letter-spacing:.5px; text-transform:uppercase;
  border-bottom:2px solid var(--border); white-space:nowrap; }
tbody tr { border-bottom:1px solid var(--border); transition:.15s; }
tbody tr:last-child { border-bottom:none; }
tbody tr:hover { background:var(--off); }
tbody td { padding:11px 14px; font-size:13px; color:var(--text); vertical-align:middle; }
tbody td a { color:var(--blue); text-decoration:none; font-weight:600; }
tbody td a:hover { text-decoration:underline; }
code { font-family:'JetBrains Mono',monospace; font-size:12px; background:var(--off);
  padding:2px 7px; border-radius:4px; color:var(--blue); }

/* ── BADGES ── */
.badge       { display:inline-flex; align-items:center; gap:5px; padding:3px 10px;
  border-radius:100px; font-size:11.5px; font-weight:700; white-space:nowrap; }
.badge-todo   { background:#FFF3CD; color:#856404; }
.badge-prog   { background:#CCE5FF; color:#004085; }
.badge-done   { background:#D4EDDA; color:#155724; }
.badge-late   { background:#F8D7DA; color:#721C24; }
.badge-high   { background:#F8D7DA; color:#721C24; }
.badge-med    { background:#FFF3CD; color:#856404; }
.badge-low    { background:#D4EDDA; color:#155724; }
.badge-admin  { background:#E2D9F3; color:#3D1C6C; }
.badge-leader { background:#CCE5FF; color:#004085; }
.badge-staff  { background:#D4EDDA; color:#155724; }

/* ── BUTTONS ── */
.btn         { display:inline-flex; align-items:center; gap:6px; padding:8px 16px;
  border-radius:7px; border:none; font-family:inherit; font-size:13px; font-weight:600;
  cursor:pointer; transition:.2s; text-decoration:none; }
.btn-primary   { background:var(--navy); color:#fff; }
.btn-primary:hover { background:var(--navy2); }
.btn-secondary { background:var(--off); color:var(--navy); border:1px solid var(--border); }
.btn-secondary:hover { background:var(--border); }
.btn-danger    { background:var(--red); color:#fff; }
.btn-danger:hover { opacity:.85; }
.btn-sm        { padding:5px 11px; font-size:12px; }

/* ── FORMS ── */
.form-grid   { display:grid; grid-template-columns:1fr 1fr; gap:14px; }
.form-full   { grid-column:1/-1; }
.form-group  { display:flex; flex-direction:column; gap:5px; }
.form-group label { font-size:11.5px; font-weight:700; color:var(--navy); text-transform:uppercase; letter-spacing:.5px; }
.form-group input,
.form-group select,
.form-group textarea { padding:9px 12px; border-radius:7px; border:1.5px solid var(--border);
  font-size:13.5px; font-family:inherit; color:var(--text); background:#fff; transition:.2s; }
.form-group input:focus,
.form-group select:focus,
.form-group textarea:focus { outline:none; border-color:var(--blue-lt); box-shadow:0 0 0 3px rgba(46,125,209,.1); }
.form-group textarea { resize:vertical; min-height:80px; }
.pj-combo        { position:relative; }
.pj-chips        { display:flex; flex-wrap:wrap; gap:6px; margin-bottom:6px; }
.pj-chip         { display:flex; align-items:center; gap:6px; background:var(--blue); color:#fff;
  font-size:12.5px; font-weight:600; border-radius:100px; padding:5px 8px 5px 12px; }
.pj-chip-remove  { cursor:pointer; display:flex; align-items:center; opacity:.8; }
.pj-chip-remove:hover { opacity:1; }
.pj-search-input { width:100%; padding:9px 12px; border-radius:7px; border:1.5px solid var(--border);
  font-size:13.5px; font-family:inherit; }
.pj-search-input:focus { outline:none; border-color:var(--blue-lt); box-shadow:0 0 0 3px rgba(46,125,209,.1); }
.pj-dropdown     { display:none; position:absolute; top:100%; left:0; right:0; margin-top:4px; max-height:180px;
  overflow-y:auto; background:#fff; border:1.5px solid var(--border); border-radius:7px;
  box-shadow:0 10px 24px rgba(0,0,0,.12); z-index:50; padding:6px; }
.pj-dropdown::-webkit-scrollbar { width:7px; }
.pj-dropdown::-webkit-scrollbar-track { background:transparent; }
.pj-dropdown::-webkit-scrollbar-thumb { background:#C3CCDB; border-radius:10px; }
.pj-dropdown::-webkit-scrollbar-thumb:hover { background:#A9B4C8; }
.pj-combo.open .pj-dropdown { display:block; }
.pj-option       { display:flex; align-items:center; gap:8px; font-size:13px; color:var(--text);
  padding:8px 10px; border-radius:6px; cursor:pointer; }
.pj-option:hover { background:var(--off); }
.pj-option input[type="checkbox"] { accent-color:var(--blue); cursor:pointer; }
.pj-option-empty { padding:8px 10px; font-size:12.5px; color:var(--muted); text-align:center; }
.form-actions { display:flex; gap:10px; margin-top:16px; justify-content:flex-end; }
.filter-bar  { display:flex; gap:10px; flex-wrap:wrap; align-items:center; }
.filter-bar input, .filter-bar select { padding:8px 12px; border-radius:7px;
  border:1.5px solid var(--border); font-size:13px; font-family:inherit; }

/* ── PROGRESS BAR ── */
.prog-bar-wrap { height:7px; background:var(--border); border-radius:10px; overflow:hidden; }
.prog-bar      { height:100%; border-radius:10px; transition:.4s; }
.prog-bar.green { background:var(--green); }
.prog-bar.amber { background:var(--amber); }
.prog-bar.red   { background:var(--red); }

/* ── ALERTS ── */
.alert         { padding:12px 16px; border-radius:8px; margin-bottom:16px; font-size:13.5px; font-weight:500; }
.alert-success { background:#D4EDDA; color:#155724; border:1px solid #C3E6CB; }
.alert-danger  { background:#F8D7DA; color:#721C24; border:1px solid #F5C6CB; }

/* ── KANBAN ── */
.kanban-board    { display:grid; grid-template-columns:repeat(3,1fr); gap:16px; }
.kanban-col      { background:var(--off); border-radius:10px; padding:14px; border:1px solid var(--border); }
.kanban-col-head { display:flex; align-items:center; justify-content:space-between;
  margin-bottom:12px; padding-bottom:10px; border-bottom:1px solid var(--border); }
.kanban-col-title { font-size:13px; font-weight:700; color:var(--navy); }
.kanban-count    { width:22px; height:22px; border-radius:50%; background:var(--navy);
  color:#fff; font-size:11px; font-weight:700; display:flex; align-items:center; justify-content:center; }
.kanban-card     { background:#fff; border-radius:8px; padding:12px 14px; border:1px solid var(--border);
  margin-bottom:8px; text-decoration:none; display:block; transition:.2s; border-left:3px solid var(--blue); }
.kanban-card:hover { box-shadow:0 3px 10px rgba(0,0,0,.1); transform:translateY(-1px); }
.kanban-card.high-p { border-left-color:var(--red); }
.kanban-card.med-p  { border-left-color:var(--amber); }
.kanban-card.low-p  { border-left-color:var(--green); }
.kc-title { font-size:13px; font-weight:600; color:var(--navy); margin-bottom:6px; }
.kc-meta  { display:flex; align-items:center; gap:8px; flex-wrap:wrap; margin-top:6px; }
.kc-assign { font-size:11.5px; color:var(--muted); }
.kc-due    { font-size:11.5px; color:var(--muted); }
.kc-due.late { color:var(--red); font-weight:700; }

/* ── TROUBLE ACCORDION ── */
.trouble-item { background:#fff; border-radius:10px; border:1px solid var(--border); overflow:hidden; margin-bottom:10px; }
.trouble-q    { padding:14px 18px; cursor:pointer; display:flex; align-items:center; justify-content:space-between;
  font-size:13.5px; font-weight:600; color:var(--navy); transition:.15s; border-left:4px solid transparent; }
.trouble-q:hover  { background:var(--off); }
.trouble-q.open   { background:var(--off); border-left-color:var(--gold); }
.trouble-chevron  { transition:.3s; font-size:11px; color:var(--muted); }
.trouble-q.open .trouble-chevron { transform:rotate(180deg); }
.trouble-a        { display:none; padding:14px 22px 16px; font-size:13px; line-height:1.8;
  color:var(--text); border-top:1px solid var(--border); }
.trouble-a.open   { display:block; }
.trouble-a ol, .trouble-a ul { padding-left:18px; margin-top:8px; }
.trouble-a li     { margin-bottom:5px; }
.trouble-tip      { background:#FFF8E1; border-left:3px solid var(--gold); padding:10px 14px;
  border-radius:0 7px 7px 0; margin-top:10px; font-size:12.5px; }
.trouble-danger   { background:#FFF0F0; border-left:3px solid var(--red); padding:10px 14px;
  border-radius:0 7px 7px 0; margin-top:10px; font-size:12.5px; }

/* ── UTILS ── */
.text-red   { color:var(--red); }
.text-amber { color:var(--amber); }
.text-muted { color:var(--muted); }
.fw-bold    { font-weight:700; }

/* ── RESPONSIVE ── */
@media (max-width:900px) {
  .stats-grid { grid-template-columns:1fr 1fr; }
  .kanban-board { grid-template-columns:1fr; }
}
@media (max-width:650px) {
  .sidebar { display:none; }
  .page { padding:16px; }
  .form-grid { grid-template-columns:1fr; }
  .stats-grid { grid-template-columns:1fr 1fr; }
}
