*{box-sizing:border-box}
body{
  margin:0;
  font-family:var(--font-body);
  color:var(--text);
  background:linear-gradient(180deg, var(--soft), #ffffff);
}

a{color:inherit; text-decoration:none}
h1,h2,h3{font-family:var(--font-head); margin:0 0 6px}
h1{font-size:28px}
h2{font-size:18px}
.muted{color:rgba(47,47,47,.65)}
code.code{background:rgba(31,95,84,.08); padding:4px 8px; border-radius:10px}

.app{display:flex; min-height:100vh}
.sidebar{
  width:var(--sidebar-w);
  background:var(--white);
  border-right:1px solid var(--border);
  padding:18px;
  position:sticky;
  top:0;
  height:100vh;
}
.brand{display:flex; gap:12px; align-items:center; padding:10px 10px 18px 10px}
.brand-mark{
  width:42px; height:42px; border-radius:50%;
  border:2px solid rgba(63,143,115,.35);
  position:relative;
}
.brand-mark:before, .brand-mark:after{
  content:"";
  position:absolute;
  inset:7px;
  border-radius:50%;
  border:2px solid rgba(31,95,84,.35);
}
.brand-mark:after{inset:15px; border-color:rgba(63,143,115,.55)}
.brand-name{font-family:var(--font-head); font-weight:700}
.brand-sub{font-size:12px; color:rgba(47,47,47,.65)}

.nav{display:flex; flex-direction:column; gap:8px}
.nav-link{
  padding:12px 12px;
  border-radius:12px;
  background:transparent;
  border:1px solid transparent;
}
.nav-link:hover{
  border-color:rgba(31,95,84,.18);
  background:rgba(31,95,84,.06);
}
.sidebar-foot{position:absolute; left:18px; right:18px; bottom:18px}

.main{flex:1; display:flex; flex-direction:column}
.topbar{
  height:var(--topbar-h);
  display:flex; align-items:center; justify-content:space-between;
  padding:0 22px;
  background:rgba(255,255,255,.85);
  backdrop-filter: blur(10px);
  border-bottom:1px solid var(--border);
  position:sticky; top:0; z-index:2;
}
.app-title{font-family:var(--font-head); font-weight:700}
.badge.role{
  display:inline-flex; align-items:center;
  padding:6px 10px; border-radius:999px;
  background:rgba(63,143,115,.12);
  border:1px solid rgba(63,143,115,.25);
  font-size:12px; margin-right:10px;
}

.content{padding:22px; max-width:1250px; margin:0 auto; width:100%}

.page-head{display:flex; align-items:flex-end; justify-content:space-between; gap:14px; margin-bottom:14px}
.actions{display:flex; gap:10px; align-items:center}
.inline{display:inline-flex; gap:8px; align-items:center}

.card{
  background:rgba(255,255,255,.92);
  border:1px solid var(--border);
  border-radius:var(--radius);
  box-shadow:var(--shadow);
  padding:16px;
  margin-bottom:14px;
}
.card-head-row{display:flex; justify-content:space-between; align-items:center; margin-bottom:10px}

.table{width:100%; border-collapse:collapse}
.table th{font-size:12px; text-transform:uppercase; letter-spacing:.04em; color:rgba(47,47,47,.55); text-align:left; padding:10px}
.table td{padding:12px 10px; border-top:1px solid rgba(47,47,47,.08); vertical-align:middle}
.table .right{text-align:right}

.btn{
  display:inline-flex; align-items:center; justify-content:center;
  height:40px;
  padding:0 14px;
  border-radius:12px;
  border:1px solid transparent;
  font-weight:600;
  font-size:14px;
  cursor:pointer;
}
.btn-sm{height:32px; padding:0 10px; border-radius:10px; font-size:13px}

.btn-primary{
  background:var(--primary);
  color:var(--white);
}
.btn-primary:hover{filter:brightness(0.98)}
.btn-secondary{
  background:rgba(31,95,84,.06);
  border-color:rgba(31,95,84,.18);
  color:var(--primary);
}
.btn-secondary:hover{background:rgba(31,95,84,.09)}

.input{
  width:100%;
  height:42px;
  padding:0 12px;
  border-radius:12px;
  border:1px solid rgba(47,47,47,.12);
  background:var(--white);
  outline:none;
}
textarea.input{height:auto; padding:10px 12px}

.form{display:flex; flex-direction:column; gap:10px}
.form.compact{gap:8px}
label{font-size:12px; color:rgba(47,47,47,.65); font-weight:600}

.row{display:flex; gap:10px; align-items:center; margin-top:8px}

.flash-wrap{display:flex; flex-direction:column; gap:10px; margin-bottom:12px}
.flash{
  padding:12px 14px;
  border-radius:12px;
  border:1px solid rgba(47,47,47,.12);
  background:var(--white);
}
.flash.success{border-color:rgba(63,143,115,.35); background:rgba(63,143,115,.10)}
.flash.danger{border-color:rgba(220,38,38,.35); background:rgba(220,38,38,.08)}
.flash.warning{border-color:rgba(245,158,11,.35); background:rgba(245,158,11,.10)}

.filters .grid{
  display:grid;
  grid-template-columns: repeat(5, 1fr);
  gap:12px;
}
.filters .wide{grid-column: span 2}
.right-align{display:flex; flex-direction:column; justify-content:flex-end}

.grid-2{display:grid; grid-template-columns: 1fr 1fr; gap:14px}
.grid.two{display:grid; grid-template-columns:1fr 1fr; gap:12px}

.pill{
  display:inline-flex;
  padding:6px 10px;
  border-radius:999px;
  background:rgba(63,143,115,.12);
  border:1px solid rgba(63,143,115,.25);
  font-size:12px;
}

.center-card{min-height:calc(100vh - var(--topbar-h) - 44px); display:flex; align-items:center; justify-content:center}
.center-card .card{width:min(420px, 92vw); padding:22px}

.card-head p{margin:0}

.tabs{display:flex; gap:8px; margin-bottom:10px}
.tab{
  padding:10px 12px;
  border-radius:12px;
  border:1px solid rgba(47,47,47,.12);
  background:rgba(255,255,255,.8);
}
.tab.active{border-color:rgba(31,95,84,.25); background:rgba(31,95,84,.06); color:var(--primary); font-weight:700}
.tab.disabled{opacity:.55; cursor:not-allowed}

.kv{display:flex; flex-direction:column; gap:8px}
.kv .k{display:inline-block; width:90px; color:rgba(47,47,47,.65); font-weight:700}
.kv .v{font-weight:600}

.scroll{max-height:520px; overflow:auto; border-radius:12px}

/* dashboard cards */
.cards-grid{
  display:grid;
  grid-template-columns: repeat(4, 1fr);
  gap:14px;
  margin: 14px 0 18px;
}
.card{
  display:block;
  padding:16px;
  border-radius:16px;
  background: rgba(255,255,255,0.92);
  border:1px solid rgba(47,47,47,.10);
  box-shadow: 0 14px 38px rgba(31,95,84,0.06);
  text-decoration:none;
  color: var(--text);
  transition: transform .08s ease;
}
.card:hover{transform: translateY(-1px)}
.card-kpi{
  font-family: var(--font-heading);
  font-size: 28px;
  font-weight: 700;
  color: var(--primary);
  line-height: 1.1;
}
.card-title{margin-top:8px; font-weight:700}
.card-sub{margin-top:4px; font-size: 13px}

.panel{
  padding:16px;
  border-radius:16px;
  background: rgba(255,255,255,0.92);
  border:1px solid rgba(47,47,47,.10);
}
.panel h2{margin:0 0 10px}
.steps{margin:0; padding-left:18px}
.steps li{margin:6px 0}

/* responsive */
@media (max-width: 980px){
  .sidebar{display:none}
  .content{padding:16px}
  .filters .grid{grid-template-columns: 1fr 1fr}
  .filters .wide{grid-column: span 2}
  .grid-2{grid-template-columns:1fr}
  .cards-grid{grid-template-columns:1fr 1fr}
}

@media (max-width: 640px){
  .cards-grid{grid-template-columns:1fr}
}


/* ---- Scope chips ---- */
.chips{display:flex; flex-wrap:wrap; gap:8px; margin-top:6px}
.chip{
  appearance:none;
  border:1px solid rgba(47,47,47,.14);
  background:rgba(255,255,255,.85);
  padding:10px 12px;
  border-radius:999px;
  font-size:13px;
  cursor:pointer;
  transition:transform .06s ease, border-color .12s ease, background .12s ease;
}
.chip:hover{transform:translateY(-1px)}
.chip.active{
  border-color:rgba(63,143,115,.45);
  background:rgba(63,143,115,.12);
}
.mt-8{margin-top:8px}


/* Danger button */
.btn-danger{
  background: #b42318;
  border: 1px solid rgba(255,255,255,0.12);
  color: #fff;
}

.btn-outline-danger{
  background: transparent;
  border: 1px solid #b42318;
  color: #b42318;
}
.btn-outline-danger:hover{
  background: rgba(180,35,24,.06);
}
.btn-danger:hover{ filter: brightness(0.95); }


/* ----------------- Modal (lightweight) ----------------- */
body.modal-open { overflow: hidden; }

/* Ensure native [hidden] always wins (prevents modals showing on load) */
.modal[hidden],
.modal-backdrop[hidden]{
  display: none !important;
}

.modal-backdrop{
  position: fixed;
  inset: 0;
  background: rgba(2,6,23,0.45);
  backdrop-filter: blur(2px);
  z-index: 50;
}

.modal{
  position: fixed;
  inset: 0;
  display: grid;
  place-items: center;
  padding: 18px;
  z-index: 60;
}

.modal-card{
  width: min(720px, 100%);
  background: var(--surface, rgba(255,255,255,0.92));
  border: 1px solid var(--border, #e2e8f0);
  border-radius: 16px;
  box-shadow: var(--shadow, 0 18px 50px rgba(2, 6, 23, 0.10));
  overflow: hidden;
}

.modal-head{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap: 12px;
  padding: 16px 18px;
  border-bottom: 1px solid var(--border-soft, #eef2f7);
}

.modal-title{ font-size: 18px; font-weight: 700; }
.modal-body{ padding: 16px 18px 18px; }

.tabs{
  display:flex;
  gap: 8px;
  margin-bottom: 14px;
}

.tab{
  border: 1px solid var(--border, #e2e8f0);
  background: rgba(255,255,255,0.65);
  padding: 10px 12px;
  border-radius: 12px;
  cursor: pointer;
  font-weight: 600;
}

.tab.active{
  background: rgba(14,165,233,0.12);
  border-color: rgba(14,165,233,0.35);
}

.grid-2{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
}

@media (max-width: 740px){
  .grid-2{ grid-template-columns: 1fr; }
}

.form-group label{
  display:block;
  font-weight: 600;
  margin-bottom: 6px;
}

.help{ margin-top: 6px; font-size: 12px; }

.modal-actions{
  display:flex;
  justify-content:flex-end;
  gap: 10px;
  margin-top: 16px;
  padding-top: 14px;
  border-top: 1px solid var(--border-soft, #eef2f7);
}

.danger-box{
  border: 1px solid rgba(220,38,38,0.35);
  background: rgba(220,38,38,0.06);
  padding: 12px 12px;
  border-radius: 14px;
}

.danger-title{ font-weight: 800; margin-bottom: 4px; }

