:root {
  --blue: #0f5fa8;
  --blue-dark: #0a2c52;
  --blue-soft: #eaf2fb;
  --red: #f5315f;
  --gold: #f2b544;
  --bg: #f3f6fb;
  --panel: #ffffff;
  --text: #17324d;
  --muted: #6b8197;
  --line: #d8e1ec;
  --success: #1e8d60;
  --danger: #c8414a;
  --warning: #d18d1f;
  --shadow: 0 24px 60px rgba(11, 44, 82, 0.14);
}
* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { margin: 0; font-family: Arial, Helvetica, sans-serif; background: linear-gradient(180deg,#f7f9fc 0%,#eef4fb 100%); color: var(--text); }
a { color: var(--blue); text-decoration: none; }
img { max-width: 100%; }
.muted { color: var(--muted); }
.small { font-size: .92rem; }
.app-shell { display: grid; grid-template-columns: 300px 1fr; min-height: 100vh; }
.sidebar { background: linear-gradient(180deg, var(--blue-dark), var(--blue)); color: #fff; padding: 24px 20px; position: sticky; top: 0; height: 100vh; overflow-y: auto; }
.brand, .public-brand, .login-brand { display: flex; gap: 14px; align-items: center; }
.brand img, .public-brand img, .login-brand img { width: 64px; height: 64px; object-fit: contain; background: #fff; border-radius: 16px; padding: 6px; box-shadow: 0 8px 20px rgba(0,0,0,.12); }
.brand strong { display: block; font-size: 1.2rem; }
.brand span, .sidebar small { color: rgba(255,255,255,.82); }
.sidebar nav { display: grid; gap: 8px; margin-top: 28px; }
.sidebar nav a { color: #fff; padding: 12px 14px; border-radius: 14px; background: rgba(255,255,255,0.05); border: 1px solid transparent; font-weight: 600; }
.sidebar nav a:hover, .sidebar nav a.active { background: rgba(255,255,255,0.14); border-color: rgba(255,255,255,.16); transform: translateX(1px); }
.nav-label { margin-top: 22px; color: rgba(255,255,255,.65); font-size: .8rem; text-transform: uppercase; letter-spacing: .08em; }
.main-content { padding: 28px; }
.topbar { display: flex; justify-content: space-between; align-items: flex-start; margin-bottom: 24px; gap: 16px; }
.topbar h1 { margin: 0 0 6px; font-size: 2rem; }
.topbar-actions, .header-links, .actions-row, .toolbar { display: flex; gap: 12px; align-items: center; flex-wrap: wrap; }
.panel, .stat-card, .card, .login-card, .mini-card, .metric-card, .hero-side, .chart-card { background: var(--panel); border: 1px solid var(--line); border-radius: 22px; box-shadow: var(--shadow); }
.panel { padding: 24px; margin-bottom: 20px; }
.stats-grid, .cards-grid, .metrics-grid, .three-grid, .four-grid { display: grid; gap: 18px; }
.stats-grid { grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)); }
.metrics-grid { grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); margin-bottom: 20px; }
.three-grid { grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); }
.four-grid { grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); }
.cards-grid { grid-template-columns: repeat(auto-fit, minmax(310px, 1fr)); padding: 28px; }
.stat-card, .metric-card, .chart-card { padding: 22px; }
.stat-card span, .metric-card span { display: block; color: var(--muted); margin-bottom: 10px; }
.stat-card strong, .metric-card strong { font-size: 2rem; color: var(--blue); }
.metric-card small { color: var(--muted); }
.card, .mini-card, .hero-side { padding: 22px; }
.card-title-row, .list-row { display: flex; justify-content: space-between; align-items: center; gap: 12px; flex-wrap: wrap; }
.card-title-row h2, .card-title-row h3 { margin: 0; }
.meta-list, .stack-list { display: grid; gap: 10px; color: var(--muted); }
.table-wrap { overflow-x: auto; }
.table { width: 100%; border-collapse: collapse; }
.table th, .table td { padding: 12px 10px; border-bottom: 1px solid var(--line); text-align: left; vertical-align: top; }
.table th { color: var(--muted); font-size: .92rem; background: #f9fbfd; position: sticky; top: 0; }
.grid-form { display: grid; gap: 16px; }
.grid-form.two-cols { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.grid-form.three-cols { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.grid-form.four-cols { grid-template-columns: repeat(4, minmax(0, 1fr)); }
.grid-form label { display: grid; gap: 8px; font-weight: 600; }
.grid-form input, .grid-form select, .grid-form textarea { width: 100%; padding: 12px 14px; border-radius: 12px; border: 1px solid #c8d4e0; font: inherit; background: #fff; }
.grid-form input:focus, .grid-form select:focus, .grid-form textarea:focus { outline: 0; border-color: var(--blue); box-shadow: 0 0 0 4px rgba(11,74,132,.09); }
.grid-form .full { grid-column: 1 / -1; }
.btn { display: inline-flex; align-items: center; justify-content: center; border: 0; padding: 12px 18px; border-radius: 12px; font-weight: 700; cursor: pointer; transition: .15s ease; }
.btn:hover { transform: translateY(-1px); }
.btn-primary { background: linear-gradient(135deg, var(--blue), var(--blue-dark)); color: #fff; }
.btn-light { background: #eef4fa; color: var(--blue); }
.btn-danger { background: #fae8ea; color: var(--danger); }
.btn-warning { background: #fff4df; color: #9a690f; }
.btn-success { background: #e7f8ef; color: #126945; }
.btn-block { width: 100%; }
.alert { padding: 14px 16px; border-radius: 14px; margin-bottom: 16px; }
.alert-success { background: #e6f7ef; color: #156e48; }
.alert-danger { background: #fdecee; color: #a52734; }
.alert-warning { background: #fff4df; color: #8b5a10; }
.hero-wrap { display: grid; grid-template-columns: 1.4fr .8fr; gap: 22px; margin: 0 28px 28px; }
.hero { background: radial-gradient(circle at top left, #174f89, #0b2f58); color: #fff; border-radius: 28px; padding: 42px; box-shadow: var(--shadow); }
.hero h2 { font-size: 2.4rem; margin: 0 0 12px; max-width: 760px; }
.hero-content p { max-width: 760px; color: rgba(255,255,255,.9); }
.hero-pill { display: inline-block; padding: 8px 14px; border-radius: 999px; background: rgba(255,255,255,.14); color: #fff; font-size: .95rem; margin-bottom: 12px; }
.public-body { background: linear-gradient(180deg, #f4f7fb, #eef3f9); }
.public-header { display: flex; justify-content: space-between; align-items: center; padding: 22px 28px; gap: 16px; }
.status { display: inline-flex; padding: 7px 10px; border-radius: 999px; background: #ebf2f9; color: var(--blue); font-size: .9rem; font-weight: 700; }
.status.success { background:#e6f7ef; color:#156e48; }
.status.warning { background:#fff4df; color:#8b5a10; }
.status.danger { background:#fdecee; color:#a52734; }
.detail-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 12px 24px; margin-bottom: 18px; }
.login-body { min-height: 100vh; background: linear-gradient(135deg, #f3f7fb, #dae7f6); display: flex; align-items: center; justify-content: center; padding: 24px; }
.login-shell { width: min(1080px, 100%); display: grid; grid-template-columns: 1.15fr 420px; gap: 28px; align-items: center; }
.login-card { padding: 28px; }
.login-brand h1 { margin-bottom: 4px; color: var(--blue-dark); font-size: 2.3rem; }
.login-links { margin-top: 18px; display: grid; gap: 8px; font-size: .95rem; }
.kpi-strip { display: grid; grid-template-columns: repeat(auto-fit, minmax(150px, 1fr)); gap: 14px; margin-bottom: 20px; }
.kpi { background: #f9fbfd; border: 1px solid var(--line); padding: 16px; border-radius: 16px; }
.kpi strong { display: block; font-size: 1.4rem; color: var(--blue-dark); margin-top: 8px; }
.filter-box { background: var(--blue-soft); border: 1px solid #d9e8f8; border-radius: 18px; padding: 18px; margin-bottom: 18px; }
.chart-list { display: grid; gap: 14px; }
.chart-row { display: grid; grid-template-columns: 180px 1fr 64px; gap: 12px; align-items: center; }
.chart-bar { position: relative; height: 13px; background: #edf2f8; border-radius: 999px; overflow: hidden; }
.chart-bar span { display:block; height:100%; border-radius:999px; background: linear-gradient(90deg,var(--blue),#3677bb); }
.chart-bar.red span { background: linear-gradient(90deg,var(--red),#ff6d86); }
.chart-bar.gold span { background: linear-gradient(90deg,var(--gold),#f2c15d); }
.chart-note { color: var(--muted); font-size: .92rem; }
.feature-list { display:grid; gap: 12px; }
.feature-item { display:flex; gap:12px; align-items:flex-start; }
.feature-badge { width:38px; height:38px; border-radius:12px; background:var(--blue-soft); color:var(--blue); display:flex; align-items:center; justify-content:center; font-weight:800; }
.footer-note { color: var(--muted); font-size: .9rem; text-align: center; padding-top: 14px; }
.print-shell { max-width: 960px; margin: 0 auto; background: #fff; padding: 30px; }
.print-head { border-bottom: 3px solid var(--blue); padding-bottom: 16px; margin-bottom: 20px; display:flex; justify-content:space-between; gap:16px; align-items:center; }
.print-logo { display:flex; gap:12px; align-items:center; }
.print-logo img { width:72px; background:#fff; border:1px solid var(--line); border-radius:14px; padding:6px; }
.print-actions { margin: 18px 0 24px; display:flex; gap:12px; }
@media print {
  body { background:#fff; }
  .print-actions { display:none !important; }
  .print-shell { padding: 0; max-width:100%; }
}
@media (max-width: 1100px) {
  .hero-wrap, .login-shell { grid-template-columns: 1fr; }
}
@media (max-width: 1000px) {
  .app-shell, .grid-form.two-cols, .grid-form.three-cols, .grid-form.four-cols, .detail-grid, .chart-row { grid-template-columns: 1fr; }
  .sidebar { display: none; }
  .main-content, .public-header, .cards-grid, .hero, .hero-wrap { padding-left: 18px; padding-right: 18px; margin: 0; }
  .topbar { flex-direction: column; align-items: flex-start; gap: 12px; }
}

.pagination{display:flex;gap:8px;justify-content:flex-end;flex-wrap:wrap;margin-top:18px}
.pagination a{display:inline-flex;min-width:38px;height:38px;align-items:center;justify-content:center;border-radius:12px;border:1px solid var(--line);background:#fff;color:var(--blue);font-weight:700}
.pagination a.active{background:linear-gradient(135deg,var(--blue),var(--blue-dark));color:#fff;border-color:transparent}
hr{border:none;border-top:1px solid var(--line);margin:20px 0}

.sidebar::before{content:"";display:block;height:140px;margin:-24px -20px 18px;border-radius:0 0 28px 28px;background:radial-gradient(circle at top left,rgba(255,255,255,.22),transparent 55%),linear-gradient(135deg,#1d79c8,#0a2c52)}
.brand{position:relative;margin-top:-128px;padding-top:8px}
.sidebar nav a{box-shadow: inset 0 1px 0 rgba(255,255,255,.05), 0 8px 20px rgba(0,0,0,.10)}
.sidebar nav a:hover,.sidebar nav a.active{background:linear-gradient(135deg,rgba(255,255,255,.18),rgba(255,255,255,.08));box-shadow:0 16px 28px rgba(0,0,0,.16)}
.topbar h1{color:var(--blue-dark);letter-spacing:-.02em}
.panel,.stat-card,.card,.login-card,.mini-card,.metric-card,.hero-side,.chart-card{backdrop-filter:blur(3px)}
.stat-card strong,.metric-card strong{letter-spacing:-.03em}
.btn-primary{box-shadow:0 14px 30px rgba(15,95,168,.28)}
.btn-danger{box-shadow:0 10px 24px rgba(245,49,95,.16)}
.btn-success{box-shadow:0 10px 24px rgba(18,105,69,.14)}
.hero{background:radial-gradient(circle at top left,rgba(255,255,255,.18),transparent 35%),linear-gradient(135deg,#1676c4 0%, #0f5fa8 38%, #0a2c52 100%)}
.hero h2{letter-spacing:-.03em}
.hero-side{background:linear-gradient(180deg,#ffffff,#f7fbff)}
.login-body{background:radial-gradient(circle at top left,#ffffff 0,#eef5ff 42%,#d9e9fb 100%)}
.login-card{border-top:5px solid var(--gold)}
.filter-box{background:linear-gradient(180deg,#f5faff,#edf6ff)}
.table tr:hover td{background:#f7fbff}
.status{box-shadow:inset 0 0 0 1px rgba(15,95,168,.07)}
.footer-note{padding-bottom:10px}
