/* ═══════════════════════════════════════════════════════════
   infoweb-admin.css  &mdash;  Shared stylesheet for InfoWeb admin pages
   SQLJobViewer.aspx · Admin.aspx · AdminWAM.aspx
   ═══════════════════════════════════════════════════════════ */

@import url('https://fonts.googleapis.com/css2?family=IBM+Plex+Mono:wght@400;600&family=IBM+Plex+Sans:wght@300;400;500;600&display=swap');

/* ── Reset ── */
*, *:before, *:after { box-sizing: border-box; margin: 0; padding: 0; }

/* ── Design tokens ── */
:root {
    --bg:         #0d1117;
    --surface:    #161b22;
    --surface2:   #1c2330;
    --border:     #30363d;
    --accent:     #58a6ff;
    --accent2:    #3fb950;
    --warn:       #d29922;
    --danger:     #f78166;
    --text:       #e6edf3;
    --text-muted: #8b949e;
    --mono:       'IBM Plex Mono', monospace;
    --sans:       'IBM Plex Sans', sans-serif;
    --radius:     8px;
    --radius-sm:  5px;
}

/* ── Base ── */
html, body {
    background: var(--bg);
    color: var(--text);
    font-family: var(--sans);
    font-size: 13px;
    min-height: 100vh;
}

/* ─────────────────────────────────────────
   TOP BAR
───────────────────────────────────────── */
#topbar {
    background: var(--surface);
    border-bottom: 1px solid var(--border);
    padding: 0 24px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    height: 56px;
    position: sticky;
    top: 0;
    z-index: 100;
}

#topbar .brand {
    display: flex;
    align-items: center;
    gap: 10px;
}

#topbar .brand-title {
    font-family: var(--mono);
    font-size: 14px;
    font-weight: 600;
    letter-spacing: 0.04em;
    color: var(--text);
}

#topbar .brand-sub {
    font-size: 11px;
    color: var(--text-muted);
    font-family: var(--mono);
}

/* ── Topbar button group ── */
.topbar-actions {
    display: flex;
    align-items: center;
    gap: 6px;
    flex-wrap: wrap;
}

/* ─────────────────────────────────────────
   BUTTONS  (covers ASP.NET input[type=submit] and <a> links)
───────────────────────────────────────── */
.btn,
input[type="submit"],
input[type="button"] {
    background: var(--surface2);
    border: 1px solid var(--border);
    color: var(--text) !important;
    font-family: var(--mono) !important;
    font-size: 11px !important;
    font-weight: 600 !important;
    letter-spacing: 0.05em;
    text-transform: uppercase;
    padding: 6px 12px;
    border-radius: var(--radius-sm);
    cursor: pointer;
    transition: background 0.15s, border-color 0.15s, color 0.15s;
    text-decoration: none;
    white-space: nowrap;
    display: inline-block;
}

input[type="submit"]:hover,
input[type="button"]:hover,
.btn:hover {
    background: var(--accent);
    border-color: var(--accent);
    color: #0d1117 !important;
}

input[type="submit"]:disabled,
input[type="button"]:disabled {
    opacity: 0.35;
    cursor: not-allowed;
}

/* Primary / destructive variants */
.btn-primary { background: #1f6feb; border-color: #1f6feb; font-weight: 700 !important; }
.btn-primary:hover { background: #388bfd; border-color: #388bfd; color: #fff !important; }

/* ── HyperLinks ── */
a, a:visited {
    color: var(--accent);
    font-family: var(--mono);
    font-size: 11px;
    text-decoration: none;
    letter-spacing: 0.03em;
    transition: color 0.15s;
}
a:hover { color: #fff; text-decoration: underline; }

/* ─────────────────────────────────────────
   MAIN WRAPPER
───────────────────────────────────────── */
#main-wrap {
    padding: 20px 24px 40px;
    max-width: 1600px;
}

/* ─────────────────────────────────────────
   SECTION HEADERS  (replaces <h2>, <h4> inside the white table)
───────────────────────────────────────── */
.page-title {
    font-family: var(--sans);
    font-size: 18px;
    font-weight: 600;
    color: var(--text);
    margin-bottom: 4px;
}

.section-heading {
    display: flex;
    align-items: center;
    gap: 8px;
    font-family: var(--mono);
    font-size: 11px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--text-muted);
    margin: 16px 0 8px;
}

.section-heading::before {
    content: '';
    display: inline-block;
    width: 3px;
    height: 12px;
    background: var(--accent);
    border-radius: 2px;
    flex-shrink: 0;
}

.section-heading.green::before  { background: var(--accent2); }
.section-heading.yellow::before { background: var(--warn); }

/* ─────────────────────────────────────────
   LAYOUT GRID  (3-col for admin pages)
───────────────────────────────────────── */
.admin-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 16px;
    margin-bottom: 20px;
}

