@import"https://cdn.jsdelivr.net/gh/orioncactus/pretendard/dist/web/static/pretendard.css";.order-bar-modern{background:linear-gradient(135deg,#0f172a 0%,#1e293b 100%);border-bottom:1px solid rgba(148,163,184,.1);padding:10px 16px;box-shadow:0 4px 6px -1px #0000004d,0 2px 4px -1px #0003}.order-bar-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(85px,1fr));gap:8px;margin-bottom:8px;align-items:end}.order-input-group{display:flex;flex-direction:column;gap:4px;position:relative}.order-input-group.with-checkbox{min-width:100px}.order-label{font-size:10px;font-weight:600;color:#94a3b8;text-transform:uppercase;letter-spacing:.8px;white-space:nowrap;display:flex;align-items:center;gap:4px}.order-label:before{content:"";width:3px;height:3px;background:#3b82f6;border-radius:50%;display:inline-block}.order-label.clickable{cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none;transition:all .2s ease}.order-label.clickable:hover{color:#cbd5e1;transform:translate(2px)}.order-checkbox-wrapper{display:flex;align-items:center;gap:6px;padding:2px 0}.order-checkbox{-moz-appearance:none;appearance:none;-webkit-appearance:none;width:18px;height:18px;border:2px solid #475569;border-radius:5px;cursor:pointer;position:relative;transition:all .3s cubic-bezier(.4,0,.2,1);background:linear-gradient(135deg,#1e293b 0%,#0f172a 100%);box-shadow:inset 0 2px 4px #0000004d}.order-checkbox:hover{border-color:#64748b;transform:scale(1.05)}.order-checkbox:checked{background:linear-gradient(135deg,#3b82f6 0%,#2563eb 100%);border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f633,inset 0 1px 2px #fff3}.order-checkbox:checked:after{content:"✓";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);color:#fff;font-size:12px;font-weight:700;text-shadow:0 1px 2px rgba(0,0,0,.3)}.order-checkbox:focus{outline:none;box-shadow:0 0 0 3px #3b82f64d}.order-input{width:100%;padding:7px 10px;font-size:13px;font-weight:600;color:#f1f5f9;background:linear-gradient(135deg,rgba(30,41,59,.8) 0%,rgba(15,23,42,.9) 100%);border:2px solid #334155;border-radius:6px;transition:all .3s cubic-bezier(.4,0,.2,1);outline:none;box-shadow:inset 0 2px 4px #0003;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.order-input::-moz-placeholder{color:#64748b}.order-input::placeholder{color:#64748b}.order-input:hover:not(:disabled){border-color:#475569;background:linear-gradient(135deg,rgba(51,65,85,.8) 0%,rgba(30,41,59,.9) 100%);transform:translateY(-1px);box-shadow:inset 0 2px 4px #0003,0 2px 4px #0000001a}.order-input:focus{border-color:#3b82f6;background:linear-gradient(135deg,rgba(51,65,85,.9) 0%,rgba(30,41,59,1) 100%);box-shadow:0 0 0 3px #3b82f626,inset 0 2px 4px #0000004d,0 4px 6px #0000001a;transform:translateY(-1px)}.order-input:disabled{opacity:.4;cursor:not-allowed;background:linear-gradient(135deg,rgba(15,23,42,.5) 0%,rgba(0,0,0,.3) 100%);border-color:#1e293b;transform:none}.order-buttons{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-top:2px}.order-btn{display:flex;align-items:center;justify-content:center;gap:6px;padding:9px 16px;font-size:12px;font-weight:700;border:none;border-radius:8px;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);text-transform:uppercase;letter-spacing:.5px;position:relative;overflow:hidden;box-shadow:0 4px 6px -1px #0000004d,0 2px 4px -1px #0003,inset 0 1px #ffffff1a}.order-btn:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent);transition:left .6s cubic-bezier(.4,0,.2,1)}.order-btn:hover:before{left:100%}.order-btn:after{content:"";position:absolute;top:0;left:0;right:0;bottom:0;border-radius:8px;box-shadow:inset 0 1px 2px #ffffff1a;pointer-events:none}.order-btn:hover{transform:translateY(-2px);box-shadow:0 10px 15px -3px #0006,0 4px 6px -2px #0000004d,inset 0 1px #fff3}.order-btn:active{transform:translateY(0);box-shadow:0 2px 4px -1px #0000004d,inset 0 2px 4px #0000004d}.order-btn-buy{background:linear-gradient(135deg,#ef4444 0%,#dc2626 100%);color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.3);border:1px solid rgba(239,68,68,.3)}.order-btn-buy:hover{background:linear-gradient(135deg,#dc2626 0%,#b91c1c 100%);box-shadow:0 10px 15px -3px #ef444466,0 4px 6px -2px #ef44444d,inset 0 1px #fff3}.order-btn-buy:active{background:linear-gradient(135deg,#b91c1c 0%,#991b1b 100%)}.order-btn-sell{background:linear-gradient(135deg,#2563eb 0%,#1d4ed8 100%);color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.3);border:1px solid rgba(37,99,235,.3)}.order-btn-sell:hover{background:linear-gradient(135deg,#1d4ed8 0%,#1e40af 100%);box-shadow:0 10px 15px -3px #2563eb66,0 4px 6px -2px #2563eb4d,inset 0 1px #fff3}.order-btn-sell:active{background:linear-gradient(135deg,#1e40af 0%,#1e3a8a 100%)}.btn-icon{font-size:14px;font-weight:700;filter:drop-shadow(0 1px 2px rgba(0,0,0,.3))}.btn-text{font-size:11px;letter-spacing:.5px;font-weight:700}.orderbar,.orderbar-label,.orderbar-input,.orderbar-actions{display:none}.order-available-qty{display:flex;align-items:center;gap:12px;padding:8px 0;font-size:10px;color:#94a3b8;border-top:1px solid rgba(148,163,184,.1);margin-top:6px}.available-label{font-weight:700;color:#cbd5e1;text-transform:uppercase;letter-spacing:.8px;display:flex;align-items:center;gap:6px}.available-label:before{content:"●";color:#3b82f6;font-size:8px}.available-buy,.available-sell{font-weight:700;font-size:12px;padding:3px 10px;border-radius:5px;display:inline-flex;align-items:center;gap:5px;transition:all .2s ease;box-shadow:0 1px 3px #0003}.available-buy:before{content:"▲";font-size:9px}.available-sell:before{content:"▼";font-size:9px}.available-buy{color:#10b981;background:linear-gradient(135deg,rgba(16,185,129,.15) 0%,rgba(16,185,129,.1) 100%);border:1px solid rgba(16,185,129,.3)}.available-buy:hover{background:linear-gradient(135deg,rgba(16,185,129,.2) 0%,rgba(16,185,129,.15) 100%);transform:translateY(-1px);box-shadow:0 2px 4px #10b9814d}.available-sell{color:#ef4444;background:linear-gradient(135deg,rgba(239,68,68,.15) 0%,rgba(239,68,68,.1) 100%);border:1px solid rgba(239,68,68,.3)}.available-sell:hover{background:linear-gradient(135deg,rgba(239,68,68,.2) 0%,rgba(239,68,68,.15) 100%);transform:translateY(-1px);box-shadow:0 2px 4px #ef44444d}*{box-sizing:border-box;margin:0;padding:0}body{font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background-color:#f8fafc;color:#1e293b;line-height:1.5;min-width:1400px;overflow-x:auto}.min-h-screen{min-height:100vh}.flex{display:flex}.flex-1{flex:1}.items-center{align-items:center}.justify-center{justify-content:center}.text-center{text-align:center}.relative{position:relative}.absolute{position:absolute}.inset-0{top:0;right:0;bottom:0;left:0}.z-10{z-index:10}.w-full{width:100%}.h-screen{height:100vh}.max-w-md{max-width:28rem}.rounded-md{border-radius:.375rem}.rounded-lg{border-radius:.5rem}.p-4{padding:1rem}.p-8{padding:2rem}.px-3{padding-left:.75rem;padding-right:.75rem}.py-2{padding-top:.5rem;padding-bottom:.5rem}.px-4{padding-left:1rem;padding-right:1rem}.mb-2{margin-bottom:.5rem}.mb-6{margin-bottom:1.5rem}.mb-8{margin-bottom:2rem}.mt-1{margin-top:.25rem}.mt-6{margin-top:1.5rem}.ml-2{margin-left:.5rem}.space-y-6>*+*{margin-top:1.5rem}.space-y-4>*+*{margin-top:1rem}.space-x-3>*+*{margin-left:.75rem}.space-x-4>*+*{margin-left:1rem}.grid{display:grid}.grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.gap-2{gap:.5rem}.gap-4{gap:1rem}.block{display:block}.inline-flex{display:inline-flex}.hidden{display:none}.overflow-hidden{overflow:hidden}.bg-white{background-color:#fff}.bg-gray-100{background-color:#f3f4f6}.bg-gray-200{background-color:#e5e7eb}.bg-gray-300{background-color:#d1d5db}.bg-gray-600{background-color:#4b5563}.bg-gray-700{background-color:#374151}.bg-gray-900{background-color:#111827}.bg-blue-600{background-color:#2563eb}.bg-blue-700{background-color:#1d4ed8}.bg-blue-800{background-color:#1e40af}.bg-red-600{background-color:#dc2626}.bg-red-700{background-color:#b91c1c}.bg-black{background-color:#000}.bg-opacity-20{background-color:#0003}.bg-opacity-10{background-color:#ffffff1a}.text-white{color:#fff}.text-gray-600{color:#4b5563}.text-gray-700{color:#374151}.text-gray-900{color:#111827}.text-blue-100{color:#dbeafe}.text-blue-500{color:#3b82f6}.text-blue-600{color:#2563eb}.text-red-500{color:#ef4444}.text-red-600{color:#dc2626}.border{border:1px solid #d1d5db}.border-gray-300{border-color:#d1d5db}.border-red-500{border-color:#ef4444}.text-sm{font-size:.875rem}.text-base{font-size:1rem}.text-2xl{font-size:1.5rem}.text-3xl{font-size:1.875rem}.font-light{font-weight:300}.font-medium{font-weight:500}.font-semibold{font-weight:600}.font-bold{font-weight:700}.bg-gradient-to-br{background-image:linear-gradient(to bottom right,var(--tw-gradient-stops))}.from-blue-600{--tw-gradient-from: #2563eb;--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to, rgba(37, 99, 235, 0))}.to-blue-800{--tw-gradient-to: #1e40af}@keyframes spin{to{transform:rotate(360deg)}}.animate-spin{animation:spin 1s linear infinite}.btn{display:inline-flex;align-items:center;justify-content:center;border-radius:12px;font-size:1rem;font-weight:600;transition:all .3s cubic-bezier(.4,0,.2,1);border:none;cursor:pointer;text-decoration:none;position:relative;overflow:hidden;min-height:48px;padding:0 24px;box-shadow:0 4px 14px #0000001a}.btn:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);transition:left .5s}.btn:hover:before{left:100%}.btn:focus{outline:none;box-shadow:0 0 0 3px #3b82f64d}.btn:disabled{opacity:.6;pointer-events:none;box-shadow:none}.btn:active{transform:translateY(1px)}.btn-primary{background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.1)}.btn-primary:hover{background:linear-gradient(135deg,#5a67d8 0%,#6b46c1 100%);transform:translateY(-2px);box-shadow:0 8px 25px #667eea66}.btn-secondary{background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.1);box-shadow:0 4px 14px #667eea4d}.btn-secondary:hover{background:linear-gradient(135deg,#5a67d8 0%,#6b46c1 100%);transform:translateY(-2px);box-shadow:0 8px 25px #667eea80}.btn-danger{background:linear-gradient(135deg,#ff6b6b 0%,#ee5a52 100%);color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.1)}.btn-danger:hover{background:linear-gradient(135deg,#ff5252 0%,#e53e3e 100%);transform:translateY(-2px);box-shadow:0 8px 25px #ff6b6b66}.btn-dark{background:linear-gradient(135deg,#434343 0%,#000000 100%);color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.1)}.btn-dark:hover{background:linear-gradient(135deg,#2d3748 0%,#1a202c 100%);transform:translateY(-2px);box-shadow:0 8px 25px #43434366}.input{width:100%;padding:16px 20px;border:2px solid #e2e8f0;border-radius:12px;font-size:1rem;font-weight:500;color:#1e293b;background:rgba(255,255,255,.9);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:0 4px 6px -1px #0000001a}.input:focus{outline:none;border-color:#667eea;color:#1e293b;background:white;box-shadow:0 0 0 3px #667eea1a,0 10px 15px -3px #0000001a;transform:translateY(-1px)}.input:hover{border-color:#cbd5e0;box-shadow:0 8px 25px -8px #00000026}.input:disabled{background-color:#f7fafc;cursor:not-allowed;opacity:.6}.input::-moz-placeholder{color:#a0aec0;font-weight:400}.input::placeholder{color:#a0aec0;font-weight:400}.select{width:100%;padding:16px 20px;border:2px solid #e2e8f0;border-radius:12px;background:rgba(255,255,255,.9);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);font-size:1rem;font-weight:500;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:0 4px 6px -1px #0000001a;cursor:pointer}.select:focus{outline:none;border-color:#667eea;background:white;box-shadow:0 0 0 3px #667eea1a,0 10px 15px -3px #0000001a;transform:translateY(-1px)}.select:hover{border-color:#cbd5e0;box-shadow:0 8px 25px -8px #00000026}.checkbox{width:20px;height:20px;border:2px solid #e2e8f0;border-radius:6px;background:white;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);position:relative}.checkbox:checked{background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);border-color:#667eea}.checkbox:checked:after{content:"";position:absolute;top:3px;left:7px;width:4px;height:8px;border:solid white;border-width:0 2px 2px 0;transform:rotate(45deg)}.checkbox:focus{outline:none;box-shadow:0 0 0 3px #667eea4d}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.6);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .3s ease-out}.modal-content{background:white;border-radius:20px;padding:32px;max-width:600px;width:90vw;max-height:90vh;overflow-y:auto;box-shadow:0 25px 50px -12px #00000040;animation:slideUp .3s ease-out}@keyframes slideUp{0%{opacity:0;transform:translateY(20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.error-message{color:#e53e3e;font-size:.875rem;font-weight:500;margin-top:8px}.form-label{display:block;font-size:.875rem;font-weight:600;color:#1e293b;margin-bottom:8px;text-transform:uppercase;letter-spacing:.05em}.form-label .required{color:#e53e3e;margin-left:4px}.container{width:100%;min-width:1400px;padding:0 2rem}.responsive-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem}.responsive-flex{display:flex;flex-direction:row}.md\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.md\:col-span-2{grid-column:span 2 / span 2}.md\:flex{display:flex}.md\:hidden{display:none}.login-layout{flex-direction:row}.login-left{min-height:100vh}.login-right{padding:2rem}.modal-content{max-width:700px;padding:40px}.btn{min-height:48px;font-size:1rem}.input,.select{padding:16px 20px;font-size:1rem}@media (prefers-reduced-motion: reduce){.btn,.input,.select,.modal-overlay,.modal-content{transition:none;animation:none}}.main-container{width:100%;min-width:1400px;height:100vh;background-color:#f5f5f5;display:flex;flex-direction:column;overflow-x:auto}.navbar{height:60px;min-height:60px;max-height:60px;background-color:#fff;border-bottom:1px solid #e0e0e0;display:flex;align-items:center;justify-content:space-between;padding:0 20px;flex-shrink:0;min-width:1400px;overflow:visible}.navbar-logo{flex:0 0 auto;flex-shrink:0;margin-right:12px}.logo-box{background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);color:#fff;padding:8px 16px;border-radius:6px;font-weight:700;font-size:16px;white-space:nowrap}.navbar-menus{flex:1;display:flex;justify-content:center;gap:15px;flex-wrap:nowrap;min-width:700px;flex-shrink:0;padding-left:8px}.navbar-menu{background:none;border:none;padding:8px 12px;font-size:13px;font-weight:500;color:#333;cursor:pointer;border-radius:4px;transition:all .2s;white-space:nowrap;flex-shrink:0}.navbar-menu:hover{background-color:#f0f0f0;color:#000}.navbar-profit{flex:0 0 auto;display:flex;gap:10px;flex-shrink:0;flex-wrap:nowrap}.profit-item{display:flex;flex-direction:column;align-items:center;padding:6px 10px;background-color:#f8f9fa;border:1px solid #dee2e6;border-radius:4px;min-width:90px;white-space:nowrap;flex-shrink:0}.profit-label{font-size:10px;color:#666;margin-bottom:2px;white-space:nowrap}.profit-value{font-size:12px;font-weight:600;white-space:nowrap}.profit-positive{color:#dc3545}.profit-negative{color:#007bff}.navbar-user{flex:0 0 auto;display:flex;align-items:center;gap:10px;padding:0 12px;border-left:1px solid #e0e0e0;margin-left:10px;flex-shrink:0;flex-wrap:nowrap}.user-name{font-size:14px;font-weight:600;color:#333}.logout-button{background-color:#6c757d;color:#fff;border:none;padding:8px 16px;font-size:13px;font-weight:500;border-radius:4px;cursor:pointer;transition:all .2s}.logout-button:hover{background-color:#5a6268;transform:translateY(-1px);box-shadow:0 2px 4px #00000026}.logout-button:active{transform:translateY(0)}.myinfo-button{background-color:#2563eb;color:#fff;border:none;padding:8px 16px;font-size:13px;font-weight:500;border-radius:4px;cursor:pointer;transition:all .2s}.myinfo-button:hover{background-color:#1d4ed8;transform:translateY(-1px);box-shadow:0 2px 4px #00000026}.main-content{flex:1;display:flex;gap:10px;padding:10px;overflow:hidden;min-width:1380px}.main-content.three-col{grid-template-columns:none}.left-panel{width:60%;display:flex;flex-direction:column;gap:10px}.left-panel.narrow{width:40%}.center-panel.wide{width:40%;display:flex;flex-direction:column}.right-panel.narrow{width:20%}.chart-section.full{height:100%}.right-panel{width:40%;background-color:#fff;border:1px solid #e0e0e0;border-radius:4px;display:flex;flex-direction:column}.price-info-section{height:25%;border-bottom:1px solid #e0e0e0;display:flex;flex-direction:column}.price-info-table{flex:1;padding:10px;overflow-y:auto}.info-table{width:100%;border-collapse:collapse;font-size:12px}.info-table td{padding:4px 8px;border:1px solid #e0e0e0;text-align:center}.info-label{background-color:#f8f9fa;font-weight:600;color:#495057;width:25%}.info-value{background-color:#fff;font-weight:500;color:#212529;width:25%}.info-value.price-up{color:#dc3545;font-weight:600}.info-value.price-down{color:#007bff;font-weight:600}.symbol-list-section{height:40%;border-bottom:1px solid #e0e0e0;display:flex;flex-direction:column}.symbol-list-content,.symbol-list-table{flex:1;overflow:hidden;display:flex;flex-direction:column}.symbol-table{width:100%;border-collapse:collapse;font-size:12px;height:100%}.symbol-table thead{background-color:#f8f9fa;position:sticky;top:0;z-index:5}.symbol-table th{padding:8px 4px;text-align:center;border:1px solid #e0e0e0;font-weight:600;color:#495057;box-sizing:border-box}.symbol-table th:nth-child(1){width:50%}.symbol-table th:nth-child(2){width:25%}.symbol-table th:nth-child(3){width:25%}.symbol-table tbody{display:block;overflow-y:auto}.symbol-table thead,.symbol-table tbody tr{display:table;width:100%;table-layout:fixed}.symbol-table td{padding:6px 4px;text-align:center;border:1px solid #e0e0e0;font-size:11px;color:#212529;box-sizing:border-box}.symbol-table td:nth-child(1){width:50%}.symbol-table td:nth-child(2){width:25%}.symbol-table td:nth-child(3){width:25%}.symbol-row{cursor:pointer;transition:background-color .2s ease}.symbol-row:hover{background-color:#f8f9fa}.symbol-row.selected{background-color:#e3f2fd;font-weight:600}.symbol-row.selected td{color:#1976d2}.symbol-table tbody::-webkit-scrollbar{width:6px}.symbol-table tbody::-webkit-scrollbar-track{background:#f1f1f1;border-radius:3px}.symbol-table tbody::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:3px}.symbol-table tbody::-webkit-scrollbar-thumb:hover{background:#a8a8a8}.trade-data-section{height:35%;display:flex;flex-direction:column}.trade-data-table{flex:1;overflow:hidden;display:flex;flex-direction:column}.trade-table{width:100%;border-collapse:collapse;font-size:11px;height:100%}.trade-table thead{background-color:#f8f9fa;position:sticky;top:0;z-index:5}.trade-table th{padding:8px 4px;text-align:center;border:1px solid #e0e0e0;font-weight:600;color:#495057}.trade-table tbody{display:block;overflow-y:auto}.trade-table thead,.trade-table tbody tr{display:table;width:100%;table-layout:fixed}.trade-table td{padding:4px;text-align:center;border:1px solid #e0e0e0;font-size:11px}.trade-price{font-weight:600;color:#212529}.trade-price.trade-buy{color:#dc3545}.trade-price.trade-sell{color:#007bff}.no-data{color:#6c757d;font-style:italic;text-align:center;padding:20px}.trade-table tbody::-webkit-scrollbar{width:6px}.trade-table tbody::-webkit-scrollbar-track{background:#f1f1f1;border-radius:3px}.trade-table tbody::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:3px}.trade-table tbody::-webkit-scrollbar-thumb:hover{background:#a8a8a8}.section-header{background-color:#f8f9fa;border-bottom:1px solid #e0e0e0;padding:10px 15px;font-weight:600;font-size:14px;color:#333;display:flex;justify-content:flex-start;align-items:center;gap:15px}.connection-status{font-size:12px;font-weight:500}.connection-status.connected{color:#28a745}.connection-status.disconnected{color:#dc3545}.price-lock-checkbox{display:inline-flex!important;align-items:center;font-size:12px;cursor:pointer;padding:4px 8px;border-radius:4px;background-color:#007bff1a;border:1px solid rgba(0,123,255,.3);margin-left:auto}.price-lock-checkbox:hover{background-color:#007bff33}.price-lock-checkbox input[type=checkbox]{margin-right:6px;cursor:pointer;width:14px;height:14px;accent-color:#007bff}.price-lock-checkbox span{color:#495057;font-weight:600;font-size:11px;-webkit-user-select:none;-moz-user-select:none;user-select:none}.fixed-column-header{display:flex;align-items:center;justify-content:center;gap:4px}.price-lock-checkbox-header{display:inline-flex;align-items:center;cursor:pointer}.price-lock-checkbox-header input[type=checkbox]{width:12px;height:12px;cursor:pointer;accent-color:#007bff;margin:0}.orderbook-loading{display:flex;align-items:center;justify-content:center;height:300px;background-color:#f8f9fa}.loading-message{color:#6c757d;font-size:14px;font-weight:500;text-align:center}.chart-section{height:37.5%;background-color:#fff;border:1px solid #e0e0e0;border-radius:4px;display:flex;flex-direction:column}.chart-content{flex:1;padding:10px}.chart-iframe{width:100%;height:100%;border:none;background-color:#f8f9fa;display:flex;align-items:center;justify-content:center;color:#666}.orderbook-section{display:flex;flex-direction:column;background-color:#fff;border:1px solid #e0e0e0;border-radius:4px;overflow:hidden}.orderbook-container{flex:1;display:flex;gap:10px;padding:10px;height:calc(100% - 50px);overflow:hidden}.orderbook-table-wrapper{flex:2;border:1px solid #e0e0e0;border-radius:4px;background-color:#fff;overflow:hidden;height:100%;display:flex;flex-direction:column}.orderbook-header-fixed{background-color:#f8f9fa;border-bottom:1px solid #e0e0e0;position:sticky;top:0;z-index:10}.orderbook-virtual-scroll{overflow-y:auto;overflow-x:hidden}.orderbook-virtual-scroll::-webkit-scrollbar{width:8px}.orderbook-virtual-scroll::-webkit-scrollbar-track{background:#f1f1f1;border-radius:4px}.orderbook-virtual-scroll::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:4px}.orderbook-virtual-scroll::-webkit-scrollbar-thumb:hover{background:#a8a8a8}.orderbook-scroll-container{flex:1;overflow:hidden;display:flex;flex-direction:column}.orderbook-scroll-container.locked .orderbook-virtual-scroll{overflow:hidden!important}.orderbook-summary-fixed{flex-shrink:0;background-color:#f8f9fa;border-top:2px solid #007bff;z-index:10}.orderbook-summary-fixed table{width:100%;border-collapse:collapse;font-size:11px;table-layout:fixed}.summary-row{background-color:#f8f9fa!important;font-weight:700}.summary-cell{background-color:#f8f9fa!important;border:1px solid #dee2e6!important;font-weight:700;font-size:11px;height:30px;line-height:26px}.sell-total{color:#007bff}.buy-total{color:#dc3545}.orderbook-summary-fixed table th:nth-child(1),.orderbook-summary-fixed table td:nth-child(1){width:8%;min-width:8%;max-width:8%}.orderbook-summary-fixed table th:nth-child(2),.orderbook-summary-fixed table td:nth-child(2){width:12%;min-width:12%;max-width:12%}.orderbook-summary-fixed table th:nth-child(3),.orderbook-summary-fixed table td:nth-child(3){width:10%;min-width:10%;max-width:10%}.orderbook-summary-fixed table th:nth-child(4),.orderbook-summary-fixed table td:nth-child(4){width:10%;min-width:10%;max-width:10%}.orderbook-summary-fixed table th:nth-child(5),.orderbook-summary-fixed table td:nth-child(5){width:16%;min-width:16%;max-width:16%;font-weight:700;background-color:#f8f9fa}.orderbook-summary-fixed table th:nth-child(6),.orderbook-summary-fixed table td:nth-child(6){width:10%;min-width:10%;max-width:10%}.orderbook-summary-fixed table th:nth-child(7),.orderbook-summary-fixed table td:nth-child(7){width:10%;min-width:10%;max-width:10%}.orderbook-summary-fixed table th:nth-child(8),.orderbook-summary-fixed table td:nth-child(8){width:12%;min-width:12%;max-width:12%}.orderbook-summary-fixed table th:nth-child(9),.orderbook-summary-fixed table td:nth-child(9){width:8%;min-width:8%;max-width:8%}.orderbook-table{width:100%;border-collapse:collapse;font-size:11px;table-layout:fixed}.orderbook-table th,.orderbook-table td{padding:2px 4px;text-align:center;border:1px solid #e0e0e0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;height:24px;line-height:20px}.orderbook-header-fixed table th:nth-child(1),.orderbook-table th:nth-child(1),.orderbook-table td:nth-child(1),.orderbook-cell:nth-child(1){width:8%;min-width:8%;max-width:8%}.orderbook-header-fixed table th:nth-child(2),.orderbook-table th:nth-child(2),.orderbook-table td:nth-child(2),.orderbook-cell:nth-child(2){width:12%;min-width:12%;max-width:12%}.orderbook-header-fixed table th:nth-child(3),.orderbook-table th:nth-child(3),.orderbook-table td:nth-child(3),.orderbook-cell:nth-child(3){width:10%;min-width:10%;max-width:10%}.orderbook-header-fixed table th:nth-child(4),.orderbook-table th:nth-child(4),.orderbook-table td:nth-child(4),.orderbook-cell:nth-child(4){width:12%;min-width:12%;max-width:12%}.orderbook-header-fixed table th:nth-child(5),.orderbook-table th:nth-child(5),.orderbook-table td:nth-child(5),.orderbook-cell:nth-child(5){width:16%;min-width:16%;max-width:16%;font-weight:700;background-color:#f8f9fa}.orderbook-header-fixed table th:nth-child(6),.orderbook-table th:nth-child(6),.orderbook-table td:nth-child(6),.orderbook-cell:nth-child(6){width:12%;min-width:12%;max-width:12%}.orderbook-header-fixed table th:nth-child(7),.orderbook-table th:nth-child(7),.orderbook-table td:nth-child(7),.orderbook-cell:nth-child(7){width:10%;min-width:10%;max-width:10%}.orderbook-header-fixed table th:nth-child(8),.orderbook-table th:nth-child(8),.orderbook-table td:nth-child(8),.orderbook-cell:nth-child(8){width:12%;min-width:12%;max-width:12%}.orderbook-header-fixed table th:nth-child(9),.orderbook-table th:nth-child(9),.orderbook-table td:nth-child(9),.orderbook-cell:nth-child(9){width:8%;min-width:8%;max-width:8%}.orderbook-header-fixed{position:sticky;top:0;z-index:10;background-color:#fff;border-bottom:2px solid #dee2e6}.orderbook-header-fixed table{width:100%;border-collapse:collapse;table-layout:fixed;font-size:11px}.orderbook-header{padding:8px 4px;text-align:center;background-color:#f8f9fa;border:1px solid #e0e0e0;font-weight:700;font-size:11px}.orderbook-cell{padding:2px 4px;text-align:center;border:1px solid #e0e0e0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:11px}.orderbook-table thead{background-color:#f8f9fa;position:sticky;top:0;z-index:10}.orderbook-table th{padding:8px 4px;text-align:center;font-weight:600;border-right:1px solid #e0e0e0;border-bottom:1px solid #e0e0e0}.orderbook-table th:last-child{border-right:none}.orderbook-table th.fixed-column{background-color:#fff3cd}.orderbook-table td{padding:4px;text-align:center;border-right:1px solid #f0f0f0;border-bottom:1px solid #f8f9fa;color:#333}.orderbook-table td:last-child{border-right:none}.orderbook-table td.fixed-column{background-color:#fff;font-weight:500}.orderbook-table td.sell-price{color:#007bff}.orderbook-table td.buy-price{color:#dc3545}:root[data-theme=dark] .orderbook-table th.fixed-column{background-color:#262626}:root[data-theme=dark] .orderbook-table td.fixed-column{background-color:#1f1f1f;color:#d8d8d8}:root[data-theme=dark] .orderbook-table td.sell-price{color:#7aa2f7}:root[data-theme=dark] .orderbook-table td.buy-price{color:#f38ba8}:root[data-theme=dark] .orderbook-table .real-data-row{background-color:#2b2518}:root[data-theme=dark] .orderbook-table .real-data-row:hover{background-color:#332b1d}:root[data-theme=dark] .orderbook-table .sell-price.has-data{background-color:#5a8ce62e}:root[data-theme=dark] .orderbook-table .buy-price.has-data{background-color:#f38ba82e}.orderbook-table tbody tr:hover{background-color:#f8f9fa}.orderbook-table .real-data-row{background-color:#fff8e1;font-weight:500}.orderbook-table .real-data-row:hover{background-color:#fff3c4}.orderbook-table .sell-price.has-data{background-color:#e3f2fd;font-weight:600}.orderbook-table .buy-price.has-data{background-color:#ffebee;font-weight:600}.price-up{background-color:#ffcdd2!important;animation:priceFlash 1s ease-out}.price-down{background-color:#c8e6c9!important;animation:priceFlash 1s ease-out}@keyframes priceFlash{0%{opacity:1}50%{opacity:.7}to{opacity:1}}.orderbook-scroll-container::-webkit-scrollbar{width:8px}.orderbook-scroll-container::-webkit-scrollbar-track{background:#f1f1f1;border-radius:4px}.orderbook-scroll-container::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:4px}.orderbook-scroll-container::-webkit-scrollbar-thumb:hover{background:#a8a8a8}.orderbook-table tbody tr:hover{background-color:transparent}.orderbook-table td:hover{background-color:#eef2f7}.orderbook-options{flex:1;display:flex;flex-direction:column;min-width:150px}.options-header{font-weight:600;font-size:13px;color:#333;margin-bottom:10px;padding-bottom:5px;border-bottom:1px solid #e0e0e0}.checkbox-group{display:flex;flex-direction:column;gap:8px}.checkbox-item{display:flex;align-items:center;gap:8px;cursor:pointer;font-size:12px;color:#555;padding:4px 0}.checkbox-item:hover{color:#333}.option-checkbox{width:14px;height:14px;cursor:pointer}.holdings-section{display:flex;flex-direction:column;background-color:#fff;border:1px solid #e0e0e0;border-radius:4px;overflow:hidden}.holdings-content{flex:1;overflow:auto;min-height:0}.holdings-table{width:100%;border-collapse:collapse;font-size:13px}.holdings-table thead{background-color:#f8f9fa;position:sticky;top:0}.holdings-table th{padding:10px 8px;text-align:center;font-weight:600;border-right:1px solid #e0e0e0;border-bottom:1px solid #e0e0e0}.holdings-table th:last-child{border-right:none}.holdings-table td{padding:8px;text-align:center;border-right:1px solid #f0f0f0;border-bottom:1px solid #f8f9fa}.holdings-table td:last-child{border-right:none}.holdings-table td.no-data{color:#666;font-style:italic;padding:30px}.order-content{flex:1;padding:20px;display:flex;align-items:center;justify-content:center;color:#666}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.75);display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-content{background:linear-gradient(145deg,#1e1e1e,#181818);border-radius:16px;width:90%;max-width:1200px;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 25px 50px #000000b3;border:1px solid #2a2a2a;animation:slideUp .3s ease}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:24px 28px;border-bottom:1px solid #2a2a2a;background:linear-gradient(135deg,#252525,#1a1a1a)}.modal-header h3{margin:0;color:#fff;font-size:22px;font-weight:700;letter-spacing:-.5px}.modal-close{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);color:#aaa;font-size:24px;cursor:pointer;padding:0;width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:8px;transition:all .2s ease}.modal-close:hover{background:rgba(255,255,255,.1);color:#fff;border-color:#fff3;transform:rotate(90deg)}.modal-filters{padding:24px 28px;background:#1a1a1a;border-bottom:1px solid #2a2a2a}.filter-row{display:flex;gap:16px;align-items:end;flex-wrap:wrap;margin-bottom:18px}.filter-group{display:flex;flex-direction:column;gap:8px}.filter-group label{color:#b0b0b0;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:1px}.filter-group input,.filter-group select{background:#2a2a2a;border:1px solid #3a3a3a;color:#e0e0e0;padding:10px 14px;border-radius:8px;font-size:14px;min-width:130px;transition:all .2s ease}.filter-group input:hover,.filter-group select:hover{border-color:#4a4a4a}.filter-group input:focus,.filter-group select:focus{outline:none;border-color:#4a9eff;background:#303030;box-shadow:0 0 0 3px #4a9eff26}.btn{padding:10px 20px;border:none;border-radius:8px;font-size:13px;font-weight:600;cursor:pointer;transition:all .2s ease;text-transform:uppercase;letter-spacing:.8px}.btn-apply{background:linear-gradient(135deg,#4a9eff,#3d7dd9);color:#fff;min-width:90px;box-shadow:0 2px 8px #4a9eff4d}.btn-apply:hover:not(:disabled){background:linear-gradient(135deg,#5aadff,#4d8de9);transform:translateY(-2px);box-shadow:0 6px 16px #4a9eff66}.btn-apply:disabled{opacity:.5;cursor:not-allowed;box-shadow:none}.summary-row{display:flex;align-items:center;gap:12px;font-size:17px;font-weight:700;padding:16px 20px;background:linear-gradient(135deg,#252525,#1f1f1f);border-radius:10px;border:1px solid #2a2a2a;box-shadow:0 2px 8px #0000004d}.summary-row span:first-child{color:#d0d0d0;font-weight:600}.modal-body{flex:1;overflow:auto;padding:0;background:#1a1a1a}.history-table{width:100%;border-collapse:collapse;font-size:13px}.history-table thead{background:linear-gradient(135deg,#2a2a2a,#252525);position:sticky;top:0;z-index:10;box-shadow:0 2px 4px #0003}.history-table th{padding:16px 14px;text-align:left;color:#e8e8e8;font-weight:700;border-bottom:2px solid #3a3a3a;text-transform:uppercase;letter-spacing:.8px;font-size:11px}.history-table td{padding:14px;border-bottom:1px solid #252525;color:#d0d0d0;vertical-align:middle}.history-table tbody tr{transition:all .2s ease;background:#1e1e1e}.history-table tbody tr:hover{background:#282828;box-shadow:0 2px 8px #0000004d}.history-table tbody tr:nth-child(2n){background:#1a1a1a}.history-table tbody tr:nth-child(2n):hover{background:#282828}.side-badge{display:inline-block;padding:5px 10px;border-radius:6px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px}.side-badge.long{background:linear-gradient(135deg,rgba(255,75,75,.15),rgba(255,75,75,.08));color:#ff6b6b;border:1px solid rgba(255,75,75,.3);box-shadow:0 2px 4px #ff4b4b1a}.side-badge.short{background:linear-gradient(135deg,rgba(74,158,255,.15),rgba(74,158,255,.08));color:#5aadff;border:1px solid rgba(74,158,255,.3);box-shadow:0 2px 4px #4a9eff1a}.no-data{text-align:center;color:#777;font-style:italic;padding:50px!important;font-size:14px}.price-up{color:#dc3545;font-weight:700;background-color:transparent!important}.price-down{color:#007bff;font-weight:700;background-color:transparent!important}.holdings-table .price-up,.history-table .price-up,.summary-row .price-up{color:#dc3545;background-color:transparent!important;text-shadow:none;animation:none}.holdings-table .price-down,.history-table .price-down,.summary-row .price-down{color:#007bff;background-color:transparent!important;text-shadow:none;animation:none}:root[data-theme=light]{--bg-primary: #ffffff;--bg-secondary: #f8f9fa;--bg-tertiary: #f3f4f6;--bg-navbar: #ffffff;--bg-panel: #ffffff;--bg-hover: #f8f9fa;--text-primary: #1e293b;--text-secondary: #4b5563;--text-tertiary: #9ca3af;--text-label: #495057;--border-primary: #e0e0e0;--border-secondary: #dee2e6;--border-light: #f0f0f0}:root[data-theme=dark]{--bg-primary: #1e1e1e;--bg-secondary: #1a1a1a;--bg-tertiary: #2a2a2a;--bg-navbar: #1a1a1a;--bg-panel: #1e1e1e;--bg-hover: #2a2a2a;--text-primary: #e0e0e0;--text-secondary: #b0b0b0;--text-tertiary: #808080;--text-label: #d0d0d0;--border-primary: #3a3a3a;--border-secondary: #2a2a2a;--border-light: #333333}body{background-color:var(--bg-secondary, #f5f5f5);color:var(--text-primary, #1e293b);transition:background-color .3s ease,color .3s ease}.main-container{background-color:var(--bg-secondary, #f5f5f5);transition:background-color .3s ease}.navbar{background-color:var(--bg-navbar, #ffffff);border-bottom-color:var(--border-primary, #e0e0e0);transition:background-color .3s ease,border-color .3s ease}.navbar-menu{color:var(--text-primary, #333);transition:background-color .2s,color .2s}.navbar-menu:hover{background-color:var(--bg-hover, #f0f0f0)}.user-name{color:var(--text-primary, #333)}.profit-item{background-color:var(--bg-tertiary, #f8f9fa);border-color:var(--border-secondary, #dee2e6);transition:background-color .3s ease,border-color .3s ease}.profit-label{color:var(--text-secondary, #666)}.right-panel,.chart-section,.orderbook-section,.holdings-section{background-color:var(--bg-panel, #ffffff);border-color:var(--border-primary, #e0e0e0);transition:background-color .3s ease,border-color .3s ease}.section-header{background-color:var(--bg-tertiary, #f8f9fa);border-bottom-color:var(--border-primary, #e0e0e0);color:var(--text-primary, #333);transition:background-color .3s ease,border-color .3s ease}.symbol-table thead{background-color:var(--bg-tertiary, #f8f9fa)}.symbol-table th{border-color:var(--border-primary, #e0e0e0);color:var(--text-label, #495057)}.symbol-table td{border-color:var(--border-primary, #e0e0e0);color:var(--text-primary, #212529)}.symbol-row:hover{background-color:var(--bg-hover, #f8f9fa)}.trade-table thead{background-color:var(--bg-tertiary, #f8f9fa)}.trade-table th{border-color:var(--border-primary, #e0e0e0);color:var(--text-label, #495057)}.trade-table td{border-color:var(--border-primary, #e0e0e0);color:var(--text-primary, #212529)}.info-table td{border-color:var(--border-primary, #e0e0e0);transition:border-color .3s ease}.info-label{background-color:var(--bg-tertiary, #f8f9fa);color:var(--text-label, #495057)}.info-value{background-color:var(--bg-panel, #ffffff);color:var(--text-primary, #212529)}.holdings-table thead{background-color:var(--bg-tertiary, #f8f9fa)}.holdings-table th{border-right-color:var(--border-primary, #e0e0e0);border-bottom-color:var(--border-primary, #e0e0e0);color:var(--text-label, #495057)}.holdings-table td{border-right-color:var(--border-light, #f0f0f0);border-bottom-color:var(--border-secondary, #f8f9fa);color:var(--text-primary, #212529)}.orderbook-table th,.orderbook-table td{border-color:var(--border-primary, #e0e0e0);color:var(--text-primary, #333)}.orderbook-header{background-color:var(--bg-tertiary, #f8f9fa);color:var(--text-label, #495057)}.orderbook-header-fixed{background-color:var(--bg-tertiary, #f8f9fa);border-bottom-color:var(--border-primary, #dee2e6)}.orderbook-cell{background-color:var(--bg-panel, #ffffff);border-color:var(--border-primary, #e0e0e0);color:var(--text-primary, #333)}.orderbook-summary-fixed{background-color:var(--bg-tertiary, #f8f9fa)}.summary-cell{background-color:var(--bg-tertiary, #f8f9fa)!important;border-color:var(--border-secondary, #dee2e6)!important}.orderbook-table-wrapper{background-color:var(--bg-panel, #ffffff);border-color:var(--border-primary, #e0e0e0)}.orderbook-virtual-scroll{background-color:var(--bg-panel, #ffffff)}.symbol-table tbody::-webkit-scrollbar-track,.trade-table tbody::-webkit-scrollbar-track,.orderbook-virtual-scroll::-webkit-scrollbar-track{background:var(--bg-tertiary, #f1f1f1)}.symbol-table tbody::-webkit-scrollbar-thumb,.trade-table tbody::-webkit-scrollbar-thumb,.orderbook-virtual-scroll::-webkit-scrollbar-thumb{background:var(--text-tertiary, #c1c1c1)}.modal-overlay{background:rgba(0,0,0,.75);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}:root[data-theme=dark] .modal-content{background:linear-gradient(145deg,#1e1e1e,#181818);border:1px solid #2a2a2a}:root[data-theme=light] .modal-content{background:#fff}.modal-header{border-bottom-color:var(--border-primary, #2a2a2a);background:var(--bg-tertiary, #252525)}.modal-header h3{color:var(--text-primary, #ffffff)}.modal-close{background:rgba(255,255,255,.05);border-color:#ffffff1a;color:var(--text-secondary, #aaa)}:root[data-theme=dark] .modal-filters{background:#1a1a1a;border-bottom-color:#2a2a2a}:root[data-theme=dark] .filter-group input,:root[data-theme=dark] .filter-group select{background:#2a2a2a;border-color:#3a3a3a;color:#e0e0e0}:root[data-theme=dark] .history-table thead{background:linear-gradient(135deg,#2a2a2a,#252525)}:root[data-theme=dark] .history-table th{color:#e8e8e8;border-bottom-color:#3a3a3a}:root[data-theme=dark] .history-table td{border-bottom-color:#252525;color:#d0d0d0}:root[data-theme=dark] .history-table tbody tr{background:#1e1e1e}:root[data-theme=dark] .history-table tbody tr:hover{background:#282828}.theme-toggle{background:var(--bg-tertiary, #f3f4f6);border:1px solid var(--border-primary, #e0e0e0);color:var(--text-primary, #1e293b);padding:8px 12px;border-radius:6px;cursor:pointer;font-size:13px;font-weight:600;display:flex;align-items:center;gap:6px;transition:all .2s ease}.theme-toggle:hover{background:var(--bg-hover, #f8f9fa);transform:translateY(-1px);box-shadow:0 2px 4px #0000001a}.theme-toggle-icon{font-size:16px}.ch-wrapper{font-family:Pretendard,-apple-system,BlinkMacSystemFont,system-ui,Roboto,Helvetica Neue,Segoe UI,Apple SD Gothic Neo,Noto Sans KR,Malgun Gothic,"Apple Color Emoji","Segoe UI Emoji",Segoe UI Symbol,sans-serif;min-height:100vh;background-color:#0f1115;color:#e5e7eb;padding-bottom:60px}.ch-header{position:sticky;top:0;z-index:100;background-color:#0f1115d9;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid #1f222a}.ch-header-inner{max-width:1560px;margin:0 auto;height:64px;display:flex;align-items:center;justify-content:space-between;padding:0 20px}.ch-logo{font-size:22px;font-weight:800;color:#fff;letter-spacing:-.5px;cursor:pointer}.ch-gnb{display:flex;height:100%}.ch-gnb button{background:transparent;border:none;color:#a1a1aa;font-size:15px;font-weight:600;padding:0 20px;height:100%;cursor:pointer;position:relative;transition:color .2s}.ch-gnb button:hover{color:#e2e8f0}.ch-gnb button.active{color:#fff}.ch-gnb button.active:after{content:"";position:absolute;bottom:-1px;left:0;width:100%;height:3px;background-color:#3b82f6}.ch-header-right{display:flex;align-items:center}.ch-btn-primary{background-color:#4f46e5;color:#fff;border:none;border-radius:6px;padding:10px 16px;font-size:14px;font-weight:600;cursor:pointer;transition:background-color .2s}.ch-btn-primary:hover:not(:disabled){background-color:#4338ca}.ch-btn-primary:disabled{background-color:#334155;color:#94a3b8;cursor:not-allowed}.ch-btn-secondary{background-color:#1e293b;color:#e2e8f0;border:none;border-radius:6px;padding:10px 16px;font-size:14px;font-weight:600;cursor:pointer;transition:background-color .2s}.ch-btn-secondary:hover{background-color:#334155}.ch-btn-outline{background-color:transparent;color:#cbd5e1;border:1px solid #334155;border-radius:6px;padding:9px 15px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s}.ch-btn-outline:hover{border-color:#4f46e5;background-color:#4f46e51a;color:#fff}.ch-btn-outline.danger{color:#ef4444;border-color:#ef4444}.ch-btn-outline.danger:hover{background-color:#ef44441a}.ch-btn-ghost{background-color:transparent;color:#94a3b8;border:none;padding:8px 12px;font-size:13px;cursor:pointer;border-radius:6px}.ch-btn-ghost:hover{background-color:#1e222b;color:#e2e8f0}.ch-btn-ghost.tiny{padding:4px 8px;font-size:12px}.ch-btn-ghost.danger{color:#ef4444}.ch-btn-ghost.danger:hover{background-color:#ef44441a}.ch-input,.ch-select{width:100%;background-color:#121418;border:1px solid #272a30;color:#f8fafc;border-radius:6px;padding:10px 14px;font-size:14px;font-family:inherit;transition:border-color .2s}.ch-input:focus,.ch-select:focus{outline:none;border-color:#3b82f6}.ch-input::-moz-placeholder{color:#64748b}.ch-input::placeholder{color:#64748b}.full-width{width:100%}.ch-container{max-width:1560px;margin:24px auto 0;display:grid;grid-template-columns:260px 1fr 300px;gap:20px;padding:0 20px}.ch-card{background-color:#181a20;border:1px solid #272a30;border-radius:10px;margin-bottom:20px;overflow:hidden}.ch-card-header{display:flex;justify-content:space-between;align-items:center;padding:16px 16px 12px;border-bottom:1px solid #1f222a}.ch-card-title{font-size:15px;font-weight:700;color:#f8fafc;margin:0;padding:16px 16px 12px}.ch-card-header .ch-card-title{padding:0}.ch-login-form{padding:0 16px 20px;display:flex;flex-direction:column;gap:10px}.ch-login-links{display:flex;justify-content:space-between;margin-top:8px}.ch-login-links button{background:none;border:none;color:#64748b;font-size:12px;cursor:pointer}.ch-login-links button:hover{color:#cbd5e1;text-decoration:underline}.ch-profile-box{padding:20px 16px;display:flex;flex-direction:column;align-items:center;text-align:center}.ch-profile-avatar{width:64px;height:64px;border-radius:50%;background:linear-gradient(135deg,#3b82f6,#0ea5e9);margin-bottom:12px}.ch-profile-avatar.large{width:80px;height:80px;margin:0 auto 16px}.ch-profile-info{font-size:14px;color:#cbd5e1;margin-bottom:16px}.ch-profile-info strong{color:#fff;font-size:16px}.ch-profile-actions{display:flex;gap:8px;width:100%}.ch-profile-actions button{flex:1}.ch-live-dot{width:8px;height:8px;background-color:#ef4444;border-radius:50%;animation:pulse 2s infinite}@keyframes pulse{0%{box-shadow:0 0 #ef444466}70%{box-shadow:0 0 0 6px #ef444400}to{box-shadow:0 0 #ef444400}}.ch-chat-list{height:380px;overflow-y:auto;padding:12px 16px;display:flex;flex-direction:column;gap:12px;font-size:13px;line-height:1.4}.ch-chat-list::-webkit-scrollbar{width:4px}.ch-chat-list::-webkit-scrollbar-thumb{background-color:#334155;border-radius:4px}.ch-chat-item{display:flex;flex-direction:column;gap:2px}.ch-chat-nick{font-weight:700;color:#7dd3fc;cursor:pointer}.ch-chat-nick:hover{text-decoration:underline}.ch-chat-msg{color:#e2e8f0;word-break:break-word}.ch-chat-input{display:flex;flex-wrap:nowrap;align-items:center;padding:12px 16px;border-top:1px solid #1f222a;background-color:#121418;gap:8px}.ch-chat-input .ch-input{flex:1 1 auto;min-width:0;width:auto}.ch-chat-input .ch-btn-primary{flex:0 0 auto;white-space:nowrap}.ch-chart-wrap{height:500px;background-color:#020617;border-top:1px solid #1f222a}.ch-chart-wrap iframe{width:100%;height:100%;border:none}.ch-notice-ticker{display:flex;align-items:center;background-color:#181a20;border:1px solid #272a30;border-radius:8px;padding:12px 16px;margin-bottom:20px}.ch-notice-badge{background-color:#ef4444;color:#fff;font-size:11px;font-weight:700;padding:3px 6px;border-radius:4px;margin-right:12px}.ch-notice-scroll{font-size:14px;color:#e2e8f0;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ch-board-card{background-color:#181a20;border:1px solid #272a30;border-radius:10px;overflow:hidden}.ch-board-header{display:flex;justify-content:space-between;align-items:center;padding:0 16px;border-bottom:1px solid #1f222a;background-color:#1e2128}.ch-board-tabs{display:flex}.ch-board-tabs button{background:none;border:none;color:#94a3b8;padding:16px;font-size:15px;font-weight:700;cursor:pointer;border-bottom:2px solid transparent}.ch-board-tabs button.active{color:#fff;border-bottom-color:#3b82f6}.ch-board-filters{display:flex;align-items:center;padding:8px 0}.ch-board-filters .ch-select{padding:6px 10px;font-size:13px;width:120px;background-color:#121418}.ch-board-list{display:flex;flex-direction:column}.ch-post-item{display:flex;justify-content:space-between;align-items:center;padding:16px;border-bottom:1px solid #1f222a;cursor:pointer;transition:background-color .2s}.ch-post-item:hover{background-color:#1c1e24}.ch-post-item.read .ch-post-title{color:#94a3b8;font-weight:400}.ch-post-item.read .ch-post-meta,.ch-post-item.read .ch-post-category{color:#6b7280}.ch-post-item:last-child{border-bottom:none}.ch-post-info{display:flex;align-items:center;gap:8px;flex:1;min-width:0}.ch-post-category{font-size:12px;color:#a1a1aa;background-color:#272a30;padding:3px 6px;border-radius:4px;white-space:nowrap}.ch-post-title{margin:0;font-size:15px;font-weight:500;color:#e2e8f0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ch-post-comments{color:#3b82f6;font-size:13px;font-weight:700}.ch-post-meta{display:flex;align-items:center;gap:16px;font-size:13px;color:#64748b;white-space:nowrap;margin-left:20px}.ch-post-author{color:#94a3b8;width:80px;overflow:hidden;text-overflow:ellipsis;text-align:right}.ch-post-date{width:80px;text-align:right}.ch-post-views,.ch-post-likes{width:60px;text-align:right}.ch-board-footer{display:flex;justify-content:space-between;align-items:center;padding:16px;border-top:1px solid #1f222a}.ch-search-box{display:flex;flex-wrap:nowrap;align-items:center;gap:8px}.ch-search-box .ch-input{width:auto;min-width:0;flex:1 1 200px;padding:8px 12px}.ch-search-box .ch-select{width:auto;min-width:116px;flex:0 0 auto}.ch-search-box .ch-btn-secondary{padding:8px 12px;flex:0 0 auto;white-space:nowrap}.ch-pagination{display:flex;justify-content:center;align-items:center;padding:16px;gap:16px;background-color:#121418}.ch-pagination button{background:none;border:1px solid #334155;color:#cbd5e1;padding:6px 12px;border-radius:4px;cursor:pointer;transition:all .2s}.ch-pagination button:hover:not(:disabled){border-color:#4f46e5;background-color:#4f46e51a;color:#fff}.ch-pagination button:disabled{opacity:.5;cursor:not-allowed}.ch-page-info{font-size:14px;color:#94a3b8}.ch-hot-list{padding:0 16px 16px;display:flex;flex-direction:column;gap:12px}.ch-hot-item{display:flex;align-items:flex-start;gap:12px;cursor:pointer}.ch-hot-item:hover .ch-hot-title{color:#3b82f6}.ch-hot-item.read .ch-hot-title{color:#94a3b8;font-weight:400}.ch-hot-rank{font-size:16px;font-weight:800;color:#64748b;width:16px;text-align:center}.ch-hot-rank.top{color:#ef4444}.ch-hot-content{flex:1}.ch-hot-title{margin:0 0 4px;font-size:14px;color:#e2e8f0;line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;transition:color .2s}.ch-hot-meta{font-size:12px;color:#64748b}.ch-activity-summary{display:flex;border-bottom:1px solid #1f222a}.ch-activity-stat{flex:1;padding:16px;text-align:center;display:flex;flex-direction:column;gap:4px}.ch-activity-stat:first-child{border-right:1px solid #1f222a}.ch-activity-stat span{font-size:12px;color:#94a3b8}.ch-activity-stat strong{font-size:18px;color:#fff}.ch-activity-recent{padding:12px 16px;display:flex;flex-direction:column;gap:8px}.ch-activity-item{display:flex;gap:8px;align-items:center;font-size:13px;cursor:pointer}.ch-activity-item:hover .ch-activity-title{text-decoration:underline}.ch-activity-type{color:#a1a1aa;background-color:#272a30;padding:2px 4px;border-radius:4px;font-size:11px}.ch-activity-title{color:#cbd5e1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1}.ch-block-list{padding:0 16px 16px;display:flex;flex-direction:column;gap:8px}.ch-block-item{display:flex;justify-content:space-between;align-items:center;font-size:13px;color:#94a3b8;background-color:#121418;padding:8px 12px;border-radius:6px}.ch-banner{background:linear-gradient(135deg,#1e3a8a,#312e81);border-radius:10px;padding:20px;text-align:center;color:#fff}.ch-banner p{margin:0 0 4px;font-size:13px;opacity:.8}.ch-banner h3{margin:0;font-size:18px;font-weight:800}.ch-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background-color:#000000bf;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.ch-modal-content{background-color:#181a20;border:1px solid #272a30;border-radius:12px;width:100%;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 20px 25px -5px #00000080}.ch-post-modal{max-width:800px}.ch-editor-modal{max-width:700px}.ch-profile-modal{max-width:400px}.ch-modal-header{padding:20px 24px;border-bottom:1px solid #1f222a;position:relative}.ch-modal-title{margin:0;font-size:20px;font-weight:700;color:#fff;line-height:1.4}.ch-post-modal-meta{display:flex;gap:16px;margin-top:12px;font-size:13px;color:#94a3b8}.ch-post-modal-meta .author{color:#cbd5e1;font-weight:600;cursor:pointer}.ch-post-modal-meta .author:hover{text-decoration:underline}.ch-modal-close{position:absolute;top:20px;right:20px;background:none;border:none;color:#64748b;font-size:20px;cursor:pointer}.ch-modal-close:hover{color:#fff}.ch-modal-body{padding:24px;overflow-y:auto}.ch-post-body-text{font-size:16px;line-height:1.7;color:#e2e8f0;white-space:pre-wrap;min-height:150px}.ch-post-actions-center{display:flex;justify-content:center;margin:40px 0 20px}.ch-btn-like{background-color:#1e222b;border:1px solid #334155;color:#cbd5e1;padding:12px 24px;border-radius:999px;font-size:15px;font-weight:600;cursor:pointer;display:flex;align-items:center;gap:8px;transition:all .2s}.ch-btn-like:hover{background-color:#272a30}.ch-btn-like.active{background-color:#3b82f61a;border-color:#3b82f6;color:#3b82f6}.ch-post-util-actions{display:flex;justify-content:flex-end;gap:8px;padding-bottom:24px;border-bottom:1px solid #1f222a}.ch-comment-section{padding-top:24px}.ch-comment-count{margin:0 0 16px;font-size:16px;color:#fff}.ch-comment-list{display:flex;flex-direction:column;gap:16px;margin-bottom:24px}.ch-comment-item{background-color:#121418;border-radius:8px;padding:16px}.ch-comment-header{display:flex;justify-content:space-between;margin-bottom:8px;font-size:13px}.ch-comment-header .author{font-weight:700;color:#e2e8f0;cursor:pointer}.ch-comment-header .date{color:#64748b}.ch-comment-body{font-size:14px;color:#cbd5e1;line-height:1.5;margin-bottom:12px}.ch-comment-actions{display:flex;justify-content:flex-end}.ch-comment-form{display:flex;flex-direction:column;gap:12px;background-color:#121418;border:1px solid #272a30;border-radius:8px;padding:12px}.ch-comment-form textarea{border:none;background:transparent;resize:none;padding:0}.ch-editor-toolbar{display:flex;gap:6px;flex-wrap:wrap}.editor-rich{min-height:280px;line-height:1.6;background:#121418}.editor-rich:empty:before{content:attr(data-placeholder);color:#64748b}.ch-upload-status{font-size:12px;color:#94a3b8}.ch-upload-list{display:flex;gap:6px;flex-wrap:wrap;margin-top:6px}.ch-attachments{margin-top:16px;padding:12px;border:1px solid #272a30;border-radius:8px;display:flex;flex-direction:column;gap:8px}.ch-attachments h5{margin:0;color:#e2e8f0}.ch-attachments a{color:#7dd3fc;text-decoration:underline;word-break:break-all}.ch-attachment-row{color:#cbd5e1;font-size:13px;line-height:1.6;border:1px solid #2b313c;border-radius:6px;padding:8px 10px;background:#141922}.ch-comment-form textarea:focus{border:none}.ch-comment-form-footer{display:flex;justify-content:flex-end}.ch-editor-form{display:flex;flex-direction:column;gap:16px}.ch-editor-form .editor-textarea{min-height:300px;resize:vertical}.ch-modal-footer{display:flex;justify-content:flex-end;gap:12px;padding:16px 24px;border-top:1px solid #1f222a;background-color:#1e2128}.ch-profile-body{display:flex;flex-direction:column;align-items:center;text-align:center}.ch-profile-nickname{margin:0 0 4px;font-size:20px;color:#fff}.ch-profile-username{margin:0 0 24px;font-size:14px;color:#64748b}.ch-profile-stats{display:flex;width:100%;border:1px solid #272a30;border-radius:8px;background-color:#121418}.ch-profile-stats .stat-box{flex:1;padding:16px;display:flex;flex-direction:column;gap:6px}.ch-profile-stats .stat-box:not(:last-child){border-right:1px solid #272a30}.ch-profile-stats .stat-box span{font-size:13px;color:#94a3b8}.ch-profile-stats .stat-box strong{font-size:18px;color:#fff}.ch-empty{padding:40px 20px;text-align:center;color:#64748b;font-size:14px;border:1px dashed #272a30;border-radius:8px;margin:20px 16px}.ch-empty.mini{padding:20px;margin:0}@media (max-width: 1024px){.ch-container{grid-template-columns:1fr}.ch-left,.ch-right{display:none}.ch-container,.ch-left,.ch-right{display:flex;flex-direction:column}}.App{width:100%;height:100vh}
