/* =========================================================================
   MEDA Internal Records System — stylesheet
   Palette: deep renewable green + solar amber, warm-neutral surfaces.
   ========================================================================= */

:root{
  --ink:#15211c;
  --paper:#f3f6f2;
  --surface:#ffffff;
  --primary:#0e5a43;
  --primary-dark:#0a4232;
  --accent:#e08a2b;
  --accent-soft:#fcefdc;
  --muted:#6b7b74;
  --line:#e2e8e3;
  --line-strong:#cfd9d2;

  --b-green-bg:#e3f3ea; --b-green-fg:#136c44;
  --b-amber-bg:#fcefda; --b-amber-fg:#9a5b12;
  --b-blue-bg:#e4eefb;  --b-blue-fg:#1d4f97;
  --b-teal-bg:#dcf1f0;  --b-teal-fg:#0c6f6a;
  --b-red-bg:#fbe6e4;   --b-red-fg:#a52a1d;
  --b-gray-bg:#eceeed;  --b-gray-fg:#5a665f;

  --radius:10px;
  --shadow:0 1px 2px rgba(20,40,32,.05), 0 8px 24px rgba(20,40,32,.04);
  --sidebar-w:248px;
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,Arial,sans-serif;
  background:var(--paper);
  color:var(--ink);
  font-size:14px;
  line-height:1.5;
  -webkit-font-smoothing:antialiased;
}
a{color:var(--primary);text-decoration:none}
a:hover{text-decoration:underline}
h1,h2,h3{margin:0;font-weight:650;letter-spacing:-.01em}

/* ---------- layout shell ---------------------------------------------- */
.layout{display:flex;min-height:100vh}

