/* ===== Parker Quoter — sistema de diseño (réplica PlenarioPayCalendar) ===== */
:root {
  --bg:#f5f7fa; --surface:#fff; --surface-2:#f9fafc; --border:#e4e8ee;
  --text:#1e2430; --text-muted:#6a7280;
  --primary:#1f4e79; --primary-2:#2a6aa8;
  --success:#2e7d32; --warning:#c27a00; --danger:#c0392b; --info:#2a6aa8; --accent:#6f42c1;
  --shadow:0 1px 3px rgba(0,0,0,.06),0 2px 8px rgba(0,0,0,.04);
  --radius:8px; --sidebar-w:240px; --topbar-h:54px;
}
[data-theme="dark"] {
  --bg:#0f1117; --surface:#1a1d27; --surface-2:#20232e; --border:#2d3148;
  --text:#e2e6ef; --text-muted:#7a829a; --primary:#4a90d9; --primary-2:#5ba3e8;
  --shadow:0 1px 3px rgba(0,0,0,.3),0 2px 8px rgba(0,0,0,.2);
}

/* reset */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
body{font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;font-size:14px;background:var(--bg);color:var(--text);line-height:1.5}
a{color:var(--primary);text-decoration:none} a:hover{text-decoration:underline}
h1{font-size:22px;font-weight:600} h2{font-size:18px;font-weight:600} h3{font-size:15px;font-weight:600}
.text-muted{color:var(--text-muted)} .text-center{text-align:center} .text-end{text-align:right} .text-start{text-align:left}
.text-danger{color:var(--danger)} .text-success{color:var(--success)} .fw-bold,.font-bold{font-weight:700}
.small{font-size:12px}
::-webkit-scrollbar{width:7px;height:7px}
::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px}
::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}

/* layout */
.sidebar{background:var(--surface);border-right:1px solid var(--border);display:flex;flex-direction:column;position:fixed;top:0;left:0;width:var(--sidebar-w);height:100vh;overflow-y:auto;z-index:200}
.sidebar-brand{padding:18px 20px 14px;border-bottom:1px solid var(--border)}
.brand-name{font-size:16px;font-weight:700;color:var(--primary);letter-spacing:.03em}
.brand-sub{font-size:11px;color:var(--text-muted);margin-top:2px}
.brand-version{display:inline-block;margin-top:6px;font-size:10px;font-weight:600;color:var(--text-muted);background:var(--surface-2);border:1px solid var(--border);border-radius:4px;padding:1px 7px;cursor:pointer;transition:color .12s,border-color .12s}
.brand-version:hover{color:var(--primary);border-color:var(--primary)}
/* changelog */
.cl-version{font-weight:700;font-size:14px;color:var(--primary)}
.cl-date{font-weight:400;font-size:12px;color:var(--text-muted)}
.cl-items{margin:6px 0 0 18px;font-size:13px} .cl-items li{margin-bottom:4px}
.sep{height:1px;background:var(--border);margin:14px 0}
.nav{flex:1;padding:8px 0}
.nav-section{padding:14px 20px 4px;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted)}
.nav-item{display:flex;align-items:center;gap:10px;padding:8px 20px;cursor:pointer;color:var(--text);border-left:3px solid transparent;transition:background .12s,border-color .12s,color .12s;font-size:13.5px;user-select:none}
.nav-item:hover{background:var(--surface-2)}
.nav-item.active{border-left-color:var(--primary);color:var(--primary);background:var(--surface-2);font-weight:600}
.nav-icon{width:18px;height:18px;flex-shrink:0;display:inline-flex;align-items:center;justify-content:center}
.nav-icon svg{width:17px;height:17px}
.sidebar-footer{padding:12px 20px;border-top:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;font-size:11px;color:var(--text-muted)}
#themeToggle{cursor:pointer;font-size:17px;user-select:none;background:none;border:none;color:var(--text-muted)}
#themeToggle:hover{color:var(--primary)}