.admin-grid-2col {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 16px;
    margin-bottom: 20px;
}

/* ─────────────────────────────────────────
   CARDS
───────────────────────────────────────── */
.card {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    overflow: hidden;
    transition: border-color 0.2s;
}

.card:hover { border-color: #444c56; }

.card-header {
    background: var(--surface2);
    border-bottom: 1px solid var(--border);
    padding: 9px 14px;
    display: flex;
    align-items: center;
    gap: 8px;
}

.card-header .card-title {
    font-family: var(--mono);
    font-size: 11px;
    font-weight: 600;
    color: var(--accent);
    letter-spacing: 0.04em;
}

.card-body {
    padding: 12px 14px;
    overflow-y: auto;
    max-height: 260px;
    scrollbar-width: thin;
    scrollbar-color: var(--border) transparent;
}

.card-body::-webkit-scrollbar { width: 4px; }
.card-body::-webkit-scrollbar-thumb { background: var(--border); border-radius: 4px; }

/* Tall variant for build-progress panels */
.card-body-tall { max-height: 220px; }

/* ─────────────────────────────────────────
   DIVIDER
───────────────────────────────────────── */
.divider {
    border: none;
    border-top: 1px solid var(--border);
    margin: 18px 0;
}

/* ─────────────────────────────────────────
   PROCESSING INDICATOR  (UpdateProgress)
───────────────────────────────────────── */
.processing-bar {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    background: rgba(88,166,255,0.1);
    border: 1px solid rgba(88,166,255,0.3);
    border-radius: 20px;
    padding: 4px 12px;
    font-family: var(--mono);
    font-size: 11px;
    color: var(--accent);
    margin-bottom: 12px;
}

.processing-bar img { opacity: 0.8; }

/* ─────────────────────────────────────────
   CHECKBOXES
───────────────────────────────────────── */
.confirm-row {
    display: flex;
    gap: 16px;
    margin-top: 10px;
    padding: 8px 10px;
    background: rgba(210,153,34,0.07);
    border: 1px solid rgba(210,153,34,0.25);
    border-radius: var(--radius-sm);
}

.confirm-row label,
.confirm-row input[type="checkbox"] + label,
input[type="checkbox"] {
    font-family: var(--mono) !important;
    font-size: 11px !important;
    color: var(--warn) !important;
    cursor: pointer;
    accent-color: var(--warn);
}

/* ─────────────────────────────────────────
   STATUS / MESSAGE LABEL
───────────────────────────────────────── */
.status-label {
    display: block;
    margin-top: 8px;
    font-family: var(--mono);
    font-size: 12px;
    font-weight: 600;
    color: var(--accent2);
    min-height: 18px;
}

/* ─────────────────────────────────────────
   GRIDVIEWS  &mdash; universal override
   ASP.NET renders as <table>, so we target
   the table element itself + child elements.
───────────────────────────────────────── */

/* Container wrapper for overflow scrolling */
.gv-wrap {
    width: 100%;
    overflow-x: auto;
    border-radius: var(--radius-sm);
}

/* Caption (GridView Caption property) */
caption {
    font-family: var(--mono);
    font-size: 10px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.07em;
    color: var(--text-muted);
    text-align: left;
    padding: 0 0 6px 2px;
    caption-side: top;
}

/* The rendered <table> */
table.gv,
.gv-wrap > table,
div[id$="Panel"] table,
#main-wrap table[id^="gv"],
#main-wrap table[id^="Grid"] {
    width: 100%;
    border-collapse: collapse;
    font-family: var(--mono);
    font-size: 11px;
    background: var(--surface);
    border: 1px solid var(--border) !important;
    border-radius: var(--radius-sm);
    overflow: hidden;
}

/* Header row */
#main-wrap table[id^="gv"] th,
#main-wrap table[id^="Grid"] th,
.gv-wrap > table th {
    background: #1f6feb !important;
    color: #fff !important;
    padding: 6px 10px !important;
    font-weight: 600;
    white-space: nowrap;
    text-align: left;
    font-size: 10px;
    letter-spacing: 0.04em;
    border: none !important;
}

/* Data rows */
#main-wrap table[id^="gv"] td,
#main-wrap table[id^="Grid"] td,
.gv-wrap > table td {
    padding: 5px 10px !important;
    border-bottom: 1px solid var(--border) !important;
    border-right: none !important;
    color: var(--text);
    background: var(--surface);
    white-space: nowrap;
}

/* Alternating rows */
#main-wrap table[id^="gv"] tr.gridAlt td,
#main-wrap table[id^="Grid"] tr:nth-child(even) td,
.gv-wrap > table tr:nth-child(even) td {
    background: var(--surface2) !important;
}

/* Hover */
#main-wrap table[id^="gv"] tr:hover td,
#main-wrap table[id^="Grid"] tr:hover td {
    background: #1c2a3a !important;
}

