/* ===========================================================================
   MYJ Capital — Admin design system
   Mirrors the iOS app: deep teal-slate canvas, warm cream type, #1f4747 accent.
   =========================================================================== */
:root{
  /* Canvas & surfaces (from the app's MYJColor) */
  --bg:#141d1d;            /* background  rgb(20,29,29)  */
  --surface:#1c2727;       /* surface     rgb(28,39,39)  */
  --surface2:#263333;      /* elevated    rgb(38,51,51)  */
  --border:rgba(244,245,239,.09);

  /* Type — warm cream #F4F5EF */
  --text:#f4f5ef;
  --text2:rgba(244,245,239,.66);
  --text3:rgba(244,245,239,.40);

  /* Signature teal accent #1f4747 + lighter derivative */
  --accent:#1f4747;
  --accent-light:#69b0aa;  /* rgb(105,176,170) */
  --teal:#387d79;

  /* Market / status */
  --up:#73e382;
  --down:#f27171;
  --green:#73e382;
  --amber:#d8a23c;
  --red:#f27171;

  --radius:18px;
  --radius-sm:12px;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  background:
    radial-gradient(1100px 460px at 100% -5%, rgba(105,176,170,.10), transparent 60%),
    var(--bg);
  background-attachment:fixed;
  color:var(--text);
  font:15px/1.55 -apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  -webkit-font-smoothing:antialiased;
  min-height:100vh;
}
a{color:var(--accent-light);text-decoration:none}
a:hover{text-decoration:underline}
::selection{background:rgba(105,176,170,.28)}

/* ---- Top bar ---- */
.topbar{
  display:flex;align-items:center;gap:26px;
  padding:14px 26px;
  background:rgba(28,39,39,.72);
  backdrop-filter:saturate(140%) blur(12px);
  -webkit-backdrop-filter:saturate(140%) blur(12px);
  border-bottom:1px solid var(--border);
  position:sticky;top:0;z-index:20;
}
.topbar .brand-logo{height:26px;width:auto;display:block;opacity:.96}
.topbar nav{display:flex;gap:4px;flex:1;flex-wrap:wrap}
.topbar nav a{
  color:var(--text2);padding:8px 14px;border-radius:10px;font-weight:500;
  text-decoration:none;transition:background .15s,color .15s;
}
.topbar nav a:hover{background:var(--surface2);color:var(--text)}
.topbar nav a.active{
  background:var(--accent);color:var(--text);
  box-shadow:inset 0 0 0 1px rgba(105,176,170,.35);
}
.who{display:flex;align-items:center;gap:14px;color:var(--text2);font-size:14px}
.inline{display:inline}

/* ---- Layout ---- */
.wrap{max-width:1120px;margin:0 auto;padding:34px 26px 70px}
h1{font-size:27px;margin:0 0 6px;letter-spacing:-.3px;font-weight:700}
h2{font-size:18px;margin:30px 0 14px;font-weight:600}
.sub{color:var(--text2);margin:0 0 24px;max-width:70ch}
.eyebrow{font-size:12px;font-weight:600;letter-spacing:2.2px;text-transform:uppercase;color:var(--accent-light)}
.foot{
  text-align:center;color:var(--text3);font-size:12px;padding:34px;
  display:flex;flex-direction:column;align-items:center;gap:10px;
}
.foot .brand-logo{height:20px;opacity:.5}

/* ---- Cards / panels ---- */
.card{
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:var(--radius);
  padding:22px;margin-bottom:20px;
  box-shadow:0 1px 0 rgba(255,255,255,.02) inset, 0 8px 30px -18px rgba(0,0,0,.6);
}
.grid{display:grid;gap:16px}
.grid.cols-3{grid-template-columns:repeat(3,1fr)}
.grid.cols-4{grid-template-columns:repeat(4,1fr)}
@media(max-width:820px){.grid.cols-3,.grid.cols-4{grid-template-columns:1fr 1fr}}
@media(max-width:520px){.grid.cols-3,.grid.cols-4{grid-template-columns:1fr}}

