/* =========================================================================
   Click-to-Pitch prototype styles. Tokens + table look copied from
   PlaylistSupply styles.css / tables.css so it matches the live tool.
   At integration: only the .ps-pitch-* and .ps-modal blocks move into PS
   (the :root tokens, table, dt-button, copy-cell, .ps-vet-btn rules already
   exist there — do NOT port them).
   ========================================================================= */
:root{
  --ink-975:#050705; --ink-950:#080c0b; --ink-900:#0c120e; --ink-800:#141e18;
  --frost-50:#ecfff4; --frost-100:#d0fce3; --frost-200:#a0f0c4; --frost-300:#6de6a0; --frost-400:#3dcc80;
  --mist-200:#d0d8d4; --mist-300:#a8b5ae; --mist-400:#7f8f86; --gold:#f9c846;
  --glass-bg:rgba(255,255,255,.045); --glass-border:rgba(130,230,170,.14); --glass-blur:blur(18px) saturate(1.5);
  --btn-primary-bg:rgba(61,204,128,.14); --btn-primary-border:rgba(130,230,170,.32);
  --shadow-glow:0 0 32px rgba(61,204,128,.22); --shadow-panel:0 18px 60px rgba(0,0,0,.55);
  --focus-glow:0 0 0 3px rgba(61,204,128,.08);
  --radius-lg:12px; --radius-xl:18px; --radius-2xl:24px;
}
body{ font-family:"Figtree",sans-serif; background:var(--ink-950); color:var(--mist-200); -webkit-font-smoothing:antialiased; overflow-x:hidden; }
.ps-accent{ color:var(--frost-300); }
a{ color:var(--frost-300); } a:hover{ color:var(--frost-200); }

/* Integrated status bar: pinned to the top-right corner so it sits above
   the existing PlaylistSupply chrome without reflowing the page. */
.ps-pitch-statusbar{ position:fixed; top:10px; right:16px; z-index:1010;
  display:flex; align-items:center; gap:10px; padding:6px 8px;
  background:rgba(10,14,20,0.72); -webkit-backdrop-filter:blur(8px);
  backdrop-filter:blur(8px); border:1px solid rgba(255,255,255,0.08);
  border-radius:999px; box-shadow:0 4px 16px rgba(0,0,0,0.35); }

/* ---------- top bar (used by the standalone prototype index.html only) ---------- */
.ps-topbar{ display:flex; align-items:center; justify-content:space-between; padding:14px 22px;
  border-bottom:1px solid var(--glass-border); background:var(--ink-975); position:sticky; top:0; z-index:20; }
.ps-brand{ font-weight:600; } .ps-brand span{ color:var(--frost-400); } .ps-brand em{ color:var(--mist-400); font-style:normal; font-size:12px; }
.ps-topbar-right{ display:flex; align-items:center; gap:12px; }
.ps-credits-pill,.ps-cap-pill{ font-size:12px; color:var(--mist-300); background:var(--glass-bg); border:1px solid var(--glass-border); border-radius:999px; padding:5px 12px; }
.ps-credits-pill b,.ps-cap-pill b{ color:var(--mist-200); }
.ps-gmail-btn{ display:inline-flex; align-items:center; gap:7px; height:32px; padding:0 14px; font-size:12px; font-weight:600;
  color:var(--frost-300); background:var(--btn-primary-bg); border:1px solid var(--btn-primary-border); border-radius:999px; cursor:pointer; }
.ps-gmail-btn:hover{ background:rgba(61,204,128,.22); color:var(--frost-200); }
.ps-gmail-btn.sm{ height:28px; font-size:11px; margin-left:8px; }
.ps-gmail-btn.connected{ color:var(--mist-300); } .ps-gmail-btn.connected svg{ color:var(--frost-400); }

/* ---------- layout (mirrors PS .background-dark / .card-body) ---------- */
.ps-main{ padding:22px; }
.background-dark{ background:var(--ink-950); }
.card-body{ background:var(--ink-950); border:1px solid var(--glass-border); border-radius:var(--radius-xl);
  box-shadow:var(--shadow-panel); padding:18px 20px; }

/* ---------- real DataTable look (from tables.css) ---------- */
table.dataTable{ color:var(--mist-200); border:none; }
#playlists_table thead th{ background:var(--ink-800); color:var(--mist-300); font-size:11px; font-weight:600;
  text-transform:uppercase; letter-spacing:.05em; border:none !important; padding:10px 10px; }
