*{box-sizing:border-box}
:root{
  --navy:#10284b;
  --navy2:#173f73;
  --gold:#c9a227;
  --light:#fff;
  --muted:#6b7785;
  --border:#d8e1ec;
  --danger:#b42318;
  --success:#027a48;
  --danger-bg:#fff1f1;
  --success-bg:#e8f7ee;
  --info-bg:#eef4fb;
}
html,body{
  margin:0;
  padding:0;
  font-family:Inter,Arial,sans-serif;
  background:#f4f7fb;
  color:#1f2d3d
}
body{min-height:100vh}

a{
  text-decoration:none;
  color:var(--navy2);
}
a:hover{
  text-decoration:underline;
}

.container{
  width:min(1200px,92%);
  margin:0 auto
}

.topbar{
  background:linear-gradient(135deg,var(--navy),var(--navy2));
  color:#fff;
  padding:16px 0;
  box-shadow:0 8px 30px rgba(16,40,75,.18)
}

.topbar .brand{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:20px
}

.brand h1{
  margin:0;
  font-family:Georgia,serif;
  font-size:1.35rem
}

.brand .meta{
  font-size:.92rem;
  color:#d9e7ff
}

.grid{
  display:grid;
  gap:20px
}

.grid-2{
  grid-template-columns:repeat(auto-fit,minmax(280px,1fr))
}

.grid-3{
  grid-template-columns:repeat(auto-fit,minmax(240px,1fr))
}

.card{
  background:var(--light);
  border:1px solid var(--border);
  border-radius:20px;
  padding:22px;
  box-shadow:0 10px 25px rgba(16,40,75,.06)
}

.hero{
  padding:38px 0
}

.hero-panel{
  background:linear-gradient(135deg,#10284b,#1f4f87);
  border-radius:28px;
  padding:34px;
  color:#fff;
  box-shadow:0 18px 40px rgba(16,40,75,.18)
}

.hero-panel h2{
  font-family:Georgia,serif;
  font-size:2rem;
  margin:0 0 10px
}

.hero-panel p{
  max-width:820px;
  color:#e6eefb;
  line-height:1.6
}

.form-row{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(220px,1fr));
  gap:16px
}

.form-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(260px,1fr));
  gap:18px
}

.form-group{
  display:flex;
  flex-direction:column;
}

.form-group.full{
  grid-column:1 / -1;
}

label{
  display:block;
  font-weight:600;
  margin-bottom:7px;
  color:#22364d
}

input,select,textarea{
  width:100%;
  padding:12px 14px;
  border:1px solid var(--border);
  border-radius:12px;
  background:#fff;
  color:#1f2d3d;
  font:inherit
}

input:focus,
select:focus,
textarea:focus{
  outline:none;
  border-color:#7aa7d9;
  box-shadow:0 0 0 3px rgba(23,63,115,.10);
}

textarea{
  min-height:120px;
  resize:vertical
}

button,.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  border:none;
  border-radius:12px;
  padding:12px 18px;
  font-weight:700;
  cursor:pointer;
  transition:.2s ease;
  background:var(--navy);
  color:#fff
}

button:hover,.btn:hover{
  transform:translateY(-1px);
  text-decoration:none;
}

.btn-secondary{
  background:#eef4fb;
  color:#173f73;
  border:1px solid var(--border)
}

.btn-gold{
  background:var(--gold);
  color:#10284b
}

.btn[disabled],button[disabled]{
  opacity:.55;
  cursor:not-allowed
}

.actions{
  display:flex;
  flex-wrap:wrap;
  gap:12px
}

.kpi{
  padding:18px;
  border-radius:18px;
  background:#f7fbff;
  border:1px solid var(--border)
}

.kpi .label{
  color:var(--muted);
  font-size:.92rem
}

.kpi .value{
  font-size:1.9rem;
  font-weight:800;
  color:var(--navy);
  margin-top:4px
}

.nav-links{
  display:flex;
  gap:12px;
  flex-wrap:wrap
}

.nav-links a{
  padding:10px 14px;
  border-radius:10px;
  background:rgba(255,255,255,.12);
  color:#fff
}

.nav-links a:hover{
  background:rgba(255,255,255,.22);
  text-decoration:none;
}

.table-wrap{
  overflow:auto
}

table{
  width:100%;
  border-collapse:collapse;
  background:#fff
}

th,td{
  padding:12px 14px;
  border-bottom:1px solid var(--border);
  text-align:left;
  vertical-align:top
}

th{
  background:#f3f7fc;
  color:#23405f;
  font-size:.93rem
}

.badge,
.status-badge{
  display:inline-block;
  padding:6px 10px;
  border-radius:999px;
  font-size:.84rem;
  font-weight:700
}

.badge.info,
.status-badge{
  background:#eef4fb;
  color:#173f73
}

.notice{
  padding:14px 16px;
  border-radius:14px;
  background:#fff8db;
  border:1px solid #f1e2a7;
  color:#7a5d00
}

.message{
  padding:14px 16px;
  border-radius:14px;
  margin-top:12px
}

.message.success{
  background:var(--success-bg);
  border:1px solid #b9e3c7;
  color:var(--success)
}

.message.error{
  background:var(--danger-bg);
  border:1px solid #f3c3c3;
  color:var(--danger)
}

.auth-wrap{
  display:grid;
  place-items:center;
  min-height:100vh;
  padding:24px
}

.auth-card{
  width:min(520px,100%);
  background:#fff;
  border:1px solid var(--border);
  border-radius:24px;
  padding:30px;
  box-shadow:0 18px 45px rgba(16,40,75,.08)
}

.auth-card h2{
  margin-top:0;
  font-family:Georgia,serif;
  color:var(--navy)
}

.small{
  font-size:.92rem;
  color:var(--muted)
}

.footer{
  padding:26px 0 38px;
  color:#5f6b7a;
  font-size:.92rem
}

.print-only{
  display:none
}

@media (max-width:860px){
  .topbar .brand{
    flex-direction:column;
    align-items:flex-start;
  }

  .form-grid,
  .form-row,
  .grid-2,
  .grid-3{
    grid-template-columns:1fr;
  }
}

@media print{
  body{background:#fff}
  .no-print,.topbar,.footer{display:none!important}
  .print-only{display:block}
  .card,.hero-panel{box-shadow:none;border:1px solid #bbb}
  @page{size:A4 landscape;margin:12mm}
}