/* ---- Stats ---- */
.stat{
  background:linear-gradient(180deg,var(--surface2),var(--surface));
  border:1px solid var(--border);border-radius:var(--radius-sm);padding:18px;
}
.stat .n{font-size:30px;font-weight:700;letter-spacing:-.5px}
.stat .l{color:var(--text2);font-size:13px;margin-top:3px}

/* ---- Tables ---- */
table{width:100%;border-collapse:collapse;font-size:14px}
th,td{text-align:left;padding:13px 14px;border-bottom:1px solid var(--border);vertical-align:middle}
th{color:var(--text3);font-weight:600;font-size:11px;text-transform:uppercase;letter-spacing:.6px}
tbody tr{transition:background .12s}
tr:hover td{background:var(--surface2)}
.muted{color:var(--text3)}

/* ---- Badges ---- */
.badge{display:inline-block;padding:3px 10px;border-radius:999px;font-size:12px;font-weight:600;line-height:1.5}
.badge.pending{background:rgba(216,162,60,.16);color:var(--amber)}
.badge.approved{background:rgba(115,227,130,.15);color:var(--green)}
.badge.rejected{background:rgba(242,113,113,.15);color:var(--red)}
.badge.suspended{background:rgba(244,245,239,.12);color:var(--text2)}
.badge.live{background:rgba(242,113,113,.18);color:var(--red)}
.badge.off{background:var(--surface2);color:var(--text2)}

/* ---- Buttons ---- */
.btn{
  display:inline-flex;align-items:center;gap:7px;
  border:1px solid var(--border);background:var(--surface2);
  color:var(--text);padding:9px 16px;border-radius:11px;font-size:14px;font-weight:600;
  cursor:pointer;font-family:inherit;transition:border-color .15s,background .15s,transform .05s;
}
.btn:hover{border-color:var(--accent-light);text-decoration:none}
.btn:active{transform:translateY(1px)}
.btn.primary{
  background:linear-gradient(135deg,var(--accent-light),var(--teal));
  border-color:transparent;color:#0e1414;
}
.btn.primary:hover{filter:brightness(1.06)}
.btn.danger{color:var(--red);border-color:rgba(242,113,113,.4);background:transparent}
.btn.danger:hover{background:rgba(242,113,113,.12)}
.btn.small{padding:6px 11px;font-size:13px;border-radius:9px}
.btn.link,.link{background:none;border:none;color:var(--text2);cursor:pointer;font:inherit;padding:0}
.link:hover{color:var(--text);text-decoration:underline}
.actions{display:flex;gap:8px;flex-wrap:wrap;align-items:center}

/* ---- Forms ---- */
label{display:block;font-size:13px;color:var(--text2);margin:0 0 7px;font-weight:600}
input[type=text],input[type=email],input[type=password],input[type=url],input[type=date],
input[type=file],textarea,select{
  width:100%;background:var(--bg);border:1px solid var(--border);color:var(--text);
  padding:12px 14px;border-radius:11px;font:inherit;transition:border-color .15s,box-shadow .15s;
}
input:focus,textarea:focus,select:focus{
  outline:none;border-color:var(--accent-light);
  box-shadow:0 0 0 3px rgba(105,176,170,.15);
}
input[type=file]{padding:9px 12px;color:var(--text2)}
textarea{min-height:120px;resize:vertical}
.field{margin-bottom:18px}
.row{display:flex;gap:16px;flex-wrap:wrap}
.row>.field{flex:1;min-width:180px}
.check{display:flex;align-items:center;gap:9px}
.check input{width:auto}

/* ---- Flash ---- */
.flash{padding:13px 17px;border-radius:12px;margin-bottom:20px;font-weight:500;border:1px solid transparent}
.flash.ok{background:rgba(115,227,130,.13);color:var(--green);border-color:rgba(115,227,130,.3)}
.flash.err{background:rgba(242,113,113,.13);color:var(--red);border-color:rgba(242,113,113,.3)}

