/* ── Reset & variables ──────────────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

:root {
  --bg:          #0d1117;
  --surface:     #161b22;
  --surface-2:   #1c2128;
  --border:      #30363d;
  --text:        #e6edf3;
  --text-muted:  #8b949e;
  --text-dim:    #6e7681;

  /* Status colours */
  --armed:     #1f6feb;
  --triggered: #d29922;
  --taken:     #238636;
  --skipped:   #6e7681;
  --disabled:  #30363d;

  /* Signal colours */
  --rs-pos:  #3fb950;
  --rs-neg:  #f85149;
  --urgent:  #f85149;
  --warn:    #e3b341;
  --ok:      #3fb950;

  --radius: 10px;
  --font: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
}

html, body { height: 100%; background: var(--bg); color: var(--text); font-family: var(--font); font-size: 15px; }

/* ── Utility ────────────────────────────────────────────────────────────────── */
.hidden { display: none !important; }

/* ── Screens ────────────────────────────────────────────────────────────────── */
.screen { min-height: 100dvh; }

/* ── Login ──────────────────────────────────────────────────────────────────── */
#login-screen {
  display: flex; align-items: center; justify-content: center;
  min-height: 100dvh; background: var(--bg);
}
.login-card {
  background: var(--surface); border: 1px solid var(--border);
  border-radius: var(--radius); padding: 2rem; width: 320px;
  display: flex; flex-direction: column; gap: 1rem; text-align: center;
}
.login-logo { font-size: 2.5rem; }
.login-card h1 { font-size: 1.4rem; font-weight: 600; }
.login-card input {
  background: var(--bg); border: 1px solid var(--border);
  border-radius: 6px; padding: .75rem 1rem; color: var(--text);
  font-size: 1rem; width: 100%; text-align: center;
}
.login-card input:focus { outline: none; border-color: var(--armed); }
.login-card button {
  background: var(--armed); color: #fff; border: none;
  border-radius: 6px; padding: .75rem; font-size: 1rem;
  cursor: pointer; font-weight: 600;
}
.login-card button:active { opacity: .8; }
.login-error { color: var(--urgent); font-size: .85rem; }

/* ── Header ─────────────────────────────────────────────────────────────────── */
header {
  position: sticky; top: 0; z-index: 10;
  background: var(--surface); border-bottom: 1px solid var(--border);
  padding: .75rem 1rem .5rem;
}
.header-row {
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: .5rem;
}
.app-title { font-size: 1.1rem; font-weight: 700; }
.header-actions { display: flex; gap: .4rem; }
.icon-btn {
  background: var(--surface-2); border: 1px solid var(--border);
  border-radius: 6px; padding: .35rem .65rem; color: var(--text);
  font-size: 1.1rem; cursor: pointer; line-height: 1;
}
.icon-btn:active { opacity: .7; }

