/* ═══════════════════════════════════════════════════════════════════════════
   DOJ Management System — Stylesheet
   Stile istituzionale governo USA: blu scuro + oro + grigio acciaio
   ═══════════════════════════════════════════════════════════════════════════ */

/* ── IMPORT FONT ─────────────────────────────────────────────────────────── */
@import url('https://fonts.googleapis.com/css2?family=Source+Serif+4:ital,opsz,wght@0,8..60,400;0,8..60,600;0,8..60,700;1,8..60,400&family=Source+Sans+3:wght@300;400;600;700&display=swap');

/* ── RESET ───────────────────────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
img { max-width: 100%; display: block; }
a { color: inherit; text-decoration: none; }

/* ── VARIABILI ───────────────────────────────────────────────────────────── */
:root {
  --navy:       #0a2342;
  --navy-mid:   #0d3061;
  --navy-light: #1a4a8a;
  --gold:       #c8992a;
  --gold-light: #e8b84b;
  --gold-pale:  #fdf6e3;
  --white:      #ffffff;
  --off-white:  #f7f8fa;
  --gray-100:   #edf0f5;
  --gray-200:   #d8dde8;
  --gray-400:   #8a95a8;
  --gray-600:   #4a5568;
  --gray-800:   #1a202c;
  --red:        #c0392b;
  --red-light:  #fdf0ef;
  --green:      #1e7e45;
  --green-light:#eef7f1;
  --orange:     #c0620c;
  --orange-light:#fef3e8;
  --blue-info:  #1a5fa8;
  --blue-info-light: #eaf2fb;

  --font-serif: 'Source Serif 4', Georgia, serif;
  --font-sans:  'Source Sans 3', 'Helvetica Neue', Arial, sans-serif;

  --radius-sm: 2px;
  --radius:    4px;
  --radius-lg: 8px;
  --shadow-sm: 0 1px 3px rgba(0,0,0,.12);
  --shadow:    0 2px 8px rgba(0,0,0,.14);
  --shadow-lg: 0 4px 20px rgba(0,0,0,.16);

  --max-width: 1160px;
  --transition: .18s ease;
}

/* ── BASE ────────────────────────────────────────────────────────────────── */
html { font-size: 16px; scroll-behavior: smooth; }
body {
  font-family: var(--font-sans);
  background: var(--off-white);
  color: var(--gray-800);
  min-height: 100vh;
  display: flex;
  flex-direction: column;
  line-height: 1.6;
}

/* ── TOPBAR ──────────────────────────────────────────────────────────────── */
.gov-topbar {
  background: var(--navy);
  color: var(--gray-200);
  font-size: .75rem;
  letter-spacing: .04em;
  text-align: center;
  padding: .35rem 1rem;
  border-bottom: 1px solid var(--gold);
}

/* ── HEADER ──────────────────────────────────────────────────────────────── */
.gov-header {
  background: linear-gradient(135deg, var(--navy) 0%, var(--navy-mid) 100%);
  border-bottom: 3px solid var(--gold);
  padding: 1.4rem 1.5rem;
}
.gov-header-inner {
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:20px;
  }

/* Sigillo DOJ */
.gov-seal {
  flex-shrink: 0;
}
.seal-ring {
  width: 64px;
  height: 64px;
  border-radius: 50%;
  border: 3px solid var(--gold);
  background: radial-gradient(circle at 40% 40%, var(--navy-light), var(--navy));
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 0 0 2px rgba(200,153,42,.3), var(--shadow);
}
.seal-text {
  font-family: var(--font-serif);
  font-weight: 700;
  font-size: .95rem;
  color: var(--gold-light);
  letter-spacing: .06em;
}

.gov-title-block { flex: 1; }
.gov-dept {
  font-size: .7rem;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--gold);
  margin-bottom: .1rem;
}
.gov-name {
  font-family: var(--font-serif);
  font-size: 1.6rem;
  font-weight: 700;
  color: var(--white);
  line-height: 1.15;
}
.gov-sub {
  font-size: .78rem;
  color: var(--gray-200);
  letter-spacing: .03em;
}

/* User badge */
.gov-user-badge {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: .35rem;
  flex-shrink: 0;
}
.badge-role {
    padding:4px 10px;
    font-size:12px;
    border-radius:4px;
    font-weight:600;
    background:#1f3a5f;
    color:#fff;
  }
