/* Project OS — 차분한 파스텔 · 행동 우선 (마음근력 톤) */
:root{
  --bg:#faf7f5; --surface:#ffffff; --line:#efe6e2;
  --ink:#33292b; --muted:#9a8e8a; --soft:#bdaea9;
  --accent:#e8a0bf; --accent-ink:#b5557e;
  --indigo:#7c83c4; --green:#5fa97e; --amber:#e0a44b; --red:#d96a6a;
  --r:16px; --shadow:0 2px 14px rgba(120,90,90,.07);
  --tap:#f4ecee;
}
*{box-sizing:border-box}
html,body{margin:0;background:var(--bg);color:var(--ink);
  font-family:-apple-system,"Segoe UI",Roboto,"Malgun Gothic",sans-serif;
  -webkit-text-size-adjust:100%}
body{padding-bottom:90px}
b{font-weight:700}
small{color:var(--muted)}

/* 상단바 */
.topbar{position:sticky;top:0;z-index:20;display:flex;align-items:center;
  justify-content:space-between;gap:12px;padding:12px 16px;
  background:rgba(250,247,245,.92);backdrop-filter:blur(8px);border-bottom:1px solid var(--line)}
.brand{cursor:pointer;font-size:18px;display:flex;align-items:baseline;gap:6px}
.brand .sub{font-size:11px;color:var(--muted);margin-left:2px}
.filter{font-size:12px;color:var(--muted);display:flex;align-items:center;gap:6px}
.filter select{font-size:14px;padding:7px 10px;border-radius:10px;border:1px solid var(--line);
  background:var(--surface);color:var(--ink);max-width:46vw}

/* 탭 메뉴 */
.tabs{position:sticky;top:53px;z-index:19;display:flex;gap:6px;overflow-x:auto;
  padding:10px 12px;background:var(--bg);border-bottom:1px solid var(--line);scrollbar-width:none}
.tabs::-webkit-scrollbar{display:none}
.tabs button{flex:0 0 auto;border:1px solid var(--line);background:var(--surface);
  color:var(--soft);padding:8px 13px;border-radius:999px;font-size:14px;cursor:pointer;white-space:nowrap}
.tabs button.on{background:var(--accent);border-color:var(--accent);color:#fff;font-weight:700}

main{max-width:760px;margin:0 auto;padding:16px 14px}
.loading{color:var(--muted);text-align:center;padding:40px}

/* 섹션 */
.section{margin-bottom:26px}
.section>h2{font-size:13px;letter-spacing:.02em;color:var(--muted);margin:0 0 10px;
  text-transform:none;display:flex;align-items:center;gap:7px}
.section.hero>h2{font-size:15px;color:var(--accent-ink);font-weight:800}

.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);
  padding:14px;box-shadow:var(--shadow);margin-bottom:10px}
.card.click{cursor:pointer;transition:transform .08s}
.card.click:active{transform:scale(.99)}
.empty{color:var(--soft);font-size:14px;padding:14px;border:1px dashed var(--line);
  border-radius:var(--r);text-align:center}

/* 오늘 할 일 (가장 크게) */
.today .task{display:flex;align-items:flex-start;gap:11px;padding:14px;
  border:1px solid var(--line);border-radius:14px;background:var(--surface);margin-bottom:9px;box-shadow:var(--shadow)}
.today .task .ttl{font-size:17px;font-weight:700;line-height:1.35}
.today .task .next{font-size:13px;color:var(--accent-ink);margin-top:3px}
.task .meta{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}

