:root{
  --bg:#f4f5f7; --card:#fff; --ink:#1c2430; --muted:#6b7684;
  --line:#e6e9ee; --brand:#1f6f54; --brand-d:#16523d; --accent:#c89b3c;
  --shadow:0 1px 3px rgba(20,30,40,.08),0 6px 18px rgba(20,30,40,.05);
  --radius:14px;
}
*{box-sizing:border-box}
body{margin:0;background:var(--bg);color:var(--ink);
  font-family:-apple-system,BlinkMacSystemFont,"Apple SD Gothic Neo","Pretendard",
  "Malgun Gothic",sans-serif;-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}

/* topbar */
.topbar{position:sticky;top:0;z-index:10;display:flex;align-items:center;
  justify-content:space-between;padding:12px 18px;background:var(--brand);
  color:#fff;padding-top:max(12px,env(safe-area-inset-top))}
.brand{font-weight:800;font-size:18px;letter-spacing:.5px}
.brand span{font-weight:500;opacity:.85}
.topbar-right{display:flex;align-items:center;gap:12px}
.who{font-size:13px;opacity:.9}
.btn-ghost{font-size:13px;border:1px solid rgba(255,255,255,.4);
  padding:5px 10px;border-radius:8px}

.container{max-width:1040px;margin:0 auto;padding:18px}

/* login */
.login-wrap{min-height:80vh;display:flex;align-items:center;justify-content:center}
.login-card{background:var(--card);border-radius:18px;box-shadow:var(--shadow);
  padding:34px 28px;width:100%;max-width:360px;text-align:center}
.login-logo{font-size:22px;font-weight:800;color:var(--brand)}
.login-logo span{color:var(--ink);font-weight:600}
.login-sub{color:var(--muted);margin:4px 0 22px;font-size:13px}
.login-form{display:flex;flex-direction:column;gap:14px;text-align:left}
.login-form label{font-size:13px;color:var(--muted);display:flex;flex-direction:column;gap:6px}
.login-form input{padding:12px;border:1px solid var(--line);border-radius:10px;font-size:15px}
.login-hint{margin-top:16px;font-size:12px;color:var(--muted)}
.alert{background:#fdecec;color:#b3261e;border-radius:10px;padding:10px;font-size:13px;margin-bottom:14px}

.btn-primary{background:var(--brand);color:#fff;border:0;padding:12px 16px;
  border-radius:10px;font-size:15px;font-weight:700;cursor:pointer}
.btn-primary:hover{background:var(--brand-d)}

/* page head */
.page-head h1{font-size:20px;margin:6px 0 14px}
.count{display:inline-block;background:var(--brand);color:#fff;font-size:12px;
  border-radius:20px;padding:2px 9px;margin-left:6px;vertical-align:middle}

/* filters */
.filters{margin-bottom:16px}
.search{width:100%;padding:12px 14px;border:1px solid var(--line);border-radius:12px;
  font-size:15px;background:#fff}
.chips{display:flex;gap:8px;flex-wrap:wrap;margin-top:10px}
.chip{font-size:13px;padding:6px 12px;border-radius:20px;background:#fff;
  border:1px solid var(--line);color:var(--muted)}
.chip.on{background:var(--brand);color:#fff;border-color:var(--brand)}

/* grid */
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:14px}
.card{background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow);
  padding:16px;display:flex;flex-direction:column;gap:6px;transition:transform .08s,box-shadow .12s;
  border:1px solid transparent}
.card:hover{transform:translateY(-2px);border-color:var(--line)}
.card-top{display:flex;justify-content:space-between;align-items:center}
.cid{font-size:12px;color:var(--muted)}
.badge{font-size:11px;background:#eef6f2;color:var(--brand);padding:2px 8px;border-radius:20px;font-weight:700}
.card-name{font-size:16px;font-weight:700;line-height:1.3}
.card-ceo{font-size:13px;color:var(--muted)}
.card-goals{display:flex;gap:5px;flex-wrap:wrap;margin-top:6px}
.tag{font-size:11px;background:#f1f3f6;color:#48515c;padding:3px 8px;border-radius:6px}
.empty{color:var(--muted);font-size:14px;padding:20px 0}

/* detail */
.back{display:inline-block;color:var(--muted);font-size:14px;margin-bottom:12px}
.detail-head{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;flex-wrap:wrap}
.detail-head h1{font-size:22px;margin:0}
.detail-meta{color:var(--muted);font-size:13px;margin-top:4px}
.detail-goals{display:flex;gap:6px;flex-wrap:wrap}
.panel{background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow);
  padding:18px;margin-top:16px}
.panel h2{font-size:15px;margin:0 0 12px;color:var(--brand)}
.kv{width:100%;border-collapse:collapse;font-size:13px}
.kv th{text-align:left;vertical-align:top;color:var(--muted);font-weight:600;
  width:38%;padding:8px 10px 8px 0;border-bottom:1px solid var(--line)}
.kv td{padding:8px 0;border-bottom:1px solid var(--line);line-height:1.5}

/* entry form */
.entry-form{display:flex;flex-direction:column;gap:10px}
.entry-form select,.entry-form textarea{padding:11px;border:1px solid var(--line);
  border-radius:10px;font-size:14px;font-family:inherit;width:100%}
.entry-form button{align-self:flex-end}

/* timeline */
.timeline{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:12px}
.timeline li{border-left:3px solid var(--brand);padding:2px 0 2px 12px}
.tl-head{display:flex;align-items:center;gap:8px;flex-wrap:wrap;font-size:12px}
.tl-kind{font-weight:700;color:var(--ink)}
.tl-src{font-size:10px;padding:1px 6px;border-radius:5px}
.src-app{background:#eef6f2;color:var(--brand)}
.src-bot{background:#eef1fb;color:#3a52b5}
.tl-meta{color:var(--muted)}
.tl-text{font-size:14px;line-height:1.55;margin-top:4px}

/* users / account management */
.alert.ok{background:#eaf6ef;color:var(--brand-d)}
.user-add{display:flex;gap:8px;flex-wrap:wrap;align-items:center}
.user-add input,.user-add select{padding:10px;border:1px solid var(--line);
  border-radius:9px;font-size:14px}
.user-add input{flex:1;min-width:120px}
table.users{width:100%;border-collapse:collapse;font-size:14px}
table.users th{text-align:left;color:var(--muted);font-weight:600;padding:8px 10px;
  border-bottom:1px solid var(--line);font-size:12px}
table.users td{padding:10px;border-bottom:1px solid var(--line);vertical-align:middle}
.u-id{font-weight:700}
.role-admin{background:#eef6f2;color:var(--brand);font-size:11px;padding:2px 8px;border-radius:6px;font-weight:700}
.inline{display:flex;gap:6px;align-items:center;margin:0}
.inline input{padding:7px 9px;border:1px solid var(--line);border-radius:8px;font-size:13px;width:120px}
.btn-mini{background:var(--brand);color:#fff;border:0;border-radius:8px;padding:7px 11px;font-size:13px;cursor:pointer}
.btn-del{background:#fff;color:#b3261e;border:1px solid #e7c3c0;border-radius:8px;padding:7px 12px;font-size:13px;cursor:pointer}
.btn-del:hover{background:#fdecec}

@media(max-width:520px){
  .grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:10px}
  .container{padding:14px}
  table.users thead{display:none}
  table.users,table.users tbody,table.users tr,table.users td{display:block;width:100%}
  table.users tr{border:1px solid var(--line);border-radius:12px;margin-bottom:10px;padding:6px 10px}
  table.users td{border:0;padding:6px 0}
  .inline input{width:100%}
}
