/* =========================================================================
   Spasio — style.css
   Tema profesional kontras tinggi (terbaca di cahaya terang, WCAG AA).
   Responsif penuh: ponsel, tablet, desktop. Tanpa dependensi eksternal.
   ========================================================================= */

:root{
  --teal-900:#0a2e2f; --teal-800:#0f3d3e; --teal-700:#14514f; --teal-600:#1c6b66;
  --amber:#e08a1e; --red:#dc2626; --green:#16a34a; --blue:#2563eb;
  --ink:#10201f; --muted:#5b6b6a; --line:#dfe6e4; --bg:#f4f7f6; --card:#ffffff;
  --radius:12px; --radius-sm:8px;
  --shadow:0 1px 2px rgba(10,46,47,.06),0 6px 20px rgba(10,46,47,.06);
  --shadow-sm:0 1px 2px rgba(10,46,47,.08);
  --sidebar-w:236px; --topbar-h:58px;
  --font:"Segoe UI",system-ui,-apple-system,Roboto,"Helvetica Neue",Arial,sans-serif;
}

*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{
  margin:0;font-family:var(--font);color:var(--ink);background:var(--bg);
  font-size:15px;line-height:1.5;
}
a{color:var(--teal-700);text-decoration:none}
a:hover{text-decoration:underline}
h1{font-size:1.5rem;margin:0 0 4px} h2{font-size:1.15rem} h3{font-size:1rem;margin:14px 0 6px}
code,.mono{font-family:ui-monospace,"SF Mono",Menlo,Consolas,monospace;font-size:.86em}
.muted{color:var(--muted)} .small{font-size:.82rem}
.ok{color:var(--green);font-weight:600} .bad{color:var(--red);font-weight:600}
hr{border:none;border-top:1px solid var(--line);margin:18px 0}

