/* =========================================================================
 * Pigee Courier — portal stylesheet (v2, modern)
 * Owner back-office SPA (#pcr-root) + driver PWA (#pcr-driver-root).
 * Brand: Pigee blue #0064A8. Display: Sora. Body: Inter.
 * Aesthetic: deep-navy premium shell, light working surfaces, soft depth,
 * tasteful gradients + motion. Pink spark reserved for the login screen.
 * ========================================================================= */

:root {
	/* brand */
	--pcr-blue: #0064A8;
	--pcr-blue-600: #0073C4;
	--pcr-blue-700: #015089;
	--pcr-blue-300: #5BA6D8;
	--pcr-blue-50: #EAF3FA;
	--pcr-blue-100: #D4E7F4;
	--pcr-pink: #EC4E86;       /* from the Pigee AI chip — login screen only */
	--pcr-pink-soft: #FBE4EE;

	/* navy shell */
	--pcr-navy: #08182B;
	--pcr-navy-800: #0C2236;
	--pcr-navy-700: #15324A;

	/* ink + surfaces */
	--pcr-ink: #0B1F30;
	--pcr-body: #3D5266;
	--pcr-muted: #74879B;
	--pcr-line: #E5EBF1;
	--pcr-line-soft: #EEF2F6;
	--pcr-bg: #F1F5F9;
	--pcr-card: #FFFFFF;

	/* status */
	--pcr-ok: #1E9E63; --pcr-ok-bg: #E4F5EC;
	--pcr-warn: #C7791A; --pcr-warn-bg: #FBF1E1;
	--pcr-err: #D23A55; --pcr-err-bg: #FBE7EB;

	--pcr-radius: 16px;
	--pcr-radius-sm: 11px;
	--pcr-shadow: 0 1px 2px rgba(8,24,43,.05), 0 6px 20px rgba(8,24,43,.06);
	--pcr-shadow-lg: 0 24px 60px rgba(8,24,43,.22);
	--pcr-ring: 0 0 0 3px rgba(0,100,168,.16);

	--pcr-display: "Sora", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
	--pcr-font: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
}

* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
.pcr-body {
	font-family: var(--pcr-font);
	color: var(--pcr-body);
	background: var(--pcr-bg);
	-webkit-font-smoothing: antialiased;
	text-rendering: optimizeLegibility;
	line-height: 1.55;
}
h1, h2, h3 { font-family: var(--pcr-display); color: var(--pcr-ink); margin: 0 0 .35em; line-height: 1.2; letter-spacing: -.015em; }
a { color: var(--pcr-blue); text-decoration: none; }
a:hover { color: var(--pcr-blue-700); }
.pcr-muted { color: var(--pcr-muted); }
.pcr-small { font-size: 13px; }

/* splash / spinner */
.pcr-splash { display: grid; place-items: center; min-height: 100vh; }
.pcr-spinner { width: 40px; height: 40px; border-radius: 50%;
	border: 3px solid var(--pcr-blue-100); border-top-color: var(--pcr-blue); animation: pcr-spin .8s linear infinite; }
@keyframes pcr-spin { to { transform: rotate(360deg); } }
@keyframes pcr-rise { from { opacity: 0; transform: translateY(10px); } to { opacity: 1; transform: none; } }
@keyframes pcr-fade { from { opacity: 0; } to { opacity: 1; } }

/* ========================= AUTH / LOGIN ============================== */
.pcr-auth-wrap { min-height: 100vh; display: grid; grid-template-columns: 1fr; }
@media (min-width: 900px) { .pcr-auth-wrap { grid-template-columns: 1.05fr .95fr; } }

