/* ================================
   ROOT VARIABLES
================================ */
:root{
  --bf-green:#16a34a;
  --bf-green-dark:#15803d;
  --bf-border:#e5e7eb;
  --bf-bg:#f8fafc;
  --bf-blue:#2563eb;
  --bf-gray:#64748b;
}

/* ================================
   GLOBAL WRAPPER
================================ */
.bf-wrap{
  max-width:1100px;
  margin:30px auto;
  font-family:system-ui,-apple-system,BlinkMacSystemFont;
  color:#1f2937;
}

/* ================================
   HEADINGS
================================ */
.bf-wrap h2{
  margin-bottom:14px;
  font-size:22px;
  font-weight:700;
}

/* ================================
   FORM
================================ */
.bf-form{
  background:#fff;
  padding:22px;
  border:1px solid var(--bf-border);
  border-radius:14px;
  box-shadow:0 4px 12px rgba(0,0,0,.04);
}

.bf-form label{
  display:block;
  font-weight:600;
  margin-top:14px;
  color:#0f172a;
}

.bf-form input,
.bf-form textarea,
.bf-form select{
  width:100%;
  padding:12px 14px;
  border-radius:10px;
  border:1px solid #d1d5db;
  font-size:14px;
  background:#f9fafb;
  transition:.2s ease;
}

.bf-form textarea{min-height:100px}

.bf-form input:focus,
.bf-form textarea:focus,
.bf-form select:focus{
  border-color:var(--bf-green);
  background:#fff;
  outline:none;
  box-shadow:0 0 0 3px rgba(34,197,94,.18);
}

/* ================================
   ROW LAYOUT
================================ */
.bf-row{
  display:flex;
  gap:14px;
  margin-top:12px;
  background:#fff;
  border:1px solid var(--bf-border);
  border-radius:14px;
  padding:14px;
  box-shadow:0 4px 12px rgba(0,0,0,.04);
  align-items:center;
}

@media (min-width:769px){
  .bf-row{
    display:grid;
    grid-template-columns:1.2fr 1.5fr 1.2fr 1fr 1fr 1fr auto;
    gap:12px;
  }
}

@media (max-width:768px){
  .bf-row{flex-direction:column}
}

/* ================================
   FILTER BAR
================================ */
.bf-filter-bar{
  background:#fff;
  border:1px solid var(--bf-border);
  border-radius:12px;
  padding:8px 10px;
  box-shadow:0 4px 12px rgba(0,0,0,.04);
  overflow:hidden;
}

@media (min-width:769px){
  .bf-filter-bar{
    display:grid;
    grid-template-columns:1.1fr 1.6fr 1.2fr 1fr 1fr 1fr auto;
    gap:12px;
    align-items:center;
  }
}

@media (max-width:768px){
  .bf-filter-bar{
    display:grid;
    grid-template-columns:1fr;
    gap:10px;
  }
}

.bf-filter-bar select,
.bf-filter-bar input{
  height:36px;
  padding:6px 10px;
  font-size:13.5px;
  border-radius:8px;
  border:1px solid #d1d5db;
  min-width:0;
  width:100%;
  background:#fff;
}

.bf-filter-bar input::placeholder{
  color:#9ca3af;
  font-size:13px;
}

/* Checkbox */
.bf-filter-bar label{
  display:flex;
  align-items:center;
  gap:6px;
  background:none;
  border:none;
  padding:0;
  font-size:13.5px;
  font-weight:500;
  color:#0f172a;
  white-space:nowrap;
}

.bf-filter-bar input[type="checkbox"]{
  width:16px;
  height:16px;
  margin:0;
  accent-color:var(--bf-blue);
  cursor:pointer;
}

