:root{--bg: #f4f8fc;--bg-soft: #e8eff7;--panel: rgba(255, 255, 255, .88);--panel-solid: #ffffff;--border: #dde7f2;--text: #0f172a;--muted: #64748b;--brand: #0f766e;--brand-soft: #d9f3f1;--danger: #be123c;--danger-soft: #ffe4e9;--up: #15803d;--down: #b91c1c;--shadow: 0 14px 36px rgba(15, 23, 42, .08)}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh;color:var(--text);font-family:PingFang SC,Noto Sans SC,SF Pro Text,sans-serif;background:radial-gradient(circle at 0% 0%,#dff5f2 0,transparent 44%),radial-gradient(circle at 100% 0%,#e2ebff 0,transparent 40%),linear-gradient(180deg,var(--bg) 0%,var(--bg-soft) 100%);text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{width:100%}.layout{max-width:1080px;margin:0 auto;padding:22px 16px 34px}.topbar{display:flex;justify-content:space-between;gap:18px;align-items:flex-start;margin-bottom:14px;padding:16px;border:1px solid var(--border);border-radius:18px;background:var(--panel);box-shadow:var(--shadow);backdrop-filter:blur(8px)}.topbar h1{margin:0;font-size:26px;letter-spacing:.01em}.topbar p{margin:8px 0 0;color:var(--muted);font-size:14px}.status{display:flex;flex-direction:column;gap:6px;align-items:flex-end;min-width:190px;font-size:12px}.pill{display:inline-flex;align-items:center;border-radius:999px;padding:6px 10px;font-weight:600;line-height:1}.pill-ok{color:#047857;background:#d1fae5}.pill-warn{color:#92400e;background:#ffedd5}.muted{color:var(--muted)}.tabs{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-bottom:12px;padding:8px;border-radius:14px;border:1px solid var(--border);background:rgba(255,255,255,.75);backdrop-filter:blur(6px)}button,input,select{border:1px solid var(--border);border-radius:12px;padding:10px 12px;font-size:14px;background:#fff;color:var(--text)}input::placeholder{color:#94a3b8}button{cursor:pointer;transition:all .18s ease}button:hover{transform:translateY(-1px)}.tabs button{border:none;background:transparent;color:#334155;font-weight:600}.tabs button.active{background:#0f766e;color:#fff;box-shadow:0 8px 20px rgba(15,118,110,.24)}.inline-form button{border-color:#0f766e;background:#0f766e;color:#fff;font-weight:600}.inline-form button:hover{background:#0d655f}button.danger{background:var(--danger-soft);color:var(--danger);border-color:#fecdd3}.panel{background:var(--panel-solid);border:1px solid var(--border);border-radius:18px;padding:16px;box-shadow:var(--shadow)}.panel h2{margin:0 0 12px;font-size:17px}.inline-form{display:grid;grid-template-columns:repeat(auto-fit,minmax(165px,1fr));gap:8px;margin-bottom:12px}.watch-controls{margin-bottom:14px;padding:12px;border:1px solid var(--border);border-radius:14px;background:#f8fbff}.watch-control-row{display:flex;gap:12px;align-items:center;margin-bottom:10px}.watch-control-row:last-child{margin-bottom:0}.watch-control-row span{width:72px;flex-shrink:0;color:var(--muted);font-size:13px}.chip-group{display:flex;flex-wrap:wrap;gap:8px}.chip{padding:6px 10px;border-radius:999px;border:1px solid #cdd9e7;background:#fff;color:#334155;font-size:13px}.chip.active{border-color:#0f766e;background:#d9f3f1;color:#0f766e}.watch-group-block{margin-top:12px}.watch-group-title{margin:0 0 10px;font-size:14px;color:#334155}.watch-tile-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:8px}.watch-tile{text-align:left;border:1px solid var(--border);border-radius:12px;background:#fbfdff;padding:10px}.watch-tile.active{border-color:#0f766e;box-shadow:0 6px 14px rgba(15,118,110,.14)}.watch-tile-head{margin-bottom:8px}.watch-tile-title{font-size:14px;font-weight:600}.watch-tile-meta{margin-top:2px;color:var(--muted);font-size:12px}.watch-tile-body{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:6px}.watch-tile-body span{display:block;color:var(--muted);font-size:11px}.watch-tile-body strong{font-size:13px}.watch-detail-card{margin-top:10px}.watch-inline-detail{grid-column:1 / -1;margin-top:0}.watch-inline-detail .metrics{gap:10px}.watch-inline-detail .metrics>div:not(.ma-block){border:1px solid #e6eef8;border-radius:10px;background:#fbfdff;padding:8px 9px}.watch-inline-detail .metrics>div:not(.ma-block) span{margin-bottom:4px;font-size:11px}.watch-inline-detail .metrics>div:not(.ma-block) strong{font-size:14px}.empty-state{border:1px dashed #cbd5e1;border-radius:12px;padding:18px;text-align:center;color:var(--muted);font-size:13px}.grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.card{border:1px solid var(--border);border-radius:14px;padding:12px;background:linear-gradient(180deg,#fff,#f9fcff)}.card-head{display:flex;justify-content:space-between;align-items:center;gap:10px}.card-head h3{margin:0;font-size:15px}.card-head p{margin:3px 0 0;color:var(--muted);font-size:12px}.metrics{margin-top:12px;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;align-items:start}.metrics span{display:block;color:var(--muted);font-size:12px;margin-bottom:2px}.metrics strong{font-size:15px;line-height:1.35;font-variant-numeric:tabular-nums}.ma-block{grid-column:1 / -1}.ma-grid{margin-top:6px;display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px}.ma-cell{border:1px solid #dfe8f3;border-radius:10px;background:#f8fbff;padding:8px 9px}.ma-cell label{display:block;color:#64748b;font-size:11px;margin-bottom:3px}.ma-cell strong{font-size:14px;white-space:nowrap}small{display:block;margin-top:10px;color:#64748b}.up{color:var(--up)}.down,.error{color:var(--down)}.summary{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;margin-bottom:12px}.summary div{border:1px solid var(--border);border-radius:14px;padding:12px;background:#fbfdff}.summary span{font-size:12px;color:var(--muted);display:block}.summary strong{font-size:19px}.summary-total strong{font-size:18px}.table{border:1px solid var(--border);border-radius:14px;overflow:hidden}.table-head,.table-row{display:grid;grid-template-columns:1.2fr 1fr 1fr 1fr 1fr 1fr;gap:6px;padding:11px 10px;font-size:13px}.table-head-portfolio,.table-row-portfolio{grid-template-columns:.8fr 1.2fr .8fr .9fr .9fr 1.2fr .8fr 1fr 1fr 1.2fr}.table-row-group{grid-template-columns:1fr 1fr;background:#f8fbff;color:#334155;font-weight:600}.market-summary{grid-template-columns:repeat(4,minmax(0,1fr))}.market-summary small{margin-top:6px}.table-head{background:#f1f6fb;color:#475569;font-weight:600}.table-row{border-top:1px solid #edf2f8}.list{display:flex;flex-direction:column;gap:8px}.list-item{border:1px solid var(--border);border-radius:12px;padding:10px;display:flex;align-items:center;justify-content:space-between;gap:10px;background:#fbfdff}.row-actions{display:flex;gap:8px}.row-actions button:not(.danger){background:#ecfeff;color:#0f766e;border-color:#a5f3fc}.portfolio-manage-panel{margin-bottom:12px;border:1px solid var(--border);border-radius:14px;background:#f8fbff;overflow:hidden}.portfolio-manage-panel summary{cursor:pointer;padding:12px;font-weight:600;color:#0f172a;background:#f2f8ff}.portfolio-manage-panel[open] summary{border-bottom:1px solid var(--border)}.portfolio-manage-panel .watch-controls,.portfolio-manage-panel .inline-form,.portfolio-manage-panel .hint,.portfolio-manage-panel .ocr-panel{margin:12px}.portfolio-sections{display:flex;flex-direction:column;gap:12px}.portfolio-market-section{border:1px solid var(--border);border-radius:14px;background:#fff;overflow:hidden}.portfolio-market-head{display:grid;grid-template-columns:.8fr 1fr 1fr;gap:8px;padding:10px 12px;background:#f7fbff;border-bottom:1px solid #e7eef8;align-items:center}.portfolio-market-head strong{font-size:15px}.portfolio-market-head span{text-align:right;font-size:13px;color:#334155}.portfolio-list-head,.portfolio-row{display:grid;grid-template-columns:1.2fr .85fr .85fr .9fr;gap:8px;padding:10px 12px;font-size:13px}.portfolio-list-head{color:#64748b;background:#fcfdff;border-bottom:1px solid #edf2f8}.portfolio-row{border-bottom:1px solid #edf2f8;grid-template-columns:1fr;gap:8px}.portfolio-market-section .portfolio-row:last-child{border-bottom:none}.portfolio-cell,.portfolio-row-title{display:flex;flex-direction:column;gap:3px}.portfolio-row-title strong{font-size:17px;line-height:1.2}.portfolio-row-title small{margin:0;color:#64748b;font-size:12px}.portfolio-inline-metrics{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.portfolio-inline-metrics span{border:1px dashed #dfe8f3;border-radius:10px;padding:6px 8px;display:flex;flex-direction:column;gap:2px}.portfolio-inline-metrics label{color:#94a3b8;font-size:11px}.portfolio-inline-metrics strong,.portfolio-cell strong{font-size:15px;line-height:1.25;font-variant-numeric:tabular-nums}.portfolio-cell small{margin:0;font-size:12px;line-height:1.2;color:#64748b}.portfolio-value-label{color:#94a3b8}.portfolio-edit-card{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:8px;padding:10px 12px 12px;border-bottom:1px solid #edf2f8;background:#f8fbff}.portfolio-edit-head{grid-column:1 / -1;display:flex;flex-direction:column;gap:2px}.portfolio-edit-head strong{font-size:14px}.portfolio-edit-head small{margin:0;font-size:12px;color:#64748b}.portfolio-edit-field{display:flex;flex-direction:column;gap:5px}.portfolio-edit-field span{font-size:12px;color:#64748b}.hint{margin:0 0 10px;color:#334155;font-size:13px}.multi-alert-picker{border:1px solid var(--border);border-radius:12px;background:#f8fbff;padding:10px;margin-bottom:10px}.multi-alert-list{max-height:160px;overflow:auto;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.multi-alert-item{display:flex;align-items:center;gap:8px;font-size:13px;color:#334155}.ocr-panel{border:1px dashed #c9d7e8;border-radius:14px;padding:12px;margin-bottom:12px;background:#f8fbff}.ocr-panel h3{margin:0 0 8px;font-size:15px}.ocr-list{border:1px solid var(--border);border-radius:10px;overflow:hidden}.ocr-item{display:grid;grid-template-columns:1fr .8fr 1fr 1fr 1.3fr;gap:8px;padding:8px 10px;font-size:12px;border-top:1px solid #e8eff6;font-variant-numeric:tabular-nums}.ocr-item:first-child{border-top:none}.ocr-raw{margin-top:8px}.ocr-raw summary{cursor:pointer;color:#334155;font-size:13px}.ocr-raw pre{margin:8px 0 0;max-height:140px;overflow:auto;padding:8px;border-radius:10px;background:#0f172a;color:#e2e8f0;font-size:11px}@media(max-width:900px){.layout{padding:14px 12px 26px}.topbar{flex-direction:column;align-items:flex-start;border-radius:16px}.status{align-items:flex-start}.tabs{grid-template-columns:repeat(2,1fr)}.watch-control-row{flex-direction:column;align-items:flex-start;gap:6px}.watch-control-row span{width:auto}.grid{grid-template-columns:1fr}.watch-tile-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.ma-grid{grid-template-columns:1fr}.watch-inline-detail .card-head{align-items:flex-start}.watch-inline-detail .card-head h3{font-size:20px}.watch-inline-detail .metrics{grid-template-columns:repeat(3,minmax(0,1fr));gap:8px}.watch-inline-detail .metrics>div:not(.ma-block){min-height:76px}.watch-inline-detail .ma-block{grid-column:1 / -1}.watch-inline-detail .ma-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:6px}.watch-inline-detail .ma-cell{padding:6px 7px}.watch-inline-detail .ma-cell strong{font-size:13px}.summary{grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.summary-total{grid-template-columns:repeat(3,minmax(0,1fr))}.summary-total div,.market-summary div{padding:10px;border-radius:12px}.summary-total strong{font-size:15px}.market-summary{grid-template-columns:repeat(2,minmax(0,1fr))}.market-summary strong{font-size:15px}.market-summary small{font-size:12px}.portfolio-market-head{grid-template-columns:1fr;gap:4px}.portfolio-market-head span{text-align:left}.portfolio-list-head,.portfolio-row{grid-template-columns:1fr;gap:6px}.portfolio-list-head{display:none}.portfolio-row{padding:12px}.portfolio-inline-metrics{grid-template-columns:repeat(2,minmax(0,1fr));gap:6px}.portfolio-inline-metrics span{border:1px solid #e8eff7;background:#fbfdff}.portfolio-inline-metrics strong{font-size:14px}.portfolio-row .row-actions{margin-top:2px}.table-head,.table-row{grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.table-head-portfolio,.table-row-portfolio{grid-template-columns:repeat(2,minmax(0,1fr))}.list-item{flex-direction:column;align-items:flex-start}.ocr-item{grid-template-columns:repeat(2,minmax(0,1fr))}.multi-alert-list{grid-template-columns:1fr}}:root{color:#0f172a;background-color:#f8fafc}