.badge-role.doj_admin { background: rgba(200,153,42,.35); }
.badge-biz {
    font-size:12px;
    color:#6b7280;
  }

  .user-info{
    display:flex;
    flex-direction:column;
    align-items:flex-end;
  }

  .gov-user-panel{
    display:flex;
    align-items:center;
    gap:12px;
  }

.btn-logout {
    padding:6px 12px;
    background:#1f3a5f;
    color:#fff;
    text-decoration:none;
    border-radius:4px;
    font-size:12px;
  }
.btn-logout:hover { background: rgba(255,255,255,.1); color: var(--white); }

/* ── NAV ─────────────────────────────────────────────────────────────────── */
.gov-nav {
  background: var(--navy-mid);
  border-bottom: 1px solid rgba(200,153,42,.35);
}
.gov-nav-inner {
  max-width: var(--max-width);
  margin: 0 auto;
  display: flex;
  flex-wrap: wrap;
}
.gov-nav a {
  display: inline-block;
  padding: .7rem 1.2rem;
  font-size: .82rem;
  font-weight: 600;
  letter-spacing: .04em;
  text-transform: uppercase;
  color: var(--gray-200);
  border-bottom: 3px solid transparent;
  transition: var(--transition);
}
.gov-nav a:hover {
  color: var(--gold-light);
  border-bottom-color: var(--gold);
  background: rgba(255,255,255,.04);
}

/* ── FLASH ───────────────────────────────────────────────────────────────── */
.flash-container {
  max-width: var(--max-width);
  margin: 1rem auto .25rem;
  padding: 0 1.5rem;
  display: flex;
  flex-direction: column;
  gap: .5rem;
}
.flash {
  display: flex;
  align-items: center;
  gap: .7rem;
  padding: .7rem 1rem;
  border-radius: var(--radius);
  font-size: .87rem;
  font-weight: 500;
  border-left: 4px solid;
}
.flash-icon { font-size: 1rem; flex-shrink: 0; }
.flash-success { background: var(--green-light);  border-color: var(--green);  color: var(--green); }
.flash-danger  { background: var(--red-light);    border-color: var(--red);    color: var(--red); }
.flash-warning { background: var(--orange-light); border-color: var(--orange); color: var(--orange); }
.flash-info    { background: var(--blue-info-light); border-color: var(--blue-info); color: var(--blue-info); }

/* ── MAIN ────────────────────────────────────────────────────────────────── */
.gov-main {
  flex: 1;
  max-width: var(--max-width);
  width: 100%;
  margin: 0 auto;
  padding: 2rem 1.5rem 3rem;
}

/* ── FOOTER ──────────────────────────────────────────────────────────────── */
.gov-footer {
  background: var(--navy);
  border-top: 3px solid var(--gold);
  padding: 1.5rem;
  text-align: center;
}
.gov-footer-inner { max-width: var(--max-width); margin: 0 auto; }
.gov-footer p { font-size: .78rem; color: var(--gray-400); line-height: 1.8; }
.footer-disclaimer { font-style: italic; font-size: .72rem; }

/* ═══════════════════════════════════════════════════════════════════════════
   COMPONENTI
   ═══════════════════════════════════════════════════════════════════════════ */

