/* GT Die Tracking — 3-tier dashboard styles */

:root {
    --brand-primary: #1e3a8a;
    --brand-accent:  #2563eb;
}

body {
    background: #f4f6fb;
    font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
}

.navbar {
    background: var(--header-bg, linear-gradient(135deg, var(--brand-primary), var(--brand-accent))) !important;
    box-shadow: 0 2px 6px rgba(0,0,0,.08);
}
.navbar .nav-link.active { font-weight: 600; }

.stats-card {
    border: 0;
    border-radius: 14px;
    box-shadow: 0 4px 14px rgba(0,0,0,.06);
    transition: transform .15s ease, box-shadow .15s ease;
}
.stats-card:hover { transform: translateY(-3px); box-shadow: 0 6px 18px rgba(0,0,0,.10); }
.stats-card h3 { font-size: 2rem; font-weight: 700; margin: 0; }
.stats-card p  { margin: .25rem 0 0; opacity: .9; font-size: .9rem; }

/* color overrides (driven by super-admin Settings) — these win over Bootstrap bg-* */
.stats-card.bg-primary[data-card="total"]      { background-color: var(--card-total)     !important; }
.stats-card.bg-success[data-card="rec"]        { background-color: var(--card-rec)       !important; }
.stats-card.bg-info[data-card="done"]          { background-color: var(--card-done)      !important; }
.stats-card.bg-warning[data-card="today"]      { background-color: var(--card-today)     !important; color:#fff; }
.stats-card.bg-primary[data-card="items"]      { background-color: var(--card-items)     !important; }
.stats-card.bg-success[data-card="completed"]  { background-color: var(--card-completed) !important; }
.stats-card.bg-info[data-card="avg"]           { background-color: var(--card-avg)       !important; }
.stats-card.bg-warning[data-card="ops"]        { background-color: var(--card-ops)       !important; color:#fff; }

/* settings page bits */
.brand-logo { width: 28px; height: 28px; object-fit: contain; }
.logo-box {
    width: 110px; height: 110px;
    border: 1px dashed #cfd6e4; border-radius: 10px;
    background: #f8fafc;
    display:flex; align-items:center; justify-content:center;
    overflow:hidden;
}
.logo-box img { max-width: 100%; max-height: 100%; object-fit: contain; }
.color-swatch {
    width: 40px; height: 32px;
    border-radius: 6px; border: 1px solid #cfd6e4;
    cursor: pointer;
    box-shadow: inset 0 0 0 2px #fff;
}
.color-hex { font-family: ui-monospace, SFMono-Regular, Menlo, monospace; }

.control-panel {
    background: #fff;
    border-radius: 12px;
    padding: 18px 20px;
    margin-bottom: 24px;
    box-shadow: 0 2px 8px rgba(0,0,0,.05);
}

.main-table-card .card-header {
    background: linear-gradient(135deg, #667eea 0%, #764ba2 100%);
    color: #fff;
    border-bottom: 0;
}

.device-status-card .card-header {
    background: linear-gradient(135deg, #11998e 0%, #38ef7d 100%);
    color: #fff;
    border-bottom: 0;
}

.role-banner {
    border-radius: 10px;
    padding: 12px 18px;
    margin-bottom: 18px;
    color: #fff;
    box-shadow: 0 2px 6px rgba(0,0,0,.08);
}
.banner-super { background: linear-gradient(135deg, #c0392b, #e74c3c); }
.banner-admin { background: linear-gradient(135deg, #d97706, #f59e0b); color:#fff; }
.banner-user  { background: linear-gradient(135deg, #0ea5e9, #06b6d4); }

/* login page */
.login-body {
    background: linear-gradient(135deg, #667eea, #764ba2);
    min-height: 100vh;
    display: flex; align-items: center;
}
.login-wrap { width: 100%; }
.login-card {
    max-width: 420px;
    margin: 0 auto;
    background: #fff;
    padding: 32px 28px;
    border-radius: 16px;
    box-shadow: 0 16px 40px rgba(0,0,0,.18);
}

footer {
    font-size: .85rem;
    background: var(--footer-bg, transparent);
    color: #fff !important;
}
footer.text-muted { color: #fff !important; }

/* ---------- avatars ---------- */
.navbar-avatar,
.navbar-avatar-fallback {
    width: 36px; height: 36px;
    border-radius: 50%;
    object-fit: cover;
    border: 2px solid rgba(255,255,255,.6);
    background: rgba(255,255,255,.15);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: #fff;
    font-weight: 700;
    font-size: 1rem;
    text-transform: uppercase;
}
.profile-avatar {
    width: 64px; height: 64px;
    border-radius: 50%;
    object-fit: cover;
    border: 3px solid #e5e7eb;
    background: #f3f4f6;
}
.profile-avatar.lg { width: 96px; height: 96px; font-size: 2.25rem; }
.profile-avatar.fallback {
    display: inline-flex; align-items: center; justify-content: center;
    color: #fff;
    background: linear-gradient(135deg, var(--brand-primary), var(--brand-accent));
    font-weight: 700;
}

/* user-dashboard hero block */
.user-hero {
    display: flex; align-items: center; gap: 18px;
    background: #fff;
    border-radius: 14px;
    padding: 18px 22px;
    margin-bottom: 18px;
    box-shadow: 0 4px 14px rgba(0,0,0,.06);
}
.user-hero .name { font-size: 1.35rem; font-weight: 600; }
.user-hero .role { font-size: .85rem; }

/* cropper modal */
.cropper-wrap { max-height: 60vh; }
.cropper-wrap img { max-width: 100%; display: block; }
