/*
   PastePanel UI v1 — own design system, no Tailwind dep
   All classes prefixed `pp-` to avoid conflicts with legacy.
    */

:root {
  --pp-bg:#fff; --pp-bg-1:#fafafa; --pp-bg-2:#f4f4f5; --pp-bg-hover:#f4f4f5;
  --pp-bd:#e4e4e7; --pp-bd-2:#d4d4d8;
  --pp-tx:#09090b; --pp-tx-2:#52525b; --pp-tx-3:#71717a; --pp-tx-4:#a1a1aa; --pp-tx-5:#d4d4d8;
  --pp-pri:#2563eb; --pp-pri-fg:#fff; --pp-pri-hover:#1d4ed8;
  --pp-pri-soft:rgba(37,99,235,.08); --pp-pri-bd:rgba(37,99,235,.25);
  --pp-danger:#ef4444; --pp-danger-bg:#fef2f2; --pp-danger-bd:#fecaca;
  --pp-success:#10b981; --pp-success-bg:#f0fdf4; --pp-success-bd:#bbf7d0;
  --pp-warn:#f59e0b; --pp-warn-bg:#fffbeb; --pp-warn-bd:#fde68a;
  --pp-info:#3b82f6; --pp-info-bg:#eff6ff; --pp-info-bd:#bfdbfe;
  --pp-r-sm:4px; --pp-r:6px; --pp-r-lg:8px; --pp-r-xl:12px; --pp-r-full:9999px;
  --pp-sh-1:0 1px 2px 0 rgb(0 0 0/.05);
  --pp-sh-2:0 4px 6px -1px rgb(0 0 0/.07),0 2px 4px -2px rgb(0 0 0/.05);
  --pp-sh-3:0 10px 15px -3px rgb(0 0 0/.1),0 4px 6px -4px rgb(0 0 0/.1);
  --pp-side-w:240px; --pp-hd-h:56px; --pp-bn-h:60px;
  --pp-font:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  --pp-fs-xs:11px; --pp-fs-sm:12.5px; --pp-fs-base:13.5px; --pp-fs-md:14px; --pp-fs-lg:16px; --pp-fs-xl:18px;
  --pp-trans:.15s cubic-bezier(.4,0,.2,1);
}

/* Base reset for chrome scope */
.pp-app, .pp-app *, .pp-app *::before, .pp-app *::after { box-sizing:border-box; }
.pp-app { font-family:var(--pp-font); -webkit-font-smoothing:antialiased; -webkit-tap-highlight-color:transparent; }

/* Layout: shell */
.pp-app { min-height:100vh; background:var(--pp-bg-1); color:var(--pp-tx); display:flex; }
.pp-main { flex:1; min-width:0; display:flex; flex-direction:column; min-height:100vh; }
@media (min-width:1024px) { .pp-main { margin-left:var(--pp-side-w); } }

/* Sidebar */
.pp-sidebar {
  position:fixed; inset:0 auto 0 0; z-index:50; width:var(--pp-side-w);
  background:var(--pp-bg); color:var(--pp-tx); display:flex; flex-direction:column;
  transform:translateX(-100%); transition:transform .22s ease-out;
  border-right:1px solid var(--pp-bd);
}
.pp-sidebar.is-open { transform:translateX(0); }
@media (min-width:1024px) { .pp-sidebar { transform:translateX(0); } }

