/* In Hand Reviews — member area (login + dashboard) */
.app-top{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.8rem clamp(1rem,4vw,2rem);
  border-bottom:1px solid var(--line);background:rgba(8,9,11,.85);position:sticky;top:0;z-index:30}
.app-top .who{display:flex;align-items:center;gap:.8rem;font-size:.9rem;color:var(--muted)}
.badge-demo{display:inline-flex;align-items:center;gap:.4rem;font-size:.72rem;font-weight:700;color:#08090b;
  background:var(--gold);padding:.25rem .6rem;border-radius:999px}
.app-wrap{max-width:920px;margin:0 auto;padding:clamp(1.5rem,4vw,2.5rem) clamp(1rem,4vw,2rem) 4rem;display:grid;gap:1.2rem}
.card2{background:var(--card);border:1px solid var(--line);border-radius:18px;padding:clamp(1.2rem,3vw,1.7rem)}
.card2 h2{font-size:1.15rem;margin:0 0 .3rem}
.card2 .sub{color:var(--muted);font-size:.9rem;margin:0 0 1.1rem}
.profile-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.rfield{display:block;font-size:.82rem;color:var(--muted);font-weight:600}
.rfield span{display:block;margin-bottom:.35rem}
.rfield input,.url-row input{width:100%;background:var(--bg);border:1px solid var(--line);color:var(--ink);
  border-radius:11px;padding:.7rem .8rem;font:inherit}
.rfield input:focus,.url-row input:focus{outline:none;border-color:var(--accent)}
.rfield input:focus-visible,.url-row input:focus-visible{outline:2px solid var(--gold);outline-offset:2px}
.url-row{display:flex;gap:.6rem;margin-bottom:.6rem}
.url-row input{flex:1}
.status{font-size:.86rem;color:var(--gold);min-height:1.2em;margin:.3rem 0 0}
.result{margin-top:1.3rem;border-top:1px solid var(--line);padding-top:1.2rem}
.eyebrow-row{display:flex;align-items:center;gap:.6rem;margin-bottom:.9rem}
.ok-chip{display:inline-flex;align-items:center;gap:.4rem;font-size:.78rem;font-weight:700;color:var(--ok);
  background:rgba(54,179,126,.12);border:1px solid rgba(54,179,126,.3);padding:.25rem .6rem;border-radius:999px}
