/* Premiere Connect — Admin Dashboard
 * Mirrors the mobile app theme:
 *   --pc-red   #D81F26  (primary)
 *   --pc-dark  #1A1A2E  (dark bg)
 *   --pc-surf  #16213E  (dark surface)
 *   --pc-orange#FF6B35  (accent)
 *   --pc-green #4CAF50  (success)
 * Font: Inter (matches mobile app's google_fonts setup).
 */

@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800;900&display=swap');

:root{
  --pc-red:#D81F26;
  --pc-red-dk:#9b1318;
  --pc-red-lt:#ff3b42;
  --pc-dark:#1A1A2E;
  --pc-surf:#16213E;
  --pc-surf-2:#1f2d52;
  --pc-orange:#FF6B35;
  --pc-yellow:#F5B400;
  --pc-blue:#1f4ea6;
  --pc-green:#4CAF50;
  --pc-line:rgba(255,255,255,.08);
  --pc-line-strong:rgba(255,255,255,.16);
  --pc-text:#e8ecf5;
  --pc-text-dim:#a4adc4;
  --pc-bg:#0e1224;
  --card-radius:14px;
}

*,*::before,*::after{box-sizing:border-box}
html,body{margin:0;padding:0;font-family:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif;
  background:var(--pc-bg);color:var(--pc-text);font-size:14px;-webkit-font-smoothing:antialiased}

/* ───────── Topbar ───────── */
.topbar{position:sticky;top:0;z-index:10;display:flex;align-items:stretch;justify-content:space-between;
  background:linear-gradient(180deg,var(--pc-dark) 0%,var(--pc-surf) 100%);
  color:#fff;height:104px;padding:0 0 0 28px;
  border-bottom:1px solid var(--pc-line-strong);
  box-shadow:0 4px 18px rgba(0,0,0,.4)}