/* Pager row */
#main-wrap table[id^="gv"] td[colspan],
#main-wrap table[id^="Grid"] td[colspan] {
    background: var(--surface2) !important;
    color: var(--text-muted);
    text-align: center;
}

/* Pager links */
#main-wrap table[id^="gv"] td[colspan] a,
#main-wrap table[id^="Grid"] td[colspan] a,
#main-wrap table[id^="gv"] td[colspan] span {
    font-family: var(--mono);
    font-size: 11px;
    color: var(--accent);
    padding: 2px 6px;
    text-decoration: none;
}

#main-wrap table[id^="gv"] td[colspan] span {
    color: #fff;
    font-weight: 700;
}

/* Empty data row */
#main-wrap table[id^="gv"] td.empty,
.gv-wrap > table td.empty {
    color: var(--text-muted);
    font-style: italic;
    padding: 12px 10px !important;
}

/* ─────────────────────────────────────────
   WEEKS BUILT  small grid  (left column)
───────────────────────────────────────── */
.weeks-built-wrap {
    font-family: var(--mono);
    font-size: 11px;
}

/* ─────────────────────────────────────────
   STATUS STRIP  (live indicator)
───────────────────────────────────────── */
#status-strip {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-bottom: 16px;
    font-family: var(--mono);
    font-size: 11px;
    color: var(--text-muted);
}

#status-strip .dot {
    width: 7px;
    height: 7px;
    border-radius: 50%;
    background: var(--accent2);
    box-shadow: 0 0 6px var(--accent2);
    display: inline-block;
    animation: pulse 2s ease-in-out infinite;
}

@keyframes pulse {
    0%, 100% { opacity: 1; }
    50%       { opacity: 0.35; }
}

/* ─────────────────────────────────────────
   FORM WRAPPER  (reset ASP.NET form styles)
───────────────────────────────────────── */
form#form1 {
    background: transparent !important;
    border: none !important;
    margin: 0 !important;
    padding: 0 !important;
}

/* ─────────────────────────────────────────
   SERVER CARD GRID  (SQLJobViewer only)
───────────────────────────────────────── */
#server-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 16px;
    margin-bottom: 32px;
}

.server-card {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    overflow: hidden;
    transition: border-color 0.2s;
}

.server-card:hover { border-color: var(--accent); }

.server-card .card-header .server-icon {
    width: 28px;
    height: 28px;
    border-radius: 6px;
    background: linear-gradient(135deg, #1f6feb 0%, #388bfd 100%);
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}

.server-card .card-header .server-icon svg {
    width: 14px; height: 14px; fill: #fff;
}

.server-card .card-header .server-name {
    font-family: var(--mono);
    font-size: 11px;
    font-weight: 600;
    color: var(--accent);
    letter-spacing: 0.03em;
    line-height: 1.2;
}

.server-card .card-header .server-role {
    font-size: 10px;
    color: var(--text-muted);
    font-family: var(--mono);
}

.server-card .card-body {
    padding: 12px 14px;
    max-height: 340px;
}

.server-card .card-body span { font-family: var(--sans) !important; font-size: 12px !important; line-height: 1.7; display: block; }

.no-jobs {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    font-family: var(--mono);
    font-size: 11px;
    color: var(--accent2);
    background: rgba(63,185,80,0.08);
    border: 1px solid rgba(63,185,80,0.25);
    border-radius: 20px;
    padding: 3px 10px;
}

.section-divider {
    border: none;
    border-top: 1px solid var(--border);
    margin: 10px 0;
}

.sched-label {
    font-family: var(--mono);
    font-size: 10px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--text-muted);
    margin-bottom: 6px;
    display: flex;
    align-items: center;
    gap: 6px;
}

.sched-label::before {
    content: '';
    width: 3px; height: 10px;
    background: var(--accent2);
    border-radius: 2px;
    display: inline-block;
}
    
/* ─────────────────────────────────────────
   MASTER PAGE SHELL
───────────────────────────────────────── */
#master-shell {
    min-height: 100vh;
    display: flex;
    flex-direction: column;
}

#master-header {
    background: var(--surface);
    border-bottom: 1px solid var(--border);
    padding: 0 24px;
    height: 56px;
    display: flex;
    align-items: center;
    position: sticky;
    top: 0;
    z-index: 100;
}

.master-brand {
    display: flex;
    align-items: center;
    gap: 10px;
}

.master-brand-title {
    font-family: var(--mono);
    font-size: 15px;
    font-weight: 600;
    letter-spacing: 0.04em;
    color: var(--text);
}

.master-brand-sub {
    font-size: 11px;
    color: var(--text-muted);
    font-family: var(--mono);
}