.pfacts{display:grid;grid-template-columns:repeat(4,1fr);gap:.8rem;margin-bottom:1.2rem}
.payout{display:grid;grid-template-columns:auto 1fr;gap:1.2rem;align-items:center;
  background:linear-gradient(120deg,#14161d,rgba(245,196,81,.06));border:1px solid var(--line);border-radius:16px;padding:1.2rem}
.payout-big{text-align:center;padding-right:1.2rem;border-right:1px solid var(--line)}
.payout-big b{display:block;font-size:2.6rem;letter-spacing:-.02em;background:linear-gradient(100deg,var(--accent),var(--gold));-webkit-background-clip:text;background-clip:text;color:transparent}
.payout-big span{font-size:.78rem;color:var(--muted)}
.payout-big small{display:block;color:var(--soft);font-size:.72rem;margin-top:.3rem}
.brow{display:grid;grid-template-columns:1.4fr 2fr auto;gap:.7rem;align-items:center;margin:.35rem 0;font-size:.84rem;color:var(--muted)}
.bbar{height:7px;border-radius:999px;background:var(--bg-2);overflow:hidden}
.bbar i{display:block;height:100%;background:linear-gradient(90deg,var(--accent),var(--gold))}
.brow b{color:var(--ink);font-size:.86rem}
.payout-note{font-size:.8rem;color:var(--soft);margin:1rem 0 0}
.demo-data-note{font-size:.74rem;color:var(--soft);margin:.2rem 0 0}
/* login */
.login-wrap{max-width:420px;margin:0 auto;padding:clamp(2.5rem,8vw,5rem) 1.2rem;text-align:center}
.login-card{background:var(--card);border:1px solid var(--line);border-radius:20px;padding:2rem;text-align:left}
.login-card h1{font-size:1.5rem;margin:0 0 .3rem}
.login-card p.sub{color:var(--muted);font-size:.92rem;margin:0 0 1.4rem}
.login-card label{display:block;font-size:.85rem;font-weight:600;margin-bottom:1rem}
.login-card input{width:100%;margin-top:.4rem;background:var(--bg);border:1px solid var(--line);color:var(--ink);border-radius:11px;padding:.75rem .85rem;font:inherit}
.login-card input:focus{outline:none;border-color:var(--accent)}
.login-card input:focus-visible{outline:2px solid var(--gold);outline-offset:2px}
.login-note{font-size:.78rem;color:var(--soft);margin-top:1rem;text-align:center}
@media (max-width:680px){.profile-grid,.pfacts{grid-template-columns:1fr 1fr}.payout{grid-template-columns:1fr}.payout-big{border-right:0;border-bottom:1px solid var(--line);padding:0 0 1rem;margin-bottom:.4rem}.brow{grid-template-columns:1fr auto}.brow .bbar{display:none}}

/* ---------- admin console ---------- */
.filterbar{display:flex;gap:.4rem;margin-bottom:1.2rem;flex-wrap:wrap}
.filterbar button{background:var(--bg-2);border:1px solid var(--line);color:var(--muted);border-radius:999px;padding:.5rem .9rem;font:inherit;font-size:.85rem;font-weight:600;cursor:pointer}
.filterbar button.active{background:var(--accent);color:#fff;border-color:transparent}
.filterbar .c{opacity:.75;font-weight:700;margin-left:.3rem}
.appcard{background:var(--card);border:1px solid var(--line);border-radius:16px;padding:1.1rem 1.2rem;margin-bottom:1rem}
.apphead{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem}
.apphead h3{margin:0 0 .2rem;font-size:1.1rem}
.apphead a{color:var(--gold);font-size:.9rem}
.st{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;padding:.25rem .6rem;border-radius:999px;white-space:nowrap}
.st-pending{background:rgba(245,196,81,.15);color:var(--gold)}
.st-accepted{background:rgba(54,179,126,.15);color:var(--ok)}
.st-declined{background:rgba(229,72,77,.15);color:var(--accent)}
.appmeta{display:flex;gap:1.2rem;flex-wrap:wrap;color:var(--muted);font-size:.86rem;margin:.7rem 0}
.applinks{font-size:.85rem;color:var(--muted);margin:.5rem 0;word-break:break-all}
.applinks a{color:var(--gold)}
.appfield{font-size:.88rem;color:var(--muted);margin:.4rem 0}
.appactions{display:flex;gap:.6rem;margin-top:.9rem}
.empty{color:var(--muted);text-align:center;padding:2rem}
.gate{text-align:center;padding:3rem 1rem;color:var(--muted)}
.toast{position:fixed;bottom:20px;left:50%;transform:translateX(-50%);background:var(--ink);color:#08090b;font-weight:600;padding:.7rem 1.2rem;border-radius:999px;z-index:80;font-size:.9rem}
.copymodal{position:fixed;inset:0;background:rgba(0,0,0,.7);display:grid;place-items:center;padding:1rem;z-index:70}
.copymodal .dlg{background:var(--card);border:1px solid var(--line);border-radius:18px;max-width:560px;width:100%;padding:1.6rem}
.copymodal .to{color:var(--muted);font-size:.85rem;margin:.2rem 0 .6rem}
.copymodal textarea{width:100%;height:230px;background:var(--bg);border:1px solid var(--line);color:var(--ink);border-radius:11px;padding:.8rem;font:inherit;font-size:.84rem;white-space:pre-wrap}
.onboard{margin-top:.9rem;font-size:.85rem;color:var(--muted)}
.onboard ul{margin:.4rem 0 0;padding-left:1.1rem}

/* ---------- CRM / AP / AR ---------- */
.secnav{display:flex;gap:.3rem;border-bottom:1px solid var(--line);margin-bottom:1.4rem;flex-wrap:wrap}
.secnav button{background:none;border:0;border-bottom:2px solid transparent;color:var(--muted);font:inherit;font-weight:600;
  padding:.7rem .9rem;cursor:pointer;font-size:.95rem}
.secnav button.active{color:var(--ink);border-bottom-color:var(--accent)}
.secnav button{position:relative}
.navbadge{display:inline-block;margin-left:.4rem;min-width:1.15em;padding:0 .35em;border-radius:999px;background:var(--accent);color:#fff;font-size:.72rem;font-weight:700;line-height:1.5;text-align:center;vertical-align:middle}
.navbadge[hidden]{display:none}
.ledger{width:100%;border-collapse:collapse;font-size:.9rem}
.ledger th{text-align:left;color:var(--soft);font-weight:600;font-size:.78rem;text-transform:uppercase;letter-spacing:.05em;padding:.5rem .6rem;border-bottom:1px solid var(--line)}
.ledger td{padding:.7rem .6rem;border-bottom:1px solid var(--line);vertical-align:top}
.ledger tr:hover td{background:var(--bg-2)}
.ledger a{color:var(--gold);word-break:break-all}
.amt{font-weight:700;color:var(--ink);white-space:nowrap}
.role{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em;padding:.2rem .55rem;border-radius:999px}
.role-creator{background:rgba(229,72,77,.14);color:var(--accent)}
.role-staff{background:rgba(124,130,141,.18);color:#c7ccd6}
.role-brand{background:rgba(245,196,81,.16);color:var(--gold)}
.role-partner{background:rgba(54,179,126,.15);color:var(--ok)}
.btn-sm{padding:.45rem .8rem;font-size:.85rem;border-radius:9px}
.addrow{display:flex;gap:.5rem;flex-wrap:wrap;margin:0 0 1.2rem;background:var(--bg-2);border:1px solid var(--line);border-radius:12px;padding:.7rem}
.addrow input,.addrow select{flex:1;min-width:130px;background:var(--bg);border:1px solid var(--line);color:var(--ink);border-radius:9px;padding:.55rem .7rem;font:inherit}
.subtabs{display:flex;gap:.4rem;margin-bottom:1rem}
.subtabs button{background:var(--bg-2);border:1px solid var(--line);color:var(--muted);border-radius:999px;padding:.4rem .85rem;font:inherit;font-size:.84rem;font-weight:600;cursor:pointer}
.subtabs button.active{background:var(--accent);color:#fff;border-color:transparent}
.kpi{display:flex;gap:1rem;flex-wrap:wrap;margin-bottom:1.2rem}
.kpi .box{flex:1;min-width:150px;background:var(--card);border:1px solid var(--line);border-radius:14px;padding:1rem 1.1rem}
.kpi .box span{font-size:.78rem;color:var(--muted)}
.kpi .box b{display:block;font-size:1.6rem;letter-spacing:-.02em;margin-top:.2rem}
.subcard{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:1rem;margin-bottom:.8rem}
.subcard .top{display:flex;justify-content:space-between;gap:1rem;align-items:flex-start}
.subcard h4{margin:0 0 .2rem;font-size:.98rem}
.subcard .meta{color:var(--muted);font-size:.84rem;margin:.3rem 0;word-break:break-all}
.subcard .meta a,.subcard h4 a{color:inherit}
.subcard h4 a:hover,.subcard .meta a:hover{color:var(--gold)}
.subcard .when{color:var(--soft);font-size:.78rem;margin-top:.15rem}
.subcard.declined{border-color:rgba(229,72,77,.38)}
.sub-steps{display:flex;align-items:center;gap:.35rem;margin:.85rem 0 .1rem;flex-wrap:wrap}
.sub-steps .step{display:flex;align-items:center;gap:.35rem;font-size:.73rem;color:var(--muted)}
.sub-steps .step .dot{width:.7rem;height:.7rem;border-radius:50%;border:1.5px solid var(--line);background:transparent;flex:none}
.sub-steps .step.done{color:var(--soft)}
.sub-steps .step.done .dot{background:var(--ok);border-color:var(--ok)}
.sub-steps .step.cur{color:var(--gold);font-weight:700}
.sub-steps .step.cur .dot{background:var(--gold);border-color:var(--gold)}
.sub-steps .sep{flex:1 1 .8rem;min-width:.6rem;height:1px;background:var(--line)}
.sub-next{font-size:.84rem;color:var(--soft);margin:.55rem 0 0;line-height:1.5}
.subcard.declined .sub-next{color:var(--muted)}
.subcard [data-resub]{margin-top:.7rem}
.filmlist-cta{display:flex;gap:.7rem;align-items:center;flex-wrap:wrap;margin-top:1rem}
.filmlist-cta .status{margin:0}
@media (max-width:680px){.ledger thead{display:none}.ledger,.ledger tbody,.ledger tr,.ledger td{display:block;width:100%}.ledger td{border:0;padding:.25rem .2rem;display:flex;justify-content:space-between;align-items:baseline;gap:1rem;text-align:right}.ledger td[data-label]:not([data-label=""])::before{content:attr(data-label);color:var(--soft);font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em;flex:none;text-align:left}.ledger tr{border:1px solid var(--line);border-radius:12px;padding:.6rem .8rem;margin-bottom:.7rem}}

.amtinput{background:var(--bg);border:1px solid var(--line);color:var(--ink);border-radius:9px;padding:.45rem .6rem;font:inherit;max-width:120px}

/* ---- onboarding checklist ---- */
.checklist{list-style:none;margin:0;padding:0;display:grid;gap:.7rem}
.checklist li{display:flex;align-items:center;gap:.8rem;background:var(--bg-2);border:1px solid var(--line);border-radius:12px;padding:.7rem .9rem}
.checklist .ck{width:24px;height:24px;border-radius:50%;border:1.5px solid var(--line);color:var(--ok);display:grid;place-items:center;font-weight:800;font-size:.8rem;flex:none}
.checklist li.is-done .ck{background:rgba(54,179,126,.15);border-color:rgba(54,179,126,.45)}
.checklist li.is-done b{color:var(--muted);text-decoration:line-through;text-decoration-color:var(--soft)}
.checklist .ct{flex:1;min-width:0}
.checklist .ct b{display:block;font-size:.95rem}
.checklist .ct small{color:var(--muted);font-size:.82rem}

/* ---- activity timeline ---- */
.tl{list-style:none;margin:0;padding:0;display:grid;gap:0}
.tl li{display:flex;gap:.85rem;padding:.75rem 0;border-bottom:1px solid var(--line)}
.tl li:last-child{border-bottom:0}
.tl .ti{width:30px;height:30px;border-radius:9px;background:var(--bg-2);border:1px solid var(--line);display:grid;place-items:center;font-size:1rem;flex:none}
.tl .td{flex:1;min-width:0}
.tl .td b{display:block;font-size:.93rem;font-weight:600}
.tl .td small{display:block;color:var(--muted);font-size:.8rem;word-break:break-all}
.tl .td time{display:block;color:var(--soft);font-size:.76rem;margin-top:.15rem}
.tl-empty{color:var(--muted);font-size:.9rem;padding:.4rem 0}

/* ---- payout on file ---- */
.payout-onfile{background:var(--bg-2);border:1px solid var(--line);border-radius:10px;padding:.6rem .8rem;font-size:.88rem;color:var(--muted);margin:0 0 1rem}
.payout-onfile b{color:var(--ink)}
/* Creator payout history — itemized record of paid videos */
.payhist{list-style:none;margin:.2rem 0 0;padding:0;display:grid;gap:0}
.payhist li{display:flex;gap:.9rem;align-items:baseline;padding:.7rem 0;border-bottom:1px solid var(--line)}
.payhist li:last-child{border-bottom:0}
.payhist .ph-amt{font-weight:700;color:var(--ok);font-size:1rem;flex:none;min-width:62px}
.payhist .ph-d{flex:1;min-width:0}
.payhist .ph-d b{display:block;font-size:.9rem;font-weight:600;word-break:break-all}
.payhist .ph-d b a{color:inherit}
.payhist .ph-d b a:hover{color:var(--gold)}
.payhist .ph-d time{display:block;color:var(--soft);font-size:.78rem;margin-top:.12rem}
.payhist-total{margin:.9rem 0 0}

/* ---- announcements banner (creator dashboard) ---- */
.annbar{display:flex;gap:.8rem;align-items:flex-start;background:linear-gradient(120deg,rgba(245,196,81,.12),rgba(229,72,77,.10));border:1px solid var(--line);border-left:3px solid var(--gold);border-radius:14px;padding:.9rem 1.1rem;margin-bottom:1rem}
.annbar .annic{font-size:1.1rem;line-height:1.4;flex:none}
.annbar b{display:block;font-size:.98rem}
.annbar span{display:block;color:var(--muted);font-size:.88rem;margin-top:.15rem}

/* ---- filming guide (collapsible) ---- */
.guide summary{cursor:pointer;font-weight:700;font-size:1.02rem;list-style:none;display:flex;align-items:center;gap:.55rem}
.guide summary::-webkit-details-marker{display:none}
.guide summary::before{content:"▸";color:var(--accent);transition:transform .2s;flex:none}
.guide[open] summary::before{transform:rotate(90deg)}
.tips{margin:1rem 0 0;padding-left:1.1rem;display:grid;gap:.6rem}
.tips li{color:var(--muted);font-size:.92rem;line-height:1.5}
.tips b{color:var(--ink)}

/* ---- admin Overview: clickable triage cards ---- */
.kpi .box[data-jump]{cursor:pointer;transition:border-color .15s,transform .12s}
.kpi .box[data-jump]:hover{border-color:var(--accent);transform:translateY(-2px)}
.kpi .box.attn{border-color:var(--accent);box-shadow:inset 0 0 0 1px var(--accent)}
.kpi .box.attn b{color:var(--accent)}

/* --- loading states (skeletons + spinner) so async KPIs/lists don't flash empty/$0 --- */
@keyframes ihrShimmer{0%{background-position:-200px 0}100%{background-position:calc(200px + 100%) 0}}
@keyframes ihrSpin{to{transform:rotate(360deg)}}
.sk{display:inline-block;min-width:1.8em;height:.9em;vertical-align:-.05em;border-radius:6px;
  background:linear-gradient(90deg,var(--line) 25%,#2c3039 37%,var(--line) 63%);
  background-size:400px 100%;animation:ihrShimmer 1.2s ease-in-out infinite}
.sk-amt{min-width:3em}
.loadingmsg{color:var(--muted);text-align:center;padding:1.6rem;font-size:.92rem}
.loadingmsg::before{content:"";display:inline-block;width:.95em;height:.95em;margin-right:.5em;vertical-align:-.12em;
  border:2px solid var(--line);border-top-color:var(--gold);border-radius:50%;animation:ihrSpin .7s linear infinite}
@media (prefers-reduced-motion:reduce){.sk{animation:none}.loadingmsg::before{animation:none;border-top-color:var(--line)}}

/* ---- admin search box ---- */
.searchbox{width:100%;background:var(--bg);border:1px solid var(--line);color:var(--ink);border-radius:10px;padding:.6rem .85rem;font:inherit;margin:0 0 1rem}
.searchbox:focus{outline:none;border-color:var(--accent)}
.searchbox:focus-visible{outline:2px solid var(--gold);outline-offset:2px}
.searchbox::placeholder{color:var(--soft)}
