:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color:#111827;background-color:#fff;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;min-width:320px;min-height:100vh;background:#fff;color:#111827}#root{width:100%;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media(prefers-color-scheme:light){a:hover{color:#747bff}button{background-color:#f9f9f9}}*{box-sizing:border-box}:root{--content-max-width: none;--content-padding-x: clamp(120px, 10vw, 420px);--content-padding-y: 32px}html,body,#root{height:100%}html{overflow:hidden}body{margin:0;display:flex;flex-direction:column;overflow-x:auto;overflow-y:auto;scrollbar-gutter:stable}.top-bar{height:32px;width:100%;display:flex;align-items:center;justify-content:flex-end;gap:14px;padding:0 var(--content-padding-x);font-size:.8rem;color:#374151;background:#f9fafb;border-bottom:1px solid #e5e7eb}.top-link{color:#374151;text-decoration:none;cursor:pointer}.top-link:hover{text-decoration:underline}.top-user{font-weight:600}.header{background:#fff;border-bottom:1px solid #e5e7eb;width:100%;min-height:64px;display:flex;align-items:center}.header-inner{display:flex;align-items:center;justify-content:space-between;width:100%;min-height:64px;padding:0 var(--content-padding-x)}.logo{font-size:1.25rem;font-weight:800;text-decoration:none;color:#111827;white-space:nowrap}.nav{display:flex;align-items:center;justify-content:center;gap:14px;flex:1;min-width:0;white-space:nowrap}.nav-ani{position:relative;padding:.5rem .9rem;font-size:.9rem;font-weight:500;line-height:1.2;color:#374151;text-decoration:none;background:none;border:none;cursor:pointer}.nav-ani:after{content:"";position:absolute;left:0;bottom:-6px;width:0%;height:2px;background:#5a33ff;transition:width .25s ease}.nav-ani:hover:after,.nav-ani.active:after{width:100%}.nav-ani:hover,.nav-ani.active{color:#5a33ff;font-weight:600}.nav-caret{margin-left:6px;font-size:1.05rem;line-height:1}.nav-dropdown{position:relative}.nav-dropdown-menu{position:absolute;top:calc(100% + 8px);left:0;min-width:160px;padding:6px 0;background:#fff;border:1px solid #e5e7eb;border-radius:10px;box-shadow:0 12px 24px #0000001f;z-index:3000;display:flex;flex-direction:column}.nav-dropdown-menu a{display:flex;align-items:center;gap:10px;padding:8px 14px;font-size:.85rem;color:#374151;text-decoration:none;white-space:nowrap}.nav-dropdown-menu a:hover{background:#f3f4f6}.nav-dd-mark{width:14px;text-align:center;color:#9ca3af;font-weight:700}.mypage-btn.login-required{color:#111827;font-weight:500;cursor:pointer}.mypage-btn.login-required:after{display:none}.content{flex:1;width:100%}.content-inner{width:100%;min-width:1200px;padding:var(--content-padding-y) var(--content-padding-x)}.page-header{margin-bottom:1.5rem;display:flex;align-items:center;justify-content:space-between}.footer{border-top:1px solid #e5e7eb;padding:.75rem;text-align:center;font-size:.8rem;color:#6b7280}.mypage-btn.login-required{position:relative}.mypage-btn.login-required:hover:before{content:attr(data-tooltip);position:absolute;top:calc(100% + 8px);left:50%;transform:translate(-50%);padding:6px 10px;font-size:.75rem;white-space:nowrap;color:#fff;background:#111827;border-radius:6px;box-shadow:0 4px 12px #00000026;z-index:4000}.mypage-btn.login-required:hover:after{content:"";position:absolute;top:calc(100% + 2px);left:50%;transform:translate(-50%);border-width:6px;border-style:solid;border-color:#111827 transparent transparent transparent}.page-header{max-width:var(--content-max-width);margin:0 auto 1.5rem;padding:0 var(--content-padding-x);display:flex;align-items:center;justify-content:space-between}@media(max-width:900px){.page-header{flex-wrap:wrap;gap:.75rem}}.page-title{font-size:1.4rem;font-weight:700;color:#111827;margin:0}.page-actions{display:flex;align-items:center;gap:.75rem}.login-page{min-height:calc(100vh - 120px);display:flex;justify-content:center;align-items:center}.login-card{width:420px;background:#fff;border-radius:10px;padding:2rem 2rem 2.2rem;box-shadow:0 8px 24px #00000014;border:1px solid #e5e7eb}.login-title{text-align:center;font-size:1.4rem;font-weight:700;margin-bottom:1.5rem}.login-error{background:#fee2e2;color:#b91c1c;font-size:.9rem;padding:.6rem;border-radius:6px;text-align:center;margin-bottom:1rem}.form-group label{display:block;font-size:.85rem;font-weight:500;color:#374151;margin-bottom:.3rem}.form-group input{width:100%;padding:.55rem .65rem;border-radius:6px;border:1px solid #d1d5db;font-size:.95rem}.form-group input:focus{outline:none;border-color:#5a33ff;box-shadow:0 0 0 2px #5a33ff26}.form-check{display:flex;align-items:center;gap:.4rem;margin:.8rem 0 1.4rem;font-size:.9rem;color:#374151}.login-btn{width:100%;padding:.65rem;border-radius:6px;border:none;background:#2563eb;color:#fff;font-size:1rem;font-weight:600;cursor:pointer}.login-btn:hover{background:#1d4ed8}.join-page{min-height:calc(100vh - 120px);display:flex;justify-content:center;align-items:center}.join-card{width:420px;background:#fff;border-radius:10px;padding:2rem;border:1px solid #e5e7eb;box-shadow:0 8px 24px #00000014}.join-title{text-align:center;font-size:1.4rem;font-weight:700;margin-bottom:1.5rem}.join-error{background:#fee2e2;color:#b91c1c;padding:.6rem;border-radius:6px;font-size:.9rem;text-align:center;margin-bottom:1rem}.form-group{margin-bottom:1rem}.form-group label{display:block;font-size:.85rem;margin-bottom:.3rem}.form-group input{width:100%;padding:.55rem;border-radius:6px;border:1px solid #d1d5db}.input-inline{display:flex;gap:.4rem}.input-inline button{padding:0 .75rem;border-radius:6px;border:1px solid #d1d5db;background:#f9fafb;cursor:pointer}.msg{font-size:.8rem;margin-top:.25rem}.msg.success{color:#047857}.msg.error{color:#b91c1c}.join-btn{width:100%;margin-top:1.2rem;padding:.65rem;border-radius:6px;border:none;background:#2563eb;color:#fff;font-weight:600;cursor:pointer}.input-inline button{min-width:90px;white-space:nowrap}.result-card-header{padding:12px 16px;border-bottom:1px solid #e5e7eb;font-weight:600;color:#111827;background:#fafafa}.result-table-header{display:grid;grid-template-columns:2fr 200px 200px;padding:10px 16px;font-weight:600;color:#111827;background:#f9fafb;border-bottom:1px solid #e5e7eb;text-align:center}.result-table-row{display:grid;grid-template-columns:2fr 200px 200px;padding:10px 16px;border-bottom:1px solid #e5e7eb;align-items:center;text-align:center;font-size:.95rem;color:#111827;transition:background .15s ease}.result-table-row:hover{background:#f8fafc;cursor:pointer}.result-col-strategy{text-align:left;padding-left:8px;font-weight:600}.result-pagination{display:flex;justify-content:center;gap:6px;padding:16px 0}.result-pagination .page-link{border-radius:6px;padding:6px 12px;font-size:.85rem;color:#2563eb;border:1px solid #e5e7eb;background:#fff;cursor:pointer;transition:all .15s ease}.result-pagination .page-link:hover{background:#eff6ff}.result-pagination .page-link.active{background:#2563eb;color:#fff;border-color:#2563eb;font-weight:600}.result-empty{padding:40px 0;text-align:center;color:#6b7280;font-size:.95rem}.search-actions{display:flex;gap:10px}.btn-search-primary{padding:8px 18px;border-radius:999px;background:linear-gradient(135deg,#4f46e5,#6366f1);border:none;color:#fff;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .2s ease}.btn-search-primary:hover{opacity:.9;transform:translateY(-1px)}.btn-search-primary:active{transform:translateY(0)}.btn-search-reset{padding:8px 18px;border-radius:999px;background:#fff;border:1px solid #e5e7eb;color:#374151;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s ease}.btn-search-reset:hover{background:#f3f4f6;border-color:#d1d5db}.btn-search-reset:active{transform:translateY(1px)}.result-filter{background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:16px 20px;margin-bottom:20px}.result-filter-row{display:flex;align-items:center;gap:16px;flex-wrap:wrap}.result-filter-group{display:flex;align-items:center;border:1px solid #e5e7eb;border-radius:10px;overflow:hidden;background:#f9fafb}.result-filter-label{padding:8px 12px;font-size:.85rem;font-weight:600;color:#374151;background:#f3f4f6;border-right:1px solid #e5e7eb;white-space:nowrap}.result-filter-select,.result-filter-input{border:none;padding:8px 12px;font-size:.9rem;background:transparent;min-width:180px}.result-filter-select:focus,.result-filter-input:focus{outline:none}.result-filter-actions{margin-left:auto;display:flex;gap:10px}.btn-search{padding:8px 18px;border-radius:999px;border:none;background:#5b3df5;color:#fff;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .15s ease}.btn-search:hover{background:#4a2ee0}.btn-reset{padding:8px 16px;border-radius:999px;border:1px solid #e5e7eb;background:#fff;color:#6b7280;font-size:.85rem;font-weight:600;cursor:pointer;transition:all .15s ease}.btn-reset:hover{background:#f9fafb;color:#374151}.result-detail-page{margin-top:1rem}.detail-header-card{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;margin-bottom:20px;border:1px solid #e5e7eb;border-radius:14px;background:#fff}.detail-header-left h4{margin:0;font-size:1.1rem;font-weight:700;color:#111827}.detail-header-sub{margin-top:4px;font-size:.9rem;color:#6b7280}.detail-header-actions{display:flex;gap:10px}.btn-primary-pill{padding:8px 18px;border-radius:999px;border:none;background:linear-gradient(135deg,#4f46e5,#6366f1);color:#fff;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .15s ease}.btn-primary-pill:hover{opacity:.9;transform:translateY(-1px)}.btn-outline-pill{padding:8px 18px;border-radius:999px;border:1px solid #e5e7eb;background:#fff;color:#374151;font-size:.85rem;font-weight:600;cursor:pointer}.btn-outline-pill:hover{background:#f9fafb}.result-card{border:1px solid #e5e7eb;border-radius:8px;background:#fff;overflow:hidden}.result-card-header{padding:12px 16px;border-bottom:1px solid #e5e7eb;font-weight:600;background:#fafafa}.detail-table{width:100%;border-collapse:collapse}.detail-table thead th{padding:12px 10px;height:44px;background:#f9fafb;font-size:.9rem;font-weight:600;vertical-align:middle;font-variant-numeric:tabular-nums}.detail-table tbody td{padding:12px 10px;border-bottom:1px solid #e5e7eb;font-size:.9rem;vertical-align:middle}.detail-table tbody tr:hover{background:#f8fafc}.align-table thead th{text-align:center}.col-check{width:48px;text-align:center}.align-table thead th.col-code,.col-code{text-align:left;padding-left:12px;font-variant-numeric:tabular-nums}.align-table thead th.col-name,.col-name{text-align:left;padding-left:12px;font-weight:500}.align-table thead th.col-num,.col-num{text-align:right;padding-right:14px;font-variant-numeric:tabular-nums}.align-table thead th.col-date,.col-date{text-align:center;white-space:nowrap}.col-num.with-detail{display:flex;justify-content:flex-end;align-items:center;gap:8px}.detail-link-btn{font-size:.75rem;color:#2563eb;background:none;border:none;padding:0;cursor:pointer;white-space:nowrap}.detail-link-btn:hover{text-decoration:underline}.detail-header-label{margin-right:8px;font-size:.75rem;color:#6b7280;font-weight:500}.batch-container{width:100%;font-family:-apple-system,BlinkMacSystemFont,Apple SD Gothic Neo,Noto Sans KR,Segoe UI,Roboto,Helvetica,Arial,sans-serif;color:#111827}.batch-title{font-size:1.25rem;font-weight:700;margin-bottom:12px}.batch-card{border:1px solid #e5e7eb;border-radius:12px;background:#fff;overflow:hidden}.batch-card-header{padding:14px 18px;font-weight:700;background:#fafafa;border-bottom:1px solid #e5e7eb}.batch-list-header,.batch-list-row{display:grid;grid-template-columns:1fr 140px 140px;align-items:center;padding:14px 16px}.batch-list-header{background:#f9fafb;font-weight:700;color:#374151;border-bottom:1px solid #e5e7eb}.batch-list-row{border-bottom:1px solid #e5e7eb;transition:background .15s ease}.batch-list-row:hover{background:#fafafa}.batch-list-header span:first-child,.batch-list-row .batch-date{text-align:left;font-family:monospace}.batch-list-header .count-col,.batch-list-row .batch-count{text-align:center;font-weight:600;font-variant-numeric:tabular-nums;color:#111827}.batch-list-header span:last-child{text-align:right}.batch-detail-panel{padding:12px 16px;background:#fafafa}.batch-detail-title{font-size:.9rem;font-weight:700;margin-bottom:8px;color:#374151}.batch-detail-header,.batch-detail-row{display:grid;grid-template-columns:60px 2fr 1.2fr 1.2fr 100px 90px;gap:8px;padding:8px 0;font-size:.8rem}.batch-detail-header{font-weight:700;border-bottom:1px solid #e5e7eb}.batch-detail-row{border-bottom:1px solid #eef2f7}.batch-detail-header span,.batch-detail-row span{align-self:center}.status-success{color:#16a34a;font-weight:700}.status-fail{color:#dc2626;font-weight:700}.batch-pagination{display:flex;justify-content:center;gap:6px;padding:16px}.page-btn{padding:6px 12px;border-radius:6px;border:1px solid #e5e7eb;background:#fff;font-size:.85rem;color:#2563eb;cursor:pointer;transition:all .15s ease}.page-btn:hover{background:#eff6ff}.page-btn.active{background:#2563eb;color:#fff;border-color:#2563eb}.nps-summary-header{margin-bottom:2rem}.nps-summary-title{font-size:1.4rem;font-weight:700;margin-bottom:.3rem}.nps-summary-desc{font-size:.85rem;color:#6b7280}.nps-card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(420px,1fr));gap:1.5rem}.nps-card{border-radius:18px;border:1px solid #e5e7eb;padding:1.5rem;min-height:420px;display:flex;flex-direction:column;justify-content:space-between;transition:transform .15s ease,box-shadow .15s ease;background:#fff}.nps-card:hover{transform:translateY(-6px);box-shadow:0 10px 28px #0000001a}.nps-card-center{text-align:center;display:flex;flex-direction:column;align-items:center;justify-content:center;flex:1}.nps-title{font-size:1.1rem;font-weight:600;margin-bottom:1rem}.nps-count{font-size:3rem;font-weight:800;margin-bottom:.3rem}.nps-sub{font-size:.9rem;color:#6b7280}.nps-card-button{display:block;margin-top:1rem;padding:.75rem;text-align:center;border-radius:12px;border:1px solid #5a33ff;color:#5a33ff;font-weight:600;text-decoration:none;transition:background .15s ease,color .15s ease}.nps-card-button:hover{background:#5a33ff;color:#fff}.nps-loading{padding:3rem;text-align:center;color:#6b7280}.nps-list{width:100%}.nps-search{max-width:720px;margin:0 auto 2rem}.nps-search-row{display:flex;gap:.75rem;align-items:center}.nps-search-input-wrap input{width:100%;height:44px;padding:0 2.75rem 0 1rem;border-radius:14px;border:2px solid #111;font-size:1rem;box-sizing:border-box}.nps-search-input-wrap input:focus{outline:none;border-color:#5a33ff}.nps-reset-inside{position:absolute;right:.75rem;top:50%;transform:translateY(-50%);width:28px;height:28px;border-radius:50%;border:none;background:#f3f4f6;color:#6b7280;font-size:1rem;cursor:pointer}.nps-reset-inside:hover{background:#e5e7eb;color:#111}.nps-search-btn{height:44px;padding:0 1.5rem;border-radius:14px;border:none;background:#5a33ff;color:#fff;font-size:.95rem;font-weight:700;cursor:pointer;white-space:nowrap;transition:background .15s ease,transform .05s ease}.nps-search-btn:hover{background:#4324d6}.nps-search-btn:active{transform:translateY(1px)}.nps-table{border-top:1px solid #e5e7eb}.nps-table-head,.nps-table-row{display:grid;grid-template-columns:80px 1.5fr 1fr 1fr 1fr;padding:.75rem;align-items:center}.nps-table-head{font-weight:600;background:#f9fafb;color:#374151;border-bottom:1px solid #e5e7eb}.nps-table-row{border-bottom:1px solid #e5e7eb;transition:background .15s ease}.nps-table-row:hover{background:#fafafa}.nps-table-head .center,.nps-table-row .center{text-align:center;font-variant-numeric:tabular-nums}.nps-table-row .name{text-align:left;font-weight:600}.nps-table-row a{color:#5a33ff;text-decoration:none;font-weight:600}.nps-table-row a:hover{text-decoration:underline}.nps-empty{padding:2rem;text-align:center;color:#6b7280;font-size:.95rem}.nps-summary{width:100%}.nps-summary-header{margin-bottom:1.5rem;padding-bottom:.75rem;border-bottom:1px solid #e5e7eb}.nps-summary-title{font-size:1.4rem;font-weight:700;color:#111}.stock-search-box{max-width:900px;margin:0 auto 2rem}.stock-search-input-wrap{position:relative;flex:1}.stock-search-input-wrap input{width:100%;height:44px;padding:0 2.75rem 0 1rem;border-radius:14px;border:2px solid #111;font-size:1rem;box-sizing:border-box}.stock-search-reset{position:absolute;right:.75rem;top:50%;transform:translateY(-50%);width:28px;height:28px;border-radius:50%;border:none;background:#f3f4f6;color:#6b7280;font-size:1rem;cursor:pointer}.stock-search-reset:hover{background:#e5e7eb;color:#111}.stock-search-btn{height:44px;padding:0 1.5rem;border-radius:14px;border:none;background:#5a33ff;color:#fff;font-size:.95rem;font-weight:700;cursor:pointer;white-space:nowrap;transition:background .15s ease,transform .05s ease}.stock-search-btn:hover{background:#4324d6}.stock-search-btn:active{transform:translateY(1px)}.modal-body{width:90%;max-width:980px;height:85vh;max-height:85vh;display:flex;flex-direction:column;min-height:0;overflow:hidden;background:#fff;border-radius:12px;box-shadow:0 12px 30px #00000040}.close-btn:hover{color:#111}.modal-content{flex:1;min-height:0;overflow-y:auto}.modal-content.kodex-holdings-content{min-height:0;overflow-y:auto}.loading,.empty{padding:2rem;text-align:center;font-size:.95rem;color:#6b7280}.holdings-header-row{position:sticky;top:0;z-index:1;display:grid;grid-template-columns:140px 1.5fr 1fr 1fr 1.2fr;align-items:center;padding:.75rem 1rem;background:#f9fafb;border-bottom:1px solid #e5e7eb;font-size:.85rem;font-weight:600;color:#374151}.holdings-row{display:grid;grid-template-columns:140px 1.5fr 1fr 1fr 1.2fr;align-items:center;padding:.75rem 1rem;border-bottom:1px solid #e5e7eb;font-size:.9rem}.holdings-row:hover{background:#f9fafb}.holdings-row .code{font-family:monospace}.holdings-row .name{font-weight:500}.holdings-header-row .num,.holdings-row .num{display:flex;justify-content:center;align-items:center;font-variant-numeric:tabular-nums}.modal-content::-webkit-scrollbar{width:8px}.modal-content::-webkit-scrollbar-thumb{background:#d1d5db;border-radius:4px}.modal-content::-webkit-scrollbar-track{background:transparent}.kodex-table{border-top:1px solid #e5e7eb}.kodex-table-header,.kodex-table-row{display:grid;grid-template-columns:1fr 140px 160px;align-items:center;padding:14px 16px}.kodex-table-header{font-weight:700;background:#f9fafb;border-bottom:1px solid #e5e7eb;color:#374151}.kodex-table-row{border-bottom:1px solid #e5e7eb;transition:background .15s ease}.kodex-table-row:hover{background:#fafafa}.etf-name{font-weight:600;display:flex;align-items:center;gap:8px}.count-col{text-align:center;font-weight:600;color:#374151;font-variant-numeric:tabular-nums}.irp-badge{padding:2px 8px;font-size:.75rem;border-radius:999px;background:#eef2ff;color:#4338ca;font-weight:600;white-space:nowrap}.view-link{justify-self:end;padding:6px 14px;border-radius:999px;border:1px solid #e0e7ff;background:#f5f7ff;color:#4338ca;font-size:.85rem;font-weight:600;cursor:pointer;transition:all .15s ease}.view-link:hover{background:#4338ca;border-color:#4338ca;color:#fff}.view-link:active{transform:translateY(1px)}.loading,.empty{padding:2rem;text-align:center;color:#6b7280;font-size:.95rem}.nps-search-input-wrap{position:relative;flex:1}.nps-search-input-wrap input{width:100%;padding-right:36px}.nps-reset-inside{position:absolute;top:50%;right:10px;transform:translateY(-50%);width:22px;height:22px;padding:0;display:flex;align-items:center;justify-content:center;border-radius:50%;border:1px solid #f3c1cf;background:#fff1f5;color:#d14b6f;font-size:.85rem;line-height:1;cursor:pointer;transition:transform .1s ease}.nps-reset-inside:active{transform:translateY(-50%) scale(.95)}.stock-search{width:100%}.stock-search-box{width:100%;max-width:none;margin:0 0 2rem}.stock-search-row{display:flex;gap:.75rem;align-items:center}.stock-search-input-wrap{flex:1}.stock-search-input-wrap input{width:100%;height:44px;padding:0 1rem;border-radius:14px;border:2px solid #111;font-size:1rem}.stock-search-input-wrap input:focus{outline:none;border-color:#5a33ff}.stock-search-btn{height:44px;padding:0 1.5rem;border-radius:14px;border:none;background:#5a33ff;color:#fff;font-weight:700;cursor:pointer}.stock-grid{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:1rem;align-items:stretch;height:700px;width:100%}.stock-table,.stock-right{min-width:0}.stock-table{height:100%;overflow-x:hidden;overflow-y:scroll;scrollbar-gutter:stable;border-top:1px solid #e5e7eb;background:#fff}.stock-table-title{padding:.75rem 1rem;font-weight:600;border-bottom:1px solid #e5e7eb;background:#fff;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.stock-table-head,.stock-table-row{display:grid;grid-template-columns:120px 1fr 1fr 1fr 1fr 1fr;padding:.7rem;align-items:center}.stock-table-head span,.stock-table-row span{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.stock-table-head{background:#f9fafb;font-weight:600;border-bottom:1px solid #e5e7eb;position:sticky;top:0;z-index:2}.stock-table-row{border-bottom:1px solid #e5e7eb;font-size:.85rem}.stock-table-row:hover{background:#fafafa}.stock-right{display:flex;flex-direction:column;height:100%;gap:1rem;min-height:0}.stock-chart-card{display:flex;flex-direction:column;flex:0 0 360px;border:1px solid #e5e7eb;border-radius:12px;background:#fff;min-height:0}.stock-chart-header{flex:0 0 44px;padding:.75rem 1rem;border-bottom:1px solid #e5e7eb;font-weight:600;display:flex;justify-content:space-between;align-items:center}.chart-header-controls{display:flex;align-items:center;gap:6px}.chart-header-controls button{padding:4px 8px;font-size:.75rem;border-radius:6px;border:1px solid #e5e7eb;background:#fff;cursor:pointer}.chart-header-controls button.active{background:#5a33ff;color:#fff;border-color:#5a33ff}.chart-expand-btn{margin-left:6px}.stock-chart-container{flex:1;min-height:0}.stock-signal{border:1px solid #e5e7eb;border-radius:12px;background:#fff;flex:1;overflow:hidden;display:flex;flex-direction:column;min-height:0}.stock-signal-header{padding:.75rem 1rem;border-bottom:1px solid #e5e7eb;font-weight:600;font-size:.95rem;background:#f9fafb}.stock-signal-body{padding:.5rem .75rem;flex:1;overflow-y:auto}.stock-signal-table{width:100%;border-collapse:separate;border-spacing:0 4px;font-size:.85rem}.stock-signal-table th{text-align:left;font-weight:600;color:#374151;padding:4px 6px;font-size:.75rem}.stock-signal-table td{padding:6px 8px}.stock-signal-table tbody tr{background:#f9fafb;border-radius:6px;transition:background .15s ease}.stock-signal-table tbody tr:hover{background:#eef2ff}.stock-signal-table td:first-child{font-weight:600;color:#4338ca}.stock-signal-table td:last-child{text-align:right;color:#6b7280;font-size:.75rem;font-variant-numeric:tabular-nums}.stock-signal-body::-webkit-scrollbar{width:6px}.stock-signal-body::-webkit-scrollbar-thumb{background:#d1d5db;border-radius:4px}.chart-modal-overlay{position:fixed;inset:0;background:#00000073;display:flex;justify-content:center;align-items:center;z-index:999}.chart-modal{width:90vw;height:80vh;background:#fff;border-radius:12px;display:flex;flex-direction:column}.chart-modal-body{flex:1;padding:12px;min-height:0}.chart-modal-body>div{height:100%}.stock-error{margin-top:1rem;padding:.75rem;border-radius:8px;background:#fef2f2;color:#b91c1c}.autocomplete-list{position:absolute;top:100%;left:0;right:0;margin-top:6px;padding:4px 0;list-style:none;background:#fff;border:1px solid #e5e7eb;border-radius:10px;box-shadow:0 10px 25px #00000014;z-index:1000;max-height:220px;overflow-y:auto}.autocomplete-list li{display:flex;justify-content:space-between;align-items:center;padding:8px 12px;cursor:pointer;font-size:.9rem;color:#111827;transition:background .15s ease}.autocomplete-list li:hover{background:#eef2ff}.autocomplete-list li strong{font-weight:600;color:#1f2937}.autocomplete-code{font-size:.75rem;color:#6b7280;margin-left:8px;font-variant-numeric:tabular-nums}.autocomplete-list::-webkit-scrollbar{width:6px}.autocomplete-list::-webkit-scrollbar-thumb{background:#d1d5db;border-radius:4px}.autocomplete-list::-webkit-scrollbar-track{background:transparent}.stock-search-input-wrap{position:relative}.input-clear-btn{position:absolute;right:12px;top:50%;transform:translateY(-50%);width:22px;height:22px;border-radius:50%;border:none;background:#e5e7eb;color:#374151;font-size:14px;font-weight:700;line-height:1;display:flex;align-items:center;justify-content:center;cursor:pointer;padding:0;transition:background .15s ease,color .15s ease}.input-clear-btn:hover{background:#5a33ff;color:#fff}.autocomplete-list li.active{background:#e0e7ff}.stock-signal-table th:last-child{text-align:right}.dashboard-card{border:1px solid #ccc;border-radius:10px;padding:1.2rem;background:#fff;box-shadow:0 2px 8px #00000014;margin-bottom:2rem}.content-box{max-height:400px;overflow-y:auto;padding-right:.5rem}th{font-weight:600;color:#374151;border-bottom:1px solid #e5e7eb;background:#fafafa}td{color:#111827;border-bottom:1px solid #f1f5f9}tbody tr:hover{background:#f9fafb}.dashboard-card{border:1px solid #d1d5db;border-radius:12px;padding:1.2rem 1.4rem;background:#fff;box-shadow:0 2px 10px #0000000f;margin-bottom:2rem}.dashboard-card h5{margin-bottom:.8rem;font-size:1rem;font-weight:600;color:#111827}.content-box{max-height:420px;overflow-y:auto;padding-right:.5rem}.content-box::-webkit-scrollbar{width:6px}.content-box::-webkit-scrollbar-thumb{background:#d1d5db;border-radius:4px}table{width:100%;font-size:.9rem;border-collapse:collapse}th,td{padding:6px 8px;vertical-align:middle}th{font-weight:600;border-bottom:1px solid #e5e7eb;color:#374151}td{border-bottom:1px solid #f1f5f9;color:#111827}tbody tr:hover{background-color:#f9fafb}.col-code{text-align:left;white-space:nowrap;font-weight:500}.col-price,.col-prev,.col-diff,.col-volume{text-align:right;white-space:nowrap;font-variant-numeric:tabular-nums}.col-date{text-align:center;white-space:nowrap;color:#6b7280}.up{color:#d93025;font-weight:600}.down{color:#1a73e8;font-weight:600}@media(max-width:768px){table{font-size:.85rem}.content-box{max-height:300px}}.detail-link-btn{display:inline-flex;align-items:center;justify-content:center;padding:4px 10px;min-height:22px;font-size:.7rem;font-weight:600;color:#2563eb;background:#eff6ff;border:1px solid #dbeafe;border-radius:999px;cursor:pointer;white-space:nowrap;transition:all .15s ease}.index-side-nav{position:fixed;right:36px;top:120px;display:flex;flex-direction:column;gap:12px;z-index:100}.index-nav-item{background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:12px 18px;font-size:.95rem;font-weight:600;min-width:96px;text-align:center;color:#333;cursor:pointer;white-space:nowrap;box-shadow:0 2px 4px #0000000f,0 6px 14px #0000001a;transition:background-color .2s ease,transform .12s ease,box-shadow .15s ease}.index-nav-item:hover{background:#f5f7fa;box-shadow:0 4px 8px #00000014,0 8px 18px #0000001f}.index-nav-item:active{transform:scale(.97)}.btn-group.btn-group-sm{display:flex;gap:8px;margin-left:auto;flex-shrink:0}.index-side-nav{position:fixed;right:24px;top:120px;display:flex;flex-direction:column;gap:8px;z-index:100}.index-nav-item{background:#fff;border:1px solid #e5e7eb;border-radius:8px;padding:6px 10px;font-size:.8rem;font-weight:500;color:#333;cursor:pointer;white-space:nowrap;text-align:center;box-shadow:0 1px 2px #0000000a,0 2px 6px #0000000f;transition:background-color .2s ease,transform .12s ease,box-shadow .15s ease}.index-nav-item:hover{background:#f5f7fa}.index-nav-item:active{transform:scale(.96)}.grid-container{display:grid;grid-template-columns:repeat(1,1fr);gap:1.25rem}.card{margin-bottom:0;border-radius:10px;border:1px solid #e5e7eb;background:#fff;box-shadow:0 1px 2px #0000000a,0 4px 12px #0000000f}.card-header{display:flex;align-items:center;gap:14px;height:52px;padding:0 14px;background:#fff;border-bottom:1px solid #e5e7eb;border-top-left-radius:10px;border-top-right-radius:10px;white-space:nowrap;overflow:hidden}.card-header .fw-bold{margin-right:6px;white-space:nowrap;flex-shrink:0}.latest-info{display:flex;align-items:center;gap:6px;font-size:.85rem;color:#333;white-space:nowrap;flex-shrink:0}.latest-info.up{color:#d93025;font-weight:600}.latest-info.down{color:#1a73e8;font-weight:600}.btn-group.btn-group-sm{display:flex;gap:8px;margin-left:auto;--indicator-color: #6d5dfc;flex-shrink:0}.btn-group.btn-group-sm .btn{padding:6px 14px;font-size:13px;border-radius:8px;border:1px solid var(--indicator-color);background:#fff;color:var(--indicator-color);cursor:pointer;transition:background-color .2s ease,color .2s ease,box-shadow .15s ease,transform .12s ease}.btn-group.btn-group-sm .btn:hover{background:color-mix(in srgb,var(--indicator-color) 10%,transparent)}.btn-group.btn-group-sm .btn.active{background:var(--indicator-color)!important;border-color:var(--indicator-color)!important;color:#fff!important;box-shadow:0 3px 8px color-mix(in srgb,var(--indicator-color) 45%,transparent)}.btn-group.btn-group-sm .btn:active{transform:scale(.96)}.card-body{padding:12px;height:360px}@media(max-width:992px){.grid-container{grid-template-columns:1fr}.card-header{flex-wrap:wrap;height:auto;min-height:52px;gap:8px;white-space:normal;overflow:visible}.btn-group.btn-group-sm{margin-left:0}}.indicator-page{width:100%}body{overflow-y:scroll}.indicator-card-wrapper{scroll-margin-top:80px}.index-side-nav{position:fixed;right:32px;top:120px;display:flex;flex-direction:column;gap:10px;z-index:100}.index-nav-item{padding:8px 14px;font-size:.9rem;min-width:72px}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;border-bottom:1px solid #e5e7eb}.modal-header h3{margin:0;font-size:1.05rem;font-weight:700}.close-btn{border:none;background:none;cursor:pointer;font-size:1.2rem;color:#6b7280}.search-row:hover:not(.header):not(.disabled){background:#f9fafb}.selected-row{padding:.4rem 0;font-size:.8rem;border-bottom:1px solid #f1f5f9}.qty-btn{width:22px;height:22px;display:flex;align-items:center;justify-content:center;border-radius:50%;border:none;font-size:.85rem;font-weight:700;line-height:1;cursor:pointer}.qty-value{min-width:18px;text-align:center;font-size:.75rem;font-weight:600;line-height:1}.primary-btn{padding:.45rem .9rem;border-radius:6px;border:none;background:#4338ca;color:#fff;font-weight:600;cursor:pointer}.secondary-btn{padding:.45rem .9rem;border-radius:6px;border:none;background:#e5e7eb;color:#374151;cursor:pointer}.modal-body{width:90%;max-width:980px;max-height:85vh;display:flex;flex-direction:column;background:#fff;border-radius:12px;box-shadow:0 12px 30px #00000040}.header-notice{font-size:.72rem;line-height:1.45;font-weight:500;color:#ea580c}.modal-content{flex:1;overflow:hidden}.form-section input,.form-section textarea,.form-section select{padding:.5rem .65rem;border-radius:8px;border:1px solid #d1d5db;font-size:.9rem}.etf-builder{display:grid;grid-template-columns:1fr 1fr;gap:1.25rem;padding:.75rem 1.25rem 1.25rem;height:360px}.search-panel,.selected-panel{display:flex;flex-direction:column;height:100%;overflow:hidden}.search-table{display:flex;flex-direction:column;flex:1;overflow-y:auto}.search-row{display:grid;grid-template-columns:1fr 90px 60px 110px 60px;align-items:center;padding:.45rem .25rem;font-size:.8rem;border-bottom:1px solid #f1f5f9;cursor:pointer}.search-row.header{font-size:.7rem;font-weight:600;color:#6b7280;cursor:default}.search-row.disabled{background:#f3f4f6;color:#9ca3af;cursor:default}.search-row .right{text-align:right}.search-row .action{text-align:center;font-size:.7rem;font-weight:600;color:#6366f1}.selected-list{flex:1;overflow-y:auto}.selected-header.table,.selected-row.table{display:grid;grid-template-columns:1.4fr 60px 100px 120px 120px 32px;align-items:center;gap:8px}.selected-row{padding:.4rem 0;border-bottom:1px solid #f1f5f9;font-size:.8rem}.qty-control{display:flex;align-items:center;justify-content:space-between;width:78px;height:26px;padding:0 6px;background:#f9fafb;border:1px solid #e5e7eb;border-radius:999px}.qty-btn{width:20px;height:20px;border-radius:50%;border:none;font-size:.8rem;font-weight:700;cursor:pointer}.qty-value{min-width:14px;text-align:center;font-size:.75rem;font-weight:600}.fixed-qty{display:inline-flex;align-items:center;justify-content:center;height:24px;padding:0 12px;font-size:.75rem;font-weight:700;color:#065f46;background:#d1fae5;border:1px solid #bbf7d0;border-radius:999px}.remove-btn.icon.disabled{cursor:not-allowed;color:#9ca3af;opacity:.5}.remove-btn.icon.disabled:hover{background:none}.mystock-container{width:100%}.mystock-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:18px}.mystock-header h3{margin:0;font-size:1.15rem;font-weight:700;color:#111827}.btn-deleted{padding:6px 14px;border-radius:999px;border:1px solid #e5e7eb;background:#fff;font-size:.85rem;font-weight:600;color:#374151;cursor:pointer;transition:all .15s ease}.btn-deleted:hover{background:#f9fafb}.mystock-card{border:1px solid #e5e7eb;border-radius:12px;background:#fff;overflow:hidden;margin-bottom:20px}.mystock-card-title{padding:14px 18px;border-bottom:1px solid #e5e7eb;background:#fafafa;font-weight:700;font-size:.95rem;color:#111827}.mystock-table{width:100%;border-collapse:collapse}.mystock-table th,.mystock-table td{padding:12px 10px;border-bottom:1px solid #e5e7eb;font-size:.9rem;vertical-align:middle}.mystock-table thead{background:#f9fafb}.mystock-table thead th{font-weight:600;color:#374151;white-space:nowrap}.mystock-table tbody tr:hover{background:#f8fafc}.col-no{width:60px;text-align:center}.col-code{text-align:left;padding-left:12px;font-family:monospace;font-variant-numeric:tabular-nums}.col-name{text-align:left;padding-left:12px;font-weight:500}.col-num{text-align:right;padding-right:12px;font-variant-numeric:tabular-nums;white-space:nowrap}.col-strategy{text-align:left;padding-left:12px;font-weight:600}.col-date{text-align:center;white-space:nowrap}.col-action{text-align:center}.mystock-table tbody tr.row-profit:hover{background:#ffecec}.mystock-table tbody tr.row-loss:hover{background:#eaf2ff}.btn-delete{padding:4px 10px;border-radius:6px;border:1px solid #fca5a5;background:#fff;color:#dc2626;font-size:.75rem;font-weight:600;cursor:pointer;transition:all .15s ease}.btn-delete:hover{background:#fee2e2}.mystock-empty{padding:24px 0;text-align:center;font-size:.9rem;color:#6b7280}.mystock-pagination{display:flex;justify-content:center;gap:6px;padding:16px 0}.mystock-pagination .page-btn{padding:6px 12px;border-radius:6px;border:1px solid #e5e7eb;background:#fff;font-size:.85rem;color:#2563eb;cursor:pointer;transition:all .15s ease}.mystock-pagination .page-btn:hover{background:#eff6ff}.mystock-pagination .page-btn.active{background:#2563eb;color:#fff;border-color:#2563eb;font-weight:600}.modal-overlay{position:fixed;inset:0;z-index:2000;display:flex;align-items:center;justify-content:center;background:#00000073}.modal-body{width:90%;max-width:1000px;max-height:85vh;background:#fff;border-radius:14px;box-shadow:0 20px 40px #0000004d;display:flex;flex-direction:column;overflow:hidden}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:14px 18px;border-bottom:1px solid #e5e7eb}.modal-content{flex:1;overflow-y:auto}.close-btn{border:none;background:none;font-size:1.2rem;cursor:pointer}.col-strategy a{display:inline-block;padding:4px 10px;border-radius:999px;background:#ecfdf5;color:#047857;font-size:.75rem;font-weight:600;text-decoration:none}.col-strategy a:hover{background:#d1fae5}.mystock-header-actions{display:flex;align-items:center;gap:8px}.btn-etf{padding:6px 14px;border-radius:999px;border:1px solid #e5e7eb;background:#fff;font-size:.85rem;font-weight:600;color:#2563eb;cursor:pointer;transition:all .15s ease}.btn-etf:hover{background:#eff6ff}.btn-etf-primary{border-color:#2563eb;background:#2563eb;color:#fff}.btn-etf-primary:hover{background:#1e40af}.col-detail{text-align:center;white-space:nowrap}.btn-etf-outline{background:#fff;border:1px solid #d1d5db;color:#4f46e5;font-weight:600}.btn-etf-outline:hover{background:#eef2ff;border-color:#4f46e5;color:#4338ca}.create-etf-modal.modal-overlay{position:fixed;inset:0;z-index:1000;display:flex;align-items:center;justify-content:center;background:#00000073}.create-etf-modal .modal-body{width:92%;max-width:1200px;max-height:85vh;display:flex;flex-direction:column;background:#fff;border-radius:12px;box-shadow:0 12px 30px #00000040}.create-etf-modal .modal-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;border-bottom:1px solid #e5e7eb}.create-etf-modal .modal-header h3{margin:0;font-size:1.05rem;font-weight:700}.create-etf-modal .close-btn{border:none;background:none;cursor:pointer;font-size:1.2rem;color:#6b7280}.create-etf-modal .close-btn:hover{color:#111827}.create-etf-modal .modal-content{flex:1;display:flex;flex-direction:column;overflow:hidden}.create-etf-modal .form-section{padding:.75rem 1.25rem;display:flex;flex-direction:column;gap:.5rem}.create-etf-modal .form-section label{font-size:.75rem;font-weight:600;color:#374151}.create-etf-modal .form-section input,.create-etf-modal .form-section textarea{padding:.5rem .65rem;border-radius:6px;border:1px solid #d1d5db;font-size:.9rem}.create-etf-modal .form-section input:focus,.create-etf-modal .form-section textarea:focus{outline:none;border-color:#2563eb}.create-etf-modal .divider{margin:.75rem 0;border-top:1px solid #e5e7eb}.create-etf-modal .etf-builder{display:grid;grid-template-columns:4fr 6fr;gap:1.25rem;padding:.75rem 1.25rem 1.25rem;flex:1;min-height:0}.create-etf-modal .search-panel,.create-etf-modal .selected-panel{display:flex;flex-direction:column;min-height:0;overflow:hidden}.create-etf-modal .search-panel h4,.create-etf-modal .selected-panel h4{margin:0 0 .5rem;font-size:.8rem;font-weight:600;color:#374151;padding-bottom:.35rem;border-bottom:1px solid #e5e7eb}.create-etf-modal .search-table{margin-top:.5rem;border-top:1px solid #e5e7eb;flex:1;overflow-y:auto}.create-etf-modal .search-row{display:grid;grid-template-columns:2fr 1fr .8fr 1fr .6fr;align-items:center;gap:6px;padding:.45rem .35rem;font-size:.8rem;border-bottom:1px solid #f1f5f9;cursor:pointer}.create-etf-modal .search-row.header{font-weight:600;font-size:.7rem;color:#6b7280;background:#f9fafb;cursor:default}.create-etf-modal .search-row:not(.header):hover{background:#f9fafb}.create-etf-modal .search-row.disabled{opacity:.5;pointer-events:none}.create-etf-modal .search-row .action{font-size:.7rem;text-align:right;color:#047857;font-weight:600}.create-etf-modal .right{text-align:right}.create-etf-modal .selected-list{flex:1;min-height:0;overflow-y:auto}.create-etf-modal .selected-list .empty{flex:1;display:flex;align-items:center;justify-content:center;font-size:.8rem;color:#6b7280}.create-etf-modal .selected-header,.create-etf-modal .selected-row{display:grid;grid-template-columns:2.4fr .6fr 1fr 1fr 1.2fr .4fr;align-items:center;gap:6px}.create-etf-modal .selected-header{font-size:.7rem;color:#6b7280;padding:.4rem 0;border-bottom:1px solid #e5e7eb}.create-etf-modal .qty-control{display:inline-flex;align-items:center;justify-content:center;width:76px;height:24px;gap:4px;background:#f9fafb;border:1px solid #e5e7eb;border-radius:999px;margin:0 auto}.create-etf-modal .qty-btn{width:22px;height:22px;border:none;border-radius:50%;font-size:.85rem;font-weight:700;cursor:pointer}.create-etf-modal .qty-btn.minus{background:#f3f4f6;color:#6b7280}.create-etf-modal .qty-btn.plus{background:#eef2ff;color:#4f46e5}.create-etf-modal .remove-btn.icon{width:22px;height:22px;margin-left:6px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:transparent;color:#ef4444;font-size:.8rem;cursor:pointer}.create-etf-modal .remove-btn.icon:hover{background:#fee2e2}.create-etf-modal .modal-footer{padding:.75rem 1.25rem;display:flex;justify-content:flex-end;gap:.5rem;border-top:1px solid #e5e7eb}.create-etf-modal .primary-btn{padding:.45rem .9rem;border-radius:6px;border:none;background:#4338ca;color:#fff;font-weight:600;cursor:pointer}.create-etf-modal .secondary-btn{padding:.45rem .9rem;border-radius:6px;border:none;background:#e5e7eb;color:#374151;cursor:pointer}.create-etf-modal .search-bar{display:flex;align-items:center;gap:6px;padding:6px 8px;background:#f9fafb;border:1px solid #e5e7eb;border-radius:999px}.create-etf-modal .search-input{flex:1;background:transparent;border:none}.create-etf-modal .reset-btn.ghost{width:26px;height:26px;display:flex;align-items:center;justify-content:center;border-radius:50%;border:none;background:#eef2f7;color:#6b7280;font-size:.75rem;font-weight:700;cursor:pointer}.create-etf-modal .reset-btn.ghost:hover{background:#e5e7eb}.create-etf-modal .search-input:focus{outline:none}.myetf-page{width:100%}.myetf-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.myetf-header h2{margin:0;font-size:22px;font-weight:600;color:#111827}.myetf-list{border:1px solid #e5e7eb;border-radius:12px;overflow:hidden;background:#fff}.myetf-row{display:grid;grid-template-columns:60px 1fr 120px 100px;align-items:center;padding:14px 16px;border-bottom:1px solid #e5e7eb}.myetf-row:last-child{border-bottom:none}.myetf-row.header{background:#f9fafb;font-weight:700;color:#374151;cursor:default}.myetf-row.header:hover{background:#f9fafb}.myetf-row.header .col.name{cursor:default;text-decoration:none}.myetf-row.header .col.name:hover{text-decoration:none}.myetf-row:not(.header):hover{background:#f8fafc}.myetf-row .col.no{color:#6b7280;text-align:center}.myetf-row .col.name{font-weight:500}.myetf-row:not(.header) .col.name{cursor:pointer}.myetf-row:not(.header) .col.name:hover{text-decoration:underline}.myetf-row .col.count,.myetf-row .col.action{text-align:center}.count-badge{display:inline-flex;align-items:center;justify-content:center;padding:2px 10px;border-radius:999px;background:#ecfdf5;color:#065f46;font-size:.75rem;font-weight:600;border:1px solid #bbf7d0;font-variant-numeric:tabular-nums}.myetf-page button{border:none;cursor:pointer;font-family:inherit}.btn-primary{padding:6px 14px;border-radius:999px;border:1px solid #111827;background:#111827;color:#fff;font-size:.85rem;font-weight:600;transition:all .15s ease}.btn-danger{padding:4px 10px;border-radius:6px;border:1px solid #fca5a5;background:#fee2e2;color:#b91c1c;font-size:.75rem;font-weight:600;transition:all .15s ease}.btn-danger:hover{background:#fecaca;border-color:#f87171}.myetf-empty,.myetf-loading{padding:48px;text-align:center;font-size:.9rem;color:#6b7280}.pagination{display:flex;justify-content:center;gap:6px;margin-top:24px}.pagination button{padding:6px 12px;border-radius:6px;border:1px solid #e5e7eb;background:#fff;font-size:.85rem;color:#2563eb;transition:all .15s ease}.pagination button:hover:not(:disabled){background:#eff6ff}.pagination button.active{background:#2563eb;color:#fff;border-color:#2563eb;font-weight:600}.pagination button:disabled{opacity:.4;cursor:not-allowed}.modal-overlay{position:fixed;inset:0;background:#00000073;display:flex;align-items:center;justify-content:center;z-index:1000}.modal-body{background:#fff;border-radius:14px;padding:24px;min-width:320px}.modal-body.small{max-width:360px}.modal-actions{display:flex;justify-content:flex-end;gap:12px;margin-top:20px}.back-btn{align-self:flex-start;margin-bottom:6px;padding:.35rem .7rem;border-radius:6px;border:1px solid #d1d5db;background:#fff;font-size:.75rem;font-weight:600;color:#374151;cursor:pointer}.back-btn:hover{background:#f9fafb}.etf-description{margin-top:6px;margin-bottom:14px}.myetf-header-actions{display:flex;align-items:center;gap:10px}.etf-summary-card{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;padding:20px 24px;margin-bottom:24px;background:#fff;border:1px solid #e5e7eb;border-radius:12px}.summary-item{display:flex;flex-direction:column;gap:6px;padding:12px 14px;border-radius:10px}.summary-item .label{font-size:13px;color:#6b7280}.summary-item .value{font-size:18px;font-weight:600;color:#111827}.summary-item.invested{background:#f9fafb}.summary-item.invested .value{color:#6b7280;font-weight:500}.summary-item.evaluated{background:#fff}.summary-item.evaluated.price-up .value{color:#dc2626}.summary-item.evaluated.price-down .value{color:#2563eb}.summary-item.evaluated.price-same .value{color:#111827}.summary-item.price-up{background:#fff5f5}.summary-item.price-up .value{color:#dc2626}.summary-item.price-down{background:#f5f9ff}.summary-item.price-down .value{color:#2563eb}.summary-item.price-same{background:#fff}.summary-item.price-same .value{color:#374151}@media(max-width:900px){.etf-summary-card{grid-template-columns:repeat(2,1fr);row-gap:20px}}.etf-item-box{background:#fff;border:1px solid #e5e7eb;border-radius:12px;overflow:hidden}.etf-item-header{padding:16px 22px;font-size:16px;font-weight:600;border-bottom:1px solid #e5e7eb}.etf-item-table-wrapper{overflow-x:auto}.etf-item-table{width:100%;border-collapse:collapse;font-size:15px}.etf-item-table thead{background:#f9fafb}.etf-item-table th,.etf-item-table td{padding:12px 14px;border-bottom:1px solid #e5e7eb;white-space:nowrap;text-align:center;vertical-align:middle}.etf-item-table th.name,.etf-item-table td.name{text-align:left;padding-left:14px;font-weight:500}.etf-item-table th.num,.etf-item-table td.num{text-align:right;padding-right:14px;font-variant-numeric:tabular-nums}.etf-item-table th.detail,.etf-item-table td.detail{text-align:center;white-space:nowrap}.etf-item-table tbody tr:hover{background:#f9fafb}.etf-item-table .profit{color:#dc2626;font-weight:600}.etf-item-table .loss{color:#2563eb;font-weight:600}.detail-link-btn{display:inline-flex;align-items:center;justify-content:center;padding:5px 12px;min-height:26px;font-size:.8rem;font-weight:600;color:#2563eb;background:#eff6ff;border:1px solid #dbeafe;border-radius:999px;cursor:pointer;white-space:nowrap;transition:all .15s ease}.detail-link-btn:hover{background:#dbeafe;border-color:#bfdbfe;color:#1d4ed8}.detail-link-btn:active{transform:scale(.96)}.row-profit{background:#fff5f5}.row-loss{background:#f5f9ff}.etf-item-table tbody tr.row-profit:hover{background:#ffecec}.etf-item-table tbody tr.row-loss:hover{background:#eaf2ff}.price-up{color:#dc2626;font-weight:600}.price-down{color:#2563eb;font-weight:600}.price-same{color:#374151}.sub-price{margin-top:2px;font-size:.8rem;color:#6b7280}.modal-overlay{position:fixed;inset:0;z-index:1000;display:flex;align-items:center;justify-content:center;background:#00000073}.modal-body{width:92%;max-width:1200px;max-height:85vh;display:flex;flex-direction:column;background:#fff;border-radius:12px;box-shadow:0 12px 30px #00000040}.modal-header{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;padding:1rem 1.25rem;border-bottom:1px solid #e5e7eb}.header-text{display:flex;flex-direction:column;gap:6px}.modal-header h3{margin:0;font-size:1.05rem;font-weight:700;color:#111827}.header-notice{margin-top:4px;font-size:.72rem;line-height:1.45;font-weight:500;color:#ea580c}.close-btn{background:none;border:none;font-size:1.2rem;cursor:pointer;color:#6b7280}.close-btn:hover{color:#111827}.modal-content{flex:1;display:flex;flex-direction:column;overflow-y:auto;min-height:0}.form-section{padding:.75rem 1.25rem;display:flex;flex-direction:column;gap:.5rem}.form-section label{font-size:.75rem;font-weight:600;color:#374151}.form-section input,.form-section textarea{padding:.5rem .65rem;border-radius:6px;border:1px solid #d1d5db;font-size:.9rem}.form-section input:focus,.form-section textarea:focus{outline:none;border-color:#2563eb}.divider{margin:.75rem 0;border-top:1px solid #e5e7eb}.etf-builder{display:grid;grid-template-columns:4fr 6fr;gap:1.25rem;padding:.75rem 1.25rem 1.25rem;flex:1;min-height:0}.search-panel,.selected-panel{display:flex;flex-direction:column;height:100%;overflow:hidden;min-height:0}.search-panel h4,.selected-panel h4{margin:0 0 .5rem;font-size:.8rem;font-weight:600;color:#374151;padding-bottom:.35rem;border-bottom:1px solid #e5e7eb}.search-bar{display:flex;align-items:center;gap:6px;padding:6px 8px;background:#f9fafb;border:1px solid #e5e7eb;border-radius:999px}.search-input{flex:1;background:transparent;border:none;padding:.25rem;font-size:.85rem}.search-input:focus{outline:none}.search-table{margin-top:.5rem;flex:1;overflow-y:auto;border-top:1px solid #e5e7eb}.search-row{display:grid;grid-template-columns:2fr 1fr .8fr 1fr .6fr;align-items:center;gap:6px;padding:.45rem .35rem;font-size:.8rem;border-bottom:1px solid #f1f5f9;cursor:pointer}.search-row.header{font-size:.7rem;font-weight:600;color:#6b7280;background:#f9fafb;cursor:default}.search-row:not(.header):hover{background:#f9fafb}.search-row.disabled{opacity:.5;pointer-events:none}.search-row .action{font-size:.7rem;font-weight:600;color:#047857;text-align:right}.reset-btn.ghost{width:26px;height:26px;display:flex;align-items:center;justify-content:center;border-radius:50%;border:none;background:#f1f5f9;color:#6b7280;font-size:.75rem;font-weight:700;cursor:pointer}.reset-btn.ghost:hover{background:#e5e7eb}.search-info{display:flex;flex-direction:column}.search-info .code{font-size:.7rem;color:#9ca3af}.add-hint{padding:.25rem .65rem;border-radius:999px;background:#ecfdf5;color:#047857;border:1px solid #bbf7d0;font-size:.7rem;font-weight:600}.added{padding:.25rem .65rem;border-radius:999px;background:#e5e7eb;color:#6b7280;font-size:.7rem;font-weight:600}.selected-list{flex:1;min-height:0;overflow-y:auto;overflow-x:hidden;scrollbar-gutter:stable;padding-right:8px}.selected-header.table,.selected-row.table{display:grid;grid-template-columns:2.4fr .7fr 1fr .9fr 1fr .4fr;align-items:center;gap:6px}.right{text-align:right}.center{text-align:center}.selected-header{font-size:.7rem;color:#6b7280;padding:.4rem 0;border-bottom:1px solid #e5e7eb}.col-name{min-width:0;overflow:hidden;white-space:nowrap;text-overflow:ellipsis}.col-qty{display:flex;justify-content:center;align-items:center}.qty-control{display:inline-flex;align-items:center;justify-content:center;margin-left:6px;width:76px;height:24px;gap:4px;background:#f9fafb;border:1px solid #e5e7eb;border-radius:999px}.qty-btn{width:22px;height:22px;border-radius:50%;border:none;font-size:.85rem;font-weight:700;cursor:pointer}.qty-btn.minus{background:#f3f4f6;color:#6b7280}.qty-btn.plus{background:#eef2ff;color:#4f46e5}.qty-value{min-width:16px;text-align:center;font-size:.75rem;font-weight:600}.fixed-qty{display:inline-flex;align-items:center;justify-content:center;height:24px;min-width:48px;padding:0 10px;font-size:.75rem;font-weight:700;color:#065f46;background:#d1fae5;border:1px solid #bbf7d0;border-radius:999px}.remove-btn.icon{width:22px;height:22px;border:none;background:none;color:#ef4444;cursor:pointer}.remove-btn.icon:hover{background:#fee2e2;border-radius:50%}.modal-footer{padding:.75rem 1.25rem;display:flex;justify-content:flex-end;gap:.5rem;border-top:1px solid #e5e7eb}.ghost-btn{padding:.45rem .9rem;border-radius:6px;border:1px solid #d1d5db;background:#fff;font-size:.75rem;font-weight:600;color:#374151;cursor:pointer}.ghost-btn:hover{background:#f9fafb;border-color:#9ca3af}.delete-warning{margin-top:.75rem;font-size:.75rem;color:#ea580c;text-align:right}.restore-content{padding:1rem 1.25rem;flex:1;overflow-y:auto}.restore-empty{padding:2rem 0;text-align:center;color:#9ca3af;font-size:.9rem}.restore-row{display:flex;align-items:center;justify-content:space-between;padding:.65rem 0;border-bottom:1px solid #e5e7eb;font-size:.85rem}.restore-row:last-child{border-bottom:none}.restore-row.disabled{opacity:.55}.restore-info{display:flex;flex-direction:column;gap:.25rem;min-width:0}.restore-info .name{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-weight:500}.restore-info .meta{font-size:.7rem;color:#6b7280;line-height:1.4}.restore-info .meta.primary{font-size:.85rem;color:#374151;font-weight:600}.restore-info .meta.secondary{font-size:.7rem;color:#9ca3af}.restore-reason,.restore-warning{margin-top:2px;font-size:.7rem;color:#ef4444;line-height:1.3}.primary-btn.disabled{background:#e5e7eb;border-color:#e5e7eb;color:#9ca3af;cursor:not-allowed}.primary-btn.disabled:hover{background:#e5e7eb}.ghost-btn{padding:.4rem .8rem;border-radius:6px;border:1px solid #d1d5db;background:#fff;font-size:.75rem;font-weight:600;cursor:pointer;transition:background .15s ease}.ghost-btn:hover{background:#f9fafb}.myetf-detail-page{width:100%}.detail-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:28px}.title-area h2{margin:0;font-size:1.25rem;font-weight:700;color:#111827}.etf-description{margin-top:8px;padding:8px 12px;background:#f9fafb;border-radius:8px;font-size:.85rem;color:#374151}.action-area{display:flex;gap:8px}.btn-primary{padding:6px 14px;border-radius:999px;border:1px solid #111827;background:#111827;color:#fff;font-size:.85rem;font-weight:600;cursor:pointer;transition:all .15s ease}.btn-primary:hover{background:#1f2937}.btn-danger-outline{padding:6px 12px;border-radius:999px;border:1px solid #fca5a5;background:#fff;color:#dc2626;font-size:.8rem;font-weight:600;cursor:pointer;transition:all .15s ease}.btn-danger-outline:hover{background:#fee2e2}.detail-summary-card{border:1px solid #e5e7eb;border-radius:12px;padding:20px 12px;margin-bottom:20px;background:#fff}.summary-grid{display:grid;grid-template-columns:repeat(4,1fr);text-align:center}.summary-item .label{font-size:.8rem;color:#6b7280}.summary-item .value{margin-top:4px;font-size:1.05rem;font-weight:700}.profit-plus{color:#dc2626}.profit-minus{color:#2563eb}.detail-item-card{border:1px solid #e5e7eb;border-radius:12px;overflow:hidden;background:#fff}.detail-item-card h3{margin:0;padding:12px 16px;border-bottom:1px solid #e5e7eb;font-size:.95rem;font-weight:700;color:#111827}.detail-item-table{width:100%;border-collapse:collapse}.detail-item-table th,.detail-item-table td{padding:10px 8px;border-bottom:1px solid #f1f3f5;text-align:center;font-size:.85rem}.detail-item-table th{background:#f9fafb;font-weight:600;color:#374151}.detail-item-table tr:last-child td{border-bottom:none}.detail-item-table tbody tr:hover{background:#f8fafc}.myetf-detail-loading{padding:48px;text-align:center;font-size:.9rem;color:#6b7280}.back-btn{margin-bottom:12px;padding:6px 12px;border-radius:6px;border:1px solid #d1d5db;background:#fff;font-size:.85rem;font-weight:600;color:#374151;cursor:pointer;transition:all .15s ease}.back-btn:hover{background:#f3f4f6}
