/* COMPONENTS — reusable UI building blocks: KPI cards, cards, tables,
   buttons, modals, dropdowns, status pills, progress bars.
   Edit this file to change how cards/tables/buttons look across the whole app. */

/* KPI cards (the colored stat boxes at the top of each page) */
.kpi-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:14px;margin-bottom:22px}
.kpi{background:var(--s1);border:1px solid var(--bd);border-radius:10px;padding:16px;position:relative;overflow:hidden;transition:border-color .2s,transform .2s;cursor:default}
.kpi:hover{transform:translateY(-2px);border-color:var(--ac);box-shadow:0 0 18px rgba(255,107,0,.1)}
.kpi::after{content:'';position:absolute;top:0;left:0;right:0;height:2px;border-radius:10px 10px 0 0}
.kpi.c-blue::after{background:var(--ac)}.kpi.c-cyan::after{background:var(--ac2)}.kpi.c-purple::after{background:var(--ac3)}.kpi.c-green::after{background:var(--gn)}.kpi.c-yellow::after{background:var(--yw)}.kpi.c-red::after{background:var(--rd)}.kpi.c-orange::after{background:var(--or)}
.kpi-lbl{font-size:10px;font-weight:600;letter-spacing:.8px;text-transform:uppercase;color:var(--tx2);margin-bottom:6px}
.kpi-val{font-family:var(--mono);font-size:24px;font-weight:700;line-height:1;margin-bottom:6px}
.kpi.c-blue .kpi-val{color:var(--ac)}.kpi.c-cyan .kpi-val{color:var(--ac2)}.kpi.c-purple .kpi-val{color:var(--ac3)}.kpi.c-green .kpi-val{color:var(--gn)}.kpi.c-yellow .kpi-val{color:var(--yw)}.kpi.c-red .kpi-val{color:var(--rd)}.kpi.c-orange .kpi-val{color:var(--or)}
.kpi-sub{font-size:11px;color:var(--tx3);display:flex;align-items:center;gap:4px;font-family:var(--mono)}
.up{color:var(--gn)}.dn{color:var(--rd)}.nt{color:var(--tx2)}

/* Generic card (used as panel/container around charts and tables) */
.card{background:var(--s1);border:1px solid var(--bd);border-radius:10px;padding:18px}
.card-hdr{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:16px;gap:12px}
.card-title{font-size:13px;font-weight:700}
.card-sub{font-size:11px;color:var(--tx2);margin-top:2px}

/* Chips (small colored tags) */
.chip{font-size:10px;font-family:var(--mono);padding:2px 7px;border-radius:4px;white-space:nowrap}
.chip-blue{background:rgba(255,107,0,.1);color:var(--ac);border:1px solid rgba(255,107,0,.2)}
.chip-green{background:rgba(16,185,129,.1);color:var(--gn);border:1px solid rgba(16,185,129,.2)}
.chip-yellow{background:rgba(245,158,11,.1);color:var(--yw);border:1px solid rgba(245,158,11,.2)}
.chip-red{background:rgba(239,68,68,.1);color:var(--rd);border:1px solid rgba(239,68,68,.2)}

/* Chart wrapper */
.ch-wrap{position:relative}

/* Progress bars */
.prog{display:flex;align-items:center;gap:8px;margin-bottom:2px}
.prog-bar{flex:1;height:5px;background:var(--bd);border-radius:3px;overflow:hidden;min-width:50px}
.prog-fill{height:100%;border-radius:3px;transition:width .5s ease}
.pf-gn{background:var(--gn)}.pf-yw{background:var(--yw)}.pf-rd{background:var(--rd)}.pf-bl{background:var(--ac)}.pf-cy{background:var(--ac2)}
.prog-pct{font-family:var(--mono);font-size:11px;color:var(--tx2);min-width:32px;text-align:right}
.prog-val{font-family:var(--mono);font-size:11px;min-width:60px;text-align:right}

/* Achievement bar (used inside team cards) */
.ach-bar{width:100%;height:4px;background:var(--bd);border-radius:2px;margin-top:4px;overflow:hidden}
.ach-fill{height:100%;border-radius:2px;transition:width .5s}

/* Tables (generic — used in MTD, Daily-by-Exec) */
.tbl-wrap{overflow-x:auto;border-radius:8px;border:1px solid var(--bd)}
table{width:100%;border-collapse:collapse;font-size:12px}
thead tr{background:var(--s2)}
th{padding:10px 12px;text-align:left;font-size:10px;font-weight:600;letter-spacing:.8px;text-transform:uppercase;color:var(--tx2);cursor:pointer;white-space:nowrap;user-select:none;border-bottom:1px solid var(--bd)}
th:hover{color:var(--tx)}
th.sa::after{content:' ↑';color:var(--ac)}th.sd::after{content:' ↓';color:var(--ac)}
tbody tr{border-bottom:1px solid rgba(44,44,44,.5);transition:background .1s}
tbody tr:hover{background:rgba(255,107,0,.04)}
tbody tr:last-child{border-bottom:none}
td{padding:9px 12px;vertical-align:middle}
td.mono{font-family:var(--mono);font-size:11px}

