/* ── Books & Taxes Inc — Payroll Portal Styles ── */

/* ── Brand Color Palette ──
   Navy Primary  : #1D2D5E
   Green Accent  : #2B6B26
   Dark Navy     : #121E42  (footer / deep)
   Light bg      : #F4F6FB
   ──────────────────────── */

@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap');

:root {
    --bnt-navy:       #1D2D5E;
    --bnt-navy-dark:  #121E42;
    --bnt-green:      #2B6B26;
    --bnt-green-dark: #1E4F1B;
    --bnt-navy-rgb:   29, 45, 94;
    --bnt-green-rgb:  43, 107, 38;

    /* Override Bootstrap primary → brand navy */
    --bs-primary:           #1D2D5E;
    --bs-primary-rgb:       29, 45, 94;
    --bs-success:           #2B6B26;
    --bs-success-rgb:       43, 107, 38;
    --bs-link-color:        #1D2D5E;
    --bs-link-hover-color:  #2B6B26;
}

body {
    font-family: 'Inter', system-ui, -apple-system, sans-serif;
    font-size: .9375rem;
    background-color: #F4F6FB;
    color: #2c3e50;
}

/* ── Bootstrap primary overrides ── */
.bg-primary                { background-color: var(--bnt-navy) !important; }
.text-primary              { color: var(--bnt-navy) !important; }
.border-primary            { border-color: var(--bnt-navy) !important; }