.topbar__left{display:flex;align-items:center;padding:8px 0}
.topbar__logo{height:80px;width:auto;display:block;filter:drop-shadow(0 4px 14px rgba(216,31,38,.45))}
.topbar__title{font-weight:900;font-size:32px;letter-spacing:.5px;
  color:transparent;background:linear-gradient(180deg,#ffffff 0%,#b9c2dc 100%);
  -webkit-background-clip:text;background-clip:text;
  margin:0;text-transform:uppercase;
  border-bottom:2px solid rgba(255,255,255,.15);padding-bottom:4px}
.topbar__right{display:flex;align-items:center;gap:18px;padding-right:24px;position:relative;height:100%}
.topbar__greet{font-size:18px;font-weight:300;color:#fff;margin-right:4px;letter-spacing:.3px}
.topbar__greet strong{font-weight:600}
.topbar__brand{display:flex;align-items:center;gap:10px;background:#fff;
  padding:10px 26px 10px 22px;height:64px;clip-path:polygon(18% 0,100% 0,100% 100%,0 100%)}
.topbar__brand img.logo{height:44px;width:auto;display:block}
.topbar__clock{background:var(--pc-orange);color:#1b1b1b;font-weight:800;font-size:17px;
  padding:0 22px 0 26px;height:64px;display:flex;align-items:center;
  clip-path:polygon(0 0,100% 0,100% 100%,8% 100%)}
.topbar__clock-label{position:absolute;right:14px;bottom:6px;font-size:10px;color:#fff;letter-spacing:1px;opacity:.7}

/* ───────── Shell ───────── */
.shell{display:grid;grid-template-columns:240px 1fr;min-height:calc(100vh - 104px);background:var(--pc-bg)}

/* ───────── Sidebar ───────── */
.sidebar{background:linear-gradient(180deg,var(--pc-dark) 0%,#0c1024 100%);
  border-right:1px solid var(--pc-line);
  padding:22px 18px 22px 22px;display:flex;flex-direction:column;gap:24px}
.sidebar__group{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:6px;
  border-bottom:1px solid var(--pc-line);padding-bottom:18px}
.sidebar__group:last-of-type{border-bottom:0}
.sidebar__item a{display:flex;align-items:center;justify-content:space-between;padding:6px 10px;
  font-weight:700;letter-spacing:.5px;color:#cfd6ec;text-decoration:none;font-size:12.5px;
  border-radius:6px;transition:all .12s ease}
.sidebar__item a:hover{background:rgba(255,255,255,.04);color:#fff}
.sidebar__item.is-active a{background:linear-gradient(90deg,var(--pc-red) 0%,var(--pc-red-dk) 100%);
  color:#fff;box-shadow:0 4px 12px rgba(216,31,38,.35)}
.sidebar__item.is-locked a{color:#7a829c}
.sidebar__item.is-locked .lock{font-size:13px;color:var(--pc-orange);opacity:.9}
.sidebar__item.is-active.is-locked a{color:#fff}
.sidebar__item.is-active.is-locked .lock{color:#fff}
.sidebar__item.is-disabled .sidebar__link--disabled{
  display:flex;align-items:center;justify-content:space-between;padding:6px 10px;
  border-radius:6px;color:#5a607a;cursor:not-allowed;font-style:italic;opacity:.65}
.sidebar__item.is-disabled .sidebar__link--disabled:hover{background:transparent;color:#5a607a}
.sidebar__soon{font-size:9px;font-weight:800;letter-spacing:1px;padding:2px 6px;border-radius:10px;
  background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);color:#8a90a8;font-style:normal}
.sidebar__logout{margin-top:auto;padding-top:18px;border-top:1px solid var(--pc-line)}
.sidebar__logout button{background:transparent;border:1px solid rgba(216,31,38,.35);color:var(--pc-red-lt);
  font-weight:800;letter-spacing:.8px;padding:9px 14px;cursor:pointer;font-size:12px;border-radius:6px;
  width:100%;transition:all .12s ease;font-family:inherit}
.sidebar__logout button:hover{background:var(--pc-red);color:#fff;border-color:var(--pc-red)}

/* ───────── Content ───────── */
.content{padding:18px 22px 30px;display:flex;flex-direction:column;gap:16px}

/* Status bar */
.statusbar{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
.status-pill{display:flex;align-items:center;gap:10px;background:var(--pc-surf);
  border:1px solid var(--pc-line-strong);border-radius:8px;
  padding:11px 14px;font-weight:600;color:var(--pc-text);font-size:13px;
  box-shadow:0 2px 6px rgba(0,0,0,.25)}
.status-pill .dot{width:16px;height:16px;border-radius:50%;background:var(--pc-green);display:inline-block;
  box-shadow:0 0 12px rgba(76,175,80,.5);transition:background .25s,box-shadow .25s}
.status-pill .dot.good{background:#34d058;box-shadow:0 0 12px rgba(76,175,80,.5)}
.status-pill .dot.warn{background:#f6c344;box-shadow:0 0 12px rgba(246,195,68,.55)}
.status-pill .dot.crit{background:#e8463a;box-shadow:0 0 12px rgba(232,70,58,.55);animation:pulseCrit 1.6s ease-in-out infinite}
.status-pill .ico{font-size:18px;color:var(--pc-text-dim)}
.status-pill .bar{display:inline-block;height:12px;width:80px;border-radius:3px;background:rgba(255,255,255,.08);margin-left:auto;transition:background .25s}
.status-pill .bar.good{background:linear-gradient(90deg,#34d058,#16a34a)}
.status-pill .bar.warn{background:linear-gradient(90deg,#f6c344,#c98a1c)}
.status-pill .bar.crit{background:linear-gradient(90deg,#ff5a4d,#a8201a)}
.status-pill.warn{border-color:rgba(246,195,68,.45)}
.status-pill.crit{border-color:rgba(232,70,58,.55)}
.status-pill .danger{color:var(--pc-red-lt)}
@keyframes pulseCrit{0%,100%{opacity:1}50%{opacity:.55}}

/* Panels */
.panel{display:flex;flex-direction:column;gap:12px;position:relative;
  padding:22px 18px 18px;border:1px solid var(--pc-line);border-radius:var(--card-radius);
  background:linear-gradient(180deg,rgba(22,33,62,.55) 0%,rgba(22,33,62,.25) 100%);
  box-shadow:0 4px 18px rgba(0,0,0,.25)}
.panel__title{position:absolute;top:-10px;left:50%;transform:translateX(-50%);
  background:var(--pc-bg);padding:2px 14px;
  font-weight:700;letter-spacing:3px;color:var(--pc-text-dim);font-size:11px}
.panel__toggle{position:absolute;right:14px;top:-10px;background:var(--pc-bg);padding:2px 8px;
  font-size:12px;color:var(--pc-text-dim)}
.panel__toggle .link{color:var(--pc-orange);text-decoration:none}
.panel__toggle .muted{color:rgba(255,255,255,.25)}

.row{display:grid;gap:12px}
.row--1{grid-template-columns:1fr}
.row--2{grid-template-columns:1fr 1fr}
.row--3{grid-template-columns:repeat(3,1fr)}
.row--4{grid-template-columns:repeat(4,1fr)}
.row--5{grid-template-columns:repeat(5,1fr)}

/* Cards */
.card{border-radius:10px;padding:14px 18px;color:#fff;position:relative;min-height:72px;
  display:flex;flex-direction:column;justify-content:center;
  box-shadow:0 4px 12px rgba(0,0,0,.35);overflow:hidden}
.card::before{content:'';position:absolute;inset:0;background:radial-gradient(circle at 100% 0%,rgba(255,255,255,.18),transparent 60%);pointer-events:none}
.card__label{font-weight:800;letter-spacing:.5px;font-size:13px;color:rgba(255,255,255,.92);position:relative}
.card__value{font-weight:900;font-size:26px;line-height:1.1;margin-top:4px;text-shadow:0 1px 0 rgba(0,0,0,.25);position:relative}
.card__value--right{text-align:right}
.card__brand{font-weight:700;font-size:13px;color:rgba(255,255,255,.95);position:relative}
.card__src{position:absolute;top:8px;right:12px;font-size:11px;opacity:.55;letter-spacing:1px}

.card--orange{background:linear-gradient(135deg,#ff8a4c 0%,#d65a23 100%)}
.card--yellow{background:linear-gradient(135deg,#ffd54a 0%,#e0a920 100%);color:#1b1b1b}
.card--yellow .card__label,.card--yellow .card__value{color:#1b1b1b}
.card--red{background:linear-gradient(135deg,var(--pc-red) 0%,var(--pc-red-dk) 100%)}
.card--blue{background:linear-gradient(135deg,#2a64c8 0%,#143a82 100%)}
.card--green{background:linear-gradient(135deg,#2fa56a 0%,#1a6b3f 100%)}
.card--purple{background:linear-gradient(135deg,#7d4cd0 0%,#4a2b8a 100%)}
.card--dark{background:linear-gradient(135deg,var(--pc-surf-2) 0%,var(--pc-surf) 100%);
  border:1px solid var(--pc-line-strong)}
.card--brand{flex-direction:row;align-items:center;justify-content:space-between}

/* Domain cells */
.cell{background:linear-gradient(180deg,rgba(255,255,255,.04) 0%,rgba(255,255,255,.01) 100%);
  border:1px solid var(--pc-line-strong);border-radius:10px;padding:14px;text-align:center;
  display:flex;flex-direction:column;justify-content:center;min-height:92px;
  box-shadow:0 2px 6px rgba(0,0,0,.18)}
.cell__label{font-weight:800;color:var(--pc-text);letter-spacing:.4px}
.cell__sub{font-size:11px;color:var(--pc-text-dim);margin-top:2px}
.cell__value{font-weight:900;font-size:26px;margin-top:8px;color:#fff}
.cell--danger{border-color:rgba(216,31,38,.5);background:linear-gradient(180deg,rgba(216,31,38,.12),rgba(216,31,38,.03))}
.cell--danger .cell__label,.cell--danger .cell__value{color:var(--pc-red-lt)}

/* Sell-out bars */
.row--sellout{}
.bar.bar--yellow,.bar.bar--red,.bar.bar--blue,.bar.bar--green,.bar.bar--purple{
  height:auto;width:auto;display:flex;align-items:center;justify-content:space-between;
  padding:12px 18px;border-radius:8px;color:#fff;font-weight:700;font-size:13px;
  box-shadow:0 4px 12px rgba(0,0,0,.35)}
.bar--yellow{background:linear-gradient(135deg,#f5b400 0%,#c98c00 100%);color:#1b1b1b}
.bar--red{background:linear-gradient(135deg,var(--pc-red) 0%,var(--pc-red-dk) 100%)}
.bar--blue{background:linear-gradient(135deg,#2a64c8 0%,#143a82 100%)}
.bar--green{background:linear-gradient(135deg,#2fa56a 0%,#1a6b3f 100%)}
.bar--purple{background:linear-gradient(135deg,#7d4cd0 0%,#4a2b8a 100%)}
.bar__value{font-weight:900;font-size:18px}

/* Stub / page placeholder */
.stub-card{background:linear-gradient(180deg,rgba(255,255,255,.04),rgba(255,255,255,.01));
  border:1px dashed var(--pc-line-strong);border-radius:12px;padding:48px;text-align:center;color:var(--pc-text-dim)}
.stub-card__icon{font-size:48px;color:var(--pc-red-lt);filter:drop-shadow(0 4px 12px rgba(216,31,38,.4))}
.stub-card h2{margin:8px 0;color:#fff;font-weight:800}
.muted{color:var(--pc-text-dim)}

/* OTP challenge inside dashboard */
.otp-challenge{background:linear-gradient(180deg,rgba(255,255,255,.04),rgba(255,255,255,.01));
  border:1px solid var(--pc-line-strong);border-radius:12px;padding:44px;max-width:520px;margin:0 auto;text-align:center}
.otp-challenge h2{margin-top:0;color:#fff}
.otp-challenge p{color:var(--pc-text-dim)}
.otp-challenge form{display:flex;flex-direction:column;align-items:center;gap:14px;margin-top:8px}
.lock-inline{color:var(--pc-orange)}

/* ───────── Auth pages (login / 2FA) ───────── */
.auth-body{margin:0;min-height:100vh;
  background:url('../img/bg_auth.png') center center / cover no-repeat,
             linear-gradient(135deg,var(--pc-red) 0%,var(--pc-red-dk) 100%);
  display:flex;align-items:center;justify-content:center;padding:24px;font-family:'Inter',sans-serif}
.auth-body::before{content:'';position:fixed;inset:0;
  background:radial-gradient(circle at 50% 0%,rgba(0,0,0,0) 0%,rgba(0,0,0,.55) 100%);pointer-events:none}
.auth-card{position:relative;background:rgba(14,18,36,.85);backdrop-filter:blur(14px);
  -webkit-backdrop-filter:blur(14px);
  border:1px solid rgba(255,255,255,.12);
  border-radius:18px;padding:36px 36px;width:100%;max-width:400px;
  box-shadow:0 24px 60px rgba(0,0,0,.55),0 0 0 1px rgba(216,31,38,.18) inset;color:var(--pc-text)}
.auth-card--wide{max-width:580px}
.auth-brand{display:flex;flex-direction:column;align-items:center;gap:12px;margin-bottom:18px}
.auth-brand img.logo{height:84px;width:auto;filter:drop-shadow(0 8px 20px rgba(216,31,38,.4))}
.auth-brand img.logo--xl{height:170px}
.auth-card__pwd{margin-bottom:32px !important}
.auth-card h1{font-size:20px;margin:6px 0 18px;font-weight:700;color:#fff;text-align:center}
.auth-card label{display:block;font-size:12px;color:var(--pc-text-dim);margin-bottom:14px;
  letter-spacing:.5px;text-transform:uppercase;font-weight:600}
.auth-card input,.auth-card textarea{width:100%;padding:12px 14px;
  background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);
  border-radius:10px;font-size:15px;margin-top:6px;font-family:inherit;color:#fff;
  transition:all .15s ease;text-transform:none;letter-spacing:normal;font-weight:500}
.auth-card input:focus,.auth-card textarea:focus{outline:0;border-color:var(--pc-red);
  background:rgba(255,255,255,.1);box-shadow:0 0 0 3px rgba(216,31,38,.25)}
.auth-card input::placeholder{color:rgba(255,255,255,.3)}
.btn{display:inline-block;padding:12px 22px;border-radius:10px;border:0;
  font-weight:800;cursor:pointer;font-size:14px;letter-spacing:.5px;
  font-family:inherit;transition:all .15s ease}
.btn--primary{background:linear-gradient(180deg,var(--pc-red) 0%,var(--pc-red-dk) 100%);color:#fff;
  box-shadow:0 6px 16px rgba(216,31,38,.4)}
.btn--primary:hover{transform:translateY(-1px);box-shadow:0 8px 22px rgba(216,31,38,.55)}
.btn--primary:active{transform:translateY(0)}
/* Auth screens want the primary button to fill the card width */
.auth-card .btn--primary,.auth-body .btn--primary{width:100%}
.alert{background:rgba(216,31,38,.15);border:1px solid rgba(216,31,38,.4);
  color:#ffb3b6;padding:11px 14px;border-radius:8px;margin-bottom:14px;font-size:13px;
  text-transform:none;letter-spacing:0;font-weight:500}
.auth-foot{margin-top:16px;font-size:12px;color:var(--pc-text-dim);text-align:center}
.auth-foot-form{margin-top:10px;text-align:center}
.link-btn{background:none;border:0;color:var(--pc-orange);cursor:pointer;text-decoration:underline;
  font-size:13px;padding:0;font-family:inherit}

/* TOTP block */
.totp-block{background:rgba(255,107,53,.08);border:1px solid rgba(255,107,53,.25);
  border-radius:10px;padding:16px;margin-bottom:16px}
.totp-label{font-size:11px;color:var(--pc-orange);letter-spacing:1.5px;text-transform:uppercase;margin-top:8px;font-weight:700}
.totp-secret{font-family:'JetBrains Mono','Consolas',monospace;font-size:18px;font-weight:700;
  letter-spacing:2px;color:#fff;padding:8px 0;word-break:break-all}
.totp-uri{width:100%;font-family:'JetBrains Mono','Consolas',monospace;font-size:11px;
  background:rgba(0,0,0,.35);border:1px solid rgba(255,255,255,.1);border-radius:6px;padding:8px;
  resize:vertical;color:#e8ecf5}
.totp-block details{margin-top:12px;font-size:13px;color:var(--pc-text-dim)}
.totp-block summary{cursor:pointer;color:var(--pc-orange);font-weight:600}

.otp-input{letter-spacing:.6em;font-family:'JetBrains Mono','Consolas',monospace;
  font-size:22px;text-align:center;padding:12px;font-weight:700}
.otp-input--lg{font-size:30px;letter-spacing:.5em;width:260px;display:inline-block;margin:12px auto;
  background:rgba(0,0,0,.3);border:1px solid var(--pc-line-strong);color:#fff;border-radius:10px;padding:14px}
.otp-input--lg:focus{outline:0;border-color:var(--pc-red);box-shadow:0 0 0 3px rgba(216,31,38,.25)}

/* --------- Loading Platforms --------- */
.data-table{width:100%;border-collapse:separate;border-spacing:0;font-size:13px;color:var(--pc-text)}
.data-table thead th{text-align:left;padding:10px 12px;font-weight:700;letter-spacing:.4px;font-size:11px;
  color:var(--pc-text-dim);text-transform:uppercase;border-bottom:1px solid var(--pc-line-strong);background:rgba(255,255,255,.02)}
.data-table tbody td{padding:12px;border-bottom:1px solid var(--pc-line);vertical-align:middle}
.data-table tbody tr:hover{background:rgba(255,255,255,.025)}
.data-table .mono{font-family:'JetBrains Mono','Consolas',monospace}
.data-table .small{font-size:12px}
.data-table code{font-family:'JetBrains Mono','Consolas',monospace;background:rgba(255,255,255,.06);
  padding:2px 6px;border-radius:4px;font-size:12px}
.data-table .actions{display:flex;gap:6px;flex-wrap:wrap;align-items:center}

.pill{display:inline-block;padding:3px 10px;border-radius:999px;font-size:11px;font-weight:700;letter-spacing:.4px}
.pill--green{background:rgba(76,175,80,.18);color:#7be08b;border:1px solid rgba(76,175,80,.4)}
.pill--mute{background:rgba(255,255,255,.06);color:var(--pc-text-dim);border:1px solid var(--pc-line-strong)}
.pill--orange{background:rgba(255,107,53,.16);color:#ffb88a;border:1px solid rgba(255,107,53,.4)}
.pill--red{background:rgba(216,31,38,.18);color:#ff8a8e;border:1px solid rgba(216,31,38,.4)}

.btn-mini{display:inline-block;padding:6px 12px;border-radius:6px;border:1px solid var(--pc-line-strong);
  background:rgba(255,255,255,.04);color:var(--pc-text);font-weight:600;font-size:12px;cursor:pointer;
  text-decoration:none;font-family:inherit;transition:all .12s ease}
.btn-mini:hover{background:rgba(255,255,255,.1);border-color:rgba(255,255,255,.3)}
.btn-mini--danger{color:#ff8a8e;border-color:rgba(216,31,38,.4)}
.btn-mini--danger:hover{background:var(--pc-red);color:#fff;border-color:var(--pc-red)}
.btn-mini--ok{color:#7be08b;border-color:rgba(76,175,80,.45)}
.btn-mini--ok:hover{background:var(--pc-green);color:#fff;border-color:var(--pc-green)}
.btn-mini.is-active{background:rgba(216,31,38,.18);border-color:rgba(216,31,38,.45);color:#fff}

/* Reusable inline notes box (dark theme) */
.notes-box{margin-top:12px;padding:10px 12px;background:rgba(255,255,255,.04);
  border:1px solid var(--pc-line-strong);border-radius:6px}
.notes-box__label{font-size:11px;color:var(--pc-text-dim);letter-spacing:.5px;text-transform:uppercase;font-weight:700}
.notes-box__body{font-size:13px;margin-top:2px;color:var(--pc-text)}

/* Diff highlight (proposed value in a change table) */
.diff-new{color:#7be08b;font-weight:600}

/* Inline inputs/selects inside data tables — keep dark-theme look without needing .form-row wrapper */
.data-table input[type=text],.data-table input[type=number],.data-table input[type=email],
.data-table input[type=tel],.data-table input[type=search],.data-table select{
  background:rgba(0,0,0,.25);border:1px solid var(--pc-line-strong);border-radius:6px;
  color:#fff;padding:6px 8px;font-size:12.5px;font-family:inherit;color-scheme:dark}
.data-table input:focus,.data-table select:focus{
  outline:0;border-color:var(--pc-red);box-shadow:0 0 0 2px rgba(216,31,38,.22)}
.data-table .num{width:96px;text-align:right;font-family:'JetBrains Mono','Consolas',monospace}

/* KPI mini-cards (replaces ad-hoc inline-styled blocks across views) */
.kpi-row{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:14px}
.kpi-card{padding:10px 14px;border:1px solid var(--pc-line-strong);border-radius:8px;min-width:160px;
  background:rgba(255,255,255,.02)}
.kpi-card__label{font-size:11px;text-transform:uppercase;letter-spacing:.4px;color:var(--pc-text-dim);font-weight:600}
.kpi-card__value{font-size:22px;font-weight:700;color:#fff;margin-top:2px}

/* In-body subhead used for version pills, timers, etc. that previously got jammed into .panel__title */
.panel__subhead{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin:2px 0 10px;
  font-size:12px;color:var(--pc-text-dim)}

/* Semantic text colors (small inline annotations — cell text, stars, deltas) */
.text--ok{color:#7bd389}
.text--warn{color:#ffb060}
.text--err{color:#ff8a8a}
.text--accent{color:#d6c089}

/* Empty-state row inside a list/modal/table */
.empty-state{padding:20px;text-align:center;font-size:13px;color:var(--pc-text-dim)}

.flash{padding:10px 14px;border-radius:8px;margin-bottom:14px;font-size:13px;font-weight:500}
.flash--ok{background:rgba(76,175,80,.14);border:1px solid rgba(76,175,80,.4);color:#a8e7b3}
.flash--err{background:rgba(216,31,38,.14);border:1px solid rgba(216,31,38,.4);color:#ffb3b6}

/* Form layout */
.form-grid{display:flex;flex-direction:column;gap:18px;max-width:760px}
.form-section{border:1px solid var(--pc-line-strong);border-radius:10px;padding:16px 18px;
  background:rgba(255,255,255,.02);margin:0}
.form-section legend{padding:0 8px;font-weight:700;color:var(--pc-orange);font-size:12px;letter-spacing:1px;text-transform:uppercase}
.form-row{display:flex;flex-direction:column;gap:6px;margin-bottom:12px}
.form-row > span{font-size:12px;font-weight:600;color:var(--pc-text-dim);letter-spacing:.3px;text-transform:uppercase}
.form-row input[type=text],.form-row input[type=password],.form-row input[type=url],
.form-row input[type=number],.form-row input[type=email],.form-row input[type=datetime-local],
.form-row input[type=date],.form-row input[type=time],.form-row input[type=month],
.form-row input[type=week],.form-row input[type=tel],.form-row input[type=search],
.form-row input:not([type]),
.form-row select,.form-row textarea,.form-section textarea{
  background:rgba(0,0,0,.25);border:1px solid var(--pc-line-strong);border-radius:8px;
  color:#fff;padding:10px 12px;font-size:14px;font-family:inherit;width:100%;
  color-scheme:dark}
.form-row input:focus,.form-row select:focus,.form-row textarea:focus,.form-section textarea:focus{
  outline:0;border-color:var(--pc-red);box-shadow:0 0 0 3px rgba(216,31,38,.22)}
.form-row input[readonly],.form-row textarea[readonly]{opacity:.7;cursor:not-allowed}
/* Native date/time pickers: invert the calendar/clock icon so it's visible on dark */
.form-row input[type=date]::-webkit-calendar-picker-indicator,
.form-row input[type=datetime-local]::-webkit-calendar-picker-indicator,
.form-row input[type=time]::-webkit-calendar-picker-indicator,
.form-row input[type=month]::-webkit-calendar-picker-indicator,
.form-row input[type=week]::-webkit-calendar-picker-indicator{
  filter:invert(1) brightness(1.4);cursor:pointer;opacity:.75}
.form-row input[type=date]::-webkit-calendar-picker-indicator:hover,
.form-row input[type=datetime-local]::-webkit-calendar-picker-indicator:hover{opacity:1}
.form-row .hint,.form-section .hint{font-size:11.5px;color:var(--pc-text-dim);font-weight:400;
  letter-spacing:0;text-transform:none;margin-top:2px}
.form-row--inline{flex-direction:row;gap:24px}
.check{display:inline-flex;align-items:center;gap:8px;font-size:13px;color:var(--pc-text);cursor:pointer}
.check input{accent-color:var(--pc-red);width:16px;height:16px}
.form-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:4px;align-items:center}
/* Secondary / ghost button (Cancel, Reset, etc.) — same footprint as .btn--primary */
.btn--ghost{background:transparent;color:var(--pc-text);border:1px solid var(--pc-line-strong);
  text-decoration:none;font-weight:600}
.btn--ghost:hover{background:rgba(255,255,255,.06);border-color:rgba(255,255,255,.3);color:#fff}

/* Inline filter forms (e.g. search + role picker rows that aren't using .form-row) */
.form-inline{display:flex;gap:10px;align-items:center;flex-wrap:wrap}
.form-inline input[type=text],.form-inline input[type=search],.form-inline input[type=number],
.form-inline input:not([type]),.form-inline select{
  background:rgba(0,0,0,.25);border:1px solid var(--pc-line-strong);border-radius:8px;
  color:#fff;padding:9px 12px;font-size:13px;font-family:inherit;color-scheme:dark}
.form-inline input:focus,.form-inline select:focus{
  outline:0;border-color:var(--pc-red);box-shadow:0 0 0 3px rgba(216,31,38,.22)}
.form-inline input::placeholder{color:rgba(255,255,255,.35)}

/* Native <dialog> styled to match the admin shell. */
.pc-dialog{border:1px solid var(--pc-line-strong);border-radius:12px;background:#10162a;
  color:var(--pc-text);padding:22px 24px;min-width:380px;max-width:520px;
  box-shadow:0 24px 60px rgba(0,0,0,.55)}
.pc-dialog::backdrop{background:rgba(4,8,18,.65);backdrop-filter:blur(2px)}
.pc-dialog h3{font-size:14px;letter-spacing:.6px;text-transform:uppercase;color:#fff}

/* Tabs (settings/products) */
.tabs{display:flex;gap:4px;align-items:center;border-bottom:1px solid var(--pc-line-strong);
  margin:6px 0 18px;padding-bottom:0}
.tab{display:inline-block;padding:9px 16px;font-size:12px;font-weight:700;letter-spacing:.5px;
  text-transform:uppercase;color:var(--pc-text-dim);text-decoration:none;border-bottom:2px solid transparent;
  transition:all .12s}
.tab:hover{color:var(--pc-text)}
.tab--active{color:var(--pc-orange);border-bottom-color:var(--pc-orange)}
.link.small{font-size:12px}
.section-h{font-size:13px;font-weight:700;letter-spacing:.6px;color:var(--pc-text-dim);
  text-transform:uppercase;margin:20px 0 12px;padding-bottom:8px;border-bottom:1px solid var(--pc-line)}

/* Audit log filter bar + JSON blocks */
.filter-bar{display:flex;flex-wrap:wrap;gap:14px;align-items:flex-end;
  padding:14px;background:rgba(255,255,255,.02);border:1px solid var(--pc-line-strong);
  border-radius:10px;margin-bottom:16px}
.filter-bar label{display:flex;flex-direction:column;gap:6px;min-width:140px}
.filter-bar label > span{font-size:11px;font-weight:700;letter-spacing:.4px;color:var(--pc-text-dim);
  text-transform:uppercase}
.filter-bar select,
.filter-bar input[type=text],.filter-bar input[type=search],.filter-bar input[type=number],
.filter-bar input[type=date],.filter-bar input[type=datetime-local],.filter-bar input[type=time],
.filter-bar input[type=month],.filter-bar input[type=week],.filter-bar input[type=tel],
.filter-bar input[type=email],.filter-bar input[type=url],.filter-bar input:not([type]){
  background:rgba(0,0,0,.25);border:1px solid var(--pc-line-strong);
  border-radius:6px;color:#fff;padding:7px 10px;font-size:13px;font-family:inherit;
  color-scheme:dark;width:100%}
.filter-bar select:focus,.filter-bar input:focus{outline:0;border-color:var(--pc-red);box-shadow:0 0 0 3px rgba(216,31,38,.22)}
.filter-bar input::placeholder{color:rgba(255,255,255,.35)}
.filter-bar input[type=date]::-webkit-calendar-picker-indicator,
.filter-bar input[type=datetime-local]::-webkit-calendar-picker-indicator,
.filter-bar input[type=time]::-webkit-calendar-picker-indicator,
.filter-bar input[type=month]::-webkit-calendar-picker-indicator,
.filter-bar input[type=week]::-webkit-calendar-picker-indicator{
  filter:invert(1) brightness(1.4);cursor:pointer;opacity:.75}
.filter-bar__actions{display:flex;gap:6px;margin-left:auto}

.json-block-h{font-size:11px;font-weight:700;letter-spacing:.5px;color:var(--pc-orange);
  text-transform:uppercase;margin:8px 0 4px}
.json-block{background:rgba(0,0,0,.4);border:1px solid var(--pc-line);border-radius:6px;
  padding:10px 12px;font-family:'JetBrains Mono','Consolas',monospace;font-size:11.5px;
  color:#cfe;max-height:280px;overflow:auto;white-space:pre-wrap;word-break:break-all;margin:0}
details > summary{cursor:pointer;list-style:none}
details > summary::-webkit-details-marker{display:none}

/* --------- Loading Platforms � dashboard polish --------- */
/* Brand tile (one per connected platform on the index page) */
.card--brand-tile{min-height:170px;align-items:stretch;justify-content:flex-start;
  padding:16px 18px 14px;gap:10px;display:flex;flex-direction:column}
.card--brand-tile .card__brand{font-size:18px;font-weight:800;letter-spacing:.3px}
.card--brand-tile .card__meta{display:flex;flex-wrap:wrap;gap:6px;position:relative}
.card--brand-tile .card__endpoint{font-size:11.5px;opacity:.88;position:relative;
  overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.card--brand-tile .card__footer{margin-top:auto;display:flex;align-items:flex-end;
  justify-content:space-between;gap:10px;position:relative;padding-top:8px;
  border-top:1px solid rgba(255,255,255,.18)}
.card--brand-tile .card__test{font-size:11.5px;font-weight:600;color:rgba(255,255,255,.95)}
.card--brand-tile .card__actions{display:flex;gap:6px;flex-wrap:wrap;justify-content:flex-end}
.card--brand-tile.is-disabled{filter:grayscale(.55) brightness(.85)}

/* Yellow card text adjustments */
.card--yellow .card__test,.card--yellow .card__endpoint{color:#1b1b1b}
.card--yellow .card__footer{border-top-color:rgba(0,0,0,.22)}

/* Pills/buttons designed to sit on a colored card */
.pill--inverse{background:rgba(0,0,0,.28);color:#fff;border:1px solid rgba(255,255,255,.25);
  font-weight:700}
.card--yellow .pill--inverse{background:rgba(255,255,255,.35);color:#1b1b1b;border-color:rgba(0,0,0,.18)}
.btn-mini--inverse{background:rgba(0,0,0,.28);border-color:rgba(255,255,255,.28);color:#fff}
.btn-mini--inverse:hover{background:rgba(0,0,0,.5);border-color:#fff}
.card--yellow .btn-mini--inverse{background:rgba(0,0,0,.18);color:#1b1b1b;border-color:rgba(0,0,0,.3)}
.card--yellow .btn-mini--inverse:hover{background:rgba(0,0,0,.32);color:#fff}

/* Inline status icons inside the management table */
.status-ok{color:#7be08b;font-weight:900;margin-right:4px}
.status-fail{color:#ff8a8e;font-weight:900;margin-right:4px}

/* Tabs � sit flush under the panel title so they look part of the chrome */
.tabs{margin:-6px -4px 14px;padding:0 4px}

/* Make the audit log JSON details summary feel clickable */
details > summary.link{display:inline-block}


/* --- Session idle warning + lock overlay ----------------------- */
.alert--warn{background:rgba(245,158,11,.15);border-color:rgba(245,158,11,.4);color:#fde7b8}
.pc-idle-warn[hidden],.pc-session-lock[hidden]{display:none !important}
.pc-idle-warn{position:fixed;right:18px;bottom:18px;z-index:9000;
  background:#16213e;color:#e6e9f5;border:1px solid rgba(245,158,11,.5);
  border-radius:10px;padding:12px 14px;box-shadow:0 10px 28px rgba(0,0,0,.45);
  max-width:360px;font-size:13px;animation:pcSlideIn .25s ease-out}
.pc-idle-warn__body{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.pc-idle-warn__body strong{color:#fde7b8}
.pc-idle-warn .btn-mini{margin-left:auto}
@keyframes pcSlideIn{from{transform:translateY(12px);opacity:0}to{transform:none;opacity:1}}
.pc-session-lock{position:fixed;inset:0;z-index:9999;
  background:rgba(8,10,24,.78);backdrop-filter:blur(8px);
  display:flex;align-items:center;justify-content:center;padding:24px;
  animation:pcFadeIn .2s ease-out}
.pc-session-lock__card{background:#1a1a2e;border:1px solid rgba(216,31,38,.4);
  border-radius:14px;padding:32px 36px;max-width:420px;width:100%;
  text-align:center;box-shadow:0 24px 60px rgba(0,0,0,.55)}
.pc-session-lock__icon{font-size:42px;line-height:1;margin-bottom:8px}
.pc-session-lock h2{margin:6px 0 10px;color:#fff;font-size:20px;letter-spacing:.5px}
.pc-session-lock p{color:var(--pc-text-dim);margin:0 0 18px;font-size:14px;line-height:1.5}
.pc-session-lock .btn{width:auto;padding:11px 22px;display:inline-block}
@keyframes pcFadeIn{from{opacity:0}to{opacity:1}}

/* --- Changelog timeline ---------------------------------------- */
.changelog{display:flex;flex-direction:column;gap:18px;position:relative;padding-left:14px}
.changelog::before{content:"";position:absolute;left:5px;top:6px;bottom:6px;width:2px;background:rgba(255,255,255,.08)}
.changelog__item{background:#16213e;border:1px solid rgba(255,255,255,.06);border-radius:10px;padding:14px 16px;position:relative}
.changelog__head{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;margin-bottom:10px}
.changelog__ver{display:flex;align-items:center;gap:8px;font-size:15px;color:#e6e9f5}
.changelog__dot{position:absolute;left:-14px;top:18px;width:10px;height:10px;border-radius:50%;background:#5a6080;border:2px solid #1a1a2e}
.changelog__dot.is-current{background:#22c55e;box-shadow:0 0 0 3px rgba(34,197,94,.18)}
.changelog__meta{display:flex;align-items:center;gap:10px;color:var(--pc-text-dim);font-size:13px}
.changelog__title{color:#e6e9f5}
.changelog__date{font-variant-numeric:tabular-nums}
.changelog__list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:6px}
.changelog__list li{display:flex;align-items:flex-start;gap:10px;font-size:13px;line-height:1.45;color:#cfd3e3}
.tag{display:inline-block;padding:2px 7px;border-radius:4px;font-size:10px;font-weight:700;letter-spacing:.5px;min-width:58px;text-align:center}
.tag--added{background:rgba(34,197,94,.18);color:#86efac}
.tag--changed{background:rgba(59,130,246,.18);color:#93c5fd}
.tag--fixed{background:rgba(245,158,11,.18);color:#fde7b8}
.tag--removed{background:rgba(216,31,38,.20);color:#fca5a5}

/* --- About page ------------------------------------------------ */
.about__hero{display:flex;align-items:center;justify-content:space-between;gap:18px;flex-wrap:wrap;padding:6px 4px}
.about__brand{display:flex;align-items:center;gap:14px}
.about__logo{width:56px;height:56px;border-radius:12px;background:linear-gradient(135deg,#D81F26,#7a1116);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:800;font-size:20px;letter-spacing:.5px;box-shadow:0 8px 22px rgba(216,31,38,.35)}
.about__name{margin:0;color:#fff;font-size:20px;letter-spacing:.4px}
.about__tag{margin:4px 0 0;color:var(--pc-text-dim);font-size:13px;max-width:560px}
.about__version{text-align:right}
.about__ver-num{font-size:22px;font-weight:700;color:#fff}
.about__ver-date{font-size:12px;color:var(--pc-text-dim)}
.about__grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px}
.about__h3{margin:0 0 8px;color:#fff;font-size:14px;letter-spacing:.5px}
.about__bullets{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:5px;color:#cfd3e3;font-size:13px}
.about__bullets li::before{content:"\2022";color:#D81F26;margin-right:8px}

/* --- Settings page --------------------------------------------- */
.settings-nav{display:flex;gap:6px;flex-wrap:wrap;margin:0 0 16px;padding:6px;background:#16213e;border:1px solid rgba(255,255,255,.06);border-radius:10px}
.settings-nav a{padding:7px 14px;border-radius:6px;color:var(--pc-text-dim);text-decoration:none;font-size:13px;letter-spacing:.4px;font-weight:600}
.settings-nav a:hover{background:rgba(255,255,255,.04);color:#fff}
.settings-2fa{display:grid;grid-template-columns:1fr minmax(260px,360px);gap:24px;align-items:start}
.settings-2fa__status{min-width:0}
.settings-2fa__form{margin:0}
.settings-2fa__form .form-row{margin-bottom:10px}
.settings-2fa__form input[name=code]{letter-spacing:.45em;text-align:center;font-variant-numeric:tabular-nums;font-family:'JetBrains Mono','Consolas',monospace}
@media (max-width:720px){.settings-2fa{grid-template-columns:1fr}}
.btn--danger{background:var(--pc-red);color:#fff;border-color:var(--pc-red)}
.btn--danger:hover{background:#b21820;border-color:#b21820}

/* -- Reports page ----------------------------------------------- */
.reports-filter{display:flex;flex-direction:column;gap:8px}
.reports-filter__row{display:flex;flex-wrap:wrap;align-items:flex-end;gap:14px}
.reports-filter__row .form-row{min-width:160px;margin:0}
.reports-filter__actions{display:flex;gap:10px;margin-left:auto}
.report-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:14px}
.report-card{background:rgba(255,255,255,.03);border:1px solid var(--pc-line);border-radius:10px;
  padding:16px;display:flex;flex-direction:column;gap:10px;min-height:170px}
.report-card:hover{border-color:rgba(255,255,255,.18);background:rgba(255,255,255,.05)}
.report-card__head{display:flex;justify-content:space-between;align-items:center;gap:10px}
.report-card__head h3{margin:0;font-size:14px;font-weight:700;letter-spacing:.3px}
.report-card__desc{margin:0;font-size:12.5px;color:var(--pc-text-dim);line-height:1.45;flex:1}
.report-card .btn{align-self:flex-start}

/* -- Report tabs + table preview -------------------------------- */
.report-tabs{display:flex;flex-wrap:wrap;gap:6px;margin-top:4px}
.report-tab{display:inline-block;padding:8px 14px;border-radius:8px;font-size:12.5px;font-weight:600;
  color:var(--pc-text-dim);background:rgba(255,255,255,.03);border:1px solid var(--pc-line);
  text-decoration:none;transition:all .15s}
.report-tab:hover{color:var(--pc-text);border-color:rgba(255,255,255,.2);background:rgba(255,255,255,.06)}
.report-tab.is-active{color:#fff;background:linear-gradient(180deg,var(--pc-red) 0%,var(--pc-red-dk) 100%);
  border-color:var(--pc-red);box-shadow:0 4px 14px rgba(216,31,38,.35)}
.report-table-wrap{overflow-x:auto;border:1px solid var(--pc-line);border-radius:8px;max-height:640px}
.report-table{min-width:100%}
.report-table thead th{position:sticky;top:0;background:#1a1d2e;z-index:1}
.report-table tbody td{font-size:12.5px;padding:8px 12px}

/* -- Chat / Communications --------------------------------------- */
.chat{display:grid;grid-template-columns:320px 1fr;gap:14px;min-height:calc(100vh - 280px)}
@media (max-width:900px){.chat{grid-template-columns:1fr}}
.chat__list{background:var(--pc-panel);border:1px solid var(--pc-line);border-radius:12px;
  display:flex;flex-direction:column;overflow:hidden;min-height:520px;max-height:calc(100vh - 230px)}
.chat__search{padding:10px;border-bottom:1px solid var(--pc-line)}
.chat__search input{width:100%;padding:8px 12px;border-radius:8px;border:1px solid var(--pc-line);
  background:rgba(255,255,255,.03);color:var(--pc-text);font-size:13px}
.chat__convs{overflow-y:auto;flex:1}
.chat__conv{display:flex;align-items:center;gap:10px;padding:12px;border-bottom:1px solid var(--pc-line);
  color:var(--pc-text);text-decoration:none;cursor:pointer;transition:background .12s}
.chat__conv:hover{background:rgba(255,255,255,.04)}
.chat__conv.is-active{background:rgba(216,31,38,.12);border-left:3px solid var(--pc-red);padding-left:9px}
.chat__conv.has-unread .chat__name{color:#fff}
.chat__conv.has-unread .chat__preview{color:var(--pc-text)}
.chat__avatar{flex:0 0 auto;width:38px;height:38px;border-radius:50%;display:flex;align-items:center;
  justify-content:center;background:linear-gradient(135deg,#3a3f5e,#1f2238);color:#fff;font-weight:700;
  font-size:13px;letter-spacing:.5px}
.chat__avatar--lg{width:46px;height:46px;font-size:15px}
.chat__conv-body{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}
.chat__conv-head{display:flex;justify-content:space-between;gap:6px;align-items:baseline}
.chat__name{font-weight:600;font-size:13.5px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.chat__time{font-size:11px;color:var(--pc-text-dim);flex:0 0 auto}
.chat__conv-meta{display:flex;align-items:center;gap:6px}
.chat__preview{flex:1;font-size:12px;color:var(--pc-text-dim);white-space:nowrap;overflow:hidden;
  text-overflow:ellipsis;min-width:0}
.chat__preview em{color:var(--pc-text);font-style:normal;font-weight:600}
.chat__badge{flex:0 0 auto;align-self:center;margin-left:8px;
  background:var(--pc-red);color:#fff;font-size:11px;font-weight:800;
  padding:3px 8px;border-radius:999px;min-width:20px;height:20px;line-height:14px;
  text-align:center;box-shadow:0 2px 6px rgba(216,31,38,.45)}
.chat__empty{text-align:center}

.chat__thread{background:var(--pc-panel);border:1px solid var(--pc-line);border-radius:12px;
  display:flex;flex-direction:column;overflow:hidden;min-height:520px;max-height:calc(100vh - 230px)}
.chat__placeholder{margin:auto;text-align:center;padding:40px;color:var(--pc-text-dim)}
.chat__placeholder-icon{font-size:48px;margin-bottom:14px;opacity:.6}
.chat__placeholder h3{margin:0 0 6px;color:var(--pc-text);font-weight:600}
.chat__header{display:flex;align-items:center;gap:12px;padding:14px 18px;border-bottom:1px solid var(--pc-line);
  background:rgba(255,255,255,.02)}
.chat__header-name{font-weight:700;font-size:15px}
.chat__header-sub{font-size:12px}

.chat__messages{flex:1;overflow-y:auto;padding:18px;display:flex;flex-direction:column;gap:10px;
  background:linear-gradient(180deg,rgba(255,255,255,.01),transparent)}
.chat__msg{display:flex;flex-direction:column;max-width:78%}
.chat__msg--mine{align-self:flex-end;align-items:flex-end}
.chat__msg--theirs{align-self:flex-start;align-items:flex-start}
.chat__bubble{padding:9px 13px;border-radius:14px;font-size:13.5px;line-height:1.45;word-wrap:break-word;
  box-shadow:0 1px 3px rgba(0,0,0,.18)}
.chat__msg--mine .chat__bubble{background:linear-gradient(180deg,var(--pc-red) 0%,var(--pc-red-dk) 100%);
  color:#fff;border-bottom-right-radius:4px}
.chat__msg--theirs .chat__bubble{background:rgba(255,255,255,.06);color:var(--pc-text);
  border:1px solid var(--pc-line);border-bottom-left-radius:4px}
.chat__msg--bcast .chat__bubble{border:1px dashed rgba(255,255,255,.25)}
.chat__text{white-space:pre-wrap}
.chat__meta{font-size:11px;color:var(--pc-text-dim);margin-top:4px;padding:0 4px}
.chat__attach{display:inline-flex;align-items:center;gap:8px;margin-top:8px;padding:8px 10px;
  background:rgba(0,0,0,.2);border-radius:8px;text-decoration:none;color:inherit;font-size:12.5px}
.chat__attach:hover{background:rgba(0,0,0,.32)}
.chat__attach--img{padding:0;background:transparent;display:block}
.chat__attach--img img{max-width:240px;max-height:240px;border-radius:8px;display:block}
.chat__attach-icon{font-size:18px}
.chat__attach-info{display:flex;flex-direction:column;line-height:1.2}
.chat__attach-name{font-weight:600}
.chat__attach-size{font-size:11px}

.chat__composer{display:flex;align-items:flex-end;gap:8px;padding:12px;border-top:1px solid var(--pc-line);
  background:rgba(255,255,255,.02)}
.chat__composer-main{flex:1 1 auto;display:flex;flex-direction:column;gap:6px;min-width:0}
.chat__composer textarea{flex:1 1 auto;resize:none;background:rgba(255,255,255,.04);color:var(--pc-text);
  border:1px solid var(--pc-line);border-radius:10px;padding:10px 12px;font-size:13.5px;
  font-family:inherit;max-height:160px;min-height:40px;min-width:0;width:100%}
.chat__composer textarea:focus{outline:none;border-color:var(--pc-red)}
.chat__composer .btn{flex:0 0 auto;width:auto;min-width:96px;padding:10px 20px;height:40px;align-self:flex-end}

/* Attachment preview chip shown above the textarea before sending */
.chat__attach-preview{display:flex;align-items:center;gap:10px;padding:6px 8px 6px 10px;
  background:rgba(255,255,255,.05);border:1px solid var(--pc-line);border-radius:10px}
.chat__attach-preview[hidden]{display:none}
.chat__attach-preview-img{max-height:56px;max-width:80px;border-radius:6px;display:block;object-fit:cover}
.chat__attach-preview-icon{font-size:22px;line-height:1}
.chat__attach-preview-info{flex:1;min-width:0;display:flex;flex-direction:column;line-height:1.2;overflow:hidden}
.chat__attach-preview-name{font-weight:600;font-size:13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.chat__attach-preview-size{font-size:11px}
.chat__attach-preview-remove{flex:0 0 auto;background:rgba(255,255,255,.06);color:var(--pc-text);
  border:1px solid var(--pc-line);border-radius:6px;width:26px;height:26px;font-size:18px;line-height:1;
  cursor:pointer;font-family:inherit}
.chat__attach-preview-remove:hover{background:var(--pc-red);color:#fff;border-color:var(--pc-red)}
.chat__attach-btn{flex:0 0 auto;display:flex;align-items:center;justify-content:center;width:40px;height:40px;
  border-radius:10px;background:rgba(255,255,255,.04);border:1px solid var(--pc-line);cursor:pointer;font-size:18px}
.chat__attach-btn:hover{background:rgba(255,255,255,.09)}
.chat__attach-btn input{display:none}

/* Broadcast form */
.bcast-audience{border:1px solid var(--pc-line);border-radius:10px;padding:12px 14px;margin:0}
.bcast-audience legend{padding:0 8px;font-size:12px;color:var(--pc-text-dim);text-transform:uppercase;letter-spacing:.5px}
.bcast-audience__opt{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:8px;cursor:pointer}
.bcast-audience__opt:hover{background:rgba(255,255,255,.04)}
.bcast-audience__opt.is-empty{opacity:.45;cursor:not-allowed}
.bcast-audience__label{flex:1;font-size:13.5px}
.bcast-audience__count{font-size:12px;color:var(--pc-text-dim);background:rgba(255,255,255,.05);
  padding:2px 10px;border-radius:999px;font-weight:600}

/* -- Standard page header inside .panel (title + meta pills + actions) - */
.page-head{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;
  gap:14px;margin:6px 0 4px}
.page-head__meta{display:flex;flex-wrap:wrap;align-items:center;gap:10px;flex:1 1 320px;min-width:0}
.page-head__sub{margin:0;font-size:13px;line-height:1.45;flex:1 1 240px;min-width:200px}
.page-head__actions{display:flex;gap:8px;align-items:center;flex-wrap:wrap;flex:0 0 auto}
.page-head__actions .btn{flex:0 0 auto;width:auto;min-width:140px;padding:10px 18px;text-align:center;text-decoration:none}

/* Dark-themed file input � same look as other form controls */
.form-row input[type=file],input.file-input{padding:8px 10px;background:rgba(255,255,255,.04);
  color:var(--pc-text);border:1px solid var(--pc-line);border-radius:8px;font-size:13px;
  font-family:inherit;width:100%;cursor:pointer}
.form-row input[type=file]::file-selector-button,input.file-input::file-selector-button{
  margin-right:10px;padding:6px 12px;border:0;border-radius:6px;
  background:rgba(255,255,255,.08);color:var(--pc-text);font-size:12px;font-weight:600;
  cursor:pointer;transition:background .12s}
.form-row input[type=file]::file-selector-button:hover,input.file-input::file-selector-button:hover{
  background:var(--pc-red);color:#fff}

/* Form actions: buttons size to content, never stretch full-width */
.form-actions .btn{flex:0 0 auto;min-width:120px;width:auto}

/* -- Reusable modal (used by Communications "New Message" picker) - */
.modal__backdrop{position:fixed;inset:0;background:rgba(0,0,0,.55);backdrop-filter:blur(2px);
  z-index:90;display:block}
.modal{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);z-index:91;
  width:min(540px,92vw);max-height:80vh;display:flex;flex-direction:column;
  background:var(--pc-panel);border:1px solid var(--pc-line-strong);border-radius:14px;
  box-shadow:0 24px 60px rgba(0,0,0,.55);overflow:hidden}
.modal__head{display:flex;justify-content:space-between;align-items:center;
  padding:14px 18px;border-bottom:1px solid var(--pc-line);font-size:14px}
.modal__close{color:var(--pc-text-dim);text-decoration:none;font-size:22px;line-height:1;
  padding:0 4px;border-radius:6px}
.modal__close:hover{color:#fff;background:rgba(255,255,255,.08)}
.modal__search{padding:12px 14px;border-bottom:1px solid var(--pc-line)}
.modal__search input{width:100%;padding:9px 12px;border-radius:8px;border:1px solid var(--pc-line);
  background:rgba(255,255,255,.04);color:var(--pc-text);font-size:13.5px}
.modal__search input:focus{outline:none;border-color:var(--pc-red)}
.modal__body{overflow-y:auto;padding:6px 0}

.picker__group{padding:4px 0}
.picker__group-label{font-size:10.5px;letter-spacing:.6px;color:var(--pc-text-dim);
  padding:8px 18px 4px;font-weight:700;text-transform:uppercase}
.picker__row{display:flex;align-items:center;gap:10px;padding:10px 18px;
  text-decoration:none;color:var(--pc-text);border:0;background:transparent;width:100%}
.picker__row:hover{background:rgba(255,255,255,.04)}
.picker__row--btn{padding:0}
.picker__btn{display:flex;align-items:center;gap:10px;padding:10px 18px;background:transparent;
  border:0;color:var(--pc-text);width:100%;cursor:pointer;text-align:left}
.picker__btn:hover{background:rgba(255,255,255,.04)}
.picker__name{font-weight:600;font-size:13.5px;flex:0 0 auto;margin-right:6px}
.picker__sub{flex:1;font-size:12px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0}
.picker__tag{flex:0 0 auto}

/* --------- DataTables dark-theme overrides --------- */
.dataTables_wrapper{color:var(--pc-text);font-size:13px;margin-top:6px}
.dataTables_wrapper .dataTables_length,
.dataTables_wrapper .dataTables_filter,
.dataTables_wrapper .dataTables_info,
.dataTables_wrapper .dataTables_paginate{color:var(--pc-text-dim);padding:10px 0}
.dataTables_wrapper .dataTables_length select,
.dataTables_wrapper .dataTables_filter input{
  background:rgba(0,0,0,.25);border:1px solid var(--pc-line-strong);color:#fff;
  border-radius:6px;padding:6px 10px;font-family:inherit;font-size:12.5px;color-scheme:dark}
.dataTables_wrapper .dataTables_filter input{margin-left:6px;min-width:220px}
.dataTables_wrapper .dataTables_length select:focus,
.dataTables_wrapper .dataTables_filter input:focus{
  outline:0;border-color:var(--pc-red);box-shadow:0 0 0 2px rgba(216,31,38,.22)}
.dataTables_wrapper .dataTables_paginate .paginate_button{
  color:var(--pc-text-dim)!important;border:1px solid transparent!important;
  border-radius:6px!important;background:transparent!important;
  padding:5px 11px!important;margin:0 2px}
.dataTables_wrapper .dataTables_paginate .paginate_button:hover{
  background:rgba(255,255,255,.06)!important;color:#fff!important;
  border-color:var(--pc-line-strong)!important}
.dataTables_wrapper .dataTables_paginate .paginate_button.current,
.dataTables_wrapper .dataTables_paginate .paginate_button.current:hover{
  background:var(--pc-red)!important;color:#fff!important;
  border-color:var(--pc-red)!important;box-shadow:0 4px 12px rgba(216,31,38,.35)}
.dataTables_wrapper .dataTables_paginate .paginate_button.disabled,
.dataTables_wrapper .dataTables_paginate .paginate_button.disabled:hover{
  color:rgba(255,255,255,.18)!important;background:transparent!important;
  border-color:transparent!important;cursor:not-allowed;box-shadow:none!important}
table.dataTable thead th,table.dataTable thead td{
  border-bottom:1px solid var(--pc-line-strong)!important}
table.dataTable.no-footer{border-bottom:1px solid var(--pc-line)!important}
table.dataTable tbody tr{background:transparent!important}
table.dataTable.stripe tbody tr.odd,
table.dataTable.display tbody tr.odd{background:rgba(255,255,255,.02)!important}
table.dataTable.hover tbody tr:hover,
table.dataTable.display tbody tr:hover{background:rgba(216,31,38,.07)!important}
table.dataTable thead .sorting:before,table.dataTable thead .sorting:after,
table.dataTable thead .sorting_asc:before,table.dataTable thead .sorting_asc:after,
table.dataTable thead .sorting_desc:before,table.dataTable thead .sorting_desc:after{
  opacity:.45;color:var(--pc-text-dim)}
table.dataTable thead .sorting_asc:before,
table.dataTable thead .sorting_desc:after{opacity:1;color:var(--pc-red)}
.dataTables_wrapper .dataTables_empty{color:var(--pc-text-dim);padding:18px;text-align:center}
