/* ============================================================
   Creator Portal — spațiul de lucru al creatorului + admin.
   Reutilizează tokenii din style.css (paper/ink, signal).
   4 suprafețe: Înregistrare · Portal creator · Profil public · Admin.
   ============================================================ */

:root {
  /* statusuri rare — aceeași cromă ca --signal, hue variat */
  --pending:    oklch(0.70 0.072 75);
  --pending-bg: oklch(0.955 0.022 75);
  --danger:     oklch(0.58 0.072 25);
  --danger-bg:  oklch(0.955 0.020 25);
  --sidebar-w:  248px;
}
[data-theme="dark"] {
  --pending-bg: oklch(0.27 0.03 75);
  --danger-bg:  oklch(0.27 0.03 25);
}

body.cp-body { background: var(--paper-2); }

/* ===================== DEMO NAVIGATOR ===================== */
.demo-bar {
  position: sticky; top: 0; z-index: 200;
  display: flex; align-items: center; gap: 18px;
  height: 56px; padding: 0 18px;
  background: oklch(0.205 0.012 70); color: var(--paper);
  border-bottom: 1px solid oklch(1 0 0 / .08);
}
[data-theme="dark"] .demo-bar { background: oklch(0.13 0.005 80); }
.db-brand {
  display: flex; align-items: center; gap: 9px;
  font-weight: 700; font-size: 14px; letter-spacing: -0.01em;
  color: oklch(1 0 0 / .92); white-space: nowrap;
}
.db-brand .mark {
  width: 24px; height: 24px; border-radius: 6px; background: var(--paper);
  display: grid; place-items: center; color: var(--ink);
  font-family: var(--ff-mono); font-size: 11px; font-weight: 600;
}
.db-tag {
  font-family: var(--ff-mono); font-size: 9px; letter-spacing: .14em;
  padding: 3px 7px; border-radius: 100px;
  background: oklch(1 0 0 / .12); color: oklch(1 0 0 / .7);
}
.db-switch {
  display: flex; gap: 2px; margin-left: auto;
  background: oklch(1 0 0 / .08); padding: 3px; border-radius: 100px;
}
.db-switch button {
  font-family: var(--ff-sans); font-size: 12.5px; font-weight: 600;
  color: oklch(1 0 0 / .62); background: none; border: none; cursor: pointer;
  padding: 7px 15px; border-radius: 100px; transition: all .18s; white-space: nowrap;
}
.db-switch button:hover { color: oklch(1 0 0 / .95); }
.db-switch button.active { background: var(--paper); color: var(--ink); }
.db-theme {
  background: oklch(1 0 0 / .1); border: none; cursor: pointer;
  width: 36px; height: 36px; border-radius: 9px; color: var(--paper);
  display: grid; place-items: center; transition: background .18s;
}
.db-theme:hover { background: oklch(1 0 0 / .18); }
.db-theme svg { width: 16px; height: 16px; }
.db-theme .ic-sun { display: none; }
[data-theme="dark"] .db-theme .ic-moon { display: none; }
[data-theme="dark"] .db-theme .ic-sun { display: block; }

/* views */
.cp-view { display: none; }
.cp-view.active { display: block; animation: cpFade .3s ease; }
@keyframes cpFade { from { transform: translateY(6px); } to { transform: none; } }

/* ===================== INREGISTRARE ===================== */
.cp-auth { min-height: calc(100vh - 56px); display: grid; grid-template-columns: 1fr 1fr; }
@media (max-width: 900px) { .cp-auth { grid-template-columns: 1fr; } }

.cp-auth-aside {
  background: oklch(0.205 0.012 70); color: oklch(0.985 0.004 80);
  padding: clamp(40px, 6vw, 80px) clamp(32px, 5vw, 64px);
  display: flex; flex-direction: column; justify-content: space-between;
  position: relative; overflow: hidden;
}
[data-theme="dark"] .cp-auth-aside { background: oklch(0.13 0.005 80); border-right: 1px solid var(--line); }
.cp-auth-aside .kicker { color: oklch(1 0 0 / .55); }
.cp-auth-aside .kicker .dot { background: var(--signal); }
.cp-auth-aside h1 {
  font-size: clamp(34px, 4vw, 52px); font-weight: 800;
  letter-spacing: -0.035em; line-height: 1.04; margin-top: 20px; max-width: 13ch;
}
.cp-auth-aside h1 em { font-style: normal; color: oklch(1 0 0 / .45); }
.cp-auth-aside .lead { color: oklch(1 0 0 / .72); font-size: 16px; line-height: 1.6; max-width: 38ch; margin-top: 18px; }
.cp-auth-points { display: flex; flex-direction: column; gap: 16px; margin-top: 40px; }
.cp-auth-points li { list-style: none; display: flex; gap: 12px; align-items: flex-start; color: oklch(1 0 0 / .82); font-size: 14.5px; line-height: 1.45; }
.cp-auth-points .ic {
  flex: none; width: 26px; height: 26px; border-radius: 7px;
  background: oklch(1 0 0 / .1); color: var(--signal);
  display: grid; place-items: center; font-size: 13px; margin-top: 1px;
}
.cp-auth-foot { font-family: var(--ff-mono); font-size: 11px; letter-spacing: .06em; color: oklch(1 0 0 / .4); margin-top: 40px; }

.cp-auth-main { padding: clamp(32px, 5vw, 64px) clamp(24px, 5vw, 72px); display: flex; align-items: flex-start; }
.cp-auth-form { width: 100%; max-width: 560px; margin: 0 auto; }

/* ---------- consents (GDPR) ---------- */
.cr-consents { display: flex; flex-direction: column; gap: 12px; margin-top: 24px; padding: 16px 18px; border: 1px solid var(--line); border-radius: 12px; background: var(--paper-2); }
.cr-consent { display: flex; gap: 11px; align-items: flex-start; font-size: 13px; color: var(--ink-2); line-height: 1.5; cursor: pointer; }
.cr-consent input { width: 17px; height: 17px; margin-top: 1px; flex: none; accent-color: var(--signal); }
.cr-consent a { color: var(--ink); text-decoration: underline; text-underline-offset: 2px; }
.cr-consent i { color: var(--signal); font-style: normal; }
.cr-consent em { color: var(--muted); font-style: normal; }

