@import url('https://fonts.googleapis.com/css2?family=Poppins:wght@300;400;600&display=swap');

:root{
  --kma-purple:#6D28D9; /* deep purple */
  --kma-purple-light:#8B5CF6;
  --kma-bg:#ffffff;
  --kma-gray:#6b7280;
}

*{box-sizing:border-box}
body{
  margin:0; font-family:Poppins,system-ui,-apple-system,Segoe UI,Roboto,Ubuntu;
  background:var(--kma-bg); color:#111827;
}
a{color:var(--kma-purple); text-decoration:none}
a:hover{color:var(--kma-purple-light)}

.container{max-width:1100px; margin:0 auto; padding:0 16px}

/* Top bar */
.topbar{position:sticky; top:0; z-index:50; background:#fff; border-bottom:1px solid #eee;}
.nav{display:flex; align-items:center; justify-content:space-between; padding:14px 0}
.brand{display:flex; align-items:center; gap:10px; font-weight:700; color:var(--kma-purple)}
.brand-logo{width:38px; height:38px; border-radius:8px; background:linear-gradient(135deg,var(--kma-purple),var(--kma-purple-light)); display:flex; align-items:center; justify-content:center; color:#fff}
.menu a{margin-left:18px; font-weight:500}
.mobile-about-link{display:none}
.btn{display:inline-block; background:var(--kma-purple); color:#fff; padding:10px 16px; border-radius:10px; transition:transform .15s ease, box-shadow .15s ease}
.btn:hover{transform:translateY(-1px); box-shadow:0 6px 18px rgba(109,40,217,.25)}
.btn-outline{background:#fff; border:1.5px solid var(--kma-purple); color:var(--kma-purple)}

/* Hero */
.hero{padding:60px 0; display:grid; grid-template-columns:1.2fr .8fr; gap:30px; align-items:center}
.card{background:#fff; border:1px solid #eee; border-radius:16px; padding:22px; box-shadow:0 12px 30px rgba(17,24,39,.05)}
.card-title{margin:0 0 6px; font-weight:700}
.muted{color:var(--kma-gray)}

/* Safer wrapping on small screens (avoid hyphenated breaks) */
h1,h2,h3,h4,h5,h6, .card, .content{
  word-break: normal;
  overflow-wrap: break-word;
  hyphens: none;
}
/* Brand and footer should not hyphenate */
.brand span, .footer p{
  hyphens: none;
  word-break: keep-all;
}

.grid{display:grid; grid-template-columns:repeat(3,1fr); gap:16px}
.grid-2{display:grid; grid-template-columns:repeat(2,1fr); gap:16px}
.grid-1{display:grid; grid-template-columns:1fr; gap:16px}

/* Responsive grids */
@media (max-width: 900px){
  .grid{grid-template-columns:1fr}
  .grid-2{grid-template-columns:1fr}
  .container{padding:0 12px}
  table{display:block; overflow-x:auto}
  .btn{width:100%; text-align:center}
  /* Tighten headings slightly on very small widths */
  h1,h2{line-height:1.15}
  /* Public nav: hide full menu; show only About link */
  .menu{display:none}
  .mobile-about-link{display:inline-flex; align-items:center}
  /* Footer stacks vertically for readability */
  .footer .flex{flex-direction:column; gap:6px}
  .footer p{text-align:center}
}

/* Sidebar transition */
.sidebar{transition:width .25s ease}

/* Tables */
table{width:100%; border-collapse:collapse}
th,td{padding:10px 12px; border-bottom:1px solid #eee; text-align:left}
th{background:#fafafa; font-weight:600}
tr:hover td{background:#fbfaff}

/* Forms */
label{display:block; font-weight:600; margin:8px 0 6px}
input[type=text], input[type=date], input[type=number], input[type=email], input[type=password], select, textarea{
  width:100%; padding:10px 12px; border:1px solid #e5e7eb; border-radius:10px; outline:none; transition:border .2s ease, box-shadow .2s ease; background:#fff
}
textarea{min-height:92px}
input:focus, select:focus, textarea:focus{border-color:var(--kma-purple-light); box-shadow:0 0 0 3px rgba(139,92,246,.15)}

.tag{display:inline-block; padding:4px 10px; background:#f3e8ff; color:var(--kma-purple); border-radius:999px; font-size:12px}
.status-pending{background:#fff7ed; color:#b45309}
.status-approved{background:#ecfdf5; color:#047857}

.footer{margin-top:40px; border-top:1px solid #eee; padding:20px 0; color:#6b7280}

/* Animations */
.fade-in{opacity:0; transform:translateY(6px); animation:fadein .5s ease forwards}
@keyframes fadein{to{opacity:1; transform:none}}

/* Utility */
.center{text-align:center}
.mt-1{margin-top:6px}.mt-2{margin-top:12px}.mt-3{margin-top:18px}.mt-4{margin-top:24px}
.mb-2{margin-bottom:12px}.mb-3{margin-bottom:18px}.mb-4{margin-bottom:24px}
.flex{display:flex}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-2{gap:8px}.gap-3{gap:12px}

/* Printable report */
.report{font-size:12px}
.report .box{border:1px solid #ddd; padding:10px; border-radius:8px}
.report .title{color:var(--kma-purple); font-weight:700}


