*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--green:#16a34a;--green-dark:#14532d;--green-mid:#166534;--green-light:#f0fdf4;--green-soft:#dcfce7;--green-border:#bbf7d0;--green-hover:#d1fae5;--accent:#16a34a;--accent-dim:#dcfce7;--accent-dark:#14532d;--shadow-green:#166534;--bg:#fff;--bg2:#f7faf8;--surface:#fff;--surface2:#f4f8f5;--border:#ddeae3;--border2:#ddeae3;--border-hover:#a7d4b8;--border-focus:#16a34a;--text:#0a1f13;--text2:#3d5c4a;--text3:#7a9e89;--text4:#a8c4b4;--red:#dc2626;--red-dim:#fef2f2;--red-border:#fecaca;--gold:#b45309;--gold-dim:#fffbeb;--gold-border:#fde68a;--yellow:#b45309;--yellow-dim:#fffbeb;--r:12px;--r-sm:10px;--r-xs:7px;--mono:"DM Sans", sans-serif;--sans:"Syne", sans-serif}html{font-size:16px}body{background:var(--bg);color:var(--text);font-family:var(--mono);-webkit-font-smoothing:antialiased;min-height:100dvh;font-weight:400;line-height:1.6;overflow-x:hidden}::-webkit-scrollbar{width:4px;height:4px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--green-border);border-radius:2px}.app{flex-direction:column;max-width:480px;min-height:100dvh;margin:0 auto;display:flex}.header{border-bottom:1px solid var(--border);background:var(--bg);z-index:50;justify-content:space-between;align-items:center;gap:12px;padding:16px 20px;display:flex;position:sticky;top:0}.logo{font-family:var(--sans);letter-spacing:-.5px;color:var(--green);font-size:21px;font-style:normal;font-weight:800}.logo-dot{color:var(--green-mid)}.content{-webkit-overflow-scrolling:touch;flex:1;padding:20px;overflow-y:auto}.btn{border-radius:var(--r);font-family:var(--mono);letter-spacing:.01em;cursor:pointer;white-space:nowrap;border:none;justify-content:center;align-items:center;gap:7px;padding:13px 20px;font-size:14px;font-weight:600;text-decoration:none;transition:background .15s,color .15s,border-color .15s,transform .1s;display:inline-flex}.btn:active{transform:scale(.985)}.btn-full{width:100%}.btn-primary{background:var(--green);color:#fff;border:none}.btn-primary:hover{background:var(--green-dark)}.btn-primary:disabled{opacity:.4;cursor:not-allowed;transform:none}.btn-outline{background:var(--bg);color:var(--green-dark);border:2px solid var(--green)}.btn-outline:hover{background:var(--green-light);border-color:var(--green-dark)}.btn-ghost{background:var(--green-light);color:var(--green-mid);border:1px solid var(--green-border);border-radius:var(--r-xs);padding:6px 12px;font-size:12px;font-weight:600}.btn-ghost:hover{background:var(--green-hover);color:var(--green-dark);border-color:var(--green)}.btn-danger{background:var(--red-dim);color:var(--red);border:1.5px solid var(--red-border)}.btn-danger:hover{background:var(--red);color:#fff}.btn-success{background:var(--green-soft);color:var(--green-dark);border:1.5px solid var(--green-border)}.btn-success:hover{background:var(--green);color:#fff}.btn-sm{border-radius:var(--r-xs);padding:6px 12px;font-size:12px}.card{background:var(--bg);border:1px solid var(--border);border-radius:var(--r);margin-bottom:10px;padding:16px;transition:border-color .15s,box-shadow .15s}.card:hover{border-color:var(--green-border)}.card-accent{border-color:var(--green-border);background:var(--green-light)}.badge{font-family:var(--mono);letter-spacing:.04em;border:1px solid;border-radius:20px;align-items:center;gap:4px;padding:4px 10px;font-size:11px;font-weight:700;display:inline-flex}.badge-pending{background:var(--gold-dim);color:var(--gold);border-color:var(--gold-border)}.badge-active{background:var(--green-light);color:var(--green-mid);border-color:var(--green-border)}.badge-inactive{background:var(--red-dim);color:#7f1d1d;border-color:var(--red-border)}.badge-verified{background:var(--green-light);color:var(--green-mid);border-color:var(--green-border)}.badge-discrepancy{background:var(--red-dim);color:#7f1d1d;border-color:var(--red-border)}.badge-matched{background:var(--green-light);color:var(--green-mid);border-color:var(--green-border)}.badge-mismatch{background:var(--gold-dim);color:#713f12;border-color:var(--gold-border)}.badge-missing{background:var(--red-dim);color:#7f1d1d;border-color:var(--red-border)}.badge-approved{background:var(--green-light);color:var(--green-mid);border-color:var(--green-border)}.badge-rejected{background:var(--red-dim);color:#7f1d1d;border-color:var(--red-border)}.badge-admin{color:#4c1d95;background:#ede9fe;border-color:#7c3aed}.badge-user{background:var(--surface2);color:var(--text2);border-color:var(--border)}.badge-superowner{background:var(--gold-dim);color:#713f12;border-color:var(--gold-border)}.field{margin-bottom:18px}.label{font-family:var(--mono);letter-spacing:.07em;text-transform:uppercase;color:var(--text3);margin-bottom:7px;font-size:11px;font-weight:600;transition:color .15s;display:block}.field:focus-within .label{color:var(--green)}.input{background:var(--surface2);border:1.5px solid var(--border);border-radius:var(--r-sm);width:100%;color:var(--text);font-family:var(--mono);appearance:none;outline:none;padding:13px 16px;font-size:15px;font-weight:500;transition:border-color .15s,background .15s,box-shadow .15s}.input::placeholder{color:var(--text4);font-weight:400}.input:hover{border-color:var(--border-hover);background:#eef6f1}.input:focus{border-color:var(--green);background:var(--bg);border-width:2px;box-shadow:0 0 0 3px #16a34a1f}.input-sm{padding:9px 12px;font-size:13px}select.input{cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg width='12' height='8' viewBox='0 0 12 8' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1L6 6L11 1' stroke='%237a9e89' stroke-width='1.8' stroke-linecap='round'/%3E%3C/svg%3E");background-position:right 14px center;background-repeat:no-repeat;padding-right:36px}.upload-zone{border:2px dashed var(--green-border);border-radius:var(--r);text-align:center;cursor:pointer;background:var(--green-light);padding:32px 20px;transition:all .15s}.upload-zone:hover,.upload-zone.over{border-color:var(--green);background:var(--green-hover)}.upload-zone-icon{margin-bottom:8px;font-size:28px}.upload-zone-title{font-family:var(--sans);color:var(--green-mid);font-size:14px;font-weight:700}.upload-zone-sub{color:var(--text3);margin-top:4px;font-size:11px}.cam-wrap{aspect-ratio:4/3;border-radius:var(--r);border:1px solid var(--border);background:#0d1f13;width:100%;position:relative;overflow:hidden}.cam-wrap video{object-fit:cover;width:100%;height:100%}.cam-overlay{background:linear-gradient(#0000 45%,#000000a6 100%);flex-direction:column;justify-content:flex-end;align-items:center;padding:16px;display:flex;position:absolute;inset:0}.cam-guide{border-radius:var(--r);pointer-events:none;border:1.5px solid #16a34ab3;width:78%;height:58%;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.shutter{background:var(--green);cursor:pointer;border:3px solid #fff;border-radius:50%;width:60px;height:60px;transition:transform .1s;box-shadow:0 0 0 4px #16a34a40}.shutter:active{transform:scale(.9)}.shutter:disabled{opacity:.35}.section-label{font-family:var(--mono);letter-spacing:.1em;text-transform:uppercase;color:var(--text3);margin-bottom:10px;font-size:10px;font-weight:700}.page-title{font-family:var(--sans);letter-spacing:-.5px;color:var(--text);font-size:24px;font-weight:800;line-height:1.15}.tbl{border-collapse:collapse;width:100%;font-size:13px}.tbl th{text-align:left;border-bottom:1px solid var(--border);font-family:var(--mono);letter-spacing:.09em;text-transform:uppercase;color:var(--text3);padding:10px 12px;font-size:10px;font-weight:700}.tbl td{border-bottom:1px solid var(--border);vertical-align:middle;color:var(--text);padding:12px}.tbl tr:last-child td{border-bottom:none}.tbl tr:hover td{background:var(--surface2)}.item-row{background:var(--bg);border:1px solid var(--border);border-radius:var(--r-sm);border-left:3px solid var(--border);grid-template-columns:1fr auto auto auto;align-items:center;gap:10px;margin-bottom:8px;padding:14px 16px;transition:border-color .15s;display:grid}.item-row.approved{border-left-color:var(--green);background:var(--green-light)}.item-row.rejected{border-left-color:var(--red);background:var(--red-dim)}.item-row.matched{border-left-color:var(--green);background:var(--green-light)}.item-row.mismatch{border-left-color:var(--gold);background:var(--gold-dim)}.item-row.missing{border-left-color:var(--red);background:var(--red-dim)}.item-name{font-family:var(--sans);text-transform:capitalize;color:var(--text);font-size:15px;font-weight:700}.item-meta{color:var(--text2);margin-top:3px;font-size:12px;font-weight:400}.stat-grid{grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:16px;display:grid}.stat-box{background:var(--surface2);border:1px solid var(--border);border-radius:var(--r-sm);text-align:center;padding:14px 10px}.stat-num{font-family:var(--sans);color:var(--text);font-size:26px;font-weight:800;line-height:1}.stat-lbl{letter-spacing:.08em;text-transform:uppercase;color:var(--text3);margin-top:4px;font-size:10px;font-weight:700}.result-banner{border-radius:var(--r);text-align:center;border:1.5px solid;margin-bottom:16px;padding:22px 20px}.result-banner.pass{background:var(--green-light);border-color:var(--green-border)}.result-banner.fail{background:var(--red-dim);border-color:var(--red-border)}.result-icon{margin-bottom:6px;font-size:32px}.result-title{font-family:var(--sans);letter-spacing:-.4px;font-size:24px;font-weight:800}.result-title.pass{color:var(--green-dark)}.result-title.fail{color:#7f1d1d}.result-sub{margin-top:4px;font-size:13px;font-weight:400}.result-banner.pass .result-sub{color:var(--green-mid)}.result-banner.fail .result-sub{color:#991b1b}.auth-shell{background:var(--bg2);flex-direction:column;justify-content:center;align-items:center;min-height:100dvh;padding:24px;display:flex}.auth-box{background:var(--bg);border:1px solid var(--border);border-radius:var(--r);width:100%;max-width:400px;padding:32px;box-shadow:0 4px 24px #16a34a12}.auth-logo{font-family:var(--sans);text-align:center;color:var(--green);margin-bottom:28px;font-size:24px;font-style:normal;font-weight:800}.auth-divider{color:var(--text3);letter-spacing:.08em;text-transform:uppercase;align-items:center;gap:12px;margin:18px 0;font-size:11px;display:flex}.auth-divider:before,.auth-divider:after{content:"";background:var(--border);flex:1;height:1px}.btn-google{background:var(--bg);border:1.5px solid var(--border);border-radius:var(--r-sm);width:100%;color:var(--text);font-family:var(--mono);cursor:pointer;justify-content:center;align-items:center;gap:10px;padding:13px 16px;font-size:14px;font-weight:500;transition:all .15s;display:flex}.btn-google:hover{border-color:var(--green);background:var(--green-light)}.btn-phone{border:1.5px solid var(--border);border-radius:var(--r-sm);width:100%;color:var(--text2);font-family:var(--mono);cursor:pointer;background:0 0;margin-top:8px;padding:13px 16px;font-size:14px;transition:all .15s}.btn-phone:hover{border-color:var(--green);color:var(--green-dark);background:var(--green-light)}.toast{background:var(--bg);border:1px solid var(--border);border-radius:var(--r-sm);font-family:var(--mono);z-index:999;white-space:nowrap;color:var(--text);padding:10px 20px;font-size:13px;font-weight:500;animation:.2s up;position:fixed;bottom:24px;left:50%;transform:translate(-50%);box-shadow:0 4px 16px #00000014}.toast.ok{border-color:var(--green-border);color:var(--green-dark);background:var(--green-light)}.toast.err{border-color:var(--red-border);color:var(--red);background:var(--red-dim)}.spinner{border:2px solid var(--green-border);border-top-color:var(--green);border-radius:50%;flex-shrink:0;width:18px;height:18px;animation:.65s linear infinite spin;display:inline-block}.loader-overlay{z-index:200;background:#ffffffeb;flex-direction:column;justify-content:center;align-items:center;gap:14px;display:flex;position:fixed;inset:0}.loader-text{font-family:var(--sans);color:var(--green-dark);letter-spacing:.02em;font-size:14px;font-weight:700}.empty{text-align:center;padding:48px 20px}.empty-icon{margin-bottom:10px;font-size:36px}.empty-title{font-family:var(--sans);color:var(--text2);font-size:18px;font-weight:700}.empty-sub{color:var(--text3);margin-top:4px;font-size:13px}.prog-wrap{background:var(--green-soft);border-radius:4px;height:5px;overflow:hidden}.prog-bar{background:var(--green);border-radius:4px;height:100%;transition:width .4s}hr{border:none;border-top:1px solid var(--border);margin:16px 0}.admin-grid{grid-template-columns:220px 1fr;min-height:100vh;display:grid}.admin-sidebar{background:var(--bg);border-right:1px solid var(--border);flex-direction:column;padding:20px 0;display:flex}.admin-nav-item{font-family:var(--mono);letter-spacing:.05em;text-transform:uppercase;color:var(--text3);cursor:pointer;text-align:left;background:0 0;border:none;align-items:center;gap:10px;width:100%;padding:12px 20px;font-size:12px;text-decoration:none;transition:all .15s;display:flex}.admin-nav-item:hover{color:var(--text);background:var(--surface2)}.admin-nav-item.on{color:var(--green-dark);background:var(--green-light);border-right:3px solid var(--green);font-weight:700}.admin-main{background:var(--bg2);padding:28px;overflow-y:auto}.user-card{background:var(--bg);border:1px solid var(--border);border-radius:var(--r);align-items:center;gap:14px;margin-bottom:8px;padding:16px;transition:border-color .15s;display:flex}.user-card:hover{border-color:var(--green-border)}.user-avatar{background:var(--green-soft);width:40px;height:40px;font-family:var(--sans);color:var(--green-dark);border:2px solid var(--green-border);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:16px;font-weight:800;display:flex;overflow:hidden}.user-avatar img{object-fit:cover;width:100%;height:100%}.user-info{flex:1;min-width:0}.user-name{font-family:var(--sans);white-space:nowrap;text-overflow:ellipsis;color:var(--text);font-size:15px;font-weight:700;overflow:hidden}.user-email{color:var(--text3);margin-top:2px;font-size:12px}.user-actions{flex-shrink:0;gap:6px;display:flex}.notice{background:var(--green-light);border:1px solid var(--green-border);border-radius:var(--r-sm);color:var(--green-mid);padding:12px 16px;font-size:13px;line-height:1.6}.notice strong{color:var(--green-dark);font-family:var(--sans)}.notice-gold{background:var(--gold-dim);border:1px solid var(--gold-border);border-radius:var(--r-sm);color:#92400e;padding:12px 16px;font-size:13px;line-height:1.6}.notice-gold strong{color:#713f12;font-family:var(--sans)}@keyframes spin{to{transform:rotate(360deg)}}@keyframes up{0%{opacity:0;transform:translate(-50%)translateY(10px)}to{opacity:1;transform:translate(-50%)translateY(0)}}@keyframes in{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.anim{animation:.25s both in}@media (max-width:680px){.admin-grid{grid-template-columns:1fr}.admin-sidebar{border-right:none;border-bottom:1px solid var(--border);flex-direction:row;padding:0;overflow-x:auto}.admin-nav-item{white-space:nowrap;border-bottom:3px solid #0000;padding:12px 14px;border-right:none!important}.admin-nav-item.on{border-bottom-color:var(--green)!important;border-right:none!important}.admin-main{padding:16px}}@supports (padding-bottom:env(safe-area-inset-bottom)){.content{padding-bottom:calc(20px + env(safe-area-inset-bottom))}}.rdp-root{--rdp-accent-color:#16a34a;--rdp-accent-background-color:#dcfce7;font-family:var(--mono);font-size:13px}.rdp-day_button{border-radius:6px!important}.rdp-selected .rdp-day_button{color:#fff!important;background:#16a34a!important}