/* ================================
   BUTTONS
================================ */
.bf-view-btn{
  background:linear-gradient(135deg,#22c55e,#16a34a);
  border:none;
  color:#fff;
  font-weight:600;
  border-radius:999px;
  padding:6px 14px;
  font-size:13px;
  cursor:pointer;
  transition:.2s ease;
  box-shadow:0 3px 8px rgba(22,163,74,.35);
}


.bf-btn:hover,
.bf-view-btn:hover{
  background:linear-gradient(135deg,#16a34a,#15803d);
  transform:translateY(-1px);
  box-shadow:0 4px 10px rgba(22,163,74,.4);
}

/* Secondary button (Search) */
.bf-btn.secondary{
  background:#64748b;
  color:#ffffff;
  box-shadow:none;
}

.bf-btn.secondary:hover{
  background:#475569;
}

.bf-btn.secondary:hover{
  background:#475569;
}

.bf-btn.danger{background:#dc2626}

.bf-btn:disabled{
  background:#9ca3af;
  cursor:not-allowed;
}

/* Filter buttons compact */
.bf-filter-actions{
  display:flex;
  gap:10px;
  align-items:center;
}

.bf-filter-actions .bf-btn{
  height:34px;
  padding:0 14px;
  font-size:13.5px;
  line-height:34px;
  border-radius:9px;
  margin-top:0;
}

.bf-clear-btn{
  background:#f1f5f9 !important;
  color:#334155 !important;
  box-shadow:none !important;
}

.bf-clear-btn:hover{
  background:#e2e8f0 !important;
}

/* ================================
   TABLE
================================ */
.bf-table{
  width:100%;
  border-collapse:collapse;
  margin-top:16px;
  background:#fff;
  border-radius:14px;
  overflow:hidden;
  table-layout:fixed;
  box-shadow:0 4px 10px rgba(0,0,0,.04);
}

.bf-table th,
.bf-table td{
  padding:12px;
  border:1px solid var(--bf-border);
  text-align:left;
  vertical-align:top;
}

.bf-table th{
  background:#f0fdf4;
  font-weight:600;
  color:#065f46;
}

.bf-table tr:hover{background:#f0fdf4}

.bf-table td:nth-child(3){
  max-width:220px;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
  cursor:help;
}

/* ================================
   MOBILE TABLE VIEW
================================ */
@media (max-width:768px){

  .bf-table thead{display:none}

  .bf-table,
  .bf-table tbody,
  .bf-table tr,
  .bf-table td{
    display:block;
    width:100%;
  }

  .bf-table tr{
    margin-bottom:14px;
    background:#fff;
    border:1px solid var(--bf-border);
    border-radius:12px;
    padding:10px 12px;
    box-shadow:0 2px 6px rgba(0,0,0,.05);
  }

  .bf-table td{
    border:none;
    padding:6px 0;
    font-size:14px;
  }

  .bf-table td:before{
    content:attr(data-label);
    font-weight:600;
    display:block;
    color:#475569;
    font-size:12px;
    margin-bottom:2px;
  }

  .bf-view-btn{
    width:100%;
    padding:10px;
    border-radius:10px;
  }
}

/* ================================
   PAGINATION
================================ */
.bf-pagination{
  margin-top:18px;
  display:flex;
  gap:8px;
  justify-content:center;
}

.bf-page{
  padding:6px 12px;
  border-radius:6px;
  border:1px solid #d1d5db;
  cursor:pointer;
  background:#fff;
}

.bf-page.active{
  background:var(--bf-blue);
  color:#fff;
  border-color:var(--bf-blue);
}

/* ================================
   MODAL
================================ */
.bf-modal{
  position:fixed;
  top:0;
  left:0;
  width:100%;
  height:100%;
  background:rgba(0,0,0,.55);
  display:none;
  justify-content:center;
  align-items:center;
  z-index:99999;
}

.bf-modal-content{
  background:#fff;
  width:90%;
  max-width:700px;
  max-height:80vh;
  overflow:auto;
  padding:22px;
  border-radius:16px;
  box-shadow:0 10px 30px rgba(0,0,0,.25);
  position:relative;
}

.bf-close{
  position:absolute;
  right:15px;
  top:10px;
  font-size:24px;
  cursor:pointer;
}

#bfModalBody pre{
  background:#f8fafc;
  border-left:4px solid var(--bf-green);
  padding:10px;
  border-radius:6px;
  white-space:pre-wrap;
}
/* Fix checkbox UI inside bf-form */
.bf-form input[type="checkbox"]{
  width:auto;
  padding:0;
  border-radius:4px;
  background:transparent;
  box-shadow:none;
}
