:root{
  --card-bg: rgba(255,255,255,.94);
  --card-brd: rgba(0,0,0,.10);
  --shadow: 0 10px 30px rgba(0,0,0,.10);
  --radius: 16px;
  --muted: rgba(0,0,0,.60);

  /* Kingart vibe: vivid accents (matches the colorful brand/background) */
  --ka-pink: #ff2b6a;
  --ka-orange: #ff7a18;
  --ka-blue: #2563eb;
  --ka-purple: #7c3aed;
  --ka-green: #16a34a;
}

.app-body{
  font-family: system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  padding: 20px;
  background-image: url('/assets/bg1.svg');
  background-repeat: no-repeat;
  background-position: center top;
  background-size: cover;
  background-attachment: fixed;
  color:#111;
}

.app-shell{
  max-width: 1280px;
  margin: 0 auto;
}

.app-topbar{
  background: var(--card-bg);
  border: 1px solid var(--card-brd);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  /* Compact topbar (smaller height) */
  padding: 6px 12px;
  backdrop-filter: blur(6px);
}

.app-card{
  background: var(--card-bg);
  border: 1px solid var(--card-brd);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  padding: 14px 16px;
  backdrop-filter: blur(6px);
}

/* Slightly larger logo while keeping topbar compact */
.app-logo{ width:64px; height:64px; object-fit:contain; display:block; }

/* Topbar layout */
.topbar-row{ display:flex; justify-content:space-between; align-items:center; gap:14px; flex-wrap:wrap; }
.topbar-left{ display:flex; align-items:center; gap:12px; min-width:220px; }
.topbar-right{ display:flex; align-items:center; justify-content:flex-end; gap:10px; flex-wrap:wrap; }
.build-badge{ display:inline-flex; align-items:center; gap:6px; padding:5px 10px; border:1px solid rgba(0,0,0,.12); border-radius:999px; font-size:12px; opacity:.9; background: rgba(255,255,255,.65); }

/* Buttons + icon buttons */
.btn{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:8px 12px;
  border-radius:12px;
  border:1px solid rgba(0,0,0,.12);
  background: rgba(255,255,255,.85);
  cursor:pointer;
  text-decoration:none;
  color:#111;
  transition: transform .08s ease, filter .15s ease, box-shadow .15s ease, background .15s ease, border-color .15s ease;
}
.btn:hover{
  filter: brightness(0.99) saturate(1.03);
  box-shadow: 0 10px 24px rgba(0,0,0,.12);
}
.btn:active{ transform: translateY(1px); }
.btn:focus-visible{
  outline: none;
  box-shadow: 0 0 0 4px rgba(255,43,106,.22), 0 10px 24px rgba(0,0,0,.12);
}

.btn-primary{
  background: linear-gradient(90deg, var(--ka-pink), var(--ka-orange));
  border-color: transparent;
  color:#fff;
}
.btn-primary:hover{ filter: brightness(0.98) saturate(1.08); }
.btn-primary:focus-visible{ box-shadow: 0 0 0 4px rgba(255,122,24,.22), 0 10px 24px rgba(0,0,0,.14); }

.btn-ghost{
  background: rgba(255,255,255,.65);
}

.btn-link{ border-color: transparent; background: transparent; padding:8px 8px; }
.btn .ico{ display:inline-flex; align-items:center; justify-content:center; }
.btn .ico svg{ width:16px; height:16px; }

