/* === BUTTONS === */
.btn{display:inline-flex;align-items:center;gap:6px;padding:8px 18px;border-radius:var(--radius);border:none;font-family:var(--font-mono);font-size:11px;font-weight:700;letter-spacing:.5px;text-transform:uppercase;transition:all .15s;white-space:nowrap}
.btn-sm{padding:5px 12px;font-size:10px}
.btn-lg{padding:11px 24px;font-size:12px}
.btn-primary{background:var(--accent);color:#000}
.btn-primary:hover{background:#00ffc0;transform:translateY(-1px);box-shadow:0 4px 16px rgba(0,229,160,.3)}
.btn-primary:active{transform:translateY(0)}
.btn-primary:disabled{opacity:.4;cursor:not-allowed;transform:none;box-shadow:none}
.btn-danger{background:var(--red);color:#fff}
.btn-danger:hover{background:#ff6078;transform:translateY(-1px)}
.btn-ghost{background:transparent;border:1px solid var(--border2);color:var(--muted)}
.btn-ghost:hover{border-color:var(--accent);color:var(--accent)}
.btn-secondary{background:var(--surface2);border:1px solid var(--border2);color:var(--text2)}
.btn-secondary:hover{border-color:var(--border2);background:var(--surface3);color:var(--text)}
.btn-icon{padding:7px;border-radius:var(--radius);background:transparent;border:1px solid var(--border);color:var(--muted)}
.btn-icon:hover{border-color:var(--accent);color:var(--accent)}

/* === CARDS === */
.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius2);padding:16px}
.card-sm{padding:12px}
.card-hover{cursor:pointer;transition:all .15s}
.card-hover:hover{border-color:var(--accent);transform:translateY(-2px);box-shadow:var(--shadow-accent)}
.card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}
.card-title{font-family:var(--font-display);font-size:12px;font-weight:700;color:var(--text2);letter-spacing:.5px;text-transform:uppercase}

/* === STAT CARDS === */
.stat-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:12px;margin-bottom:20px}
.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius2);padding:14px 16px;position:relative;overflow:hidden}
.stat-card::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:var(--border)}
.stat-card.accent::before{background:var(--accent)}
.stat-card.red::before{background:var(--red)}
.stat-card.blue::before{background:var(--accent2)}
.stat-card.yellow::before{background:var(--yellow)}
.stat-label{font-size:9px;color:var(--muted);text-transform:uppercase;letter-spacing:1.2px;margin-bottom:6px}
.stat-val{font-family:var(--font-display);font-size:22px;font-weight:800;letter-spacing:-1px}
.stat-sub{font-size:9px;color:var(--muted);margin-top:3px}

/* === BADGES / PILLS === */
.badge{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:20px;font-size:9px;font-weight:700;letter-spacing:.5px;text-transform:uppercase}
.badge-green{background:rgba(0,229,160,.12);color:var(--green);border:1px solid rgba(0,229,160,.2)}
.badge-red{background:rgba(255,61,90,.12);color:var(--red);border:1px solid rgba(255,61,90,.2)}
.badge-yellow{background:rgba(245,197,66,.12);color:var(--yellow);border:1px solid rgba(245,197,66,.2)}
.badge-blue{background:rgba(0,117,255,.12);color:var(--accent2);border:1px solid rgba(0,117,255,.2)}
.badge-purple{background:rgba(124,58,237,.12);color:#a78bfa;border:1px solid rgba(124,58,237,.2)}
.badge-gray{background:rgba(107,114,128,.12);color:var(--muted);border:1px solid var(--border)}

/* === TABLES === */
.table-wrap{overflow:auto;border-radius:var(--radius2);border:1px solid var(--border)}
table{width:100%;border-collapse:collapse;font-size:11px}
thead th{padding:9px 14px;text-align:left;color:var(--muted);font-weight:400;font-size:9px;letter-spacing:1px;text-transform:uppercase;background:var(--surface2);border-bottom:1px solid var(--border);white-space:nowrap;cursor:pointer;user-select:none}
thead th:hover{color:var(--accent)}
thead th.sorted{color:var(--accent);font-weight:700}
tbody td{padding:9px 14px;border-bottom:1px solid var(--border);color:var(--text2);vertical-align:middle}
tbody tr:last-child td{border-bottom:none}
tbody tr:hover td{background:var(--surface2);color:var(--text)}
.td-sym{font-family:var(--font-display);font-weight:700;color:var(--text);font-size:12px}
.td-price{font-family:var(--font-display);font-weight:700;font-size:12px}
.td-action{display:flex;gap:6px;align-items:center}

/* === STRENGTH METER === */
.strength-meter{height:4px;background:var(--border);border-radius:4px;overflow:hidden}
.strength-fill{height:100%;border-radius:4px;transition:width .4s ease}
.strength-text{font-size:10px;font-weight:700;margin-top:3px}

/* === FORM ELEMENTS === */
.form-group{margin-bottom:14px}
.form-label{font-size:10px;color:var(--muted);text-transform:uppercase;letter-spacing:.8px;margin-bottom:5px;display:block}
.form-input{width:100%;background:var(--bg);border:1px solid var(--border2);border-radius:var(--radius);padding:8px 12px;font-size:12px;color:var(--text)}
.form-input:focus{border-color:var(--accent)}
.form-select{width:100%;background:var(--bg);border:1px solid var(--border2);border-radius:var(--radius);padding:8px 12px;font-size:12px;color:var(--text)}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.form-row-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:12px}