/* Rank badges (1, 2, 3, …) */
.rk{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:5px;font-family:var(--mono);font-size:10px;font-weight:700}
.rk1{background:rgba(245,158,11,.12);color:var(--yw);border:1px solid rgba(245,158,11,.25)}
.rk2{background:rgba(148,163,184,.08);color:#94a3b8;border:1px solid rgba(148,163,184,.18)}
.rk3{background:rgba(249,115,22,.1);color:var(--or);border:1px solid rgba(249,115,22,.2)}
.rkn{background:rgba(71,85,105,.08);color:var(--tx3);border:1px solid rgba(71,85,105,.15)}

/* Status pills (small colored labels for ach %) */
.st{display:inline-flex;align-items:center;padding:2px 7px;border-radius:4px;font-size:10px;font-weight:600;font-family:var(--mono)}
.st-gn{background:rgba(16,185,129,.1);color:var(--gn)}.st-rd{background:rgba(239,68,68,.1);color:var(--rd)}.st-yw{background:rgba(245,158,11,.1);color:var(--yw)}.st-nt{background:rgba(148,163,184,.08);color:var(--tx2)}

/* Form controls (search inputs, dropdowns above tables) */
.ctrl{display:flex;gap:10px;margin-bottom:16px;flex-wrap:wrap;align-items:center}
input[type=text],select{padding:8px 12px;background:var(--s1);border:1px solid var(--bd);border-radius:7px;color:var(--tx);font-family:var(--sans);font-size:13px;outline:none;transition:border-color .2s}
input[type=text]:focus,select:focus{border-color:rgba(255,107,0,.4)}
input[type=text]::placeholder{color:var(--tx3)}
input[type=text].srch{flex:1;min-width:180px}
.cnt{font-family:var(--mono);font-size:11px;color:var(--tx2);margin-left:auto}

/* Pagination */
.pager{display:flex;gap:6px;margin-top:14px;justify-content:center;flex-wrap:wrap}
.pg{padding:5px 10px;background:var(--s1);border:1px solid var(--bd);color:var(--tx);border-radius:5px;cursor:pointer;font-family:var(--mono);font-size:11px;transition:all .15s}
.pg:hover,.pg.on{background:rgba(255,107,0,.1);border-color:var(--ac);color:var(--ac)}
.pg:disabled{opacity:.3;cursor:not-allowed}

/* Modal (backdrop + dialog box used by "Update Daily Data" popup) */
.modal-bg{display:none;position:fixed;inset:0;background:rgba(0,0,0,.7);backdrop-filter:blur(4px);z-index:500;align-items:center;justify-content:center}
.modal-bg.show{display:flex}
.modal{background:var(--s2);border:1px solid var(--bd2);border-radius:14px;padding:28px;width:min(580px,95vw);max-height:90vh;overflow-y:auto;position:relative}
.modal h2{font-size:18px;font-weight:700;margin-bottom:6px}
.modal-sub{font-size:13px;color:var(--tx2);margin-bottom:24px}
.modal-close{position:absolute;top:16px;right:16px;background:var(--s3);border:1px solid var(--bd);border-radius:6px;color:var(--tx2);width:28px;height:28px;cursor:pointer;font-size:16px;display:flex;align-items:center;justify-content:center}
.modal-close:hover{color:var(--tx)}
.tabs-mini{display:flex;gap:8px;margin-bottom:16px;flex-wrap:wrap}
.tab-mini{padding:6px 14px;background:var(--s2);border:1px solid var(--bd);border-radius:6px;color:var(--tx2);font-size:12px;cursor:pointer;transition:all .15s}
.tab-mini.active,.tab-mini:hover{background:rgba(255,107,0,.1);border-color:var(--ac);color:var(--ac)}
.scroll-x{overflow-x:auto}

/* Buttons */
.btn{padding:9px 18px;border:none;border-radius:7px;font-family:var(--sans);font-size:13px;font-weight:600;cursor:pointer;transition:all .2s}
.btn-primary{background:var(--ac);color:#fff}
.btn-primary:hover{background:#e55a00}
.btn-outline{background:transparent;border:1px solid var(--bd);color:var(--tx)}
.btn-outline:hover{border-color:var(--ac);color:var(--ac)}
.btn-row{display:flex;gap:10px;justify-content:flex-end}

/* Form fields (inside modal) */
.field-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:20px}
.field{display:flex;flex-direction:column;gap:5px}
.field label{font-size:11px;font-weight:600;letter-spacing:.4px;color:var(--tx2)}
.field input{padding:9px 12px;background:var(--s3);border:1px solid var(--bd);border-radius:7px;color:var(--tx);font-family:var(--mono);font-size:13px;outline:none;transition:border-color .2s;width:100%}
.field input:focus{border-color:var(--ac)}
.field.full{grid-column:1/-1}
.field select{padding:9px 12px;background:var(--s3);border:1px solid var(--bd);border-radius:7px;color:var(--tx);font-size:13px;outline:none}

/* Success / error banners */
.success-msg{display:none;padding:12px 16px;background:rgba(16,185,129,.1);border:1px solid rgba(16,185,129,.25);border-radius:8px;color:var(--gn);font-size:13px;margin-bottom:16px;text-align:center}
.success-msg.show{display:block}

/* Team cards (Daily-by-Team page, currently hidden) */
.team-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:14px}
.team-card{background:var(--s1);border:1px solid var(--bd);border-radius:10px;padding:16px;transition:border-color .2s}
.team-card:hover{border-color:var(--ac);box-shadow:0 0 14px rgba(255,107,0,.08)}
.tc-hdr{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:12px}
.tc-name{font-size:13px;font-weight:700;margin-bottom:2px}
.tc-terr{font-size:11px;color:var(--tx2);font-family:var(--mono)}
.tc-metrics{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-top:10px}
.tc-m{background:var(--s2);border-radius:6px;padding:8px 10px}
.tc-m-lbl{font-size:9px;letter-spacing:.6px;text-transform:uppercase;color:var(--tx3);margin-bottom:3px}
.tc-m-val{font-family:var(--mono);font-size:14px;font-weight:700}
.tc-m-sub{font-size:10px;color:var(--tx3);font-family:var(--mono)}
.divider{height:1px;background:var(--bd);margin:12px 0}
