/*
 * Shared components — cards, dialogs, row lists, badges/status pills,
 * alerts, and small utilities (including classes that templates already
 * reference but no stylesheet previously defined).
 * Tokens come from tokens.css; no :root declarations here.
 */

/* ---- Card (rendered by {% card %}) ---- */
.card{margin:var(--space-3) 0;padding:var(--space-3);border:1px solid var(--border);border-radius:var(--r-3);background:#fff;box-shadow:0 1px 0 rgba(var(--shadow-color)/.04)}
.card-head{display:flex;align-items:baseline;gap:var(--space-2);flex-wrap:wrap;margin-bottom:var(--space-2)}
.card-head h2{margin:0}
.card-head .subdued{margin:0;flex-basis:100%;font-size:var(--fs-1)}
.card-actions{margin-left:auto;display:flex;gap:var(--space-2);align-items:center}
.card-body{min-width:0}
/* Subheadings inside a card (e.g. Documents / Pipelines under one Candidate card) */
.card-subhead{margin:var(--space-4) 0 var(--space-2);font-size:var(--fs-2);text-transform:uppercase;letter-spacing:.04em;color:var(--muted)}
.card-subhead-row{display:flex;align-items:center;justify-content:space-between;gap:var(--space-2);margin-top:var(--space-4)}
.card-subhead-row .card-subhead{margin:0}
/* Convert-action buttons row in the page header */
.header-convert{margin-top:6px}

/* Group identity = hue: tone accent on the left border + header chip. */
.card[data-tone]{border-left:3px solid var(--tone-ink,var(--border))}
.card[data-tone] .card-head .card-chip{display:inline-block;padding:2px 8px;border-radius:var(--r-1);background:var(--tone,var(--panel));color:var(--tone-ink,var(--ink))}
.card[data-tone=identity]{--tone:var(--tone-identity);--tone-ink:var(--tone-identity-ink)}
.card[data-tone=contact]{--tone:var(--tone-contact);--tone-ink:var(--tone-contact-ink)}
.card[data-tone=languages]{--tone:var(--tone-languages);--tone-ink:var(--tone-languages-ink)}
.card[data-tone=system]{--tone:var(--tone-system);--tone-ink:var(--tone-system-ink)}
.card[data-tone=finance]{--tone:var(--tone-finance);--tone-ink:var(--tone-finance-ink)}
.card[data-tone=compliance]{--tone:var(--tone-compliance);--tone-ink:var(--tone-compliance-ink)}
.card[data-tone=danger]{--tone:var(--tone-danger);--tone-ink:var(--tone-danger-ink)}

/* ---- Modal (native <dialog>, wired by js/ui/modal.js) ----
   Scoped to dialog.modal so it cannot collide with the legacy div.modal
   overlays that remain on unconverted pages. */
dialog.modal{width:min(92vw,560px);padding:0;border:1px solid var(--border);border-radius:var(--r-3);box-shadow:0 10px 30px rgba(var(--shadow-color)/.25);color:var(--ink)}
dialog.modal::backdrop{background:rgba(0,0,0,.35)}
dialog.modal[data-wide]{width:min(92vw,720px)}
dialog.modal .modal-head{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--border)}
dialog.modal .modal-head h2{margin:0;flex:1 1 auto}
dialog.modal .modal-body{padding:var(--space-4)}
dialog.modal .modal-foot{display:flex;justify-content:flex-end;gap:var(--space-2);padding:var(--space-3) var(--space-4);border-top:1px solid var(--border)}
dialog.modal[data-danger] .modal-head{background:var(--danger-soft)}
dialog.modal .confirm-code{display:inline-block;padding:6px 10px;border:1px solid var(--border);border-radius:var(--r-1);background:var(--panel);font-weight:700;font-size:var(--fs-5);letter-spacing:3px;user-select:all}
dialog.modal .confirm-phrase{display:inline-block;padding:4px 8px;border:1px solid var(--border);border-radius:var(--r-1);background:var(--panel);font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;user-select:all}
dialog.modal .confirm-input-code{width:120px}