/* Summary chips */
.summary-chips {
  display: flex; gap: .5rem; flex-wrap: wrap; margin-bottom: .5rem;
}
.chip {
  font-size: .75rem; font-weight: 600; padding: .2rem .55rem;
  border-radius: 20px; border: 1px solid transparent;
}
.chip-armed    { background: rgba(31,111,235,.15); color: #58a6ff; border-color: rgba(31,111,235,.3); }
.chip-trigger  { background: rgba(210,153,34,.15);  color: #e3b341; border-color: rgba(210,153,34,.3); }
.chip-taken    { background: rgba(35,134,54,.15);   color: #3fb950; border-color: rgba(35,134,54,.3); }
.chip-warn     { background: rgba(248,81,73,.15);   color: #f85149; border-color: rgba(248,81,73,.3); }
.chip-watching { background: rgba(110,118,129,.15); color: #8b949e; border-color: rgba(110,118,129,.3); }

/* Filter tabs */
.filter-bar { display: flex; gap: .35rem; overflow-x: auto; padding-bottom: 2px; }
.filter-bar::-webkit-scrollbar { display: none; }
.tab {
  background: transparent; border: 1px solid var(--border);
  border-radius: 20px; padding: .3rem .8rem; color: var(--text-muted);
  font-size: .8rem; cursor: pointer; white-space: nowrap; flex-shrink: 0;
}
.tab.active { background: var(--surface-2); color: var(--text); border-color: #58a6ff; }
.tab:active { opacity: .7; }

/* ── Search ─────────────────────────────────────────────────────────────────── */
.search-bar { margin-top: .5rem; }
.search-bar input {
  width: 100%; background: var(--bg); border: 1px solid var(--border);
  border-radius: 8px; padding: .5rem .75rem; color: var(--text);
  font-size: .9rem; outline: none;
}
.search-bar input:focus { border-color: #58a6ff; }
.search-bar input::placeholder { color: var(--text-dim); }
/* hide native clear button; we rely on the browser's built-in × for type=search */

/* ── Cards ──────────────────────────────────────────────────────────────────── */
main { padding: .75rem; display: flex; flex-direction: column; gap: .6rem; }

.empty-state { text-align: center; color: var(--text-muted); padding: 3rem 1rem; }

.card {
  background: var(--surface); border: 1px solid var(--border);
  border-radius: var(--radius); padding: .85rem 1rem;
  cursor: pointer; transition: border-color .15s;
  border-left: 3px solid transparent;
}
.card:active { opacity: .85; }
.card[data-status="armed"]     { border-left-color: var(--armed); }
.card[data-status="triggered"] { border-left-color: var(--triggered); }
.card[data-status="taken"]     { border-left-color: var(--taken); }
.card[data-status="skipped"]   { border-left-color: var(--skipped); }
.card[data-status="disabled"]  { border-left-color: var(--disabled); opacity: .6; }

/* Card top row */
.card-top {
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: .45rem;
}
.card-left   { display: flex; align-items: baseline; gap: .5rem; }
.card-ticker { font-size: 1.05rem; font-weight: 700; letter-spacing: .5px; }
.card-price  { font-size: .9rem; color: var(--text-muted); font-weight: 500; }
.card-right  { display: flex; align-items: center; gap: .5rem; }

/* Status badge */
.status-badge {
  font-size: .7rem; font-weight: 700; padding: .15rem .45rem;
  border-radius: 4px; text-transform: uppercase; letter-spacing: .5px;
}
.badge-armed     { background: rgba(31,111,235,.2);  color: #58a6ff; }
.badge-triggered { background: rgba(210,153,34,.2);  color: #e3b341; }
.badge-taken     { background: rgba(35,134,54,.2);   color: #3fb950; }
.badge-skipped   { background: rgba(110,118,129,.2); color: #8b949e; }
.badge-disabled  { background: rgba(48,54,61,.4);    color: #6e7681; }

/* % to trigger */
.pct-badge {
  font-size: .85rem; font-weight: 700; padding: .1rem .4rem;
  border-radius: 4px;
}
.pct-urgent { color: var(--urgent);  background: rgba(248,81,73,.12); }
.pct-warn   { color: var(--warn);    background: rgba(227,179,65,.12); }
.pct-ok     { color: var(--text-muted); }

/* Card meta row */
.card-meta {
  display: flex; flex-wrap: wrap; gap: .3rem .8rem;
  font-size: .82rem; color: var(--text-muted); margin-bottom: .4rem;
}
.card-meta strong { color: var(--text); }
.rs-pos { color: var(--rs-pos); }
.rs-neg { color: var(--rs-neg); }
.fib-tag { color: #a371f7; }

/* Thesis */
.card-thesis {
  font-size: .8rem; color: var(--text-dim);
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
  margin-bottom: .5rem;
}

/* Card actions */
.card-actions { display: flex; gap: .5rem; }
.action-btn {
  flex: 1; padding: .45rem .5rem; border: 1px solid var(--border);
  border-radius: 6px; background: var(--surface-2); color: var(--text);
  font-size: .8rem; cursor: pointer; font-weight: 600; text-align: center;
}
.action-btn:active { opacity: .7; }
.action-btn.take  { border-color: rgba(35,134,54,.4);  color: #3fb950; }
.action-btn.skip  { border-color: rgba(248,81,73,.3);  color: #f85149; }
.action-btn.rearm { border-color: rgba(31,111,235,.3); color: #58a6ff; }
.action-btn.chart { border-color: var(--border); color: var(--text-muted); }

/* Stage badge */
.stage-badge { font-size: .72rem; font-weight: 700; padding: .1rem .38rem; border-radius: 4px; }
.stage-2  { background: rgba(31,111,235,.2);  color: #58a6ff; }
.stage-2p { background: rgba(227,179,65,.15); color: #e3b341; }
.stage-t  { background: rgba(110,118,129,.15);color: #8b949e; }
.stage-4  { background: rgba(248,81,73,.15);  color: #f85149; }

/* Volume badge */
.vol-badge  { font-size: .72rem; font-weight: 600; padding: .1rem .38rem; border-radius: 4px; }
.vol-low    { background: rgba(63,185,80,.15); color: #3fb950; }
.vol-high   { background: rgba(227,179,65,.15);color: #e3b341; }

/* Earnings badge */
.earn-badge  { font-size: .72rem; font-weight: 700; padding: .1rem .38rem; border-radius: 4px; }
.earn-urgent { background: rgba(248,81,73,.2); color: #f85149; }
.earn-warn   { background: rgba(227,179,65,.2);color: #e3b341; }
.earn-ok     { background: rgba(31,111,235,.15);color: #58a6ff; }

/* TradingEdge badge */
.mn-badge { font-size: .72rem; font-weight: 700; padding: .1rem .38rem; border-radius: 4px;
            background: rgba(163,113,247,.2); color: #a371f7; cursor: default; }

/* Price ladder */
.price-ladder { display: flex; flex-direction: column; gap: 2px; margin: .25rem 0; }
.ladder-row {
  display: flex; align-items: center; gap: .6rem;
  padding: .35rem .6rem; border-radius: 6px; font-size: .85rem;
}
.ladder-price { font-weight: 700; min-width: 80px; text-align: right; font-variant-numeric: tabular-nums; }
.ladder-label { color: var(--text-muted); flex: 1; }
.ladder-tag   { font-size: .65rem; font-weight: 800; letter-spacing: .5px; padding: .1rem .35rem;
                border-radius: 3px; }
.ladder-res        { background: rgba(248,81,73,.08); }
.ladder-res .ladder-price { color: #f85149; }
.ladder-target     { background: rgba(248,81,73,.14); }
.ladder-target .ladder-tag { background: rgba(248,81,73,.3); color: #f85149; }
.ladder-sup        { background: rgba(63,185,80,.08); }
.ladder-sup .ladder-price  { color: #3fb950; }
.ladder-entry      { background: rgba(31,111,235,.12); }
.ladder-entry.ladder-sup .ladder-price { color: #3fb950; }
.ladder-entry .ladder-tag  { background: rgba(31,111,235,.3); color: #58a6ff; }
.ladder-stop       { background: rgba(248,81,73,.05); }
.ladder-stop .ladder-price { color: #f85149; opacity: .7; }
.ladder-stop .ladder-tag   { background: rgba(248,81,73,.2); color: #f85149; }
.ladder-current    { background: var(--surface-2); border: 1px solid var(--border); }
.ladder-current .ladder-price { color: var(--text); }
.ladder-current .ladder-label { color: var(--text-dim); font-style: italic; }
/* User-set custom levels — amber/orange to distinguish from algo S/R */
.ladder-custom-r { background: rgba(227,113,31,.1); border-left: 2px solid #e37a1f; }
.ladder-custom-r .ladder-price { color: #e3a01f; }
.ladder-custom-r .ladder-tag   { background: rgba(227,113,31,.25); color: #e3a01f; }
.ladder-custom-s { background: rgba(227,179,31,.1); border-left: 2px solid #c8a31f; }
.ladder-custom-s .ladder-price { color: #c8a31f; }
.ladder-custom-s .ladder-tag   { background: rgba(227,179,31,.25); color: #c8a31f; }

/* My Levels form */
.my-levels-hint   { font-size: .72rem; font-weight: 400; color: var(--text-dim); margin-left: .4rem; }
.my-levels-form   { display: flex; flex-direction: column; gap: .6rem; }
.my-levels-row    { display: flex; align-items: center; gap: .75rem; }
.my-levels-label  { font-size: .8rem; font-weight: 600; min-width: 105px; }
.my-levels-input  {
  flex: 1; background: var(--bg); border: 1px solid var(--border);
  border-radius: 6px; padding: .45rem .7rem; color: var(--text);
  font-size: .9rem; font-variant-numeric: tabular-nums;
}
.my-levels-input:focus { outline: none; border-color: #e3a01f; }
.my-levels-actions { display: flex; gap: .6rem; }
.my-levels-save {
  flex: 1; background: rgba(227,160,31,.15); border: 1px solid rgba(227,160,31,.4);
  border-radius: 6px; color: #e3a01f; font-size: .85rem; font-weight: 600;
  padding: .55rem; cursor: pointer;
}
.my-levels-save:active { opacity: .8; }
.my-levels-clear {
  background: var(--surface-2); border: 1px solid var(--border);
  border-radius: 6px; color: var(--text-muted); font-size: .85rem;
  padding: .55rem .9rem; cursor: pointer;
}
.my-levels-note { font-size: .72rem; color: var(--text-dim); text-align: center; }

/* Score badge */
.score-badge {
  font-size: .75rem; font-weight: 700; padding: .1rem .4rem;
  border-radius: 4px; letter-spacing: .3px;
}
.score-exceptional { background: rgba(227,179,65,.2);  color: #e3b341; border: 1px solid rgba(227,179,65,.4); }
.score-strong      { background: rgba(63,185,80,.15);  color: #3fb950; border: 1px solid rgba(63,185,80,.3); }
.score-ok          { background: rgba(88,166,255,.1);  color: #58a6ff; border: 1px solid rgba(88,166,255,.2); }
.score-weak        { background: rgba(110,118,129,.1); color: #6e7681; border: 1px solid rgba(110,118,129,.2); }

/* S&R zone row on card */
.card-sr    { display: flex; gap: .75rem; align-items: center; margin-top: .3rem; font-size: .78rem; font-weight: 600; }
.sr-sup     { color: #3fb950; }
.sr-res     { color: #f85149; }
.sr-adaptive { font-size: .68rem; font-weight: 700; background: rgba(163,113,247,.2);
               color: #a371f7; border-radius: 4px; padding: .1rem .35rem; }
/* Modal S&R section title labels */
.sr-adaptive-label { font-size: .7rem; font-weight: 400; color: #a371f7; margin-left: .5rem; }
.sr-window-label   { font-size: .7rem; font-weight: 400; color: var(--text-dim);  margin-left: .5rem; }

/* S&R values in modal */
.sr-sup-val { color: #3fb950; }
.sr-res-val { color: #f85149; }
.sr-sup-val small, .sr-res-val small { font-weight: 400; color: var(--text-muted); font-size: .75em; }

/* T212 tag */
.t212-tag {
  font-size: .72rem; background: rgba(163,113,247,.15);
  color: #a371f7; border-radius: 4px; padding: .1rem .4rem;
  margin-top: .3rem; display: inline-block;
}

/* ── Chart modal ─────────────────────────────────────────────────────────────── */
.modal {
  position: fixed; inset: 0; background: var(--bg);
  z-index: 100; display: flex; flex-direction: column; overflow-y: auto;
}

.modal-header {
  display: flex; align-items: center; gap: .75rem;
  padding: .75rem 1rem; background: var(--surface);
  border-bottom: 1px solid var(--border);
  position: sticky; top: 0; z-index: 10; flex-shrink: 0;
}
.back-btn {
  background: none; border: none; color: #58a6ff;
  font-size: .95rem; cursor: pointer; padding: .2rem 0;
}
.modal-title { font-size: 1.1rem; font-weight: 700; flex: 1; }

/* TradingView chart wrapper */
#tv-chart-wrap {
  width: 100%; flex-shrink: 0;
  height: 55dvh;
  min-height: 300px;
  max-height: 500px;
  background: #131722;
}
#tv-chart { width: 100%; height: 100%; }

/* Modal detail panel */
.modal-detail {
  padding: 1rem; display: grid; gap: .75rem;
}
.detail-grid {
  display: grid; grid-template-columns: 1fr 1fr;
  gap: .5rem;
}
.detail-item { display: flex; flex-direction: column; gap: .15rem; }
.detail-label { font-size: .7rem; color: var(--text-muted); text-transform: uppercase; letter-spacing: .5px; }
.detail-value { font-size: 1rem; font-weight: 600; }
.detail-value.positive { color: var(--rs-pos); }
.detail-value.negative { color: var(--rs-neg); }
.detail-value.highlight { color: #a371f7; }

.detail-section { border-top: 1px solid var(--border); padding-top: .75rem; }
.detail-section-title { font-size: .72rem; color: var(--text-muted); text-transform: uppercase; letter-spacing: .5px; margin-bottom: .5rem; }
.thesis-text { font-size: .88rem; color: var(--text-muted); line-height: 1.5; }

/* Modal action buttons */
.modal-actions {
  display: flex; gap: .6rem; padding: 1rem;
  border-top: 1px solid var(--border);
  position: sticky; bottom: 0; background: var(--bg);
}
.modal-actions .action-btn { padding: .65rem .5rem; font-size: .9rem; }

/* ── Toast ──────────────────────────────────────────────────────────────────── */
.toast {
  position: fixed; bottom: 5rem; left: 50%; transform: translateX(-50%);
  background: var(--surface-2); border: 1px solid var(--border);
  border-radius: 8px; padding: .6rem 1.2rem; font-size: .9rem;
  z-index: 200; white-space: nowrap; pointer-events: none;
  transition: opacity .3s;
}
.toast.success { border-color: rgba(35,134,54,.5); color: #3fb950; }
.toast.error   { border-color: rgba(248,81,73,.5); color: #f85149; }

/* ── Desktop layout (tablet+) ───────────────────────────────────────────────── */
@media (min-width: 700px) {
  main { max-width: 800px; margin: 0 auto; padding: 1rem; }
  #tv-chart-wrap { height: 60dvh; max-height: 600px; }
  .modal-detail { max-width: 800px; margin: 0 auto; }
  .modal-actions { max-width: 800px; margin: 0 auto; }
  .detail-grid { grid-template-columns: repeat(4, 1fr); }
}

/* ── Form modals (add ticker, change password) ───────────────────────────────── */
.form-modal-body {
  padding: 1.25rem 1rem;
  display: flex; flex-direction: column; gap: 1.1rem;
  max-width: 480px; margin: 0 auto;
}
.form-group { display: flex; flex-direction: column; gap: .35rem; }
.form-row   { display: grid; grid-template-columns: 1fr 1fr; gap: .75rem; }
.form-label { font-size: .75rem; color: var(--text-muted); text-transform: uppercase; letter-spacing: .5px; font-weight: 600; }
.form-hint  { font-weight: 400; text-transform: none; letter-spacing: 0; color: #555; }
.form-input, .form-select, .form-textarea {
  background: var(--surface-2); border: 1px solid var(--border);
  border-radius: 8px; padding: .7rem .85rem; color: var(--text);
  font-size: .95rem; font-family: inherit; width: 100%; box-sizing: border-box;
}
.form-input-large { font-size: 1.2rem; font-weight: 600; letter-spacing: .5px; }
.form-input:focus, .form-select:focus, .form-textarea:focus {
  outline: none; border-color: #58a6ff;
}
.form-textarea { resize: vertical; min-height: 72px; }
.form-select   { cursor: pointer; }
.form-submit {
  background: #238636; border: none; border-radius: 8px;
  padding: .8rem 1rem; color: #fff; font-size: 1rem; font-weight: 600;
  cursor: pointer; width: 100%; margin-top: .25rem;
}
.form-submit:active { opacity: .8; }
.form-footnote { font-size: .75rem; color: var(--text-muted); text-align: center; margin: 0; }