/* ── PAGE HEADER ─────────────────────────────────────────────────────────── */
.page-header {
  margin-bottom: 1.8rem;
  padding-bottom: .8rem;
  border-bottom: 2px solid var(--gray-200);
}
.page-header-admin {
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.page-title {
  font-family: var(--font-serif);
  font-size: 1.65rem;
  font-weight: 700;
  color: var(--navy);
}
.page-sub {
  font-size: .82rem;
  color: var(--gray-400);
  margin-top: .2rem;
}
.admin-badge {
  font-size: .65rem;
  font-weight: 700;
  letter-spacing: .12em;
  text-transform: uppercase;
  padding: .4rem 1rem;
  background: var(--navy);
  color: var(--gold-light);
  border: 1px solid var(--gold);
  border-radius: var(--radius-sm);
}

.mission-left {
    display: flex;
    align-items: center;
    justify-content: center;
  }
  
  .mission-left img {
    width: 200px;
    max-width: 100%;
    filter: drop-shadow(0 4px 12px rgba(0,0,0,0.4));
  }



/* ── STATS STRIP ─────────────────────────────────────────────────────────── */
.stats-strip {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1px;
  background: var(--gray-200);
  border: 1px solid var(--gray-200);
  border-radius: var(--radius);
  overflow: hidden;
  margin-bottom: 2rem;
}
.stat-item {
  background: var(--white);
  padding: 1.2rem 1.4rem;
  text-align: center;
}
.stat-num {
  display: block;
  font-family: var(--font-serif);
  font-size: 2rem;
  font-weight: 700;
  color: var(--navy);
}
.stat-lbl {
  display: block;
  font-size: .72rem;
  letter-spacing: .06em;
  text-transform: uppercase;
  color: var(--gray-400);
  margin-top: .15rem;
}

/* ── INFO CARDS ──────────────────────────────────────────────────────────── */
.card-row {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.2rem;
  margin-bottom: 2rem;
}
.info-card {
  background: var(--white);
  border: 1px solid var(--gray-200);
  border-top: 3px solid var(--gold);
  border-radius: var(--radius);
  padding: 1.5rem;
  box-shadow: var(--shadow-sm);
  transition: var(--transition);
}
.info-card:hover {
  box-shadow: var(--shadow);
  transform: translateY(-1px);
}
.info-card-icon { font-size: 1.6rem; margin-bottom: .7rem; }
.info-card h3 {
  font-family: var(--font-serif);
  font-size: 1rem;
  font-weight: 600;
  color: var(--navy);
  margin-bottom: .4rem;
}
.info-card p { font-size: .85rem; color: var(--gray-600); margin-bottom: 1rem; }
.link-arrow {
  font-size: .82rem;
  font-weight: 600;
  color: var(--navy-light);
  letter-spacing: .02em;
  transition: var(--transition);
}
.link-arrow:hover { color: var(--gold); }

/* ── NOTICE BANNER ───────────────────────────────────────────────────────── */
.notice-banner {
  display: flex;
  align-items: flex-start;
  gap: .8rem;
  background: #fdf8ec;
  border: 1px solid var(--gold);
  border-left: 4px solid var(--gold);
  border-radius: var(--radius);
  padding: .9rem 1.2rem;
  font-size: .85rem;
  margin-bottom: 1.5rem;
}
.notice-banner.notice-info {
  background: var(--blue-info-light);
  border-color: var(--blue-info);
}
.notice-icon { font-size: 1.1rem; flex-shrink: 0; }

/* ── BUTTONS ─────────────────────────────────────────────────────────────── */
.btn {
  display: inline-block;
  font-family: var(--font-sans);
  font-size: .82rem;
  font-weight: 600;
  letter-spacing: .05em;
  text-transform: uppercase;
  padding: .6rem 1.4rem;
  border-radius: var(--radius-sm);
  border: 1px solid transparent;
  cursor: pointer;
  transition: var(--transition);
  white-space: nowrap;
  text-decoration: none;
}
.btn-primary {
  background: var(--navy);
  border-color: var(--gold);
  color: var(--gold-light);
}
.btn-primary:hover {
  background: var(--navy-light);
  color: var(--white);
}
.btn-outline {
  background: transparent;
  border-color: var(--navy);
  color: var(--navy);
}
.btn-outline:hover {
  background: var(--navy);
  color: var(--white);
}
.btn-full { width: 100%; text-align: center; padding: .8rem; font-size: .9rem; }
.btn-sm   { padding: .4rem .9rem; font-size: .76rem; }
.btn-xs   { padding: .22rem .6rem; font-size: .72rem; }

.btn-success { background: var(--green);  border-color: var(--green);  color: var(--white); }
.btn-success:hover { background: #176138; }
.btn-danger  { background: var(--red);    border-color: var(--red);    color: var(--white); }
.btn-danger:hover  { background: #9b2920; }
.btn-warn    { background: var(--orange); border-color: var(--orange); color: var(--white); }
.btn-warn:hover    { background: #a3530a; }

/* ── DASHBOARD GRID ──────────────────────────────────────────────────────── */
.dashboard-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1rem;
  margin-bottom: 2rem;
}
.dash-card {
  background: var(--white);
  border: 1px solid var(--gray-200);
  border-top: 3px solid var(--navy-light);
  border-radius: var(--radius);
  padding: 1.2rem 1.4rem;
  box-shadow: var(--shadow-sm);
}
.dash-card-primary { border-top-color: var(--gold); }
.dash-card-success { border-top-color: var(--green); }
.dash-card-warn    { border-top-color: var(--orange); }
.dash-card-danger  { border-top-color: var(--red); }

.dash-card-label {
  font-size: .65rem;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--gray-400);
  margin-bottom: .4rem;
}
.dash-card-value {
  font-family: var(--font-serif);
  font-size: 1.9rem;
  font-weight: 700;
  color: var(--navy);
  line-height: 1.1;
}
.dash-card-meta { font-size: .78rem; color: var(--gray-600); margin-top: .3rem; }
.dash-card-detail {
  font-size: .8rem;
  color: var(--gray-600);
  margin-top: .6rem;
  line-height: 1.5;
}
.dash-card-link {
  display: inline-block;
  margin-top: .6rem;
  font-size: .78rem;
  font-weight: 600;
  color: var(--navy-light);
  transition: var(--transition);
}
.dash-card-link:hover { color: var(--gold); }

/* ── SECTIONS ────────────────────────────────────────────────────────────── */
.section { margin-bottom: 2.5rem; }
.section-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 1rem;
  padding-bottom: .5rem;
  border-bottom: 1px solid var(--gray-200);
}
.section-header h3 {
  font-family: var(--font-serif);
  font-size: 1.15rem;
  font-weight: 600;
  color: var(--navy);
  display: flex;
  align-items: center;
  gap: .6rem;
}

/* ── TABLES ──────────────────────────────────────────────────────────────── */
.table-wrapper {
  overflow-x: auto;
  border: 1px solid var(--gray-200);
  border-radius: var(--radius);
  box-shadow: var(--shadow-sm);
}
.gov-table {
  width: 100%;
  border-collapse: collapse;
  font-size: .84rem;
  background: var(--white);
}
.gov-table thead tr {
  background: var(--navy);
  color: var(--gray-200);
}
.gov-table th {
  padding: .7rem 1rem;
  text-align: left;
  font-size: .7rem;
  font-weight: 700;
  letter-spacing: .07em;
  text-transform: uppercase;
  white-space: nowrap;
}
.gov-table tbody tr {
  border-bottom: 1px solid var(--gray-100);
  transition: background var(--transition);
}
.gov-table tbody tr:last-child { border-bottom: none; }
.gov-table tbody tr:hover { background: var(--off-white); }
.gov-table td { padding: .65rem 1rem; vertical-align: middle; }
.gov-table-compact td,
.gov-table-compact th { padding: .45rem .8rem; }
.tr-self { background: #fffde7 !important; }

.td-id   { color: var(--gray-400); font-size: .78rem; width: 50px; }
.td-date { font-size: .78rem; color: var(--gray-400); white-space: nowrap; }
.td-name { font-size: .9rem; }
.td-details { font-size: .78rem; color: var(--gray-600); max-width: 240px; }
.table-count {
  font-size: .78rem;
  color: var(--gray-400);
  margin-top: .6rem;
  text-align: right;
}

/* ── STATUS BADGES ───────────────────────────────────────────────────────── */
.status-badge {
  display: inline-block;
  font-size: .65rem;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
  padding: .2rem .6rem;
  border-radius: var(--radius-sm);
  border: 1px solid;
}
.status-active    { background: var(--green-light);   color: var(--green);  border-color: var(--green); }
.status-pending   { background: var(--orange-light);  color: var(--orange); border-color: var(--orange); }
.status-suspended { background: #fff3cd;              color: #856404;       border-color: #ffc107; }
.status-revoked   { background: var(--red-light);     color: var(--red);    border-color: var(--red); }

/* ── ROLE BADGES ─────────────────────────────────────────────────────────── */
.role-badge {
  display: inline-block;
  font-size: .65rem;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
  padding: .2rem .6rem;
  border-radius: var(--radius-sm);
}
.role-owner      { background: #e8f0fe; color: var(--navy); border: 1px solid var(--navy-light); }
.role-manager    { background: #e3f2fd; color: #0d47a1; border: 1px solid #1976d2; }
.role-staff      { background: var(--gray-100); color: var(--gray-600); border: 1px solid var(--gray-200); }
.role-doj_admin  { background: var(--navy); color: var(--gold-light); border: 1px solid var(--gold); }
.role-pending    { background: var(--orange-light); color: var(--orange); border: 1px solid var(--orange); }

/* ── DOT STATUS ──────────────────────────────────────────────────────────── */
.dot {
  display: inline-block;
  width: 7px; height: 7px;
  border-radius: 50%;
  margin-right: .3rem;
  vertical-align: middle;
}
.dot-green { background: var(--green); box-shadow: 0 0 0 2px rgba(30,126,69,.2); }
.dot-red   { background: var(--red);   box-shadow: 0 0 0 2px rgba(192,57,43,.2); }

/* ── ACTION TAG (audit) ──────────────────────────────────────────────────── */
.action-tag {
  display: inline-block;
  font-size: .65rem;
  font-weight: 700;
  font-family: monospace;
  letter-spacing: .04em;
  padding: .2rem .55rem;
  background: var(--gray-100);
  border: 1px solid var(--gray-200);
  border-radius: var(--radius-sm);
  color: var(--navy);
  white-space: nowrap;
}

/* ── FORMS ───────────────────────────────────────────────────────────────── */
.form-page {
  display: flex;
  justify-content: center;
  align-items: flex-start;
  padding-top: 1rem;
}
.form-card {
  background: var(--white);
  border: 1px solid var(--gray-200);
  border-top: 4px solid var(--gold);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-lg);
  padding: 2.2rem 2.5rem;
  width: 100%;
  max-width: 440px;
}
.form-card-wide { max-width: 680px; }
.form-card-inline {
  background: var(--white);
  border: 1px solid var(--gray-200);
  border-radius: var(--radius);
  padding: 1.2rem 1.5rem;
  margin-bottom: .5rem;
}
.form-card-header {
  text-align: center;
  margin-bottom: 1.8rem;
}
.form-seal {
  width: 52px; height: 52px;
  border-radius: 50%;
  border: 2px solid var(--gold);
  background: var(--navy);
  color: var(--gold-light);
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-serif);
  font-size: .9rem;
  font-weight: 700;
  margin: 0 auto .8rem;
}
.form-card-header h2 {
  font-family: var(--font-serif);
  font-size: 1.35rem;
  color: var(--navy);
  margin-bottom: .2rem;
}
.form-card-header p { font-size: .8rem; color: var(--gray-400); }
.form-section-title {
  font-size: .68rem;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--gray-400);
  margin: 1.4rem 0 .8rem;
  padding-bottom: .4rem;
  border-bottom: 1px solid var(--gray-100);
}
.gov-form .form-group { margin-bottom: 1rem; }
.gov-form label {
  display: block;
  font-size: .78rem;
  font-weight: 600;
  letter-spacing: .04em;
  text-transform: uppercase;
  color: var(--gray-600);
  margin-bottom: .3rem;
}
.gov-form input,
.gov-form select,
.gov-form textarea {
  width: 100%;
  padding: .58rem .85rem;
  border: 1px solid var(--gray-200);
  border-radius: var(--radius-sm);
  font-family: var(--font-sans);
  font-size: .87rem;
  color: var(--gray-800);
  background: var(--off-white);
  transition: border-color var(--transition), box-shadow var(--transition);
  outline: none;
}
.gov-form input:focus,
.gov-form select:focus {
  border-color: var(--navy-light);
  box-shadow: 0 0 0 3px rgba(10,35,66,.1);
  background: var(--white);
}
.form-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1rem;
}
.form-inline-row {
  display: flex;
  flex-wrap: wrap;
  gap: .8rem;
  align-items: flex-end;
}
.form-inline-row .form-group { margin-bottom: 0; flex: 1; min-width: 140px; }
.form-group-btn { flex: 0 0 auto; }
.form-footer {
  margin-top: 1.4rem;
  text-align: center;
  font-size: .82rem;
  color: var(--gray-600);
}
.form-footer a { color: var(--navy-light); font-weight: 600; }
.form-footer a:hover { text-decoration: underline; }

/* ── INLINE FORMS in tables ──────────────────────────────────────────────── */
.inline-form {
  display: inline-flex;
  align-items: center;
  gap: .4rem;
}
.action-row {
  display: flex;
  gap: .4rem;
  align-items: center;
  flex-wrap: wrap;
}
.select-sm {
  padding: .25rem .5rem;
  border: 1px solid var(--gray-200);
  border-radius: var(--radius-sm);
  font-size: .78rem;
  background: var(--off-white);
  outline: none;
}
.select-sm:focus { border-color: var(--navy-light); }

/* ── FILTER BAR ──────────────────────────────────────────────────────────── */
.filter-bar {
  display: flex;
  align-items: center;
  gap: .5rem;
  margin-bottom: 1.2rem;
  flex-wrap: wrap;
}
.filter-label {
  font-size: .75rem;
  font-weight: 700;
  letter-spacing: .06em;
  text-transform: uppercase;
  color: var(--gray-400);
  margin-right: .3rem;
}
.filter-btn {
  font-size: .74rem;
  font-weight: 600;
  padding: .3rem .85rem;
  border: 1px solid var(--gray-200);
  border-radius: var(--radius-sm);
  color: var(--gray-600);
  background: var(--white);
  transition: var(--transition);
}
.filter-btn:hover,
.filter-btn.active {
  background: var(--navy);
  border-color: var(--navy);
  color: var(--white);
}

/* ── QUICK ACCESS ────────────────────────────────────────────────────────── */
.quick-access-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1rem;
}
.quick-card {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  background: var(--white);
  border: 1px solid var(--gray-200);
  border-radius: var(--radius-lg);
  padding: 1.5rem 1rem;
  box-shadow: var(--shadow-sm);
  transition: var(--transition);
  gap: .5rem;
}
.quick-card:hover {
  border-color: var(--gold);
  box-shadow: var(--shadow);
  transform: translateY(-2px);
}
.qc-icon { font-size: 1.8rem; }
.qc-label {
  font-family: var(--font-serif);
  font-size: .95rem;
  font-weight: 600;
  color: var(--navy);
}
.qc-sub { font-size: .76rem; color: var(--gray-400); }

