/* Job-Bot.ai theme — neutral palette with light / dark / system support.
   All selectors are scoped to `.jb-body` so this file cannot leak into the
   Frappe desk shell at /app even if it is ever loaded there by mistake. */

:root {
	--jb-radius: 10px;
	--jb-radius-sm: 6px;
	--jb-radius-pill: 999px;

	--jb-font-body: "Inter", system-ui, -apple-system, "Segoe UI", sans-serif;

	/* Brand gradient — matches job-bot.ai: --color-primary (#3b82f6) on the
	   bottom-left, --color-accent (#93c5fd) on the top-right.  Darker blue
	   to lighter blue. NOTE: the real site uses purple (#7c3aed) for the
	   accent in [data-theme=light]; we don't replicate that here because the
	   user prefers a single consistent blue-to-blue gradient across modes. */
	--jb-brand-grad: linear-gradient(to top right, #3b82f6 0%, #93c5fd 100%);
}

/* ── Light theme ─────────────────────────────────── */
[data-theme="light"] {
	--jb-bg:           #f4f5f7;
	--jb-bg-alt:       #eceef2;
	--jb-surface:      #ffffff;
	--jb-surface-alt:  #f8f9fb;
	--jb-border:       #e5e7eb;
	--jb-border-strong:#c8cad0;

	--jb-text:         #1a1a1a;
	--jb-text-soft:    #374151;
	--jb-text-muted:   #6b7280;
	--jb-text-faint:   #9ca3af;

	--jb-accent:       #2563eb;
	--jb-accent-soft:  #dbe8ff;
	--jb-accent-strong:#1d4ed8;

	--jb-status-open-bg:     #fef3c7; --jb-status-open-fg:     #854d0e;
	--jb-status-replied-bg:  #dbeafe; --jb-status-replied-fg:  #1e40af;
	--jb-status-resolved-bg: #dcfce7; --jb-status-resolved-fg: #166534;
	--jb-status-closed-bg:   #e5e7eb; --jb-status-closed-fg:   #4b5563;

	--jb-priority-high-bg:   #fee2e2; --jb-priority-high-fg:   #991b1b;
	--jb-priority-medium-bg: #fef3c7; --jb-priority-medium-fg: #92400e;
	--jb-priority-low-bg:    #e5e7eb; --jb-priority-low-fg:    #6b7280;

	--jb-shadow-sm: 0 1px 2px rgba(17, 24, 39, 0.05);
	--jb-focus-ring: 0 0 0 3px rgba(37, 99, 235, 0.3);
}

/* ── Dark theme ──────────────────────────────────── */
[data-theme="dark"] {
	--jb-bg:           #1c1f26;
	--jb-bg-alt:       #22262f;
	--jb-surface:      #2a2e38;
	--jb-surface-alt:  #242832;
	--jb-border:       #353a45;
	--jb-border-strong:#4a5060;

	--jb-text:         #f4f5f7;
	--jb-text-soft:    #c8cad0;
	--jb-text-muted:   #a8adb5;
	--jb-text-faint:   #6b7280;

	--jb-accent:       #3b82f6;
	--jb-accent-soft:  rgba(59, 130, 246, 0.18);
	--jb-accent-strong:#60a5fa;

	--jb-status-open-bg:     rgba(251, 191, 36, 0.18); --jb-status-open-fg:     #fcd34d;
	--jb-status-replied-bg:  rgba(59, 130, 246, 0.20); --jb-status-replied-fg:  #93c5fd;
	--jb-status-resolved-bg: rgba(34, 197, 94, 0.18);  --jb-status-resolved-fg: #86efac;
	--jb-status-closed-bg:   rgba(148, 163, 184, 0.16);--jb-status-closed-fg:   #cbd5e1;

	--jb-priority-high-bg:   rgba(248, 113, 113, 0.18);--jb-priority-high-fg:   #fca5a5;
	--jb-priority-medium-bg: rgba(251, 191, 36, 0.18); --jb-priority-medium-fg: #fcd34d;
	--jb-priority-low-bg:    rgba(148, 163, 184, 0.14);--jb-priority-low-fg:    #94a3b8;

	--jb-shadow-sm: 0 1px 2px rgba(0, 0, 0, 0.4);
	--jb-focus-ring: 0 0 0 3px rgba(96, 165, 250, 0.4);
}

/* All resets/typography are scoped to .jb-body so they can't escape. */

.jb-body {
	margin: 0;
	padding: 0;
	background: var(--jb-bg);
	color: var(--jb-text);
	font-family: var(--jb-font-body);
	font-size: 15px;
	line-height: 1.55;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
	color-scheme: light dark;
}
.jb-body * { box-sizing: border-box; }
.jb-body a { color: var(--jb-accent); text-decoration: none; }
.jb-body a:hover { color: var(--jb-accent-strong); text-decoration: underline; }
.jb-body :focus-visible { outline: none; box-shadow: var(--jb-focus-ring); border-radius: 4px; }

.jb-container {
	width: 100%;
	max-width: 1120px;
	margin: 0 auto;
	padding: 0 24px;
}

/* ── Header ─────────────────────────────────────── */
.jb-header {
	background: var(--jb-bg);
	border-bottom: 1px solid var(--jb-border);
}
.jb-header__inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	height: 72px;
	gap: 16px;
}