.btn-primary {
    background-color: var(--bnt-navy);
    border-color: var(--bnt-navy);
    color: #fff;
}
.btn-primary:hover,
.btn-primary:focus {
    background-color: var(--bnt-navy-dark);
    border-color: var(--bnt-navy-dark);
    color: #fff;
}
.btn-primary:active { background-color: #0d1630; border-color: #0d1630; }

.btn-outline-primary {
    color: var(--bnt-navy);
    border-color: var(--bnt-navy);
}
.btn-outline-primary:hover {
    background-color: var(--bnt-navy);
    border-color: var(--bnt-navy);
    color: #fff;
}

/* Green / success */
.bg-success               { background-color: var(--bnt-green) !important; }
.text-success             { color: var(--bnt-green) !important; }
.btn-success {
    background-color: var(--bnt-green);
    border-color: var(--bnt-green);
}
.btn-success:hover,
.btn-success:focus {
    background-color: var(--bnt-green-dark);
    border-color: var(--bnt-green-dark);
}
.btn-outline-success {
    color: var(--bnt-green);
    border-color: var(--bnt-green);
}
.btn-outline-success:hover {
    background-color: var(--bnt-green);
    border-color: var(--bnt-green);
    color: #fff;
}

/* ── Navbar ── */
.navbar.bnt-navbar {
    background-color: var(--bnt-navy-dark) !important;
    border-bottom: 3px solid var(--bnt-green);
    padding-top: .6rem;
    padding-bottom: .6rem;
}

.bnt-navbar .navbar-brand {
    display: flex;
    align-items: center;
    gap: .65rem;
    text-decoration: none;
    padding: 0;
}

/* Logo mark — CSS-drawn B with green slash */
.bnt-logo-mark {
    position: relative;
    width: 38px;
    height: 38px;
    flex-shrink: 0;
}

.bnt-logo-text-wrap {
    display: flex;
    flex-direction: column;
    line-height: 1.1;
}
.bnt-logo-text-wrap .bnt-brand-name {
    font-size: .95rem;
    font-weight: 700;
    color: #fff;
    letter-spacing: .04em;
    text-transform: uppercase;
}
.bnt-logo-text-wrap .bnt-brand-sub {
    font-size: .7rem;
    font-weight: 500;
    color: rgba(255,255,255,.55);
    letter-spacing: .06em;
    text-transform: uppercase;
}

.bnt-navbar .nav-divider {
    width: 1px;
    height: 28px;
    background: rgba(255,255,255,.2);
    margin: 0 .25rem;
    align-self: center;
}

.bnt-navbar .nav-link {
    color: rgba(255,255,255,.75) !important;
    font-size: .875rem;
    font-weight: 500;
    padding: .45rem .75rem !important;
    border-radius: .375rem;
    transition: background .15s, color .15s;
}
.bnt-navbar .nav-link:hover {
    color: #fff !important;
    background: rgba(255,255,255,.08);
}
.bnt-navbar .nav-link.active {
    color: #fff !important;
    background: var(--bnt-green);
}
.bnt-navbar .nav-link .bi { opacity: .8; }

.bnt-navbar .navbar-text {
    color: rgba(255,255,255,.55);
    font-size: .8rem;
}

.bnt-navbar .btn-outline-light {
    border-color: rgba(255,255,255,.3);
    color: rgba(255,255,255,.8);
    font-size: .8rem;
}
.bnt-navbar .btn-outline-light:hover {
    background-color: rgba(255,255,255,.12);
    border-color: rgba(255,255,255,.5);
    color: #fff;
}

.bnt-navbar .badge.bg-warning {
    background-color: #f0b429 !important;
    color: #1a1a1a;
    font-size: .65rem;
}

/* ── Cards ── */
.card {
    border-radius: .5rem;
    border-color: #dde3f0;
}
.card-header {
    background-color: #fff;
    border-bottom: 1px solid #dde3f0;
    font-weight: 600;
    color: var(--bnt-navy);
}
.card-header.bg-primary {
    background-color: var(--bnt-navy) !important;
    border-bottom-color: var(--bnt-navy) !important;
    border-radius: .5rem .5rem 0 0 !important;
}

/* ── Stat cards ── */
.stat-card {
    text-align: center;
    padding: 1.5rem 1rem;
}
.stat-card .stat-number {
    font-size: 2.5rem;
    font-weight: 700;
    line-height: 1;
    color: var(--bnt-navy);
}
.stat-card .stat-number.text-warning { color: #d97706 !important; }
.stat-card .stat-number.text-success  { color: var(--bnt-green) !important; }
.stat-card .stat-label {
    font-size: .85rem;
    color: #6c757d;
    margin-top: .25rem;
}

/* ── Tables ── */
.table th {
    white-space: nowrap;
    font-size: .8rem;
    text-transform: uppercase;
    letter-spacing: .05em;
    color: var(--bnt-navy);
    opacity: .75;
}
.table-light th {
    background-color: #eef1f9;
}

/* ── Payroll entry table ── */
.payroll-table input[type="number"] {
    width: 90px;
    text-align: right;
}
.payroll-table .emp-name {
    font-weight: 600;
    white-space: nowrap;
}
.payroll-table .emp-type { font-size: .8rem; }

tr.inactive-row td { color: #adb5bd; }

/* ── Status badges ── */
.badge {
    font-size: .75rem;
    padding: .35em .7em;
    font-weight: 600;
    letter-spacing: .02em;
}

/* ── Form controls ── */
.form-control:focus,
.form-select:focus {
    border-color: var(--bnt-navy);
    box-shadow: 0 0 0 .2rem rgba(var(--bnt-navy-rgb), .18);
}
.form-label { font-weight: 600; color: var(--bnt-navy); font-size: .875rem; }
.input-group-text {
    background-color: #eef1f9;
    border-color: #ced4da;
    color: var(--bnt-navy);
}

/* ── Footer ── */
footer.bnt-footer {
    background-color: var(--bnt-navy-dark);
    color: rgba(255,255,255,.6);
    font-size: .8rem;
    padding: .85rem 1.5rem;
    position: relative;
    overflow: hidden;
    margin-top: 3rem;
}
footer.bnt-footer a {
    color: rgba(255,255,255,.75);
    text-decoration: none;
}
footer.bnt-footer a:hover { color: #fff; }

/* Green diagonal accent (bottom-right, mirrors the business card) */
footer.bnt-footer::after {
    content: '';
    position: absolute;
    right: 0;
    bottom: 0;
    width: 120px;
    height: 100%;
    background: var(--bnt-green);
    clip-path: polygon(40% 0%, 100% 0%, 100% 100%, 0% 100%);
    opacity: .85;
}

/* ── Login page ── */
body.login-page {
    background: linear-gradient(135deg, #0e1732 0%, #1d2d5e 60%, #1e3a1a 100%);
    min-height: 100vh;
}
.login-card {
    border: none;
    border-radius: .75rem;
    overflow: hidden;
    box-shadow: 0 20px 60px rgba(0,0,0,.35);
    max-width: 440px;
    width: 100%;
}
.login-card .login-header {
    background-color: var(--bnt-navy-dark);
    border-bottom: 3px solid var(--bnt-green);
    padding: 2rem 1.5rem 1.75rem;
    text-align: center;
}
.login-card .login-body  { background: #fff; padding: 2rem; }
.login-card .login-footer {
    background-color: var(--bnt-navy-dark);
    padding: .85rem 1.5rem;
    text-align: center;
    position: relative;
    overflow: hidden;
}
.login-card .login-footer::after {
    content: '';
    position: absolute;
    right: 0;
    bottom: 0;
    width: 80px;
    height: 100%;
    background: var(--bnt-green);
    clip-path: polygon(40% 0%, 100% 0%, 100% 100%, 0% 100%);
    opacity: .85;
}
.login-card .login-footer small {
    color: rgba(255,255,255,.55);
    font-size: .75rem;
    position: relative;
    z-index: 1;
}
.login-card .login-footer a {
    color: rgba(255,255,255,.75);
    text-decoration: none;
}
.login-card .login-footer a:hover { color: #fff; }

/* ── Print view ── */
@media print {
    .navbar, footer, .btn, .alert, .no-print { display: none !important; }
    .container-fluid { padding: 0 !important; }
    .card { border: none !important; box-shadow: none !important; }
}

/* ── Responsive table scroll ── */
.table-responsive-payroll {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
}
