/* assets/css/admin.css
   BMD admin UI additions
*/

.admin-auth{
  min-height: calc(100vh - 120px);
  display:grid;
  place-items:center;
  padding:70px 0;
}

.admin-auth-card{
  width:min(520px, 100%);
  padding:26px 24px 20px;
  box-shadow: var(--shadow);
}

.admin-badge{
  font-size:11px;
  letter-spacing:.14em;
  text-transform:uppercase;
  color: rgba(255,255,255,.78);
  margin-bottom:10px;
}

.admin-title{
  margin:0 0 10px;
  font-family: var(--font-display);
  letter-spacing:.06em;
  text-transform:uppercase;
  font-size:24px;
}

.admin-sub{
  margin:0 0 16px;
  color: rgba(232,232,238,.78);
  font-size:13px;
  line-height:1.6;
}

.admin-alert{
  border: 1px solid rgba(255,45,45,.35);
  background: rgba(255,45,45,.10);
  border-radius: 16px;
  padding:10px 12px;
  margin: 0 0 14px;
  font-size:13px;
}

.admin-form{
  display:flex;
  flex-direction:column;
  gap:10px;
}

.admin-label{
  font-size:11px;
  letter-spacing:.12em;
  text-transform:uppercase;
  color: rgba(184,186,198,.95);
  font-weight:800;
}

.admin-input{
  width:100%;
  height:44px;
  padding:0 14px;
  border-radius:16px;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.04);
  color: var(--text);
  outline:none;
}

.admin-input:focus{
  border-color: rgba(255,45,45,.35);
  box-shadow: 0 0 0 3px rgba(255,45,45,.10);
}

.admin-actions{
  display:flex;
  justify-content:flex-end;
  margin-top:6px;
}

.admin-footnote{
  margin-top:10px;
  color: rgba(184,186,198,.85);
  font-size:12px;
}

/* Dashboard */
.admin-top{ padding:48px 0 18px; }
.admin-topbar{
  padding:18px 18px;
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap:18px;
  box-shadow: var(--shadow-soft);
}
.admin-topbar-right{
  display:flex;
  align-items:center;
  gap:12px;
}
.admin-user{ text-align:right; }
.admin-user-k{
  display:block;
  font-size:11px;
  letter-spacing:.12em;
  text-transform:uppercase;
  color: rgba(184,186,198,.95);
}
.admin-user-v{ font-size:13px; }




/* --- Board tiles (shared) --- */
.gb-hidden{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}

.gb-split{display:grid;grid-template-columns:1fr 1fr;gap:14px}
@media(max-width:980px){.gb-split{grid-template-columns:1fr}}

.gb-media-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:10px}

.gb-tiles{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}
@media(max-width:980px){.gb-tiles{grid-template-columns:repeat(3,1fr)}}
@media(max-width:560px){.gb-tiles{grid-template-columns:repeat(2,1fr)}}

.gb-tile{
  position:relative;border-radius:18px;border:1px solid rgba(255,255,255,.12);
  background:rgba(255,255,255,.04);overflow:hidden;min-height:120px;cursor:pointer;
  transition:transform .18s ease,border-color .18s ease,background .18s ease
}
.gb-tile:hover{transform:translateY(-1px);border-color:rgba(255,45,45,.24);background:rgba(255,255,255,.06)}
.gb-tile.is-add{display:grid;place-items:center}

.gb-plus{
  width:52px;height:52px;border-radius:18px;border:1px solid rgba(255,255,255,.14);
  background:rgba(255,255,255,.03);display:grid;place-items:center;font-size:26px;
  line-height:1;color:rgba(232,232,238,.92)
}
.gb-addlabel{
  margin-top:8px;font-size:11px;letter-spacing:.12em;text-transform:uppercase;
  color:rgba(184,186,198,.95);font-weight:900;text-align:center;padding:0 10px
}

.gb-thumbimg{width:100%;height:140px;object-fit:cover;display:block}
.gb-fn{
  padding:8px 10px;border-top:1px solid rgba(255,255,255,.08);
  font-size:12px;color:rgba(184,186,198,.95);white-space:nowrap;overflow:hidden;text-overflow:ellipsis
}
.gb-x{
  position:absolute;top:8px;right:8px;width:30px;height:30px;border-radius:12px;
  border:1px solid rgba(255,255,255,.14);background:rgba(10,10,14,.45);
  display:grid;place-items:center;color:#fff;font-weight:900;cursor:pointer;opacity:.95;z-index:2
}
.gb-x:hover{border-color:rgba(255,45,45,.35)}