/* ── BADGES & COUNTS ─────────────────────────────────────────────────────── */
.count-badge {
  display: inline-block;
  font-size: .7rem;
  font-weight: 700;
  padding: .15rem .55rem;
  border-radius: 999px;
  vertical-align: middle;
}
.count-warn { background: var(--orange-light); color: var(--orange); }
.count-ok   { background: var(--green-light);  color: var(--green); }
.you-badge {
  display: inline-block;
  font-size: .6rem;
  font-weight: 700;
  letter-spacing: .06em;
  text-transform: uppercase;
  padding: .1rem .45rem;
  background: #e8f0fe;
  color: var(--navy);
  border-radius: var(--radius-sm);
  margin-left: .35rem;
  vertical-align: middle;
}

/* ── LICENSE CARDS ───────────────────────────────────────────────────────── */
.license-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 1.2rem;
  margin-bottom: 1.5rem;
}
.license-card {
  background: var(--white);
  border: 1px solid var(--gray-200);
  border-radius: var(--radius-lg);
  padding: 1.4rem;
  box-shadow: var(--shadow-sm);
  position: relative;
  overflow: hidden;
}
.license-card::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 4px;
}
.license-card-valid::before   { background: var(--green); }
.license-card-expired::before { background: var(--red); }
.license-card-other::before   { background: var(--orange); }
.lic-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: .5rem;
}
.lic-type {
  font-size: .68rem;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--gray-400);
}
.lic-status {
  font-size: .68rem;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
}
.lic-number {
  font-family: monospace;
  font-size: 1.15rem;
  font-weight: 700;
  color: var(--navy);
  letter-spacing: .04em;
  margin-bottom: .8rem;
}
.lic-meta { font-size: .8rem; color: var(--gray-600); line-height: 1.8; }
.lic-notes {
  margin-top: .7rem;
  font-size: .78rem;
  color: var(--gray-400);
  font-style: italic;
  border-top: 1px solid var(--gray-100);
  padding-top: .5rem;
}
.lic-alert {
  margin-top: .7rem;
  font-size: .76rem;
  font-weight: 600;
  color: var(--red);
  background: var(--red-light);
  padding: .35rem .6rem;
  border-radius: var(--radius-sm);
}