.sidebar{
  width:var(--sidebar-w);
  flex:0 0 var(--sidebar-w);
  background:var(--primary-dark);
  color:#dfeae4;
  display:flex;flex-direction:column;
  position:fixed;top:0;bottom:0;left:0;
}
.brand{
  padding:20px 18px 16px;
  border-bottom:1px solid rgba(255,255,255,.08);
}
.brand .mark{
  display:flex;align-items:center;gap:10px;
}
.brand .dot{
  width:34px;height:34px;border-radius:8px;flex:0 0 34px;
  background:linear-gradient(135deg,var(--accent),#f0a94e);
  display:grid;place-items:center;color:#3a2208;font-weight:800;font-size:15px;
}
.brand .t1{font-size:14px;font-weight:700;color:#fff;line-height:1.2}
.brand .t2{font-size:11px;color:#9fc0b0;margin-top:2px}

.nav{padding:12px 10px;flex:1;overflow-y:auto}
.nav .group{
  font-size:10.5px;text-transform:uppercase;letter-spacing:.12em;
  color:#7ba593;padding:14px 10px 6px;font-weight:700;
}
.nav a{
  display:flex;align-items:center;gap:10px;
  padding:9px 11px;border-radius:8px;color:#cfe1d8;
  font-size:13.5px;font-weight:500;margin-bottom:2px;
}
.nav a:hover{background:rgba(255,255,255,.06);text-decoration:none;color:#fff}
.nav a.active{background:var(--primary);color:#fff}
.nav a .ic{width:18px;text-align:center;opacity:.9}

.sidefoot{padding:14px 16px;border-top:1px solid rgba(255,255,255,.08);font-size:11px;color:#8fb3a2}

/* ---------- main ------------------------------------------------------ */
.main{margin-left:var(--sidebar-w);flex:1;min-width:0;display:flex;flex-direction:column}
.topbar{
  background:var(--surface);
  border-bottom:1px solid var(--line);
  padding:14px 26px;
  display:flex;align-items:center;justify-content:space-between;gap:16px;
  position:sticky;top:0;z-index:20;
}
.topbar .ttl{font-size:18px;font-weight:680}
.topbar .sub{font-size:12px;color:var(--muted);margin-top:1px}
.usermenu{display:flex;align-items:center;gap:12px;font-size:13px}
.usermenu .who{text-align:right;line-height:1.25}
.usermenu .who b{display:block;font-weight:600}
.usermenu .who span{color:var(--muted);font-size:11.5px}
.avatar{
  width:36px;height:36px;border-radius:50%;
  background:var(--accent-soft);color:var(--accent);
  display:grid;place-items:center;font-weight:700;
}
.content{padding:24px 26px 48px;max-width:1280px;width:100%}

/* ---------- flash ----------------------------------------------------- */
.flash{padding:11px 15px;border-radius:8px;margin-bottom:16px;font-size:13.5px;border:1px solid}
.flash.success{background:var(--b-green-bg);color:var(--b-green-fg);border-color:#bfe3cd}
.flash.error{background:var(--b-red-bg);color:var(--b-red-fg);border-color:#f0c4be}
.flash.info{background:var(--b-blue-bg);color:var(--b-blue-fg);border-color:#c6dbf6}

/* ---------- cards / stats --------------------------------------------- */
.stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:14px;margin-bottom:22px}
.stat{
  background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);
  padding:16px 16px 14px;box-shadow:var(--shadow);position:relative;overflow:hidden;
}
.stat .k{font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);font-weight:600}
.stat .v{font-size:30px;font-weight:720;margin-top:6px;letter-spacing:-.02em}
.stat .rail{position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--line-strong)}
.stat.lead{background:linear-gradient(135deg,var(--primary),#0b6b4d);color:#fff;border:none}
.stat.lead .k{color:#bfe0cf}
.stat.lead .rail{background:var(--accent)}
.stat .rail.green{background:var(--b-green-fg)}
.stat .rail.amber{background:var(--accent)}
.stat .rail.blue{background:var(--b-blue-fg)}
.stat .rail.red{background:var(--b-red-fg)}

.card{
  background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);
  box-shadow:var(--shadow);margin-bottom:20px;
}
.card .hd{
  padding:14px 18px;border-bottom:1px solid var(--line);
  display:flex;align-items:center;justify-content:space-between;gap:12px;
}
.card .hd h2{font-size:14.5px;font-weight:650}
.card .bd{padding:18px}
.card .bd.flush{padding:0}

/* ---------- toolbar (search + filters) -------------------------------- */
.toolbar{
  display:flex;flex-wrap:wrap;gap:10px;align-items:center;margin-bottom:16px;
}
.toolbar form{display:flex;flex-wrap:wrap;gap:10px;align-items:center}
.toolbar .grow{flex:1 1 220px}

/* ---------- forms ----------------------------------------------------- */
.field{margin-bottom:15px}
.field label{display:block;font-size:12.5px;font-weight:600;margin-bottom:5px;color:#33433c}
.field .hint{font-size:11.5px;color:var(--muted);margin-top:4px}
input,select,textarea{
  width:100%;padding:9px 11px;border:1px solid var(--line-strong);border-radius:8px;
  font:inherit;font-size:13.5px;background:#fff;color:var(--ink);
}
input:focus,select:focus,textarea:focus{
  outline:none;border-color:var(--primary);box-shadow:0 0 0 3px rgba(14,90,67,.12);
}
textarea{resize:vertical;min-height:80px}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:0 18px}
.grid3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:0 18px}
.searchbox{min-width:200px}
select.compact,input.compact{width:auto;min-width:150px}

/* ---------- buttons --------------------------------------------------- */
.btn{
  display:inline-flex;align-items:center;gap:7px;justify-content:center;
  padding:9px 15px;border-radius:8px;font-size:13.5px;font-weight:600;
  border:1px solid transparent;cursor:pointer;background:#fff;color:var(--ink);
  text-decoration:none;line-height:1;
}
.btn:hover{text-decoration:none}
.btn-primary{background:var(--primary);color:#fff}
.btn-primary:hover{background:var(--primary-dark)}
.btn-accent{background:var(--accent);color:#fff}
.btn-accent:hover{background:#c9761f}
.btn-ghost{background:#fff;border-color:var(--line-strong);color:#33433c}
.btn-ghost:hover{background:#f5f8f5}
.btn-danger{background:#fff;border-color:#e6b3ab;color:var(--b-red-fg)}
.btn-danger:hover{background:var(--b-red-bg)}
.btn-sm{padding:6px 11px;font-size:12.5px}
.btn-row{display:flex;gap:10px;flex-wrap:wrap;margin-top:8px}

/* ---------- tables ---------------------------------------------------- */
.table-wrap{overflow-x:auto}
table.data{width:100%;border-collapse:collapse;font-size:13px}
table.data th{
  text-align:left;padding:11px 14px;background:#f6f9f6;
  font-size:11px;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);
  font-weight:700;border-bottom:1px solid var(--line);white-space:nowrap;
}
table.data td{padding:11px 14px;border-bottom:1px solid var(--line);vertical-align:middle}
table.data tr:last-child td{border-bottom:none}
table.data tbody tr:hover{background:#f8faf8}
table.data td.num{text-align:right;font-variant-numeric:tabular-nums}
.mono{font-variant-numeric:tabular-nums;font-feature-settings:"tnum"}
.strong{font-weight:600}
.dim{color:var(--muted)}

/* ---------- badges ---------------------------------------------------- */
.badge{
  display:inline-block;padding:3px 9px;border-radius:999px;
  font-size:11.5px;font-weight:600;white-space:nowrap;
}
.b-green{background:var(--b-green-bg);color:var(--b-green-fg)}
.b-amber{background:var(--b-amber-bg);color:var(--b-amber-fg)}
.b-blue{background:var(--b-blue-bg);color:var(--b-blue-fg)}
.b-teal{background:var(--b-teal-bg);color:var(--b-teal-fg)}
.b-red{background:var(--b-red-bg);color:var(--b-red-fg)}
.b-gray{background:var(--b-gray-bg);color:var(--b-gray-fg)}

/* ---------- pagination ------------------------------------------------ */
.pager{display:flex;gap:6px;align-items:center;justify-content:flex-end;padding:14px 18px;flex-wrap:wrap}
.pager a,.pager span{
  padding:6px 11px;border-radius:7px;font-size:13px;border:1px solid var(--line-strong);
  color:#33433c;background:#fff;
}
.pager a:hover{background:#f5f8f5;text-decoration:none}
.pager .cur{background:var(--primary);color:#fff;border-color:var(--primary)}
.pager .muted{border:none;color:var(--muted)}

/* ---------- detail rows ----------------------------------------------- */
.kv{display:grid;grid-template-columns:200px 1fr;gap:0}
.kv .r{display:contents}
.kv dt{padding:10px 0;border-bottom:1px solid var(--line);color:var(--muted);font-size:12.5px}
.kv dd{padding:10px 0;border-bottom:1px solid var(--line);margin:0;font-weight:500}

/* ---------- empty state ----------------------------------------------- */
.empty{text-align:center;padding:48px 20px;color:var(--muted)}
.empty .big{font-size:15px;color:var(--ink);font-weight:600;margin-bottom:6px}

/* ---------- login ----------------------------------------------------- */
.login-wrap{min-height:100vh;display:grid;place-items:center;padding:20px;
  background:radial-gradient(1200px 500px at 50% -10%,#10674c 0%,var(--primary-dark) 55%,#072c21 100%);}
.login-card{
  width:100%;max-width:380px;background:#fff;border-radius:14px;
  box-shadow:0 24px 60px rgba(0,0,0,.28);overflow:hidden;
}
.login-card .top{padding:26px 28px 6px;text-align:center}
.login-card .dot{
  width:46px;height:46px;border-radius:11px;margin:0 auto 12px;
  background:linear-gradient(135deg,var(--accent),#f0a94e);
  display:grid;place-items:center;color:#3a2208;font-weight:800;font-size:20px;
}
.login-card h1{font-size:18px}
.login-card .org{font-size:12px;color:var(--muted);margin-top:3px}
.login-card .body{padding:18px 28px 28px}
.login-foot{text-align:center;color:#bfe0cf;font-size:11.5px;margin-top:16px}

/* ---------- responsive ------------------------------------------------ */
@media (max-width:860px){
  .sidebar{transform:translateX(-100%);transition:transform .2s;z-index:60}
  body.nav-open .sidebar{transform:translateX(0)}
  .main{margin-left:0}
  .menu-toggle{display:inline-flex !important}
  .grid2,.grid3{grid-template-columns:1fr}
  .kv{grid-template-columns:1fr}
  .kv dt{border:none;padding-bottom:0}
  .kv dd{padding-top:2px}
  .scrim{display:none;position:fixed;inset:0;background:rgba(0,0,0,.4);z-index:50}
  body.nav-open .scrim{display:block}
}
.menu-toggle{display:none;background:none;border:1px solid var(--line-strong);
  border-radius:8px;padding:7px 10px;cursor:pointer;font-size:16px}
