/* ============================================================
   COMPONENTS — Cards, Badges, Buttons, Forms, Tables, Modals
   ============================================================ */

/* GRIDS */
.g2{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.g3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:14px}
.g4{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
@media(max-width:768px){.g2,.g3,.g4{grid-template-columns:1fr}}

/* CARDS */
.card{background:#fff;border:1px solid var(--paper3);border-radius:var(--r);padding:20px;box-shadow:var(--shadow)}
.card-xs{padding:14px}
.card-hover{cursor:pointer;transition:all .2s}
.card-hover:hover{border-color:var(--gold);box-shadow:var(--shadow2);transform:translateY(-1px)}

/* STAT */
.stat-v{font-family:'Fraunces',serif;font-size:38px;font-weight:700;line-height:1;color:var(--ink)}
.stat-l{font-size:11px;color:var(--ink3);margin-top:3px;font-weight:500;text-transform:uppercase;letter-spacing:.4px}

/* BADGE */
.badge{display:inline-flex;align-items:center;padding:2px 9px;border-radius:20px;font-size:11px;font-weight:600;gap:4px}
.b-gold{background:var(--gold-a);color:var(--gold)}
.b-red{background:var(--red-a);color:var(--red)}
.b-green{background:var(--green-a);color:var(--green)}
.b-blue{background:var(--blue-a);color:var(--blue)}
.b-gray{background:var(--paper2);color:var(--ink2)}
.b-pending{background:#fff8e1;color:#b45309;border:1px solid #fde68a}
.b-active{background:#dcfce7;color:#166534;border:1px solid #bbf7d0}
.b-blocked{background:#fee2e2;color:#991b1b;border:1px solid #fecaca}

/* FORMS */
.inp{width:100%;background:#fff;border:1.5px solid var(--paper3);color:var(--ink);padding:10px 14px;border-radius:var(--r2);font-size:13px;font-family:'Outfit',sans-serif;outline:none;transition:border .18s;margin-bottom:10px}
.inp:focus{border-color:var(--gold)}
.inp::placeholder{color:var(--ink3)}
.sel{background:#fff;border:1.5px solid var(--paper3);color:var(--ink);padding:10px 14px;border-radius:var(--r2);font-size:13px;font-family:'Outfit',sans-serif;outline:none;cursor:pointer;width:100%}
.label{font-size:11px;font-weight:600;color:var(--ink2);text-transform:uppercase;letter-spacing:.4px;display:block;margin-bottom:5px}
.field{margin-bottom:14px}

/* BUTTONS */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:7px;padding:9px 20px;border-radius:var(--r2);font-size:13px;font-weight:600;cursor:pointer;transition:all .18s;border:none;font-family:'Outfit',sans-serif;white-space:nowrap}
.btn-p{background:var(--gold);color:#fff}
.btn-p:hover{background:var(--gold2);transform:translateY(-1px);box-shadow:0 6px 20px rgba(212,130,10,.3)}
.btn-ink{background:var(--ink);color:#fff}
.btn-ink:hover{background:#333;transform:translateY(-1px)}
.btn-s{background:#fff;color:var(--ink);border:1.5px solid var(--paper3)}
.btn-s:hover{border-color:var(--ink2);background:var(--paper2)}
.btn-danger{background:var(--red-a);color:var(--red);border:1px solid rgba(196,30,58,.2)}
.btn-danger:hover{background:rgba(196,30,58,.14)}
.btn-sm{padding:6px 12px;font-size:12px}
.btn-full{width:100%}
.btn:disabled{opacity:.4;cursor:not-allowed;transform:none!important;box-shadow:none!important}

/* PROGRESS */
.prog-wrap{background:var(--paper3);border-radius:3px;height:5px;overflow:hidden}
.prog-bar{height:100%;border-radius:3px;transition:width .5s ease}
.p-gold{background:var(--gold)}
.p-green{background:var(--green)}
.p-red{background:var(--red)}

/* TABLE */
.tbl{width:100%;border-collapse:collapse}
.tbl th{font-size:10px;color:var(--ink3);font-weight:600;text-transform:uppercase;letter-spacing:.5px;padding:8px 14px;border-bottom:1.5px solid var(--paper3);text-align:left}
.tbl td{padding:11px 14px;border-bottom:1px solid var(--paper2);font-size:13px;color:var(--ink)}
.tbl tr:last-child td{border-bottom:none}
.tbl tr:hover td{background:var(--paper)}
.tbl th:first-child,.tbl td:first-child{padding-left:0}

/* NOTIFICATION */
#notif{position:fixed;top:16px;right:16px;z-index:9999;display:flex;flex-direction:column;gap:8px;pointer-events:none}
.notif-i{background:#fff;border:1px solid var(--paper3);border-radius:10px;padding:12px 18px;font-size:13px;display:flex;align-items:center;gap:10px;animation:fadeIn .3s ease;box-shadow:var(--shadow2);pointer-events:all;max-width:320px}
.notif-i.ok{border-left:3px solid var(--green)}
.notif-i.err{border-left:3px solid var(--red)}
.notif-i.info{border-left:3px solid var(--blue)}

/* MODAL */
.modal-ov{position:fixed;inset:0;background:rgba(0,0,0,.4);backdrop-filter:blur(4px);z-index:1000;display:flex;align-items:center;justify-content:center;animation:fadeIn .2s ease}
.modal{background:#fff;border-radius:14px;padding:28px;width:520px;max-width:92vw;max-height:88vh;overflow-y:auto;box-shadow:var(--shadow2)}
.modal h3{font-family:'Fraunces',serif;font-size:20px;font-weight:700;color:var(--ink);margin-bottom:4px}
.modal-sub{font-size:13px;color:var(--ink3);margin-bottom:20px}
.modal-foot{display:flex;gap:8px;margin-top:18px}

/* PAGE HEADER */
.page-hd{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:22px;gap:12px;flex-wrap:wrap}
.page-title{font-family:'Fraunces',serif;font-size:24px;font-weight:700;color:var(--ink)}
.page-sub{font-size:13px;color:var(--ink3);margin-top:3px}

/* SPINNER */
.spin{width:16px;height:16px;border:2px solid var(--paper3);border-top-color:var(--gold);border-radius:50%;animation:spin .6s linear infinite;flex-shrink:0}

/* EMPTY STATE */
.empty{text-align:center;padding:48px 20px;color:var(--ink3)}
.empty-ico{font-size:40px;margin-bottom:12px}

/* HR */
.hr{border:none;border-top:1px solid var(--paper3);margin:16px 0}

/* BAR CHART */
.bar-row{display:flex;align-items:center;gap:10px;margin-bottom:8px}
.bar-lbl{font-size:11px;color:var(--ink2);width:90px;flex-shrink:0;font-family:'JetBrains Mono',monospace}
.bar-track{flex:1;background:var(--paper2);border-radius:3px;height:16px;overflow:hidden}
.bar-fill{height:100%;border-radius:3px;transition:width .8s ease;display:flex;align-items:center;padding-left:8px}
.bar-val{font-size:10px;font-weight:600;font-family:'JetBrains Mono',monospace;color:#fff}

/* APPROVAL CARD */
.appr-card{display:flex;align-items:center;gap:14px;padding:14px;border:1px solid var(--paper3);border-radius:var(--r);margin-bottom:8px;background:#fff;transition:all .18s}
.appr-card:hover{box-shadow:var(--shadow)}

/* CAT CHIPS */
.cat-chip{padding:5px 14px;border-radius:20px;border:1.5px solid var(--paper3);font-size:12px;cursor:pointer;transition:all .18s;color:var(--ink2);background:#fff;font-family:'Outfit',sans-serif;font-weight:500}
.cat-chip:hover,.cat-chip.active{border-color:var(--gold);background:var(--gold-a);color:var(--gold);font-weight:600}

/* QTYPE GRID */
.qtype-grid{display:grid;grid-template-columns:1fr 1fr;gap:7px;margin-bottom:14px}
.qtype-item{display:flex;align-items:center;gap:8px;padding:9px 12px;border:1.5px solid var(--paper3);border-radius:8px;cursor:pointer;transition:all .18s;font-size:12px;color:var(--ink2);font-weight:500}
.qtype-item:hover,.qtype-item.qtsel{border-color:var(--gold);background:var(--gold-a);color:var(--gold)}
@media(max-width:768px){.qtype-grid{grid-template-columns:1fr}}

/* PENDING NOTICE */
.pending-banner{background:#fffbeb;border:1.5px solid #fde68a;border-radius:var(--r);padding:20px;text-align:center}

/* LEVEL DOTS */
.lv-dots{display:flex;gap:4px}
.lv-d{width:8px;height:8px;border-radius:50%;background:var(--paper3)}
.lv-d.on{background:var(--gold)}
