*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}:root{--bg-primary: #0f1419;--bg-secondary: #1a2332;--bg-card: #1e2d3d;--bg-input: #152231;--border-color: #2a3f55;--border-focus: #38bdf8;--text-primary: #e8edf2;--text-secondary: #8899aa;--text-muted: #5a6d7e;--accent: #38bdf8;--accent-glow: rgba(56, 189, 248, .15);--approve-color: #22c55e;--approve-glow: rgba(34, 197, 94, .15);--reject-color: #ef4444;--reject-glow: rgba(239, 68, 68, .15);--warning-color: #f59e0b;--save-color: #a78bfa;--save-glow: rgba(167, 139, 250, .15);--radius: 12px;--radius-sm: 8px;--transition: .2s ease;--font: "Inter", -apple-system, BlinkMacSystemFont, sans-serif}html{font-size:14px}body{font-family:var(--font);background:var(--bg-primary);color:var(--text-primary);height:100vh;overflow:hidden}body:before{content:"";position:fixed;inset:0;background:radial-gradient(ellipse at 20% 20%,rgba(56,189,248,.04) 0%,transparent 50%),radial-gradient(ellipse at 80% 80%,rgba(167,139,250,.04) 0%,transparent 50%);pointer-events:none;z-index:0}#app{position:relative;z-index:1;max-width:1400px;margin:0 auto;padding:0 1rem;height:100vh;display:flex;flex-direction:column;overflow:hidden}.offline-banner{position:fixed;top:0;left:0;right:0;z-index:2000;background:linear-gradient(90deg,#b45309,#d97706);color:#fff;text-align:center;padding:.5rem 1rem;font-size:.85rem;font-weight:600;letter-spacing:.02em;animation:slideDown .3s ease}@keyframes slideDown{0%{transform:translateY(-100%)}to{transform:translateY(0)}}.auth-screen{position:fixed;inset:0;z-index:100;display:flex;align-items:center;justify-content:center;background:var(--bg-primary)}.auth-screen:before{content:"";position:absolute;inset:0;background:radial-gradient(ellipse at 30% 30%,rgba(56,189,248,.08) 0%,transparent 50%),radial-gradient(ellipse at 70% 70%,rgba(167,139,250,.08) 0%,transparent 50%);pointer-events:none}.auth-card{position:relative;background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius);padding:2.5rem;width:100%;max-width:400px;backdrop-filter:blur(12px);box-shadow:0 20px 60px #0006}.auth-title{font-size:1.8rem;font-weight:700;text-align:center;background:linear-gradient(135deg,var(--accent),#a78bfa);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:.4rem}.auth-subtitle{text-align:center;color:var(--text-secondary);font-size:.9rem;margin-bottom:1.5rem}.auth-field{margin-bottom:1rem}.auth-field label{display:block;font-size:.82rem;font-weight:500;color:var(--text-secondary);margin-bottom:.3rem}.auth-field input{width:100%;background:var(--bg-input);border:1px solid var(--border-color);color:var(--text-primary);padding:.6rem .8rem;border-radius:var(--radius-sm);font-family:var(--font);font-size:.9rem;transition:all var(--transition)}.auth-field input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}.btn-auth{width:100%;padding:.7rem;margin-top:.5rem;background:linear-gradient(135deg,var(--accent),#60a5fa);border:none;border-radius:var(--radius-sm);color:#fff;font-family:var(--font);font-size:.95rem;font-weight:600;cursor:pointer;transition:all var(--transition)}.btn-auth:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 20px #38bdf84d}.btn-auth:disabled{opacity:.6;cursor:not-allowed}.btn-auth-secondary{width:100%;padding:.5rem;margin-top:.5rem;background:transparent;border:1px solid var(--border-color);border-radius:var(--radius-sm);color:var(--text-secondary);font-family:var(--font);font-size:.82rem;cursor:pointer;transition:all var(--transition)}.btn-auth-secondary:hover{border-color:var(--accent);color:var(--accent)}.auth-error{margin-top:1rem;padding:.6rem .8rem;background:var(--reject-glow);border:1px solid rgba(239,68,68,.3);border-radius:var(--radius-sm);color:var(--reject-color);font-size:.85rem;text-align:center}#app-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 0;gap:1rem;flex-wrap:wrap;border-bottom:1px solid var(--border-color);margin-bottom:0}.header-left{display:flex;align-items:center;gap:.75rem}.header-left h1{font-size:1.3rem;font-weight:700;background:linear-gradient(135deg,var(--accent),#a78bfa);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;display:flex;align-items:center;gap:.5rem}.app-logo{width:28px;height:28px;border-radius:6px}.auth-logo{width:48px;height:48px;border-radius:10px;vertical-align:middle}.counter-badge{background:var(--bg-card);border:1px solid var(--border-color);padding:.25rem .75rem;border-radius:20px;font-size:.85rem;font-weight:600;color:var(--accent);letter-spacing:.02em}.view-toggle{display:flex;background:var(--bg-card);border:1px solid var(--border-color);border-radius:20px;overflow:hidden}.view-toggle-btn{background:none;border:none;color:var(--text-secondary);padding:.3rem .9rem;font-size:.82rem;font-weight:600;font-family:var(--font);cursor:pointer;transition:background var(--transition),color var(--transition)}.view-toggle-btn:hover{color:var(--text-primary)}.view-toggle-btn.active{background:var(--accent);color:#0f1419}.posts-only.hidden,.stories-only.hidden{display:none!important}.header-right{display:flex;align-items:center;gap:1rem;flex-wrap:wrap}.filter-group{display:flex;align-items:center;gap:.5rem;font-size:.85rem;color:var(--text-secondary)}.confidence-toggle{cursor:pointer;user-select:none;border-bottom:1px dashed var(--text-secondary);transition:color var(--transition)}.confidence-toggle:hover{color:var(--accent);border-bottom-color:var(--accent)}.filter-group select,.filter-group input[type=range]{accent-color:var(--accent)}.filter-group select{background:var(--bg-card);border:1px solid var(--border-color);color:var(--text-primary);padding:.35rem .5rem;border-radius:var(--radius-sm);font-family:var(--font);font-size:.85rem;cursor:pointer;transition:border-color var(--transition)}.filter-group select:focus,.filter-group input[type=text]:focus{outline:none;border-color:var(--accent)}.filter-group input[type=text]{background:var(--bg-card);border:1px solid var(--border-color);color:var(--text-primary);padding:.35rem .5rem;border-radius:var(--radius-sm);font-family:var(--font);font-size:.85rem;width:160px;transition:border-color var(--transition)}.filter-group input[type=text]::placeholder{color:var(--text-muted)}.filter-group input[type=range]{width:100px;cursor:pointer}#confidence-value{min-width:2.5rem;text-align:right;font-weight:600;color:var(--accent)}.btn-icon{background:var(--bg-card);border:1px solid var(--border-color);color:var(--text-primary);width:36px;height:36px;border-radius:var(--radius-sm);font-size:1.1rem;cursor:pointer;display:grid;place-items:center;transition:all var(--transition)}.btn-icon:hover{background:var(--accent);color:var(--bg-primary);border-color:var(--accent);transform:rotate(180deg)}.btn-logout-icon:hover{background:var(--reject-color);border-color:var(--reject-color);transform:none}#filter-bar{display:flex;align-items:center;gap:1rem;padding:.5rem 0;flex-wrap:wrap;border-bottom:1px solid var(--border-color);margin-bottom:.75rem}.search-wrapper{position:relative;display:inline-flex;align-items:center}.search-wrapper input[type=text]{padding-right:1.8rem}.search-clear{position:absolute;right:4px;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--text-muted);font-size:1rem;cursor:pointer;width:20px;height:20px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all var(--transition);padding:0}.search-clear:hover{color:var(--text-primary);background:var(--border-color)}.search-active input[type=text]{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-glow)}.collapsible-toggle{cursor:pointer;display:flex;align-items:center;gap:.35rem;user-select:none;transition:color var(--transition)}.collapsible-toggle:hover{color:var(--text-secondary)}.collapsible-toggle .chevron{display:inline-block;transition:transform .2s ease;font-size:.7rem}.collapsible:not(.collapsed) .collapsible-toggle .chevron{transform:rotate(90deg)}.collapsible.collapsed .text-content{display:none}.thumbnail-strip{display:flex;gap:4px;padding:6px 0;overflow-x:auto;overflow-y:hidden;flex-shrink:0;scroll-behavior:smooth;-webkit-overflow-scrolling:touch;margin-bottom:.5rem}.thumbnail-strip::-webkit-scrollbar{height:4px}.thumbnail-strip::-webkit-scrollbar-track{background:transparent}.thumbnail-strip::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:2px}.thumb-item{flex-shrink:0;width:48px;height:48px;border-radius:4px;overflow:hidden;cursor:pointer;border:2px solid transparent;transition:border-color var(--transition),opacity var(--transition);position:relative;background:var(--bg-secondary)}.thumb-item:hover{border-color:var(--text-muted)}.thumb-item.active{border-color:var(--accent);box-shadow:0 0 6px var(--accent-glow)}.thumb-item img{width:100%;height:100%;object-fit:cover;display:block}.thumb-item.status-approved{border-color:var(--approve-color)}.thumb-item.status-rejected{border-color:var(--reject-color)}.thumb-item.active.status-approved{box-shadow:0 0 6px var(--approve-glow)}.thumb-item.active.status-rejected{box-shadow:0 0 6px var(--reject-glow)}.thumb-video-icon{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:1.2rem;color:#fff;background:#00000059;pointer-events:none}.state-overlay{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;gap:1rem;color:var(--text-secondary);font-size:1rem}.hidden{display:none!important}.spinner{width:40px;height:40px;border:3px solid var(--border-color);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.empty-icon{font-size:3rem}#viewer{flex:1;min-height:0;display:flex;flex-direction:column;padding-bottom:.5rem}.viewer-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem;transition:box-shadow .4s ease;flex:1;min-height:0;grid-template-rows:1fr}.viewer-grid.status-approved{box-shadow:0 0 0 2px var(--approve-color),0 0 30px var(--approve-glow);border-radius:var(--radius)}.viewer-grid.status-rejected{box-shadow:0 0 0 2px var(--reject-color),0 0 30px var(--reject-glow);border-radius:var(--radius)}.panel{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius);overflow:hidden;backdrop-filter:blur(8px)}.media-panel{display:flex;flex-direction:column;position:relative;min-height:0;overflow:hidden}.panel-header{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;background:linear-gradient(135deg,#1a3a4a,#1e2d3d);border-bottom:1px solid var(--border-color)}.username-tag{font-weight:600;color:var(--accent);font-size:.95rem}.nama-tag{color:var(--text-secondary);font-size:.85rem}.media-container{flex:1;display:flex;align-items:center;justify-content:center;background:#0a1520;overflow:hidden;position:relative;min-height:0}.media-container img,.media-container video{max-width:100%;max-height:100%;object-fit:contain}.media-container img{transition:transform .3s ease}.media-container img:hover{transform:scale(1.02)}.media-loading{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:#0a1520b3;z-index:2}.media-error{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.5rem;color:var(--text-muted);padding:2rem}.media-error .error-icon{font-size:3rem;opacity:.5}.media-error p{font-size:.9rem}.media-type-badge{position:absolute;bottom:12px;right:12px;background:#000000b3;backdrop-filter:blur(6px);padding:.25rem .6rem;border-radius:6px;font-size:.75rem;font-weight:600;color:var(--accent);text-transform:uppercase;letter-spacing:.05em;border:1px solid rgba(56,189,248,.2)}.carousel-indicator{padding:.4rem 1rem;background:#f59e0b1a;border-top:1px solid rgba(245,158,11,.2);color:var(--warning-color);font-size:.8rem;font-weight:500;text-align:center}.info-panel{display:flex;flex-direction:column;gap:0;min-height:0;overflow-y:auto}.info-panel::-webkit-scrollbar{width:6px}.info-panel::-webkit-scrollbar-track{background:transparent}.info-panel::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:3px}.dirty-indicator{padding:.4rem 1rem;background:#f59e0b1f;border-bottom:1px solid rgba(245,158,11,.2);color:var(--warning-color);font-size:.8rem;font-weight:600;text-align:center;animation:pulse-dirty 2s ease-in-out infinite}@keyframes pulse-dirty{0%,to{opacity:1}50%{opacity:.6}}.info-block{padding:.75rem 1rem;border-bottom:1px solid var(--border-color)}.info-block h3{font-size:.8rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;margin-bottom:.4rem}.text-content{font-size:.9rem;line-height:1.5;color:var(--text-secondary);white-space:pre-wrap;word-break:break-word}.scrollable{max-height:120px;overflow-y:auto;padding-right:.25rem}.scrollable::-webkit-scrollbar{width:4px}.scrollable::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:2px}.confidence-bar-wrapper{display:flex;align-items:center;gap:.75rem}.confidence-bar{flex:1;height:8px;background:var(--bg-input);border-radius:4px;overflow:hidden}.confidence-fill{height:100%;border-radius:4px;transition:width .5s cubic-bezier(.22,1,.36,1),background .3s ease}.confidence-fill.high{background:linear-gradient(90deg,#22c55e,#4ade80);box-shadow:0 0 8px #22c55e4d}.confidence-fill.medium{background:linear-gradient(90deg,#f59e0b,#fbbf24);box-shadow:0 0 8px #f59e0b4d}.confidence-fill.low{background:linear-gradient(90deg,#ef4444,#f87171);box-shadow:0 0 8px #ef44444d}.confidence-label{font-weight:700;font-size:.9rem;min-width:3rem;text-align:right}.is-event-row{display:flex;align-items:center;gap:.5rem;margin-top:.4rem;font-size:.85rem;color:var(--text-secondary)}.event-badge{padding:.15rem .5rem;border-radius:4px;font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em}.event-badge.is-yes{background:var(--approve-glow);color:var(--approve-color);border:1px solid rgba(34,197,94,.3)}.event-badge.is-no{background:#64748b26;color:var(--text-muted);border:1px solid rgba(100,116,139,.2)}.editable-fields{flex:1}.field-grid{display:flex;flex-direction:column;gap:.4rem}.field-row{display:grid;grid-template-columns:140px 1fr;align-items:center;gap:.5rem}.field-row label{font-size:.82rem;color:var(--text-secondary);font-weight:500}.field-row input{background:var(--bg-input);border:1px solid var(--border-color);color:var(--text-primary);padding:.4rem .6rem;border-radius:var(--radius-sm);font-family:var(--font);font-size:.85rem;transition:all var(--transition)}.field-row input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}.field-row input::placeholder{color:var(--text-muted)}.action-bar{display:flex;flex-direction:column;gap:1rem;padding:1rem 1.25rem 1.25rem;border-top:1px solid var(--border-color);margin-top:auto}.action-bar-primary{display:flex;align-items:center;justify-content:center;gap:.75rem}.action-bar-secondary{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding-top:.75rem;border-top:1px solid var(--border-color)}.pagination-controls{display:flex;align-items:center;gap:.5rem;margin-left:auto}.page-indicator{font-size:.78rem;color:var(--text-secondary);font-weight:500;min-width:80px;text-align:center}.btn-page{background:var(--bg-secondary);border:1px solid var(--border-color);color:var(--text-secondary);padding:.3rem .65rem;border-radius:var(--radius-sm);font-family:var(--font);font-size:.72rem;font-weight:500;cursor:pointer;transition:all var(--transition)}.btn-page:hover:not(:disabled){background:var(--accent);color:var(--bg-primary);border-color:var(--accent)}.btn-page:disabled{opacity:.35;cursor:not-allowed}.bulk-actions{display:flex;align-items:center;gap:.5rem}.btn-bulk{padding:.3rem .7rem;border:1px solid;border-radius:var(--radius-sm);font-family:var(--font);font-size:.72rem;font-weight:600;cursor:pointer;transition:all var(--transition);text-transform:uppercase;letter-spacing:.03em}.btn-bulk:disabled{opacity:.4;cursor:not-allowed}.btn-bulk-approve{background:#22c55e14;border-color:#22c55e40;color:var(--approve-color)}.btn-bulk-approve:hover:not(:disabled){background:#22c55e33}.btn-bulk-reject{background:#ef444414;border-color:#ef444440;color:var(--reject-color)}.btn-bulk-reject:hover:not(:disabled){background:#ef444433}.bulk-progress{font-size:.72rem;color:var(--text-secondary);font-weight:500}.btn-nav{background:var(--bg-secondary);border:1px solid var(--border-color);color:var(--text-primary);width:44px;height:44px;border-radius:var(--radius-sm);font-size:1rem;cursor:pointer;display:grid;place-items:center;transition:all var(--transition)}.btn-nav:hover{background:var(--accent);color:var(--bg-primary);border-color:var(--accent);transform:scale(1.05)}.btn-action{padding:.6rem 1.4rem;border:1px solid;border-radius:var(--radius-sm);font-family:var(--font);font-size:.9rem;font-weight:600;cursor:pointer;transition:all var(--transition);letter-spacing:.02em;position:relative}.btn-action:disabled{opacity:.5;cursor:not-allowed;transform:none!important}.btn-action.btn-loading:after{content:"";position:absolute;top:50%;right:8px;width:14px;height:14px;margin-top:-7px;border:2px solid currentColor;border-top-color:transparent;border-radius:50%;animation:spin .6s linear infinite}.btn-approve{background:#22c55e1a;border-color:#22c55e4d;color:var(--approve-color)}.btn-approve:hover:not(:disabled){background:var(--approve-color);color:#fff;box-shadow:0 0 20px var(--approve-glow);transform:translateY(-1px)}.btn-reject{background:#ef44441a;border-color:#ef44444d;color:var(--reject-color)}.btn-reject:hover:not(:disabled){background:var(--reject-color);color:#fff;box-shadow:0 0 20px var(--reject-glow);transform:translateY(-1px)}.btn-save{background:#a78bfa1a;border-color:#a78bfa4d;color:var(--save-color)}.btn-save:hover:not(:disabled){background:var(--save-color);color:#fff;box-shadow:0 0 20px var(--save-glow);transform:translateY(-1px)}.modal-overlay{position:fixed;inset:0;z-index:500;display:flex;align-items:center;justify-content:center;background:#0009;backdrop-filter:blur(4px);animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius);padding:1.5rem 2rem;width:100%;max-width:380px;box-shadow:0 20px 60px #00000080}.modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.2rem}.modal-header h2{font-size:1.1rem;font-weight:700;color:var(--text-primary)}.btn-close-modal{background:transparent;border:1px solid var(--border-color);color:var(--text-secondary);width:30px;height:30px;border-radius:6px;font-size:.9rem;cursor:pointer;display:grid;place-items:center;transition:all var(--transition)}.btn-close-modal:hover{background:var(--reject-color);color:#fff;border-color:var(--reject-color)}.shortcuts-grid{display:flex;flex-direction:column;gap:.6rem}.shortcut-item{display:flex;align-items:center;gap:.75rem;font-size:.9rem;color:var(--text-secondary)}.shortcut-item kbd{display:inline-flex;align-items:center;justify-content:center;min-width:36px;height:28px;padding:0 .5rem;background:var(--bg-input);border:1px solid var(--border-color);border-radius:5px;font-family:var(--font);font-size:.8rem;font-weight:600;color:var(--accent);box-shadow:0 2px 0 var(--border-color)}#toast-container{position:fixed;bottom:1.5rem;right:1.5rem;display:flex;flex-direction:column;gap:.5rem;z-index:1000}.toast{padding:.75rem 1.25rem;border-radius:var(--radius-sm);font-size:.9rem;font-weight:500;backdrop-filter:blur(12px);transform:translate(120%);opacity:0;transition:all .3s cubic-bezier(.22,1,.36,1);max-width:350px;border:1px solid}.toast.show{transform:translate(0);opacity:1}.toast-success{background:#22c55e26;color:var(--approve-color);border-color:#22c55e4d}.toast-error{background:#ef444426;color:var(--reject-color);border-color:#ef44444d}.toast-warning{background:#f59e0b26;color:var(--warning-color);border-color:#f59e0b4d}.toast-info{background:#38bdf826;color:var(--accent);border-color:#38bdf84d}@media(max-width:900px){body{height:auto;overflow:auto}#app{height:auto;overflow:visible}.viewer-grid{grid-template-columns:1fr;grid-template-rows:auto auto}.media-container{min-height:250px;max-height:350px}#app-header{flex-direction:column;align-items:flex-start}.header-right{width:100%}#filter-bar{gap:.5rem}.field-row{grid-template-columns:120px 1fr}}@media(max-width:500px){html{font-size:13px}.action-bar-secondary{flex-direction:column;align-items:stretch}.action-bar-primary{flex-wrap:wrap}.pagination-controls{justify-content:center;margin-left:0}.bulk-actions{justify-content:center}.btn-action{flex:1;min-width:80px}.auth-card{margin:1rem}}
