/* ─────────────────────────────────────────────────────────────────────────
   Data Hub — page styling for /data-hub and its sub-views.

   Adopted from the prototype Craig dropped 2026-05-23 (the canonical
   CodePen mockup, post-refinement). Everything is scoped under .dh-page
   so the bare class names (.card, .badge, .btn, .stat, etc.) can't leak
   into other pages — only elements inside <div class="dh-page"> pick
   them up.

   Stripped from the prototype:
     • body / sidebar / topbar / .main rules — ZDIV2's chrome already
       handles the app shell; the data hub renders inside the content area
     • The "Open Menu" button + page title at the top — ZDIV2 has these
       on every page via the layout
     • Footer copyright — out of scope for now

   The cross-cutting "UI not wired" utility (.dh-not-wired / .dh-nw-badge
   / .dh-nw-row) lives in chrome.css since other pages may need it too.
   ───────────────────────────────────────────────────────────────────────── */

.dh-page {
    /* Design tokens. Most overlap with chrome.css's --dh-* set, but the
       prototype's bare names are used by every selector below so we declare
       them here. The dh-page scope keeps them out of the global :root. */
    --navy:        #071426;
    --navy2:       #0D1E38;
    --blue:        #1565BE;
    --blue2:       #2178D4;
    --blue-pale:   #EDF4FB;
    --blue-mid:    #B0CEEC;
    --silver:      #8AAED4;
    --text:        #1a2535;
    --text2:       #4a6a8a;
    --text3:       #8AAED4;
    --border:      rgba(0,0,0,0.09);
    --bg:          #EEF3F8;
    --white:       #ffffff;
    --green:       #27500A;
    --green-pale:  #EAF3DE;
    --green-mid:   #3B6D11;
    --amber:       #633806;
    --amber-pale:  #FAEEDA;
    --amber-mid:   #BA7517;
    --red:         #791F1F;
    --red-pale:    #FCEBEB;
    --red-mid:     #A32D2D;
    --purple:      #3C3489;
    --purple-pale: #EEEDFE;
    --teal:        #085041;
    --teal-pale:   #E1F5EE;

    font-family: 'DM Sans', system-ui, sans-serif;
    color: var(--text);
    font-size: 14px;
    padding: 1.5rem;
    background: var(--bg);
    min-height: calc(100vh - 54px);
}

.dh-page a { text-decoration: none; color: inherit; }
.dh-page button { font-family: inherit; cursor: pointer; }

/* ── PAGE HEADER ── */
.dh-page .page-hdr {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 1.25rem;
}
.dh-page .page-title { font-size: 22px; font-weight: 700; }
.dh-page .page-sub { font-size: 12px; color: var(--text2); margin-top: 2px; }

.dh-page .level-pill {
    font-size: 10px;
    padding: 2px 9px;
    border-radius: 20px;
    background: var(--blue);
    color: #fff;
    font-weight: 700;
}
.dh-page .user-pill {
    font-size: 11px;
    padding: 4px 10px;
    border-radius: 20px;
    background: var(--navy2);
    color: #fff;
    font-weight: 600;
}