/* === TABS === */
.tabs{display:flex;gap:2px;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);padding:3px}
.tab{flex:1;padding:6px 12px;border-radius:4px;font-size:10px;font-family:var(--font-mono);cursor:pointer;color:var(--muted);transition:all .15s;text-align:center;letter-spacing:.3px;border:none;background:transparent}
.tab.active{background:var(--surface2);color:var(--text);font-weight:700}
.tab.active.tab-green{background:rgba(0,229,160,.15);color:var(--green)}
.tab.active.tab-red{background:rgba(255,61,90,.15);color:var(--red)}

/* === PILL TABS === */
.pill-tabs{display:flex;gap:6px;flex-wrap:wrap}
.pill-tab{padding:5px 14px;border-radius:20px;font-size:10px;border:1px solid var(--border2);color:var(--muted);cursor:pointer;transition:all .15s;background:transparent}
.pill-tab.active,.pill-tab:hover{background:var(--accent);color:#000;border-color:var(--accent);font-weight:700}

/* === SEARCH BOX === */
.search-wrap{position:relative}
.search-wrap .search-icon{position:absolute;left:10px;top:50%;transform:translateY(-50%);color:var(--muted);font-size:12px;pointer-events:none}
.search-box{padding-left:30px !important}

/* === MODALS === */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.7);z-index:900;backdrop-filter:blur(3px)}
.modal-box{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);z-index:901;background:var(--surface);border:1px solid var(--border2);border-radius:var(--radius2);padding:24px;min-width:380px;max-width:560px;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow)}
.modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}
.modal-title{font-family:var(--font-display);font-size:16px;font-weight:800}
.modal-close{background:none;border:none;color:var(--muted);font-size:18px;cursor:pointer;padding:4px}
.modal-close:hover{color:var(--text)}
.modal-footer{display:flex;gap:8px;justify-content:flex-end;margin-top:20px;padding-top:16px;border-top:1px solid var(--border)}

/* === TOGGLE SWITCH === */
.toggle-wrap{display:flex;align-items:center;gap:10px;cursor:pointer}
.toggle{width:36px;height:20px;background:var(--border2);border-radius:20px;position:relative;transition:background .2s;flex-shrink:0}
.toggle.on{background:var(--accent)}
.toggle::after{content:'';position:absolute;width:14px;height:14px;background:#fff;border-radius:50%;top:3px;left:3px;transition:transform .2s}
.toggle.on::after{transform:translateX(16px)}
.toggle-label{font-size:11px;color:var(--text2)}

/* === PROGRESS BAR === */
.progress-bar{height:6px;background:var(--border);border-radius:6px;overflow:hidden}
.progress-fill{height:100%;border-radius:6px;transition:width .4s ease;background:var(--accent)}

/* === SPARKLINE SVG === */
.sparkline{display:block;flex-shrink:0}

/* === EMPTY / LOADING === */
.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;padding:60px 24px;color:var(--muted);text-align:center}
.empty-icon{font-size:48px;opacity:.25}
.empty-title{font-family:var(--font-display);font-size:16px;font-weight:700;color:var(--muted)}
.empty-sub{font-size:11px;color:var(--muted2);max-width:280px;line-height:1.7}
.spinner{width:20px;height:20px;border:2px solid var(--border2);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite}
.loading-state{display:flex;align-items:center;justify-content:center;padding:40px;gap:12px;color:var(--muted);font-size:12px}

