/* =========================================================================
   Booky — Creator Studio  •  upload-only styles
   Layers on top of the shared Nightfall Library system (styles.css).
   Reuses shared tokens/components; only adds what the studio needs.
   The console is intentionally calmer & more utilitarian than the
   marketing surfaces: less spectacle, more signal.
   ========================================================================= */

/* ---------- Studio header ---------- */
.studio-head{ padding:var(--s8) 0 var(--s6); position:relative; }
.studio-head .eyebrow{ margin-bottom:var(--s4); }
.studio-head h1{ font-size:clamp(32px,4.4vw,52px); max-width:18ch; }
.studio-head .lede{ max-width:58ch; margin-top:var(--s4); font-size:clamp(15px,1.6vw,17px); color:var(--on-med); line-height:1.55; }
.studio-head .head-meta{ display:flex; flex-wrap:wrap; gap:var(--s4); margin-top:var(--s5); }
.studio-head .head-meta .pill{ display:inline-flex; align-items:center; gap:8px; font-size:13px; color:var(--on-med);
  padding:9px 15px; border-radius:var(--r-pill); background:rgba(244,241,234,0.04); border:1px solid var(--line); }
.studio-head .head-meta .pill b{ color:var(--on-high); font-weight:600; }
.studio-head .head-meta .pill .k{ color:var(--gold); }

/* the studio grid — publish flow (wider) beside the dashboard */
.studio-grid{ display:grid; grid-template-columns:1.15fr 0.85fr; gap:var(--s6); align-items:start; margin-bottom:var(--s8); }
@media (max-width:1000px){ .studio-grid{ grid-template-columns:1fr; } }

.col-stack > * + *{ margin-top:var(--s5); }

/* section caption inside panels */
.panel-head{ display:flex; align-items:center; justify-content:space-between; gap:var(--s4); margin-bottom:var(--s5); }
.panel-head h2{ font-size:21px; }
.panel-head .sub{ font-size:12.5px; color:var(--on-low); margin-top:3px; }
.kicker{ font-family:var(--f-text); font-size:11px; font-weight:600; letter-spacing:0.14em;
  text-transform:uppercase; color:var(--on-low); }

/* =========================================================================
   PUBLISH STATUS STEPPER  (draft → in review → published)
   ========================================================================= */
.stepper{ display:flex; align-items:flex-start; gap:0; margin:var(--s2) 0 var(--s6); }
.step{ flex:1; display:flex; flex-direction:column; align-items:center; gap:9px; position:relative; text-align:center; }
.step .node{ width:34px; height:34px; border-radius:50%; display:grid; place-items:center;
  background:rgba(244,241,234,0.05); border:1px solid var(--line-strong); color:var(--on-low);
  font-size:14px; font-weight:700; flex:0 0 auto; z-index:1;
  transition:background var(--d-base) var(--ease), border-color var(--d-base) var(--ease),
             color var(--d-base) var(--ease), box-shadow var(--d-base) var(--ease); }
.step .s-label{ font-size:12.5px; font-weight:600; color:var(--on-low); transition:color var(--d-base) var(--ease); }
.step .s-sub{ font-size:11px; color:var(--tx-faint); }
/* connector line between nodes */
.step::before{ content:""; position:absolute; top:17px; left:-50%; width:100%; height:2px;
  background:var(--line-strong); z-index:0; transition:background var(--d-base) var(--ease); }