/* ── MISC ────────────────────────────────────────────────────────────────── */
.notes-block {
  margin-top: 1rem;
  font-size: .82rem;
  background: var(--gold-pale);
  border: 1px solid var(--gold);
  border-radius: var(--radius);
  padding: .7rem 1rem;
  color: var(--gray-800);
}
.empty-state {
  text-align: center;
  padding: 3rem 2rem;
  color: var(--gray-400);
  background: var(--white);
  border: 1px dashed var(--gray-200);
  border-radius: var(--radius-lg);
}
.empty-icon { font-size: 2.2rem; display: block; margin-bottom: .6rem; }
.empty-state p { font-size: .9rem; }
.text-danger { color: var(--red); font-weight: 600; }
.text-muted  { color: var(--gray-400); }

/* ── PAGINATION ──────────────────────────────────────────────────────────── */
.pagination {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 1rem;
  margin-top: 1.5rem;
  font-size: .82rem;
}
.page-btn {
  padding: .4rem 1rem;
  border: 1px solid var(--gray-200);
  border-radius: var(--radius-sm);
  color: var(--navy);
  background: var(--white);
  transition: var(--transition);
}
.page-btn:hover {
  background: var(--navy);
  border-color: var(--navy);
  color: var(--white);
}
.page-info { color: var(--gray-600); }

