/* Wocom Traffic Analytics — minimal, self-hosted styles (strict CSP compatible). */
*, *::before, *::after { box-sizing: border-box; }
html { font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif; }
body { margin: 0; background: #0f172a; color: #e2e8f0; min-height: 100vh; }
a { color: #60a5fa; text-decoration: none; }
a:hover { text-decoration: underline; }
.container { max-width: 1100px; margin: 0 auto; padding: 2rem 1.25rem; }

header.topbar {
    background: #1e293b;
    border-bottom: 1px solid #334155;
    padding: 0.9rem 1.5rem;
    display: flex; justify-content: space-between; align-items: center;
}
header.topbar .brand { font-weight: 600; color: #f8fafc; letter-spacing: 0.02em; }
header.topbar nav a { margin-left: 1rem; color: #cbd5e1; }
header.topbar form { display: inline; }
header.topbar button {
    background: transparent; border: 1px solid #475569; color: #cbd5e1;
    padding: 0.4rem 0.8rem; border-radius: 4px; cursor: pointer;
    font: inherit;
}
header.topbar button:hover { background: #334155; }

h1 { color: #f8fafc; margin-top: 0; font-size: 1.5rem; }
h2 { color: #e2e8f0; font-size: 1.1rem; margin-bottom: 0.5rem; }

.grid { display: grid; gap: 1rem; }
.grid-3 { grid-template-columns: repeat(3, 1fr); }
@media (max-width: 800px) { .grid-3 { grid-template-columns: 1fr; } }

.card {
    background: #1e293b; border: 1px solid #334155; border-radius: 8px;
    padding: 1rem 1.25rem;
}
.card .metric { font-size: 2rem; font-weight: 600; color: #f8fafc; margin: 0.25rem 0; }
.card .label { font-size: 0.8rem; color: #94a3b8; text-transform: uppercase; letter-spacing: 0.05em; }

table { width: 100%; border-collapse: collapse; margin-top: 0.5rem; }
th, td {
    text-align: left; padding: 0.6rem 0.75rem; border-bottom: 1px solid #334155;
    font-size: 0.9rem;
}
th { color: #94a3b8; font-weight: 500; text-transform: uppercase; letter-spacing: 0.05em; font-size: 0.72rem; }
tr:last-child td { border-bottom: none; }
.badge {
    display: inline-block; padding: 0.15rem 0.5rem; border-radius: 10px;
    font-size: 0.72rem; background: #334155; color: #cbd5e1;
}
.badge.entry { background: #065f46; color: #d1fae5; }
.badge.exit  { background: #7c2d12; color: #fed7aa; }
.masked { font-family: ui-monospace, SFMono-Regular, Menlo, monospace; color: #e2e8f0; }

/* Auth */
.auth-wrap { min-height: 100vh; display: flex; align-items: center; justify-content: center; padding: 2rem; }
.auth-card {
    background: #1e293b; border: 1px solid #334155; border-radius: 10px;
    padding: 2rem; width: 100%; max-width: 380px;
}
.auth-card h1 { margin-top: 0; text-align: center; color: #f8fafc; }
.auth-card label { display: block; margin: 0.75rem 0 0.25rem; font-size: 0.85rem; color: #cbd5e1; }
.auth-card input[type=email], .auth-card input[type=password], .auth-card input[type=text] {
    width: 100%; background: #0f172a; border: 1px solid #475569; border-radius: 6px;
    padding: 0.55rem 0.7rem; color: #f8fafc; font: inherit;
}
.auth-card input:focus { outline: none; border-color: #60a5fa; }
.auth-card button[type=submit] {
    width: 100%; margin-top: 1.25rem; padding: 0.7rem 1rem;
    background: #2563eb; color: #f8fafc; border: none; border-radius: 6px;
    font: inherit; font-weight: 600; cursor: pointer;
}
.auth-card button[type=submit]:hover { background: #1d4ed8; }
.auth-card .errors { background: #7f1d1d; color: #fecaca; padding: 0.6rem 0.8rem; border-radius: 6px; margin-top: 1rem; font-size: 0.85rem; }
.auth-card .errors ul { margin: 0; padding-left: 1.1rem; }