/* ---------- login form ---------- */
.cp-login-form { max-width: 420px; align-self: center; }
.cp-auth-main:has(.cp-login-form) { align-items: center; }
.cp-login-passrow { display: flex; align-items: baseline; justify-content: space-between; gap: 12px; margin-bottom: 7px; }
.cp-login-forgot { font-size: 13px; color: var(--signal); text-decoration: none; }
.cp-login-forgot:hover { text-decoration: underline; }
.cp-login-remember { display: flex; align-items: center; gap: 9px; margin-top: 16px; font-size: 14px; color: var(--ink-2); cursor: pointer; }
.cp-login-remember input { width: 16px; height: 16px; accent-color: var(--signal); }
.cp-login-alt { margin-top: 22px; padding-top: 20px; border-top: 1px solid var(--line); font-size: 14px; color: var(--ink-2); text-align: center; }
.cp-login-alt a { color: var(--ink); font-weight: 600; text-decoration: none; }
.cp-login-alt a:hover { text-decoration: underline; }
.cp-auth-form > h2 { font-size: 26px; font-weight: 800; letter-spacing: -0.02em; }
.cp-auth-form > .sub { color: var(--ink-2); font-size: 15px; margin-top: 6px; line-height: 1.5; }

.cp-fset { border: none; padding: 0; margin: 30px 0 0; }
.cp-fset-h { display: flex; align-items: baseline; gap: 10px; margin-bottom: 16px; }
.cp-fset-h .n {
  font-family: var(--ff-mono); font-size: 11px; color: var(--paper);
  background: var(--ink); width: 22px; height: 22px; border-radius: 6px;
  display: grid; place-items: center; flex: none;
}
.cp-fset-h h3 { font-size: 16px; font-weight: 700; letter-spacing: -0.01em; }

/* platform repeater */
.cp-plat { display: flex; flex-direction: column; gap: 10px; }
.cp-plat-row {
  display: grid; grid-template-columns: 150px 1fr 110px;
  gap: 10px; align-items: center;
}
@media (max-width: 520px) { .cp-plat-row { grid-template-columns: 1fr 1fr; } }
.cp-sel {
  width: 100%; border: 1px solid var(--line-2); border-radius: 10px;
  padding: 13px 15px; font-family: var(--ff-sans); font-size: 14.5px;
  color: var(--ink); background: var(--surface); cursor: pointer;
}
.cp-sel:focus { border-color: var(--ink); outline: none; }

/* pricing control */
.cp-price-modes { display: flex; gap: 8px; flex-wrap: wrap; }
.cp-price-modes label { cursor: pointer; }
.cp-price-modes input { position: absolute; opacity: 0; width: 0; height: 0; }
.cp-price-modes span {
  display: inline-flex; flex-direction: column; gap: 2px;
  border: 1px solid var(--line-2); border-radius: 10px; padding: 11px 16px;
  transition: all .18s; min-width: 130px;
}
.cp-price-modes .t { font-size: 14px; font-weight: 600; color: var(--ink); }
.cp-price-modes .d { font-family: var(--ff-mono); font-size: 10.5px; color: var(--muted); letter-spacing: .03em; }
.cp-price-modes label:hover span { border-color: var(--ink-2); }
.cp-price-modes input:checked + span { border-color: var(--ink); background: var(--paper-2); box-shadow: inset 0 0 0 1px var(--ink); }

.cp-price-panel { margin-top: 16px; display: none; }
.cp-price-panel.show { display: block; animation: cpFade .25s ease; }
.cp-rate-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
@media (max-width: 520px) { .cp-rate-grid { grid-template-columns: 1fr; } }
.cp-rate {
  display: grid; grid-template-columns: 1fr 120px; align-items: center; gap: 10px;
  border: 1px solid var(--line); border-radius: 10px; padding: 8px 8px 8px 14px;
}
.cp-rate .lbl { font-size: 13.5px; color: var(--ink-2); }
.cp-rate .inp { display: flex; align-items: center; border: 1px solid var(--line-2); border-radius: 8px; overflow: hidden; background: var(--surface); }
.cp-rate .inp input { border: none; background: none; padding: 9px 4px 9px 11px; width: 100%; font-family: var(--ff-mono); font-size: 14px; color: var(--ink); }
.cp-rate .inp input:focus { outline: none; }
.cp-rate .inp .cur { font-family: var(--ff-mono); font-size: 13px; color: var(--muted); padding-right: 11px; }
.cp-price-note { font-size: 13.5px; color: var(--ink-2); line-height: 1.5; padding: 14px 16px; border: 1px dashed var(--line-2); border-radius: 10px; }

/* success state */
.cp-done { display: none; text-align: center; max-width: 460px; margin: 0 auto; padding-top: 30px; }
.cp-done.show { display: block; }
.cp-done .seal {
  width: 64px; height: 64px; border-radius: 50%; margin: 0 auto 22px;
  display: grid; place-items: center; font-size: 28px;
  background: var(--signal-bg); color: var(--signal); border: 1px solid oklch(0.6 0.07 158 / .4);
}
.cp-done h2 { font-size: 26px; font-weight: 800; letter-spacing: -0.02em; }
.cp-done p { color: var(--ink-2); font-size: 15px; line-height: 1.6; margin-top: 10px; }
.cp-done-steps { text-align: left; margin: 26px 0 0; display: flex; flex-direction: column; gap: 12px; }
.cp-done-steps li { list-style: none; display: flex; gap: 12px; align-items: flex-start; font-size: 14px; color: var(--ink-2); }
.cp-done-steps .ord { font-family: var(--ff-mono); font-size: 11px; color: var(--muted); border: 1px solid var(--line-2); border-radius: 6px; width: 22px; height: 22px; display: grid; place-items: center; flex: none; }