#playlists_table tbody td{ border-top:1px solid rgba(255,255,255,.05) !important; vertical-align:middle; font-size:13.5px; }
table.dataTable tbody tr{ background:transparent; }
table.dataTable tbody tr:nth-child(even){ background:rgba(255,255,255,.03); }
table.dataTable tbody tr.selected,table.dataTable tbody tr.selected td{ background:rgba(61,204,128,.10) !important; }
.cell-copyable{ display:inline-flex; align-items:center; gap:6px; }
.copy-btn{ cursor:pointer; color:var(--mist-400); font-size:13px; } .copy-btn:hover{ color:var(--frost-300); }
.dataTables_wrapper .dataTables_filter input,.dataTables_wrapper .dataTables_length select{
  background:var(--ink-900); color:var(--mist-200); border:1px solid var(--glass-border); border-radius:8px; }
.dataTables_wrapper .dataTables_info,.dataTables_wrapper .dataTables_paginate{ color:var(--mist-400) !important; font-size:12px; }
.dataTables_wrapper .paginate_button.page-item .page-link{ background:var(--ink-900); color:var(--mist-300); border-color:var(--glass-border); }
.dataTables_wrapper .paginate_button.page-item.active .page-link{ background:var(--frost-400); border-color:var(--frost-400); color:#04140b; }
.dtr-control{ cursor:pointer; }

/* export / save button bar (.dt-button .custom-button) */
.dt-buttons{ margin-bottom:12px; }
.dt-button.custom-button{ font-family:"Figtree",sans-serif !important; font-size:11px !important; font-weight:600;
  letter-spacing:.04em; text-transform:uppercase; color:var(--frost-300) !important; background:var(--btn-primary-bg) !important;
  border:1px solid var(--btn-primary-border) !important; border-radius:999px !important; padding:6px 14px !important; margin-right:6px; }
.dt-button.custom-button:hover{ background:rgba(61,204,128,.22) !important; color:var(--frost-200) !important; }

/* ---------- per-row Vet button (real, copied from PS styles.css) ---------- */
.ps-vet-btn{ display:inline-flex; align-items:center; justify-content:center; gap:6px; min-width:96px; height:30px; padding:0 14px;
  font-family:"Figtree",sans-serif; font-size:10.5px; font-weight:600; letter-spacing:.08em; text-transform:uppercase;
  color:var(--frost-300); background:var(--btn-primary-bg); border:1px solid var(--btn-primary-border); border-radius:999px; cursor:pointer; white-space:nowrap; }
.ps-vet-btn:hover{ background:rgba(61,204,128,.22); border-color:rgba(130,230,170,.5); color:var(--frost-200); box-shadow:var(--focus-glow); }
.ps-vet-icon{ width:13px; height:13px; flex:0 0 13px; }

/* ---------- per-row Pitch button (NEW — same recipe as .ps-vet-btn) ---------- */
.ps-pitch-btn{ display:inline-flex; align-items:center; justify-content:center; gap:6px; min-width:96px; height:30px; padding:0 14px;
  font-family:"Figtree",sans-serif; font-size:10.5px; font-weight:600; letter-spacing:.08em; text-transform:uppercase;
  color:var(--frost-300); background:var(--btn-primary-bg); border:1px solid var(--btn-primary-border); border-radius:999px; cursor:pointer; white-space:nowrap; }
.ps-pitch-btn:hover{ background:rgba(61,204,128,.22); border-color:rgba(130,230,170,.5); color:var(--frost-200); box-shadow:var(--focus-glow); }
.ps-pitch-btn:active{ transform:scale(.97); }
.ps-pitch-btn.pitched{ color:var(--mist-400); background:transparent; border-color:rgba(255,255,255,.1); cursor:default; }
.ps-pitch-icon{ width:13px; height:13px; flex:0 0 13px; }
.ps-noemail{ color:var(--mist-400); font-size:11px; font-style:italic; }

/* ---------- plan gate (Viral+) ---------- */
.ps-pitch-btn.locked{ filter:blur(1px); opacity:.6; cursor:pointer; }
.ps-pitch-btn.locked:hover{ filter:none; opacity:1; color:var(--gold); background:rgba(249,200,70,.14); border-color:rgba(249,200,70,.4); box-shadow:none; }
.ps-plan-pill{ font-size:12px; color:var(--frost-300); background:var(--btn-primary-bg); border:1px solid var(--btn-primary-border); border-radius:999px; padding:5px 12px; cursor:pointer; }
.ps-plan-pill b{ color:var(--frost-200); }
.ps-plan-pill.locked{ color:var(--gold); background:rgba(249,200,70,.10); border-color:rgba(249,200,70,.35); }
.ps-plan-pill.locked b{ color:var(--gold); }
/* upgrade modal */
.ps-upgrade .modal-body{ padding:30px 28px 26px; }
.ps-upgrade-badge{ display:inline-block; font-size:11px; font-weight:600; text-transform:uppercase; letter-spacing:.08em; color:var(--gold); background:rgba(249,200,70,.12); border:1px solid rgba(249,200,70,.3); border-radius:999px; padding:5px 12px; margin-bottom:14px; }
.ps-upgrade-title{ font-size:19px; font-weight:600; margin:0 0 10px; color:var(--mist-200); }
.ps-upgrade-copy{ font-size:13.5px; color:var(--mist-300); margin:0 0 12px; line-height:1.5; }
.ps-upgrade-sub{ font-size:12.5px; color:var(--mist-400); margin:0 0 20px; }
.ps-upgrade-actions{ display:flex; flex-direction:column; gap:10px; align-items:center; }
.ps-upgrade-actions .ps-btn-primary{ width:100%; justify-content:center; height:42px; }
.ps-upgrade-actions .ps-btn-ghost{ width:100%; }

/* ---------- modal (dark glass over Bootstrap) ---------- */
.ps-modal{ background:var(--ink-900); border:1px solid var(--glass-border); border-radius:var(--radius-xl); box-shadow:var(--shadow-panel); color:var(--mist-200); }
.ps-modal .modal-header,.ps-modal .modal-footer{ border-color:rgba(255,255,255,.06); }
.ps-modal .modal-title{ font-size:16px; font-weight:600; }
.ps-modal .close{ color:var(--mist-300); text-shadow:none; opacity:.8; }
.ps-field-row{ margin-bottom:14px; }
.ps-field-row label{ display:block; font-size:11px; text-transform:uppercase; letter-spacing:.06em; color:var(--mist-400); margin-bottom:5px; }
.ps-readonly{ font-size:13.5px; color:var(--mist-200); background:var(--ink-950); border:1px solid var(--glass-border); border-radius:8px; padding:8px 12px; }
.ps-input{ width:100%; font-family:"Figtree",sans-serif; font-size:13.5px; color:var(--mist-200); background:var(--ink-950);
  border:1px solid var(--glass-border); border-radius:8px; padding:9px 12px; outline:none; }
.ps-input:focus{ border-color:var(--btn-primary-border); box-shadow:var(--focus-glow); }
textarea.ps-input{ resize:vertical; line-height:1.5; }
.ps-merge-hint{ font-size:11.5px; color:var(--mist-400); margin-top:2px; }
.ps-merge-hint code{ color:var(--frost-300); background:rgba(61,204,128,.08); padding:1px 5px; border-radius:4px; }
.ps-warn{ font-size:13px; color:var(--gold); background:rgba(249,200,70,.08); border:1px solid rgba(249,200,70,.25); border-radius:10px; padding:10px 14px; margin-bottom:16px; }
.ps-footer-note{ font-size:11px; color:var(--mist-400); margin-right:auto; }

/* ---------- buttons ---------- */
.ps-btn-primary{ display:inline-flex; align-items:center; gap:7px; height:36px; padding:0 18px; font-size:13px; font-weight:600;
  color:var(--frost-200); background:rgba(61,204,128,.18); border:1px solid var(--btn-primary-border); border-radius:10px; cursor:pointer; }
.ps-btn-primary:hover{ background:rgba(61,204,128,.28); } .ps-btn-primary:disabled{ opacity:.5; cursor:not-allowed; }
.ps-btn-ghost{ height:36px; padding:0 16px; font-size:13px; color:var(--mist-300); background:transparent; border:1px solid rgba(255,255,255,.12); border-radius:10px; cursor:pointer; }
.ps-btn-ghost:hover{ color:var(--mist-200); border-color:rgba(255,255,255,.2); }

.ps-hint{ font-size:10.5px; color:var(--mist-400); text-transform:none; letter-spacing:0; font-weight:400; }

/* ---------- toast ---------- */
.ps-toast{ position:fixed; bottom:24px; left:50%; transform:translateX(-50%) translateY(20px); background:var(--ink-800); color:var(--mist-200);
  border:1px solid var(--glass-border); border-radius:10px; padding:12px 18px; font-size:13px; box-shadow:var(--shadow-panel);
  opacity:0; pointer-events:none; transition:opacity .2s, transform .2s; z-index:60; }
.ps-toast.show{ opacity:1; transform:translateX(-50%) translateY(0); } .ps-toast b{ color:var(--frost-300); }