.pcr-auth-hero {
	display: none; position: relative; overflow: hidden; color: #fff;
	padding: 60px 60px 48px; flex-direction: column; justify-content: space-between;
	background:
		radial-gradient(900px 500px at 85% -10%, rgba(236,78,134,.30), transparent 55%),
		radial-gradient(1100px 700px at 0% 110%, rgba(91,166,216,.40), transparent 55%),
		linear-gradient(160deg, #013A66 0%, var(--pcr-blue) 55%, #015089 100%);
}
@media (min-width: 900px) { .pcr-auth-hero { display: flex; } }
.pcr-auth-hero::after {
	content: ""; position: absolute; inset: 0; pointer-events: none; opacity: .5;
	background-image: radial-gradient(rgba(255,255,255,.10) 1px, transparent 1.4px);
	background-size: 22px 22px; mask-image: linear-gradient(150deg, #000, transparent 70%);
}
.pcr-auth-hero > * { position: relative; z-index: 1; }
.pcr-auth-hero h1 { color: #fff; font-size: 38px; font-weight: 800; max-width: 14ch; }
.pcr-auth-hero .lede { color: rgba(255,255,255,.88); font-size: 17px; max-width: 34ch; }
.pcr-hero-points { list-style: none; padding: 0; margin: 30px 0 0; }
.pcr-hero-points li { display: flex; gap: 13px; align-items: flex-start; margin: 15px 0; color: rgba(255,255,255,.95); animation: pcr-rise .5s both; }
.pcr-hero-points li:nth-child(2) { animation-delay: .08s; }
.pcr-hero-points li:nth-child(3) { animation-delay: .16s; }
.pcr-hero-points .tick { flex: none; width: 26px; height: 26px; border-radius: 8px; display: grid; place-items: center;
	background: rgba(255,255,255,.16); backdrop-filter: blur(4px); margin-top: 1px; }
.pcr-logo-img { height: 34px; width: auto; }
.pcr-hero-foot { color: rgba(255,255,255,.7); font-size: 13px; }

.pcr-auth-panel { display: grid; place-items: center; padding: 40px 22px; }
.pcr-auth-card { width: 100%; max-width: 410px; animation: pcr-rise .5s both; }
.pcr-auth-logo { height: 38px; margin-bottom: 26px; }
.pcr-auth-card h2 { font-size: 25px; }
.pcr-tabs { display: flex; gap: 4px; background: var(--pcr-bg); padding: 5px; border-radius: 13px; margin: 22px 0 24px; border: 1px solid var(--pcr-line-soft); }
.pcr-tabs button { flex: 1; border: 0; background: transparent; padding: 10px; border-radius: 9px;
	font: 600 14px var(--pcr-font); color: var(--pcr-body); cursor: pointer; transition: all .18s; }
.pcr-tabs button.is-on { background: #fff; color: var(--pcr-blue); box-shadow: var(--pcr-shadow); }

/* ============================ APP SHELL ============================== */
.pcr-shell { display: grid; grid-template-columns: 256px 1fr; min-height: 100vh; }
@media (max-width: 880px) { .pcr-shell { grid-template-columns: 1fr; } }

.pcr-side {
	position: relative; color: #AFC2D6; padding: 24px 16px 18px; display: flex; flex-direction: column;
	background: linear-gradient(180deg, var(--pcr-navy) 0%, var(--pcr-navy-800) 100%);
	border-right: 1px solid rgba(255,255,255,.05);
}
@media (max-width: 880px) {
	.pcr-side { position: fixed; inset: 0 auto 0 0; width: 272px; z-index: 60; transform: translateX(-106%);
		transition: transform .24s cubic-bezier(.4,0,.2,1); }
	.pcr-side.is-open { transform: none; box-shadow: var(--pcr-shadow-lg); }
}
.pcr-side-logo { height: 30px; width: auto; margin: 4px 6px 24px; }
.pcr-nav { display: flex; flex-direction: column; gap: 3px; flex: 1; }
.pcr-nav button {
	display: flex; align-items: center; gap: 12px; text-align: left; border: 0; background: transparent;
	color: #92A8C0; cursor: pointer; padding: 11px 13px; border-radius: 11px; font: 600 14px var(--pcr-font);
	position: relative; transition: all .16s;
}
.pcr-nav button svg { flex: none; opacity: .9; }
.pcr-nav button:hover { background: rgba(255,255,255,.05); color: #fff; }
.pcr-nav button.is-on {
	background: linear-gradient(100deg, var(--pcr-blue), var(--pcr-blue-600));
	color: #fff; box-shadow: 0 8px 20px rgba(0,100,168,.40);
}
.pcr-nav button.is-on svg { opacity: 1; }
.pcr-side-foot { border-top: 1px solid rgba(255,255,255,.08); padding-top: 16px; margin-top: 14px; }
.pcr-side-foot .pcr-biz { color: #fff; font-weight: 600; font-size: 14px; }
.pcr-plan-chip { display: inline-flex; align-items: center; gap: 6px; margin: 6px 0 12px; padding: 3px 10px; border-radius: 999px;
	background: rgba(91,166,216,.16); color: var(--pcr-blue-300); font: 600 12px var(--pcr-font); text-transform: capitalize; }

.pcr-main { display: flex; flex-direction: column; min-width: 0; }
.pcr-topbar { height: 64px; background: rgba(255,255,255,.85); backdrop-filter: saturate(180%) blur(12px);
	border-bottom: 1px solid var(--pcr-line); display: flex; align-items: center; gap: 14px; padding: 0 26px; position: sticky; top: 0; z-index: 30; }
.pcr-topbar h1 { font-size: 20px; margin: 0; }
.pcr-burger { display: none; border: 0; background: transparent; cursor: pointer; padding: 6px; }
@media (max-width: 880px) { .pcr-burger { display: block; } }
.pcr-topbar-spacer { flex: 1; }
.pcr-content { padding: 28px 26px 72px; max-width: 1180px; width: 100%; animation: pcr-fade .35s both; }
.pcr-scrim { display: none; }
@media (max-width: 880px) { .pcr-scrim.is-on { display: block; position: fixed; inset: 0; background: rgba(8,24,43,.45); backdrop-filter: blur(2px); z-index: 55; } }

/* ============================ PRIMITIVES ============================= */
.pcr-card { background: var(--pcr-card); border: 1px solid var(--pcr-line); border-radius: var(--pcr-radius); box-shadow: var(--pcr-shadow); padding: 22px; }
.pcr-card + .pcr-card { margin-top: 16px; }
.pcr-card-h { display: flex; align-items: center; gap: 12px; margin-bottom: 18px; }
.pcr-card-h h2 { font-size: 16px; margin: 0; }
.pcr-card-h .pcr-topbar-spacer { flex: 1; }

.pcr-field { margin-bottom: 15px; }
.pcr-field label { display: block; font: 600 13px var(--pcr-font); color: var(--pcr-ink); margin-bottom: 6px; }
.pcr-input, .pcr-select, textarea.pcr-input {
	width: 100%; border: 1px solid var(--pcr-line); border-radius: var(--pcr-radius-sm); padding: 11px 13px;
	font: 400 15px var(--pcr-font); color: var(--pcr-ink); background: #fff; transition: border-color .15s, box-shadow .15s;
}
.pcr-input:focus, .pcr-select:focus, textarea.pcr-input:focus { outline: 0; border-color: var(--pcr-blue); box-shadow: var(--pcr-ring); }
.pcr-input::placeholder { color: #A9B7C6; }
textarea.pcr-input { min-height: 80px; resize: vertical; }
.pcr-row { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.pcr-row-3 { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 14px; }
@media (max-width: 560px) { .pcr-row, .pcr-row-3 { grid-template-columns: 1fr; } }

.pcr-btn { display: inline-flex; align-items: center; justify-content: center; gap: 8px; border: 1px solid transparent;
	border-radius: var(--pcr-radius-sm); cursor: pointer; font: 600 14px var(--pcr-font); padding: 11px 17px;
	transition: transform .12s, box-shadow .15s, background .15s; }
.pcr-btn:active { transform: translateY(1px); }
.pcr-btn-primary { background: linear-gradient(100deg, var(--pcr-blue), var(--pcr-blue-600)); color: #fff; box-shadow: 0 6px 16px rgba(0,100,168,.28); }
.pcr-btn-primary:hover { box-shadow: 0 10px 24px rgba(0,100,168,.36); color: #fff; }
.pcr-btn-ghost { background: #fff; border-color: var(--pcr-line); color: var(--pcr-ink); }
.pcr-btn-ghost:hover { background: var(--pcr-bg); }
.pcr-btn-danger { background: var(--pcr-err-bg); color: var(--pcr-err); }
.pcr-btn-danger:hover { background: #F8D8DE; }
.pcr-btn-block { width: 100%; }
.pcr-btn[disabled] { opacity: .55; cursor: default; transform: none; }
.pcr-btn-sm { padding: 7px 11px; font-size: 13px; }

.pcr-badge { display: inline-flex; align-items: center; gap: 6px; padding: 3px 10px; border-radius: 999px; font: 600 12px var(--pcr-font); text-transform: capitalize; }
.pcr-badge::before { content: ""; width: 6px; height: 6px; border-radius: 50%; background: currentColor; }
.b-unassigned { background: #EDF1F6; color: #5E7088; }
.b-assigned { background: var(--pcr-blue-50); color: var(--pcr-blue); }
.b-picked_up, .b-out_for_delivery { background: var(--pcr-warn-bg); color: var(--pcr-warn); }
.b-delivered, .b-ordered { background: var(--pcr-ok-bg); color: var(--pcr-ok); }
.b-failed, .b-returned { background: var(--pcr-err-bg); color: var(--pcr-err); }
.b-quoted { background: var(--pcr-blue-50); color: var(--pcr-blue); }

.pcr-table { width: 100%; border-collapse: collapse; }
.pcr-table th { text-align: left; font: 600 11px var(--pcr-font); text-transform: uppercase; letter-spacing: .05em; color: var(--pcr-muted); padding: 11px 12px; border-bottom: 1px solid var(--pcr-line); }
.pcr-table td { padding: 13px 12px; border-bottom: 1px solid var(--pcr-line-soft); font-size: 14px; vertical-align: middle; }
.pcr-table tr:last-child td { border-bottom: 0; }
.pcr-table tbody tr { transition: background .12s; }
.pcr-table tbody tr:hover { background: var(--pcr-blue-50); }
.pcr-table-wrap { overflow-x: auto; }
.pcr-cell-strong { color: var(--pcr-ink); font-weight: 600; }

.pcr-stats { display: grid; grid-template-columns: repeat(auto-fit, minmax(155px, 1fr)); gap: 16px; margin-bottom: 20px; }
.pcr-stat { position: relative; overflow: hidden; background: var(--pcr-card); border: 1px solid var(--pcr-line); border-radius: var(--pcr-radius); padding: 18px 20px; box-shadow: var(--pcr-shadow); animation: pcr-rise .4s both; }
.pcr-stat .n { font-family: var(--pcr-display); font-size: 30px; font-weight: 800; color: var(--pcr-ink); letter-spacing: -.02em; }
.pcr-stat .l { font-size: 13px; color: var(--pcr-muted); margin-top: 2px; }
.pcr-stat.accent { color: #fff; border-color: transparent;
	background: radial-gradient(420px 200px at 110% -40%, rgba(91,166,216,.55), transparent 60%), linear-gradient(135deg, var(--pcr-blue), var(--pcr-blue-700)); }
.pcr-stat.accent .n, .pcr-stat.accent .l { color: #fff; }
.pcr-stat.accent .l { color: rgba(255,255,255,.85); }

.pcr-empty { text-align: center; padding: 46px 20px; color: var(--pcr-muted); }
.pcr-empty svg { opacity: .35; margin-bottom: 12px; }
.pcr-note { padding: 12px 15px; border-radius: var(--pcr-radius-sm); font-size: 14px; margin-bottom: 14px; }
.pcr-note-err { background: var(--pcr-err-bg); color: var(--pcr-err); }
.pcr-note-ok { background: var(--pcr-ok-bg); color: var(--pcr-ok); }
.pcr-note-info { background: var(--pcr-blue-50); color: var(--pcr-blue-700); }

.pcr-modal-scrim { position: fixed; inset: 0; background: rgba(8,24,43,.55); backdrop-filter: blur(3px); display: grid; place-items: center; padding: 18px; z-index: 80; animation: pcr-fade .2s both; }
.pcr-modal { background: #fff; border-radius: var(--pcr-radius); box-shadow: var(--pcr-shadow-lg); width: 100%; max-width: 540px; max-height: 90vh; overflow: auto; animation: pcr-rise .25s both; }
.pcr-modal-h { padding: 20px 22px; border-bottom: 1px solid var(--pcr-line); display: flex; align-items: center; }
.pcr-modal-h h3 { margin: 0; font-size: 18px; }
.pcr-modal-b { padding: 22px; }
.pcr-modal-f { padding: 16px 22px; border-top: 1px solid var(--pcr-line); display: flex; gap: 10px; justify-content: flex-end; background: var(--pcr-bg); }
.pcr-x { margin-left: auto; border: 0; background: transparent; cursor: pointer; color: var(--pcr-muted); font-size: 24px; line-height: 1; padding: 0 4px; }
.pcr-x:hover { color: var(--pcr-ink); }

.pcr-code { background: var(--pcr-navy); color: #BBD6EC; border-radius: var(--pcr-radius-sm); padding: 15px 17px; font: 13px/1.65 ui-monospace, SFMono-Regular, Menlo, monospace; white-space: pre-wrap; word-break: break-all; border: 1px solid var(--pcr-navy-700); }

.pcr-quote-opt { display: flex; align-items: center; gap: 14px; border: 1px solid var(--pcr-line); border-radius: var(--pcr-radius-sm); padding: 15px; margin-bottom: 11px; transition: border-color .15s, box-shadow .15s; }
.pcr-quote-opt.is-best { border-color: var(--pcr-blue); background: var(--pcr-blue-50); box-shadow: var(--pcr-ring); }
.pcr-quote-opt .meth { flex: 1; }
.pcr-quote-opt .meth b { color: var(--pcr-ink); display: block; }
.pcr-quote-opt .price { font-family: var(--pcr-display); font-size: 21px; font-weight: 800; color: var(--pcr-ink); }
.pcr-quote-break { font-size: 13px; color: var(--pcr-muted); margin-top: 2px; }

/* ============================ DRIVER PWA ============================= */
.pcr-driver { background: var(--pcr-navy); }
.pcr-driver-shell { max-width: 560px; margin: 0 auto; min-height: 100vh; background: var(--pcr-bg); display: flex; flex-direction: column; box-shadow: 0 0 80px rgba(0,0,0,.35); }
.pcr-driver-top { position: sticky; top: 0; z-index: 10; color: #fff; padding: calc(18px + env(safe-area-inset-top)) 20px 18px;
	background: radial-gradient(500px 200px at 100% -30%, rgba(91,166,216,.5), transparent 60%), linear-gradient(135deg, var(--pcr-blue), var(--pcr-blue-700)); }
.pcr-driver-top .biz { font-size: 13px; opacity: .85; }
.pcr-driver-top .nm { font-family: var(--pcr-display); font-size: 22px; font-weight: 800; }
.pcr-driver-meta { display: flex; gap: 16px; font-size: 13px; margin-top: 10px; }
.pcr-driver-meta b { font-family: var(--pcr-display); }
.pcr-progress { height: 6px; border-radius: 999px; background: rgba(255,255,255,.22); margin-top: 12px; overflow: hidden; }
.pcr-progress > i { display: block; height: 100%; background: #fff; border-radius: 999px; transition: width .4s ease; }
.pcr-stops { padding: 16px 14px 96px; display: flex; flex-direction: column; gap: 13px; }
.pcr-stop { background: #fff; border: 1px solid var(--pcr-line); border-radius: var(--pcr-radius); box-shadow: var(--pcr-shadow); overflow: hidden; animation: pcr-rise .35s both; }
.pcr-stop.is-done { opacity: .72; }
.pcr-stop-h { display: flex; gap: 13px; padding: 15px 16px; align-items: flex-start; }
.pcr-seq { flex: none; width: 32px; height: 32px; border-radius: 11px; background: linear-gradient(135deg, var(--pcr-blue), var(--pcr-blue-600)); color: #fff; font: 700 14px var(--pcr-display); display: grid; place-items: center; box-shadow: 0 4px 10px rgba(0,100,168,.35); }
.pcr-seq.done { background: var(--pcr-ok); box-shadow: 0 4px 10px rgba(30,158,99,.35); }
.pcr-stop-info { flex: 1; min-width: 0; }
.pcr-stop-info .who { font-weight: 700; color: var(--pcr-ink); margin-top: 6px; }
.pcr-stop-info .addr { font-size: 14px; color: var(--pcr-body); }
.pcr-stop-actions { display: flex; flex-wrap: wrap; gap: 8px; padding: 0 16px 15px; }
.pcr-dir-tag { font: 700 11px var(--pcr-font); text-transform: uppercase; letter-spacing: .04em; padding: 2px 8px; border-radius: 7px; background: var(--pcr-blue-50); color: var(--pcr-blue); }
.pcr-dir-tag.inbound { background: var(--pcr-ok-bg); color: var(--pcr-ok); }
.pcr-dir-tag.outbound { background: var(--pcr-warn-bg); color: var(--pcr-warn); }
.pcr-tel { color: var(--pcr-blue); font-weight: 600; }
.pcr-pod-thumb { width: 100%; border-radius: var(--pcr-radius-sm); margin-top: 10px; border: 1px solid var(--pcr-line); }
.pcr-driver-empty { padding: 64px 24px; text-align: center; color: var(--pcr-muted); }
