/* ===== Tradomatic console — teal theme, animated, responsive ===== */
:root {
  --bg: #06181a;
  --bg-2: #041012;
  --surface: #0c2529;
  --surface-2: #0f2e33;
  --border: #164a4f;
  --border-glow: #1f6b70;
  --teal: #2dd4bf;
  --teal-bright: #5eead4;
  --teal-dim: #14b8a6;
  --text: #dff5f1;
  --muted: #7fa8a4;
  --pos: #34d399;
  --neg: #fb7185;
  --warn: #fbbf24;
  --radius: 18px;
  --shadow: 0 10px 40px rgba(0,0,0,.45);
}
* { box-sizing: border-box; margin: 0; }
html { -webkit-text-size-adjust: 100%; }
body {
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Inter, Roboto, sans-serif;
  color: var(--text);
  background:
    radial-gradient(1200px 600px at 80% -10%, rgba(45,212,191,.10), transparent 60%),
    radial-gradient(900px 500px at 0% 10%, rgba(20,184,166,.08), transparent 55%),
    linear-gradient(160deg, var(--bg) 0%, var(--bg-2) 100%);
  min-height: 100vh;
  -webkit-font-smoothing: antialiased;
}
.hidden { display: none !important; }
.muted { color: var(--muted); font-size: .8rem; }

/* ===== Login ===== */
.login-wrap { min-height: 100vh; display: grid; place-items: center; padding: 24px; }
.login-card {
  width: min(380px, 100%); background: rgba(12,37,41,.85); backdrop-filter: blur(12px);
  border: 1px solid var(--border); border-radius: var(--radius); padding: 34px 30px;
  box-shadow: var(--shadow); display: flex; flex-direction: column; gap: 14px;
  animation: pop .5s cubic-bezier(.2,.9,.3,1.2);
}
.login-sub { color: var(--muted); font-size: .85rem; margin-top: -6px; margin-bottom: 6px; }
.login-card label { display: flex; flex-direction: column; gap: 6px; font-size: .78rem; color: var(--muted); }
.login-card input {
  background: var(--bg-2); border: 1px solid var(--border); color: var(--text);
  padding: 12px 14px; border-radius: 12px; font-size: .95rem; transition: border-color .2s, box-shadow .2s;
}
.login-card input:focus { outline: none; border-color: var(--teal); box-shadow: 0 0 0 3px rgba(45,212,191,.18); }
.login-card button, #login-btn {
  margin-top: 6px; padding: 13px; border: none; border-radius: 12px; cursor: pointer;
  font-weight: 600; font-size: .95rem; color: #04191a;
  background: linear-gradient(135deg, var(--teal-bright), var(--teal-dim));
  transition: transform .12s, box-shadow .2s;
}
.login-card button:hover { transform: translateY(-1px); box-shadow: 0 8px 22px rgba(45,212,191,.35); }
.login-card button:active { transform: translateY(0); }
.login-error { color: var(--neg); font-size: .82rem; min-height: 1em; text-align: center; }

/* ===== Brand ===== */
.brand { display: flex; align-items: center; gap: 10px; font-weight: 700; }
.brand-mark {
  color: var(--teal-bright); font-size: 1.4rem;
  filter: drop-shadow(0 0 8px rgba(94,234,212,.6)); animation: spin 8s linear infinite;
}
.brand-name { letter-spacing: .3px; font-size: 1.15rem;
  background: linear-gradient(90deg, var(--teal-bright), var(--teal)); -webkit-background-clip: text;
  background-clip: text; color: transparent; }

/* ===== App shell ===== */
.app { max-width: 1440px; margin: 0 auto; padding: 18px clamp(14px, 3vw, 34px) 40px; }
.topbar {
  display: flex; align-items: center; justify-content: space-between; gap: 12px;
  padding: 12px 4px 18px; position: sticky; top: 0; z-index: 20;
  backdrop-filter: blur(8px); flex-wrap: wrap;
}
.topbar-right { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; }
.account-pill { font-size: .78rem; color: var(--teal-bright); background: rgba(45,212,191,.10);
  border: 1px solid var(--border); padding: 6px 12px; border-radius: 999px; }
.badge { display: inline-flex; align-items: center; gap: 7px; font-size: .74rem; color: var(--muted);
  border: 1px solid var(--border); padding: 6px 11px; border-radius: 999px; text-transform: uppercase; letter-spacing: .5px; }
