/* =========================================================
   KPI UI — shared styles for all KPI pages
   Pages: team.php, history.php, reports.php, targets.php, logs.php, dashboard
   ========================================================= */

/* ---------- CSS Variables ---------- */
:root{
    --bg1:#f6f8ff; --bg2:#fcfcff;
    --card-bg: rgba(255,255,255,.86);
    --card-bd: rgba(30,64,175,.08);
    --primary:#1e40af; --primary-50:#e6ebff;
    --muted:#6b7280;
}

/* ---------- Page shell (apply same look to all KPI pages) ---------- */
.kpi-page,
.team-kpi-page,
.kpi-history-page,
.kpi-reports-page,
.kpi-targets-page,
.kpi-logs-page{
    background:
            radial-gradient(1200px 800px at -10% -10%, var(--bg1), transparent 60%),
            radial-gradient(1200px 800px at 110% -10%, #f0f7ff, transparent 60%),
            linear-gradient(180deg, var(--bg2), #ffffff);
    padding: 20px 20px 30px;
    border-radius: 24px;
    font-size: 16.5px;
    line-height: 1.45;
}

/* ---------- Typography ---------- */
.page-title{ font-weight: 800; letter-spacing:.2px; font-size: 2.1rem; margin-bottom: 0; }
.section-h{
    font-size:1rem; font-weight:800; letter-spacing:.4px; text-transform:uppercase;
    color:#111827; opacity:.85; margin:0;
}
.muted{ color: var(--muted); }
.metric{
    font-size: 2.05rem; font-weight: 800; line-height: 1.05; letter-spacing: .3px;
    margin-top: 6px;
}

/* ---------- Cards (glass) ---------- */
.glass-card{
    background: var(--card-bg);
    backdrop-filter: blur(6px);
    border: 1px solid var(--card-bd);
    border-radius: 18px;
    box-shadow: 0 10px 30px rgba(30,64,175,.06);
    transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}
.glass-card .card-body{
    padding: 18px 22px;
}
.glass-card .card-body .grid-view{
    padding: 20px 20px;
}
.glass-card .card-header{
    padding: 14px 18px;
    border-bottom: 1px solid rgba(30,64,175,.10);
    background: transparent;
    border-top-left-radius: 18px; border-top-right-radius: 18px;
}
.glass-card:hover{
    transform: translateY(-2px);
    box-shadow: 0 18px 38px rgba(30,64,175,.12);
    border-color: rgba(30,64,175,.16);
}

/* ---------- Buttons / Badges / Filters ---------- */
.btn{ font-weight: 600; padding: .6rem 1rem; }
.btn-soft{
    background:#ffffff; border:1px solid rgba(30,64,175,.14);
    box-shadow:0 4px 14px rgba(30,64,175,.08);
    transition: transform .15s ease, box-shadow .15s ease, border-color .15s ease;
}
.btn-soft:hover{
    border-color: rgba(30,64,175,.28);
    box-shadow:0 10px 24px rgba(30,64,175,.15);
    transform: translateY(-1px);
}
.badge-soft{ background: var(--primary-50); color: var(--primary); border:1px solid rgba(30,64,175,.12); }

.filter-actions{ display:flex; gap:12px; align-items:end; padding-top:6px; flex-wrap:wrap; }
.form-control{ padding:.6rem .85rem; font-size:16px; }

/* Pills (Daily / Monthly selectors) */
.type-pill{
    cursor: pointer; user-select: none; padding: .45rem .9rem;
    border-radius: 999px; border: 1px solid rgba(30,64,175,.18);
}
.type-pill.active{ background:#1e40af; color:#fff; border-color:#1e40af; }

/* ---------- Progress ---------- */
.progress{
    height:10px; margin-bottom:0; background:#eef2ff;
    border-radius:8px; box-shadow: inset 0 1px 2px rgba(0,0,0,.06);
}
.progress .progress-bar{ border-radius:8px; }

/* ---------- Tables / Grids ---------- */
.kpi-table-wrap{ overflow-x:auto; }

.kpi-grid{ font-size: 15.5px; }
.kpi-grid td, .kpi-grid th{ white-space: nowrap; }
.kpi-grid thead th{
    position: sticky; top: 0; z-index: 3; background: #fff;
}
.kpi-grid tbody tr{ transition: background .12s ease; }
.kpi-grid tbody tr:hover{ background:#f7faff; }

/* Header look (use headerRowOptions => ['class'=>'kpi-head']) */
.kpi-head th{
    background: linear-gradient(180deg, #f5f7ff, #eef2ff);
    color:#1f2937; font-weight:800; letter-spacing:.2px;
    border-bottom: 2px solid rgba(30,64,175,.18) !important;
}

/* Per-grid paddings (keep modifier classes on tableOptions) */
.kpi-grid--lb th, .kpi-grid--lb td,
.kpi-grid--hist th, .kpi-grid--hist td,
.kpi-grid--rep th, .kpi-grid--rep td,
.kpi-grid--tgt th, .kpi-grid--tgt td,
.kpi-grid--logs th, .kpi-grid--logs td{
    padding: 14px 16px;
}

/* Cell alignment helpers */
.cell-center{ text-align: center; }
.cell-num{ text-align: right; font-variant-numeric: tabular-nums; }
.cell-muted{ color: #6b7280; }

/* KPI chip (used for highlighted numbers) */
.kpi-chip{
    display:inline-block; padding:.25rem .55rem; border-radius:999px;
    font-weight:700; border:1px solid rgba(30,64,175,.12);
}
.kpi-chip.total{ background:#eef2ff; color:#1e40af; }
.kpi-chip.type { background:#f2f7ff; color:#1e40af; }

/* ---------- Utility / Components ---------- */
.table-borderless tr td{ padding:8px 0; }
.table-borderless tr + tr td{ border-top:1px dashed rgba(30,64,175,.10); padding-top:10px; }

/* Top performers — small details */
.rank-badge{
    width: 40px; height: 40px; border-radius: 999px;
    display: inline-flex; align-items:center; justify-content:center; font-weight:800;
}
.tp-card .name{ font-weight: 700; }

/* Legend dot (used in charts/summary hints) */
.legend-dot{
    width:10px; height:10px; border-radius:50%;
    display:inline-block; background:#0d6efd; margin-right:6px;
}

/* ---------- Responsive tweaks ---------- */
@media (max-width: 991.98px){
    .page-title{ font-size: 1.8rem; }
    .metric{ font-size: 1.8rem; }
    .kpi-grid{ font-size: 15px; }
}
@media (max-width: 575.98px){
    .page-title{ font-size: 1.6rem; }
    .metric{ font-size: 1.6rem; }
    .kpi-grid{ font-size: 14.5px; }
}
/* === Bigger inputs + icons INSIDE the field === */
.form-field{ position:relative; }
.form-field .form-control{
    height:56px; padding:0 3rem 0 3rem; font-size:1.05rem; border-radius:.8rem;
}
.form-field .form-control:focus{
    border-color:#97acff; box-shadow:0 0 0 .2rem rgba(30,64,175,.15);
}
.form-field .field-icon{
    position:absolute; left:16px; top:50%; transform:translateY(-50%);
    display:inline-flex; width:24px; height:24px; opacity:.95;
}
.form-field .field-addon{
    position:absolute; right:10px; top:50%; transform:translateY(-50%);
    border:0; background:transparent; padding:6px; border-radius:.5rem;
}
.form-field .field-addon:focus{ outline:none; box-shadow:none; }
.form-field .field-addon svg{ pointer-events:none; }

@media (max-width:575.98px){
    .form-field .form-control{ height:52px; font-size:1rem; }
}

/* Spacing tweaks for form stack */
.form-group.mb-3{ margin-bottom:1rem !important; }
.form-group.mb-2{ margin-bottom:.75rem !important; }
.form-group.mb-4{ margin-bottom:1.25rem !important; }
:root{
    --bg1:#eef3ff; --bg2:#ffffff; --bg3:#e8f1ff;
    --primary:#1e40af; --primary-600:#1d4ed8;
    --muted:#6b7280;
    --card-bg: rgba(255,255,255,.95);
    --card-bd: rgba(30,64,175,.12);
}
/* Layout */
.auth-wrap{
    min-height:100vh;
    background:
            radial-gradient(1400px 900px at -10% -10%, var(--bg1), transparent 60%),
            radial-gradient(1400px 900px at 110% -10%, var(--bg3), transparent 60%),
            linear-gradient(180deg, var(--bg2), #fbfbff);
    display:flex; align-items:center; justify-content:center;
    padding: 48px 16px;
}
.login-container{ width:100%; max-width: 1024px; }
.login-card{
    border:1px solid var(--card-bd);
    border-radius: 24px;
    background: var(--card-bg);
    backdrop-filter: blur(8px);
    box-shadow: 0 28px 72px rgba(30,64,175,.16);
    overflow:hidden;
    transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}
.login-card:hover{ transform: translateY(-2px); box-shadow:0 34px 88px rgba(30,64,175,.20); border-color: rgba(30,64,175,.18); }

/* Grid */
.login-grid{ display:grid; gap:0; }
@media (min-width: 992px){ .login-grid{ grid-template-columns: 1fr 1.1fr; } }

/* Left side */
.login-hero{
    background: linear-gradient(180deg, #f3f7ff, #eaf1ff);
    padding: 42px 36px;
}
.brand{ display:flex; align-items:center; gap:14px; margin-bottom:12px; }
.brand-badge{
    width:52px; height:52px; border-radius:50%;
    display:flex; align-items:center; justify-content:center;
    color:#fff; font-weight:800; background: var(--primary);
    box-shadow:0 12px 24px rgba(30,64,175,.28);
    font-size:18px;
}
.brand-title{ margin:0; font-weight:800; letter-spacing:.2px; font-size:1.2rem; color:#0f172a; }
.page-title{ margin:10px 0 6px; font-weight:800; letter-spacing:.2px; font-size:1.9rem; }
.muted{ color:var(--muted); }
.feature{ display:flex; gap:10px; align-items:flex-start; margin-bottom:10px; }
.feature svg{ flex:0 0 auto; margin-top:3px; }

/* Right side (form) */
.login-form{ padding: 42px 36px; }
.form-group{ margin-bottom: 1.1rem; }
.input-group-lg > .form-control{ height:auto; padding: 1rem 1.1rem; font-size:1.05rem; }
.input-group-text{ background:#f1f4ff; border-color: rgba(30,64,175,.20); }
.form-control{
    border-color: rgba(30,64,175,.22); border-radius: .55rem;
}
.form-control:focus{
    border-color:#97acff; box-shadow:0 0 0 .2rem rgba(30,64,175,.15);
}
.help-block{ margin-top:.35rem; font-size:.92rem; }

.alert-soft{
    background:#fff; border:1px solid rgba(220,53,69,.28);
    box-shadow:0 12px 24px rgba(220,53,69,.10);
    border-radius:.75rem;
    padding: .85rem 1rem;
}

.btn-primary{
    background: linear-gradient(180deg, var(--primary), var(--primary-600));
    border-color: var(--primary);
    font-weight:700; letter-spacing:.2px;
}
.btn-primary:hover{
    filter: brightness(1.02);
    transform: translateY(-1px);
    box-shadow:0 20px 36px rgba(30,64,175,.26);
}
.btn-lg{ padding: 1rem 1rem; font-size:1.05rem; border-radius:.7rem; }
.btn-block{ display:block; width:100%; }
.form-footer{
    display:flex; justify-content:space-between; align-items:center; gap:12px; flex-wrap:wrap; margin-top:.75rem;
}
.xsmall{ font-size:.95rem; }

.toggle-pwd{ background:#f1f4ff; border:1px solid rgba(30,64,175,.20); }
.toggle-pwd:focus{ box-shadow:none; }

/* Extra spacing tweaks for tight layouts */
.mb-2p{ margin-bottom: .5rem !important; }
.mb-3p{ margin-bottom: .75rem !important; }
.mb-4p{ margin-bottom: 1rem !important; }
.page-title{font-weight:600; letter-spacing:.2px;}
/* "soft" badge Primary ranglarga mos (#1e40af, #3b82f6) */
.badge-soft{background-color: rgba(59,130,246,.12); color:#1e40af;}
.badge-lg{font-size:.95rem; line-height:1.1;}
@media (max-width: 576px){
    .page-title{font-size:1.25rem;}
}
