/* ============================================================
   AU Pokies — v3 Feature Styles
   RTP calculator · Trust badges · Compare drawer/page
   Comments · Command palette · Surprise button
   ============================================================ */

/* ---------- TRUST BADGES ---------- */
.trust-row {
  display:flex; flex-wrap:wrap; gap:8px; margin:16px 0 22px;
  align-items:center;
}
.trust-row > * { animation: fadeUp .4s ease both; }
@keyframes fadeUp { from { opacity:0; transform:translateY(8px); } }

.badge-pf, .badge-verified, .badge-ok, .trust-pill, .rtp-badge {
  display:inline-flex; align-items:center; gap:6px;
  padding:6px 12px; border-radius:999px;
  font-size:12.5px; font-weight:600;
  border:1px solid var(--border-strong);
  background:var(--surface);
  cursor:help;
}
.badge-pf {
  background:linear-gradient(135deg, rgba(124,92,255,.18), rgba(0,212,255,.14));
  border-color:rgba(124,92,255,.5);
  color:var(--txt-strong);
}
.badge-verified {
  background:linear-gradient(135deg, rgba(34,197,94,.18), rgba(132,204,22,.12));
  border-color:rgba(34,197,94,.5);
  color:#86efac;
}
.badge-ok {
  background:rgba(34,197,94,.15);
  border-color:rgba(34,197,94,.45);
  color:#86efac;
  padding:4px 10px; font-size:12px;
}
.rtp-badge.rtp-good {
  background:rgba(34,197,94,.18); border-color:rgba(34,197,94,.5); color:#86efac;
}
.rtp-badge.rtp-avg {
  background:rgba(250,204,21,.16); border-color:rgba(250,204,21,.5); color:#fde047;
}
.rtp-badge.rtp-low {
  background:rgba(239,68,68,.15); border-color:rgba(239,68,68,.5); color:#fca5a5;
}

/* Volatility meter (inline) */
.vol-meter { display:inline-flex; align-items:flex-end; gap:3px; height:18px; }
.vm-bar { display:inline-block; width:5px; border-radius:2px; transition:all .3s; }
.vol-label { font-size:12.5px; color:var(--muted); margin-left:8px; }