.badge .dot { width: 8px; height: 8px; border-radius: 50%; background: var(--muted); }
.badge.live .dot { background: var(--pos); box-shadow: 0 0 0 0 rgba(52,211,153,.6); animation: pulse 1.8s infinite; }
.badge.live { color: var(--pos); }
.badge.paused .dot { background: var(--warn); } .badge.paused { color: var(--warn); }
.badge.down .dot { background: var(--neg); } .badge.down { color: var(--neg); }
.icon-btn, .ghost-btn {
  background: var(--surface); border: 1px solid var(--border); color: var(--text);
  border-radius: 10px; cursor: pointer; transition: transform .12s, border-color .2s, background .2s;
}
.icon-btn { width: 38px; height: 38px; font-size: 1.1rem; }
.ghost-btn { padding: 9px 14px; font-size: .82rem; }
.icon-btn:hover, .ghost-btn:hover { border-color: var(--teal); transform: translateY(-1px); }
.icon-btn:active { transform: rotate(180deg); }

/* ===== Grid + cards ===== */
.grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; }
.card {
  background: linear-gradient(180deg, var(--surface) 0%, var(--surface-2) 100%);
  border: 1px solid var(--border); border-radius: var(--radius); padding: 20px;
  box-shadow: var(--shadow); position: relative; overflow: hidden;
  animation: rise .55s both;
}
.card::before { content: ""; position: absolute; inset: 0 0 auto 0; height: 1px;
  background: linear-gradient(90deg, transparent, var(--border-glow), transparent); }
.card:hover { border-color: var(--border-glow); }
.span-2 { grid-column: span 2; } .span-3 { grid-column: span 3; }
.card:nth-child(1){animation-delay:.02s}.card:nth-child(2){animation-delay:.08s}
.card:nth-child(3){animation-delay:.14s}.card:nth-child(4){animation-delay:.20s}
.card:nth-child(5){animation-delay:.26s}.card:nth-child(6){animation-delay:.32s}
.card-head { display: flex; align-items: center; justify-content: space-between; margin-bottom: 16px; }
.card-head h2 { font-size: .95rem; font-weight: 600; letter-spacing: .3px; }

/* Overview */
.overview-body { display: flex; align-items: flex-end; justify-content: space-between; gap: 20px; flex-wrap: wrap; }
.equity-value { font-size: clamp(2rem, 5vw, 2.9rem); font-weight: 700; letter-spacing: -1px;
  background: linear-gradient(90deg, #fff, var(--teal-bright)); -webkit-background-clip: text; background-clip: text; color: transparent; }
.equity-label { color: var(--muted); font-size: .8rem; margin-top: 4px; }
.equity-delta { margin-top: 10px; font-size: .95rem; font-weight: 600; }
.mini-stats { display: flex; gap: 22px; flex-wrap: wrap; }
.mini-stats > div { display: flex; flex-direction: column; gap: 3px; }
.mini-label { color: var(--muted); font-size: .7rem; text-transform: uppercase; letter-spacing: .5px; }
.mini-val { font-size: 1.05rem; font-weight: 600; }

/* Gauge */
.gauge-wrap { position: relative; display: grid; place-items: center; padding: 6px 0; }
.gauge { width: 100%; max-width: 220px; }
.gauge-track { fill: none; stroke: var(--border); stroke-width: 9; stroke-linecap: round; }
.gauge-fill { fill: none; stroke: var(--teal); stroke-width: 9; stroke-linecap: round;
  stroke-dasharray: 157; stroke-dashoffset: 157; transition: stroke-dashoffset 1s cubic-bezier(.2,.8,.2,1), stroke .4s; }
.gauge-center { position: absolute; bottom: 6px; text-align: center; }
.gauge-center span { display: block; font-size: 1.6rem; font-weight: 700; }
.gauge-center small { color: var(--muted); font-size: .68rem; }
.risk-note { text-align: center; margin-top: 8px; font-size: .78rem; color: var(--muted); }
.risk-note.warn { color: var(--warn); } .risk-note.breach { color: var(--neg); font-weight: 600; }

/* Chart */
.chart-box { height: 220px; }

/* Table */
.table-scroll { overflow-x: auto; }
.data-table { width: 100%; border-collapse: collapse; font-size: .86rem; }
.data-table th { text-align: left; color: var(--muted); font-weight: 500; font-size: .72rem;
  text-transform: uppercase; letter-spacing: .5px; padding: 8px 10px; border-bottom: 1px solid var(--border); }
.data-table td { padding: 11px 10px; border-bottom: 1px solid rgba(22,74,79,.4); }
.data-table tbody tr { transition: background .2s; } .data-table tbody tr:hover { background: rgba(45,212,191,.05); }
.data-table td:first-child { font-weight: 600; }
.pos { color: var(--pos); } .neg { color: var(--neg); }
.empty { color: var(--muted); text-align: center; padding: 22px 0; }

/* Feed */
.feed { list-style: none; display: flex; flex-direction: column; gap: 10px; max-height: 300px; overflow-y: auto; }
.feed li { border: 1px solid var(--border); border-radius: 12px; padding: 10px 12px; background: var(--bg-2);
  display: flex; flex-direction: column; gap: 3px; animation: rise .4s both; }
.feed .row { display: flex; justify-content: space-between; align-items: center; gap: 8px; }
.tag { font-size: .68rem; font-weight: 700; padding: 2px 8px; border-radius: 6px; letter-spacing: .5px; }
.tag.BUY { background: rgba(52,211,153,.15); color: var(--pos); }
.tag.HOLD, .tag.SELL { background: rgba(127,168,164,.14); color: var(--muted); }
.feed .reason { color: var(--muted); font-size: .76rem; line-height: 1.35; }
.feed .when { color: var(--muted); font-size: .68rem; }

/* News */
.news-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(230px, 1fr)); gap: 14px; }
.news-item { border: 1px solid var(--border); border-radius: 14px; overflow: hidden; background: var(--bg-2);
  display: flex; flex-direction: column; text-decoration: none; color: inherit;
  transition: transform .15s, border-color .2s; animation: rise .4s both; }