.pp-sidebar__head {
  height:var(--pp-hd-h); flex-shrink:0; display:flex; align-items:center; justify-content:space-between;
  padding:0 16px; border-bottom:1px solid var(--pp-bd);
}
.pp-brand { display:flex; align-items:center; gap:10px; min-width:0; color:var(--pp-tx); text-decoration:none; }
.pp-brand__logo {
  width:30px; height:30px; flex-shrink:0; border-radius:var(--pp-r);
  background:linear-gradient(135deg,#2563eb,#1d4ed8); color:#fff;
  display:flex; align-items:center; justify-content:center; font-weight:700; font-size:12px;
}
.pp-brand__logo img { width:100%; height:100%; object-fit:contain; border-radius:inherit; }
.pp-brand__logo:has(img) { background:none; box-shadow:none; border-radius:0; }
.pp-brand__name { font-size:14px; font-weight:600; letter-spacing:-.01em; color:var(--pp-tx); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }

.pp-sidebar__nav {
  flex:1; overflow-y:auto; padding:8px 8px 12px; display:flex; flex-direction:column; gap:1px;
  scrollbar-width:thin; scrollbar-color:var(--pp-bd) transparent;
}
.pp-sidebar__nav::-webkit-scrollbar { width:5px; }
.pp-sidebar__nav::-webkit-scrollbar-thumb { background:var(--pp-bd); border-radius:5px; }

.pp-nav-section {
  padding:14px 10px 4px; font-size:10px; font-weight:600; color:var(--pp-tx-4);
  letter-spacing:.08em; text-transform:uppercase;
}
.pp-nav-section:first-of-type { padding-top:6px; }

.pp-nav-link {
  position:relative; display:flex; align-items:center; gap:10px;
  padding:7px 10px; border-radius:var(--pp-r); font-size:13px; color:var(--pp-tx-2);
  text-decoration:none; transition:background var(--pp-trans),color var(--pp-trans);
  cursor:pointer; line-height:1.2;
}
.pp-nav-link i { width:16px; text-align:center; font-size:12.5px; color:var(--pp-tx-3); transition:color var(--pp-trans); }
.pp-nav-link:hover { background:var(--pp-bg-2); color:var(--pp-tx); }
.pp-nav-link:hover i { color:var(--pp-pri); }
.pp-nav-link.is-active { background:var(--pp-pri-soft); color:var(--pp-pri); font-weight:500; }
.pp-nav-link.is-active i { color:var(--pp-pri); }
.pp-nav-link.is-active::before {
  content:''; position:absolute; left:-2px; top:6px; bottom:6px; width:2px;
  background:var(--pp-pri); border-radius:2px;
}

.pp-sidebar__foot { padding:8px; border-top:1px solid var(--pp-bd); }
.pp-user {
  display:flex; align-items:center; gap:10px; padding:8px;
  border-radius:var(--pp-r); text-decoration:none; transition:background var(--pp-trans);
}
.pp-user:hover { background:var(--pp-bg-2); }
.pp-user__avatar {
  width:32px; height:32px; border-radius:var(--pp-r-full); flex-shrink:0;
  background:linear-gradient(135deg,#2563eb,#1d4ed8); color:#fff;
  display:flex; align-items:center; justify-content:center; font-weight:600; font-size:11.5px;
}
.pp-user__info { flex:1; min-width:0; }
.pp-user__name { font-size:12.5px; font-weight:500; color:var(--pp-tx); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.pp-user__role { font-size:10.5px; color:var(--pp-tx-3); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.pp-user__chev { color:var(--pp-tx-4); font-size:9px; transition:color var(--pp-trans); }
.pp-user:hover .pp-user__chev { color:var(--pp-tx-2); }

/* Sidebar overlay (mobile) */
.pp-overlay {
  position:fixed; inset:0; z-index:40; background:rgba(0,0,0,.55);
  opacity:0; pointer-events:none; transition:opacity .2s;
}
.pp-overlay.is-open { opacity:1; pointer-events:auto; }
@media (min-width:1024px) { .pp-overlay { display:none; } }

/* Header */
.pp-header {
  position:sticky; top:0; z-index:30; height:var(--pp-hd-h); flex-shrink:0;
  display:flex; align-items:center; justify-content:space-between; gap:12px;
  padding:0 14px; background:var(--pp-bg); border-bottom:1px solid var(--pp-bd);
}
@media (min-width:640px) { .pp-header { padding:0 20px; } }

.pp-header__left { display:flex; align-items:center; gap:10px; min-width:0; flex:1; }
.pp-header__right { display:flex; align-items:center; gap:4px; }
.pp-header__title { font-size:14px; font-weight:600; color:var(--pp-tx); letter-spacing:-.01em; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }

.pp-header__divider { width:1px; height:20px; background:var(--pp-bd); margin:0 4px; }
@media (max-width:640px) { .pp-header__divider { display:none; } }

/* Icon Button */
.pp-iconbtn {
  display:inline-flex; align-items:center; justify-content:center;
  width:36px; height:36px; border-radius:var(--pp-r); border:none; background:transparent;
  color:var(--pp-tx-3); cursor:pointer; position:relative;
  transition:background var(--pp-trans),color var(--pp-trans);
  font-size:13px; padding:0; text-decoration:none;
}
.pp-iconbtn:hover { background:var(--pp-bg-2); color:var(--pp-tx); }
.pp-iconbtn--burger { display:none; }
@media (max-width:1023px) { .pp-iconbtn--burger { display:inline-flex; } }
.pp-iconbtn img { display:block; }

.pp-iconbtn__dot {
  position:absolute; top:8px; right:8px; width:7px; height:7px; border-radius:50%;
  background:var(--pp-danger); border:1.5px solid var(--pp-bg);
}

/* Avatar button */
.pp-avatarbtn {
  width:36px; height:36px; border-radius:var(--pp-r-full); border:none; background:transparent;
  cursor:pointer; padding:0; transition:box-shadow var(--pp-trans);
  display:inline-flex; align-items:center; justify-content:center;
}
.pp-avatarbtn:hover { box-shadow:0 0 0 2px var(--pp-bd); }
.pp-avatarbtn__img {
  width:32px; height:32px; border-radius:50%;
  background:linear-gradient(135deg,#18181b,#52525b);
  color:#fafafa; display:flex; align-items:center; justify-content:center;
  font-size:12px; font-weight:600;
}
.pp-avatarbtn__img { background:linear-gradient(135deg,#2563eb,#1d4ed8); color:#fff; }

/* Dropdown menu */
.pp-menu {
  position:absolute; right:0; top:calc(100% + 6px); min-width:180px;
  background:var(--pp-bg); border:1px solid var(--pp-bd); border-radius:var(--pp-r);
  box-shadow:var(--pp-sh-2); padding:4px; z-index:60;
  opacity:0; transform:translateY(-4px); pointer-events:none;
  transition:opacity .15s,transform .15s;
}
.pp-menu.is-open { opacity:1; transform:translateY(0); pointer-events:auto; }
/* Dropdown clipping fix: only activates while the menu is open, so normal layout is untouched */
.pp-card:has(.pp-menu.is-open){overflow:visible}

.pp-menu__heading { padding:8px 8px 4px; font-size:10px; font-weight:600; color:var(--pp-tx-4); text-transform:uppercase; letter-spacing:.06em; }
.pp-menu__userbox { padding:8px 8px 6px; }
.pp-menu__userbox p { margin:0; line-height:1.3; }
.pp-menu__name { font-size:13px; font-weight:500; color:var(--pp-tx); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.pp-menu__sub { font-size:11px; color:var(--pp-tx-3); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; margin-top:1px; }
.pp-menu__sep { height:1px; background:var(--pp-bd); margin:4px -4px; }

.pp-menu__item {
  display:flex; align-items:center; gap:8px; padding:7px 8px;
  border-radius:var(--pp-r-sm); font-size:13px; color:var(--pp-tx-2);
  text-decoration:none; cursor:pointer; border:none; background:transparent;
  width:100%; text-align:left; font-family:inherit; transition:background var(--pp-trans),color var(--pp-trans);
}
.pp-menu__item i { width:16px; text-align:center; color:var(--pp-tx-3); font-size:12px; }
.pp-menu__item:hover { background:var(--pp-bg-2); color:var(--pp-tx); }
.pp-menu__item.is-active { background:var(--pp-bg-2); color:var(--pp-tx); font-weight:500; }
.pp-menu__item--danger { color:var(--pp-danger); }
.pp-menu__item--danger i { color:var(--pp-danger); }
.pp-menu__item--danger:hover { background:var(--pp-danger-bg); color:var(--pp-danger); }

.pp-menu__check { margin-left:auto; color:var(--pp-tx-3); font-size:10px; }

/* Wrapper to position menu */
.pp-rel { position:relative; }

/* Mobile Bottom Nav */
.pp-bottomnav {
  position:fixed; left:0; right:0; bottom:0; z-index:30;
  height:calc(var(--pp-bn-h) + env(safe-area-inset-bottom,0));
  padding-bottom:env(safe-area-inset-bottom,0);
  background:var(--pp-bg); border-top:1px solid var(--pp-bd);
  display:grid; grid-template-columns:repeat(5,1fr);
}
@media (min-width:1024px) { .pp-bottomnav { display:none; } }
.pp-bn-item {
  display:flex; flex-direction:column; align-items:center; justify-content:center; gap:3px;
  padding:6px 4px; color:var(--pp-tx-3); cursor:pointer; position:relative;
  text-decoration:none; background:transparent; border:none; font-family:inherit;
  transition:color var(--pp-trans);
}
.pp-bn-item i { font-size:15px; line-height:1; }
.pp-bn-item span { font-size:10.5px; font-weight:500; }
.pp-bn-item:hover { color:var(--pp-pri); }
.pp-bn-item.is-active { color:var(--pp-pri); }
.pp-bn-item.is-active::before {
  content:''; position:absolute; top:0; left:50%; transform:translateX(-50%);
  width:24px; height:2px; background:var(--pp-pri); border-radius:0 0 2px 2px;
}

/* Content area padding */
.pp-content {
  flex:1; min-width:0; padding:14px;
}
@media (min-width:640px) { .pp-content { padding:18px; } }
@media (min-width:1024px) { .pp-content { padding:24px; } }

.pp-footer {
  display:none; padding:10px 24px; border-top:1px solid var(--pp-bd);
  text-align:center; font-size:11px; color:var(--pp-tx-4);
}
@media (min-width:1024px) { .pp-footer { display:block; } }

/* Loader */
.pp-loader { position:fixed; top:0; left:0; right:0; height:2px; z-index:9999; pointer-events:none; opacity:0; transition:opacity .2s; }
.pp-loader.is-active { opacity:1; }
.pp-loader__bar { height:100%; background:var(--pp-info); width:0; transition:width .3s; }

/* Toast */
.pp-toast {
  position:fixed; bottom:20px; right:16px; z-index:80;
  display:flex; align-items:center; gap:8px; padding:10px 14px;
  border-radius:var(--pp-r); font-size:12.5px; border:1px solid;
  box-shadow:var(--pp-sh-2); max-width:340px;
}
@media (min-width:1024px) { .pp-toast { bottom:24px; right:24px; } }
.pp-toast--success { background:var(--pp-success-bg); border-color:var(--pp-success-bd); color:#15803d; }
.pp-toast--error { background:var(--pp-danger-bg); border-color:var(--pp-danger-bd); color:#b91c1c; }
.pp-toast--info { background:var(--pp-info-bg); border-color:var(--pp-info-bd); color:#1d4ed8; }
.pp-toast__close { margin-left:auto; background:transparent; border:none; font-size:16px; line-height:1; opacity:.6; cursor:pointer; color:inherit; }
.pp-toast__close:hover { opacity:1; }

/* Lock body scroll when sidebar open */
body.pp-locked { overflow:hidden; }

   Content components — for admin page bodies
    */

/* Layout utilities (minimal) */
.pp-flex{display:flex}.pp-inline-flex{display:inline-flex}.pp-grid{display:grid}.pp-block{display:block}.pp-inline-block{display:inline-block}.pp-hidden{display:none!important}
.pp-flex-col{flex-direction:column}.pp-flex-row{flex-direction:row}.pp-flex-wrap{flex-wrap:wrap}
.pp-flex-1{flex:1}.pp-flex-none{flex:none}.pp-grow{flex-grow:1}.pp-shrink-0{flex-shrink:0}
.pp-items-start{align-items:flex-start}.pp-items-center{align-items:center}.pp-items-end{align-items:flex-end}
.pp-justify-start{justify-content:flex-start}.pp-justify-center{justify-content:center}.pp-justify-end{justify-content:flex-end}.pp-justify-between{justify-content:space-between}
.pp-gap-1{gap:4px}.pp-gap-2{gap:8px}.pp-gap-3{gap:12px}.pp-gap-4{gap:16px}.pp-gap-5{gap:20px}.pp-gap-6{gap:24px}
.pp-mt-1{margin-top:4px}.pp-mt-2{margin-top:8px}.pp-mt-3{margin-top:12px}.pp-mt-4{margin-top:16px}.pp-mt-6{margin-top:24px}
.pp-mb-1{margin-bottom:4px}.pp-mb-2{margin-bottom:8px}.pp-mb-3{margin-bottom:12px}.pp-mb-4{margin-bottom:16px}.pp-mb-6{margin-bottom:24px}
.pp-w-full{width:100%}.pp-h-full{height:100%}
.pp-min-w-0{min-width:0}
.pp-text-left{text-align:left}.pp-text-center{text-align:center}.pp-text-right{text-align:right}
.pp-truncate{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.pp-grid-cols-1{grid-template-columns:1fr}
.pp-grid-cols-2{grid-template-columns:repeat(2,1fr)}
.pp-grid-cols-3{grid-template-columns:repeat(3,1fr)}
.pp-grid-cols-4{grid-template-columns:repeat(4,1fr)}
@media(min-width:640px){.pp-sm\:grid-cols-2{grid-template-columns:repeat(2,1fr)}.pp-sm\:grid-cols-3{grid-template-columns:repeat(3,1fr)}.pp-sm\:grid-cols-4{grid-template-columns:repeat(4,1fr)}}
@media(min-width:1024px){.pp-lg\:grid-cols-2{grid-template-columns:repeat(2,1fr)}.pp-lg\:grid-cols-3{grid-template-columns:repeat(3,1fr)}.pp-lg\:grid-cols-4{grid-template-columns:repeat(4,1fr)}.pp-lg\:flex-row{flex-direction:row}.pp-lg\:hidden{display:none}.pp-lg\:block{display:block}.pp-lg\:flex{display:flex}}

/* Typography */
.pp-h1{font-size:22px;font-weight:600;letter-spacing:-.015em;color:var(--pp-tx);line-height:1.2;margin:0}
.pp-h2{font-size:18px;font-weight:600;letter-spacing:-.01em;color:var(--pp-tx);line-height:1.3;margin:0}
.pp-h3{font-size:15px;font-weight:600;color:var(--pp-tx);line-height:1.3;margin:0}
.pp-h4{font-size:13.5px;font-weight:600;color:var(--pp-tx);margin:0}
.pp-text-xs{font-size:11px}.pp-text-sm{font-size:12.5px}.pp-text-base{font-size:13.5px}.pp-text-md{font-size:14px}.pp-text-lg{font-size:16px}
.pp-font-medium{font-weight:500}.pp-font-semibold{font-weight:600}.pp-font-bold{font-weight:700}
.pp-text-muted{color:var(--pp-tx-3)}.pp-text-subtle{color:var(--pp-tx-4)}.pp-text-strong{color:var(--pp-tx)}
.pp-text-success{color:var(--pp-success)}.pp-text-danger{color:var(--pp-danger)}.pp-text-warn{color:var(--pp-warn)}.pp-text-info{color:var(--pp-info)}
.pp-mono{font-family:'SF Mono',Menlo,Monaco,Consolas,monospace;font-size:12px}

/* Page header */
.pp-page-head{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;flex-wrap:wrap;margin-bottom:18px}
.pp-page-head__main{min-width:0}
.pp-page-head__title{font-size:22px;font-weight:600;letter-spacing:-.015em;color:var(--pp-tx);margin:0;line-height:1.2}
.pp-page-head__sub{font-size:13px;color:var(--pp-tx-3);margin-top:4px}
.pp-page-head__actions{display:flex;gap:8px;flex-wrap:wrap}

/* Card */
.pp-card{background:var(--pp-bg);border:1px solid var(--pp-bd);border-radius:var(--pp-r-lg);overflow:hidden}
.pp-card__head{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 18px;border-bottom:1px solid var(--pp-bd)}
.pp-card__head--sm{padding:10px 14px}
.pp-card__title{font-size:14px;font-weight:600;color:var(--pp-tx);margin:0;letter-spacing:-.01em}
.pp-card__sub{font-size:12px;color:var(--pp-tx-3);margin-top:2px}
.pp-card__body{padding:18px}
.pp-card__body--sm{padding:14px}
.pp-card__body--md{padding:20px}
.pp-card__body--none{padding:0}
.pp-card__foot{padding:12px 18px;border-top:1px solid var(--pp-bd);display:flex;align-items:center;justify-content:space-between;gap:12px;background:var(--pp-bg-1)}

/* Stats grid */
.pp-stats{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}
@media(min-width:640px){.pp-stats{grid-template-columns:repeat(4,1fr)}}
.pp-stat{padding:14px 16px;background:var(--pp-bg);border:1px solid var(--pp-bd);border-radius:var(--pp-r-lg)}
.pp-stat__label{font-size:11.5px;font-weight:500;color:var(--pp-tx-3);text-transform:uppercase;letter-spacing:.04em;margin-bottom:6px}
.pp-stat__value{font-size:22px;font-weight:600;color:var(--pp-tx);letter-spacing:-.015em;line-height:1.1}
.pp-stat__delta{font-size:11.5px;color:var(--pp-tx-3);margin-top:4px;display:inline-flex;align-items:center;gap:4px}
.pp-stat__delta--up{color:var(--pp-success)}
.pp-stat__delta--down{color:var(--pp-danger)}
.pp-stat__icon{float:right;width:32px;height:32px;border-radius:var(--pp-r);background:var(--pp-bg-2);display:inline-flex;align-items:center;justify-content:center;color:var(--pp-tx-3);font-size:13px;margin-left:8px}

/* Buttons */
.pp-btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:0 14px;height:36px;font-size:13px;font-weight:500;font-family:inherit;border-radius:var(--pp-r);border:1px solid transparent;cursor:pointer;text-decoration:none;transition:background var(--pp-trans),color var(--pp-trans),border-color var(--pp-trans);white-space:nowrap;line-height:1}
.pp-btn:disabled{opacity:.5;cursor:not-allowed}
.pp-btn--sm{height:30px;padding:0 10px;font-size:12px;gap:5px}
.pp-btn--lg{height:42px;padding:0 18px;font-size:14px}
.pp-btn--icon{width:36px;padding:0}
.pp-btn--icon-sm{width:30px;height:30px;padding:0}
.pp-btn--block{width:100%}
.pp-btn--primary{background:var(--pp-pri);color:var(--pp-pri-fg);border-color:var(--pp-pri)}
.pp-btn--primary:hover:not(:disabled){background:var(--pp-pri-hover);border-color:var(--pp-pri-hover)}
.pp-btn--secondary{background:var(--pp-bg-2);color:var(--pp-tx);border-color:var(--pp-bd)}
.pp-btn--secondary:hover:not(:disabled){background:var(--pp-bd)}
.pp-btn--outline{background:transparent;color:var(--pp-tx);border-color:var(--pp-bd)}
.pp-btn--outline:hover:not(:disabled){background:var(--pp-bg-2)}
.pp-btn--ghost{background:transparent;color:var(--pp-tx-2);border-color:transparent}
.pp-btn--ghost:hover:not(:disabled){background:var(--pp-bg-2);color:var(--pp-tx)}
.pp-btn--danger{background:var(--pp-danger);color:#fff;border-color:var(--pp-danger)}
.pp-btn--danger:hover:not(:disabled){background:#dc2626;border-color:#dc2626}
.pp-btn--danger-outline{background:transparent;color:var(--pp-danger);border-color:var(--pp-danger-bd)}
.pp-btn--danger-outline:hover:not(:disabled){background:var(--pp-danger-bg)}
.pp-btn--success{background:var(--pp-success);color:#fff;border-color:var(--pp-success)}
.pp-btn--success:hover:not(:disabled){background:#059669;border-color:#059669}

/* Form fields */
.pp-field{display:flex;flex-direction:column;gap:6px;min-width:0}
.pp-label{font-size:13px;font-weight:500;color:var(--pp-tx-2);line-height:1.3}
.pp-label--req::after{content:' *';color:var(--pp-danger)}
.pp-help{font-size:11.5px;color:var(--pp-tx-3);line-height:1.4}
.pp-input,.pp-select,.pp-textarea{
  width:100%;padding:0 12px;height:36px;font-size:13px;font-family:inherit;
  border:1px solid var(--pp-bd);border-radius:var(--pp-r);background:var(--pp-bg);color:var(--pp-tx);
  transition:border-color var(--pp-trans),box-shadow var(--pp-trans);
}
.pp-textarea{height:auto;padding:8px 12px;line-height:1.5;resize:vertical;min-height:80px}
.pp-input::placeholder,.pp-textarea::placeholder{color:var(--pp-tx-4)}
.pp-input:focus,.pp-select:focus,.pp-textarea:focus{outline:none;border-color:var(--pp-pri);box-shadow:0 0 0 1px var(--pp-pri)}
.pp-input--sm{height:30px;font-size:12px;padding:0 10px}
.pp-select{appearance:none;-webkit-appearance:none;padding-right:30px;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%2371717a' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 8px center}

/* Search input with icon */
.pp-search{position:relative}
.pp-search__icon{position:absolute;left:10px;top:50%;transform:translateY(-50%);color:var(--pp-tx-4);font-size:12px;pointer-events:none}
.pp-search .pp-input{padding-left:32px}

/* Checkbox / Radio */
.pp-cb,.pp-radio{-webkit-appearance:none;appearance:none;width:16px;height:16px;border:1px solid var(--pp-bd-2);background:var(--pp-bg);cursor:pointer;flex-shrink:0;position:relative;transition:.15s}
.pp-cb{border-radius:4px}.pp-radio{border-radius:50%}
.pp-cb:checked,.pp-radio:checked{background:var(--pp-pri);border-color:var(--pp-pri)}
.pp-cb:checked::after{content:'';position:absolute;left:4px;top:1px;width:4px;height:8px;border:solid var(--pp-pri-fg);border-width:0 2px 2px 0;transform:rotate(45deg)}
.pp-radio:checked::after{content:'';position:absolute;left:50%;top:50%;width:6px;height:6px;background:var(--pp-pri-fg);border-radius:50%;transform:translate(-50%,-50%)}

/* Switch */
.pp-switch{position:relative;display:inline-block;width:36px;height:20px;flex-shrink:0}
.pp-switch input{position:absolute;opacity:0;width:0;height:0}
.pp-switch__bg{position:absolute;inset:0;background:var(--pp-bd);border-radius:11px;transition:background var(--pp-trans);cursor:pointer}
.pp-switch__bg::before{content:'';position:absolute;left:2px;top:2px;width:16px;height:16px;background:#fff;border-radius:50%;box-shadow:var(--pp-sh-1);transition:transform var(--pp-trans)}
.pp-switch input:checked+.pp-switch__bg{background:var(--pp-pri)}
.pp-switch input:checked+.pp-switch__bg::before{transform:translateX(16px)}

/* Tables */
.pp-table{width:100%;border-collapse:collapse;font-size:13px}
.pp-table thead th{text-align:left;padding:10px 14px;font-size:11px;font-weight:600;color:var(--pp-tx-3);text-transform:uppercase;letter-spacing:.04em;background:var(--pp-bg-1);border-bottom:1px solid var(--pp-bd);white-space:nowrap}
.pp-table tbody td{padding:11px 14px;border-bottom:1px solid var(--pp-bd);color:var(--pp-tx-2);vertical-align:middle}
.pp-table tbody tr:last-child td{border-bottom:none}
.pp-table tbody tr:hover{background:var(--pp-bg-1)}
.pp-table--compact tbody td,.pp-table--compact thead th{padding:8px 12px}
.pp-table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}

/* Badges / Pills */
.pp-badge{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;font-size:11px;font-weight:500;border-radius:var(--pp-r-full);border:1px solid transparent;line-height:1.4;white-space:nowrap}
.pp-badge--neutral{background:var(--pp-bg-2);color:var(--pp-tx-2);border-color:var(--pp-bd)}
.pp-badge--success{background:transparent;color:#16a34a;border-color:#bbf7d0}
.pp-badge--danger{background:transparent;color:#dc2626;border-color:#fecaca}
.pp-badge--warn{background:transparent;color:#d97706;border-color:#fde68a}
.pp-badge--info{background:transparent;color:#2563eb;border-color:#bfdbfe}
.pp-dot{display:inline-block;width:7px;height:7px;border-radius:50%;flex-shrink:0}
.pp-dot--success{background:var(--pp-success)}.pp-dot--danger{background:var(--pp-danger)}.pp-dot--warn{background:var(--pp-warn)}.pp-dot--info{background:var(--pp-info)}.pp-dot--neutral{background:var(--pp-tx-4)}

/* Tabs */
.pp-tabs{display:flex;gap:2px;border-bottom:1px solid var(--pp-bd);overflow-x:auto;-webkit-overflow-scrolling:touch}
.pp-tab{display:inline-flex;align-items:center;gap:6px;padding:9px 14px;font-size:13px;font-weight:500;color:var(--pp-tx-3);text-decoration:none;cursor:pointer;background:transparent;border:none;font-family:inherit;border-bottom:2px solid transparent;margin-bottom:-1px;transition:color var(--pp-trans),border-color var(--pp-trans);white-space:nowrap}
.pp-tab:hover{color:var(--pp-tx)}
.pp-tab.is-active{color:var(--pp-tx);border-bottom-color:var(--pp-tx)}
.pp-tab__count{font-size:10.5px;background:var(--pp-bg-2);color:var(--pp-tx-3);padding:1px 6px;border-radius:var(--pp-r-full)}

/* Modal */
.pp-modal-backdrop{position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:90;opacity:0;pointer-events:none;transition:opacity .15s;display:flex;align-items:center;justify-content:center;padding:16px}
.pp-modal-backdrop.is-open{opacity:1;pointer-events:auto}
.pp-modal{background:var(--pp-bg);border:1px solid var(--pp-bd);border-radius:var(--pp-r-lg);box-shadow:var(--pp-sh-3);width:100%;max-width:480px;max-height:calc(100vh - 32px);display:flex;flex-direction:column;transform:translateY(8px);transition:transform .15s}
.pp-modal-backdrop.is-open .pp-modal{transform:translateY(0)}
.pp-modal--sm{max-width:380px}
.pp-modal--lg{max-width:680px}
.pp-modal--xl{max-width:880px}
.pp-modal__head{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 18px;border-bottom:1px solid var(--pp-bd)}
.pp-modal__title{font-size:15px;font-weight:600;color:var(--pp-tx);margin:0;letter-spacing:-.01em}
.pp-modal__close{background:transparent;border:none;width:30px;height:30px;border-radius:var(--pp-r);color:var(--pp-tx-3);cursor:pointer;display:inline-flex;align-items:center;justify-content:center;font-size:13px;transition:background var(--pp-trans),color var(--pp-trans)}
.pp-modal__close:hover{background:var(--pp-bg-2);color:var(--pp-tx)}
.pp-modal__body{padding:18px;overflow-y:auto;flex:1}
.pp-modal__foot{padding:12px 18px;border-top:1px solid var(--pp-bd);display:flex;align-items:center;justify-content:flex-end;gap:8px;background:var(--pp-bg-1)}

/* Empty state */
.pp-empty{text-align:center;padding:48px 24px;color:var(--pp-tx-3)}
.pp-empty__icon{font-size:32px;margin-bottom:12px;color:var(--pp-tx-4)}
.pp-empty__title{font-size:14px;font-weight:600;color:var(--pp-tx);margin-bottom:4px}
.pp-empty__sub{font-size:12.5px;color:var(--pp-tx-3);margin-bottom:14px}

/* Pagination */
.pp-pagination{display:inline-flex;gap:2px;align-items:center}
.pp-pagination__btn{display:inline-flex;align-items:center;justify-content:center;min-width:32px;height:32px;padding:0 8px;font-size:12.5px;color:var(--pp-tx-2);background:var(--pp-bg);border:1px solid var(--pp-bd);border-radius:var(--pp-r);text-decoration:none;cursor:pointer;font-family:inherit;transition:background var(--pp-trans)}
.pp-pagination__btn:hover{background:var(--pp-bg-2)}
.pp-pagination__btn.is-active{background:var(--pp-pri);color:var(--pp-pri-fg);border-color:var(--pp-pri)}
.pp-pagination__btn:disabled{opacity:.4;cursor:not-allowed}

/* Alert */
.pp-alert{display:flex;align-items:flex-start;gap:10px;padding:12px 14px;border-radius:var(--pp-r);font-size:12.5px;border:1px solid;line-height:1.5}
.pp-alert i{font-size:13px;margin-top:1px;flex-shrink:0}
.pp-alert--success{background:var(--pp-success-bg);border-color:var(--pp-success-bd);color:#15803d}
.pp-alert--danger{background:var(--pp-danger-bg);border-color:var(--pp-danger-bd);color:#b91c1c}
.pp-alert--warn{background:var(--pp-warn-bg);border-color:var(--pp-warn-bd);color:#a16207}
.pp-alert--info{background:var(--pp-info-bg);border-color:var(--pp-info-bd);color:#1d4ed8}

/* Avatar (generic) */
.pp-avatar{display:inline-flex;align-items:center;justify-content:center;border-radius:50%;background:var(--pp-bg-2);color:var(--pp-tx-2);font-weight:600;font-size:12px;flex-shrink:0;overflow:hidden}
.pp-avatar img{width:100%;height:100%;object-fit:cover}
.pp-avatar--xs{width:20px;height:20px;font-size:9px}
.pp-avatar--sm{width:28px;height:28px;font-size:11px}
.pp-avatar--md{width:36px;height:36px;font-size:13px}
.pp-avatar--lg{width:48px;height:48px;font-size:16px}

/* Skeleton loading */
.pp-skeleton{background:linear-gradient(90deg,var(--pp-bg-2) 0%,var(--pp-bg-hover) 50%,var(--pp-bg-2) 100%);background-size:200% 100%;animation:pp-shimmer 1.4s linear infinite;border-radius:var(--pp-r-sm)}
@keyframes pp-shimmer{0%{background-position:200% 0}100%{background-position:-200% 0}}

/* Divider */
.pp-divider{height:1px;background:var(--pp-bd);margin:12px 0}
.pp-divider--vertical{width:1px;height:auto;align-self:stretch;margin:0 8px}

   pp-combo — Custom dropdown (replaces native <select>)
   Progressive enhancement: native <select> stays in DOM (form
   submit), JS hides it and renders polished UI.
    */
.pp-combo{position:relative;display:block;width:100%}
.pp-combo > select{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
.pp-combo__btn{
  display:flex;align-items:center;gap:8px;width:100%;height:36px;
  padding:0 32px 0 12px;font-size:13px;font-family:inherit;
  border:1px solid var(--pp-bd);background:var(--pp-bg);color:var(--pp-tx);
  border-radius:var(--pp-r);cursor:pointer;text-align:left;position:relative;
  transition:border-color var(--pp-trans),box-shadow var(--pp-trans);
}
.pp-combo__btn:hover{border-color:var(--pp-bd-2)}
.pp-combo__btn:focus,.pp-combo.is-open .pp-combo__btn{outline:none;border-color:var(--pp-pri);box-shadow:0 0 0 1px var(--pp-pri)}
.pp-combo__btn--sm{height:30px;font-size:12px;padding:0 28px 0 10px}
.pp-combo__btn--lg{height:42px;font-size:14px;padding:0 36px 0 14px}
.pp-combo__btn:disabled{opacity:.5;cursor:not-allowed;background:var(--pp-bg-1)}
.pp-combo__icon{flex-shrink:0;font-size:14px;color:var(--pp-tx-3);line-height:1;display:inline-flex;align-items:center}
.pp-combo__label{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.pp-combo__label.is-placeholder{color:var(--pp-tx-4)}
.pp-combo__chev{position:absolute;right:10px;top:50%;transform:translateY(-50%);color:var(--pp-tx-3);font-size:10px;transition:transform var(--pp-trans);pointer-events:none}
.pp-combo.is-open .pp-combo__chev{transform:translateY(-50%) rotate(180deg)}
.pp-combo__clear{position:absolute;right:28px;top:50%;transform:translateY(-50%);width:16px;height:16px;border-radius:50%;background:transparent;border:0;color:var(--pp-tx-4);cursor:pointer;display:none;align-items:center;justify-content:center;font-size:9px;padding:0;transition:.12s}
.pp-combo__clear:hover{background:var(--pp-bg-2);color:var(--pp-tx)}
.pp-combo.has-value .pp-combo__clear{display:inline-flex}

.pp-combo__panel{
  position:absolute;left:0;right:0;top:calc(100% + 4px);z-index:70;
  background:var(--pp-bg);border:1px solid var(--pp-bd);border-radius:var(--pp-r);
  box-shadow:var(--pp-sh-2);overflow:hidden;display:none;min-width:max-content;max-width:calc(100vw - 32px);
  opacity:0;transform:translateY(-4px);transition:opacity .12s,transform .12s;
}
.pp-combo.is-open .pp-combo__panel{display:block;opacity:1;transform:translateY(0)}
.pp-combo--up.is-open .pp-combo__panel{top:auto;bottom:calc(100% + 4px);transform:translateY(4px)}
.pp-combo--up.is-open .pp-combo__panel{transform:translateY(0)}

.pp-combo__search{padding:6px;border-bottom:1px solid var(--pp-bd);position:relative;background:var(--pp-bg)}
.pp-combo__search i{position:absolute;left:16px;top:50%;transform:translateY(-50%);color:var(--pp-tx-4);font-size:11px;pointer-events:none}
.pp-combo__search input{width:100%;height:30px;padding:0 10px 0 28px;font-size:12.5px;border:1px solid var(--pp-bd);background:var(--pp-bg-1);border-radius:var(--pp-r-sm);color:var(--pp-tx);font-family:inherit}
.pp-combo__search input:focus{outline:none;border-color:var(--pp-pri);box-shadow:0 0 0 1px var(--pp-pri)}

.pp-combo__list{max-height:240px;overflow-y:auto;padding:4px;scrollbar-width:thin}
.pp-combo__list::-webkit-scrollbar{width:6px}
.pp-combo__list::-webkit-scrollbar-thumb{background:var(--pp-bd-2);border-radius:6px}

.pp-combo__group{padding:8px 8px 4px 10px;font-size:10px;font-weight:600;color:var(--pp-tx-4);text-transform:uppercase;letter-spacing:.06em;user-select:none}
.pp-combo__group:not(:first-child){margin-top:6px;border-top:1px solid var(--pp-bd);padding-top:10px}

.pp-combo__option{
  display:flex;align-items:center;gap:8px;padding:7px 8px;
  font-size:13px;color:var(--pp-tx-2);cursor:pointer;
  background:transparent;border:0;width:100%;text-align:left;font-family:inherit;
  border-radius:var(--pp-r-sm);transition:background var(--pp-trans),color var(--pp-trans);
  line-height:1.3;
}
.pp-combo__option:hover,.pp-combo__option.is-cursor{background:var(--pp-bg-2);color:var(--pp-tx)}
.pp-combo__option.is-selected{background:rgba(14,165,233,.08);color:#0284c7;font-weight:500}
.pp-combo__option:disabled{opacity:.4;cursor:not-allowed}
.pp-combo__option-text{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.pp-combo__option-tick{margin-left:auto;color:#0284c7;font-size:10px;display:none;flex-shrink:0}
.pp-combo__option.is-selected .pp-combo__option-tick{display:inline}
.pp-combo__option-prefix{flex-shrink:0;width:18px;display:inline-flex;align-items:center;justify-content:center;font-size:13px;line-height:1}

.pp-combo__empty{padding:18px 12px;font-size:12px;color:var(--pp-tx-4);text-align:center}

/* Multi-select */
.pp-combo--multi.has-value .pp-combo__btn{padding-left:6px}
.pp-combo__chips{display:flex;flex-wrap:wrap;gap:4px;flex:1;min-width:0;overflow:hidden}
.pp-combo__chip{display:inline-flex;align-items:center;gap:5px;padding:2px 4px 2px 8px;font-size:11.5px;background:var(--pp-bg-2);border-radius:var(--pp-r-sm);color:var(--pp-tx);max-width:140px}
.pp-combo__chip span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.pp-combo__chip button{width:14px;height:14px;border:0;background:transparent;color:var(--pp-tx-3);font-size:9px;cursor:pointer;border-radius:50%;display:inline-flex;align-items:center;justify-content:center}
.pp-combo__chip button:hover{background:var(--pp-bd-2);color:var(--pp-tx)}

/* ── Dark mode ─────────────────────────────────────────────── */
html[data-theme="dark"] {
  --pp-bg:#09090b; --pp-bg-1:#09090b; --pp-bg-2:#18181b; --pp-bg-hover:#18181b;
  --pp-bd:#27272a; --pp-bd-2:#3f3f46;
  --pp-tx:#fafafa; --pp-tx-2:#e4e4e7; --pp-tx-3:#a1a1aa; --pp-tx-4:#71717a; --pp-tx-5:#52525b;
  --pp-danger-bg:rgba(239,68,68,.1); --pp-danger-bd:rgba(239,68,68,.25);
  --pp-success-bg:rgba(16,185,129,.1); --pp-success-bd:rgba(16,185,129,.25);
  --pp-warn-bg:rgba(245,158,11,.1); --pp-warn-bd:rgba(245,158,11,.25);
  --pp-info-bg:rgba(59,130,246,.1); --pp-info-bd:rgba(59,130,246,.25);
  --pp-pri-soft:rgba(37,99,235,.15); --pp-pri-bd:rgba(37,99,235,.35);
}
html[data-theme="dark"] .pp-app { background:var(--pp-bg-1); }
html[data-theme="dark"] .pp-card { background:var(--pp-bg-2) !important; border-color:var(--pp-bd) !important; }
html[data-theme="dark"] .pp-modal__body { background:var(--pp-bg-2); }
html[data-theme="dark"] .pp-modal__head,
html[data-theme="dark"] .pp-modal__foot { border-color:var(--pp-bd); }
html[data-theme="dark"] .pp-input,
html[data-theme="dark"] .pp-textarea,
html[data-theme="dark"] .pp-select { background:var(--pp-bg-2); border-color:var(--pp-bd); color:var(--pp-tx); }
html[data-theme="dark"] .pp-input::placeholder,
html[data-theme="dark"] .pp-textarea::placeholder { color:var(--pp-tx-5); }
html[data-theme="dark"] .pp-menu { background:var(--pp-bg-2); border-color:var(--pp-bd); }
html[data-theme="dark"] .pp-menu__userbox { border-color:var(--pp-bd); }
html[data-theme="dark"] .pp-table thead th { border-bottom-color:var(--pp-bd); }
html[data-theme="dark"] .pp-table tbody td { border-bottom-color:var(--pp-bd); }
html[data-theme="dark"] .pp-table tbody tr:hover td { background:var(--pp-bg-hover); }
html[data-theme="dark"] .pp-footer { border-top-color:var(--pp-bd); }
html[data-theme="dark"] .pp-badge--outline { border-color:var(--pp-bd-2); color:var(--pp-tx-3); }