.step:first-child::before{ display:none; }
/* states */
.step.done .node{ background:var(--gold); border-color:var(--gold); color:#241b04; box-shadow:0 4px 16px rgba(232,184,100,0.3); }
.step.done .s-label{ color:var(--on-high); }
.step.done::before{ background:linear-gradient(90deg,var(--gold-deep),var(--gold)); }
.step.current .node{ background:rgba(232,184,100,0.12); border-color:var(--gold); color:var(--gold-bright);
  box-shadow:0 0 0 4px rgba(232,184,100,0.12); }
.step.current .s-label{ color:var(--gold-bright); }

/* =========================================================================
   DROPZONE  (refined over the shared .dropzone base)
   ========================================================================= */
.dropzone{ position:relative; overflow:hidden; }
.dropzone .dz-ic{ width:60px; height:60px; margin:0 auto 14px; border-radius:50%; display:grid; place-items:center;
  font-size:26px; color:var(--gold-bright); background:radial-gradient(circle at 50% 35%, rgba(232,184,100,0.18), rgba(232,184,100,0.04));
  border:1px solid rgba(232,184,100,0.28); transition:transform var(--d-base) var(--ease); }
.dropzone:hover .dz-ic, .dropzone.drag .dz-ic{ transform:translateY(-3px); }
.dropzone .dz-formats{ display:inline-flex; gap:6px; margin-top:14px; flex-wrap:wrap; justify-content:center; }
.dropzone .dz-formats span{ font-size:10.5px; font-weight:700; letter-spacing:0.08em; padding:4px 10px; border-radius:var(--r-pill);
  background:rgba(244,241,234,0.05); border:1px solid var(--line); color:var(--on-med); }
.dropzone .dz-browse{ color:var(--gold); font-weight:600; text-decoration:underline; text-underline-offset:3px; cursor:pointer; }

/* uploaded item — surface the real PDF with a thumb */
.uploaded-item .uf-ic{ position:relative; overflow:hidden; }
.uploaded-item .uf-ic::after{ content:""; position:absolute; left:0; right:0; top:0; height:40%;
  background:linear-gradient(180deg,rgba(255,255,255,0.18),transparent); }
.uf-name{ font-family:var(--f-display); font-size:15.5px; font-weight:600; }
.uf-status{ font-size:11px; }
.uploaded-item .row{ display:flex; justify-content:space-between; align-items:center; gap:12px; }

/* =========================================================================
   FORM  (refined over shared .form-grid / .field)
   ========================================================================= */
.field .hint{ font-size:11.5px; color:var(--on-low); font-weight:400; text-transform:none; letter-spacing:0; }
.field .req{ color:var(--gold); }
fieldset{ border:none; margin:0; padding:0; min-width:0; }
fieldset legend{ padding:0; }
/* legend styled to match shared .field label */
.field-legend{ font-size:12px; letter-spacing:0.06em; text-transform:uppercase; color:var(--on-low);
  font-weight:600; margin-bottom:6px; }
.field select{ appearance:none; -webkit-appearance:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%23B8BAC8' stroke-width='1.6' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
  background-repeat:no-repeat; background-position:right 14px center; padding-right:38px; }

/* tag-style category chips reuse shared .chip; wrap them */
.chip-row{ display:flex; flex-wrap:wrap; gap:8px; }
.chip-row .chip{ user-select:none; }

/* price row */
.price-wrap{ display:flex; align-items:center; gap:12px; flex-wrap:wrap; }
.price-input{ position:relative; flex:1; min-width:140px; display:none; }
.price-input.show{ display:block; }
.price-input .cur{ position:absolute; left:14px; top:50%; transform:translateY(-50%); color:var(--on-low); font-size:14px; pointer-events:none; }
.price-input input{ padding-left:30px; }

/* attestation — the rights/DMCA checkbox, with validation state */
.attest{ align-items:flex-start; transition:border-color var(--d-base) var(--ease), background var(--d-base) var(--ease); }
.attest .copy{ line-height:1.5; }
.attest .copy b{ color:var(--on-high); }
.attest a{ color:var(--gold); text-decoration:underline; text-underline-offset:2px; }
.attest.invalid{ border-color:var(--ember); background:rgba(229,68,109,0.06); }
.attest-error{ display:none; font-size:12px; color:var(--ember); margin-top:8px; align-items:center; gap:6px; }
.attest-error.show{ display:flex; }
.attest-error::before{ content:"!"; display:inline-grid; place-items:center; width:16px; height:16px; border-radius:50%;
  background:var(--ember); color:#fff; font-size:11px; font-weight:700; }

/* publish footer row */
.publish-row{ display:flex; align-items:center; gap:var(--s4); flex-wrap:wrap; }
.publish-row .save-note{ font-size:12px; color:var(--on-low); }
.publish-row .save-note b{ color:var(--on-med); }

/* =========================================================================
   SUCCESS STATE  (replaces the form on publish)
   ========================================================================= */
.success{ display:none; text-align:center; padding:var(--s7) var(--s4); }
.success.show{ display:block; }
.success .seal{ width:74px; height:74px; margin:0 auto var(--s5); border-radius:50%; display:grid; place-items:center;
  font-size:32px; color:#241b04; background:linear-gradient(135deg,var(--gold-bright),var(--gold));
  box-shadow:0 10px 40px rgba(232,184,100,0.45); }
.success h2{ font-size:26px; margin-bottom:10px; }
.success p{ color:var(--on-med); max-width:42ch; margin:0 auto var(--s5); }
.success .btn-row{ display:flex; gap:12px; justify-content:center; flex-wrap:wrap; }
@media (prefers-reduced-motion: no-preference){
  .success.show .seal{ animation:bk-seal 560ms var(--ease-emph) both; }
  @keyframes bk-seal{ 0%{ transform:scale(0.4); opacity:0; } 60%{ transform:scale(1.08); } 100%{ transform:scale(1); opacity:1; } }
}

/* =========================================================================
   EARNINGS DASHBOARD
   ========================================================================= */
.earn-card{ position:relative; }
.earn-card .big{ font-variant-numeric:tabular-nums; }
.earn-card .delta.flat{ color:var(--on-low); }
.earn-card .ic{ position:absolute; top:var(--s5); right:var(--s5); font-size:16px; opacity:0.5; }

/* payout / balance card — the memorable touch: a "ledger receipt" feel */
.payout{ background:
    radial-gradient(120% 90% at 80% -10%, rgba(232,184,100,0.12), transparent 60%),
    linear-gradient(180deg,var(--bg-elevated),var(--bg-card));
  border:1px solid rgba(232,184,100,0.22); }
.payout .balance{ display:flex; align-items:baseline; gap:10px; margin:var(--s2) 0 var(--s4); }
.payout .balance .amt{ font-family:var(--f-display); font-size:clamp(40px,6vw,56px); font-weight:600; line-height:1;
  color:var(--gold-bright); letter-spacing:-0.02em; font-variant-numeric:tabular-nums;
  text-shadow:0 0 30px rgba(232,184,100,0.25); }
.payout .balance .cur{ font-family:var(--f-display); font-size:24px; color:var(--gold); }
.payout .ledger{ list-style:none; margin:0 0 var(--s5); padding:var(--s4) 0 0; border-top:1px dashed var(--line-strong); }
.payout .ledger li{ display:flex; justify-content:space-between; align-items:center; padding:8px 0; font-size:13.5px; color:var(--on-med); }
.payout .ledger li span:last-child{ font-variant-numeric:tabular-nums; color:var(--on-high); font-weight:600; }
.payout .ledger li.total{ border-top:1px solid var(--line); margin-top:6px; padding-top:14px; font-size:15px; color:var(--on-high); }
.payout .ledger li.total span:last-child{ color:var(--gold-bright); }
.payout .next-date{ display:flex; align-items:center; gap:8px; font-size:12.5px; color:var(--on-low); margin-bottom:var(--s5); }
.payout .next-date .dot{ width:7px; height:7px; border-radius:50%; background:var(--success); box-shadow:0 0 8px var(--success); }

/* chart — refined over shared .chart */
.chart{ height:170px; }
.chart .bar{ cursor:default; }
.chart .bar::after{ content:attr(data-val); position:absolute; top:-22px; left:0; right:0; text-align:center;
  font-size:11px; font-weight:600; color:var(--gold-soft); font-variant-numeric:tabular-nums;
  opacity:0; transform:translateY(4px); transition:opacity var(--d-fast) var(--ease), transform var(--d-fast) var(--ease); }
.chart .bar:hover::after, .chart .bar:focus-visible::after{ opacity:1; transform:none; }
.chart .bar.peak{ background:linear-gradient(180deg,var(--gold-bright),var(--gold)); box-shadow:0 0 20px rgba(232,184,100,0.3); }
.chart-legend{ display:flex; justify-content:space-between; align-items:center; margin-top:var(--s6); font-size:12px; color:var(--on-low); }
.chart-legend .swatch{ display:inline-block; width:10px; height:10px; border-radius:3px; vertical-align:-1px; margin-right:6px;
  background:linear-gradient(180deg,var(--gold-soft),var(--gold-deep)); }

/* top-performing book card */
.top-book{ display:flex; gap:16px; align-items:center; }
.top-book .mini-cover{ width:66px; aspect-ratio:2/3; border-radius:8px; flex:0 0 auto; box-shadow:var(--sh-card);
  position:relative; overflow:hidden; }
.top-book .mini-cover .gloss{ position:absolute; inset:0; background:linear-gradient(135deg,rgba(255,255,255,0.16),transparent 50%); }
.top-book .mini-cover .mt{ position:absolute; left:8px; right:8px; top:9px; font-family:var(--f-display); font-size:11px;
  font-weight:600; color:#fff; line-height:1.1; text-shadow:0 1px 4px rgba(0,0,0,0.5); }
.top-book .tb-title{ font-family:var(--f-display); font-size:18px; font-weight:600; }
.top-book .tb-meta{ font-size:12.5px; color:var(--on-low); margin:5px 0 9px; font-variant-numeric:tabular-nums; }
.share-track{ height:8px; background:rgba(255,255,255,0.06); border-radius:99px; overflow:hidden; }
.share-track i{ display:block; height:100%; width:0; background:linear-gradient(90deg,var(--gold-deep),var(--gold-soft));
  border-radius:99px; transition:width var(--d-cine) var(--ease); }
.share-cap{ font-size:11.5px; color:var(--on-low); margin-top:8px; }

/* small print under panels */
.fine{ font-size:12px; color:var(--on-low); line-height:1.5; margin-top:var(--s4); }

/* reduced motion: chart bars + share track render at final height, no anim */
@media (prefers-reduced-motion: reduce){
  .chart .bar{ transition:none !important; }
  .share-track i{ transition:none !important; }
}