.news-item:hover { transform: translateY(-3px); border-color: var(--teal); }
.news-thumb { height: 110px; background: var(--surface-2) center/cover no-repeat; }
.news-body { padding: 12px 13px; display: flex; flex-direction: column; gap: 6px; }
.news-head { font-size: .84rem; font-weight: 600; line-height: 1.3;
  display: -webkit-box; -webkit-line-clamp: 3; -webkit-box-orient: vertical; overflow: hidden; }
.news-meta { display: flex; gap: 8px; align-items: center; color: var(--muted); font-size: .68rem; margin-top: auto; }
.news-syms { display: flex; gap: 5px; flex-wrap: wrap; }
.news-sym { font-size: .62rem; color: var(--teal-bright); background: rgba(45,212,191,.1); padding: 1px 6px; border-radius: 5px; }

.foot { text-align: center; color: var(--muted); font-size: .72rem; margin-top: 30px; }

/* Skeleton shimmer */
.shimmer { background: linear-gradient(90deg, var(--surface) 25%, var(--surface-2) 50%, var(--surface) 75%);
  background-size: 200% 100%; animation: shimmer 1.4s infinite; border-radius: 8px; color: transparent !important; }

/* ===== Animations ===== */
@keyframes rise { from { opacity: 0; transform: translateY(14px); } to { opacity: 1; transform: none; } }
@keyframes pop { from { opacity: 0; transform: scale(.94); } to { opacity: 1; transform: none; } }
@keyframes spin { to { transform: rotate(360deg); } }
@keyframes pulse { 0% { box-shadow: 0 0 0 0 rgba(52,211,153,.5);} 70% { box-shadow: 0 0 0 7px rgba(52,211,153,0);} 100%{box-shadow:0 0 0 0 rgba(52,211,153,0);} }
@keyframes shimmer { to { background-position: -200% 0; } }

/* ===== Responsive ===== */
@media (max-width: 1000px) {
  .grid { grid-template-columns: repeat(2, 1fr); }
  .span-2, .span-3 { grid-column: span 2; }
}
@media (max-width: 640px) {
  .grid { grid-template-columns: 1fr; gap: 14px; }
  .span-2, .span-3 { grid-column: span 1; }
  .card { padding: 16px; }
  .topbar { justify-content: center; }
  .overview-body { flex-direction: column; align-items: flex-start; }
  .equity-value { font-size: 2.2rem; }
  .foot { margin-bottom: env(safe-area-inset-bottom); }
}
@media (prefers-reduced-motion: reduce) { * { animation: none !important; transition: none !important; } }
