* {
	box-sizing: border-box;
}

html, body {
	margin: 0;
	padding: 0;
	font-family: Arial, sans-serif;
	background: #f5f6f8;
	color: #111;
}

a {
	color: #0b57d0;
	text-decoration: none;
}

a:hover {
	text-decoration: underline;
}

.container {
	max-width: 1760px;
	margin: 0 auto;
	padding: 20px 24px;
}

.topbar {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 18px;
	margin-bottom: 20px;
}

.brand {
	font-size: 22px;
	font-weight: 700;
}

.nav {
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
	margin-bottom: 20px;
}

.nav a {
	padding: 10px 14px;
	border: 1px solid #d8dbe2;
	border-radius: 10px;
	background: #fff;
	color: #111;
}

.nav a.active {
	background: #111;
	color: #fff;
	border-color: #111;
}

.page-title {
	margin: 0 0 16px;
	font-size: 28px;
}

.page-subtitle {
	margin: 0 0 20px;
	color: #666;
}

.grid {
	display: grid;
	grid-template-columns: repeat(12, 1fr);
	gap: 16px;
}

.col-12 { grid-column: span 12; }
.col-8 { grid-column: span 8; }
.col-6 { grid-column: span 6; }
.col-4 { grid-column: span 4; }
.col-3 { grid-column: span 3; }

.card {
	background: #fff;
	border: 1px solid #ddd;
	border-radius: 14px;
	padding: 18px 20px;
}

.card h2, .card h3 {
	margin-top: 0;
}

.actions {
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
	margin-top: 12px;
}

button,
.button {
	padding: 10px 14px;
	border: 1px solid #cfd4dc;
	border-radius: 10px;
	background: #fff;
	cursor: pointer;
	font-size: 14px;
}

button:hover,
.button:hover {
	background: #f3f4f6;
	text-decoration: none;
}

button.primary {
	background: #111;
	color: #fff;
	border-color: #111;
}

.muted {
	color: #666;
	font-size: 14px;
}

.kpi {
	display: flex;
	flex-direction: column;
	gap: 8px;
}

.kpi-value {
	font-size: 32px;
	font-weight: 700;
}

.kpi-label {
	color: #666;
	font-size: 14px;
}

.table-wrap {
	overflow: auto;
	border: 1px solid #ddd;
	border-radius: 12px;
	background: #fff;
}

table {
	width: 100%;
	border-collapse: collapse;
	background: #fff;
}

th, td {
	padding: 10px 12px;
	border-bottom: 1px solid #eee;
	text-align: left;
	font-size: 14px;
	white-space: nowrap;
}

th {
	background: #f3f4f6;
	position: sticky;
	top: 0;
	z-index: 1;
}

.badge {
	display: inline-block;
	padding: 4px 8px;
	border-radius: 999px;
	font-size: 12px;
	border: 1px solid #d8dbe2;
	background: #fafafa;
}

.badge.ok {
	background: #edf8ed;
	border-color: #b7ddb7;
	color: #1f6b2c;
}

.badge.warn {
	background: #fff6df;
	border-color: #ead18a;
	color: #7d5a00;
}

.badge.off {
	background: #f7f0f0;
	border-color: #e1c7c7;
	color: #8a3b3b;
}

.form-grid {
	display: grid;
	grid-template-columns: repeat(12, 1fr);
	gap: 12px;
}

.field {
	grid-column: span 12;
}

.field.half {
	grid-column: span 6;
}

label {
	display: block;
	margin-bottom: 6px;
	font-size: 14px;
	font-weight: 600;
}

input[type="text"],
input[type="number"],
textarea,
select {
	width: 100%;
	padding: 10px 12px;
	border: 1px solid #ccd2da;
	border-radius: 10px;
	background: #fff;
	font-size: 14px;
}

textarea {
	resize: vertical;
	min-height: 110px;
}

.notice {
	padding: 12px 14px;
	border-radius: 10px;
	border: 1px solid #cfe3cf;
	background: #edf8ed;
	color: #1f6b2c;
	margin-bottom: 16px;
	display: none;
}

.notice.show {
	display: block;
}

.empty {
	padding: 20px;
	color: #666;
	text-align: center;
}

@media (max-width: 960px) {
	.col-8, .col-6, .col-4, .col-3 {
		grid-column: span 12;
	}

	.form-grid .field.half {
		grid-column: span 12;
	}
}

input[type="password"] {
	width: 100%;
	padding: 10px 12px;
	border: 1px solid #ccd2da;
	border-radius: 10px;
	background: #fff;
	font-size: 14px;
}

.notice.notice-error {
	border: 1px solid #e5b9b9;
	background: #fff1f1;
	color: #8d2f2f;
	display: block;
}

.auth-body {
	min-height: 100vh;
	background: linear-gradient(180deg, #f5f6f8 0%, #eceff4 100%);
}

.auth-shell {
	min-height: 100vh;
	max-width: 1120px;
	margin: 0 auto;
	padding: 20px 24px;
	display: grid;
	grid-template-columns: minmax(320px, 1.1fr) minmax(320px, 0.9fr);
	gap: 24px;
	align-items: center;
}

.auth-hero,
.auth-card {
	padding: 28px;
	border-radius: 18px;
	border: 1px solid #d8dbe2;
	box-shadow: 0 8px 30px rgba(17, 17, 17, 0.04);
}

.auth-title {
	margin-top: 18px;
	margin-bottom: 10px;
}

.auth-subtitle {
	margin-bottom: 18px;
}

.auth-points {
	display: grid;
	gap: 10px;
	line-height: 1.5;
}

.auth-form {
	gap: 14px;
}

.auth-actions {
	margin-top: 2px;
}

@media (max-width: 960px) {
	.auth-shell {
		grid-template-columns: 1fr;
		align-items: stretch;
	}
}


.table-wrap.wide {
	max-width: 100%;
}

@media (min-width: 1600px) {
	.container {
		max-width: 1880px;
	}
}

@media (max-width: 1200px) {
	.container {
		padding: 16px;
	}
}


/* global primary button shimmer (same as suppliers) */
.primary {
    transition: background .18s ease, box-shadow .18s ease, transform .18s ease;
}

.primary:hover {
    background: linear-gradient(90deg, #000 0%, #3a3a3a 22%, #f5f5f5 50%, #3a3a3a 78%, #000 100%);
    box-shadow: inset 0 0 0 1px rgba(255,255,255,.24), 0 0 12px rgba(255,255,255,.12);
}

/* user badge dot sparkle */

.user-badge::before {
    animation: userBadgeDotBlink 2.6s ease-in-out infinite !important;
}

@keyframes userBadgeDotBlink {

    0% {
        background:#111827;
        box-shadow:0 0 0 3px rgba(17,24,39,.08);
    }

    82% {
        background:#111827;
        box-shadow:0 0 0 3px rgba(17,24,39,.08);
    }

    88% {
        background:#ffffff;
        box-shadow:
            0 0 6px rgba(255,255,255,.95),
            0 0 14px rgba(255,255,255,.65),
            0 0 22px rgba(255,255,255,.35);
    }

    92% {
        background:#e5e7eb;
        box-shadow:
            0 0 6px rgba(255,255,255,.7),
            0 0 12px rgba(255,255,255,.45);
    }

    100% {
        background:#111827;
        box-shadow:0 0 0 3px rgba(17,24,39,.08);
    }

}