:root{--primary: #1e3a8a;--primary-dark: #172554;--accent: #2563eb;--bg: #f1f5f9;--card: #ffffff;--text: #0f172a;--muted: #64748b;--border: #e2e8f0;--danger: #dc2626;--shadow: 0 1px 3px rgba(0, 0, 0, .1), 0 1px 2px rgba(0, 0, 0, .06)}*{margin:0;padding:0;box-sizing:border-box;-webkit-tap-highlight-color:transparent}html,body{height:100%}body{font-family:Noto Sans Lao,Segoe UI,Tahoma,sans-serif;background:#e2e8f0;color:var(--text);-webkit-font-smoothing:antialiased}#root{min-height:100vh}.app-shell{max-width:480px;margin:0 auto;min-height:100vh;background:var(--bg);position:relative;display:flex;flex-direction:column;box-shadow:0 0 24px #00000014}.app-header{background:var(--primary);color:#fff;padding:14px 16px;padding-top:calc(14px + env(safe-area-inset-top));display:flex;align-items:center;gap:10px;position:sticky;top:0;z-index:20}.app-header h1{font-size:18px;font-weight:600}.back-btn{background:#ffffff26;border:none;color:#fff;width:36px;height:36px;border-radius:50%;font-size:20px;display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0}.back-btn:active{background:#ffffff4d}.page-body{flex:1;padding:16px 16px 96px;overflow-y:auto}.menu-grid{display:flex;flex-direction:column;gap:16px;margin-top:8px}.menu-card{background:var(--card);border-radius:16px;padding:28px 20px;display:flex;align-items:center;gap:18px;box-shadow:var(--shadow);cursor:pointer;border:1px solid var(--border)}.menu-card:active{transform:scale(.98)}.menu-icon{width:64px;height:64px;border-radius:16px;display:flex;align-items:center;justify-content:center;font-size:34px;flex-shrink:0}.menu-icon.cars{background:#dbeafe}.menu-icon.drivers{background:#dcfce7}.menu-card-text h2{font-size:18px;font-weight:600}.menu-card-text p{font-size:13px;color:var(--muted);margin-top:4px}.list{display:flex;flex-direction:column;gap:12px}.list-item{background:var(--card);border-radius:14px;padding:12px;display:flex;align-items:center;gap:14px;box-shadow:var(--shadow);cursor:pointer;border:1px solid var(--border)}.list-item:active{background:#f8fafc}.item-photo{width:64px;height:64px;border-radius:12px;object-fit:cover;flex-shrink:0;background:#e2e8f0}.item-photo.placeholder{display:flex;align-items:center;justify-content:center;font-size:28px;color:#94a3b8}.editable-photo{position:relative;width:64px;height:64px;flex-shrink:0}.photo-edit-btn{position:absolute;right:-6px;bottom:-6px;width:26px;height:26px;border-radius:50%;background:var(--accent);color:#fff;border:2px solid #fff;font-size:12px;line-height:1;padding:0;display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 1px 4px #0000004d}.photo-edit-btn:active{transform:scale(.9)}.photo-edit-btn:disabled{background:#94a3b8;cursor:default}.item-info{flex:1;min-width:0}.item-info .title{font-size:16px;font-weight:600}.item-info .sub{font-size:13px;color:var(--muted);margin-top:3px}.chevron{color:#cbd5e1;font-size:22px}.item-delete-btn{width:34px;height:34px;border-radius:50%;background:#fee2e2;color:var(--danger);border:none;font-size:15px;display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0}.item-delete-btn:active{background:#fecaca}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a8c;display:flex;align-items:center;justify-content:center;padding:24px;z-index:50}.modal-card{background:var(--card);border-radius:16px;padding:22px;width:100%;max-width:320px}.modal-title{font-size:17px;font-weight:700}.modal-message{font-size:14px;color:var(--muted);margin-top:8px;line-height:1.5}.modal-actions{display:flex;gap:10px;margin-top:20px}.modal-actions .btn{flex:1}.btn-danger{background:var(--danger);color:#fff}.btn-danger:active:not(:disabled){background:#b91c1c}.btn-danger:disabled{background:#fca5a5;cursor:not-allowed}.fab{position:fixed;bottom:24px;right:24px;width:58px;height:58px;border-radius:50%;background:var(--accent);color:#fff;border:none;font-size:30px;display:flex;align-items:center;justify-content:center;box-shadow:0 6px 16px #2563eb73;cursor:pointer;z-index:30}.fab:active{transform:scale(.92)}@media (min-width: 480px){.fab{right:calc(50% - 216px)}}.form{display:flex;flex-direction:column;gap:18px}.field label{display:block;font-size:14px;font-weight:600;margin-bottom:6px}.field input{width:100%;padding:12px 14px;border:1px solid var(--border);border-radius:10px;font-size:16px;font-family:inherit;background:#fff}.field input:focus{outline:none;border-color:var(--accent)}.field input:disabled{background:#f1f5f9;color:var(--muted)}.field .hint{font-size:12px;color:var(--muted);margin-top:4px}.field .error{font-size:12px;color:var(--danger);margin-top:4px}.photo-picker{width:100%;aspect-ratio:4 / 3;border:2px dashed var(--border);border-radius:14px;background:#fff;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;color:var(--muted);cursor:pointer;overflow:hidden}.photo-picker img{width:100%;height:100%;object-fit:cover}.photo-picker .picker-icon{font-size:40px}.btn{width:100%;padding:14px;border:none;border-radius:12px;font-size:16px;font-weight:600;font-family:inherit;cursor:pointer}.btn-primary{background:var(--accent);color:#fff}.btn-primary:disabled{background:#93c5fd;cursor:not-allowed}.btn-primary:active:not(:disabled){background:var(--primary)}.btn-outline{background:#fff;color:var(--accent);border:1px solid var(--accent)}.qr-card{background:var(--card);border-radius:16px;padding:24px;display:flex;flex-direction:column;align-items:center;gap:16px;box-shadow:var(--shadow);border:1px solid var(--border)}.qr-card canvas{width:240px!important;height:240px!important;border-radius:8px}.qr-caption{text-align:center}.qr-caption .big{font-size:18px;font-weight:700}.qr-caption .small{font-size:13px;color:var(--muted);margin-top:4px;word-break:break-all}.success-banner{background:#dcfce7;color:#166534;border-radius:12px;padding:12px 16px;font-size:14px;font-weight:600;text-align:center;margin-bottom:16px}.state{text-align:center;padding:48px 16px;color:var(--muted)}.state .state-icon{font-size:48px;margin-bottom:12px}.spinner{width:36px;height:36px;border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite;margin:0 auto}@keyframes spin{to{transform:rotate(360deg)}}.header-right{margin-left:auto;display:flex;align-items:center}.lock-btn{background:#ffffff26;border:none;color:#fff;width:36px;height:36px;border-radius:50%;font-size:16px;display:flex;align-items:center;justify-content:center;cursor:pointer}.lock-btn:active{background:#ffffff4d}.role-banner{display:flex;align-items:center;justify-content:space-between;gap:10px;background:var(--card);border:1px solid var(--border);border-radius:12px;padding:12px 14px;margin-bottom:16px;box-shadow:var(--shadow)}.role-banner-name{font-weight:600;font-size:15px}.role-banner-perm{font-size:12px;color:var(--muted);margin-top:2px}.role-badge{font-size:11px;font-weight:700;letter-spacing:.5px;padding:5px 12px;border-radius:999px;flex-shrink:0}.role-badge.role-admin{background:#dbeafe;color:#1e40af}.role-badge.role-staff{background:#dcfce7;color:#166534}.role-badge.role-guest{background:#f1f5f9;color:#475569}.pin-shell{justify-content:center;align-items:center;padding:24px;background:var(--primary)}.pin-box{width:100%;display:flex;flex-direction:column;align-items:center}.pin-logo{width:96px;height:96px;border-radius:24px;background:#fff;display:flex;align-items:center;justify-content:center;overflow:hidden;padding:12px;margin-bottom:20px}.pin-logo img{width:100%;height:100%;object-fit:contain}.pin-title{color:#fff;font-size:22px;font-weight:700}.pin-sub{color:#ffffffb3;font-size:13px;margin-top:6px}.pin-dots{display:flex;gap:16px;margin-top:28px}.pin-dot{width:16px;height:16px;border-radius:50%;border:2px solid rgba(255,255,255,.5);background:transparent;transition:background .15s,border-color .15s}.pin-dot.filled{background:#fff;border-color:#fff}.pin-dot.err{border-color:#fca5a5}.pin-dot.filled.err{background:#fca5a5}.pin-dots.shake{animation:shake .4s}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-8px)}75%{transform:translate(8px)}}.pin-status{height:22px;margin:14px 0 18px;color:#fffc;font-size:14px;display:flex;align-items:center}.pin-error{color:#fca5a5;font-weight:600}.numpad{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;width:100%;max-width:296px}.num-key{aspect-ratio:1;border:none;border-radius:50%;background:#ffffff1f;color:#fff;font-size:26px;font-weight:600;font-family:inherit;cursor:pointer;display:flex;align-items:center;justify-content:center}.num-key:active:not(:disabled){background:#ffffff4d}.num-key:disabled{opacity:.35;cursor:default}.num-key.del{background:transparent;font-size:22px}
