*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #f8f9fb;--surface: #ffffff;--surface-2: #f1f3f7;--border: #e4e7ef;--sidebar-bg: #0f1117;--sidebar-2: #1a1d27;--sidebar-active: #242838;--accent: #6366f1;--accent-2: #818cf8;--accent-glow: rgba(99,102,241,.15);--text: #0f1117;--text-2: #6b7280;--text-3: #9ca3af;--sidebar-text: #e2e4ea;--sidebar-text-2: #8b90a0;--green: #10b981;--amber: #f59e0b;--red: #ef4444;--radius: 10px;--radius-lg: 16px;--shadow: 0 1px 3px rgba(0,0,0,.07), 0 1px 2px rgba(0,0,0,.04);--shadow-md: 0 4px 12px rgba(0,0,0,.08), 0 2px 4px rgba(0,0,0,.04);--shadow-lg: 0 20px 40px rgba(0,0,0,.12);--font: "Inter", "Noto Sans JP", -apple-system, sans-serif}html,body,#root{height:100%;font-family:var(--font);background:var(--bg);color:var(--text)}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border);border-radius:99px}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}@keyframes slideIn{0%{opacity:0;transform:translate(-8px)}to{opacity:1;transform:none}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes livePing{0%{transform:scale(1);opacity:1}to{transform:scale(2.2);opacity:0}}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.fadeIn{animation:fadeIn .25s ease both}.slideIn{animation:slideIn .2s ease both}.app-shell{display:flex;height:100vh;overflow:hidden}.main-area{flex:1;display:flex;flex-direction:column;overflow:hidden}.page-body{flex:1;overflow-y:auto;padding:28px 32px}.sidebar{width:240px;min-width:240px;background:var(--sidebar-bg);display:flex;flex-direction:column;padding:0;border-right:1px solid rgba(255,255,255,.05);transition:transform .3s ease,width .3s ease}.sidebar-brand{padding:22px 20px 18px;border-bottom:1px solid rgba(255,255,255,.06);display:flex;align-items:center;gap:10px}.sidebar-logo{width:34px;height:34px;border-radius:8px;background:linear-gradient(135deg,var(--accent) 0%,#8b5cf6 100%);display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0}.sidebar-brand-text{line-height:1.2}.sidebar-brand-name{font-size:13px;font-weight:700;color:#fff;letter-spacing:-.2px}.sidebar-brand-sub{font-size:11px;color:var(--sidebar-text-2)}.sidebar-nav{flex:1;padding:12px 10px;overflow-y:auto}.nav-section-label{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--sidebar-text-2);padding:14px 10px 6px}.nav-item{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:7px;font-size:13.5px;color:var(--sidebar-text-2);cursor:pointer;transition:background .15s,color .15s;margin-bottom:2px;-webkit-user-select:none;user-select:none;border:none;background:none;width:100%;text-align:left}.nav-item:hover:not(:disabled){background:var(--sidebar-2);color:var(--sidebar-text)}.nav-item.active{background:var(--sidebar-active);color:#fff}.nav-item .nav-icon{width:16px;flex-shrink:0;opacity:.7}.nav-item.active .nav-icon{opacity:1}.nav-item .nav-badge{margin-left:auto;background:var(--accent);color:#fff;font-size:10px;font-weight:700;padding:1px 6px;border-radius:99px}.sidebar-footer{padding:14px 10px;border-top:1px solid rgba(255,255,255,.06)}.store-key-pill{background:var(--sidebar-2);border-radius:7px;padding:8px 10px;font-size:11px;color:var(--sidebar-text-2)}.store-key-pill strong{display:block;color:var(--sidebar-text);font-size:12px;margin-bottom:2px}.store-key-mono{font-family:monospace;letter-spacing:.04em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.topbar{height:60px;background:var(--surface);border-bottom:1px solid var(--border);display:flex;align-items:center;padding:0 28px;gap:16px;flex-shrink:0}.topbar-title{font-size:15px;font-weight:600;letter-spacing:-.2px}.topbar-sub{font-size:12px;color:var(--text-2);margin-top:1px}.topbar-left{flex:1}.topbar-actions{display:flex;align-items:center;gap:10px}.live-indicator{display:flex;align-items:center;gap:7px;padding:5px 12px;border-radius:99px;background:#10b9811a;color:var(--green);font-size:12px;font-weight:600}.live-dot{width:7px;height:7px;border-radius:50%;background:var(--green);position:relative}.live-dot:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:50%;background:var(--green);animation:livePing 1.4s ease infinite}.logout-btn{background:none;border:1px solid var(--border);border-radius:7px;padding:6px 12px;font-size:12px;font-weight:500;color:var(--text-2);cursor:pointer;transition:all .15s}.logout-btn:hover{background:var(--red);border-color:var(--red);color:#fff}.login-screen{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#0f1117,#1a1d27,#0f1117);padding:20px}.login-card{background:#ffffff0a;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.1);border-radius:var(--radius-lg);padding:44px 40px;width:420px;max-width:100%;box-shadow:var(--shadow-lg);animation:fadeIn .4s ease}.login-logo{width:52px;height:52px;border-radius:13px;background:linear-gradient(135deg,var(--accent) 0%,#8b5cf6 100%);display:flex;align-items:center;justify-content:center;font-size:24px;margin-bottom:20px}.login-title{font-size:22px;font-weight:700;color:#fff;margin-bottom:6px}.login-sub{font-size:13.5px;color:#ffffff73;margin-bottom:28px;line-height:1.5}.login-label{display:block;font-size:12px;font-weight:600;color:#ffffff8c;margin-bottom:8px;text-transform:uppercase;letter-spacing:.06em}.field-label{display:block;font-size:11px;font-weight:700;color:var(--text-2);margin-bottom:6px;text-transform:uppercase;letter-spacing:.05em}.login-input{width:100%;background:#ffffff12;border:1px solid rgba(255,255,255,.12);border-radius:var(--radius);padding:11px 14px;font-size:14px;color:#fff;font-family:monospace;letter-spacing:.04em;outline:none;transition:border-color .2s,box-shadow .2s}.login-input::placeholder{color:#fff3;font-family:var(--font);letter-spacing:0}.login-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}.login-btn{width:100%;margin-top:18px;padding:12px;background:linear-gradient(135deg,var(--accent) 0%,#8b5cf6 100%);border:none;border-radius:var(--radius);font-size:14px;font-weight:600;color:#fff;cursor:pointer;transition:opacity .15s,transform .15s;letter-spacing:-.1px}.login-btn:hover:not(:disabled){opacity:.9;transform:translateY(-1px)}.login-btn:disabled{opacity:.5;cursor:not-allowed}.login-error{margin-top:12px;font-size:13px;color:#fca5a5;text-align:center}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden}.card-header{padding:18px 20px 14px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:10px}.card-title{font-size:14px;font-weight:600}.card-sub{font-size:12px;color:var(--text-2);margin-top:1px}.card-actions{margin-left:auto;display:flex;align-items:center;gap:8px}.stats-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:16px;margin-bottom:24px}.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:18px 20px;display:flex;align-items:flex-start;gap:14px}.stat-icon{width:38px;height:38px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:15px;flex-shrink:0}.stat-icon.indigo{background:#6366f11f;color:var(--accent)}.stat-icon.green{background:#10b9811f;color:var(--green)}.stat-icon.amber{background:#f59e0b1f;color:var(--amber)}.stat-value{font-size:24px;font-weight:700;letter-spacing:-.5px;line-height:1}.stat-label{font-size:12px;color:var(--text-2);margin-top:3px}.feed-list{padding:0}.feed-item{display:flex;align-items:center;gap:14px;padding:14px 20px;border-bottom:1px solid var(--border);transition:background .12s;cursor:pointer;animation:slideIn .2s ease both}.feed-item:last-child{border-bottom:none}.feed-item:hover{background:var(--surface-2)}.feed-avatar{width:44px;height:44px;border-radius:50%;object-fit:cover;flex-shrink:0;background:var(--surface-2)}.feed-avatar-placeholder{width:44px;height:44px;border-radius:50%;background:linear-gradient(135deg,var(--accent) 0%,#8b5cf6 100%);display:flex;align-items:center;justify-content:center;color:#fff;font-size:16px;font-weight:700;flex-shrink:0}.feed-info{flex:1;min-width:0}.feed-name{font-size:13.5px;font-weight:600;transition:color .15s;display:flex;align-items:center}.visit-badge{font-size:11px;font-weight:500;color:var(--text-3);margin-left:6px;background:var(--surface-2);padding:1px 6px;border-radius:4px}.new-badge{font-size:10px;font-weight:700;color:#fff;background:var(--green);padding:1px 6px;border-radius:4px;margin-left:6px;letter-spacing:.5px;box-shadow:0 0 10px #10b98133}.feed-item:hover .feed-name{color:var(--accent)}.feed-order{font-size:12px;color:var(--text-2);margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.feed-meta{text-align:right;flex-shrink:0}.feed-time{font-size:11.5px;color:var(--text-3)}.feed-conf{display:inline-flex;align-items:center;gap:4px;margin-top:3px}.conf-bar{height:4px;width:48px;background:var(--surface-2);border-radius:99px;overflow:hidden}.conf-fill{height:100%;border-radius:99px;background:linear-gradient(90deg,var(--accent),var(--green))}.conf-label{font-size:10px;color:var(--text-3)}.customer-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:16px;padding:20px}.customer-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;cursor:pointer;transition:box-shadow .15s,transform .15s,border-color .15s}.customer-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px);border-color:var(--accent-2)}.customer-card.selected{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}.customer-card-photo{width:100%;aspect-ratio:1;object-fit:cover;background:var(--surface-2)}.customer-card-photo-placeholder{width:100%;aspect-ratio:1;background:linear-gradient(135deg,#1a1d27,#2d2f3f);display:flex;align-items:center;justify-content:center;font-size:40px;color:#fff3}.customer-card-body{padding:12px 14px 14px}.customer-card-name{font-size:13.5px;font-weight:600;margin-bottom:3px}.customer-card-order{font-size:11.5px;color:var(--text-2);line-height:1.4;margin-bottom:8px;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.customer-card-stats{display:flex;gap:10px}.customer-stat{font-size:11px;color:var(--text-3);display:flex;align-items:center;gap:3px}.detail-layout{display:grid;grid-template-columns:1fr 380px;gap:20px}.detail-photo-wrap{border-radius:var(--radius-lg);overflow:hidden;background:var(--surface-2);aspect-ratio:3/4;max-height:380px}.detail-photo{width:100%;height:100%;object-fit:cover}.detail-photo-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:72px;color:var(--text-3)}.detail-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg)}.detail-section{padding:18px 20px;border-bottom:1px solid var(--border)}.detail-section:last-child{border-bottom:none}.detail-section-title{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--text-2);margin-bottom:12px}.detail-row{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:10px;gap:16px}.detail-row:last-child{margin-bottom:0}.detail-key{font-size:12.5px;color:var(--text-2);flex-shrink:0}.detail-value{font-size:12.5px;font-weight:500;text-align:right}.visit-row{display:flex;align-items:center;gap:10px;padding:8px 0;border-bottom:1px solid var(--border)}.visit-row:last-child{border-bottom:none}.visit-time{font-size:12px;color:var(--text-2);flex:1}.visit-conf{font-size:11.5px;font-weight:600;color:var(--accent)}.visit-match{width:8px;height:8px;border-radius:50%;background:var(--green);flex-shrink:0}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;color:var(--text-2);gap:10px}.empty-state .icon{font-size:36px;opacity:.3}.empty-state p{font-size:13.5px}.spinner{width:20px;height:20px;border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .7s linear infinite}.spinner-lg{width:32px;height:32px;border-width:3px}.loading-row{display:flex;align-items:center;gap:14px;padding:14px 20px;border-bottom:1px solid var(--border)}.skeleton{background:var(--surface-2);border-radius:4px;animation:pulse 1.5s ease infinite}.sk-circle{width:44px;height:44px;border-radius:50%;flex-shrink:0}.sk-lines{flex:1;display:flex;flex-direction:column;gap:6px}.sk-line{height:10px}.sk-line.w60{width:60%}.sk-line.w40{width:40%}.badge{display:inline-flex;align-items:center;gap:4px;padding:3px 8px;border-radius:99px;font-size:11px;font-weight:600}.badge.green{background:#10b9811f;color:var(--green)}.badge.indigo{background:#6366f11f;color:var(--accent)}.badge.amber{background:#f59e0b1f;color:var(--amber)}.two-col{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:20px}.full-col{display:grid;gap:20px}.live-indicator.idle{background:#9ca3af1f;color:var(--text-2)}.live-indicator.idle .live-dot,.live-indicator.idle .live-dot:after{background:var(--text-3)}.camera-layout{display:grid;grid-template-columns:minmax(0,1.35fr) minmax(340px,.95fr);gap:20px}.camera-controls{flex-wrap:wrap;justify-content:flex-end}.camera-toggle{display:inline-flex;align-items:center;gap:8px;font-size:12px;color:var(--text-2);padding:0 4px}.camera-select{background:var(--surface-2);border:1px solid var(--border);border-radius:7px;padding:9px 12px;font-size:13px;color:var(--text)}.camera-stage{position:relative;aspect-ratio:16 / 10;background:radial-gradient(circle at top right,rgba(99,102,241,.28),transparent 34%),linear-gradient(180deg,#0d1018,#161b26);overflow:hidden}.camera-video{width:100%;height:100%;object-fit:cover}.camera-empty{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;justify-content:center;align-items:center;gap:12px;color:#ffffffb8;text-align:center;padding:24px}.camera-empty .icon{font-size:40px}.camera-overlay{position:absolute;left:16px;right:16px;bottom:16px;display:flex;flex-wrap:wrap;gap:8px}.camera-chip{display:inline-flex;align-items:center;background:#0f1117c7;color:#fff;border:1px solid rgba(255,255,255,.12);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-radius:999px;padding:7px 12px;font-size:11.5px;font-weight:600}.camera-chip.muted{color:#ffffffbd}.camera-result{padding:20px}.camera-result-header{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:16px}.camera-person{display:flex;gap:14px;align-items:center;padding:14px;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface-2)}.camera-person-photo{width:72px;height:72px;border-radius:16px;flex-shrink:0}.camera-person-fallback{width:72px;height:72px;border-radius:16px;display:flex;align-items:center;justify-content:center;font-size:28px;background:linear-gradient(135deg,var(--accent) 0%,var(--accent-2) 100%);color:#fff}.camera-person-body{min-width:0}.camera-person-name{font-size:16px;font-weight:700;letter-spacing:-.02em}.camera-person-meta{font-size:12.5px;color:var(--text-2);margin-top:4px;line-height:1.45}.camera-error{margin-top:14px;padding:10px 12px;border-radius:10px;background:#ef444414;border:1px solid rgba(239,68,68,.16);color:#b91c1c;font-size:12.5px}.camera-frame-panel,.camera-json-wrap{padding:20px}.camera-frame-preview{width:100%;display:block;border-radius:14px;background:var(--surface-2);border:1px solid var(--border)}.camera-json{margin:0;padding:16px;border-radius:14px;background:#0f1117;color:#d4dae5;font-size:12px;line-height:1.55;overflow:auto;max-height:340px}.empty-state.compact{padding:28px 20px}.icon-btn{background:none;border:1px solid var(--border);border-radius:7px;padding:6px;width:32px;height:32px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .15s;color:var(--text-2)}.icon-btn:hover:not(:disabled){background:var(--surface-2);color:var(--text)}.icon-btn.spinning svg{animation:spin .7s linear infinite}.btn-primary{background:var(--accent);color:#fff;border:none;border-radius:7px;padding:10px 16px;font-size:13.5px;font-weight:600;cursor:pointer;transition:all .15s}.btn-primary:hover:not(:disabled){background:var(--accent-2);transform:translateY(-1px)}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-secondary{background:var(--surface-2);color:var(--text);border:1px solid var(--border);border-radius:7px;padding:10px 16px;font-size:13.5px;font-weight:500;cursor:pointer;transition:all .15s}.btn-secondary:hover:not(:disabled){background:var(--border)}.btn-danger{background:var(--red);color:#fff;border:none;border-radius:7px;padding:10px 16px;font-size:13.5px;font-weight:600;cursor:pointer;transition:all .15s}.btn-danger:hover:not(:disabled){filter:brightness(.96);transform:translateY(-1px)}.btn-danger:disabled{opacity:.5;cursor:not-allowed;transform:none}.edit-input{width:100%;background:var(--surface-2);border:1px solid var(--border);border-radius:6px;padding:6px 10px;font-size:13px;font-family:inherit;outline:none;transition:all .15s}.edit-input:focus{border-color:var(--accent);background:var(--surface);box-shadow:0 0 0 2px var(--accent-glow)}.detail-danger-card{border-color:#ef44442e;background:linear-gradient(180deg,#ef444408,#ef444403)}.detail-danger-title{color:var(--red)}.detail-danger-copy{font-size:12.5px;color:var(--text-2);line-height:1.6;margin-bottom:12px}.confirm-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#0f11177a;display:flex;align-items:center;justify-content:center;padding:20px;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.confirm-card{width:420px;max-width:100%;background:var(--surface);border-radius:16px;box-shadow:var(--shadow-lg);border:1px solid var(--border);padding:20px;display:flex;flex-direction:column;gap:12px}.confirm-title{font-size:18px;font-weight:700;letter-spacing:-.02em}.confirm-copy{font-size:13px;color:var(--text-2);line-height:1.6}.confirm-error{font-size:12.5px;color:var(--red)}.confirm-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:4px}.tabs{display:flex;gap:2px;background:var(--surface-2);border-radius:8px;padding:3px}.tab{padding:6px 16px;border-radius:6px;font-size:13px;font-weight:500;cursor:pointer;border:none;background:none;color:var(--text-2);transition:all .15s}.tab.active{background:var(--surface);color:var(--text);box-shadow:var(--shadow)}.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:16px}.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}@media (max-width: 1024px){.detail-layout{grid-template-columns:1fr}.stats-row{grid-template-columns:repeat(2,1fr)}.grid-4{grid-template-columns:1fr 1fr}.camera-layout{grid-template-columns:1fr}}@media (max-width: 768px){.app-shell{flex-direction:column}.sidebar{width:100%;min-width:0;height:auto;border-right:none;border-bottom:1px solid rgba(255,255,255,.06);position:relative;z-index:100}.sidebar:not(.mobile-open) .sidebar-brand{border-bottom:none}.sidebar-nav{display:none;padding:10px;max-height:60vh;overflow-y:auto}.sidebar-footer{display:none}.sidebar.mobile-open .sidebar-nav,.sidebar.mobile-open .sidebar-footer{display:block}.topbar{padding:0 16px;height:50px}.page-body{padding:20px 16px}.stats-row,.two-col,.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}.camera-controls{justify-content:flex-start}.camera-select{width:100%}.camera-overlay{left:12px;right:12px;bottom:12px}.camera-person{align-items:flex-start}.customer-grid{grid-template-columns:1fr 1fr;padding:16px;gap:12px}.card-header{padding:14px 16px;flex-direction:column;align-items:flex-start;gap:12px}.card-actions{width:100%;margin-left:0;overflow-x:auto;padding-bottom:4px;display:flex;flex-wrap:nowrap}.tabs{width:100%}.tab{flex:1;text-align:center;padding:6px 4px;font-size:12px}.mobile-nav-toggle{display:flex;background:none;border:none;color:#fff;font-size:20px;padding:10px;cursor:pointer;margin-left:auto}}@media (min-width: 769px){.mobile-nav-toggle{display:none}}@media (max-width: 480px){.customer-grid{grid-template-columns:1fr}.login-card{padding:32px 24px}.stat-card{padding:14px}.stat-value{font-size:20px}}
