/* assets/css/theme.css - Design system for SaaS-like style (soft, modern)
   Non-breaking: keeps header/sidebar DOM intact; provides utility classes. */
:root{
  --color-primary: #3366FF;
  --color-accent: #22C1C3;
  --color-success: #2ECC71;
  --color-warning: #F0B429;
  --color-danger: #FF6B6B;
  --bg: #F7F9FC;
  --card-bg: #FFFFFF;
  --muted: #6B7280;
  --text: #0F172A;
  --radius: 10px;
  --shadow-sm: 0 1px 3px rgba(16,24,40,0.06);
  --shadow-md: 0 8px 24px rgba(16,24,40,0.08);
  --font-sans: 'Inter', system-ui, -apple-system, 'Segoe UI', Roboto, 'Helvetica Neue', Arial;
}

html,body{height:100%;font-family:var(--font-sans);background:var(--bg);color:var(--text);margin:0;padding:0}

/* Card */
.card{background:var(--card-bg);border-radius:var(--radius);box-shadow:var(--shadow-sm);padding:1rem;margin-bottom:1rem}

/* Buttons */
.btn{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem .75rem;border-radius:8px;border:0;cursor:pointer;font-weight:600}
.btn-primary{background:var(--color-primary);color:#fff}
.btn-ghost{background:transparent;border:1px solid rgba(15,23,42,0.06);color:var(--muted)}
.btn-sm{padding:.25rem .5rem;font-size:.9rem}

/* Badges */
.badge{padding:.25rem .6rem;border-radius:999px;font-size:.82rem;display:inline-block;font-weight:600}
.badge-warning{background:linear-gradient(90deg,rgba(240,180,41,0.12),rgba(240,180,41,0.06));color:var(--color-warning)}
.badge-success{background:linear-gradient(90deg,rgba(46,204,113,0.08),rgba(46,204,113,0.04));color:var(--color-success)}
.badge-danger{background:linear-gradient(90deg,rgba(255,107,107,0.08),rgba(255,107,107,0.04));color:var(--color-danger)}

/* Table basics */
.table{width:100%;border-collapse:collapse}
.table thead th{background:rgba(15,23,42,0.9);color:#fff;padding:.75rem;text-align:left;font-weight:700}
.table tbody tr{background:var(--card-bg);border-bottom:1px solid rgba(15,23,42,0.04)}
.table td, .table th{padding:.6rem .75rem}

/* Progress */
.progress{height:12px;border-radius:999px;background:rgba(15,23,42,0.06);overflow:hidden}
.progress .bar{height:100%;transition:width .5s ease;border-radius:999px}
.progress.warning .bar{background:linear-gradient(90deg,var(--color-warning),#FFD54F)}
.progress.green .bar{background:linear-gradient(90deg,var(--color-success),#7CE07A)}
.progress.red .bar{background:linear-gradient(90deg,var(--color-danger),#FF8A8A)}
.progress.orange .bar{background:linear-gradient(90deg,#FFA726,#FFCC80)}

/* Utilities */
.d-flex{display:flex}
.justify-between{justify-content:space-between}
.mt-1{margin-top:.5rem}
.text-muted{color:var(--muted)}
.small{font-size:.85rem}

/* Responsive tweaks */
@media (max-width: 768px){
  .table thead th{font-size:.9rem}
  .card{padding:.75rem}
}

/* Accessibility: skip link */
.skip-link{
  position:absolute;left:-9999px;top:auto;width:1px;height:1px;overflow:hidden;
}
.skip-link:focus{position:static;left:0;top:0;width:auto;height:auto;padding:.5rem 1rem;background:var(--color-primary);color:#fff;z-index:9999;border-radius:6px}

/* Focus outlines for keyboard users */
a:focus, button:focus, .btn:focus, input:focus, select:focus, textarea:focus{outline:3px solid rgba(51,102,255,0.18);outline-offset:2px}

/* Responsive table wrapper */
.table-responsive{overflow:auto;-webkit-overflow-scrolling:touch}
.table-responsive table{min-width:700px}

/* Screen-reader only */
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}

/* Ensure icons spacing */
.icon{display:inline-flex;align-items:center;justify-content:center}
.icon-left{margin-right:.4rem}

/* Soft input styles (non-invasive) */
.form-input, input[type="text"], input[type="date"], select, textarea{padding:.5rem .6rem;border-radius:8px;border:1px solid rgba(15,23,42,0.06);background:#fff}

/* Make data table paging, etc., fit theme */
.dataTables_wrapper .dataTables_paginate .paginate_button{background:transparent;border:1px solid rgba(15,23,42,0.06);border-radius:6px;padding:.25rem .5rem}

/* Reporting specific styles */
.reporting-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1rem;margin-bottom:1rem}
.report-card{padding:1rem;background:var(--card-bg);border-radius:12px;box-shadow:var(--shadow-sm);display:flex;align-items:center;gap:1rem}
.report-icon{width:56px;height:56px;border-radius:12px;display:flex;align-items:center;justify-content:center;color:#fff;font-size:1.25rem}
.report-metric{flex:1}
.metric-value{font-size:1.5rem;font-weight:700}
.metric-label{color:var(--muted);font-size:.92rem}
.report-icon.primary{background:linear-gradient(90deg,var(--color-primary),#4f7bff)}
.report-icon.accent{background:linear-gradient(90deg,var(--color-accent),#32d6d6)}
.report-icon.warn{background:linear-gradient(90deg,var(--color-warning),#FFCF66);color:#2b2b2b}
.report-icon.danger{background:linear-gradient(90deg,var(--color-danger),#FF8A8A)}

/* small cards inside reporting for lists */
.report-subcard{padding:.75rem;border-radius:10px;background:#fbfdff;border:1px solid rgba(15,23,42,0.03)}

/* end reporting styles */
