
:root{
  --bg:#f5f8fd;
  --panel:#ffffff;
  --panel-soft:#f3f7ff;
  --text:#0f172a;
  --muted:#64748b;
  --line:#dbe4f0;
  --line-strong:#c5d3e6;
  --primary:#2f6fed;
  --primary-strong:#2557c7;
  --primary-soft:#eaf1ff;
  --profit:#d92d20;
  --profit-soft:#fde8e7;
  --loss:#2563eb;
  --loss-soft:#e8f0ff;
  --warning:#d97706;
  --warning-soft:#fff3e3;
  --success:#059669;
  --success-soft:#e4faf3;
  --shadow:0 10px 28px rgba(15,23,42,.08);
  --radius:18px;
  --radius-sm:12px;
  --radius-xs:10px;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0;background:var(--bg);color:var(--text);font-family:-apple-system,BlinkMacSystemFont,"Apple SD Gothic Neo","Pretendard","Noto Sans KR",sans-serif}
body.modal-open{overflow:hidden}
button,input,select,textarea{font:inherit}
button{cursor:pointer}
a{color:inherit;text-decoration:none}
.app-shell{min-height:100vh;padding:18px 16px 112px}
.screen-root{max-width:760px;margin:0 auto}
.header-row{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:16px}
.page-title{font-size:28px;font-weight:800;letter-spacing:-.03em;margin:0}
.page-subtitle{margin:6px 0 0;color:var(--muted);font-size:14px;line-height:1.45}
.save-trust{display:inline-flex;align-items:center;gap:8px;margin-top:8px;padding:7px 10px;border-radius:999px;border:1px solid var(--line);background:var(--panel-soft);font-size:12px;color:var(--muted)}
.save-dot{width:8px;height:8px;border-radius:50%;background:var(--primary);box-shadow:0 0 0 4px rgba(47,111,237,.12)}
.card{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:16px;box-shadow:var(--shadow)}
.card + .card{margin-top:14px}
.card-title{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:10px}
.card-title h2,.card-title h3{margin:0;font-size:17px}
.card-title span{font-size:12px;color:var(--muted)}
.stack-8>*+*{margin-top:8px}
.stack-10>*+*{margin-top:10px}
.stack-12>*+*{margin-top:12px}
.stack-14>*+*{margin-top:14px}
.muted{color:var(--muted)}
.tiny{font-size:12px;color:var(--muted)}
.small{font-size:13px}
.row{display:flex;align-items:center;gap:8px}
.row.wrap{flex-wrap:wrap}
.space{display:flex;align-items:center;justify-content:space-between;gap:10px}
.grid-2{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}
.grid-3{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}
@media (max-width:720px){.grid-3,.grid-2{grid-template-columns:1fr}}
.kpi-card{padding:14px;border-radius:16px;background:linear-gradient(180deg,var(--panel-soft),#fff);border:1px solid var(--line)}
.kpi-label{font-size:12px;color:var(--muted)}
.kpi-value{margin-top:4px;font-size:22px;font-weight:800}
.section-spacer{height:8px}
.meta-line{font-size:12px;color:var(--muted)}
.empty-card{text-align:center;padding:20px 16px}
.empty-card h3{margin:0 0 6px;font-size:16px}
.empty-card p{margin:0 0 12px;color:var(--muted);font-size:14px;line-height:1.45}
.btn{appearance:none;border:none;border-radius:14px;padding:11px 14px;min-height:42px;font-weight:700}
.btn.primary{background:var(--primary);color:#fff}
.btn.primary:hover{background:var(--primary-strong)}
.btn.secondary{background:#fff;color:var(--primary);border:1px solid #b8cbef}
.btn.ghost{background:transparent;color:var(--muted);border:1px solid var(--line)}
.btn.danger{background:#fff;color:var(--profit);border:1px solid #f3c6c2}
.btn.icon{display:inline-flex;align-items:center;justify-content:center;padding:9px 12px;min-width:42px}
.btn.small{min-height:34px;padding:8px 10px;border-radius:12px;font-size:13px}
.inline-actions{display:flex;flex-wrap:wrap;gap:8px}
.inline-actions-2{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}
.badge{display:inline-flex;align-items:center;justify-content:center;min-height:28px;padding:4px 10px;border-radius:999px;font-size:12px;font-weight:700}
.badge.hold{color:var(--primary);background:var(--primary-soft)}
.badge.watch{color:var(--warning);background:var(--warning-soft)}
.badge.closed{color:var(--muted);background:#eef3f9}
.badge.buy{color:var(--profit);background:var(--profit-soft)}
.badge.sell{color:var(--loss);background:var(--loss-soft)}
.badge.warning{color:var(--warning);background:var(--warning-soft)}
.badge.success{color:var(--success);background:var(--success-soft)}
.badge.tag{color:var(--muted);background:#eef3f9}
.badge.due-today{color:var(--profit);background:var(--profit-soft)}
.badge.due-soon{color:var(--warning);background:var(--warning-soft)}
.badge.due-idle{color:var(--muted);background:#eef3f9}
.compact-card{padding:15px}
.card-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}
.card-main{min-width:0}
.card-title-line{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.card-title-line strong{font-size:17px}
.card-reason{margin-top:6px;font-size:14px;font-weight:700;line-height:1.45}
.card-snippet{margin-top:6px;font-size:13px;line-height:1.45;color:var(--muted);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.keyword-row{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}
.keyword{display:inline-flex;align-items:center;gap:4px;padding:4px 8px;border-radius:999px;border:1px solid var(--line);background:var(--panel-soft);font-size:11px;font-weight:700;color:var(--muted)}
.keyword.strategy{color:var(--primary);background:#eef4ff;border-color:#d2dff7}
.keyword.caution{color:var(--warning);background:var(--warning-soft);border-color:#f5ddb8}
.keyword.alert{color:var(--profit);background:var(--profit-soft);border-color:#f5cdca}
.card-meta{margin-top:10px;font-size:12px;color:var(--muted)}
.metrics-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}
.metric-box{padding:12px;border:1px solid var(--line);border-radius:14px;background:var(--panel-soft)}
.metric-box .label{font-size:12px;color:var(--muted)}
.metric-box .value{margin-top:4px;font-size:15px;font-weight:800}
.metric-box .value.profit{color:var(--profit)}
.metric-box .value.loss{color:var(--loss)}
.note-section{padding-top:4px}
.note-section h4{margin:0 0 6px;font-size:14px}
.note-line{font-size:14px;line-height:1.55}
.list{display:flex;flex-direction:column;gap:10px}
.list-btn{appearance:none;border:none;background:transparent;padding:0;text-align:left}
.filter-row{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;margin-bottom:14px}
.chips{display:flex;flex-wrap:wrap;gap:8px}
.chip{appearance:none;border:none;padding:8px 12px;border-radius:999px;background:#eef3f9;color:var(--muted);font-size:13px;font-weight:700}
.chip.is-active{background:var(--primary);color:#fff}
.search-box{display:flex;align-items:center;gap:8px;padding:10px 12px;border-radius:14px;border:1px solid var(--line);background:#fff}
.search-box input{border:none;outline:none;background:transparent;width:100%;font-size:14px}
.search-box .clear-btn{appearance:none;border:none;background:transparent;color:var(--muted);font-size:13px}
.tabbar{position:fixed;left:50%;transform:translateX(-50%);bottom:18px;width:min(760px,calc(100vw - 24px));display:grid;grid-template-columns:repeat(4,1fr);gap:8px;padding:10px;border-radius:24px;background:rgba(255,255,255,.96);backdrop-filter:blur(18px);box-shadow:0 18px 34px rgba(15,23,42,.16);border:1px solid rgba(219,228,240,.9);z-index:40}
.tab{appearance:none;border:none;background:transparent;color:var(--muted);padding:10px 6px;border-radius:16px;display:flex;flex-direction:column;align-items:center;gap:6px;font-size:12px;font-weight:800}
.tab.is-active{color:var(--primary);background:var(--primary-soft)}
.tab-icon{font-size:16px;line-height:1}
.fab{position:fixed;right:max(18px,calc((100vw - min(760px,calc(100vw - 24px))) / 2 + 16px));bottom:98px;width:58px;height:58px;border:none;border-radius:50%;background:var(--primary);color:#fff;font-size:30px;line-height:1;box-shadow:0 18px 34px rgba(47,111,237,.3);z-index:35}
.modal-root{position:fixed;inset:0;display:none;z-index:90}
.modal-root[data-open="true"]{display:flex}
.modal-backdrop{position:absolute;inset:0;background:rgba(15,23,42,.48)}
.sheet{position:relative;margin-top:auto;width:min(760px,100%);max-height:min(88vh,920px);margin-left:auto;margin-right:auto;background:var(--panel);border-radius:28px 28px 0 0;overflow:auto;padding:14px 16px 18px;box-shadow:0 -18px 40px rgba(15,23,42,.22)}
.sheet-handle{width:54px;height:5px;border-radius:999px;background:var(--line-strong);margin:0 auto 12px}
.sheet-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:12px}
.sheet-title{margin:0;font-size:22px;font-weight:800}
.sheet-subtitle{margin:6px 0 0;font-size:13px;color:var(--muted);line-height:1.45}
.form{display:flex;flex-direction:column;gap:12px}
.field{display:flex;flex-direction:column;gap:6px}
.field label{font-size:13px;font-weight:800}
.field .hint{font-size:12px;color:var(--muted)}
.field input,.field select,.field textarea{width:100%;border:1px solid var(--line);background:#fff;border-radius:14px;padding:11px 12px;outline:none;font-size:14px;color:var(--text)}
.field input:focus,.field select:focus,.field textarea:focus{border-color:#b8cbef;box-shadow:0 0 0 4px rgba(47,111,237,.10)}
.field textarea{min-height:90px;resize:vertical}
.form-status{font-size:12px;color:var(--muted)}
.form-status.saved{color:var(--success)}
.form-status.error{color:var(--profit)}
.form-footer{display:flex;align-items:center;justify-content:space-between;gap:12px;padding-top:2px}
.form-footer .btn.primary{min-width:136px}
.summary-banner{padding:12px 14px;border-radius:16px;border:1px solid var(--line);background:linear-gradient(180deg,var(--panel-soft),#fff)}
.summary-banner h4{margin:0 0 6px;font-size:14px}
.summary-banner p{margin:0;font-size:13px;line-height:1.5;color:var(--muted)}
.archive-inline{display:inline-flex;align-items:center;gap:8px}
.archive-side{display:flex;align-items:center;justify-content:space-between;gap:12px}
.toast{position:fixed;left:50%;bottom:164px;transform:translateX(-50%) translateY(16px);padding:12px 16px;border-radius:14px;background:#0f172a;color:#fff;font-size:13px;font-weight:700;opacity:0;pointer-events:none;transition:.18s ease;z-index:120;max-width:calc(100vw - 40px);text-align:center;box-shadow:0 14px 30px rgba(15,23,42,.25)}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
.divider{height:1px;background:var(--line);margin:4px 0}
.linkish{appearance:none;border:none;padding:0;background:transparent;color:var(--primary);font-size:13px;font-weight:800}
.warning-box{padding:12px 14px;border-radius:16px;background:var(--warning-soft);border:1px solid #f3d7ac}
.alert-box{padding:12px 14px;border-radius:16px;background:var(--profit-soft);border:1px solid #f4ccc8}
.success-box{padding:12px 14px;border-radius:16px;background:var(--success-soft);border:1px solid #c6eedf}
.hidden{display:none!important}
mark.hl{background:#fff2c7;color:inherit;padding:0 2px;border-radius:4px}
@media (max-width:540px){
  .app-shell{padding:14px 12px 110px}
  .page-title{font-size:24px}
  .card{padding:14px}
  .sheet{padding:12px 12px 16px}
  .inline-actions-2{grid-template-columns:1fr}
  .fab{width:54px;height:54px;bottom:94px}
}
