:root{
  --bg:#f4f7f6; --card:#ffffff; --ink:#2b3a34; --sub:#6b7c75;
  --brand:#3aa078; --brand-d:#2c7d5d; --accent:#e8915b;
  --line:#e3ece8; --warn:#c0563c; --ok:#2c7d5d; --pend:#c98a2b;
}
*{box-sizing:border-box}
body{margin:0;font-family:"Hiragino Kaku Gothic ProN","Yu Gothic UI",Meiryo,sans-serif;
  background:var(--bg);color:var(--ink);line-height:1.7}
a{color:var(--brand-d);text-decoration:none}
a:hover{text-decoration:underline}

.topbar{display:flex;align-items:center;gap:16px;background:linear-gradient(100deg,#3aa078,#2c7d5d);
  color:#fff;padding:12px 22px;box-shadow:0 2px 8px rgba(0,0,0,.08)}
.topbar .brand a{color:#fff;font-weight:700;font-size:18px}
.topbar .facility{font-weight:600;opacity:.95}
.topbar .userbox{margin-left:auto;display:flex;align-items:center;gap:12px;font-size:14px}
.topbar .logout{color:#eafff6;border:1px solid rgba(255,255,255,.5);padding:4px 10px;border-radius:8px}
.badge{display:inline-block;background:rgba(255,255,255,.25);border-radius:6px;padding:1px 7px;font-size:12px;margin-left:4px}
.badge-principal{background:var(--accent)}

.wrap{max-width:920px;margin:26px auto;padding:0 18px}
.foot{text-align:center;color:var(--sub);font-size:12px;padding:26px 12px 40px}

.flash{background:#fff7ec;border:1px solid #f0d9b8;color:#8a5a1c;padding:10px 14px;border-radius:10px;margin-bottom:16px}

.card{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:22px;margin-bottom:18px;box-shadow:0 1px 4px rgba(0,0,0,.03)}
h1{font-size:22px;margin:.2em 0 .5em}
h2{font-size:18px;margin:.2em 0 .6em}
.lead{color:var(--sub);margin-top:0}

.tiles{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.tile{display:block;background:var(--card);border:1px solid var(--line);border-radius:14px;padding:20px;text-align:center;transition:.15s}
.tile:hover{transform:translateY(-2px);box-shadow:0 6px 18px rgba(44,125,93,.12);text-decoration:none}
.tile .ico{font-size:34px}
.tile .tt{font-weight:700;margin-top:8px;color:var(--ink)}
.tile .ds{font-size:12.5px;color:var(--sub);margin-top:4px}

.stats{display:flex;gap:14px;margin-bottom:20px}
.stat{flex:1;background:var(--card);border:1px solid var(--line);border-radius:12px;padding:14px 16px}
.stat .n{font-size:26px;font-weight:700;color:var(--brand-d)}
.stat .l{font-size:12.5px;color:var(--sub)}

table{width:100%;border-collapse:collapse}
th,td{text-align:left;padding:9px 8px;border-bottom:1px solid var(--line);font-size:14px}
th{color:var(--sub);font-weight:600;font-size:12.5px}

.st{display:inline-block;padding:2px 9px;border-radius:20px;font-size:12px;font-weight:600}
.st-draft{background:#eef2f0;color:#5a6b64}
.st-pending{background:#fbf0d8;color:var(--pend)}
.st-approved{background:#dff1e6;color:var(--ok)}
.st-rejected{background:#fadfd7;color:var(--warn)}

label{display:block;font-weight:600;font-size:14px;margin:14px 0 5px}
.req{color:var(--warn);font-size:12px;margin-left:4px}
input[type=text],input,textarea{width:100%;padding:10px 12px;border:1px solid #cfdbd5;border-radius:9px;font-size:15px;font-family:inherit}
textarea{min-height:90px;resize:vertical}
.hint{color:var(--sub);font-size:12px;margin-top:3px}

.btn{display:inline-block;background:var(--brand);color:#fff;border:none;border-radius:10px;padding:11px 20px;font-size:15px;font-weight:700;cursor:pointer}
.btn:hover{background:var(--brand-d);text-decoration:none}
.btn-sub{background:#eef2f0;color:var(--ink)}
.btn-sub:hover{background:#e0e8e4}
.btn-ok{background:var(--ok)}
.btn-warn{background:var(--warn)}
.btn-row{display:flex;gap:10px;flex-wrap:wrap;margin-top:18px;align-items:center}

.docbody{white-space:pre-wrap;background:#fbfdfc;border:1px solid var(--line);border-radius:10px;padding:18px;font-size:15px}
.note{background:#fef8f1;border-left:4px solid var(--accent);padding:10px 14px;border-radius:6px;color:#7a5a36;font-size:13.5px;margin:14px 0}

.timeline{list-style:none;padding:0;margin:0}
.timeline li{padding:7px 0;border-bottom:1px dashed var(--line);font-size:13px;color:var(--sub)}
.timeline b{color:var(--ink)}

/* login */
.login-wrap{max-width:380px;margin:8vh auto;padding:0 18px}
.login-card{background:#fff;border-radius:16px;padding:32px 28px;box-shadow:0 8px 30px rgba(44,125,93,.12);border:1px solid var(--line)}
.login-logo{text-align:center;font-size:30px}
.login-title{text-align:center;font-weight:700;font-size:20px;margin:6px 0 2px}
.login-sub{text-align:center;color:var(--sub);font-size:13px;margin-bottom:18px}

@media(max-width:680px){.tiles{grid-template-columns:1fr}.stats{flex-direction:column}}