/* ── RESPONSIVE ──────────────────────────────────────────────────────────── */
@media (max-width: 900px) {
  .dashboard-grid,
  .stats-strip,
  .quick-access-grid { grid-template-columns: 1fr 1fr; }
  .card-row           { grid-template-columns: 1fr; }
  .form-row           { grid-template-columns: 1fr; }
  .form-inline-row    { flex-direction: column; }
}
@media (max-width: 600px) {
  .gov-header-inner   { flex-wrap: wrap; gap: .8rem; }
  .gov-user-badge     { align-items: flex-start; }
  .dashboard-grid,
  .stats-strip,
  .quick-access-grid  { grid-template-columns: 1fr; }
  .gov-main           { padding: 1rem .8rem 2rem; }
  .form-card          { padding: 1.4rem 1.2rem; }
  .hero-heading       { font-size: 1.5rem; }
  .page-header-admin  { flex-direction: column; gap: .6rem; align-items: flex-start; }
  .filter-bar         { gap: .3rem; }
}



.doj-hero{
    position: relative;
    overflow: hidden;
  
    /* IMMAGINE + overlay DOJ */
    background:
      linear-gradient(90deg, rgba(0,0,0,0.6) 0%, rgba(0,0,0,0.2) 60%),
      url("../img/hero_doj_flag.webp") center/cover no-repeat;
  
    color:#fff;
    padding:80px 40px;
    display:flex;
    align-items:center;
    justify-content:center;
  }
  
  .hero-content{
    max-width:700px;
  }
  
  .hero-tag{
    font-size:12px;
    letter-spacing:1px;
    color:#f2a900;
    font-weight:700;
  }
  
  .hero-content h1{
    font-size:42px;
    margin:10px 0;
  }
  
  .hero-sub{
    font-size:18px;
    font-weight:600;
    margin-bottom:10px;
  }
  
  .hero-desc{
    color:#cbd5e1;
    margin-bottom:20px;
  }
  
  .hero-actions{
    display:flex;
    gap:10px;
  }
  
  .btn-primary{
    background:#f2a900;
    color:#000;
    padding:10px 18px;
    font-weight:600;
    border-radius:4px;
    text-decoration:none;
  }
  
  .btn-secondary{
    border:1px solid rgba(255,255,255,0.4);
    padding:10px 18px;
    border-radius:4px;
    color:#fff;
    text-decoration:none;
  }
  

  
  /* ACTION CENTER */
  .doj-action-center {
    padding:60px;
    background:#f5f5f5;
    text-align:center;
  }
  
  .action-grid {
    display:grid;
    grid-template-columns: repeat(2,1fr);
    gap:20px;
    margin-top:30px;
  }
  
  .action-item {
    display:flex;
    gap:15px;
    padding:20px;
    background:#fff;
    border-radius:8px;
    text-decoration:none;
    color:#000;
  }
  
  /* MISSION */
  .doj-mission {
    background:#1f3a5f;
    color:#fff;
    padding:60px;
  }
  
  .mission-content {
    display:flex;
    gap:40px;
  }
  
  /* STATS */
  .doj-stats {
    background:#1f3a5f;
    color:#f2a900;
    padding:40px;
  }
  
  .stats-grid {
    display:grid;
    grid-template-columns: repeat(4,1fr);
    text-align:center;
  }
  
  .stat-box span {
    font-size:40px;
    font-weight:bold;
  }
  
  /* NOTICE */
  .doj-notice {
    background:#fff3cd;
    padding:20px;
    text-align:center;
  }
