/* Base styles and variables for BugemaPayments */
:root{
    --brand:#0e6ba8; /* primary */
    --brand-dark:#0b5687;
    --accent:#2e7d32; /* success */
    --text:#0f172a;
    --muted:#64748b;
    --border:#e6e8ec;
    --bg:#f4f6fb;
}

*{box-sizing:border-box}

html,body{height:100%}
body{
    font-family:system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,"Helvetica Neue",Arial,sans-serif;
    background:var(--bg);
    color:var(--text);
    margin:0;
}

/* Typography */
h1,h2,h3,h4,h5,h6{color:var(--text);margin:0}
small{color:var(--muted)}

/* Links (centralized, accessible) */
a{color:#0b5ed7;text-decoration:none;text-underline-offset:2px}
a:hover,a:focus{color:#0b5ed7;text-decoration:none}
a:active{color:#0b5ed7}
a:visited{color:#0b5ed7}
a:focus-visible{outline:3px solid rgba(14,107,168,.3);outline-offset:2px;border-radius:4px}

/* Footer links on translucent/white backgrounds */
.site-footer a{color:#111827;text-decoration:none}
.site-footer a:hover,.site-footer a:focus,.site-footer a:active{color:#111827;text-decoration:none}
.site-footer a:visited{color:#111827}

/* Link utilities for common contexts */
/*.link-dark{color:#111827}*/
/*.link-dark:visited{color:#111827}*/
/*.link-dark:hover,.link-dark:focus,.link-dark:active{color:#111827;text-decoration:underline}*/
/*.link-light{color:#ffffff}*/
/*.link-light:visited{color:#ffffff}*/
/*.link-light:hover,.link-light:focus,.link-light:active{color:#ffffff;text-decoration:underline}*/
/*.link-muted{color:#475569}*/
/*.link-muted:visited{color:#475569}*/
/*.link-muted:hover,.link-muted:focus,.link-muted:active{color:#475569;text-decoration:underline}*/
/*.link-underline{text-decoration:underline !important}*/

/* Link utilities for common contexts */
.link-dark{color:#ffffff}
.link-dark:visited{color:#ffffff}
.link-dark:hover,.link-dark:focus,.link-dark:active{color:#ffffff;text-decoration:underline}
.link-light{color:#ffffff}
.link-light:visited{color:#ffffff}
.link-light:hover,.link-light:focus,.link-light:active{color:#ffffff;text-decoration:underline}
.link-muted{color:#ffffff}
.link-muted:visited{color:#ffffff}
.link-muted:hover,.link-muted:focus,.link-muted:active{color:#ffffff;text-decoration:underline}
.link-underline{text-decoration:underline !important}


/* Forms */
label{display:block;margin:.5rem 0 .3rem;color:#1f2937;font-size:14px}
input[type=text],
input[type=email],
input[type=password],
input[type=tel],
input[type=number],
input[type=search],
select,
textarea{
    width:100%;
    padding:12px 14px;
    border:1px solid #c9ced6;
    border-radius:12px;
    font-size:14px;
    outline:none;
    background:#fff;
    transition:border-color .15s ease, box-shadow .15s ease;
}
input[type=text]:focus,
input[type=email]:focus,
input[type=password]:focus,
input[type=tel]:focus,
input[type=number]:focus,
input[type=search]:focus,
select:focus,
textarea:focus{
    border-color: var(--brand);
    box-shadow:0 0 0 3px rgba(14,107,168,.15);
}
input::placeholder{color:#9aa4b2}
select{line-height:1.25}

/* Layout helpers */
.row{display:grid;grid-template-columns:repeat(2, 1fr);column-gap:20px;row-gap:24px}
.mt-10{margin-top:20px}
.mt-12{margin-top:28px}
.mt-20{margin-top:20px}
.ml-8{margin-left:8px}
.text-center{text-align:center}
.text-right{text-align:right}
.nowrap{white-space:nowrap}

/* Field layout and spacing */
.field{display:flex;flex-direction:column;width:100%}
.field label{margin-bottom:6px;font-weight:500}
.field input,.field select{padding:12px 14px;border-radius:10px}

/* Row variants */
.row.actions{grid-template-columns:1fr}

/* Lists */
.errorlist{color:#b00020;margin:0 0 12px 0;list-style:none;padding:0}

/* Buttons - base reset (colors set per-context) */
.btn{
    display:inline-block;
    color:#fff;
    border:none;
    border-radius:10px;
    padding:12px 16px;
    font-size:14px;
    cursor:pointer;
    text-decoration:none;
}

/* Tables (generic) */
table{width:100%;border-collapse:collapse}
th,td{padding:8px 10px;border-bottom:1px solid #eee;text-align:left}

/* Cards (generic app content container) */
.card{background:#fff;border:1px solid var(--border);border-radius:8px;box-shadow:0 2px 10px rgba(2,6,23,.06);padding:18px 20px}

/* Muted text */
.muted{color:#666}

/* Links helpers */
.link-danger{color:#c62828}
.link-danger:hover,.link-danger:focus,.link-danger:active{color:#c62828;text-decoration:underline}


/* Utilities added */
.justify-between{justify-content:space-between}
.btn-block{width:100%}


/* Buttons: Secondary (neutral/gray) */
.btn-secondary{
    background:#e5e7eb; /* gray-200 */
    color:#111827; /* gray-900 for strong contrast */
    border:1px solid #cbd5e1; /* slate-300 */
}
.btn-secondary:hover{background:#d1d5db;border-color:#cbd5e1}
.btn-secondary:focus{outline:none;box-shadow:0 0 0 3px rgba(14,107,168,.20)}
.btn-secondary:active{background:#cfd3d9}
.btn-secondary.disabled,
.btn-secondary:disabled{opacity:1;color:#94a3b8;background:#eef2f7;border-color:#e5e7eb;cursor:not-allowed}


/* Buttons: Primary and other variants (centralized) */
.btn-primary{background:var(--brand);color:#fff}
.btn-primary:hover{background:var(--brand-dark)}
.btn-primary:focus{outline:none;box-shadow:0 0 0 3px rgba(14,107,168,.2)}
.btn-primary:active{transform:translateY(.5px)}

.btn-success{background:var(--accent);color:#fff}
.btn-success:hover{filter:brightness(.95)}
.btn-success:focus{outline:none;box-shadow:0 0 0 3px rgba(46,125,50,.2)}
.btn-success:active{transform:translateY(.5px)}

.btn-danger{background:#c62828;color:#fff}
.btn-danger:hover{background:#b71c1c}
.btn-danger:focus{outline:none;box-shadow:0 0 0 3px rgba(198,40,40,.2)}
.btn-danger:active{transform:translateY(.5px)}

/* Existing secondary button is defined above; keeping here for centralization */
/* .btn-secondary styles already present */

.btn-warning{background:#f59e0b;color:#fff}
.btn-warning:hover{background:#d97706}
.btn-warning:focus{outline:none;box-shadow:0 0 0 3px rgba(245,158,11,.25)}
.btn-warning:active{transform:translateY(.5px)}

/* Light (neutral) button for pagination and secondary actions */
.btn-light{background:#f8fafc;color:#0f172a;border:1px solid #e5e7eb}
.btn-light:hover{background:#f1f5f9;border-color:#e2e8f0}
.btn-light:focus{outline:none;box-shadow:0 0 0 3px rgba(2,6,23,.10)}
.btn-light:active{transform:translateY(.5px)}


/* Icon-only and small button utilities */
.btn-sm{
    padding:6px 8px;
    font-size:12px;
    border-radius:8px;
}
.btn-icon{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    padding:8px;
}
/* Default icon size inside icon-only buttons */
.btn-icon svg{width:16px;height:16px;display:block}
/* Small variant for icon-only buttons */
.btn-icon.btn-sm{padding:6px}


/* Inline actions utility to avoid grid stretching in header action area */
.actions-inline{display:flex;align-items:center}

/* Extra-extra small button size for tiny icons */
.btn-xxs{padding:4px 6px;font-size:11px;border-radius:6px}
.btn-icon.btn-xxs{padding:4px}
.btn-icon.btn-xxs svg{width:12px;height:12px}


/* Home page (scoped) and Modal components (centralized) */
/* Home page: make all links black for consistency with design request */
.home a{color:#111827;text-decoration:none}
.home a:hover,.home a:focus,.home a:active,.home a:visited{color:#111827}
/* Inline icon support for anchor-buttons */
.btn.with-icon{display:inline-flex;align-items:center;gap:10px}
.btn.with-icon svg{color:currentColor;opacity:.9}
/* Home page specific layout and hero background */
body.home{
    background: linear-gradient(0deg, rgba(14,107,168,.15), rgba(14,107,168,.15)), url('../img/login-hero.webp') center/cover no-repeat fixed;
    padding-bottom:60px; /* space for sticky footer */
}
.home .page .right{display:none}
.home .left{flex:0 1 auto;width:100%}
.home .panel{max-width:900px;width:100%;margin-left:auto;margin-right:auto}
.home .actions{display:grid;gap:14px;margin-top:18px}
@media (min-width: 720px){.home .actions{grid-template-columns:1fr 1fr}}
.home .card.info{background:rgba(255,255,255,.85)}
.home .lead{color:#1f2937}
.home .quick-links{display:grid;gap:10px;margin-top:8px}
.home .btn-big{padding-top:14px;padding-bottom:14px;font-size:1.05rem}
.home .list{margin:0;padding-left:18px}
.home .muted{color:var(--muted, #6b7280)}

/* Simple sticky footer with translucent background (scoped to home) */
.home .site-footer{position:fixed;left:0;right:0;bottom:0;padding:10px 12px;text-align:center;background:rgba(255,255,255,.85);border-top:1px solid rgba(0,0,0,.06);backdrop-filter:blur(4px)}
.home .site-footer .sep{color:#9ca3af;margin:0 6px}

/* Modal (reusable across pages) */
.modal{position:fixed;inset:0;display:none;align-items:center;justify-content:center;z-index:50}
.modal.open{display:flex}
.modal .backdrop{position:absolute;inset:0;background:rgba(0,0,0,.5);opacity:0;transition:opacity .18s ease-out}
.modal.open .backdrop{opacity:1}
.modal .dialog{position:relative;background:#ffffff;border-radius:12px;width:92%;max-width:720px;box-shadow:0 20px 50px rgba(0,0,0,.25);overflow:hidden;transform:translateY(10px) scale(.98);opacity:0;transition:transform .2s ease-out, opacity .2s ease-out;max-height:92vh;display:flex;flex-direction:column}
.modal.open .dialog{transform:translateY(0) scale(1);opacity:1}
.modal header,.modal footer{padding:14px 18px;background:rgba(14,107,168,.06)}
.modal header{position:sticky;top:0;z-index:1;backdrop-filter:blur(2px);border-bottom:1px solid rgba(0,0,0,.06)}
.modal footer{position:sticky;bottom:0;z-index:1;border-top:1px solid rgba(0,0,0,.06);background:#f9fafb}
.modal header h3{margin:0;font-size:1.2rem;letter-spacing:.2px;color:#0e3351}
.modal main{padding:16px;overflow:auto}
.modal .close{position:absolute;top:10px;right:12px;background:transparent;border:0;font-size:22px;cursor:pointer;color:#374151}
.modal .close:hover,.modal .close:focus{color:#0e6ba8}
.modal .row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
@media (max-width:640px){.modal .row{grid-template-columns:1fr}}
/* Unified field styling within modal */
.modal .field{margin-bottom:12px}
.modal .field label{display:block;margin-bottom:6px;font-weight:600;color:#0f172a}
.modal input[type="text"],
.modal input[type="email"],
.modal input[type="tel"],
.modal input[type="file"],
.modal textarea,
.modal select{
    width:100%;
    border:1px solid #cbd5e1; /* slate-300 */
    border-radius:10px;
    padding:10px 12px;
    font-size:1rem;
    line-height:1.25;
    background-color:#ffffff;
    transition:border-color .15s ease, box-shadow .15s ease;
}
.modal textarea{resize:vertical;min-height:110px}
.modal input[type="file"]{padding:8px 12px}
.modal input:focus,.modal textarea:focus,.modal select:focus{outline:none;border-color:#0e6ba8;box-shadow:0 0 0 3px rgba(14,107,168,.18)}
/* Show invalid required fields in red */
.modal form :invalid[required]{border-color:#ef4444}
.modal .muted{color:#6b7280}
.modal .actions-row{display:grid;grid-template-columns:auto auto;gap:12px;justify-content:end}
@media (max-width:640px){.modal .actions-row{grid-template-columns:1fr 1fr}}

/* Home page icon grid tiles (Payments quick actions) */
.home .icon-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:22px;margin-top:18px}
@media (min-width: 900px){.home .icon-grid{grid-template-columns:repeat(4,1fr)}}
.icon-tile{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;min-height:150px;padding:18px 12px;color:#ffffff;border:1.8px solid rgba(255,255,255,.92);border-radius:16px;background:rgba(7,34,52,.28);backdrop-filter:blur(2px);text-align:center;font-weight:600;line-height:1.25;transition:transform .15s ease, box-shadow .15s ease, border-color .15s ease}
.icon-tile .icon svg{display:block;color:#ffffff;opacity:.95}
.icon-tile .label{display:block;font-size:16px;letter-spacing:.2px}
.icon-tile:hover,.icon-tile:focus-visible{transform:translateY(-1px);border-color:#ffffff;box-shadow:0 8px 18px rgba(0,0,0,.18)}
.icon-tile:active{transform:translateY(0)}


/* Icon color variants for home tiles */
.icon-tile .icon.c-blue svg{color:#3b82f6}     /* blue */
.icon-tile .icon.c-green svg{color:#22c55e}    /* green */
.icon-tile .icon.c-amber svg{color:#f59e0b}    /* amber */
.icon-tile .icon.c-violet svg{color:#8b5cf6}   /* violet */
.icon-tile .icon.c-rose svg{color:#f43f5e}     /* rose */
.icon-tile .icon.c-cyan svg{color:#06b6d4}     /* cyan */


/* Pagination styles: make page numbers black and ensure contrast */
.pagination .btn{background:#f8fafc;color:#111827;border:1px solid #e5e7eb}
.pagination a.btn:link,
.pagination a.btn:visited,
.pagination a.btn:hover,
.pagination a.btn:active,
.pagination a:link,
.pagination a:visited,
.pagination a:hover,
.pagination a:active{color:#111827;text-decoration:none}
.pagination .btn:hover{background:#f1f5f9;border-color:#e2e8f0}
.pagination .btn.disabled,
.pagination .btn[aria-disabled="true"],
.pagination span[aria-disabled="true"]{opacity:1;color:#94a3b8;background:#f1f5f9;border-color:#e5e7eb;cursor:not-allowed}
/* Keep current page highlighted but readable on light background */
.pagination .btn.btn-primary{background:#eef2f7;color:#111827;border:1px solid #e5e7eb}