/* Card trust micro-icons */
.card-trust {
  position:absolute; top:10px; right:10px;
  display:flex; gap:4px; z-index:2;
}
.card-trust span {
  display:inline-flex; align-items:center; justify-content:center;
  width:26px; height:26px; border-radius:50%;
  background:rgba(0,0,0,.6); backdrop-filter:blur(6px);
  font-size:13px; border:1px solid rgba(255,255,255,.15);
}
.ct-pf  { color:#a78bfa; }
.ct-v   { color:#86efac; }

/* ---------- RTP CALCULATOR ---------- */
.rtp-calc {
  margin:32px 0;
  padding:24px;
  background:linear-gradient(135deg, rgba(124,92,255,.06), rgba(0,212,255,.04));
  border:1px solid var(--border);
  border-radius:var(--radius-lg);
  box-shadow:var(--shadow);
  position:relative;
  overflow:hidden;
}
.rtp-calc::before {
  content:""; position:absolute; inset:-2px;
  background:linear-gradient(135deg, rgba(124,92,255,.25), transparent 50%, rgba(0,212,255,.25));
  border-radius:inherit; z-index:-1; opacity:.4; pointer-events:none;
}
.rtp-calc-head {
  display:flex; justify-content:space-between; align-items:flex-start;
  gap:18px; margin-bottom:18px; flex-wrap:wrap;
}
.rtp-calc-head h2 { margin:0; font-size:22px; }
.rtp-calc-note {
  color:var(--muted); font-size:13.5px;
  max-width:480px; line-height:1.5;
}
.rtp-calc-grid {
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(160px, 1fr));
  gap:14px; margin-bottom:22px;
}
.rtp-calc-grid label {
  display:flex; flex-direction:column; gap:6px;
  font-size:13px; color:var(--muted);
  font-weight:600;
}
.rtp-calc-grid .input-wrap {
  display:flex; align-items:center;
  background:var(--bg-elev);
  border:1px solid var(--border-strong);
  border-radius:10px;
  overflow:hidden;
  transition:border-color .15s;
}
.rtp-calc-grid .input-wrap:focus-within { border-color:var(--acc); }
.rtp-calc-grid .prefix {
  padding:0 10px; font-size:12px; color:var(--muted);
  background:var(--surface); height:42px;
  display:flex; align-items:center; font-weight:700;
  border-right:1px solid var(--border);
}
.rtp-calc-grid input, .rtp-calc-grid select {
  background:transparent; color:var(--txt); border:0; outline:0;
  height:42px; padding:0 12px; flex:1; font-size:15px; font-weight:600;
  font-family:inherit;
}
.rtp-calc-grid select {
  background:var(--bg-elev); border:1px solid var(--border-strong);
  border-radius:10px;
}

.rtp-calc-results {
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(150px, 1fr));
  gap:12px;
  margin-bottom:18px;
}
.rcr-tile {
  background:var(--bg-elev);
  border:1px solid var(--border);
  border-radius:12px;
  padding:14px 16px;
  display:flex; flex-direction:column; gap:6px;
  transition:transform .15s, border-color .15s;
}
.rcr-tile:hover { transform:translateY(-2px); border-color:var(--border-strong); }
.rcr-label { font-size:11.5px; color:var(--muted); text-transform:uppercase; letter-spacing:.05em; font-weight:700; }
.rcr-val   { font-size:20px; color:var(--txt-strong); font-family:var(--font-display); font-variant-numeric:tabular-nums; }
.rcr-loss .rcr-val  { color:#fca5a5; }
.rcr-jp   .rcr-val  { color:var(--gold); }
.rtp-calc-results.rcr-warn .rcr-loss { box-shadow:0 0 0 2px rgba(239,68,68,.4) inset; }

.rtp-calc-chart { margin-top:6px; }
.rcr-bar {
  display:flex; height:18px; border-radius:9px; overflow:hidden;
  background:var(--bg-elev);
  border:1px solid var(--border);
}
.rcr-bar-fill { background:linear-gradient(90deg, #22c55e, #16a34a); transition:width .5s ease; }
.rcr-bar-loss { background:linear-gradient(90deg, #ef4444, #dc2626); transition:width .5s ease; }
.rcr-bar-legend {
  display:flex; gap:18px; margin-top:8px; font-size:12px; color:var(--muted);
}
.rcr-bar-legend i {
  display:inline-block; width:10px; height:10px; border-radius:3px; margin-right:6px;
  vertical-align:-1px;
}
.rtp-calc-disclaimer {
  margin:14px 0 0; padding-top:14px; border-top:1px dashed var(--border);
  font-size:12px; color:var(--muted); line-height:1.55;
}

/* ---------- COMPARE: card + detail buttons ---------- */
.cmp-add-btn, .cmp-add-btn-mini {
  display:inline-flex; align-items:center; gap:6px;
  background:var(--surface); color:var(--txt-strong);
  border:1px solid var(--border-strong); padding:8px 14px;
  border-radius:10px; font-size:13px; font-weight:600;
  cursor:pointer; transition:all .15s; font-family:inherit;
}
.cmp-add-btn:hover, .cmp-add-btn-mini:hover {
  background:var(--acc); color:#fff; border-color:var(--acc); transform:translateY(-1px);
}
.cmp-add-btn.is-active, .cmp-add-btn-mini.is-active {
  background:linear-gradient(135deg, var(--acc), var(--acc-2));
  color:#fff; border-color:transparent;
}
.cmp-add-btn-mini {
  margin-top:10px; padding:6px 10px; font-size:12px; width:100%; justify-content:center;
}

/* ---------- COMPARE DRAWER (sticky bottom) ---------- */
.cmp-drawer {
  position:fixed; left:50%; bottom:18px; transform:translateX(-50%);
  z-index:80; max-width:min(960px, calc(100vw - 24px)); width:100%;
  background:rgba(17,23,42,.95); backdrop-filter:blur(14px);
  border:1px solid var(--border-strong); border-radius:18px;
  box-shadow:var(--shadow-lg);
  transition:transform .3s, opacity .3s;
}
:root[data-theme="light"] .cmp-drawer { background:rgba(255,255,255,.95); }
.cmp-drawer.hidden { transform:translateX(-50%) translateY(140%); opacity:0; pointer-events:none; }
.cmp-drawer.collapsed .cmp-drawer-items,
.cmp-drawer.collapsed .cmp-drawer-actions { display:none; }
.cmp-drawer-inner { padding:14px 18px; }
.cmp-drawer-head {
  display:flex; align-items:center; gap:12px; flex-wrap:wrap; margin-bottom:10px;
}
.cmp-drawer-head strong { font-size:15px; color:var(--txt-strong); }
.cmp-drawer-count {
  background:var(--acc); color:#fff; font-size:12px; padding:2px 10px; border-radius:999px; font-weight:700;
}
.cmp-drawer-hint { color:var(--muted); font-size:12.5px; flex:1; }
.cmp-drawer-close {
  background:transparent; border:0; color:var(--muted); font-size:18px; cursor:pointer;
  width:32px; height:32px; border-radius:8px;
}
.cmp-drawer-close:hover { background:var(--surface); color:var(--txt-strong); }
.cmp-drawer-items {
  display:flex; gap:10px; flex-wrap:wrap; margin-bottom:12px;
}
.cmp-slot {
  display:flex; align-items:center; gap:8px;
  padding:8px 12px 8px 8px;
  background:var(--surface); border:1px solid var(--border);
  border-radius:12px; max-width:260px;
}
.cmp-slot-thumb {
  width:38px; height:38px; border-radius:8px;
  background:var(--bg-elev) center/cover no-repeat;
  display:flex; align-items:center; justify-content:center;
  font-weight:700; color:var(--txt-strong);
  flex-shrink:0;
}
.cmp-slot-name {
  font-size:13.5px; font-weight:600; color:var(--txt-strong);
  white-space:nowrap; overflow:hidden; text-overflow:ellipsis; max-width:160px;
}
.cmp-slot-x {
  background:transparent; border:0; color:var(--muted); cursor:pointer; font-size:14px;
  padding:4px 6px; border-radius:6px;
}
.cmp-slot-x:hover { background:var(--err); color:#fff; }
.cmp-drawer-actions { display:flex; justify-content:flex-end; gap:10px; }
.cmp-drawer-actions .btn.disabled { opacity:.45; pointer-events:none; }

/* ---------- COMPARE PAGE ---------- */
.empty-compare {
  text-align:center; padding:60px 24px;
  background:var(--bg-elev); border:1px dashed var(--border-strong);
  border-radius:var(--radius-lg);
}
.empty-art { font-size:54px; margin-bottom:10px; }
.compare-toolbar {
  display:flex; align-items:center; gap:14px; margin-bottom:18px;
  background:var(--bg-elev); border:1px solid var(--border);
  padding:12px 18px; border-radius:14px;
}
.compare-toolbar strong { font-size:15px; }
.btn-ghost {
  background:transparent; border:1px solid var(--border-strong);
  color:var(--txt); padding:8px 14px; border-radius:10px; cursor:pointer;
  font-size:13px; font-weight:600; text-decoration:none; font-family:inherit;
  display:inline-flex; align-items:center; gap:6px;
  transition:all .15s;
}
.btn-ghost:hover { background:var(--surface); color:var(--txt-strong); }
.compare-wrap { overflow-x:auto; }
.compare-table {
  width:100%; border-collapse:separate; border-spacing:0;
  min-width:680px;
}
.compare-table th, .compare-table td {
  padding:14px 16px; border-bottom:1px solid var(--border);
  vertical-align:middle; text-align:center;
}
.compare-table th.row-label {
  text-align:left; color:var(--muted); font-size:13px; font-weight:600;
  white-space:nowrap; background:var(--bg-elev);
  position:sticky; left:0; z-index:1;
}
.compare-table thead th {
  padding:18px 16px; background:var(--bg-elev);
  border-bottom:2px solid var(--border-strong);
  vertical-align:top;
}
.cmp-thumb {
  display:flex; width:120px; height:80px; margin:0 auto 10px;
  border-radius:12px; align-items:center; justify-content:center;
  background:var(--surface); overflow:hidden;
  position:relative;
}
.cmp-initial { font-size:36px; font-weight:700; color:var(--txt-strong); }
.cmp-name {
  display:block; font-size:15px; font-weight:700; color:var(--txt-strong); text-decoration:none;
  margin-bottom:4px;
}
.cmp-name:hover { color:var(--acc-2); }
.cmp-provider { font-size:12px; color:var(--muted); margin-bottom:8px; }
.cmp-remove {
  background:transparent; border:0; color:var(--muted); cursor:pointer;
  font-size:14px; padding:4px 8px; border-radius:6px;
}
.cmp-remove:hover { background:var(--err); color:#fff; }
.cmp-winner { position:relative; background:rgba(34,197,94,.08); }
.cmp-winner::after {
  content:"★ Best"; position:absolute; top:4px; right:6px;
  font-size:10px; color:var(--ok); font-weight:700;
}
.v-meter { display:inline-flex; gap:3px; align-items:flex-end; height:18px; margin-right:8px; }
.v-bar { width:5px; height:6px; background:rgba(255,255,255,.14); border-radius:2px; }
.v-bar.on:nth-child(1) { height:8px; background:#22c55e; }
.v-bar.on:nth-child(2) { height:11px; background:#84cc16; }
.v-bar.on:nth-child(3) { height:14px; background:#facc15; }
.v-bar.on:nth-child(4) { height:17px; background:#f97316; }
.v-bar.on:nth-child(5) { height:20px; background:#ef4444; }
.btn-mini {
  display:inline-flex; align-items:center; gap:6px;
  background:var(--acc); color:#fff; padding:8px 14px;
  border-radius:10px; text-decoration:none; font-size:13px; font-weight:600;
  transition:all .15s; border:0; cursor:pointer;
}
.btn-mini.secondary { background:var(--surface); color:var(--txt-strong); border:1px solid var(--border-strong); }
.btn-mini:hover { transform:translateY(-1px); box-shadow:var(--shadow-sm); }

/* ---------- COMMENTS ---------- */
.comments-section { margin:40px 0; padding-top:16px; border-top:1px solid var(--border); }
.comments-head { display:flex; align-items:center; gap:14px; margin-bottom:18px; }
.comments-head h2 { margin:0; }
.cmt-count {
  background:var(--surface); color:var(--muted);
  padding:4px 12px; border-radius:999px; font-size:12.5px; font-weight:600;
}
.cmt-form {
  background:var(--bg-elev); border:1px solid var(--border);
  border-radius:14px; padding:18px; margin-bottom:22px;
  position:relative;
}
.cmt-form-top {
  display:flex; gap:12px; margin-bottom:12px; flex-wrap:wrap;
}
.cmt-form-top input[type="text"] {
  flex:1; min-width:200px; height:42px; padding:0 14px;
  background:var(--bg); border:1px solid var(--border-strong);
  border-radius:10px; color:var(--txt); font-family:inherit; font-size:14px;
}
.cmt-form-top input[type="text"]:focus { border-color:var(--acc); outline:0; }
.cmt-form textarea {
  width:100%; min-height:100px; padding:12px 14px;
  background:var(--bg); border:1px solid var(--border-strong);
  border-radius:10px; color:var(--txt); font-family:inherit; font-size:14px;
  resize:vertical; box-sizing:border-box;
}
.cmt-form textarea:focus { border-color:var(--acc); outline:0; }
.cmt-char-count {
  display:block; text-align:right; margin-top:4px;
  font-size:11.5px; color:var(--muted-2); font-variant-numeric:tabular-nums;
  transition:color .15s;
}
.cmt-char-count.warn { color:var(--gold); font-weight:600; }
.cmt-form-bot {
  display:flex; justify-content:space-between; align-items:center;
  gap:14px; margin-top:12px; flex-wrap:wrap;
}
.cmt-form-info {
  display:flex; flex-direction:column; gap:4px;
  font-size:12px; color:var(--muted); flex:1;
}
.cmt-disclaimer { font-size:11.5px; opacity:.85; }
.star-rating {
  display:inline-flex; align-items:center; gap:2px;
  background:var(--bg); border:1px solid var(--border-strong); border-radius:10px;
  padding:4px 8px; height:42px;
}
.star-rating button {
  background:transparent; border:0; color:rgba(255,255,255,.2);
  font-size:22px; cursor:pointer; padding:0 2px; transition:color .12s;
  line-height:1;
}
.star-rating button.on,
.star-rating button:hover { color:var(--gold); }

.cmt-list { display:flex; flex-direction:column; gap:18px; }
.cmt-empty, .cmt-loading {
  padding:32px; text-align:center; color:var(--muted);
  background:var(--bg-elev); border:1px dashed var(--border-strong); border-radius:12px;
}
.cmt-item {
  display:flex; gap:14px; padding:16px; background:var(--bg-elev);
  border:1px solid var(--border); border-radius:14px;
  animation:fadeUp .3s ease both;
}
.cmt-item.is-reply {
  margin-left:34px; background:var(--surface); border-color:var(--border);
}
.cmt-avatar {
  flex-shrink:0; width:42px; height:42px; border-radius:50%;
  background:linear-gradient(135deg, var(--acc), var(--acc-2));
  color:#fff; font-weight:700; font-size:17px;
  display:flex; align-items:center; justify-content:center;
}
.cmt-body { flex:1; min-width:0; }
.cmt-body header {
  display:flex; gap:10px; align-items:center; flex-wrap:wrap; margin-bottom:6px;
}
.cmt-body header strong { color:var(--txt-strong); font-size:14px; }
.cmt-stars { color:var(--gold); font-size:13px; letter-spacing:1px; }
.cmt-date { color:var(--muted-2); font-size:12px; margin-left:auto; }
.cmt-body p {
  margin:0 0 8px; line-height:1.6; color:var(--txt); font-size:14.5px; word-wrap:break-word;
}
.cmt-body footer {
  display:flex; gap:14px; margin-top:4px;
}
.cmt-helpful, .cmt-reply {
  background:transparent; border:1px solid var(--border);
  color:var(--muted); cursor:pointer; padding:4px 10px;
  border-radius:8px; font-size:12px; font-weight:600; font-family:inherit;
  transition:all .15s;
}
.cmt-helpful:hover, .cmt-reply:hover {
  background:var(--surface); color:var(--txt-strong); border-color:var(--border-strong);
}
.cmt-helpful.voted { background:rgba(34,197,94,.15); color:#86efac; border-color:rgba(34,197,94,.4); }
.cmt-replies { margin-top:14px; display:flex; flex-direction:column; gap:14px; }

/* ---------- COMMAND PALETTE ---------- */
.cmd-palette {
  position:fixed; inset:0; background:rgba(0,0,0,.6); backdrop-filter:blur(8px);
  display:none; align-items:flex-start; justify-content:center;
  padding-top:12vh; z-index:200;
}
.cmd-palette.open { display:flex; animation:fadeIn .15s; }
@keyframes fadeIn { from { opacity:0; } }
.cmd-box {
  width:min(620px, calc(100vw - 24px));
  background:var(--bg-elev); border:1px solid var(--border-strong);
  border-radius:16px; box-shadow:var(--shadow-lg);
  overflow:hidden;
  animation:slideDown .2s ease;
}
@keyframes slideDown { from { transform:translateY(-12px); opacity:0; } }
.cmd-search {
  display:flex; align-items:center; gap:12px;
  padding:14px 18px; border-bottom:1px solid var(--border);
}
.cmd-search > span { font-size:18px; color:var(--muted); }
.cmd-search input {
  flex:1; background:transparent; border:0; outline:0;
  color:var(--txt-strong); font-family:inherit; font-size:16px;
}
.cmd-search input::placeholder { color:var(--muted-2); }
.cmd-search kbd {
  font-size:11px; padding:2px 8px; border-radius:6px;
  background:var(--surface); color:var(--muted); border:1px solid var(--border);
}
.cmd-results {
  max-height:50vh; overflow-y:auto;
}
.cmd-row {
  display:flex; align-items:center; gap:12px;
  padding:11px 18px; text-decoration:none; color:var(--txt);
  border-left:3px solid transparent;
  transition:background .1s;
  cursor:pointer;
}
.cmd-row:hover, .cmd-row.active {
  background:var(--surface); border-left-color:var(--acc);
}
.cmd-thumb {
  width:32px; height:32px; border-radius:8px;
  background:var(--bg) center/cover no-repeat;
  display:flex; align-items:center; justify-content:center;
  font-weight:700; font-size:14px; color:var(--txt-strong);
  flex-shrink:0;
}
.cmd-l { flex:1; font-size:14px; font-weight:600; color:var(--txt-strong); }
.cmd-l small { display:block; font-size:11.5px; color:var(--muted); font-weight:500; margin-top:1px; }
.cmd-k {
  font-size:10.5px; padding:2px 8px; border-radius:6px;
  background:var(--surface); color:var(--muted); border:1px solid var(--border);
}
.cmd-empty { padding:40px 18px; text-align:center; color:var(--muted); font-size:14px; }
.cmd-foot {
  display:flex; gap:18px; padding:10px 18px;
  border-top:1px solid var(--border); background:var(--bg);
  font-size:11.5px; color:var(--muted);
}
.cmd-foot kbd {
  display:inline-block; font-size:10px; padding:1px 6px; border-radius:4px;
  background:var(--surface); color:var(--txt); border:1px solid var(--border); margin:0 2px;
}

.cmd-launcher {
  position:fixed; bottom:18px; right:18px; z-index:60;
  display:inline-flex; align-items:center; gap:8px;
  padding:10px 16px;
  background:rgba(17,23,42,.95); backdrop-filter:blur(14px);
  color:var(--txt-strong); border:1px solid var(--border-strong);
  border-radius:999px; font-family:inherit; font-size:13px; font-weight:600;
  box-shadow:var(--shadow); cursor:pointer; transition:all .15s;
}
:root[data-theme="light"] .cmd-launcher { background:rgba(255,255,255,.95); }
.cmd-launcher:hover { transform:translateY(-2px); box-shadow:var(--shadow-lg); }
.cmd-launcher kbd {
  font-size:10.5px; padding:2px 6px; border-radius:5px;
  background:var(--surface); color:var(--muted); border:1px solid var(--border);
}
@media (max-width: 640px) {
  .cmd-launcher { bottom:14px; right:14px; padding:8px 12px; }
  .cmd-launcher kbd { display:none; }
  .cmp-drawer { bottom:80px; }
}

/* ---------- SURPRISE ME BUTTON ---------- */
.surprise-btn {
  display:inline-flex; align-items:center; gap:8px;
  background:linear-gradient(135deg, var(--gold), #ff8a3d);
  color:#1a0e02; padding:10px 18px; border-radius:12px;
  border:0; font-weight:700; font-family:inherit; font-size:14px;
  cursor:pointer; box-shadow:var(--shadow);
  transition:all .2s;
}
.surprise-btn:hover { transform:translateY(-2px) rotate(-2deg); box-shadow:var(--shadow-lg); }
.surprise-btn.spinning {
  animation:rocking .15s linear infinite;
  background:linear-gradient(135deg, var(--acc), var(--acc-3));
  color:#fff;
}
@keyframes rocking {
  0%,100% { transform:rotate(-2deg); }
  50%     { transform:rotate(2deg); }
}

/* ---------- Mobile tweaks ---------- */
@media (max-width: 640px) {
  .rtp-calc { padding:18px; }
  .rtp-calc-grid { gap:10px; }
  .rcr-val { font-size:17px; }
  .comments-head { flex-wrap:wrap; }
  .cmt-form-top { flex-direction:column; }
  .star-rating { align-self:flex-start; }
  .cmt-item.is-reply { margin-left:14px; }
  .trust-row { gap:6px; }
  .badge-pf, .badge-verified, .rtp-badge { font-size:11.5px; padding:5px 9px; }
}
