:root{--bg:#f6f8fb;--card:#fff;--ink:#0f172a;--muted:#64748b;--line:#e2e8f0;--brand:#0f172a;--green:#16a34a;--red:#dc2626;--amber:#f59e0b;--shadow:0 14px 35px rgba(15,23,42,.08);--r:22px}*{box-sizing:border-box}body{margin:0;background:var(--bg);color:var(--ink);font-family:system-ui,-apple-system,"Segoe UI",sans-serif}a{text-decoration:none;color:inherit}.top{height:64px;background:#fff;border-bottom:1px solid var(--line);position:sticky;top:0;z-index:20;display:flex;align-items:center;gap:12px;padding:10px 16px}.brand{display:flex;align-items:center;gap:10px}.brand img{width:38px;height:38px;border-radius:11px}.hamb{margin-left:auto}.who{display:none;color:var(--muted)}.side{display:none;position:fixed;top:64px;left:0;bottom:0;width:245px;background:#0f172a;padding:16px;z-index:30}.side.open{display:block}.side nav{display:grid;gap:8px}.side a{color:#cbd5e1;padding:12px 14px;border-radius:14px}.side a.active,.side a:hover{background:rgba(255,255,255,.12);color:#fff}.side .logout{color:#fecaca;margin-top:16px}.main{padding:18px 0 92px}.container{width:min(1180px,100%);padding:0 16px;margin:auto}.bottom{position:fixed;left:0;right:0;bottom:0;background:#fff;border-top:1px solid var(--line);display:grid;grid-template-columns:repeat(5,1fr);z-index:25}.bottom a{text-align:center;font-size:12px;font-weight:700;color:var(--muted);padding:10px 4px}.card,.stat,.login,.mobile-card{background:var(--card);border:1px solid var(--line);box-shadow:var(--shadow);border-radius:var(--r);padding:18px}.grid{display:grid;gap:16px}.stats{grid-template-columns:repeat(2,minmax(0,1fr))}.stat b{font-size:28px;display:block}.stat span,.muted{color:var(--muted)}h1{font-size:27px;margin:6px 0 14px}h2{font-size:21px;margin:6px 0 14px}.actions{display:flex;flex-wrap:wrap;gap:10px;margin-top:12px}.btn,button{border:1px solid var(--line);background:#fff;border-radius:14px;padding:11px 14px;font-weight:800;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:8px}.btn.primary,button.primary{background:var(--brand);border-color:var(--brand);color:#fff}.btn.green{background:var(--green);border-color:var(--green);color:#fff}.btn.red{background:var(--red);border-color:var(--red);color:#fff}.full{width:100%}label{display:grid;gap:7px;margin:12px 0;font-weight:800;font-size:14px}input,select,textarea{border:1px solid var(--line);border-radius:14px;padding:12px;font:inherit;width:100%;background:#fff}textarea{min-height:100px}.table{overflow:auto;border:1px solid var(--line);border-radius:18px;background:#fff}table{width:100%;border-collapse:collapse;min-width:760px}th,td{padding:12px;text-align:left;border-bottom:1px solid var(--line);vertical-align:top}th{background:#f8fafc;color:var(--muted);font-size:13px}.badge{display:inline-flex;border-radius:999px;padding:5px 9px;background:#e2e8f0;font-size:12px;font-weight:900}.b-open,.b-active,.b-approved,.b-paid{background:#dcfce7;color:#166534}.b-pending,.b-assigned{background:#fef3c7;color:#92400e}.b-disabled,.b-rejected,.b-cancelled{background:#fee2e2;color:#991b1b}.b-clocked-in{background:#dbeafe;color:#1d4ed8}.alert{padding:12px 14px;border-radius:16px;background:#dcfce7;margin-bottom:14px}.alert.danger{background:#fee2e2}.login{max-width:420px;margin:8vh auto}.login img{width:80px;height:80px;border-radius:18px}.demo{padding:12px;border-radius:14px;background:#f8fafc;margin-top:14px}.hero{border-radius:28px;padding:22px;background:linear-gradient(135deg,#0f172a,#334155);color:#fff;box-shadow:var(--shadow)}.online{display:flex;align-items:center;justify-content:space-between;gap:16px}.switch{position:relative;width:68px;height:38px}.switch input{display:none}.slider{position:absolute;inset:0;background:#475569;border-radius:999px}.slider:before{content:"";position:absolute;width:30px;height:30px;left:4px;top:4px;background:#fff;border-radius:999px;transition:.2s}.switch input:checked+.slider{background:#16a34a}.switch input:checked+.slider:before{transform:translateX(30px)}.map{height:260px;border:1px dashed #94a3b8;border-radius:22px;background:linear-gradient(45deg,#dbeafe,#dcfce7);display:flex;align-items:center;justify-content:center;text-align:center;color:#334155}.msg{padding:12px;border-radius:14px;background:#f8fafc;margin:8px 0}.msg.admin{background:#e0f2fe}@media(min-width:850px){.side{display:block}.main{margin-left:245px;padding-bottom:40px}.bottom{display:none}.hamb{display:none}.who{display:inline;margin-left:auto}.stats{grid-template-columns:repeat(4,1fr)}.two{display:grid;grid-template-columns:1.2fr .8fr;gap:16px}}@media(max-width:620px){.stats{grid-template-columns:1fr}.actions .btn,.actions button{flex:1 1 100%}h1{font-size:24px}}
/* v3 polish */
.stat{min-height:98px;display:flex;flex-direction:column;justify-content:center}.mobile-card+.mobile-card{margin-top:12px}.top .hamb{min-width:72px}.role-admin .hero{background:linear-gradient(135deg,#111827,#1f2937)}.role-driver .hero{background:linear-gradient(135deg,#0f172a,#0369a1)}.role-restaurant .hero{background:linear-gradient(135deg,#0f172a,#14532d)}
@media(max-width:849px){.side{box-shadow:0 30px 70px rgba(15,23,42,.35)}.main{padding-top:14px}.container{padding:0 14px}.table table{min-width:680px}.top{height:62px}.brand b{font-size:18px}.brand img{width:34px;height:34px}.card,.stat,.login,.mobile-card{border-radius:20px;padding:16px}.bottom a{min-height:54px;display:flex;align-items:center;justify-content:center}}


/* v4 hardening: inline styling + stronger form layout */
.brand-mark,.login-logo{width:38px;height:38px;border-radius:12px;display:inline-flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#0f172a,#22c55e);color:#fff;font-weight:950;box-shadow:0 8px 22px rgba(15,23,42,.22)}
.login-logo{width:82px;height:82px;border-radius:22px;font-size:38px;margin-bottom:12px}.brand img{display:none}.brand b{letter-spacing:-.02em}.card form{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;align-items:end}.card form label{margin:0}.card form textarea{min-height:52px}.card form input[type=file]{padding:9px;background:#f8fafc}.card form button{min-height:48px}.card form input[type=hidden],.card form input[name=csrf]{display:none}.card > form:first-of-type{margin-top:6px}.card p{line-height:1.5}.role-restaurant .card h2{display:flex;align-items:center;gap:10px}.role-restaurant .card h2:before{content:'🍽️';font-size:20px}.top{backdrop-filter:saturate(150%) blur(10px)}
@media(max-width:760px){.card form{grid-template-columns:1fr}.card form button{width:100%}.top{padding-left:12px;padding-right:12px}.who{max-width:140px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.brand b{font-size:18px}.hamb{padding:9px 12px}.side{width:min(88vw,290px)}}