/* ── STATS ── */
.dh-page .stat-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 12px;
    margin-bottom: 1.25rem;
}
.dh-page .stat {
    background: var(--navy2);
    border-radius: 10px;
    padding: 14px 16px;
    border: 1px solid rgba(21, 101, 190, 0.3);
}
.dh-page .stat-n {
    font-size: 24px;
    font-weight: 700;
    color: #fff;
    font-family: 'DM Mono', monospace;
}
.dh-page .stat-l {
    font-size: 9px;
    color: var(--silver);
    margin-top: 3px;
    text-transform: uppercase;
    letter-spacing: 0.07em;
    font-weight: 600;
}
.dh-page .stat-d {
    font-size: 10px;
    margin-top: 6px;
    font-weight: 600;
}
.dh-page .up { color: #5FC470; }
.dh-page .dn { color: #F08080; }

/* ── TWO COL ── */
.dh-page .two-col {
    display: grid;
    grid-template-columns: 1fr 290px;
    gap: 1.1rem;
}

/* ── CARD ── */
.dh-page .card {
    background: var(--white);
    border: 0.5px solid var(--border);
    border-radius: 10px;
    margin-bottom: 1rem;
    overflow: hidden;
}
.dh-page .card-top { border-top: 2.5px solid var(--blue); }
.dh-page .card-hdr {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 12px 16px;
    border-bottom: 0.5px solid var(--border);
}
.dh-page .card-title {
    font-size: 10px;
    font-weight: 700;
    color: var(--text2);
    text-transform: uppercase;
    letter-spacing: 0.07em;
}
.dh-page .card-body { padding: 14px 16px; }

/* ── ENTITY GRID ── */
.dh-page .entity-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 8px;
}
.dh-page .ec {
    border: 0.5px solid var(--border);
    border-radius: 8px;
    padding: 10px 12px;
    cursor: pointer;
    transition: all 0.12s;
}
.dh-page .ec:hover {
    border-color: var(--blue);
    background: var(--blue-pale);
}
.dh-page .ec.hi {
    border: 1.5px solid var(--blue);
    background: var(--blue-pale);
}
.dh-page .ec-name { font-size: 11px; font-weight: 700; margin-bottom: 2px; }
.dh-page .ec.hi .ec-name { color: #0A3266; }
.dh-page .ec-count { font-size: 10px; color: var(--text2); }
.dh-page .ec-btns { display: flex; gap: 3px; margin-top: 6px; }
.dh-page .mb {
    font-size: 9px;
    padding: 2px 7px;
    border-radius: 4px;
    border: 0.5px solid;
    cursor: pointer;
    font-weight: 700;
    transition: opacity 0.1s;
    text-transform: lowercase;
}
.dh-page .mb:hover { opacity: 0.75; }
.dh-page .mb-i { background: var(--blue-pale);   color: #0A3266;        border-color: var(--blue-mid); }
.dh-page .mb-e { background: var(--green-pale);  color: var(--green);   border-color: #9FCF6A; }
.dh-page .mb-a { background: var(--purple-pale); color: var(--purple);  border-color: #CECBF6; }

/* ── MASTER OPS ── */
.dh-page .mrow { display: flex; gap: 8px; margin-bottom: 12px; }
.dh-page .mast {
    flex: 1;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 4px;
    padding: 14px 8px;
    border-radius: 8px;
    cursor: pointer;
    border: 1px solid;
    text-align: center;
    transition: opacity 0.12s;
}
.dh-page .mast:hover { opacity: 0.82; }
.dh-page .mi2 { background: var(--navy);  border-color: var(--blue); }
.dh-page .me2 { background: #081A08;      border-color: var(--green-mid); }
.dh-page .ms2 { background: #120E28;      border-color: #534AB7; }
.dh-page .mast-l { font-size: 11px; font-weight: 700; color: #fff; }
.dh-page .mast-s { font-size: 9px; color: rgba(255, 255, 255, 0.45); }

/* ── SOURCE LIST ── */
.dh-page .src-item {
    display: flex;
    align-items: center;
    gap: 9px;
    padding: 7px 12px;
    border-bottom: 0.5px solid var(--border);
    font-size: 11px;
}
.dh-page .src-item:last-child { border-bottom: none; }
.dh-page .sdot { width: 8px; height: 8px; border-radius: 50%; flex-shrink: 0; }

/* ── QUICK ACTIONS ── */
.dh-page .qa-item {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 9px 14px;
    border-bottom: 0.5px solid var(--border);
    cursor: pointer;
    transition: background 0.1s;
}
.dh-page .qa-item:last-child { border-bottom: none; }
.dh-page .qa-item:hover { background: var(--blue-pale); }
.dh-page .qa-icon {
    width: 26px;
    height: 26px;
    border-radius: 6px;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    font-size: 13px;
    font-weight: 700;
}
.dh-page .qa-title { font-size: 12px; font-weight: 600; }
.dh-page .qa-sub { font-size: 10px; color: var(--text2); margin-top: 1px; }

/* ── AUDIT LOG ── */
.dh-page .audit-item {
    display: flex;
    align-items: flex-start;
    gap: 9px;
    padding: 8px 14px;
    border-bottom: 0.5px solid var(--border);
}
.dh-page .audit-item:last-child { border-bottom: none; }
.dh-page .av {
    width: 28px;
    height: 28px;
    border-radius: 50%;
    background: var(--navy2);
    color: var(--silver);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 9px;
    font-weight: 800;
    flex-shrink: 0;
    margin-top: 1px;
    border: 1px solid rgba(21, 101, 190, 0.3);
}
.dh-page .audit-title { font-size: 11px; font-weight: 600; line-height: 1.4; }
.dh-page .audit-sub { font-size: 10px; color: var(--text2); margin-top: 1px; }
.dh-page .audit-right {
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    gap: 3px;
    flex-shrink: 0;
}
.dh-page .badge {
    font-size: 9px;
    padding: 2px 8px;
    border-radius: 20px;
    font-weight: 700;
}
.dh-page .b-blue   { background: var(--blue-pale);   color: #0A3266; }
.dh-page .b-green  { background: var(--green-pale);  color: var(--green); }
.dh-page .b-amber  { background: var(--amber-pale);  color: var(--amber); }
.dh-page .b-red    { background: var(--red-pale);    color: var(--red); }
.dh-page .b-navy   { background: var(--navy2);       color: var(--silver); }
.dh-page .b-purple { background: var(--purple-pale); color: var(--purple); }
.dh-page .rb-btn {
    font-size: 9px;
    padding: 2px 8px;
    border-radius: 4px;
    border: 0.5px solid #F09595;
    background: var(--white);
    color: var(--red);
    cursor: pointer;
    font-weight: 700;
}
.dh-page .rb-btn:hover { background: var(--red-pale); }
.dh-page .rb-btn.off { opacity: 0.28; cursor: not-allowed; }

/* ── FILTER CHIPS ── */
.dh-page .fc-row {
    display: flex;
    gap: 5px;
    padding: 10px 14px;
    border-bottom: 0.5px solid var(--border);
    flex-wrap: wrap;
}
.dh-page .fc {
    font-size: 10px;
    padding: 3px 10px;
    border-radius: 20px;
    border: 0.5px solid #ccd;
    cursor: pointer;
    color: var(--text2);
    background: var(--white);
    font-weight: 500;
    transition: all 0.1s;
}
.dh-page .fc:hover { border-color: var(--blue); color: var(--blue); }
.dh-page .fc.on {
    background: var(--navy2);
    border-color: var(--blue);
    color: #fff;
    font-weight: 700;
}

/* ── ACTION BUTTONS ── */
.dh-page .btn {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 8px 18px;
    border-radius: 7px;
    font-size: 12px;
    font-weight: 700;
    cursor: pointer;
    border: 1px solid;
    transition: opacity 0.12s;
    font-family: inherit;
}
.dh-page .btn:hover { opacity: 0.85; }
.dh-page .btn-primary { background: var(--blue);      color: #fff; border-color: var(--blue); }
.dh-page .btn-success { background: var(--green-mid); color: #fff; border-color: var(--green-mid); }
.dh-page .btn-danger  { background: var(--white);     color: var(--red-mid); border-color: #F09595; }
.dh-page .btn-outline { background: var(--white);     color: var(--text);    border-color: var(--border); }
.dh-page .btn-sm { padding: 5px 12px; font-size: 11px; }

/* ── MODAL ── */
.dh-page .modal-overlay {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.45);
    z-index: 999;
    display: flex;
    align-items: center;
    justify-content: center;
}
.dh-page .modal-box {
    background: var(--white);
    border-radius: 12px;
    padding: 1.5rem;
    width: 440px;
    box-shadow: 0 20px 60px rgba(0, 0, 0, 0.2);
}
.dh-page .modal-title { font-size: 16px; font-weight: 700; margin-bottom: 0.75rem; }
.dh-page .modal-body  { font-size: 13px; color: var(--text2); margin-bottom: 1.25rem; line-height: 1.6; }
.dh-page .modal-footer { display: flex; gap: 8px; justify-content: flex-end; }

/* ── EXPORT SPINNER OVERLAY ── */
.dh-page .export-overlay {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.3);
    z-index: 9999;
    display: flex;
    align-items: center;
    justify-content: center;
}
.dh-page .export-overlay > .box {
    background: var(--white);
    border-radius: 10px;
    padding: 1.5rem 2rem;
    text-align: center;
    box-shadow: 0 20px 60px rgba(0, 0, 0, 0.2);
}
.dh-page .spinner {
    width: 32px;
    height: 32px;
    border: 3px solid var(--blue-pale);
    border-top-color: var(--blue);
    border-radius: 50%;
    margin: 0 auto 8px;
    animation: dh-spin 0.8s linear infinite;
}
@keyframes dh-spin {
    to { transform: rotate(360deg); }
}

/* ── INPUTS ── */
.dh-page input[type=text],
.dh-page input[type=search],
.dh-page input[type=date],
.dh-page select {
    font-family: inherit;
    font-size: 12px;
    padding: 7px 10px;
    border: 0.5px solid var(--border);
    border-radius: 6px;
    background: var(--white);
    color: var(--text);
    outline: none;
}
.dh-page input:focus, .dh-page select:focus { border-color: var(--blue); }

/* ── TOAST ── */
.dh-page .toast {
    position: fixed;
    bottom: 24px;
    right: 24px;
    background: var(--navy2);
    color: #fff;
    padding: 12px 20px;
    border-radius: 8px;
    font-size: 12px;
    font-weight: 600;
    z-index: 9999;
    border-left: 3px solid var(--blue);
    animation: dh-slideUp 0.25s ease;
}
.dh-page .toast.toast-success { border-left-color: var(--green-mid); }
.dh-page .toast.toast-danger  { border-left-color: var(--red-mid); }
@keyframes dh-slideUp {
    from { opacity: 0; transform: translateY(10px); }
    to   { opacity: 1; transform: translateY(0); }
}

/* ─────────────────────────────────────────────────────────────────────────
   IMPORT WIZARD — stepper, step cards, mapping table, preview table,
   validation stats, company/direction/table pickers.
   ───────────────────────────────────────────────────────────────────────── */

.dh-page .stepper { display: flex; margin-bottom: 1.5rem; }
.dh-page .stp {
    flex: 1;
    display: flex;
    align-items: center;
    gap: 6px;
    padding: 8px 10px;
    font-size: 11px;
    font-weight: 500;
    border: 0.5px solid var(--border);
    background: var(--white);
    color: var(--text2);
    border-right: none;
    cursor: default;
}
.dh-page .stp:first-child { border-radius: 8px 0 0 8px; }
.dh-page .stp:last-child  { border-right: 0.5px solid var(--border); border-radius: 0 8px 8px 0; }
.dh-page .stp.done {
    background: var(--green-pale);
    color: var(--green-mid);
    border-color: #97C459;
    border-right: none;
}
.dh-page .stp.done + .stp { border-left: 0.5px solid #97C459; }
.dh-page .stp.curr {
    background: var(--blue-pale);
    color: #0A3266;
    border-color: var(--blue-mid);
    border-right: none;
}
.dh-page .stp.curr + .stp { border-left: 0.5px solid var(--blue-mid); }
.dh-page .sn {
    width: 18px;
    height: 18px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 9px;
    font-weight: 700;
    flex-shrink: 0;
    background: rgba(0, 0, 0, 0.08);
    color: var(--text2);
}
.dh-page .stp.curr .sn { background: var(--blue);      color: #fff; }
.dh-page .stp.done .sn { background: var(--green-mid); color: #fff; }

.dh-page .wiz-step { display: none; }
.dh-page .wiz-step.active { display: block; }

/* Step 1 — company result */
.dh-page .company-result {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 10px 14px;
    border: 1.5px solid var(--blue-mid);
    border-radius: 8px;
    background: var(--blue-pale);
    margin-top: 8px;
}
.dh-page .co-av {
    width: 36px;
    height: 36px;
    border-radius: 50%;
    background: var(--blue);
    color: #fff;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 11px;
    font-weight: 700;
    flex-shrink: 0;
}
.dh-page .co-name { font-size: 13px; font-weight: 700; color: #0A3266; }
.dh-page .co-meta { font-size: 10px; color: var(--blue2); margin-top: 1px; }

/* Step 2 — direction picker */
.dh-page .dir-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; }
.dh-page .dir-card {
    padding: 12px 14px;
    border: 0.5px solid var(--border);
    border-radius: 8px;
    cursor: pointer;
    transition: all 0.1s;
}
.dh-page .dir-card:hover, .dh-page .dir-card.sel {
    border-color: var(--blue);
    background: var(--blue-pale);
}
.dh-page .dir-card.sel { border-width: 1.5px; }
.dh-page .dir-title { font-size: 13px; font-weight: 700; }
.dh-page .dir-sub { font-size: 11px; color: var(--text2); margin-top: 2px; }
.dh-page .dir-card.sel .dir-title { color: #0A3266; }

/* Step 3 — table picker */
.dh-page .table-opt {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 8px 12px;
    border-bottom: 0.5px solid var(--border);
    cursor: pointer;
    font-size: 12px;
    transition: background 0.1s;
}
.dh-page .table-opt:last-child { border-bottom: none; }
.dh-page .table-opt:hover, .dh-page .table-opt.sel { background: var(--blue-pale); }
.dh-page .table-opt.sel { font-weight: 700; color: #0A3266; }

/* Step 4 — column mapping table */
.dh-page .map-tbl { width: 100%; border-collapse: collapse; font-size: 12px; }
.dh-page .map-tbl th {
    background: var(--bg);
    padding: 6px 10px;
    text-align: left;
    font-size: 10px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: var(--text2);
    border-bottom: 0.5px solid var(--border);
}
.dh-page .map-tbl td {
    padding: 6px 10px;
    border-bottom: 0.5px solid var(--border);
}
.dh-page .map-tbl tr:last-child td { border-bottom: none; }
.dh-page .auto-chip {
    font-size: 9px;
    padding: 1px 6px;
    border-radius: 8px;
    background: var(--green-pale);
    color: var(--green-mid);
    font-weight: 700;
    margin-left: 5px;
}
.dh-page .req-star { color: var(--red); font-size: 9px; }
.dh-page .sel-mock {
    font-size: 11px;
    padding: 3px 8px;
    border-radius: 5px;
    border: 0.5px solid var(--border);
    background: var(--white);
    color: var(--text);
}

/* Step 5 — preview table + validation stats */
.dh-page .prev-tbl {
    width: 100%;
    border-collapse: collapse;
    font-size: 11px;
    table-layout: fixed;
}
.dh-page .prev-tbl th {
    background: var(--bg);
    padding: 5px 8px;
    text-align: left;
    font-size: 10px;
    font-weight: 700;
    border-bottom: 0.5px solid var(--border);
    color: var(--text2);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.dh-page .prev-tbl td {
    padding: 5px 8px;
    border-bottom: 0.5px solid var(--border);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.dh-page .prev-tbl tr:last-child td { border-bottom: none; }
.dh-page .td-ok   { color: var(--green-mid); }
.dh-page .td-warn { background: var(--amber-pale); color: var(--amber); }
.dh-page .td-err  { background: var(--red-pale);   color: var(--red-mid); }

.dh-page .vstat-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 8px;
    margin-bottom: 12px;
}
.dh-page .vstat {
    background: var(--bg);
    border-radius: 8px;
    padding: 10px 12px;
    text-align: center;
}
.dh-page .vstat-n { font-size: 22px; font-weight: 700; font-family: 'DM Mono', monospace; }
.dh-page .vstat-l { font-size: 10px; color: var(--text2); margin-top: 2px; }
.dh-page .vn-ok   { color: var(--green-mid); }
.dh-page .vn-warn { color: var(--amber-mid); }
.dh-page .vn-err  { color: var(--red-mid); }

.dh-page .file-banner {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 7px 10px;
    background: var(--bg);
    border-radius: 6px;
    font-size: 12px;
    margin-bottom: 12px;
}

/* ─────────────────────────────────────────────────────────────────────────
   EXPORT FULL VIEW — table picker grid
   ───────────────────────────────────────────────────────────────────────── */

.dh-page .export-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 10px;
    margin-bottom: 1rem;
}
.dh-page .ex-card {
    border: 0.5px solid var(--border);
    border-radius: 8px;
    padding: 14px;
    cursor: pointer;
    transition: all 0.12s;
    background: var(--white);
}
.dh-page .ex-card:hover {
    border-color: var(--green-mid);
    background: var(--green-pale);
}
.dh-page .ex-card.sel {
    border-color: var(--green-mid);
    border-width: 1.5px;
    background: var(--green-pale);
}
.dh-page .ex-name { font-size: 12px; font-weight: 700; margin-bottom: 2px; }
.dh-page .ex-desc { font-size: 10px; color: var(--text2); }

.dh-page .field-label {
    font-size: 11px;
    font-weight: 600;
    color: var(--text2);
    margin-bottom: 5px;
    display: block;
}

/* ─────────────────────────────────────────────────────────────────────────
   AUDIT FULL VIEW — full-history row layout
   ───────────────────────────────────────────────────────────────────────── */

.dh-page .audit-full-row {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 10px 14px;
    border-bottom: 0.5px solid var(--border);
    font-size: 12px;
}
.dh-page .audit-full-row:last-child { border-bottom: none; }
.dh-page .audit-full-row:hover { background: var(--bg); }
.dh-page .audit-full-row.audit-head {
    background: var(--bg);
    font-size: 10px;
    font-weight: 700;
    color: var(--text2);
    text-transform: uppercase;
    letter-spacing: 0.05em;
}
.dh-page .audit-full-row.audit-head:hover { background: var(--bg); }

.dh-page .audit-col-batch    { width: 70px; font-family: 'DM Mono', monospace; font-size: 11px; color: var(--text2); }
.dh-page .audit-col-file     { flex: 1; min-width: 0; }
.dh-page .audit-col-by       { width: 110px; font-size: 11px; }
.dh-page .audit-col-when     { width: 90px;  font-size: 11px; color: var(--text2); }
.dh-page .audit-col-rows     { width: 60px;  text-align: right; font-size: 11px; font-weight: 600; }
.dh-page .audit-col-status   { width: 90px;  text-align: right; }
.dh-page .audit-col-action   { width: 90px;  text-align: right; }

/* ── RESPONSIVE ── */
@media (max-width: 900px) {
    .dh-page .stat-grid    { grid-template-columns: repeat(2, 1fr); }
    .dh-page .two-col      { grid-template-columns: 1fr; }
    .dh-page .export-grid  { grid-template-columns: repeat(2, 1fr); }
    .dh-page .vstat-grid   { grid-template-columns: repeat(2, 1fr); }
}