.admin-grid-wrap{ padding:18px 0 18px; }
.admin-grid{
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap:18px;
}

.admin-card{
  padding:18px 18px 16px;
  box-shadow: var(--shadow-soft);
  transition: transform .18s ease, border-color .18s ease, background .18s ease;
}
.admin-card:hover{
  transform: translateY(-2px);
  border-color: rgba(255,45,45,.22);
}

.admin-card-tag{
  font-size:11px;
  letter-spacing:.14em;
  text-transform:uppercase;
  color: rgba(255,255,255,.78);
  margin-bottom:10px;
}
.admin-card-title{
  font-weight:900;
  letter-spacing:.02em;
  margin-bottom:8px;
}
.admin-card-text{
  color: rgba(232,232,238,.78);
  font-size:13px;
  line-height:1.6;
  margin-bottom:14px;
}
.admin-card-foot{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
}
.admin-pill{
  display:inline-flex;
  align-items:center;
  height:28px;
  padding:0 10px;
  border-radius:999px;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.04);
  font-size:11px;
  color: rgba(232,232,238,.88);
}
.admin-go{
  font-size:12px;
  font-weight:800;
  letter-spacing:.02em;
}

.admin-quick{ padding:0 0 60px; }
.admin-quick-card{
  padding:18px 18px;
  box-shadow: var(--shadow-soft);
}
.admin-quick-title{
  font-size:11px;
  letter-spacing:.14em;
  text-transform:uppercase;
  color: rgba(184,186,198,.95);
  font-weight:900;
  margin-bottom:12px;
}
.admin-quick-row{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
}
.admin-quick-note{
  margin-top:12px;
  color: rgba(184,186,198,.85);
  font-size:12px;
  line-height:1.6;
}

@media (max-width: 980px){
  .admin-grid{ grid-template-columns: 1fr; }
  .admin-topbar{ flex-direction:column; align-items:flex-start; }
  .admin-topbar-right{ width:100%; justify-content:space-between; }
}


/* ---------------------------------------
   Admin field normalization (WIPBoard + boards)
   Maps .label/.input/.textarea/.select to admin style
---------------------------------------- */

.admin-form .label,
.admin-quick-card .label{
  display:block;
  font-size:11px;
  letter-spacing:.12em;
  text-transform:uppercase;
  color: rgba(184,186,198,.95);
  font-weight:800;
  margin: 0 0 6px;
}

.admin-form .input,
.admin-form .select,
.admin-form .textarea,
.admin-quick-card .input,
.admin-quick-card .select,
.admin-quick-card .textarea{
  width:100%;
  box-sizing:border-box;
  border-radius:16px;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.04);
  color: var(--text);
  outline:none;
  font-size:13px;
}

.admin-form .input,
.admin-quick-card .input{
  height:44px;
  padding:0 14px;
}

.admin-form .select,
.admin-quick-card .select{
  height:44px;
  padding:0 14px;
  appearance:none;
}

.admin-form .textarea,
.admin-quick-card .textarea{
  min-height:110px;
  padding:12px 14px;
  line-height:1.55;
  resize:vertical;
}

.admin-form .input:focus,
.admin-form .select:focus,
.admin-form .textarea:focus,
.admin-quick-card .input:focus,
.admin-quick-card .select:focus,
.admin-quick-card .textarea:focus{
  border-color: rgba(255,45,45,.35);
  box-shadow: 0 0 0 3px rgba(255,45,45,.10);
}

/* optional: nicer disabled */
.admin-form .input:disabled,
.admin-form .select:disabled,
.admin-form .textarea:disabled{
  opacity:.65;
  cursor:not-allowed;
}

/* keep your invalid highlight consistent */
.admin-form .invalid,
.admin-quick-card .invalid{
  border: 1px solid rgba(255,90,90,.35) !important;
  box-shadow: 0 0 0 3px rgba(255,90,90,.10) !important;
}