/* Brand: logo tile + wordmark with gradient .ai
   Selectors are scoped to .jb-body to beat the broader `.jb-body a { color }`
   rule above (which would otherwise paint "Job-Bot" the accent blue). */
.jb-body .jb-brand {
	display: inline-flex;
	align-items: center;
	gap: 10px;
	color: var(--jb-text);
	text-decoration: none;
	font-family: var(--jb-font-body);
	font-weight: 700;
	font-size: 20px;
	letter-spacing: -0.01em;
	line-height: 1;
}
.jb-body .jb-brand:hover,
.jb-body .jb-brand:focus,
.jb-body .jb-brand:visited {
	color: var(--jb-text);
	text-decoration: none;
}
.jb-body .jb-brand .jb-brand__text { color: var(--jb-text); }
.jb-brand__mark {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 32px;
	height: 32px;
	border-radius: 8px;
	background: var(--jb-brand-grad);
	color: #ffffff;
	flex-shrink: 0;
}
.jb-brand__text { display: inline-flex; align-items: baseline; }
.jb-brand__suffix {
	background: var(--jb-brand-grad);
	-webkit-background-clip: text;
	background-clip: text;
	-webkit-text-fill-color: transparent;
	color: transparent;
	font-weight: 700;
	font-style: normal;
	margin-left: 1px;
}
.jb-brand--sm { font-size: 16px; }
.jb-brand--sm .jb-brand__mark { width: 26px; height: 26px; border-radius: 6px; }

/* Theme dropdown — button + popover with three options */
.jb-theme-menu {
	position: relative;
	display: inline-block;
}
.jb-theme-toggle {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 36px;
	height: 36px;
	padding: 0;
	background: transparent;
	border: 1px solid var(--jb-border);
	border-radius: var(--jb-radius-pill);
	color: var(--jb-text-soft);
	cursor: pointer;
	transition: background 120ms ease, color 120ms ease, border-color 120ms ease;
}
.jb-theme-toggle:hover,
.jb-theme-toggle[aria-expanded="true"] {
	background: var(--jb-surface);
	color: var(--jb-text);
	border-color: var(--jb-border-strong);
}
.jb-theme-toggle .jb-icon { display: none; }
[data-theme-pref="light"]  .jb-theme-toggle .jb-icon--sun    { display: block; }
[data-theme-pref="dark"]   .jb-theme-toggle .jb-icon--moon   { display: block; }
[data-theme-pref="system"] .jb-theme-toggle .jb-icon--system { display: block; }

.jb-theme-popover {
	position: absolute;
	top: calc(100% + 8px);
	right: 0;
	min-width: 168px;
	padding: 6px;
	background: var(--jb-surface);
	border: 1px solid var(--jb-border);
	border-radius: var(--jb-radius);
	box-shadow:
		0 10px 25px -5px rgba(0, 0, 0, 0.1),
		0 8px 10px -6px rgba(0, 0, 0, 0.08);
	z-index: 1000;
	display: flex;
	flex-direction: column;
	gap: 2px;
	transform-origin: top right;
	animation: jb-pop-in 100ms ease-out;
}
[data-theme="dark"] .jb-theme-popover {
	box-shadow:
		0 10px 25px -5px rgba(0, 0, 0, 0.5),
		0 8px 10px -6px rgba(0, 0, 0, 0.4);
}
.jb-theme-popover[hidden] { display: none; }
@keyframes jb-pop-in {
	from { opacity: 0; transform: scale(0.96) translateY(-4px); }
	to   { opacity: 1; transform: scale(1)    translateY(0); }
}