.app-btn{ display:inline-flex; align-items:center; justify-content:center; padding:6px 10px; border-radius:12px; border:1px solid rgba(0,0,0,.12); background: rgba(255,255,255,.85); cursor:pointer; text-decoration:none; color:#111; font-size:13px; }
.app-btn:hover{ filter: brightness(0.98); }

/* Tabs (dashboard + admin) */
.tabs{ display:flex; gap:8px; flex-wrap:wrap; margin: 10px 0 18px; }
.tabbtn{ cursor:pointer; padding:8px 10px; border:1px solid rgba(0,0,0,.12); border-radius:12px; background: rgba(255,255,255,.92); display:inline-flex; align-items:center; gap:8px; box-shadow: 0 6px 18px rgba(0,0,0,.08), inset 0 2px 0 rgba(255,43,106,.28); transition: transform .08s ease, box-shadow .15s ease, filter .15s ease; }
.tabbtn .ico svg{ width:16px; height:16px; }
.tabbtn:hover{ filter: brightness(0.99) saturate(1.05); box-shadow: 0 10px 24px rgba(0,0,0,.12); }
.tabbtn:active{ transform: translateY(1px); }
.tabbtn.active{
  background: linear-gradient(90deg, var(--ka-pink), var(--ka-orange));
  color:#fff;
  border-color: transparent;
}

/* Admin nav pills */
.navtabs{ display:flex; gap:8px; flex-wrap:wrap; align-items:center; }
.navtab{ display:inline-flex; align-items:center; gap:8px; padding:8px 12px; border:1px solid rgba(0,0,0,.12); border-radius:12px; background: rgba(255,255,255,.75); color:#111; text-decoration:none; }
.navtab .ico svg{ width:16px; height:16px; }
.navtab.active{
  background: linear-gradient(90deg, var(--ka-pink), var(--ka-orange));
  color:#fff;
  border-color: transparent;
}

hr { border:0; height:1px; background: rgba(0,0,0,.12); margin:18px 0; }

a { color:#2b2bff; text-decoration: none; }
a:hover{ text-decoration: underline; }

button, input, select, textarea { font-family: inherit; }


/* Tables */
.table-wrap{
  border:1px solid rgba(0,0,0,.10);
  border-radius: 14px;
  overflow:auto;
  -webkit-overflow-scrolling: touch;
  background: rgba(255,255,255,.70);
}
.table,
.k-table{
  width:100%;
  border-collapse: separate;
  border-spacing: 0;
}
.table th, .table td,
.k-table th, .k-table td{
  padding: 10px 12px;
  border-bottom: 1px solid rgba(0,0,0,.10);
  font-size: 14px;
}
.table th,
.k-table th{
  background: rgba(255,255,255,.90);
  font-weight: 700;
  text-align:left;
  position: sticky;
  top: 0;
  z-index: 1;
}
.table tbody tr:nth-child(even) td,
.k-table tbody tr:nth-child(even) td{
  background: rgba(255,255,255,.82);
}
.table tbody tr:hover td,
.k-table tbody tr:hover td{
  background: rgba(255,255,255,.95);
}
.table tr:last-child td,
.k-table tr:last-child td{ border-bottom:0; }

.ta-right{ text-align:right; }

/* Forms */
.form-grid{ display:grid; gap:12px; max-width:640px; }

/* Consistent inline rows for forms (dashboard modal + admin) */
.form-row{
  display:flex;
  gap:12px;
  flex-wrap:wrap;
}
.form-row > .field,
.form-row > .form-group{
  flex:1;
  min-width:0; /* allow inputs (date) to shrink and not overflow */
}
.form-row input,
.form-row select,
.form-row textarea{
  width:100%;
  box-sizing:border-box;
  min-width:0;
}

/* Make labels + inputs behave consistently */
.field label{ display:block; }
.field input, .field select, .field textarea{
  padding:8px;
  border-radius:10px;
  border:1px solid rgba(0,0,0,.14);
  background: rgba(255,255,255,.92);
}

/* 2-column rows stack on mobile */
@media (max-width: 640px){
  .form-row{ flex-direction:column; }
}
.field{ display:grid; gap:6px; }
.field label{ font-size: 12px; color: var(--muted); }
.field input, .field select, .field textarea{ width:100%; }
.form-actions{ display:flex; gap:10px; align-items:center; flex-wrap:wrap; margin-top:4px; }
.section-title{ font-size:20px; font-weight:800; margin: 10px 0 12px; }
.section-sub{ color: var(--muted); font-size: 12px; margin-top:-8px; margin-bottom: 12px; }

/* Buttons */
.btn-sm{ padding:6px 10px; border-radius:10px; font-size:13px; }
.btn-danger{ background:#e11d48; border-color:#e11d48; color:#fff; }
.btn-danger:hover{ filter: brightness(0.95); }

/* Badges */
.badge{ display:inline-flex; align-items:center; padding:3px 8px; border-radius:999px; font-size:12px; border:1px solid rgba(0,0,0,.12); background: rgba(255,255,255,.85); }
.badge-ok{ background:#d4edda; border-color:#c3e6cb; }
.badge-warn{ background:#fff3cd; border-color:#ffeeba; }



.muted{ color: var(--muted); }

.tabbtn{
  background: rgba(255,255,255,.9);
  border: 1px solid var(--card-brd);
}

/* -----------------------------
   Modern UI helpers
------------------------------*/
.topbar-row{ display:flex; justify-content:space-between; align-items:center; gap:12px; flex-wrap:wrap; }
.topbar-left{ display:flex; align-items:center; gap:12px; min-width: 200px; }
.topbar-right{ display:flex; align-items:center; gap:10px; flex-wrap:wrap; justify-content:flex-end; }

.build-badge{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:6px 10px;
  border:1px solid var(--card-brd);
  border-radius:999px;
  font-size:12px;
  background: rgba(255,255,255,.86);
}

.btn{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:8px 10px;
  border-radius: 12px;
  border:1px solid rgba(0,0,0,.18);
  background: rgba(255,255,255,.92);
  cursor:pointer;
  text-decoration:none;
  color:#111;
  line-height: 1;
}
.btn:hover{ filter: brightness(0.98); }
.btn:active{ transform: translateY(1px); }

.btn-primary{
  background: linear-gradient(90deg, var(--ka-pink), var(--ka-orange));
  border-color: transparent;
  color:#fff;
}

.btn-ghost{
  background: rgba(255,255,255,.70);
}

.btn-link{
  border:none;
  background: transparent;
  padding:8px 8px;
}

.ico{ display:inline-flex; }
.ico svg{ width:16px; height:16px; display:block; }

/* Tab buttons (dashboard + admin) */
.tabbtn{ display:inline-flex; align-items:center; gap:8px; }
.tabbtn .ico svg{ width:15px; height:15px; }

/* Admin nav tabs */
.navtabs{ display:flex; gap:8px; flex-wrap:wrap; align-items:center; }
.navtab{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:8px 12px;
  border:1px solid rgba(0,0,0,.12);
  border-radius: 12px;
  background: rgba(255,255,255,.88);
  text-decoration:none;
  color:#111;
}
.navtab:hover{ filter: brightness(0.98); }
.navtab.active{
  background: linear-gradient(90deg, var(--ka-pink), var(--ka-purple));
  border-color: transparent;
  color:#fff;
}
.navtab.active .ico svg{ filter: none; }


/* Modal actions (dashboard add project) */
.modal-actions{ display:flex; gap:10px; justify-content:flex-end; margin-top:6px; }


/* =========================
   Admin - unified layout
   ========================= */
.admin-split{display:flex;gap:24px;align-items:flex-start;flex-wrap:wrap;}
.admin-panel{background:rgba(255,255,255,.88);border:1px solid rgba(0,0,0,.06);border-radius:18px;padding:14px 14px 16px;box-shadow:0 10px 30px rgba(0,0,0,.06);}
.admin-panel--list{flex:0 0 380px;min-width:340px;}
.admin-panel--detail{flex:1;min-width:420px;}
.subcard{background:rgba(255,255,255,.75);border:1px solid rgba(0,0,0,.08);border-radius:16px;padding:12px;margin:12px 0;}
.subcard hr{border:0;border-top:1px solid rgba(0,0,0,.08);margin:12px 0;}
.form-inline{display:flex;gap:12px;align-items:flex-end;flex-wrap:wrap;}
.form-inline .field{min-width:180px;flex:0 0 auto;}
.form-inline .field label{display:block;font-size:12px;opacity:.8;margin-bottom:6px;}
.form-inline input,.form-inline select{padding:10px 12px;border:1px solid rgba(0,0,0,.14);border-radius:12px;background:#fff;min-height:40px;}
.form-inline input[type=number]{width:140px;}
.form-inline input[type=text]{width:240px;}
.form-inline button{white-space:nowrap;}
.kpi-title{font-size:16px;font-weight:800;margin:0 0 10px;}

.table-compact th,.table-compact td{padding:8px 10px;font-size:13px;}


/* Admin: compact widget editor (collapsible) */
.td-actions{white-space:nowrap; min-width:150px;}
.widget-edit{display:inline-block; margin-right:8px;}
.widget-edit > summary{list-style:none; cursor:pointer; user-select:none;}
.widget-edit > summary::-webkit-details-marker{display:none;}
.widget-edit[open] > summary{filter:brightness(.98);}
.widget-edit__body{
  margin-top:8px;
  padding:10px;
  background: rgba(255,255,255,.92);
  border:1px solid rgba(0,0,0,.12);
  border-radius: 14px;
  box-shadow: 0 8px 18px rgba(0,0,0,.08);
  max-width: 640px;
}
.widget-edit__body form{
  display:flex;
  gap:8px;
  align-items:flex-end;
  flex-wrap:wrap;
}
.widget-edit__body input,
.widget-edit__body select{
  max-width: 190px;
}