/* === LOADING BAR === */
.loading-bar{position:fixed;top:0;left:0;height:2px;background:var(--accent);box-shadow:0 0 8px var(--accent);transition:width .3s;z-index:999}

/* === TOAST === */
.toast{position:fixed;bottom:24px;right:24px;z-index:999;background:var(--surface2);border:1px solid var(--border2);border-radius:var(--radius2);padding:12px 18px;font-size:11px;display:flex;align-items:center;gap:10px;transform:translateY(80px);opacity:0;transition:all .3s;max-width:340px;box-shadow:var(--shadow)}
.toast.show{transform:translateY(0);opacity:1}
.toast.success{border-color:rgba(0,229,160,.3)}
.toast.error{border-color:rgba(255,61,90,.3)}

/* === SECTION HEADER === */
.section-hdr{display:flex;align-items:center;gap:12px;margin-bottom:16px}
.section-title{font-family:var(--font-display);font-size:13px;font-weight:800;letter-spacing:-.2px}
.section-line{flex:1;height:1px;background:var(--border)}
.section-count{font-size:10px;color:var(--muted);background:var(--surface2);border:1px solid var(--border);padding:2px 8px;border-radius:10px}

/* === COLOR DOT === */
.color-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}

/* === MARKET CARD (overview grid) === */
.market-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius2);padding:14px 16px;cursor:pointer;transition:all .15s;position:relative;overflow:hidden}
.market-card:hover{border-color:var(--accent);transform:translateY(-2px);box-shadow:var(--shadow-accent)}
.market-card::after{content:'';position:absolute;bottom:0;left:0;right:0;height:2px;background:var(--border)}
.market-card.up-card::after{background:var(--green)}
.market-card.down-card::after{background:var(--red)}
.mc-sym{font-family:var(--font-display);font-size:13px;font-weight:800}
.mc-price{font-family:var(--font-display);font-size:17px;font-weight:700;margin-top:5px}
.mc-chg{font-size:10px;margin-top:2px;font-weight:700}
.mc-spark{position:absolute;bottom:10px;right:12px;opacity:.35}

/* === TICKER === */
.ticker-bar{background:var(--surface);border-bottom:1px solid var(--border);height:34px;overflow:hidden;display:flex;align-items:center}
.ticker-inner{display:flex;white-space:nowrap;animation:ticker 50s linear infinite}
.ticker-inner:hover{animation-play-state:paused}
.ticker-item{padding:0 18px;font-size:10px;border-right:1px solid var(--border);display:flex;align-items:center;gap:7px;height:34px;flex-shrink:0}
.ticker-sym{font-family:var(--font-display);font-weight:700;font-size:10px}

/* === PATTERN BADGE === */
.pattern-status{display:inline-flex;align-items:center;gap:4px;padding:3px 9px;border-radius:4px;font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.5px}
.status-pending{background:rgba(245,197,66,.12);color:var(--yellow);border:1px solid rgba(245,197,66,.2)}
.status-valid{background:rgba(0,229,160,.12);color:var(--green);border:1px solid rgba(0,229,160,.2)}
.status-invalidated{background:rgba(255,61,90,.12);color:var(--red);border:1px solid rgba(255,61,90,.2)}

/* === CANDLESTICK CHART === */
.chart-container{position:relative;width:100%}
canvas{display:block;width:100%}

/* === RESPONSIVE === */
@media(max-width:900px){
  .form-row-3{grid-template-columns:1fr 1fr}
  .stat-cards{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:640px){
  .form-row,.form-row-3{grid-template-columns:1fr}
  .stat-cards{grid-template-columns:1fr 1fr}
  .modal-box{min-width:unset;width:calc(100vw - 32px)}
}