.jb-theme-option {
	display: flex;
	align-items: center;
	gap: 10px;
	width: 100%;
	padding: 8px 10px;
	background: transparent;
	border: none;
	border-radius: var(--jb-radius-sm);
	color: var(--jb-text-soft);
	font-family: inherit;
	font-size: 14px;
	font-weight: 500;
	text-align: left;
	cursor: pointer;
	transition: background 80ms ease, color 80ms ease;
}
.jb-theme-option > span { flex: 1; }
.jb-theme-option svg { flex-shrink: 0; }
.jb-theme-option:hover {
	background: var(--jb-surface-alt);
	color: var(--jb-text);
}
.jb-theme-option[aria-checked="true"] {
	color: var(--jb-text);
	background: var(--jb-surface-alt);
}
.jb-theme-option .jb-theme-option__check {
	visibility: hidden;
	color: var(--jb-accent);
}
.jb-theme-option[aria-checked="true"] .jb-theme-option__check {
	visibility: visible;
}

/* ── Main ───────────────────────────────────────── */
.jb-main {
	min-height: calc(100vh - 72px - 96px);
	padding: 56px 0 80px;
}

/* ── Footer ─────────────────────────────────────── */
.jb-footer {
	background: var(--jb-bg-alt);
	border-top: 1px solid var(--jb-border);
}
.jb-footer__inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	height: 96px;
	gap: 24px;
}
.jb-footer__copy {
	margin: 0;
	color: var(--jb-text-muted);
	font-size: 13px;
}

/* ── Help page ──────────────────────────────────── */
.jb-page-head {
	display: flex;
	align-items: flex-start;
	justify-content: space-between;
	gap: 24px;
	margin-bottom: 32px;
}
.jb-page-head__text { max-width: 640px; }
.jb-eyebrow {
	font-size: 12px;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: var(--jb-text-muted);
	margin: 0 0 8px;
	font-weight: 600;
}
.jb-h1 {
	font-family: var(--jb-font-body);
	font-weight: 700;
	font-size: 36px;
	line-height: 1.15;
	letter-spacing: -0.02em;
	margin: 0 0 8px;
	color: var(--jb-text);
}
.jb-lede {
	color: var(--jb-text-soft);
	margin: 0;
	font-size: 16px;
}

