:root{
  --green-900:#0c3a1f;
  --green-800:#0f4626;
  --green-700:#13502b;
  --green-600:#1c6c3a;
  --green-100:#e9f2ea;
  --green-050:#f4f8f4;
  --gold:#d99c0a;
  --gold-dark:#a9770a;
  --gold-100:#fbf2dc;
  --ink:#1f2a24;
  --muted:#5c6b61;
  --line:#dde5de;
  --paper:#ffffff;
  --danger:#a8341f;
  --danger-bg:#fbe9e4;
  --radius:10px;
  --shadow:0 1px 2px rgba(12,58,31,.06),0 6px 20px rgba(12,58,31,.06);
  --serif:Georgia,'Times New Roman',serif;
  --sans:-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,Helvetica,Arial,sans-serif;
}

*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{
  margin:0;font-family:var(--sans);color:var(--ink);
  background:var(--green-050);line-height:1.5;font-size:15px;
}
a{color:var(--green-700);text-decoration:none}
a:hover{text-decoration:underline}
h1,h2,h3{line-height:1.2;margin:0 0 .4em}

/* ---------- Brand bar ---------- */
.topbar{
  background:var(--green-700);
  background:linear-gradient(180deg,var(--green-700),var(--green-800));
  color:#fff;border-bottom:3px solid var(--gold);
}
.topbar-inner{
  max-width:1080px;margin:0 auto;padding:10px 20px;
  display:flex;align-items:center;gap:16px;flex-wrap:wrap;
}
.brand{display:flex;align-items:center;gap:12px;min-width:0}
.brand img{height:40px;width:auto;background:#fff;border-radius:6px;padding:4px}
.brand .titles{display:flex;flex-direction:column;min-width:0}
.brand .uni{font-family:var(--serif);font-weight:700;font-size:15px;letter-spacing:.2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.brand .sub{font-size:11px;color:var(--gold-100);letter-spacing:.5px;text-transform:uppercase}
.topbar .spacer{flex:1}
.topbar .who{font-size:13px;text-align:right;line-height:1.3}
.topbar .who b{display:block;font-weight:600}
.topbar .who a{color:var(--gold-100)}

/* ---------- Nav ---------- */
.nav{background:var(--green-800);border-bottom:1px solid rgba(255,255,255,.08)}
.nav-inner{max-width:1080px;margin:0 auto;padding:0 20px;display:flex;gap:4px;flex-wrap:wrap}
.nav a{
  color:#dfeede;padding:11px 14px;font-size:14px;font-weight:500;
  border-bottom:3px solid transparent;
}
.nav a:hover{text-decoration:none;color:#fff}
.nav a.active{color:#fff;border-bottom-color:var(--gold)}

/* ---------- Layout ---------- */
.wrap{max-width:1080px;margin:0 auto;padding:24px 20px 60px}
.page-head{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;margin-bottom:18px;flex-wrap:wrap}
.page-head h1{font-family:var(--serif);font-size:24px;color:var(--green-900)}
.page-head p{margin:.2em 0 0;color:var(--muted);font-size:14px}

.card{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow)}
.card-pad{padding:20px}
.grid{display:grid;gap:20px}
@media(min-width:820px){.memo-grid{grid-template-columns:1.15fr .85fr}}

/* ---------- Tabs ---------- */
.tabs{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:18px}
.tabs a{
  padding:7px 14px;border-radius:999px;font-size:13.5px;font-weight:600;
  background:var(--green-100);color:var(--green-800);border:1px solid transparent;
}
.tabs a:hover{text-decoration:none;background:var(--green-100);border-color:var(--green-600)}
.tabs a.active{background:var(--green-700);color:#fff}
.tabs a .count{margin-left:6px;background:var(--gold);color:#3a2900;border-radius:999px;padding:0 7px;font-size:11px;font-weight:700}
.tabs a.active .count{background:var(--gold)}

/* ---------- Tables ---------- */
table.memos{width:100%;border-collapse:collapse;background:var(--paper);border-radius:var(--radius);overflow:hidden;border:1px solid var(--line)}
table.memos th{
  text-align:left;font-size:11.5px;text-transform:uppercase;letter-spacing:.6px;
  color:var(--muted);background:var(--green-050);padding:11px 14px;border-bottom:1px solid var(--line);
}
table.memos td{padding:12px 14px;border-bottom:1px solid var(--line);vertical-align:top;font-size:14px}
table.memos tr:last-child td{border-bottom:none}
table.memos tr:hover td{background:var(--green-050)}
.ref{font-family:var(--serif);font-weight:700;color:var(--green-800);white-space:nowrap}
.subject-link{font-weight:600}

/* ---------- Badges ---------- */
.badge{display:inline-block;padding:2px 9px;border-radius:999px;font-size:11.5px;font-weight:700;letter-spacing:.2px}
.badge-open{background:var(--green-100);color:var(--green-800)}
.badge-closed{background:#e7e9ea;color:#566}
.badge-urgent{background:var(--gold-100);color:var(--gold-dark)}
.badge-confidential{background:var(--danger-bg);color:var(--danger)}
.tag-action{display:inline-block;background:var(--gold-100);color:var(--gold-dark);border:1px solid #e7d29a;padding:2px 9px;border-radius:6px;font-size:11.5px;font-weight:700}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:7px;cursor:pointer;
  border:1px solid transparent;border-radius:8px;padding:9px 16px;
  font-size:14px;font-weight:600;font-family:inherit;
  background:var(--green-700);color:#fff;
}
.btn:hover{background:var(--green-800);text-decoration:none}
.btn-gold{background:var(--gold);color:#3a2900}
.btn-gold:hover{background:var(--gold-dark);color:#fff}
.btn-ghost{background:#fff;color:var(--green-800);border-color:var(--line)}
.btn-ghost:hover{background:var(--green-050)}
.btn-sm{padding:6px 12px;font-size:13px}
.btn-danger{background:var(--danger)}
.btn-danger:hover{background:#7f2616}

/* ---------- Forms ---------- */
label.fld{display:block;margin:0 0 14px}
label.fld > span{display:block;font-size:13px;font-weight:600;color:var(--green-900);margin-bottom:5px}
.hint{font-weight:400;color:var(--muted);font-size:12px}
input[type=text],input[type=email],input[type=password],input[type=date],select,textarea{
  width:100%;padding:10px 12px;border:1px solid var(--line);border-radius:8px;
  font-family:inherit;font-size:14.5px;color:var(--ink);background:#fff;
}
textarea{min-height:120px;resize:vertical;line-height:1.55}
input:focus,select:focus,textarea:focus{outline:2px solid var(--green-600);outline-offset:1px;border-color:var(--green-600)}
.row2{display:grid;gap:0 16px}
@media(min-width:640px){.row2{grid-template-columns:1fr 1fr}}
select[multiple]{min-height:120px}
.check{display:flex;align-items:center;gap:8px;font-size:14px}
.check input{width:auto}

/* ---------- Flash ---------- */
.flash{padding:11px 16px;border-radius:8px;margin-bottom:16px;font-size:14px;font-weight:500;border:1px solid}
.flash-info{background:var(--green-100);border-color:#bcd9c2;color:var(--green-900)}
.flash-success{background:#e3f4e6;border-color:#aedcb6;color:#1d5b2c}
.flash-error{background:var(--danger-bg);border-color:#e8b6a8;color:var(--danger)}

/* ---------- Memo document ---------- */
.doc{font-family:var(--serif);color:#23302a}
.doc .letterhead{display:flex;align-items:center;gap:14px;border-bottom:2px solid var(--green-700);padding-bottom:12px;margin-bottom:16px}
.doc .letterhead img{height:54px}
.doc .letterhead .uni{font-weight:700;font-size:17px;color:var(--green-900);line-height:1.2}
.doc .letterhead .motto{font-size:12px;color:var(--gold-dark);font-style:italic}
.doc .meta{font-family:var(--sans);font-size:13px;color:var(--muted);display:grid;gap:4px;margin-bottom:14px}
.doc .meta b{color:var(--ink)}
.doc h2.subject{font-size:19px;color:var(--green-900);margin:6px 0 12px}
.doc .bodytext{white-space:pre-wrap;font-size:15.5px;line-height:1.7}

/* ---------- Minute thread (signature element) ---------- */
.minutes{position:relative;padding-left:22px}
.minutes:before{content:"";position:absolute;left:7px;top:6px;bottom:6px;width:2px;background:var(--green-100)}
.minute{position:relative;margin-bottom:16px}
.minute:before{content:"";position:absolute;left:-22px;top:5px;width:14px;height:14px;border-radius:50%;background:#fff;border:3px solid var(--green-600)}
.minute.is-close:before{border-color:var(--gold)}
.minute .m-head{display:flex;align-items:baseline;justify-content:space-between;gap:10px;flex-wrap:wrap}
.minute .m-author{font-weight:700;color:var(--green-900);font-size:14px}
.minute .m-title{font-weight:400;color:var(--muted);font-size:12.5px}
.minute .m-time{font-size:12px;color:var(--muted);white-space:nowrap}
.minute .m-route{font-size:12.5px;color:var(--muted);margin:3px 0 6px}
.minute .m-route b{color:var(--green-800)}
.minute .m-body{background:var(--green-050);border:1px solid var(--line);border-left:3px solid var(--green-600);border-radius:0 8px 8px 0;padding:10px 12px;font-size:14px;white-space:pre-wrap}
.minute .m-attach{font-size:12.5px;margin-top:6px}

/* ---------- Movement timeline ---------- */
.move{display:flex;gap:10px;font-size:13px;padding:8px 0;border-bottom:1px dashed var(--line)}
.move:last-child{border-bottom:none}
.move .dot{flex:none;width:9px;height:9px;border-radius:50%;margin-top:5px;background:var(--green-600)}
.move .dot.cc{background:var(--gold)}
.move .m-when{color:var(--muted);font-size:12px}
.section-title{font-size:12px;text-transform:uppercase;letter-spacing:.7px;color:var(--muted);font-weight:700;margin:0 0 10px}

/* ---------- Login ---------- */
.login-wrap{min-height:100vh;display:grid;place-items:center;padding:24px;
  background:radial-gradient(1200px 500px at 50% -10%,var(--green-100),var(--green-050))}
.login-card{width:100%;max-width:380px;background:#fff;border:1px solid var(--line);border-radius:14px;box-shadow:var(--shadow);overflow:hidden}
.login-head{background:var(--green-700);color:#fff;text-align:center;padding:24px 20px;border-bottom:3px solid var(--gold)}
.login-head img{height:64px;background:#fff;border-radius:50%;padding:6px;margin-bottom:10px}
.login-head .uni{font-family:var(--serif);font-weight:700;font-size:16px;line-height:1.25}
.login-head .sub{font-size:11px;text-transform:uppercase;letter-spacing:1px;color:var(--gold-100);margin-top:4px}
.login-body{padding:24px}

.muted{color:var(--muted)}
.small{font-size:12.5px}
.empty{text-align:center;color:var(--muted);padding:40px 20px}
.empty .big{font-size:15px;color:var(--ink);font-weight:600;margin-bottom:4px}
.stack>*+*{margin-top:14px}
.inline-actions{display:flex;gap:10px;flex-wrap:wrap;align-items:center}
hr.soft{border:none;border-top:1px solid var(--line);margin:18px 0}

@media (prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important}}

/* ---------- Print (file cover) ---------- */
@media print{
  .topbar,.nav,.no-print,.tabs{display:none!important}
  body{background:#fff}
  .wrap{max-width:none;padding:0}
  .card{border:none;box-shadow:none}
  .memo-grid{display:block}
}