#master-footer {
    margin-top: auto;
    border-top: 1px solid var(--border);
    padding: 12px 24px;
    font-family: var(--mono);
    font-size: 10px;
    color: var(--text-muted);
    letter-spacing: 0.03em;
}

#master-footer a,
#master-footer a:visited {
    color: var(--text-muted);
    font-size: 10px;
}

#master-footer a:hover { color: var(--accent); }

/* ─────────────────────────────────────────
   DEFAULT.ASPX -- Login page
───────────────────────────────────────── */
#login-wrap {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 48px 24px;
    gap: 32px;
}

/* Login card */
.login-card {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    width: 100%;
    max-width: 360px;
    overflow: hidden;
}

.login-card-header {
    background: var(--surface2);
    border-bottom: 1px solid var(--border);
    padding: 14px 20px;
    font-family: var(--mono);
    font-size: 12px;
    font-weight: 600;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: var(--accent);
    display: flex;
    align-items: center;
    gap: 8px;
}

.login-card-body {
    padding: 20px;
    display: flex;
    flex-direction: column;
    gap: 14px;
}

.login-field {
    display: flex;
    flex-direction: column;
    gap: 5px;
}

.login-field label {
    font-family: var(--mono);
    font-size: 10px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.07em;
    color: var(--text-muted);
}

.login-field input[type="text"],
.login-field input[type="password"],
/* ASP.NET Login control textboxes */
#login-wrap input[type="text"],
#login-wrap input[type="password"] {
    background: var(--surface2) !important;
    border: 1px solid var(--border) !important;
    border-radius: var(--radius-sm) !important;
    color: var(--text) !important;
    font-family: var(--mono) !important;
    font-size: 13px !important;
    padding: 8px 10px !important;
    width: 100% !important;
    outline: none !important;
    transition: border-color 0.15s !important;
}

#login-wrap input[type="text"]:focus,
#login-wrap input[type="password"]:focus {
    border-color: var(--accent) !important;
}

/* Login button override */
#login-wrap input[type="submit"] {
    width: 100%;
    background: #1f6feb !important;
    border-color: #1f6feb !important;
    color: #fff !important;
    font-size: 12px !important;
    padding: 9px 0 !important;
    border-radius: var(--radius-sm) !important;
    margin-top: 4px;
}

#login-wrap input[type="submit"]:hover {
    background: #388bfd !important;
    border-color: #388bfd !important;
}

/* Remember me checkbox */
#login-wrap input[type="checkbox"] {
    accent-color: var(--accent);
    margin-right: 6px;
}

#login-wrap table {
    background: transparent !important;
    border: none !important;
    width: 100% !important;
}

#login-wrap table td {
    background: transparent !important;
    border: none !important;
    padding: 4px 0 !important;
    color: var(--text) !important;
    font-family: var(--mono) !important;
    font-size: 12px !important;
}

/* Login title bar (TitleTextStyle maps to a td) */
#login-wrap td[style*="background-color:#5D7B9D"],
#login-wrap td[style*="background-color: #5D7B9D"] {
    background: var(--surface2) !important;
    border-bottom: 1px solid var(--border) !important;
    color: var(--accent) !important;
    font-family: var(--mono) !important;
    font-size: 11px !important;
    font-weight: 600 !important;
    letter-spacing: 0.06em !important;
    text-transform: uppercase;
    padding: 10px !important;
    border-radius: var(--radius-sm) var(--radius-sm) 0 0 !important;
}

/* Failure text */
#login-wrap span[id$="FailureText"] {
    color: var(--danger) !important;
    font-family: var(--mono) !important;
    font-size: 11px !important;
}

/* User status bar (logged-in row) */
.user-status-bar {
    display: flex;
    align-items: center;
    gap: 12px;
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: 10px 16px;
    font-family: var(--mono);
    font-size: 11px;
    color: var(--text-muted);
    flex-wrap: wrap;
}

.user-status-bar .username {
    color: var(--accent2);
    font-weight: 600;
    font-size: 12px;
}

.user-status-bar .sep {
    color: var(--border);
}

/* Nav links (TopNavRepeat) */
.top-nav {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    list-style: none;
    padding: 0;
    margin: 0;
}

.top-nav li { list-style: none; }

.top-nav a,
.top-nav a:visited {
    display: inline-block;
    padding: 5px 12px;
    background: var(--surface2);
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    font-family: var(--mono);
    font-size: 11px;
    font-weight: 600;
    color: var(--text) !important;
    letter-spacing: 0.04em;
    text-decoration: none;
    transition: background 0.15s, border-color 0.15s, color 0.15s;
}

.top-nav a:hover {
    background: var(--accent);
    border-color: var(--accent);
    color: #0d1117 !important;
    text-decoration: none;
}

/* Forgot / change password links */
.login-aux-links {
    display: flex;
    gap: 12px;
    justify-content: center;
    font-family: var(--mono);
    font-size: 11px;
}