/* Buttons */
.jb-btn {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	padding: 10px 18px;
	border-radius: var(--jb-radius-sm);
	font-family: var(--jb-font-body);
	font-weight: 500;
	font-size: 14px;
	line-height: 1;
	cursor: pointer;
	border: 1px solid transparent;
	transition: background 120ms ease, border-color 120ms ease, color 120ms ease;
	text-decoration: none;
}
.jb-btn:hover { text-decoration: none; }
.jb-btn--primary {
	background: var(--jb-text);
	color: var(--jb-bg);
}
.jb-btn--primary:hover { background: var(--jb-accent); color: #fff; }
.jb-btn--ghost {
	background: transparent;
	color: var(--jb-text);
	border-color: var(--jb-border-strong);
}
.jb-btn--ghost:hover { background: var(--jb-surface); color: var(--jb-text); }

/* Tabs / counters */
.jb-toolbar {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 16px;
	margin: 24px 0 16px;
	flex-wrap: wrap;
}
.jb-tabs {
	display: flex;
	gap: 4px;
	padding: 4px;
	background: var(--jb-bg-alt);
	border-radius: var(--jb-radius);
}
.jb-tab {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	padding: 8px 14px;
	border-radius: var(--jb-radius-sm);
	font-size: 13px;
	font-weight: 500;
	color: var(--jb-text-soft);
	cursor: pointer;
	text-decoration: none;
	border: none;
	background: transparent;
}
.jb-tab:hover { color: var(--jb-text); text-decoration: none; }
.jb-tab--active {
	background: var(--jb-surface);
	color: var(--jb-text);
	box-shadow: var(--jb-shadow-sm);
}
.jb-tab__count {
	font-variant-numeric: tabular-nums;
	color: var(--jb-text-muted);
	font-size: 12px;
}
.jb-tab--active .jb-tab__count { color: var(--jb-text-soft); }

.jb-filter {
	display: flex;
	align-items: center;
	gap: 8px;
	font-size: 13px;
	color: var(--jb-text-muted);
}
.jb-select {
	font-family: inherit;
	font-size: 13px;
	color: var(--jb-text);
	padding: 8px 32px 8px 12px;
	border: 1px solid var(--jb-border-strong);
	background-color: var(--jb-surface);
	background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%236b7280' stroke-width='2'><polyline points='6 9 12 15 18 9'/></svg>");
	background-repeat: no-repeat;
	background-position: right 10px center;
	border-radius: var(--jb-radius-sm);
	appearance: none;
	cursor: pointer;
}

/* Ticket table */
.jb-card {
	background: var(--jb-surface);
	border: 1px solid var(--jb-border);
	border-radius: var(--jb-radius);
	overflow: hidden;
}
.jb-table {
	width: 100%;
	border-collapse: collapse;
	font-size: 14px;
}
.jb-table thead th {
	text-align: left;
	font-weight: 600;
	font-size: 12px;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	color: var(--jb-text-muted);
	padding: 14px 20px;
	background: var(--jb-surface-alt);
	border-bottom: 1px solid var(--jb-border);
}
.jb-table tbody td {
	padding: 18px 20px;
	border-bottom: 1px solid var(--jb-border);
	vertical-align: top;
	color: var(--jb-text);
}
.jb-table tbody tr:last-child td { border-bottom: none; }
.jb-table tbody tr:hover { background: var(--jb-surface-alt); }

.jb-ticket-id {
	font-family: ui-monospace, SFMono-Regular, Menlo, monospace;
	font-size: 12px;
	color: var(--jb-text-muted);
	white-space: nowrap;
}
.jb-ticket-subject {
	font-weight: 500;
	color: var(--jb-text);
	margin: 0 0 4px;
}
.jb-ticket-subject a { color: inherit; }
.jb-ticket-subject a:hover { color: var(--jb-accent); text-decoration: none; }
.jb-ticket-snippet {
	color: var(--jb-text-soft);
	font-size: 13px;
	margin: 0;
	max-width: 480px;
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
}
.jb-ticket-assignee {
	display: block;
	color: var(--jb-text-muted);
	font-size: 12px;
	margin-top: 6px;
}

.jb-pill {
	display: inline-flex;
	align-items: center;
	padding: 4px 10px;
	border-radius: var(--jb-radius-pill);
	font-size: 12px;
	font-weight: 500;
	white-space: nowrap;
}
.jb-pill--category { background: var(--jb-bg-alt); color: var(--jb-text-soft); }
.jb-pill--status-open     { background: var(--jb-status-open-bg);     color: var(--jb-status-open-fg); }
.jb-pill--status-replied  { background: var(--jb-status-replied-bg);  color: var(--jb-status-replied-fg); }
.jb-pill--status-resolved { background: var(--jb-status-resolved-bg); color: var(--jb-status-resolved-fg); }
.jb-pill--status-closed   { background: var(--jb-status-closed-bg);   color: var(--jb-status-closed-fg); }
.jb-pill--prio-high   { background: var(--jb-priority-high-bg);   color: var(--jb-priority-high-fg); }
.jb-pill--prio-medium { background: var(--jb-priority-medium-bg); color: var(--jb-priority-medium-fg); }
.jb-pill--prio-low    { background: var(--jb-priority-low-bg);    color: var(--jb-priority-low-fg); }

.jb-updated { color: var(--jb-text-muted); font-size: 13px; white-space: nowrap; }

.jb-meta {
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: 14px 20px;
	background: var(--jb-surface-alt);
	border-top: 1px solid var(--jb-border);
	color: var(--jb-text-muted);
	font-size: 13px;
}
.jb-meta a { color: var(--jb-text-soft); }

.jb-empty {
	padding: 80px 24px;
	text-align: center;
	color: var(--jb-text-muted);
}
.jb-empty__title {
	font-family: var(--jb-font-body);
	font-weight: 600;
	font-size: 20px;
	color: var(--jb-text);
	margin: 0 0 8px;
}

/* Resources strip */
.jb-resources {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
	gap: 16px;
	margin-top: 40px;
}
.jb-resource {
	display: block;
	padding: 20px;
	background: var(--jb-surface);
	border: 1px solid var(--jb-border);
	border-radius: var(--jb-radius);
	color: var(--jb-text);
	text-decoration: none;
	transition: border-color 120ms ease, transform 120ms ease, background 120ms ease;
}
.jb-resource:hover {
	border-color: var(--jb-border-strong);
	color: var(--jb-text);
	text-decoration: none;
	background: var(--jb-surface-alt);
	transform: translateY(-1px);
}
.jb-resource__title { font-weight: 600; margin: 0 0 4px; }
.jb-resource__desc  { color: var(--jb-text-muted); font-size: 13px; margin: 0; }

@media (max-width: 720px) {
	.jb-h1 { font-size: 28px; }
	.jb-page-head { flex-direction: column; }
	.jb-table thead { display: none; }
	.jb-table tbody td {
		display: block;
		padding: 8px 16px;
		border-bottom: none;
	}
	.jb-table tbody tr {
		display: block;
		padding: 12px 0;
		border-bottom: 1px solid var(--jb-border);
	}
}

/* ── Frappe website overrides ──────────────────────
   Frappe's website.bundle.css and login.bundle.css ship hardcoded light-mode
   colors (white page-cards, white form-controls, light buttons). The rules
   below restyle Frappe-owned classes using our theme tokens so dark mode
   actually looks dark on /login, /signup, and any other www/* page.

   Scoped under .jb-body so they only apply on themed pages and never leak
   into anything that isn't using our base.html. */

.jb-body .page-content-wrapper,
.jb-body main.page-content,
.jb-body .container,
.jb-body .page_content {
	background: transparent !important;
	color: var(--jb-text);
}

.jb-body .page-card,
.jb-body .login-content,
.jb-body .login-content.page-card {
	background: var(--jb-surface) !important;
	border: 1px solid var(--jb-border) !important;
	color: var(--jb-text) !important;
	box-shadow: 0 1px 3px rgba(0, 0, 0, 0.06);
	border-radius: var(--jb-radius);
}

.jb-body .page-card-head,
.jb-body .page-card-body,
.jb-body .page-card-actions {
	background: transparent !important;
	color: inherit !important;
	border-color: var(--jb-border) !important;
}

.jb-body h1, .jb-body h2, .jb-body h3, .jb-body h4, .jb-body h5, .jb-body h6 {
	color: var(--jb-text);
}

.jb-body .text-muted,
.jb-body .text-secondary,
.jb-body small {
	color: var(--jb-text-muted) !important;
}

.jb-body label,
.jb-body .control-label {
	color: var(--jb-text-soft);
}

.jb-body .form-control,
.jb-body input[type="text"],
.jb-body input[type="email"],
.jb-body input[type="password"],
.jb-body input[type="number"],
.jb-body input[type="search"],
.jb-body select,
.jb-body textarea {
	background: var(--jb-bg) !important;
	color: var(--jb-text) !important;
	border: 1px solid var(--jb-border-strong) !important;
	border-radius: var(--jb-radius-sm) !important;
}
.jb-body .form-control:focus,
.jb-body input:focus,
.jb-body select:focus,
.jb-body textarea:focus {
	box-shadow: var(--jb-focus-ring) !important;
	border-color: var(--jb-accent) !important;
	outline: none !important;
}
.jb-body .form-control::placeholder,
.jb-body input::placeholder {
	color: var(--jb-text-faint);
}

.jb-body .btn-default,
.jb-body .btn-secondary {
	background: var(--jb-surface-alt) !important;
	color: var(--jb-text) !important;
	border: 1px solid var(--jb-border-strong) !important;
}
.jb-body .btn-default:hover,
.jb-body .btn-secondary:hover {
	background: var(--jb-bg-alt) !important;
	color: var(--jb-text) !important;
}

.jb-body .btn-primary,
.jb-body .btn-login {
	background: var(--jb-text) !important;
	color: var(--jb-bg) !important;
	border-color: var(--jb-text) !important;
}
.jb-body .btn-primary:hover,
.jb-body .btn-login:hover {
	background: var(--jb-accent) !important;
	color: #fff !important;
	border-color: var(--jb-accent) !important;
}

.jb-body .btn-login-option,
.jb-body .btn-authentik,
.jb-body .social-login-buttons .btn {
	background: var(--jb-surface-alt) !important;
	color: var(--jb-text) !important;
	border: 1px solid var(--jb-border-strong) !important;
}
.jb-body .btn-login-option:hover,
.jb-body .btn-authentik:hover {
	background: var(--jb-bg-alt) !important;
	border-color: var(--jb-accent) !important;
}

.jb-body .login-divider {
	color: var(--jb-text-muted);
	border-color: var(--jb-border);
}
.jb-body .login-divider::before,
.jb-body .login-divider::after {
	background: var(--jb-border) !important;
}

.jb-body a.btn-forgot,
.jb-body a.btn-link {
	color: var(--jb-accent);
}
.jb-body hr { border-color: var(--jb-border); }

/* Make sure the Frappe app-logo (small avatar above the form) doesn't paint
   itself a hardcoded white bg in dark mode. */
.jb-body .app-logo {
	background: var(--jb-surface-alt);
	border: 1px solid var(--jb-border);
}

/* breadcrumbs strip on website pages */
.jb-body .page-breadcrumbs,
.jb-body .breadcrumb,
.jb-body ol.breadcrumb {
	background: transparent !important;
	color: var(--jb-text-muted);
}
.jb-body .breadcrumb a { color: var(--jb-text-soft); }