.main{margin-left:var(--sidebar-w);display:flex;flex-direction:column;min-height:100vh}
.topbar{height:var(--topbar-h);background:var(--surface);border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;padding:0 24px;position:sticky;top:0;z-index:100}
.breadcrumb{font-size:13px;color:var(--text-muted)} .breadcrumb strong{color:var(--text);font-weight:600}
.user-chip{display:flex;align-items:center;gap:8px;font-size:13px}
.user-avatar{width:30px;height:30px;border-radius:50%;background:var(--primary);color:#fff;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;flex-shrink:0;cursor:pointer;user-select:none}
.user-avatar:hover{background:var(--primary-2)}
.user-name{font-weight:600}
.content{flex:1;padding:24px}
.footer{padding:14px 24px;border-top:1px solid var(--border);display:flex;justify-content:space-between;font-size:11px;color:var(--text-muted)}

/* page header */
.page-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:20px;gap:12px}
.page-header h1{font-size:22px;font-weight:600}
.page-header .subtitle{font-size:13px;color:var(--text-muted);margin-top:4px}
.page-header-actions{display:flex;gap:8px;align-items:center;flex-shrink:0}

/* cards */
.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);margin-bottom:16px}
.card-body{padding:16px}
.card-title{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);margin-bottom:10px}
.stat-tile .card-body .h2,.h2{font-size:26px;font-weight:700}

