:root{--primary: #2563eb;--primary-dark: #1d4ed8;--secondary: #64748b;--success: #10b981;--danger: #ef4444;--warning: #f59e0b;--bg-primary: #ffffff;--bg-secondary: #f8fafc;--bg-tertiary: #f1f5f9;--text-primary: #0f172a;--text-secondary: #475569;--border: #e2e8f0;--shadow: 0 1px 3px rgba(0, 0, 0, .1);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1)}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;background:var(--bg-secondary);color:var(--text-primary);line-height:1.6;overflow-x:hidden}#app{min-height:100vh}.auth-container{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:20px;background:linear-gradient(135deg,#667eea,#764ba2)}.auth-card{background:var(--bg-primary);padding:40px;border-radius:16px;box-shadow:var(--shadow-lg);width:100%;max-width:440px}.auth-title{font-size:32px;font-weight:700;margin-bottom:8px;text-align:center;color:var(--text-primary)}.auth-subtitle{text-align:center;color:var(--text-secondary);margin-bottom:32px;font-size:16px}.auth-form{display:flex;flex-direction:column;gap:20px}.form-group{display:flex;flex-direction:column;gap:8px}.form-group label{font-weight:500;color:var(--text-primary);font-size:14px}.form-group input,.form-group select,.form-group textarea{padding:12px 16px;border:1px solid var(--border);border-radius:8px;font-size:15px;transition:all .2s}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #2563eb1a}.btn-primary,.btn-secondary{padding:12px 24px;border:none;border-radius:8px;font-size:15px;font-weight:600;cursor:pointer;transition:all .2s}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover{background:var(--primary-dark);transform:translateY(-1px);box-shadow:var(--shadow)}.btn-secondary{background:var(--bg-tertiary);color:var(--text-primary)}.btn-secondary:hover{background:var(--border)}.error-message{color:var(--danger);font-size:14px;min-height:20px}.auth-toggle{text-align:center;margin-top:24px;color:var(--text-secondary)}.link-button{background:none;border:none;color:var(--primary);cursor:pointer;font-weight:600;text-decoration:underline}.dashboard{display:flex;flex-direction:column;min-height:100vh}.dashboard-header{background:#fff;border-bottom:1px solid var(--border);box-shadow:var(--shadow);position:sticky;top:0;z-index:200}.header-content{max-width:1400px;margin:0 auto;padding:14px 24px;display:flex;justify-content:space-between;align-items:center;gap:12px}.header-left{display:flex;align-items:center;gap:12px;flex-shrink:0}.header-content h1{font-size:20px;font-weight:700;color:var(--text-primary);white-space:nowrap}.btn-sidebar-toggle{display:none;flex-direction:column;justify-content:center;align-items:center;gap:5px;width:40px;height:40px;background:var(--bg-tertiary);border:1px solid var(--border);border-radius:8px;cursor:pointer;flex-shrink:0;padding:0}.btn-sidebar-toggle span{display:block;width:18px;height:2px;background:var(--text-primary);border-radius:2px;transition:all .2s}.btn-sidebar-toggle:hover{background:var(--border)}.user-info{display:flex;align-items:center;gap:12px;flex-wrap:wrap;justify-content:flex-end}.user-identity,.header-actions{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.user-name{font-weight:600;color:var(--text-primary);font-size:14px}.user-role{padding:3px 10px;border-radius:20px;font-size:11px;font-weight:600;text-transform:uppercase}.user-role.admin{background:#dbeafe;color:#1e40af}.user-role.manager{background:#d1fae5;color:#065f46}.user-role.member{background:#f1f5f9;color:#475569}.user-score{font-weight:600;color:var(--warning);font-size:14px}.btn-icon{font-size:14px}.btn-logout-icon{width:16px;height:16px;object-fit:contain}.dashboard-body{display:grid;grid-template-columns:280px 1fr;max-width:1400px;margin:0 auto;width:100%;flex:1;position:relative}.sidebar-overlay{display:block;position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;z-index:150;opacity:0;pointer-events:none;transition:opacity .25s}.sidebar-overlay--visible{opacity:1;pointer-events:auto}.sidebar{background:#fff;border-right:1px solid var(--border);padding:20px;overflow-y:auto;height:calc(100vh - 61px);position:sticky;top:61px}.sidebar-header{display:none;justify-content:space-between;align-items:center;margin-bottom:20px}.sidebar-title{font-size:16px;font-weight:700;color:var(--text-primary)}.btn-sidebar-close{background:var(--bg-tertiary);border:none;border-radius:6px;width:32px;height:32px;cursor:pointer;font-size:14px;color:var(--text-secondary);display:flex;align-items:center;justify-content:center;transition:all .2s}.btn-sidebar-close:hover{background:var(--border);color:var(--text-primary)}.sidebar-section-label{font-size:11px;font-weight:700;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.6px;margin-bottom:12px}.category-list{list-style:none}.category-item{display:flex;align-items:center;gap:12px;padding:11px 14px;border-radius:8px;cursor:pointer;transition:all .2s;margin-bottom:3px;font-size:14px}.category-item:hover{background:var(--bg-tertiary)}.category-item.active{background:var(--primary);color:#fff}.category-icon{font-size:18px;flex-shrink:0}.main-content{padding:28px;min-width:0}.content-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px;gap:12px}.content-header h2{font-size:24px;font-weight:700}.task-form-container{margin-bottom:32px}.task-form-card{background:#fff;padding:24px;border-radius:12px;box-shadow:var(--shadow);margin-bottom:24px}.task-form-card h3{margin-bottom:24px;font-size:20px}.task-form{display:flex;flex-direction:column;gap:20px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:20px}.form-actions{display:flex;gap:12px;justify-content:flex-end;margin-top:8px}.task-section{margin-bottom:40px}.task-section-title{font-size:18px;font-weight:600;margin-bottom:16px;color:var(--text-secondary)}.task-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:16px}.task-card{background:#fff;padding:20px;border-radius:12px;box-shadow:var(--shadow);transition:all .2s;border:1px solid var(--border)}.task-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}.task-card.task-completed{background:#f0fdf4;border-color:#86efac;opacity:.85}.task-card.task-completed:hover{transform:none}.task-header{display:flex;justify-content:space-between;align-items:start;margin-bottom:12px}.task-name{font-size:16px;font-weight:600;color:var(--text-primary);flex:1}.task-points{background:#fef3c7;color:#92400e;padding:4px 8px;border-radius:6px;font-size:12px;font-weight:700}.task-description{color:var(--text-secondary);font-size:14px;margin-bottom:12px;line-height:1.5}.completion-notice{background:#dcfce7;color:#166534;padding:10px 14px;border-radius:8px;font-size:13px;font-weight:600;margin-bottom:12px;display:flex;align-items:center;gap:6px}.task-footer{display:flex;justify-content:space-between;align-items:center;margin-top:16px;padding-top:16px;border-top:1px solid var(--border)}.task-category{font-size:12px;color:var(--text-secondary);font-weight:500}.task-actions{display:flex;gap:8px}.btn-complete,.btn-delete,.btn-visibility,.btn-edit{padding:6px 12px;border:none;border-radius:6px;font-size:13px;font-weight:600;cursor:pointer;transition:all .2s}.btn-complete{background:var(--success);color:#fff}.btn-complete:hover{background:#059669;transform:translateY(-1px)}.btn-complete.btn-disabled{background:#d1d5db;color:#6b7280;cursor:not-allowed;opacity:.6}.btn-complete.btn-disabled:hover{background:#d1d5db;transform:none}.btn-visibility{background:var(--secondary);color:#fff;padding:6px 10px}.btn-visibility:hover{background:#475569}.btn-edit{background:var(--primary);color:#fff;padding:6px 10px}.btn-edit:hover{background:var(--primary-dark)}.btn-delete{background:var(--danger);color:#fff;padding:6px 10px}.btn-delete:hover{background:#dc2626}.task-hidden{opacity:.6;border:1px dashed var(--border)}.visibility-badge{display:inline-block;font-size:11px;font-weight:600;background:#fee2e2;color:#991b1b;padding:2px 8px;border-radius:4px;margin-left:8px}.leaderboard{display:flex;flex-direction:column;gap:8px}.leaderboard-item{display:flex;align-items:center;gap:12px;padding:12px;background:var(--bg-tertiary);border-radius:8px}.rank{font-weight:700;color:var(--primary);font-size:16px;width:24px}.member-name{flex:1;font-weight:500;font-size:14px}.score{font-weight:700;color:var(--warning);font-size:14px}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.modal-content{background:#fff;border-radius:16px;box-shadow:var(--shadow-lg);width:100%;max-width:600px;max-height:90vh;overflow-y:auto}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:24px 24px 16px;border-bottom:1px solid var(--border)}.modal-header h2{font-size:24px;font-weight:700;color:var(--text-primary)}.modal-close{background:none;border:none;font-size:32px;color:var(--text-secondary);cursor:pointer;line-height:1;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s}.modal-close:hover{background:var(--bg-tertiary);color:var(--text-primary)}.modal-content .auth-form{padding:24px}.modal-actions{display:flex;gap:12px;justify-content:flex-end;margin-top:24px}.category-progress-section{margin-bottom:32px}.category-progress-title{font-size:14px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:16px}.category-progress-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:12px}.progress-card{background:#fff;border:1px solid var(--border);border-radius:12px;padding:16px;box-shadow:var(--shadow);transition:box-shadow .2s,transform .2s,border-color .2s}.progress-card:hover{box-shadow:var(--shadow-lg)}.progress-card--clickable{cursor:pointer}.progress-card--clickable:hover{border-color:var(--primary);transform:translateY(-2px);box-shadow:0 6px 20px #0000001f}.progress-card--clickable:active{transform:translateY(0);box-shadow:var(--shadow)}.scroll-to-top-btn{position:fixed;bottom:24px;right:24px;width:44px;height:44px;border-radius:50%;background:var(--primary);color:#fff;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 14px #0003;z-index:99999;opacity:0;visibility:hidden;transform:translateY(8px);transition:opacity .25s ease,visibility .25s ease,transform .25s ease,background .2s}.scroll-to-top-btn--visible{opacity:1;visibility:visible;transform:translateY(0)}.scroll-to-top-btn:hover{background:var(--primary-dark, #1d4ed8);box-shadow:0 6px 20px #00000040}.scroll-to-top-btn:active{transform:scale(.94)}.progress-card--complete{border-color:#86efac;background:#f0fdf4}.progress-card-header{display:flex;align-items:center;gap:10px;margin-bottom:12px}.progress-card-icon{font-size:20px;flex-shrink:0}.progress-card-info{display:flex;flex-direction:column;flex:1;min-width:0}.progress-card-name{font-size:14px;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.progress-card-fraction{font-size:12px;color:var(--text-secondary);margin-top:1px}.progress-card-pct{font-size:15px;font-weight:700;color:var(--primary);flex-shrink:0}.progress-card-pct--complete{color:var(--success)}.progress-track{height:8px;background:var(--bg-tertiary);border-radius:999px;overflow:hidden}.progress-fill{height:100%;background:var(--primary);border-radius:999px;transition:width .6s ease}.progress-fill--complete{background:var(--success)}.btn-report{padding:8px 18px;border:1.5px solid var(--primary);border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;background:transparent;color:var(--primary);transition:all .2s}.btn-report:hover,.btn-report--active{background:var(--primary);color:#fff}.task-section-cooldown{opacity:.65}.task-section-title--cooldown{color:var(--secondary);font-style:italic}.task-card--cooldown{background:var(--bg-tertiary);border:1px dashed var(--border)}.cooldown-badge{display:inline-block;font-size:11px;font-weight:600;background:#fef3c7;color:#92400e;padding:2px 8px;border-radius:4px;margin-left:8px}.cooldown-badge--done{background:#dcfce7;color:#166534}.cooldown-info{padding:8px 12px;background:#f8fafc;border-radius:6px;margin-bottom:12px;font-size:13px;color:var(--text-secondary)}.cooldown-text strong{color:var(--text-primary)}.report-view{max-width:100%}.report-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.report-title{font-size:28px;font-weight:700}.btn-export{padding:10px 20px;background:var(--success);color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s}.btn-export:hover{background:#059669;transform:translateY(-1px)}.report-filters{display:flex;flex-wrap:wrap;gap:16px;align-items:flex-end;background:#fff;padding:20px;border-radius:12px;border:1px solid var(--border);margin-bottom:24px;box-shadow:var(--shadow)}.filter-group{display:flex;flex-direction:column;gap:6px;min-width:160px}.filter-group label{font-size:12px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.4px}.filter-group input,.filter-group select{padding:9px 12px;border:1px solid var(--border);border-radius:8px;font-size:14px;background:var(--bg-secondary);color:var(--text-primary);transition:border-color .2s}.filter-group input:focus,.filter-group select:focus{outline:none;border-color:var(--primary)}.filter-group--btn{justify-content:flex-end;min-width:unset}.summary-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px;margin-bottom:24px}.summary-card{background:#fff;border:1px solid var(--border);border-radius:12px;padding:20px;box-shadow:var(--shadow);text-align:center}.summary-card--highlight{background:#eff6ff;border-color:#bfdbfe}.summary-value{font-size:28px;font-weight:700;color:var(--primary);line-height:1.2;margin-bottom:6px}.summary-label{font-size:13px;color:var(--text-secondary);font-weight:500}.member-breakdown{background:#fff;border:1px solid var(--border);border-radius:12px;padding:20px;margin-bottom:24px;box-shadow:var(--shadow)}.breakdown-title{font-size:14px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.4px;margin-bottom:16px}.breakdown-grid{display:flex;flex-wrap:wrap;gap:12px}.breakdown-card{display:flex;align-items:center;gap:16px;padding:12px 16px;background:var(--bg-tertiary);border-radius:8px;min-width:220px}.breakdown-name{font-weight:600;font-size:14px;flex:1}.breakdown-stats{display:flex;flex-direction:column;align-items:flex-end;gap:2px}.breakdown-count{font-size:12px;color:var(--text-secondary)}.breakdown-points{font-size:13px;font-weight:700;color:var(--warning)}.report-day-group{margin-bottom:32px}.report-day-header{display:flex;justify-content:space-between;align-items:center;padding:10px 16px;background:var(--bg-tertiary);border-radius:8px 8px 0 0;border:1px solid var(--border);border-bottom:none}.report-day-date{font-weight:700;font-size:15px;color:var(--text-primary)}.report-day-stats{font-size:13px;color:var(--text-secondary);font-weight:500}.report-table{width:100%;border-collapse:collapse;border:1px solid var(--border);border-radius:0 0 8px 8px;overflow:hidden;background:#fff;box-shadow:var(--shadow)}.report-table th{padding:12px 14px;text-align:left;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.4px;color:var(--text-secondary);background:#fff;border-bottom:1px solid var(--border)}.report-table td{padding:12px 14px;font-size:14px;color:var(--text-primary);border-bottom:1px solid var(--bg-tertiary)}.report-table tr:last-child td{border-bottom:none}.report-table tr:hover td{background:var(--bg-secondary)}.report-cell-time{color:var(--text-secondary);font-size:13px;white-space:nowrap}.report-cell-task{font-weight:600}.report-cell-points{font-weight:700;color:var(--warning);text-align:center}.freq-badge{display:inline-block;padding:3px 8px;border-radius:4px;font-size:11px;font-weight:600}.freq-daily{background:#dbeafe;color:#1e40af}.freq-weekly{background:#dcfce7;color:#166534}.freq-biweekly{background:#fef9c3;color:#854d0e}.freq-oneoff{background:#fee2e2;color:#991b1b}.report-loading,.report-empty,.report-error{text-align:center;padding:48px 24px;color:var(--text-secondary);font-size:15px}.report-error{color:var(--danger)}.btn-stock-nav{padding:8px 16px;border:none;border-radius:8px;font-size:13px;font-weight:700;cursor:pointer;background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff;transition:all .2s;white-space:nowrap;box-shadow:0 2px 4px #d977064d;letter-spacing:.2px}.btn-stock-nav:hover{background:linear-gradient(135deg,#d97706,#b45309);transform:translateY(-1px);box-shadow:0 4px 8px #d9770666}.stock-report-modal{max-width:480px}.stock-report-header{background:linear-gradient(135deg,#fffbeb,#fef3c7);border-radius:16px 16px 0 0}.stock-report-header-left{display:flex;align-items:center;gap:12px}.stock-report-icon{font-size:28px}.stock-report-body{padding:24px;display:flex;flex-direction:column;gap:20px}.autocomplete-wrapper{position:relative}.autocomplete-wrapper input{width:100%;padding:12px 16px;border:1px solid var(--border);border-radius:8px;font-size:15px;transition:all .2s}.autocomplete-wrapper input:focus{outline:none;border-color:#f59e0b;box-shadow:0 0 0 3px #f59e0b26}.autocomplete-dropdown{position:absolute;top:calc(100% + 4px);left:0;right:0;background:#fff;border:1px solid var(--border);border-radius:8px;box-shadow:var(--shadow-lg);list-style:none;z-index:1100;max-height:200px;overflow-y:auto;display:none}.autocomplete-item{padding:10px 16px;cursor:pointer;font-size:14px;color:var(--text-primary);text-transform:capitalize;transition:background .15s}.autocomplete-item:hover{background:#fef9c3}.stock-duplicate-warning{background:#fee2e2;color:#991b1b;border:1px solid #fecaca;border-radius:8px;padding:10px 14px;font-size:13px;font-weight:600;margin-top:8px}.stock-success-msg{background:#dcfce7;color:#166534;border:1px solid #86efac;border-radius:8px;padding:12px 16px;font-size:14px;font-weight:600;text-align:center}.btn-stock-report{padding:12px 24px;border:none;border-radius:8px;font-size:15px;font-weight:700;cursor:pointer;background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff;transition:all .2s}.btn-stock-report:hover:not(:disabled){background:linear-gradient(135deg,#d97706,#b45309);transform:translateY(-1px)}.btn-stock-report:disabled,.btn-stock-report.btn-disabled{background:#d1d5db;color:#6b7280;cursor:not-allowed;transform:none}.stock-badge{display:inline-block;padding:3px 10px;border-radius:20px;font-size:12px;font-weight:700;white-space:nowrap}.stock-badge--low20{background:#fef9c3;color:#854d0e}.stock-badge--low10{background:#fed7aa;color:#9a3412}.stock-badge--empty{background:#fee2e2;color:#991b1b}.stock-admin-panel{max-width:100%}.stock-admin-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px;flex-wrap:wrap;gap:16px}.stock-admin-title{font-size:28px;font-weight:700}.stock-admin-tabs{display:flex;gap:8px;background:var(--bg-tertiary);padding:4px;border-radius:10px}.stock-tab-btn{padding:8px 20px;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;background:transparent;color:var(--text-secondary);transition:all .2s;display:flex;align-items:center;gap:8px}.stock-tab-btn:hover{color:var(--text-primary);background:#fff}.stock-tab-btn--active{background:#fff;color:var(--text-primary);box-shadow:var(--shadow)}.stock-pending-badge{background:#ef4444;color:#fff;font-size:11px;font-weight:700;width:20px;height:20px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center}.stock-tab-content{animation:fadeIn .2s ease}.stock-tab-content.hidden{display:none}@keyframes fadeIn{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.pending-reports-list{display:flex;flex-direction:column;gap:16px}.pending-card{background:#fff;border-radius:12px;border:1px solid var(--border);border-left:4px solid var(--border);box-shadow:var(--shadow);overflow:hidden;transition:box-shadow .2s}.pending-card:hover{box-shadow:var(--shadow-lg)}.pending-card--low20{border-left-color:#f59e0b}.pending-card--low10{border-left-color:#f97316}.pending-card--empty{border-left-color:#ef4444}.pending-card-header{padding:16px 20px;display:flex;justify-content:space-between;align-items:flex-start;gap:16px;flex-wrap:wrap}.pending-card-info{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.pending-item-name{font-size:17px;font-weight:700;color:var(--text-primary);text-transform:capitalize}.pending-card-meta{display:flex;flex-direction:column;align-items:flex-end;gap:2px}.pending-reporter{font-size:13px;color:var(--text-secondary)}.pending-time{font-size:12px;color:var(--text-secondary)}.pending-card-footer{padding:0 20px 16px}.btn-sudah-beli{padding:8px 20px;background:var(--success);color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s}.btn-sudah-beli:hover{background:#059669;transform:translateY(-1px)}.purchase-form-container{background:var(--bg-secondary);border-top:1px solid var(--border);padding:16px 20px;animation:slideDown .2s ease}@keyframes slideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.purchase-form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px}.purchase-form-actions{display:flex;gap:10px;justify-content:flex-end}.btn-confirm-purchase{padding:8px 20px;font-size:14px;font-weight:600}.btn-cancel-purchase{padding:8px 16px;font-size:14px}@media (max-width: 480px){.purchase-form-container{padding:12px 14px}.purchase-form-row{grid-template-columns:1fr;gap:12px;margin-bottom:12px}.purchase-form-actions{flex-direction:column-reverse;gap:8px}.btn-confirm-purchase,.btn-cancel-purchase{width:100%;text-align:center;padding:12px 16px;font-size:15px}}.stock-empty-state{text-align:center;padding:64px 24px;color:var(--text-secondary)}.stock-empty-icon{font-size:48px;margin-bottom:16px}.stock-empty-state p{font-size:15px}.stock-loading{text-align:center;padding:48px 24px;color:var(--text-secondary);font-size:15px}.stock-error{text-align:center;padding:48px 24px;color:var(--danger);font-size:15px}.stock-history-filters{display:flex;flex-wrap:wrap;gap:16px;align-items:flex-end;background:#fff;padding:20px;border-radius:12px;border:1px solid var(--border);margin-bottom:24px;box-shadow:var(--shadow)}.stock-history-table-wrapper{overflow-x:auto;border-radius:12px;box-shadow:var(--shadow);border:1px solid var(--border)}.stock-history-table{width:100%;border-collapse:collapse;background:#fff;min-width:800px}.stock-history-table th{padding:12px 14px;text-align:left;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.4px;color:var(--text-secondary);background:#fff;border-bottom:1px solid var(--border);white-space:nowrap}.stock-history-table td{padding:12px 14px;font-size:14px;color:var(--text-primary);border-bottom:1px solid var(--bg-tertiary)}.stock-history-table tr:last-child td{border-bottom:none}.stock-history-table tr:hover td{background:var(--bg-secondary)}.history-item-name{font-weight:600;text-transform:capitalize}.history-price{font-weight:700;color:var(--success)}.drag-handle{color:#94a3b8;font-size:18px;cursor:grab;-webkit-user-select:none;user-select:none;margin-bottom:8px;line-height:1;transition:color .15s;width:fit-content}.drag-handle:hover{color:var(--primary)}.drag-handle:active{cursor:grabbing}.task-card--ghost{opacity:.4;background:#eff6ff;border:2px dashed var(--primary)}.task-card--chosen{box-shadow:0 8px 24px #2563eb33;border-color:var(--primary)}.task-card--drag{opacity:.95;transform:rotate(1.5deg);box-shadow:0 12px 32px #00000026}.drag-save-indicator{position:fixed;bottom:24px;right:24px;padding:10px 18px;border-radius:8px;font-size:14px;font-weight:600;display:flex;align-items:center;gap:8px;z-index:9999;box-shadow:var(--shadow-lg);transition:all .2s}.drag-save-indicator--saving{background:#eff6ff;color:var(--primary);border:1px solid #bfdbfe}.drag-save-indicator--success{background:#dcfce7;color:#166534;border:1px solid #86efac}.drag-save-indicator--error{background:#fee2e2;color:#991b1b;border:1px solid #fecaca}@media (max-width: 900px){.header-content{padding:12px 16px}.btn-sidebar-toggle{display:flex}.dashboard-body{grid-template-columns:1fr}.sidebar-overlay{display:block;pointer-events:none;top:61px;inset:unset;left:0;right:0;bottom:0}.sidebar{position:fixed;top:61px;left:0;height:calc(100vh - 61px);width:280px;max-width:85vw;z-index:160;border-right:1px solid var(--border);box-shadow:var(--shadow-lg);transform:translate(-100%);transition:transform .28s cubic-bezier(.4,0,.2,1);padding:20px}.sidebar--open{transform:translate(0)}.sidebar-header{display:flex}.task-grid,.form-row{grid-template-columns:1fr}.main-content{padding:16px}.content-header{margin-bottom:16px}.content-header h2{font-size:20px}.category-progress-grid{grid-template-columns:1fr;gap:10px}.progress-card-header{align-items:flex-start}.progress-card-info{flex:1;min-width:0}.progress-card-name{white-space:normal;overflow:visible;text-overflow:unset;line-height:1.3}.progress-track{height:10px}.modal-content{max-height:95vh;margin:8px;width:calc(100vw - 16px);max-width:100%;border-radius:12px}.modal-overlay{padding:0;align-items:flex-end}.stock-report-overlay{align-items:center;padding:16px}.stock-report-overlay .modal-content{margin:0;width:100%;max-height:90vh}.header-content h1{font-size:17px}.user-identity{gap:6px}.user-name,.user-score{font-size:13px}.header-actions{gap:6px}.btn-stock-nav,.btn-report,.btn-logout,.btn-games{padding:7px 10px;font-size:12px}.btn-label{display:none}.btn-icon{font-size:16px}.report-header{flex-direction:column;align-items:flex-start;gap:12px}.report-title{font-size:20px}.task-section{margin-bottom:28px}}@media (max-width: 480px){.header-content{padding:10px 12px}.user-identity{display:flex;gap:4px}.user-name{display:none}.user-role{font-size:10px;padding:2px 6px}.user-score{font-size:11px}.category-progress-grid{grid-template-columns:1fr;gap:8px}.progress-card{padding:14px 16px}.progress-card-header{align-items:flex-start;margin-bottom:10px}.progress-card-icon{font-size:18px;margin-top:2px}.progress-card-name{font-size:13px;white-space:normal;overflow:visible;text-overflow:unset;line-height:1.3}.progress-card-fraction{font-size:11px}.progress-card-pct{font-size:14px;margin-top:2px}.progress-track{height:10px}.task-card{padding:14px}.task-footer{flex-direction:column;align-items:flex-start;gap:10px}.task-actions{width:100%;justify-content:flex-end}.content-header{flex-wrap:wrap}}.games-dropdown-wrapper{position:relative}.btn-games{padding:8px 16px;border:1.5px solid var(--primary);border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;background:transparent;color:var(--primary);transition:all .2s;display:flex;align-items:center;gap:6px}.btn-games:hover{background:var(--primary);color:#fff}.games-dropdown{position:absolute;top:calc(100% + 6px);right:0;min-width:180px;background:#fff;border:1px solid var(--border);border-radius:10px;box-shadow:0 8px 24px #0000001f;z-index:300;opacity:0;visibility:hidden;transform:translateY(-4px);transition:opacity .18s ease,transform .18s ease,visibility .18s;padding:6px}.games-dropdown--open{opacity:1;visibility:visible;transform:translateY(0)}.games-dropdown-item{display:flex;align-items:center;gap:10px;padding:10px 14px;border-radius:6px;text-decoration:none;color:var(--text-primary);font-size:14px;font-weight:500;transition:background .15s}.games-dropdown-item:hover{background:var(--bg-tertiary)}.games-dropdown-icon{font-size:18px;flex-shrink:0}.welcome-banner{background:linear-gradient(135deg,#1a73e8,#0d5fca);color:#fff;text-align:center;padding:12px 24px;font-size:1rem;font-weight:500;letter-spacing:.01em;opacity:1;transition:opacity .6s ease,max-height .5s ease,padding .5s ease;max-height:60px;overflow:hidden}.welcome-banner.hidden{opacity:0;max-height:0;padding-top:0;padding-bottom:0}.more-menu-btn{display:none;align-items:center;justify-content:center;width:40px;height:40px;border-radius:10px;border:1px solid var(--border);background:#fff;color:var(--text-primary);cursor:pointer;transition:background .18s ease,border-color .18s ease;flex-shrink:0}.more-menu-btn:hover{background:#f1f5f9;border-color:#cbd5e1}@media (max-width: 900px){.user-info{flex-wrap:nowrap;gap:8px;position:relative}.user-identity{flex-wrap:nowrap;flex-shrink:0}.more-menu-btn{display:inline-flex}.header-actions{position:absolute;top:calc(100% + 10px);right:0;flex-direction:column;align-items:stretch;gap:4px;background:#fff;border:1px solid var(--border);border-radius:12px;box-shadow:0 12px 32px #0f172a24;padding:8px;min-width:220px;z-index:200;opacity:0;visibility:hidden;transform:translateY(-6px);transition:opacity .18s ease,transform .18s ease,visibility .18s}.header-actions.header-actions--open{opacity:1;visibility:visible;transform:translateY(0)}.header-actions>button,.header-actions .btn-stock-nav,.header-actions .btn-report,.header-actions .btn-report--active,.header-actions .btn-games,.header-actions .btn-gate-lock,.header-actions .btn-logout{width:100%;display:flex;align-items:center;justify-content:flex-start;gap:12px;padding:10px 12px;font-size:14px;font-weight:500;min-height:44px;border:none;border-radius:8px;background:transparent;color:var(--text-primary);box-shadow:none;text-shadow:none;letter-spacing:normal;transform:none;transition:background .15s ease}.header-actions>button:hover,.header-actions .btn-stock-nav:hover,.header-actions .btn-report:hover,.header-actions .btn-games:hover,.header-actions .btn-gate-lock:hover,.header-actions .btn-logout:hover{background:#f1f5f9;color:var(--text-primary);box-shadow:none;transform:none}.header-actions .btn-report--active{background:#eff6ff;color:var(--primary)}.header-actions .btn-logout{color:#b91c1c;margin-top:4px;border-top:1px solid var(--border);border-top-left-radius:0;border-top-right-radius:0;padding-top:12px}.header-actions .btn-logout:hover{background:#fef2f2;color:#b91c1c}.header-actions .btn-label{display:inline}.header-actions .btn-icon{font-size:18px;width:22px;display:inline-flex;justify-content:center;flex-shrink:0}.games-dropdown-wrapper{width:100%}.games-dropdown{position:static;box-shadow:none;border:none;padding:4px 0 0 34px;min-width:0}.games-dropdown:not(.games-dropdown--open){display:none}}.admin-sec-modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a8c;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:1000;animation:asec-fade .15s ease-out}.admin-sec-modal{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);width:min(860px,calc(100vw - 32px));max-height:calc(100vh - 32px);background:#fff;border-radius:16px;box-shadow:0 25px 50px -12px #00000040;z-index:1001;display:flex;flex-direction:column;overflow:hidden;animation:asec-pop .18s ease-out}@keyframes asec-fade{0%{opacity:0}to{opacity:1}}@keyframes asec-pop{0%{opacity:0;transform:translate(-50%,-48%) scale(.96)}to{opacity:1;transform:translate(-50%,-50%) scale(1)}}.admin-sec-header{padding:20px 24px;border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between;align-items:center;gap:16px;background:linear-gradient(135deg,#0f172a,#1e293b);color:#f8fafc}.admin-sec-header h2{margin:0 0 4px;font-size:1.25rem;font-weight:700}.admin-sec-sub{margin:0;font-size:.8125rem;color:#94a3b8}.admin-sec-close{background:#ffffff1a;color:#f8fafc;border:none;width:36px;height:36px;border-radius:10px;cursor:pointer;font-size:18px;line-height:1;transition:background .15s}.admin-sec-close:hover{background:#fff3}.admin-sec-body{padding:20px 24px;overflow-y:auto;display:flex;flex-direction:column;gap:24px}.admin-sec-section h3{margin:0 0 12px;font-size:1rem;font-weight:600;color:#0f172a}.admin-sec-note{font-size:.875rem;color:#64748b;margin:0 0 12px}.admin-sec-btn{background:#0f172a;color:#fff;border:none;padding:10px 16px;border-radius:10px;font-weight:600;cursor:pointer;font-size:.875rem;transition:background .15s}.admin-sec-btn:hover{background:#1e293b}.admin-sec-btn--danger{background:#dc2626}.admin-sec-btn--danger:hover{background:#b91c1c}.admin-sec-radio-group{display:flex;flex-direction:column;gap:8px}.admin-sec-radio{display:flex;gap:12px;align-items:flex-start;padding:12px 14px;border:1px solid #e5e7eb;border-radius:10px;cursor:pointer;transition:all .15s}.admin-sec-radio:hover{border-color:#0f172a;background:#f8fafc}.admin-sec-radio input{margin-top:3px}.admin-sec-radio span{font-size:.875rem;color:#334155;line-height:1.5}.admin-sec-whitelist-add{display:flex;gap:8px;margin-bottom:12px;flex-wrap:wrap}.admin-sec-whitelist-add input{flex:1;min-width:160px;padding:9px 12px;border:1px solid #d1d5db;border-radius:8px;font-size:.875rem}.admin-sec-wl-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:6px}.admin-sec-wl-item{display:flex;justify-content:space-between;align-items:center;padding:10px 12px;background:#f8fafc;border-radius:8px;font-size:.875rem}.admin-sec-wl-label{color:#64748b;margin-left:8px;font-size:.8125rem}.admin-sec-wl-del{background:transparent;border:1px solid #fecaca;color:#dc2626;padding:4px 10px;border-radius:6px;cursor:pointer;font-size:.8125rem}.admin-sec-wl-del:hover{background:#fef2f2}.admin-sec-empty{color:#94a3b8;font-style:italic;font-size:.875rem;margin:0}.admin-sec-log{max-height:280px;overflow:auto;border:1px solid #e5e7eb;border-radius:10px}.admin-sec-log-table{width:100%;border-collapse:collapse;font-size:.8125rem}.admin-sec-log-table th,.admin-sec-log-table td{padding:8px 10px;text-align:left;border-bottom:1px solid #f1f5f9}.admin-sec-log-table th{background:#f8fafc;font-weight:600;color:#475569;position:sticky;top:0}.admin-sec-log-blocked td{background:#fef2f2;color:#991b1b}.ip-blocked-info{background:#fef2f2;border:1px solid #fecaca;border-radius:10px;padding:14px 16px;margin:16px 0;display:flex;flex-direction:column;gap:6px}.ip-blocked-row{display:flex;justify-content:space-between;font-size:.875rem;color:#334155}.ip-blocked-row strong{color:#0f172a}