/* ---- Login ---- */
.login{max-width:400px;margin:9vh auto;padding:0 22px}
.login .card{padding:32px}
.login .brand-wrap{display:flex;justify-content:center;margin-bottom:8px}
.login .brand-logo{height:34px}
.login h1{text-align:center;font-size:22px;margin:18px 0 4px}
.login .sub{text-align:center;margin-bottom:22px}

/* ---- Misc ---- */
.attach-thumb{width:56px;height:56px;object-fit:cover;border-radius:9px;border:1px solid var(--border)}
.attach-file{font-size:13px;color:var(--text2)}
.comment{padding:12px 0;border-bottom:1px solid var(--border)}
.comment .t{color:var(--text3);font-size:12px}
.empty{color:var(--text3);text-align:center;padding:34px}

/* ---- Realtime chat feed ---- */
.msg{padding:12px 6px;border-bottom:1px solid var(--border)}
.msg:last-child{border-bottom:none}
.msg-head{display:flex;align-items:center;gap:9px;font-size:13px}
.msg-time{color:var(--text3);font-size:12px}
.msg-actions{margin-left:auto}
.msg-body{margin-top:5px;white-space:pre-wrap;word-break:break-word;line-height:1.5}
.msg-atts{display:flex;flex-wrap:wrap;gap:9px;margin-top:10px}
.att-img{max-width:190px;max-height:190px;border-radius:11px;border:1px solid var(--border);display:block}
.att-video{max-width:270px;max-height:210px;border-radius:11px;border:1px solid var(--border);background:#000}
.att-file{display:inline-flex;align-items:center;gap:7px;padding:9px 13px;background:var(--surface2);border:1px solid var(--border);border-radius:11px;font-size:13px}
.att-ic{font-size:16px}
.cash{color:var(--accent-light);font-weight:600}

/* ---- Link preview card (chat) ---- */
.lp-card{
  display:flex;margin-top:10px;max-width:420px;
  background:var(--bg);border:1px solid var(--border);border-radius:12px;
  overflow:hidden;text-decoration:none;transition:border-color .15s;
}
.lp-card:hover{border-color:var(--accent-light);text-decoration:none}
.lp-img{width:110px;flex:none;background-size:cover;background-position:center;background-color:var(--surface2)}
.lp-body{padding:11px 13px;min-width:0}
.lp-site{font-size:11px;letter-spacing:.5px;text-transform:uppercase;color:var(--accent-light);margin-bottom:3px}
.lp-title{font-size:14px;font-weight:600;color:var(--text);line-height:1.3;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.lp-desc{font-size:12.5px;color:var(--text2);margin-top:3px;line-height:1.4;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.msg-body a{color:var(--accent-light);word-break:break-all}
@media(max-width:520px){.lp-img{width:84px}}

/* ---- Ticker clip (frozen chart + video) ---- */
.att-clip{display:inline-block;max-width:270px;border:1px solid var(--border);border-radius:12px;overflow:hidden;background:var(--bg)}
.att-clip .att-video{display:block;max-width:270px;border:none;border-radius:0;margin:0}
.clip-head{padding:9px 11px;background:var(--surface)}
.clip-row{display:flex;align-items:baseline;gap:8px}
.clip-sym{color:var(--accent-light);font-weight:700;font-size:14px}
.clip-price{color:var(--text);font-size:13px;font-variant-numeric:tabular-nums}
.clip-pct{margin-left:auto;font-size:12px;font-weight:600}
.clip-pct.up{color:var(--up)} .clip-pct.down{color:var(--down)}
.clip-spark{display:block;width:100%;height:44px;margin-top:6px}

/* ---- Bilingual chat (original + translation) ---- */
.msg-tickers{margin-top:4px}
.msg-tr{margin-top:6px;padding-left:10px;border-left:2px solid var(--border);color:var(--text2);font-size:14px;line-height:1.5}
.tr-tag{display:inline-block;font-size:10px;font-weight:700;letter-spacing:.5px;color:var(--accent-light);background:rgba(105,176,170,.12);padding:1px 6px;border-radius:6px;margin-right:6px;vertical-align:1px}