/* buttons */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:5px;padding:7px 14px;border-radius:6px;border:1px solid var(--border);background:var(--surface);color:var(--text);font-size:13px;font-family:inherit;cursor:pointer;transition:background .12s,border-color .12s,color .12s;text-decoration:none;white-space:nowrap}
.btn:hover{background:var(--surface-2)}
.btn:disabled{opacity:.55;cursor:not-allowed}
.btn-primary{background:var(--primary);color:#fff;border-color:var(--primary)} .btn-primary:hover{background:var(--primary-2);border-color:var(--primary-2);color:#fff}
.btn-danger{background:var(--danger);color:#fff;border-color:var(--danger)} .btn-danger:hover{background:#a93226;border-color:#a93226}
.btn-success{background:var(--success);color:#fff;border-color:var(--success)} .btn-success:hover{background:#256427;border-color:#256427}
.btn-secondary{background:var(--surface-2);color:var(--text)}
.btn-sm{padding:4px 10px;font-size:12px}
.btn-outline-primary{color:var(--primary);border-color:var(--primary);background:transparent} .btn-outline-primary:hover{background:var(--primary);color:#fff}
.btn-outline-secondary{color:var(--text-muted);background:transparent} .btn-outline-secondary:hover{background:var(--surface-2);color:var(--text)}
.btn-outline-danger{color:var(--danger);border-color:var(--danger);background:transparent} .btn-outline-danger:hover{background:var(--danger);color:#fff}
.btn-outline-warning{color:var(--warning);border-color:var(--warning);background:transparent} .btn-outline-warning:hover{background:var(--warning);color:#fff}
.btn-outline-success{color:var(--success);border-color:var(--success);background:transparent} .btn-outline-success:hover{background:var(--success);color:#fff}
.btn svg{width:15px;height:15px}

/* pills / badges (compat) */
.pill,.badge{display:inline-block;padding:2px 10px;border-radius:999px;font-size:11px;font-weight:600;white-space:nowrap;line-height:1.5}
.pill-success,.badge.bg-success{background:rgba(46,125,50,.12);color:var(--success)}
.pill-warning,.badge.bg-warning{background:rgba(194,122,0,.14);color:var(--warning)}
.pill-danger,.badge.bg-danger{background:rgba(192,57,43,.12);color:var(--danger)}
.pill-info,.badge.bg-info{background:rgba(42,106,168,.12);color:var(--info)}
.pill-muted,.badge.bg-secondary{background:rgba(106,114,128,.14);color:var(--text-muted)}
.pill-primary{background:rgba(31,78,121,.12);color:var(--primary)}
.badge.text-dark{color:var(--text)}

/* tables (.tbl nativo + .table compat) */
.tbl,.table{width:100%;border-collapse:collapse;font-size:13px;font-variant-numeric:tabular-nums}
.tbl thead th,.table thead th{background:var(--surface-2);padding:9px 12px;text-align:left;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);border-bottom:1px solid var(--border);white-space:nowrap}
.tbl tbody td,.table tbody td,.table td{padding:9px 12px;border-bottom:1px solid var(--border);vertical-align:middle}
.table th{padding:9px 12px}
.tbl tbody tr:hover td,.table tbody tr:hover td{background:var(--surface-2)}
.table-sm td,.table-sm th{padding:6px 10px}
.table-active td,tr.table-active td{background:var(--surface-2)}
.table-responsive{overflow-x:auto}
.table[data-sortable] thead th{cursor:pointer;user-select:none}
.table tfoot th,.table tfoot td{padding:9px 12px;border-top:2px solid var(--border);font-weight:700}

/* forms */
.form-row{display:flex;flex-direction:column;gap:5px;margin-bottom:14px}
.form-row label,.form-label{font-size:13px;font-weight:600;color:var(--text);display:block;margin-bottom:4px}
input,select,textarea{font-family:inherit}
.form-row input,.form-row select,.form-row textarea,.form-control,.form-select{
  width:100%;padding:7px 10px;border:1px solid var(--border);border-radius:6px;font-size:13px;font-family:inherit;background:var(--surface);color:var(--text);transition:border-color .12s,box-shadow .12s}
.form-row input:focus,.form-row select:focus,.form-row textarea:focus,.form-control:focus,.form-select:focus{
  outline:none;border-color:var(--primary);box-shadow:0 0 0 2px rgba(31,78,121,.15)}
.form-check{display:flex;align-items:center;gap:8px;margin-bottom:14px}
.form-check-input{width:16px;height:16px}
.input-group{display:flex} .input-group .form-control{border-top-right-radius:0;border-bottom-right-radius:0}
.input-group .btn{border-top-left-radius:0;border-bottom-left-radius:0}

/* alerts */
.alert{padding:10px 14px;border-radius:6px;font-size:13px;margin-bottom:12px;border:1px solid transparent}
.alert-success{background:rgba(46,125,50,.08);color:var(--success);border-color:rgba(46,125,50,.25)}
.alert-danger{background:rgba(192,57,43,.07);color:var(--danger);border-color:rgba(192,57,43,.25)}
.alert-warning{background:rgba(194,122,0,.08);color:var(--warning);border-color:rgba(194,122,0,.25)}
.alert-info{background:rgba(42,106,168,.08);color:var(--info);border-color:rgba(42,106,168,.25)}

/* modal propio */
.modal-backdrop{position:fixed;inset:0;background:rgba(0,0,0,.48);z-index:1000;display:none;align-items:center;justify-content:center;padding:16px}
.modal-backdrop.open{display:flex}
.modal{background:var(--surface);border-radius:var(--radius);box-shadow:0 8px 40px rgba(0,0,0,.2);width:100%;max-width:520px;max-height:92vh;overflow:hidden;display:flex;flex-direction:column}
.modal-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border);flex-shrink:0}
.modal-header h3{font-size:15px;font-weight:700}
.modal-close{background:none;border:none;cursor:pointer;font-size:22px;color:var(--text-muted);padding:0 4px;line-height:1}
.modal-close:hover{color:var(--text)}
.modal-body{padding:20px;overflow-y:auto;flex:1}
.modal-footer{padding:14px 20px;border-top:1px solid var(--border);display:flex;justify-content:flex-end;gap:8px;flex-shrink:0}

/* toasts */
#toasts{position:fixed;top:18px;right:18px;z-index:2000;display:flex;flex-direction:column;gap:8px;pointer-events:none}
.toast{padding:10px 16px;border-radius:var(--radius);font-size:13px;font-weight:500;box-shadow:0 4px 16px rgba(0,0,0,.18);max-width:360px;animation:toastIn .22s ease;pointer-events:all;color:#fff}
.toast.success{background:var(--success)} .toast.danger,.toast.error{background:var(--danger)}
.toast.warning{background:var(--warning)} .toast.info{background:var(--info)}
@keyframes toastIn{from{opacity:0;transform:translateX(16px)}to{opacity:1;transform:translateX(0)}}

/* spinner (compat .spinner-border) */
.spinner,.spinner-border{width:34px;height:34px;border:3px solid var(--border);border-top-color:var(--primary);border-radius:50%;animation:spin .65s linear infinite;display:inline-block}
@keyframes spin{to{transform:rotate(360deg)}}

/* dropzone */
.dropzone{border:2px dashed var(--border);border-radius:var(--radius);padding:2.4rem 1.5rem;text-align:center;color:var(--text-muted);background:var(--surface-2);cursor:pointer;transition:border-color .12s,background .12s,color .12s}
.dropzone:hover,.dropzone.dragover{border-color:var(--primary);background:rgba(31,78,121,.05);color:var(--text)}
.dropzone svg{width:30px;height:30px;color:var(--text-muted)}

/* login */
.login-wrap{position:fixed;inset:0;background:linear-gradient(135deg,#1f4e79,#2a6aa8);display:flex;align-items:center;justify-content:center;padding:16px}
.login-card{background:#fff;border-radius:12px;box-shadow:0 16px 48px rgba(0,0,0,.28);padding:34px 38px;width:100%;max-width:400px}
.login-logo{font-size:22px;font-weight:700;color:var(--primary);text-align:center}
.login-sub{font-size:12px;color:#6a7280;margin-bottom:22px;text-align:center}
.login-tabs{display:flex;gap:6px;margin-bottom:18px;background:#f1f3f7;border-radius:8px;padding:4px}
.login-tab{flex:1;text-align:center;padding:7px;border-radius:6px;font-size:13px;font-weight:600;color:#6a7280;cursor:pointer;user-select:none}
.login-tab.active{background:#fff;color:var(--primary);box-shadow:0 1px 3px rgba(0,0,0,.08)}
.login-card .form-row label{color:#1e2430}
.login-card input{color:#1e2430;background:#fff}

/* utilidades (subset) */
.d-flex{display:flex} .d-grid{display:grid} .d-none{display:none} .flex-column{flex-direction:column}
.justify-content-between{justify-content:space-between} .justify-content-end{justify-content:flex-end}
.align-items-center{align-items:center} .align-self-center{align-self:center} .flex-wrap{flex-wrap:wrap}
.gap-2{gap:8px} .gap-3{gap:12px}
.w-100{width:100%} .w-auto{width:auto} .my-0{margin:0} .mb-0{margin-bottom:0}
.mb-1{margin-bottom:4px} .mb-2{margin-bottom:8px} .mb-3{margin-bottom:16px} .mb-4{margin-bottom:24px}
.mt-1{margin-top:4px} .mt-2{margin-top:8px} .mt-3{margin-top:16px} .mt-4{margin-top:24px}
.me-1{margin-right:4px} .me-2{margin-right:8px} .ms-2{margin-left:8px} .pe-4{padding-right:24px}
.p-1{padding:4px} .p-3{padding:16px} .py-4{padding-top:24px;padding-bottom:24px} .py-5{padding-top:36px;padding-bottom:36px}
.row{display:flex;flex-wrap:wrap;gap:12px}
.col,.col-md-6{flex:1;min-width:200px} .col-md-6{flex:0 0 calc(50% - 6px)}
.align-middle{vertical-align:middle}
@media (max-width:760px){
  .sidebar{transform:translateX(-100%);transition:transform .2s} .sidebar.open{transform:none}
  .main{margin-left:0} .col-md-6{flex:1 1 100%}
}