/* 배지 */
.badge{font-size:11px;font-weight:700;padding:3px 8px;border-radius:999px;white-space:nowrap}
.b-me{background:#fdeef4;color:var(--accent-ink)}
.b-claude{background:#eef0fb;color:var(--indigo)}
.b-긴급{background:#fbe6e6;color:var(--red)}
.b-높음{background:#fcefdc;color:#c98421}
.b-보통{background:#eef3ef;color:var(--green)}
.b-낮음{background:#f0eeee;color:var(--soft)}
.b-plain{background:var(--tap);color:var(--muted)}
.dot{width:9px;height:9px;border-radius:50%;flex:0 0 auto;margin-top:6px}
.s-대기{background:var(--soft)}.s-진행중{background:var(--amber)}
.s-완료{background:var(--green)}.s-보류{background:var(--soft)}

/* 프로젝트 카드 (목록) */
.pgrid{display:grid;grid-template-columns:1fr 1fr;gap:10px}
@media(max-width:520px){.pgrid{grid-template-columns:1fr}}
.pcard h3{margin:0 0 4px;font-size:16px}
.pcard .goal{font-size:13px;color:var(--muted);line-height:1.4;min-height:18px}
.pcard .bar{height:7px;border-radius:4px;background:var(--tap);margin-top:10px;overflow:hidden}
.pcard .bar>i{display:block;height:100%;background:var(--accent);border-radius:4px}
.pcard .pct{font-size:11px;color:var(--soft);margin-top:5px;display:flex;justify-content:space-between}
.statuschip{font-size:11px;padding:2px 8px;border-radius:999px;background:var(--tap);color:var(--muted)}
.st-운영중{background:#eaf5ee;color:var(--green)}
.st-개발중{background:#fcefdc;color:#c98421}
.st-기획{background:#eef0fb;color:var(--indigo)}
.st-보류{background:#f0eeee;color:var(--soft)}

/* 인박스 빠른 입력 */
.inboxbox{display:flex;gap:8px}
.inboxbox input{flex:1;padding:13px 14px;border:1px solid var(--line);border-radius:12px;
  font-size:15px;background:var(--surface)}
.inboxbox button{padding:0 18px;border:none;border-radius:12px;background:var(--accent);
  color:#fff;font-weight:700;font-size:15px;cursor:pointer}
.linelist .row{display:flex;align-items:flex-start;gap:9px;padding:11px 4px;border-bottom:1px solid var(--line)}
.linelist .row:last-child{border-bottom:none}
.linelist .row .c1{flex:1;font-size:14px;line-height:1.4}
.linelist .mini{font-size:11px;color:var(--soft);margin-top:2px}
.rowbtn{font-size:12px;border:1px solid var(--line);background:var(--surface);color:var(--accent-ink);
  border-radius:8px;padding:5px 9px;cursor:pointer;white-space:nowrap}

/* 프로젝트 상세 */
.back{font-size:14px;color:var(--accent-ink);background:none;border:none;cursor:pointer;padding:0;margin-bottom:8px}
.recall{background:linear-gradient(180deg,#fff,#fdf6f9);border:2px solid var(--accent);
  border-radius:20px;padding:18px;box-shadow:var(--shadow);margin-bottom:18px}
.recall .pname{font-size:22px;font-weight:800;margin-bottom:2px}
.recall .tag{font-size:12px;color:var(--accent-ink);font-weight:700;margin-bottom:14px}
.recall .row{display:flex;gap:11px;padding:11px 0;border-top:1px solid #f3e3ea}
.recall .row:first-of-type{border-top:none}
.recall .k{flex:0 0 96px;font-size:12px;color:var(--muted);font-weight:700;padding-top:2px}
.recall .v{flex:1;font-size:15px;line-height:1.5}
.recall .v.big{font-size:17px;font-weight:700}
.recall .v.paused{color:var(--amber)}
.need{color:var(--soft);font-style:italic}

.detail h4{font-size:12px;color:var(--muted);margin:18px 0 8px}
.chips{display:flex;flex-wrap:wrap;gap:6px}
.chip{font-size:13px;background:var(--tap);color:var(--ink);padding:5px 10px;border-radius:9px}
.chip.no{background:#fbeeee;color:var(--red)}
.kv{font-size:13px;line-height:1.7}
.kv b{color:var(--muted);font-weight:600;display:inline-block;min-width:88px}

/* FAB */
.fab{position:fixed;right:18px;bottom:22px;width:60px;height:60px;border-radius:50%;
  border:none;background:var(--accent);color:#fff;font-size:32px;line-height:1;cursor:pointer;
  box-shadow:0 6px 20px rgba(184,85,126,.4);z-index:30}
.fab:active{transform:scale(.94)}

/* 모달 */
.modal-bg{position:fixed;inset:0;background:rgba(60,45,50,.4);z-index:40;
  display:flex;align-items:flex-end;justify-content:center}
.modal-bg[hidden]{display:none}
.modal{background:var(--surface);width:100%;max-width:520px;border-radius:22px 22px 0 0;
  padding:16px 16px 24px;box-shadow:0 -6px 30px rgba(0,0,0,.15);animation:up .18s ease}
@keyframes up{from{transform:translateY(40px);opacity:.6}to{transform:none;opacity:1}}
@media(min-width:560px){.modal-bg{align-items:center}.modal{border-radius:22px}}
.modal-head{display:flex;justify-content:space-between;align-items:center;font-weight:800;font-size:16px;margin-bottom:12px}
.modal-head .x{border:none;background:var(--tap);width:32px;height:32px;border-radius:50%;cursor:pointer;font-size:15px;color:var(--muted)}
.qa-tabs{display:flex;gap:6px;margin-bottom:14px}
.qa-tabs button{flex:1;padding:11px 4px;border:1px solid var(--line);background:var(--surface);
  border-radius:12px;font-size:14px;cursor:pointer;color:var(--soft)}
.qa-tabs button.on{background:var(--accent);border-color:var(--accent);color:#fff;font-weight:700}
.qa-body label{display:block;font-size:12px;color:var(--muted);margin:10px 0 4px}
.qa-body input,.qa-body textarea,.qa-body select{width:100%;padding:12px;border:1px solid var(--line);
  border-radius:12px;font-size:15px;background:var(--surface);color:var(--ink);font-family:inherit}
.qa-body textarea{min-height:64px;resize:vertical}
.qa-save{width:100%;margin-top:16px;padding:15px;border:none;border-radius:14px;background:var(--accent);
  color:#fff;font-weight:800;font-size:16px;cursor:pointer}
.qa-row{display:flex;gap:8px}.qa-row>*{flex:1}
.toast{position:fixed;left:50%;bottom:96px;transform:translateX(-50%);background:var(--ink);color:#fff;
  padding:11px 18px;border-radius:999px;font-size:14px;z-index:50;opacity:0;transition:opacity .2s}
.toast.on{opacity:1}

/* 로그인 */
#loginOverlay{position:fixed;inset:0;z-index:60;background:var(--bg);display:flex;align-items:center;justify-content:center;padding:24px}
#loginOverlay[hidden]{display:none}
.login-card{background:var(--surface);border:1px solid var(--line);border-radius:22px;padding:30px 22px;
  width:100%;max-width:340px;box-shadow:var(--shadow);text-align:center}
.login-card h2{margin:0 0 2px;font-size:24px}
.login-card p{color:var(--muted);margin:0 0 20px;font-size:13px}
.login-card input{width:100%;padding:14px;margin-bottom:10px;border:1px solid var(--line);
  border-radius:12px;font-size:15px;background:var(--surface)}
.login-card button{width:100%;padding:15px;border:none;border-radius:14px;background:var(--accent);
  color:#fff;font-weight:800;font-size:16px;cursor:pointer;margin-top:4px}
.login-card button:active{transform:scale(.99)}
.login-err{color:var(--red);font-size:13px;margin-top:12px;min-height:18px}