/* ---- Row list (extensible add/remove/reorder rows, js/ui/rowlist.js) ---- */
.rowlist-items{display:flex;flex-direction:column;gap:var(--space-1)}
.rowlist-row{display:grid;grid-template-columns:var(--row-cols,auto 1fr auto);gap:var(--space-2);align-items:center;padding:var(--space-1) var(--space-2);border:1px solid var(--border);border-radius:var(--r-2);background:#fff}
.rowlist-row .drag-handle{cursor:move;color:var(--muted);user-select:none}
.rowlist-row.is-removing{opacity:.55;background:var(--danger-soft)}
.rowlist-add-row{margin-top:var(--space-2)}
.rowlist-row .person-links{font-size:var(--fs-1);color:var(--muted)}
.rowlist-row label{display:block;min-width:0}
.rowlist-row select,.rowlist-row input{width:100%}
/* Row layouts (set per row partial; replaces the inline grid styles) */
.rowlist-row.row-select{--row-cols:1fr auto}
.rowlist-row.row-drag-select{--row-cols:auto 1fr auto}
.rowlist-row.row-contact{--row-cols:1fr 1fr 1fr auto}
.rowlist-row.row-drag-contact{--row-cols:auto 1fr 1fr 1fr auto}
@media(max-width:720px){
  .rowlist-row.row-contact{--row-cols:1fr auto}
  .rowlist-row.row-drag-contact{--row-cols:auto 1fr auto}
}

/* ---- Attachment panel (ui/attachment_panel.html) ---- */
.attachment-upload{display:grid;grid-template-columns:1fr 1fr 1fr auto;gap:var(--space-2);align-items:end;margin-top:var(--space-2);max-width:760px}
@media(max-width:720px){.attachment-upload{grid-template-columns:1fr}}

/* ---- Status pills (workflow state = the status ramp, never group hue) ---- */
.status,
select.status-select{border-radius:var(--r-1);padding:4px 8px;border:1px solid rgba(0,0,0,.08);font-weight:600}
.status[data-status],select.status-select[data-status]{background:var(--st-bg,var(--panel));color:var(--st-ink,var(--muted))}
[data-status=APPLIED]{--st-bg:var(--st-applied);--st-ink:var(--st-applied-ink)}
[data-status=PROSPECT]{--st-bg:var(--st-prospect);--st-ink:var(--st-prospect-ink)}
[data-status=QUALIFIED]{--st-bg:var(--st-qualified);--st-ink:var(--st-qualified-ink)}
[data-status=CV_SENT]{--st-bg:var(--st-cv-sent);--st-ink:var(--st-cv-sent-ink)}
[data-status=SHORTLISTED]{--st-bg:var(--st-shortlisted);--st-ink:var(--st-shortlisted-ink)}
[data-status=INTERVIEW]{--st-bg:var(--st-interview);--st-ink:var(--st-interview-ink)}
[data-status=OFFERED]{--st-bg:var(--st-offered);--st-ink:var(--st-offered-ink)}
[data-status=ACCEPTED]{--st-bg:var(--st-accepted);--st-ink:var(--st-accepted-ink)}
[data-status=HIRED]{--st-bg:var(--st-hired);--st-ink:var(--st-hired-ink)}
[data-status=REJECTED]{--st-bg:var(--st-rejected);--st-ink:var(--st-rejected-ink)}
[data-status=UNCLARIFIED]{--st-bg:var(--st-unclarified);--st-ink:var(--st-unclarified-ink)}
/* Placement, billing-document and payment-direction states (detail-page
   header chips) — mapped onto the existing ramp tokens. */
[data-status=ACTIVE]{--st-bg:var(--st-accepted);--st-ink:var(--st-accepted-ink)}
[data-status=ENDED]{--st-bg:var(--st-unclarified);--st-ink:var(--st-unclarified-ink)}
[data-status=ON_HOLD]{--st-bg:var(--st-offered);--st-ink:var(--st-offered-ink)}
[data-status=DRAFT]{--st-bg:var(--st-prospect);--st-ink:var(--st-prospect-ink)}
[data-status=SENT]{--st-bg:var(--st-applied);--st-ink:var(--st-applied-ink)}
[data-status=PARTIAL]{--st-bg:var(--st-offered);--st-ink:var(--st-offered-ink)}
[data-status=PAID]{--st-bg:var(--st-hired);--st-ink:var(--st-hired-ink)}
[data-status=OVERDUE]{--st-bg:var(--st-rejected);--st-ink:var(--st-rejected-ink)}
[data-status=CANCELLED]{--st-bg:var(--st-unclarified);--st-ink:var(--st-unclarified-ink)}
[data-status=IN]{--st-bg:var(--st-accepted);--st-ink:var(--st-accepted-ink)}
[data-status=OUT]{--st-bg:var(--st-offered);--st-ink:var(--st-offered-ink)}
/* GDPR contact-request states (gdpr_requests_detail/list) — mapped onto the
   existing tone tokens: OPEN amber, IN_PROGRESS blue, RESOLVED green,
   CLOSED grey. */
[data-status=OPEN]{--st-bg:var(--tone-compliance);--st-ink:var(--tone-compliance-ink)}
[data-status=IN_PROGRESS]{--st-bg:var(--tone-identity);--st-ink:var(--tone-identity-ink)}
[data-status=RESOLVED]{--st-bg:var(--tone-contact);--st-ink:var(--tone-contact-ink)}
[data-status=CLOSED]{--st-bg:var(--st-unclarified);--st-ink:var(--st-unclarified-ink)}

/* ---- Badge tones (group identity on small labels) ---- */
.badge.tone-identity{background:var(--tone-identity);border-color:var(--tone-identity-ink);color:var(--tone-identity-ink)}
.badge.tone-contact{background:var(--tone-contact);border-color:var(--tone-contact-ink);color:var(--tone-contact-ink)}
.badge.tone-languages{background:var(--tone-languages);border-color:var(--tone-languages-ink);color:var(--tone-languages-ink)}
.badge.tone-system{background:var(--tone-system);border-color:var(--tone-system-ink);color:var(--tone-system-ink)}
.badge.tone-finance{background:var(--tone-finance);border-color:var(--tone-finance-ink);color:var(--tone-finance-ink)}
.badge.tone-compliance,.badge.tone-warn{background:var(--tone-compliance);border-color:var(--tone-compliance-ink);color:var(--tone-compliance-ink)}
.badge.tone-danger{background:var(--tone-danger);border-color:var(--tone-danger-ink);color:var(--tone-danger-ink)}

/* Legacy badge colour classes already used in templates (previously undefined
   or restated inline) — mapped onto the tone palette. */
.badge-blue{background:var(--tone-identity);color:var(--tone-identity-ink)}
.badge-green{background:var(--tone-contact);color:var(--tone-contact-ink)}
.badge-purple{background:var(--tone-system);color:var(--tone-system-ink)}
.badge-gray{background:#f3f4f6;color:#6b7280}
.badge-warning{background:var(--tone-compliance);color:var(--tone-compliance-ink)}

/* Tone-tinted buttons (same palette as card/badge tones) — for colour-coding
   action banners by function. */
.btn-tone-identity{background:var(--tone-identity);color:var(--tone-identity-ink);border:1px solid var(--tone-identity-ink)}
.btn-tone-contact{background:var(--tone-contact);color:var(--tone-contact-ink);border:1px solid var(--tone-contact-ink)}
.btn-tone-compliance{background:var(--tone-compliance);color:var(--tone-compliance-ink);border:1px solid var(--tone-compliance-ink)}
.btn-tone-system{background:var(--tone-system);color:var(--tone-system-ink);border:1px solid var(--tone-system-ink)}
.btn-tone-danger{background:var(--tone-danger);color:var(--tone-danger-ink);border:1px solid var(--tone-danger-ink)}
.btn-tone-identity:hover,.btn-tone-contact:hover,.btn-tone-compliance:hover,.btn-tone-system:hover,.btn-tone-danger:hover{filter:brightness(0.97)}
/* Archive actions: a solid but calmer red than the intense delete red (.btn-danger). */
.btn-danger-muted{background:var(--danger-muted);color:#fff;border:1px solid var(--danger-muted)}
.btn-danger-muted:hover{filter:brightness(0.95)}

/* Action banner: equal-height buttons whether they are <a> or <button>. */
.btn-banner{margin-left:auto;display:flex;gap:var(--space-2);align-items:center;flex-wrap:wrap}
.btn-banner .btn{display:inline-flex;align-items:center;justify-content:center;min-height:38px;box-sizing:border-box}

/* ---- Alerts (real component replacing the .toast position:static hack) ---- */
.alert{margin:var(--space-3) 0;padding:var(--space-2) var(--space-3);border:1px solid var(--border);border-radius:var(--r-2);background:var(--panel)}
.alert.alert-danger{border-color:var(--danger);background:var(--danger-soft);color:var(--danger-ink)}
.alert.alert-warning{border-color:var(--tone-compliance-ink);background:var(--tone-compliance);color:var(--tone-compliance-ink)}

/* ---- Phantom utility/button classes referenced across templates ---- */
.btn-primary{background:var(--accent);color:var(--accent-ink);border:0}
.btn-sm{padding:4px 8px;font-size:var(--fs-1)}
.muted{color:var(--muted)}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:10px}
@media(max-width:560px){.grid-2{grid-template-columns:1fr}}
.sr-only{position:absolute;width:1px;height:1px;margin:-1px;padding:0;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap;border:0}

/* ---- Pipeline rows (people_form + job recruiting share these) ---- */
.pipeline-notes{width:100%;display:block;min-height:68px;line-height:1.4;padding:8px;border:1px solid var(--border);border-radius:var(--r-1);resize:vertical}
.notes-row td{background:#fcfdff;border-top:0;border-bottom:1px solid var(--border)}
.cell-actions{display:flex;gap:6px}

/* ---- Conflict-resolution option rows (person type modal) ---- */
.conflict-options{display:grid;gap:8px}
.conflict-option{display:flex;align-items:center;gap:8px;padding:8px;background:var(--panel);border-radius:var(--r-1)}
.conflict-option input{width:auto}

/* ---- Copyable identifier chip (TEID, refs) ---- */
.chip.copyable{user-select:all;font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace}

/* ---- Page header band (edit-page identity strip) ---- */
.page-head{display:flex;gap:var(--space-3);align-items:center;margin-bottom:var(--space-3)}
.page-head-avatar{width:64px;height:64px;object-fit:cover;border-radius:var(--r-2);border:1px solid var(--border)}
.page-head h1{margin:0}
.page-head-meta{display:flex;gap:var(--space-2);align-items:center;flex-wrap:wrap;margin:4px 0 0}
.page-head-actions{margin-left:auto;display:flex;gap:var(--space-2);align-items:center}
.nowrap{white-space:nowrap}

/* ---- Two-column detail layout (main form + side rail of cards) ---- */
.two-col{display:grid;grid-template-columns:2fr 1fr;gap:0 var(--space-3);align-items:start}
@media(max-width:1080px){.two-col{grid-template-columns:1fr}}

/* Sticky side rail ("review + update" pages, e.g. gdpr_requests_detail) */
.sticky-rail{position:sticky;top:16px}

/* Preserve user line breaks (message bodies, free-text quotes) */
.pre-wrap{white-space:pre-wrap}

/* ---- Key/value grid (label/value pairs inside cards; replaces the
   table-only .kv class that div-based templates misused) ---- */
.kv-grid{display:grid;grid-template-columns:180px 1fr;gap:var(--space-1) var(--space-3);margin:0}
.kv-grid dt,.kv-grid .kv-key{color:var(--muted);font-weight:600}
.kv-grid dd{margin:0}
@media(max-width:560px){.kv-grid{grid-template-columns:1fr}.kv-grid dd{margin-bottom:var(--space-2)}}

/* ---- Narrow public card (token/confirmation flow pages) ---- */
.narrow-card{max-width:420px;margin:40px auto;padding:var(--space-4);border:1px solid var(--border);border-radius:var(--r-2);background:#fff;box-shadow:0 1px 0 rgba(var(--shadow-color)/.04)}
.narrow-card h1{font-size:var(--fs-5)}

/* ---- Cookie/legal note under public auth forms (moved out of the
   signup_form.html inline style) ---- */
.legal-note{margin-top:12px;font-size:0.9em;color:#555}

/* ---- Wizard stepper ---- */
.stepper{display:flex;gap:var(--space-2);margin:0 0 var(--space-3);padding:0;list-style:none}
.stepper li{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:999px;border:1px solid var(--border);background:var(--panel);color:var(--muted);font-size:var(--fs-1)}
.stepper li.active{background:var(--accent-soft);border-color:var(--accent);color:var(--accent-ink);font-weight:600}
.stepper li.done{background:var(--tone-contact);border-color:var(--tone-contact-ink);color:var(--tone-contact-ink)}

/* ---- Full-bleed pages (editors) — set via {% block main_class %} ---- */
.content-wrapper.full-bleed{max-width:none;padding:0}

/* ---- Template editor chrome (utils email/page template editors) ---- */
.tag-toolbar{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin:6px 0}
.tag-toolbar #tag-buttons{display:inline-flex;gap:4px;flex-wrap:wrap}
.preview-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-3)}
@media(max-width:720px){.preview-grid{grid-template-columns:1fr}}
.preview-text{white-space:pre-wrap;background:var(--panel);padding:10px;border-radius:var(--r-1)}
.preview-frame{width:100%;height:400px;border:1px solid var(--border);border-radius:var(--r-1)}
.preview-frame-wrap{border:1px solid var(--border);border-radius:var(--r-1);overflow:hidden}
.preview-frame-wrap .preview-frame--tall{height:500px;border:none;border-radius:0}

/* Markdown editor toolbar (page template editor; markdown_utils.js injects
   .md-toolbar into #md-toolbar-container — scoped under the container so the
   different .md-toolbar skin in job_pages.css is unaffected). Moved here from
   the in-content <style> block of internal/page_templates/edit.html. */
#md-toolbar-container .md-toolbar{display:flex;gap:4px;margin-bottom:6px;flex-wrap:wrap}
#md-toolbar-container .md-toolbar button{padding:4px 8px;border:1px solid #ccc;background:#f5f5f5;border-radius:4px;cursor:pointer;font-weight:600;min-width:28px;transition:background-color .15s}
#md-toolbar-container .md-toolbar button:hover{background:#e5e5e5}
#md-content{font-family:'Consolas','Monaco','Lucida Console',monospace;font-size:14px;line-height:1.5}

/* ---- Toasts (moved out of base.html inline <style>) ---- */
.toast-root{position:fixed;right:20px;bottom:20px;z-index:9999;display:grid;gap:8px}
.toast{background:#1a1f29;color:#fff;padding:10px 12px;border-radius:var(--r-1);box-shadow:0 6px 24px rgba(0,0,0,.2)}
.toast.success{background:#2e7d32}
.toast.error{background:#b00020}
.toast.info{background:#1a1f29}
.toast.warning{background:#7a5b00}

/* ---- Site footer (moved out of base.html inline <style>) ---- */
.site-footer{margin-top:40px;padding:16px 0;border-top:1px solid var(--border);color:var(--muted);font-size:.9em}
.site-footer .container{max-width:1100px;margin:0 auto;padding:0 16px;display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap}
.site-footer a{color:#374151;text-decoration:underline}