.skip-link{position:absolute;left:-999px}
.skip-link:focus{left:8px;top:8px;background:#fff;padding:8px;z-index:1000;border-radius:6px}

/* ---------- Topbar ---------- */
.topbar{
  position:fixed;top:0;left:0;right:0;height:var(--topbar-h);z-index:50;
  display:flex;align-items:center;gap:12px;padding:0 16px;
  background:var(--teal-800);color:#fff;box-shadow:var(--shadow-sm);
}
.brand{display:flex;align-items:center;gap:10px;color:#fff;font-weight:700;text-decoration:none}
.brand:hover{text-decoration:none}
.brand-mark{
  display:grid;place-items:center;width:32px;height:32px;border-radius:9px;
  background:linear-gradient(135deg,var(--amber),#f0a93f);color:#3a2400;font-weight:800;
}
.brand-name{font-size:1.05rem;letter-spacing:.2px}
.topbar-right{margin-left:auto;display:flex;align-items:center;gap:10px}
.user-name{color:#dbeae8;font-size:.9rem}
.nav-toggle{display:none;background:transparent;border:0;color:#fff;font-size:1.5rem;cursor:pointer;padding:4px 8px}

.role-badge{font-size:.7rem;font-weight:700;padding:3px 8px;border-radius:999px;text-transform:uppercase;letter-spacing:.3px}
.role-superadmin{background:#fde68a;color:#7a4d00}
.role-admin{background:#bfdbfe;color:#1e3a8a}
.role-manager{background:#bbf7d0;color:#14532d}
.role-user{background:#e2e8f0;color:#334155}
.role-guest{background:#f1f5f9;color:#64748b}

/* ---------- Sidebar ---------- */
.sidebar{
  position:fixed;top:var(--topbar-h);bottom:0;left:0;width:var(--sidebar-w);z-index:40;
  background:var(--teal-900);color:#cfe3e0;padding:14px 10px;overflow-y:auto;
  display:flex;flex-direction:column;
}
.sidebar ul{list-style:none;margin:0;padding:0;flex:1}
.sidebar li{margin:2px 0}
.sidebar a{
  display:flex;align-items:center;gap:11px;padding:11px 13px;border-radius:10px;
  color:#cfe3e0;font-weight:500;text-decoration:none;transition:background .15s,color .15s;
}
.sidebar a:hover{background:rgba(255,255,255,.07);color:#fff}
.sidebar li.active a{background:var(--amber);color:#2a1a00;font-weight:700}
.sidebar .ico{font-size:1.05rem;width:20px;text-align:center}
.sidebar-foot{color:#6f8d8a;font-size:.72rem;padding:10px 13px;border-top:1px solid rgba(255,255,255,.08)}

/* ---------- Content ---------- */
.content{margin-top:var(--topbar-h);margin-left:var(--sidebar-w);padding:24px;max-width:1180px}
.content-full{margin-left:0}
.page-head{display:flex;justify-content:space-between;align-items:flex-end;gap:16px;margin-bottom:18px;flex-wrap:wrap}
.page-actions,.page-actions form{display:flex;gap:8px;align-items:center}

/* ---------- Cards & grid ---------- */
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);
  padding:18px;box-shadow:var(--shadow);margin-bottom:18px}
.card-title{margin:0 0 12px;padding-bottom:10px;border-bottom:1px solid var(--line)}
.grid{display:grid;gap:18px}
.grid-2{grid-template-columns:1fr 1fr}
.grid-dash{grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}
.grid-cards{grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}
.card-link{display:block;transition:transform .12s,box-shadow .12s}
.card-link:hover{transform:translateY(-2px);box-shadow:0 8px 26px rgba(10,46,47,.12);text-decoration:none}
.card-ico{font-size:1.7rem;display:block;margin-bottom:6px}

/* ---------- Widgets ---------- */
.widget-title{font-size:1rem;margin:0 0 12px}
.row-item{display:flex;align-items:center;gap:10px;padding:9px 4px;border-bottom:1px solid var(--line);
  color:var(--ink);text-decoration:none}
.row-item:last-child{border-bottom:0}
a.row-item:hover{background:#f8fafa;text-decoration:none}
.row-main{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.row-meta{font-size:.8rem;color:var(--muted);white-space:nowrap}
.row-meta.overdue,.overdue{color:var(--red);font-weight:600}
.empty{color:var(--muted);text-align:center;padding:18px;font-style:italic}
.widget-kpi{text-align:center}
.kpi{margin:8px 0}
.kpi-num{font-size:2.4rem;font-weight:800;color:var(--teal-700);line-height:1}
.kpi-label{color:var(--muted);font-size:.85rem}
.progress{height:9px;background:var(--line);border-radius:999px;overflow:hidden;margin:8px 0}
.progress span{display:block;height:100%;background:linear-gradient(90deg,var(--teal-600),var(--green))}

.quick-actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:6px}

/* ---------- Badges / chips / status ---------- */
.badge{display:inline-block;min-width:30px;text-align:center;font-size:.72rem;font-weight:700;
  padding:3px 7px;border-radius:6px;color:#fff}
.prio-1{background:#b91c1c}.prio-2{background:#ea580c}.prio-3{background:#0891b2}
.prio-4{background:#64748b}.prio-5{background:#94a3b8}
.sev-1{background:#b91c1c}.sev-2{background:#ea580c}.sev-3{background:#ca8a04}
.sev-4{background:#64748b}.sev-5{background:#94a3b8}
.chip{display:inline-block;font-size:.74rem;padding:3px 9px;border-radius:999px;background:#eef3f2;color:var(--teal-800);font-weight:600}
.chip-cat{background:#e0efee}
.status{display:inline-block;font-size:.74rem;font-weight:600;padding:3px 9px;border-radius:999px}
.status-new{background:#e2e8f0;color:#334155}
.status-in-progress{background:#dbeafe;color:#1e40af}
.status-pending,.status-pending-verification{background:#fef3c7;color:#92400e}
.status-done,.status-resolved,.status-complete,.status-accepted{background:#dcfce7;color:#166534}
.status-close,.status-closed,.status-wf-end{background:#e5e7eb;color:#374151}
.status-rejected,.status-cancelled{background:#fee2e2;color:#991b1b}
.status-open,.status-assigned{background:#e0f2fe;color:#075985}
.status-transferred,.status-require-action{background:#ede9fe;color:#5b21b6}

/* ---------- Tables ---------- */
.table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}
.data-table{width:100%;border-collapse:collapse;background:var(--card)}
.data-table th,.data-table td{padding:11px 12px;text-align:left;border-bottom:1px solid var(--line);vertical-align:middle}
.data-table th{font-size:.74rem;text-transform:uppercase;letter-spacing:.4px;color:var(--muted);background:#fafcfb;position:sticky;top:0}
.data-table.compact th,.data-table.compact td{padding:8px 10px}
.data-table tbody tr[onclick]{cursor:pointer}
.data-table tbody tr:hover{background:#f6faf9}

/* ---------- Forms ---------- */
.form label{display:block;margin-bottom:14px;font-weight:600;font-size:.9rem;color:#243534}
.form input,.form select,.form textarea{
  display:block;width:100%;margin-top:6px;padding:10px 12px;font:inherit;color:var(--ink);
  background:#fff;border:1px solid var(--line);border-radius:var(--radius-sm);transition:border .15s,box-shadow .15s}
.form input:focus,.form select:focus,.form textarea:focus{
  outline:none;border-color:var(--teal-600);box-shadow:0 0 0 3px rgba(28,107,102,.15)}
.form textarea{resize:vertical}
.form-card{max-width:680px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.form-actions{display:flex;gap:10px;margin-top:8px}
.has-error input,.has-error select{border-color:var(--red)}
.err{color:var(--red);font-weight:500;font-size:.8rem;display:block;margin-top:-8px;margin-bottom:10px}
fieldset{border:1px solid var(--line);border-radius:var(--radius-sm);padding:14px;margin:0 0 16px}
legend{padding:0 6px;font-weight:700;color:var(--teal-700)}
.filterbar{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:16px;align-items:center}
.filterbar input,.filterbar select{padding:9px 11px;border:1px solid var(--line);border-radius:var(--radius-sm);font:inherit;background:#fff}
.filterbar input[type=search]{min-width:200px;flex:1}
.inline-actions{display:flex;gap:8px;flex-wrap:wrap;margin-top:6px}
.checkbox-row{display:flex;align-items:center;gap:8px;font-weight:500}
.checkbox-row input{width:auto;margin:0}

/* ---------- Buttons ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;cursor:pointer;
  font:inherit;font-weight:600;padding:10px 16px;border-radius:var(--radius-sm);border:1px solid transparent;
  transition:background .15s,box-shadow .15s,transform .05s;text-decoration:none;white-space:nowrap}
.btn:hover{text-decoration:none}
.btn:active{transform:translateY(1px)}
.btn-sm{padding:7px 12px;font-size:.85rem}
.btn-block{width:100%}
.btn-primary{background:var(--teal-700);color:#fff}
.btn-primary:hover{background:var(--teal-800)}
.btn-outline{background:#fff;color:var(--teal-700);border-color:var(--teal-600)}
.btn-outline:hover{background:#eef5f4}
.btn-ghost{background:transparent;color:#fff;border-color:rgba(255,255,255,.4)}
.content .btn-ghost{color:var(--teal-700);border-color:var(--line)}
.content .btn-ghost:hover{background:#eef5f4}

/* ---------- Alerts ---------- */
.alert{padding:12px 15px;border-radius:var(--radius-sm);margin-bottom:16px;border-left:4px solid;font-size:.92rem}
.alert-info{background:#e0f2fe;border-color:var(--blue);color:#075985}
.alert-success{background:#dcfce7;border-color:var(--green);color:#166534}
.alert-error{background:#fee2e2;border-color:var(--red);color:#991b1b}
.alert-warn{background:#fef3c7;border-color:var(--amber);color:#92400e}

/* ---------- Detail lists / misc ---------- */
.kv{display:grid;grid-template-columns:140px 1fr;gap:6px 14px;margin:0}
.kv dt{color:var(--muted);font-size:.85rem}
.kv dd{margin:0;font-weight:500}
.prose{white-space:normal;color:#243534}
.comment{padding:10px 0;border-bottom:1px solid var(--line)}
.comment:last-child{border-bottom:0}
.feature-list{margin:0;padding-left:20px}
.feature-list li{margin:6px 0}
.tabs{display:flex;gap:6px;margin-bottom:16px;border-bottom:1px solid var(--line)}
.tab{padding:10px 16px;font-weight:600;color:var(--muted);border-bottom:2px solid transparent}
.tab.active{color:var(--teal-700);border-color:var(--teal-600)}
.qr-box{text-align:center;margin:14px 0;padding:14px;background:#fafcfb;border-radius:var(--radius-sm)}

/* ---------- Auth pages ---------- */
.auth-body{display:grid;place-items:center;min-height:100vh;padding:20px;
  background:linear-gradient(135deg,var(--teal-900),var(--teal-700))}
.auth-card{width:100%;max-width:410px;background:#fff;border-radius:16px;padding:30px;box-shadow:0 20px 60px rgba(0,0,0,.25)}
.auth-brand{display:flex;align-items:center;gap:12px;margin-bottom:8px}
.auth-brand h1{margin:0;font-size:1.4rem}
.auth-brand .brand-mark{width:42px;height:42px;font-size:1.3rem;border-radius:11px}
.auth-title{margin:18px 0 4px}
.auth-foot{text-align:center;margin-top:18px}

/* ---------- Responsive: tablet & phone ---------- */
@media (max-width:900px){
  .nav-toggle{display:block}
  .sidebar{transform:translateX(-100%);transition:transform .22s ease;
    box-shadow:6px 0 30px rgba(0,0,0,.25)}
  body.nav-open .sidebar{transform:translateX(0)}
  .content{margin-left:0}
  body.nav-open::after{content:"";position:fixed;inset:var(--topbar-h) 0 0 0;background:rgba(0,0,0,.35);z-index:39}
}
@media (max-width:620px){
  body{font-size:14px}
  .content{padding:16px 13px}
  .form-row{grid-template-columns:1fr}
  .kv{grid-template-columns:1fr;gap:2px 0}
  .kv dt{margin-top:8px}
  .grid-2{grid-template-columns:1fr}
  .user-name{display:none}
  h1{font-size:1.3rem}
  .page-head{align-items:flex-start}
  .data-table th,.data-table td{padding:9px 8px}
}
@media (min-width:1500px){ .content{max-width:1320px} }

/* ---------- Kalender Agenda ---------- */
.cal-toolbar{display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap;margin-bottom:12px}
.cal-nav{display:flex;align-items:center;gap:6px}
.cal-title{font-size:1.05rem;margin-left:8px}
.cal-views{display:flex;gap:4px}
.cal-dot{display:inline-block;width:8px;height:8px;border-radius:50%;flex:none}

.cal-month{display:grid;grid-template-columns:repeat(7,1fr);gap:1px;background:var(--line);
  border:1px solid var(--line);border-radius:var(--radius);overflow:hidden}
.cal-dow{background:#fafcfb;text-align:center;font-size:.74rem;font-weight:700;color:var(--muted);padding:8px 0;text-transform:uppercase}
.cal-cell{background:#fff;min-height:104px;padding:5px 6px;display:flex;flex-direction:column;gap:3px}
.cal-cell.cal-out{background:#f7f9f9}
.cal-cell.cal-out .cal-daynum{color:#b6c2c0}
.cal-cell.cal-today{background:#eef7f6;box-shadow:inset 0 0 0 2px var(--teal-600)}
.cal-daynum{font-size:.82rem;font-weight:600;text-align:right}
.cal-daynum a{color:inherit}
.cal-event{display:flex;align-items:center;gap:4px;font-size:.74rem;line-height:1.25;
  background:#f4f7f6;border-left:3px solid var(--teal-700);border-radius:4px;
  padding:2px 5px;color:var(--ink);text-decoration:none;overflow:hidden;white-space:nowrap;text-overflow:ellipsis}
.cal-event:hover{background:#e9efee;text-decoration:none}
.cal-time{font-weight:700;font-variant-numeric:tabular-nums}
.cal-more{font-size:.7rem;color:var(--muted)}

.cal-week{display:grid;grid-template-columns:repeat(7,1fr);gap:10px}
.cal-weekday{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:10px;min-height:120px}
.cal-weekday h3{margin:0 0 8px;font-size:.86rem}
.cal-weekday h3 a{color:var(--ink)}
.cal-weekday.cal-today{box-shadow:inset 0 0 0 2px var(--teal-600)}
.cal-weekday .cal-event{white-space:normal;margin-bottom:4px}

@media (max-width:900px){
  .cal-month .cal-event .cal-time{display:none}
  .cal-cell{min-height:78px}
  .cal-week{grid-template-columns:1fr}        /* tumpuk hari di layar kecil */
}
@media (max-width:620px){
  .cal-cell{min-height:60px;padding:3px}
  .cal-event{font-size:.68rem}
  .cal-toolbar{flex-direction:column;align-items:stretch}
}

/* ---------- Meeting Free/Busy grid ---------- */
.fb-wrap{margin-top:10px}
.fb-grid{border-collapse:collapse;font-size:.7rem;min-width:max-content}
.fb-grid th{padding:3px 4px;font-size:.62rem;color:var(--muted);font-weight:700;text-align:center;white-space:nowrap;border-bottom:1px solid var(--line)}
.fb-grid th:first-child,.fb-name{text-align:left;position:sticky;left:0;background:#fff;z-index:1;
  padding:4px 8px;font-weight:600;white-space:nowrap;border-right:1px solid var(--line)}
.fb-cell{width:18px;height:20px;border:1px solid #eef2f1}
.fb-free{background:#dcfce7}
.fb-busy{background:#fecaca}
.fb-ok{background:var(--teal-600)}
.fb-all td.fb-cell{height:10px}
.fb-all .fb-name{color:var(--teal-700)}
.fb-key{display:inline-block;width:14px;height:12px;border-radius:3px;vertical-align:middle;margin:0 3px}

/* ---------- Laporan: chart & cetak ---------- */
.chart-pie{display:flex;gap:18px;align-items:center;flex-wrap:wrap}
.chart-legend{display:flex;flex-direction:column;gap:5px;font-size:.82rem}
.chart-legend .lg{display:flex;align-items:center;gap:7px}
.chart-legend .lg span{width:12px;height:12px;border-radius:3px;display:inline-block}
.inline-label{display:flex;align-items:center;gap:6px;font-size:.85rem;font-weight:600}
.inline-label input{width:auto}

@media print {
  .topbar,.sidebar,.no-print,.page-actions,.filterbar,.skip-link{display:none !important}
  .content{margin:0 !important;max-width:100% !important;padding:0 !important}
  .card{box-shadow:none;border-color:#ccc;break-inside:avoid}
  body{background:#fff}
  .grid-2{grid-template-columns:1fr 1fr}
}

/* ---------- Inline row editor (workgroup) ---------- */
.row-edit summary{cursor:pointer;list-style:none;display:inline-flex}
.row-edit summary::-webkit-details-marker{display:none}
.row-edit[open] summary{margin-bottom:4px}
.row-edit .form label{margin-bottom:8px}

/* ---------- Topbar: site switcher + bell ---------- */
.site-switch select{background:rgba(255,255,255,.12);color:#fff;border:1px solid rgba(255,255,255,.25);
  border-radius:8px;padding:6px 8px;font:inherit;font-size:.82rem;max-width:160px}
.site-switch select option{color:#10201f}
.site-name{color:#dbeae8;font-size:.82rem;background:rgba(255,255,255,.1);padding:5px 9px;border-radius:8px}
.bell{position:relative;color:#fff;text-decoration:none;font-size:1.1rem;padding:4px 6px;line-height:1}
.bell:hover{text-decoration:none}
.bell-badge{position:absolute;top:-3px;right:-6px;background:var(--amber);color:#3a2400;
  font-size:.62rem;font-weight:800;min-width:16px;height:16px;border-radius:999px;
  display:inline-flex;align-items:center;justify-content:center;padding:0 4px}
.notif-unread{background:#eef7f6}
.notif-unread .row-main strong::before{content:"● ";color:var(--amber)}
@media (max-width:620px){
  .site-switch select{max-width:108px}
  .site-name{display:none}
}
