/* ============================================================
   ShaFX Brokers — dark theme (v39)
   Fixes Platforms & features table label visibility,
   Trader reviews form (was white-on-white), and comparison rows.
   ============================================================ */

.brk-wrap{max-width:1200px;margin:0 auto;padding:32px 16px 64px}
.brk-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:18px;margin-top:24px}

.brk-card{
  background:linear-gradient(180deg,var(--surface) 0%,var(--bg-3) 100%);
  border:1px solid var(--line);border-radius:14px;
  padding:22px;display:flex;flex-direction:column;
  text-decoration:none;color:var(--text);
  transition:transform .12s,border-color .12s,box-shadow .12s;
  position:relative;
}
.brk-card:hover{transform:translateY(-2px);border-color:var(--brand);box-shadow:0 8px 24px rgba(0,0,0,.4)}
.brk-card .badge{
  position:absolute;top:12px;right:12px;
  font-size:.68rem;text-transform:uppercase;letter-spacing:.06em;
  font-weight:800;padding:4px 10px;border-radius:999px;
  background:var(--brand);color:var(--brand-ink);
}
.brk-card .badge.partner{background:#16a34a;color:#fff}
.brk-card .badge.feat{background:var(--brand-ink);color:var(--brand);border:1px solid rgba(255,204,0,.4)}
.brk-card .head{display:flex;gap:12px;align-items:center;margin-bottom:14px}
.brk-card .logo{
  width:48px;height:48px;border-radius:10px;
  background:var(--brand);color:var(--brand-ink);
  display:flex;align-items:center;justify-content:center;
  font-weight:900;font-size:1.1rem;flex-shrink:0;
}
.brk-card h3{font-size:1.15rem;margin:0 0 2px;font-weight:800;color:var(--text)}
.brk-card .reg{font-size:.78rem;color:var(--text-3);font-weight:600}
.brk-card .stat-row{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin:10px 0 14px}
.brk-card .stat{font-size:.78rem}
.brk-card .stat .lbl{
  color:var(--text-3);text-transform:uppercase;letter-spacing:.04em;
  font-weight:700;font-size:.68rem;display:block;margin-bottom:2px;
}
.brk-card .stat .val{font-weight:700;color:var(--text)}
.brk-card .platforms{display:flex;gap:4px;flex-wrap:wrap;margin-bottom:10px}
.brk-card .platforms span{
  font-size:.68rem;padding:3px 8px;border-radius:4px;
  background:rgba(255,255,255,.05);border:1px solid var(--line);
  color:var(--text-2);font-weight:700;
}
.brk-card .score{
  display:flex;align-items:center;gap:6px;
  margin-top:auto;padding-top:14px;
  border-top:1px solid var(--line);
}
.brk-card .score .num{font-size:1.5rem;font-weight:900;color:var(--brand);line-height:1}
.brk-card .score .max{color:var(--text-3);font-size:.85rem}
.brk-card .score .stars{color:var(--brand);margin-left:auto;font-size:.95rem}

.brk-hero{
  background:linear-gradient(135deg,var(--brand-ink),var(--bg));
  color:#fff;border-radius:18px;padding:36px;margin-bottom:24px;
  display:grid;grid-template-columns:auto 1fr auto;gap:24px;align-items:center;
  border:1px solid var(--line-2);
}
.brk-hero .logo{
  width:88px;height:88px;border-radius:14px;
  background:var(--brand);color:var(--brand-ink);
  display:flex;align-items:center;justify-content:center;
  font-weight:900;font-size:2rem;
}
.brk-hero h1{margin:0 0 4px;font-size:2.2rem;font-weight:900;color:#fff}
.brk-hero .tag{color:rgba(255,255,255,.78);font-size:1rem;margin:0 0 6px}
.brk-hero .reg{color:rgba(255,255,255,.6);font-size:.85rem}
.brk-hero .cta{display:flex;flex-direction:column;gap:8px}
.brk-hero .cta a{padding:12px 22px;border-radius:8px;text-decoration:none;font-weight:700;text-align:center;font-size:.95rem}
.brk-hero .cta .primary{background:var(--brand);color:var(--brand-ink)}
.brk-hero .cta .ghost{color:#fff;border:1px solid rgba(255,255,255,.18)}

.brk-spec{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px;margin:24px 0}
.brk-spec .item{
  background:linear-gradient(180deg,var(--surface) 0%,var(--bg-3) 100%);
  border:1px solid var(--line);border-radius:10px;padding:14px 18px;
}
.brk-spec .lbl{
  font-size:.7rem;text-transform:uppercase;color:var(--text-3);
  font-weight:700;letter-spacing:.04em;margin-bottom:4px;
}
.brk-spec .val{font-weight:800;color:var(--text);font-size:1.1rem}

.brk-section{
  background:linear-gradient(180deg,var(--surface) 0%,var(--bg-3) 100%);
  border:1px solid var(--line);border-radius:14px;
  padding:28px;margin-bottom:18px;color:var(--text-2);
}
.brk-section h2{font-size:1.4rem;margin:0 0 14px;font-weight:800;color:var(--text)}
.brk-section p{color:var(--text-2);line-height:1.7}
.brk-section a{color:var(--brand)}

/* Pros/Cons */
.brk-proscons{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.brk-proscons .col{padding:18px;border-radius:10px}
.brk-proscons .col.pros{background:rgba(34,197,94,.06);border:1px solid rgba(34,197,94,.2)}
.brk-proscons .col.cons{background:rgba(239,68,68,.05);border:1px solid rgba(239,68,68,.2)}
.brk-proscons h3{margin:0 0 8px;font-size:1rem;color:var(--text)}
.brk-proscons .col.pros h3{color:#4ade80}
.brk-proscons .col.cons h3{color:#f87171}
.brk-proscons ul{margin:0;padding-left:20px;line-height:1.7;font-size:.95rem;color:var(--text-2)}
.brk-proscons li{color:var(--text-2)}

/* Platforms & features table — fix invisible labels */
.brk-cmp-table{
  width:100%;border-collapse:collapse;
  background:transparent;border-radius:14px;
  overflow:hidden;border:1px solid var(--line);
}
.brk-cmp-table th,.brk-cmp-table td{
  padding:14px 18px;text-align:left;
  border-bottom:1px solid var(--line);font-size:.95rem;
}
.brk-cmp-table th{
  background:rgba(255,255,255,.03);
  color:var(--text);font-weight:700;
  width:30%;text-transform:uppercase;
  letter-spacing:.04em;font-size:.82rem;
}
.brk-cmp-table td{font-weight:600;color:var(--text)}
.brk-cmp-table .winner{background:rgba(34,197,94,.08);position:relative}
.brk-cmp-table .winner::before{content:'★';color:#4ade80;font-size:.85rem;margin-right:6px}

.brk-cmp-head{
  display:grid;grid-template-columns:1fr auto 1fr;gap:18px;align-items:center;
  background:linear-gradient(135deg,var(--brand-ink),var(--bg));
  color:#fff;border-radius:18px;padding:28px;margin-bottom:24px;
  text-align:center;border:1px solid var(--line-2);
}
.brk-cmp-head .logo{
  width:72px;height:72px;border-radius:14px;
  background:var(--brand);color:var(--brand-ink);
  display:flex;align-items:center;justify-content:center;
  font-weight:900;font-size:1.6rem;margin:0 auto 8px;
}
.brk-cmp-head h2{margin:0;font-size:1.5rem;color:#fff;font-weight:900}
.brk-cmp-head .reg{color:rgba(255,255,255,.6);font-size:.85rem}
.brk-cmp-head .vs{font-size:1.4rem;font-weight:900;color:var(--brand)}

/* Reviews */
.review-stars{color:var(--brand);letter-spacing:2px;font-size:1.05rem}
.review-block{padding:18px 0;border-bottom:1px solid var(--line)}
.review-block:last-child{border-bottom:0}
.review-block .head{display:flex;justify-content:space-between;align-items:start;gap:12px;margin-bottom:6px}
.review-block strong{font-size:1rem;color:var(--text)}
.review-block .meta{font-size:.78rem;color:var(--text-3)}
.review-block .body{color:var(--text-2);line-height:1.6;margin:6px 0}
.review-block .expert-badge{
  background:var(--brand-ink);color:var(--brand);
  font-size:.65rem;font-weight:800;padding:2px 8px;border-radius:4px;
  text-transform:uppercase;letter-spacing:.05em;margin-left:8px;
  border:1px solid rgba(255,204,0,.3);
}

/* Review submission form — was white-on-white */
.review-form{
  background:rgba(255,255,255,.03);
  border:1px solid var(--line);
  border-radius:12px;padding:24px;margin-top:18px;
}
.review-form h3{color:var(--text);margin:0 0 12px}
.review-form .row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.review-form label{
  display:block;font-size:.82rem;font-weight:700;
  margin:10px 0 6px;color:var(--text-2);
}
.review-form input,.review-form textarea,.review-form select{
  width:100%;padding:11px 14px;
  border:1px solid var(--line-2);border-radius:8px;
  font-family:inherit;font-size:.95rem;box-sizing:border-box;
  background:rgba(0,0,0,.28);color:var(--text);
}
.review-form input:focus,.review-form textarea:focus,.review-form select:focus{
  outline:none;border-color:var(--brand);
  box-shadow:0 0 0 3px rgba(255,204,0,.15);
}
.review-form input::placeholder,.review-form textarea::placeholder{color:var(--text-3)}
.review-form button{
  background:var(--brand);color:var(--brand-ink);
  padding:12px 24px;border-radius:8px;
  font-weight:700;border:none;cursor:pointer;font-size:.95rem;
  margin-top:12px;
}
.review-form button:hover{background:var(--brand-2)}
.review-form .small,.review-form .muted{color:var(--text-3);font-size:.82rem;margin-top:10px}

.rating-input{display:flex;gap:4px;font-size:1.6rem;cursor:pointer}
.rating-input input{display:none}
.rating-input label{color:var(--text-3);margin:0;cursor:pointer;font-size:1.6rem;font-weight:normal}
.rating-input input:checked ~ label,
.rating-input label:hover,
.rating-input label:hover ~ label{color:var(--brand)}

.disclosure{
  background:rgba(255,204,0,.06);
  border-left:3px solid var(--brand);
  padding:14px 18px;font-size:.85rem;color:var(--text-2);
  margin:24px 0;border-radius:6px;
}
.disclosure strong{color:var(--text)}

/* "Availability varies by entity" — informational, not error */
.brk-cmp-table td.entity-note,
.brk-section .entity-note{
  color:var(--brand);font-weight:700;
}

@media (max-width:768px){
  .brk-hero{grid-template-columns:1fr;text-align:center}
  .brk-hero .logo{margin:0 auto}
  .brk-cmp-head{grid-template-columns:1fr}
  .brk-cmp-head .vs{margin:8px 0}
  .brk-proscons{grid-template-columns:1fr}
  .review-form .row{grid-template-columns:1fr}
}