/* ===================== APP SHELL (portal + admin) ===================== */

/* ---------- settings: toggles, danger, logout ---------- */
.cp-toggle-list { display: flex; flex-direction: column; }
.cp-toggle { display: flex; align-items: center; gap: 16px; padding: 14px 0; border-top: 1px solid var(--line); cursor: pointer; }
.cp-toggle:first-child { border-top: none; padding-top: 0; }
.cp-toggle > span { display: flex; flex-direction: column; gap: 2px; flex: 1; min-width: 0; }
.cp-toggle b { font-size: 14.5px; font-weight: 600; letter-spacing: -0.01em; }
.cp-toggle small { font-size: 13px; color: var(--ink-2); line-height: 1.4; }
.cp-toggle input { position: absolute; opacity: 0; pointer-events: none; }
.cp-toggle i { flex: none; width: 42px; height: 24px; border-radius: 100px; background: var(--line-2); position: relative; transition: background .18s; }
.cp-toggle i::after { content: ""; position: absolute; top: 2px; left: 2px; width: 20px; height: 20px; border-radius: 50%; background: #fff; box-shadow: 0 1px 3px oklch(0 0 0 / .3); transition: transform .18s; }
.cp-toggle input:checked + i { background: var(--signal); }
.cp-toggle input:checked + i::after { transform: translateX(18px); }
.cp-toggle input:focus-visible + i { outline: 2px solid var(--signal); outline-offset: 2px; }

.cp-card-form.cp-danger { border-color: oklch(0.62 0.18 25 / .35); }
.cp-danger-acts { display: flex; gap: 10px; flex-wrap: wrap; }

.cp-logout { color: var(--muted) !important; margin-top: 4px; }
.cp-logout:hover { color: oklch(0.55 0.2 25) !important; background: oklch(0.62 0.18 25 / .08) !important; }
.cp-logout:hover .ic { color: oklch(0.55 0.2 25) !important; }

/* ---------- admin review drawer ---------- */
.cp-drawer { position: fixed; inset: 0; z-index: 200; }
.cp-drawer[hidden] { display: none; }
.cp-drawer-scrim { position: absolute; inset: 0; background: oklch(0.205 0.012 70 / 0); transition: background .24s; }
.cp-drawer.open .cp-drawer-scrim { background: oklch(0.15 0.01 70 / .55); }
.cp-drawer-panel {
  position: absolute; top: 0; right: 0; height: 100%; width: min(520px, 100%);
  background: var(--paper); border-left: 1px solid var(--line); display: flex; flex-direction: column;
  transform: translateX(100%); transition: transform .26s cubic-bezier(.3,.8,.3,1);
  box-shadow: -30px 0 80px -40px oklch(0 0 0 / .5);
}
.cp-drawer.open .cp-drawer-panel { transform: translateX(0); }
.cp-drawer-top { display: flex; align-items: flex-start; gap: 12px; padding: 22px 24px; border-bottom: 1px solid var(--line); }
.rv-id { display: flex; gap: 14px; flex: 1; min-width: 0; }
.rv-av { flex: none; width: 48px; height: 48px; border-radius: 50%; background: var(--ink); color: var(--paper); display: grid; place-items: center; font-family: var(--ff-mono); font-weight: 600; font-size: 16px; }
.rv-name { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; }
.rv-name h2 { font-size: 20px; font-weight: 800; letter-spacing: -0.02em; }
.cp-verbadge.pend { color: var(--pending); border-color: oklch(0.72 0.13 75 / .4); background: oklch(0.72 0.13 75 / .12); }
.rv-meta { font-family: var(--ff-mono); font-size: 11px; letter-spacing: .03em; color: var(--muted); margin-top: 5px; line-height: 1.5; }
.cp-drawer-top .cp-icon-btn { flex: none; }

.cp-drawer-body { flex: 1; overflow-y: auto; padding: 22px 24px; display: flex; flex-direction: column; gap: 26px; }
.rv-block .rv-h { font-family: var(--ff-mono); font-size: 11px; letter-spacing: .1em; text-transform: uppercase; color: var(--faint); margin-bottom: 12px; display: flex; align-items: baseline; gap: 8px; }
.rv-h-note { color: var(--ink-2); letter-spacing: .02em; text-transform: none; font-size: 12px; }
.rv-accounts { display: flex; flex-direction: column; gap: 8px; }
.rv-acc { display: grid; grid-template-columns: 90px 1fr auto; align-items: center; gap: 12px; padding: 11px 14px; border: 1px solid var(--line-2); border-radius: 10px; background: var(--surface); }
.rv-acc .p { font-family: var(--ff-mono); font-size: 11px; letter-spacing: .04em; color: var(--muted); text-transform: uppercase; }
.rv-acc .h { font-size: 14px; font-weight: 600; letter-spacing: -0.01em; }
.rv-acc .n { font-size: 15px; font-weight: 800; letter-spacing: -0.02em; }
.rv-engage { display: flex; gap: 8px; flex-wrap: wrap; margin-top: 10px; }
.rv-pill { font-family: var(--ff-mono); font-size: 11px; letter-spacing: .02em; padding: 5px 10px; border-radius: 100px; border: 1px solid var(--line-2); color: var(--ink-2); }
.rv-pill.ok { color: var(--signal); border-color: oklch(0.6 0.07 158 / .35); background: var(--signal-bg); }
.rv-pill.warn { color: var(--pending); border-color: oklch(0.72 0.13 75 / .4); background: oklch(0.72 0.13 75 / .1); }
.rv-gallery { grid-template-columns: repeat(3, 1fr); }
.rv-gallery image-slot { aspect-ratio: 1; border-radius: 9px; }
.rv-about { font-size: 14px; color: var(--ink); line-height: 1.6; }
.rv-team { margin-top: 12px; font-size: 13px; color: var(--ink-2); }
.rv-team-lbl { font-family: var(--ff-mono); font-size: 10px; letter-spacing: .08em; color: var(--faint); }
.cp-drawer-foot { display: flex; gap: 10px; padding: 16px 24px; border-top: 1px solid var(--line); background: var(--surface); }
.cp-drawer-foot .cp-btn-ok { margin-left: auto; }
@media (max-width: 560px) { .cp-drawer-foot { flex-wrap: wrap; } .cp-drawer-foot .cp-btn-ok { margin-left: 0; width: 100%; } }

/* ---------- admin sub-pages ---------- */
.cp-adminpage { display: none; }
.cp-adminpage.active { display: block; }
.cp-find input { font-family: var(--ff-sans, inherit); font-size: 13.5px; padding: 9px 14px; border: 1px solid var(--line-2); border-radius: 9px; background: var(--surface); color: var(--ink); width: 240px; max-width: 50vw; }
.cp-find input:focus { outline: none; border-color: var(--ink); }
.cp-cr-tr { grid-template-columns: 1.6fr 1fr 1fr 0.6fr 0.8fr; }
.cp-apay-tr { grid-template-columns: 1.6fr 1fr 1fr 0.7fr 0.9fr; }
.cp-cr-who { display: flex; align-items: center; gap: 11px; min-width: 0; }
.cp-cr-who .av { flex: none; width: 32px; height: 32px; border-radius: 50%; background: var(--ink); color: var(--paper); display: grid; place-items: center; font-family: var(--ff-mono); font-weight: 600; font-size: 11px; }
.cp-cr-who .nm { font-size: 14px; font-weight: 600; letter-spacing: -0.01em; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.cp-brief-admin { display: flex; flex-direction: column; gap: 12px; }
.cp-status.new { background: var(--signal-bg); color: var(--signal); }

/* ---------- campaign drawer ---------- */
.cm-logo { flex: none; width: 48px; height: 48px; border-radius: 11px; background: var(--paper-2); border: 1px solid var(--line); display: grid; place-items: center; font-family: var(--ff-mono); font-weight: 600; font-size: 16px; }
.cm-budget-row { display: flex; gap: 14px; }
.cm-budget-row > div { flex: 1; border: 1px solid var(--line-2); border-radius: 12px; padding: 14px 16px; background: var(--surface); }
.cm-bl { font-family: var(--ff-mono); font-size: 10px; letter-spacing: .08em; text-transform: uppercase; color: var(--muted); }
.cm-bv { font-size: 24px; font-weight: 800; letter-spacing: -0.02em; margin-top: 4px; }
.cm-bv.sm { font-size: 15px; font-weight: 600; }
.cm-stepper { list-style: none; display: flex; gap: 0; margin: 0; padding: 0; }
.cm-stepper li { flex: 1; display: flex; flex-direction: column; align-items: center; gap: 7px; position: relative; text-align: center; }
.cm-stepper li::before { content: ""; position: absolute; top: 13px; left: -50%; width: 100%; height: 2px; background: var(--line-2); z-index: 0; }
.cm-stepper li:first-child::before { display: none; }
.cm-stepper li.done::before, .cm-stepper li.current::before { background: var(--signal); }
.cm-stepper .dot { position: relative; z-index: 1; width: 28px; height: 28px; border-radius: 50%; display: grid; place-items: center; font-family: var(--ff-mono); font-size: 12px; font-weight: 600; background: var(--surface); border: 2px solid var(--line-2); color: var(--muted); }
.cm-stepper li.done .dot { background: var(--signal); border-color: var(--signal); color: #fff; }
.cm-stepper li.current .dot { border-color: var(--signal); color: var(--signal); }
.cm-stepper .lb { font-size: 11px; color: var(--ink-2); letter-spacing: -0.01em; }
.cm-stepper li.current .lb { color: var(--ink); font-weight: 600; }
.cm-deliv { display: flex; flex-direction: column; gap: 8px; }
.cm-deliv-row { display: flex; align-items: center; gap: 12px; padding: 12px 14px; border: 1px solid var(--line-2); border-radius: 10px; background: var(--surface); }
.cm-deliv-row.done { background: var(--signal-bg); border-color: oklch(0.6 0.07 158 / .3); }
.cm-deliv-check { flex: none; width: 24px; height: 24px; border-radius: 50%; display: grid; place-items: center; font-family: var(--ff-mono); font-size: 11px; font-weight: 600; background: var(--paper-2); border: 1px solid var(--line-2); color: var(--muted); }
.cm-deliv-row.done .cm-deliv-check { background: var(--signal); border-color: var(--signal); color: #fff; }
.cm-deliv-l { flex: 1; font-size: 14px; line-height: 1.4; }
.cm-deliv-up { flex: none; font-size: 13px; font-weight: 600; color: var(--ink); background: var(--paper-2); border: 1px solid var(--line-2); border-radius: 8px; padding: 7px 12px; cursor: pointer; transition: border-color .15s; }
.cm-deliv-up:hover { border-color: var(--ink); }
.cm-deliv-state { flex: none; font-family: var(--ff-mono); font-size: 11px; letter-spacing: .03em; }
.cm-deliv-state.ok { color: var(--signal); }
.cm-note { font-size: 13.5px; color: var(--ink-2); line-height: 1.6; padding: 14px 16px; background: var(--paper-2); border: 1px solid var(--line); border-radius: 10px; }
.cm-foot-note { font-size: 13px; color: var(--ink-2); text-align: center; }

/* ---------- notifications dropdown ---------- */
.cp-notif-wrap { position: relative; }
.cp-notif { position: absolute; top: calc(100% + 10px); right: 0; width: 340px; max-width: 90vw; background: var(--paper); border: 1px solid var(--line-2); border-radius: 14px; box-shadow: 0 30px 70px -30px oklch(0.205 0.012 70 / .45); z-index: 90; overflow: hidden; }
.cp-notif[hidden] { display: none; }
.cp-notif-h { display: flex; align-items: center; justify-content: space-between; padding: 14px 16px; border-bottom: 1px solid var(--line); font-weight: 700; font-size: 14px; }
.cp-notif-h button { font-family: var(--ff-mono); font-size: 11px; color: var(--signal); background: none; border: none; cursor: pointer; letter-spacing: .02em; }
.cp-notif-h button:hover { text-decoration: underline; }
.cp-notif-list { max-height: 360px; overflow-y: auto; }
.cp-notif-item { display: flex; gap: 12px; padding: 13px 16px; border-bottom: 1px solid var(--line); position: relative; }
.cp-notif-item:last-child { border-bottom: none; }
.cp-notif-item.unread { background: var(--signal-bg); }
.cp-notif-item.unread::before { content: ""; position: absolute; left: 6px; top: 50%; transform: translateY(-50%); width: 5px; height: 5px; border-radius: 50%; background: var(--signal); }
.ni-ic { flex: none; width: 32px; height: 32px; border-radius: 9px; background: var(--paper-2); border: 1px solid var(--line); display: grid; place-items: center; font-size: 14px; color: var(--ink); }
.ni-tx { min-width: 0; }
.ni-t { font-size: 13.5px; font-weight: 600; letter-spacing: -0.01em; }
.ni-s { font-size: 12.5px; color: var(--ink-2); margin-top: 1px; line-height: 1.4; }
.ni-w { font-family: var(--ff-mono); font-size: 10px; color: var(--muted); margin-top: 4px; letter-spacing: .03em; }
.cp-notif-foot { display: block; text-align: center; padding: 12px; font-size: 13px; font-weight: 600; color: var(--ink); text-decoration: none; border-top: 1px solid var(--line); cursor: pointer; }
.cp-notif-foot:hover { background: var(--paper-2); }

/* ---------- allocate creators list ---------- */
.al-list { display: flex; flex-direction: column; gap: 8px; }
.al-row { display: flex; align-items: center; gap: 12px; padding: 12px 14px; border: 1px solid var(--line-2); border-radius: 10px; background: var(--surface); cursor: pointer; transition: border-color .15s; }
.al-row:hover { border-color: var(--ink); }
.al-row:has(input:checked) { border-color: var(--signal); background: var(--signal-bg); }
.al-row input { width: 18px; height: 18px; flex: none; accent-color: var(--signal); }
.al-row .av { flex: none; width: 34px; height: 34px; border-radius: 50%; background: var(--ink); color: var(--paper); display: grid; place-items: center; font-family: var(--ff-mono); font-weight: 600; font-size: 12px; }
.al-tx { display: flex; flex-direction: column; gap: 2px; min-width: 0; }
.al-tx .nm { font-size: 14px; font-weight: 600; letter-spacing: -0.01em; }
.al-tx .mt { font-family: var(--ff-mono); font-size: 11px; color: var(--muted); letter-spacing: .02em; }
.cp-shell { display: grid; grid-template-columns: var(--sidebar-w) 1fr; min-height: calc(100vh - 56px); }
@media (max-width: 820px) { .cp-shell { grid-template-columns: 1fr; } }

.cp-side {
  background: var(--surface); border-right: 1px solid var(--line);
  display: flex; flex-direction: column; padding: 22px 16px;
  position: sticky; top: 56px; height: calc(100vh - 56px);
}
@media (max-width: 820px) { .cp-side { display: none; } }
.cp-side-brand { display: flex; align-items: center; gap: 10px; padding: 4px 8px 18px; font-weight: 800; font-size: 15px; letter-spacing: -0.01em; }
.cp-side-brand .mark { width: 26px; height: 26px; border-radius: 7px; background: var(--ink); color: var(--paper); display: grid; place-items: center; font-family: var(--ff-mono); font-size: 12px; }
.cp-nav { display: flex; flex-direction: column; gap: 2px; }
.cp-nav-label { font-family: var(--ff-mono); font-size: 10px; letter-spacing: .14em; text-transform: uppercase; color: var(--faint); padding: 14px 10px 6px; }
.cp-nav a {
  display: flex; align-items: center; gap: 11px; padding: 10px 11px; border-radius: 9px;
  color: var(--ink-2); text-decoration: none; font-size: 14.5px; font-weight: 500;
  transition: background .15s, color .15s; cursor: pointer;
}
.cp-nav a .ic { width: 18px; text-align: center; font-size: 15px; color: var(--muted); transition: color .15s; }
.cp-nav a:hover { background: var(--paper-2); color: var(--ink); }
.cp-nav a.active { background: var(--ink); color: var(--paper); }
.cp-nav a.active .ic { color: var(--paper); }
.cp-nav a .badge { margin-left: auto; font-family: var(--ff-mono); font-size: 10.5px; background: var(--signal); color: #fff; border-radius: 100px; padding: 1px 7px; }
.cp-nav a.active .badge { background: var(--paper); color: var(--ink); }

.cp-side-card {
  margin-top: auto; border: 1px solid var(--line); border-radius: 12px;
  padding: 13px; display: flex; gap: 11px; align-items: center;
}
.cp-side-card .av { width: 38px; height: 38px; border-radius: 50%; background: var(--ink); color: var(--paper); display: grid; place-items: center; font-family: var(--ff-mono); font-weight: 600; font-size: 13px; flex: none; }
.cp-side-card .nm { font-size: 13.5px; font-weight: 700; letter-spacing: -0.01em; }
.cp-side-card .st { font-family: var(--ff-mono); font-size: 10px; letter-spacing: .04em; color: var(--signal); display: flex; align-items: center; gap: 4px; }
.cp-side-card .st.pend { color: var(--pending); }

/* topbar */
.cp-main { display: flex; flex-direction: column; min-width: 0; }
.cp-top {
  display: flex; align-items: center; gap: 16px;
  padding: 18px clamp(20px, 4vw, 40px); border-bottom: 1px solid var(--line);
  background: var(--paper); position: sticky; top: 56px; z-index: 20;
}
.cp-top h1 { font-size: 21px; font-weight: 800; letter-spacing: -0.02em; }
.cp-top .crumb { font-family: var(--ff-mono); font-size: 11px; color: var(--faint); letter-spacing: .04em; }
.cp-top-actions { margin-left: auto; display: flex; align-items: center; gap: 10px; }
.cp-icon-btn { width: 38px; height: 38px; border-radius: 9px; border: 1px solid var(--line-2); background: var(--surface); color: var(--ink-2); display: grid; place-items: center; cursor: pointer; position: relative; transition: all .15s; }
.cp-icon-btn:hover { border-color: var(--ink); color: var(--ink); }
.cp-icon-btn svg { width: 17px; height: 17px; }
.cp-icon-btn .dot { position: absolute; top: 8px; right: 9px; width: 7px; height: 7px; border-radius: 50%; background: var(--signal); border: 2px solid var(--surface); }

.cp-content { padding: clamp(22px, 3.4vw, 38px) clamp(20px, 4vw, 40px); max-width: 1080px; width: 100%; margin-inline: auto; }

/* sub-pages */
.cp-page { display: none; }
.cp-page.active { display: block; animation: cpFade .28s ease; }

/* section heads */
.cp-sec-h { display: flex; align-items: center; justify-content: space-between; gap: 14px; margin: 0 0 16px; }
.cp-sec-h h2 { font-size: 17px; font-weight: 700; letter-spacing: -0.01em; }
.cp-sec-h .more { font-size: 13px; color: var(--muted); text-decoration: none; cursor: pointer; }
.cp-sec-h .more:hover { color: var(--ink); }

/* verification banner */
.cp-verif {
  display: flex; align-items: center; gap: 16px; flex-wrap: wrap;
  border: 1px solid var(--line-2); border-radius: 14px; padding: 18px 20px; margin-bottom: 24px;
  background: var(--surface);
}
.cp-verif.pend { background: var(--pending-bg); border-color: oklch(0.7 0.072 75 / .4); }
.cp-verif.ok { background: var(--signal-bg); border-color: oklch(0.6 0.07 158 / .4); }
.cp-verif .vic { width: 40px; height: 40px; border-radius: 10px; display: grid; place-items: center; font-size: 18px; flex: none; }
.cp-verif.pend .vic { background: oklch(0.7 0.072 75 / .18); color: var(--pending); }
.cp-verif.ok .vic { background: oklch(0.6 0.07 158 / .15); color: var(--signal); }
.cp-verif .vt { font-size: 15px; font-weight: 700; }
.cp-verif .vs { font-size: 13.5px; color: var(--ink-2); margin-top: 2px; }
.cp-verif .va { margin-left: auto; }

/* stat cards */
.cp-stats { display: grid; grid-template-columns: repeat(4, 1fr); gap: 14px; margin-bottom: 26px; }
@media (max-width: 900px) { .cp-stats { grid-template-columns: repeat(2, 1fr); } }
.cp-stat { border: 1px solid var(--line); border-radius: 13px; padding: 16px 17px; background: var(--surface); }
.cp-stat .l { font-family: var(--ff-mono); font-size: 10.5px; letter-spacing: .08em; text-transform: uppercase; color: var(--muted); }
.cp-stat .v { font-size: 28px; font-weight: 800; letter-spacing: -0.02em; margin-top: 8px; }
.cp-stat .d { font-size: 12px; color: var(--ink-2); margin-top: 4px; display: flex; align-items: center; gap: 5px; }
.cp-stat .d .up { color: var(--signal); font-family: var(--ff-mono); }

/* two-col layout */
.cp-grid2 { display: grid; grid-template-columns: 1.5fr 1fr; gap: 22px; align-items: start; }
@media (max-width: 920px) { .cp-grid2 { grid-template-columns: 1fr; } }

/* brief cards */
.cp-brief {
  border: 1px solid var(--line-2); border-radius: 13px; padding: 18px; background: var(--surface);
  display: flex; flex-direction: column; gap: 13px; transition: border-color .15s, box-shadow .15s;
}
.cp-brief + .cp-brief { margin-top: 12px; }
.cp-brief:hover { border-color: var(--ink-2); box-shadow: 0 14px 34px -26px oklch(0.205 0.012 70 / .5); }
.cp-brief .bh { display: flex; align-items: flex-start; gap: 12px; }
.cp-brief .blogo { width: 42px; height: 42px; border-radius: 10px; background: var(--paper-2); border: 1px solid var(--line); display: grid; place-items: center; font-family: var(--ff-mono); font-weight: 600; font-size: 14px; color: var(--ink); flex: none; }
.cp-brief .bn { font-size: 16px; font-weight: 700; letter-spacing: -0.01em; }
.cp-brief .bmeta { font-family: var(--ff-mono); font-size: 11px; color: var(--muted); letter-spacing: .03em; margin-top: 2px; }
.cp-brief .bbudget { margin-left: auto; text-align: right; }
.cp-brief .bbudget .bv { font-size: 18px; font-weight: 800; letter-spacing: -0.01em; }
.cp-brief .bbudget .bl { font-family: var(--ff-mono); font-size: 10px; color: var(--muted); letter-spacing: .06em; text-transform: uppercase; }
.cp-brief .bbody { font-size: 13.5px; color: var(--ink-2); line-height: 1.55; }
.cp-tags { display: flex; flex-wrap: wrap; gap: 6px; }
.cp-tag { font-family: var(--ff-mono); font-size: 11px; padding: 4px 10px; border-radius: 100px; border: 1px solid var(--line-2); color: var(--ink-2); }
.cp-tag.due { color: var(--pending); border-color: oklch(0.7 0.072 75 / .45); }
.cp-brief .bact { display: flex; gap: 10px; align-items: center; }
.cp-btn { font-family: var(--ff-sans); font-size: 13.5px; font-weight: 600; border-radius: 9px; padding: 10px 16px; cursor: pointer; border: 1px solid transparent; transition: all .16s; display: inline-flex; align-items: center; gap: 7px; }
.cp-btn-pri { background: var(--ink); color: var(--paper); }
.cp-btn-pri:hover { transform: translateY(-1px); box-shadow: 0 10px 24px -12px oklch(0.205 0.012 70 / .6); }
.cp-btn-ghost { background: transparent; color: var(--ink-2); border-color: var(--line-2); }
.cp-btn-ghost:hover { border-color: var(--ink); color: var(--ink); }
.cp-btn-sm { padding: 8px 13px; font-size: 12.5px; }

/* status pill */
.cp-status { font-family: var(--ff-mono); font-size: 10.5px; letter-spacing: .06em; padding: 4px 10px; border-radius: 100px; display: inline-flex; align-items: center; gap: 6px; }
.cp-status::before { content: ""; width: 6px; height: 6px; border-radius: 50%; background: currentColor; }
.cp-status.new { color: var(--signal); background: var(--signal-bg); }
.cp-status.active { color: var(--ink); background: var(--paper-2); }
.cp-status.pend { color: var(--pending); background: var(--pending-bg); }
.cp-status.done { color: var(--muted); background: var(--paper-2); }
.cp-status.rej { color: var(--danger); background: var(--danger-bg); }

/* side panels (mini lists) */
.cp-panel { border: 1px solid var(--line); border-radius: 13px; background: var(--surface); padding: 18px; }
.cp-panel + .cp-panel { margin-top: 18px; }
.cp-panel h3 { font-size: 14px; font-weight: 700; letter-spacing: -0.01em; margin-bottom: 14px; }
.cp-progress { height: 8px; border-radius: 100px; background: var(--paper-2); overflow: hidden; margin: 6px 0 12px; }
.cp-progress span { display: block; height: 100%; background: var(--signal); border-radius: 100px; }
.cp-check { display: flex; flex-direction: column; gap: 9px; }
.cp-check li { list-style: none; display: flex; align-items: center; gap: 10px; font-size: 13px; color: var(--ink-2); }
.cp-check .box { width: 18px; height: 18px; border-radius: 5px; border: 1px solid var(--line-2); display: grid; place-items: center; font-size: 11px; flex: none; }
.cp-check li.ok .box { background: var(--signal); border-color: var(--signal); color: #fff; }
.cp-check li.ok { color: var(--ink); }

.cp-payrow { display: flex; align-items: center; justify-content: space-between; padding: 11px 0; border-bottom: 1px solid var(--line); }
.cp-payrow:last-child { border-bottom: none; }
.cp-payrow .pt { font-size: 13.5px; font-weight: 600; }
.cp-payrow .ps { font-family: var(--ff-mono); font-size: 11px; color: var(--muted); margin-top: 2px; }
.cp-payrow .pv { font-family: var(--ff-mono); font-size: 14px; font-weight: 600; }

/* filter tabs */
.cp-tabs { display: flex; gap: 4px; background: var(--paper-2); border: 1px solid var(--line); padding: 4px; border-radius: 100px; margin-bottom: 20px; }
.cp-tabs button { font-family: var(--ff-sans); font-size: 13px; font-weight: 600; color: var(--ink-2); background: none; border: none; cursor: pointer; padding: 8px 16px; border-radius: 100px; transition: all .16s; }
.cp-tabs button:hover { color: var(--ink); }
.cp-tabs button.active { background: var(--surface); color: var(--ink); box-shadow: 0 2px 8px -4px oklch(0.205 0.012 70 / .3); }
.cp-tabs .ct { font-family: var(--ff-mono); font-size: 11px; opacity: .6; margin-left: 5px; }

/* tables */
.cp-table { border: 1px solid var(--line); border-radius: 13px; overflow: hidden; background: var(--surface); }
.cp-tr { display: grid; align-items: center; gap: 14px; padding: 14px 18px; border-bottom: 1px solid var(--line); }
.cp-tr:last-child { border-bottom: none; }
.cp-tr.head { background: var(--paper-2); }
.cp-tr.head span { font-family: var(--ff-mono); font-size: 10px; letter-spacing: .1em; text-transform: uppercase; color: var(--muted); }
.cp-pay-tr { grid-template-columns: 1.6fr 1fr 1fr 110px; }
@media (max-width: 700px) { .cp-pay-tr { grid-template-columns: 1.6fr 1fr; } .cp-pay-tr .hide-sm { display: none; } }

/* portfolio gallery */
.cp-gallery { display: grid; grid-template-columns: repeat(4, 1fr); gap: 12px; }
@media (max-width: 700px) { .cp-gallery { grid-template-columns: repeat(2, 1fr); } }
.cp-gallery image-slot { aspect-ratio: 4/5; border-radius: 11px; overflow: hidden; border: 1px solid var(--line); display: block; }
.cp-gallery .add-slot { aspect-ratio: 4/5; border-radius: 11px; border: 1.5px dashed var(--line-2); display: grid; place-items: center; color: var(--muted); cursor: pointer; transition: all .16s; gap: 6px; text-align: center; }
.cp-gallery .add-slot:hover { border-color: var(--ink); color: var(--ink); }
.cp-gallery .add-slot .pl { font-size: 24px; }
.cp-gallery .add-slot .tx { font-family: var(--ff-mono); font-size: 10px; letter-spacing: .06em; }

/* profile edit form rows */
.cp-card-form { border: 1px solid var(--line); border-radius: 14px; background: var(--surface); padding: clamp(20px, 3vw, 30px); }
.cp-card-form + .cp-card-form { margin-top: 20px; }

/* ===================== PROFIL PUBLIC ===================== */
.cp-public { max-width: 980px; margin: 0 auto; padding: clamp(26px, 4vw, 50px) clamp(20px, 4vw, 40px) 80px; }
.cp-pub-back { font-family: var(--ff-mono); font-size: 12px; color: var(--muted); text-decoration: none; display: inline-flex; gap: 7px; align-items: center; margin-bottom: 22px; }
.cp-pub-back:hover { color: var(--ink); }
.cp-pub-head { display: grid; grid-template-columns: auto 1fr auto; gap: 24px; align-items: center; padding-bottom: 26px; border-bottom: 1px solid var(--line); }
@media (max-width: 640px) { .cp-pub-head { grid-template-columns: 1fr; text-align: center; justify-items: center; } }
.cp-pub-av { width: 96px; height: 96px; border-radius: 22px; background: var(--ink); color: var(--paper); display: grid; place-items: center; font-family: var(--ff-mono); font-size: 30px; font-weight: 600; }
.cp-pub-name { display: flex; align-items: center; gap: 10px; }
.cp-pub-name h1 { font-size: clamp(26px, 3.4vw, 38px); font-weight: 800; letter-spacing: -0.025em; }
.cp-verbadge { display: inline-flex; align-items: center; gap: 5px; font-family: var(--ff-mono); font-size: 11px; color: var(--signal); background: var(--signal-bg); border: 1px solid oklch(0.6 0.07 158 / .35); padding: 4px 10px; border-radius: 100px; }
.cp-pub-meta { display: flex; flex-wrap: wrap; gap: 8px 18px; margin-top: 10px; color: var(--ink-2); font-size: 14px; }
.cp-pub-meta .mono { font-family: var(--ff-mono); font-size: 12px; color: var(--muted); }
.cp-pub-stats { display: grid; grid-template-columns: repeat(auto-fit, minmax(120px, 1fr)); gap: 14px; margin: 26px 0; }
.cp-pub-stat { border: 1px solid var(--line); border-radius: 12px; padding: 15px 16px; background: var(--surface); }
.cp-pub-stat .pl { font-family: var(--ff-mono); font-size: 10.5px; letter-spacing: .06em; color: var(--muted); display: flex; align-items: center; gap: 6px; }
.cp-pub-stat .nu { font-size: 24px; font-weight: 800; letter-spacing: -0.02em; margin-top: 7px; }
.cp-pub-h2 { font-size: 16px; font-weight: 700; letter-spacing: -0.01em; margin: 34px 0 14px; }
.cp-rate-list { display: grid; grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); gap: 12px; }
.cp-rate-pub { border: 1px solid var(--line); border-radius: 12px; padding: 16px; background: var(--surface); }
.cp-rate-pub .rl { font-size: 13.5px; color: var(--ink-2); }
.cp-rate-pub .rv { font-size: 20px; font-weight: 800; letter-spacing: -0.01em; margin-top: 6px; }
.cp-rate-pub .rv small { font-family: var(--ff-mono); font-size: 12px; font-weight: 500; color: var(--muted); }

/* admin detail drawer */
.cp-review { display: grid; grid-template-columns: 1fr; gap: 0; }
.cp-admin-row { display: grid; grid-template-columns: 1.5fr 1fr 0.9fr auto; gap: 16px; align-items: center; padding: 15px 18px; border-bottom: 1px solid var(--line); cursor: pointer; transition: background .14s; }
.cp-admin-row:last-child { border-bottom: none; }
.cp-admin-row:hover { background: var(--paper-2); }
.cp-admin-row .who { display: flex; align-items: center; gap: 12px; }
.cp-admin-row .av { width: 40px; height: 40px; border-radius: 10px; background: var(--ink); color: var(--paper); display: grid; place-items: center; font-family: var(--ff-mono); font-weight: 600; font-size: 13px; flex: none; }
.cp-admin-row .nm { font-size: 14.5px; font-weight: 700; letter-spacing: -0.01em; }
.cp-admin-row .sub { font-family: var(--ff-mono); font-size: 11px; color: var(--muted); margin-top: 2px; }
.cp-admin-row .thumbs { display: flex; gap: 5px; }
.cp-admin-row .thumbs i { width: 30px; height: 38px; border-radius: 5px; background: var(--paper-2); border: 1px solid var(--line); display: block; background-size: cover; }
.cp-admin-row .acts { display: flex; gap: 8px; }
@media (max-width: 760px) { .cp-admin-row { grid-template-columns: 1fr auto; } .cp-admin-row .hide-sm { display: none; } }

.cp-btn-ok { background: var(--signal); color: #fff; }
.cp-btn-ok:hover { filter: brightness(1.05); transform: translateY(-1px); }
.cp-btn-rej { background: transparent; color: var(--danger); border-color: oklch(0.58 0.072 25 / .4); }
.cp-btn-rej:hover { background: var(--danger-bg); }

.cp-empty-row { padding: 40px; text-align: center; color: var(--muted); font-size: 14px; }

/* responsive mobile note for app */
.cp-mob-hint { display: none; }
@media (max-width: 820px) {
  .cp-mob-tabs { display: flex; }
}
.cp-mob-tabs { display: none; gap: 4px; padding: 12px clamp(20px,4vw,40px) 0; flex-wrap: wrap; }
.cp-mob-tabs button { font-family: var(--ff-mono); font-size: 11px; padding: 8px 12px; border-radius: 100px; border: 1px solid var(--line-2); background: var(--surface); color: var(--ink-2); cursor: pointer; }
.cp-mob-tabs button.active { background: var(--ink); color: var(--paper); border-color: var(--ink); }

/* ---------- profile photo (image-slot avatars) ---------- */
.cp-av-up { display: flex; align-items: center; gap: 16px; }
.cp-av-up image-slot { width: 84px; height: 84px; flex: none; }
.cp-av-hint { font-size: 13px; color: var(--ink-2); line-height: 1.5; max-width: 34ch; }
.cp-av-hint b { display: block; color: var(--ink); font-weight: 600; font-size: 13.5px; margin-bottom: 2px; }
.cp-side-card image-slot.cp-av { width: 38px; height: 38px; flex: none; }
image-slot.cp-pub-av { width: 96px; height: 96px; flex: none; }
.cp-admin-row image-slot.cp-av { width: 40px; height: 40px; flex: none; }
.rv-id image-slot.cp-av { width: 48px; height: 48px; flex: none; }
