*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background-color:#f5f5f5}.App{min-height:100vh}.loading,.config-needed{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100vh;text-align:center}.config-needed{background:white;padding:2rem;border-radius:8px;box-shadow:0 2px 10px #0000001a;margin:2rem}.login-container{display:flex;align-items:center;justify-content:center;min-height:100vh;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%)}.login-form{background:white;padding:2rem;border-radius:8px;box-shadow:0 4px 20px #0000001a;width:100%;max-width:400px}.login-form h2{margin-bottom:1.5rem;text-align:center;color:#333}.form-group{margin-bottom:1rem}.form-group label{display:block;margin-bottom:.5rem;color:#555;font-weight:500}.form-group input{width:100%;padding:.75rem;border:1px solid #ddd;border-radius:4px;font-size:1rem}.form-group input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 2px #667eea33}.login-form button{width:100%;padding:.75rem;background:#667eea;color:#fff;border:none;border-radius:4px;font-size:1rem;cursor:pointer;transition:background .2s}.login-form button:hover:not(:disabled){background:#5a6fd8}.login-form button:disabled{opacity:.6;cursor:not-allowed}.error-message{background:#fee;color:#d33;padding:.75rem;border-radius:4px;margin-bottom:1rem;border:1px solid #fcc}.login-method-toggle{display:flex;margin-bottom:1.5rem;border-radius:6px;overflow:hidden;border:1px solid #ddd}.toggle-btn{flex:1;padding:.75rem 1rem;border:none;background:#f8f9fa;color:#666;font-size:1rem;cursor:pointer;transition:all .2s}.toggle-btn:first-child{border-right:1px solid #ddd}.toggle-btn:hover:not(:disabled){background:#e9ecef}.toggle-btn.active{background:#667eea;color:#fff}.toggle-btn:disabled{opacity:.6;cursor:not-allowed}.input-hint{display:block;margin-top:.25rem;font-size:.8rem;color:#888}.secondary-btn{width:100%;padding:.75rem;background:transparent;color:#667eea;border:1px solid #667eea;border-radius:4px;font-size:.9rem;cursor:pointer;transition:all .2s;margin-top:.75rem}.secondary-btn:hover:not(:disabled){background:rgba(102,126,234,.1)}.secondary-btn:disabled{opacity:.6;cursor:not-allowed}.dashboard-container{min-height:100vh;background:#f8fafc}.dashboard-header{background:white;padding:1rem 2rem;box-shadow:0 2px 4px #0000001a;display:flex;justify-content:space-between;align-items:center}.dashboard-header h1{color:#333;font-size:1.5rem}.user-info{display:flex;align-items:center;gap:1rem}.user-info span{color:#666}.logout-btn{padding:.5rem 1rem;background:#dc3545;color:#fff;border:none;border-radius:4px;cursor:pointer;transition:background .2s}.logout-btn:hover{background:#c82333}.dashboard-main{padding:2rem}.dashboard-content{max-width:1200px;margin:0 auto}.card{background:white;padding:1.5rem;border-radius:8px;box-shadow:0 2px 10px #0000001a;margin-bottom:2rem}.card h2{margin-bottom:1rem;color:#333}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem}.stat-card{background:white;padding:1.5rem;border-radius:8px;box-shadow:0 2px 10px #0000001a;text-align:center}.stat-card h3{color:#666;font-size:.9rem;margin-bottom:.5rem;text-transform:uppercase;letter-spacing:.5px}.stat-number{font-size:2rem;font-weight:700;color:#333}.token-section{margin-top:1rem}.token-actions{margin-bottom:1rem}.copy-btn{padding:.5rem 1rem;background:#28a745;color:#fff;border:none;border-radius:4px;cursor:pointer;transition:background .2s;font-size:.9rem}.copy-btn:hover{background:#218838}.token-display{width:100%;padding:.75rem;border:1px solid #ddd;border-radius:4px;font-family:Courier New,monospace;font-size:.85rem;background:#f8f9fa;resize:vertical;min-height:150px;word-break:break-all}.dashboard-layout{display:flex;min-height:calc(100vh - 60px)}.sidebar{width:220px;background:white;border-right:1px solid #e2e8f0;padding:1rem 0;flex-shrink:0}.nav-list{list-style:none;padding:0;margin:0}.nav-list li{margin-bottom:.25rem}.nav-btn{width:100%;padding:.75rem 1.5rem;background:transparent;border:none;text-align:left;font-size:.95rem;color:#4a5568;cursor:pointer;transition:all .2s;border-left:3px solid transparent}.nav-btn:hover{background:#f7fafc;color:#2d3748}.nav-btn.active{background:#edf2f7;color:#667eea;border-left-color:#667eea;font-weight:500}.admin-section{background:white;border-radius:8px;box-shadow:0 2px 10px #0000001a;overflow:hidden}.admin-header{padding:1.5rem;border-bottom:1px solid #e2e8f0}.admin-header h2{margin:0 0 1rem;color:#2d3748}.admin-tabs{display:flex;gap:.5rem;flex-wrap:wrap}.tab-btn{padding:.5rem 1rem;background:#f7fafc;border:1px solid #e2e8f0;border-radius:6px;font-size:.9rem;color:#4a5568;cursor:pointer;transition:all .2s}.tab-btn:hover{background:#edf2f7}.tab-btn.active{background:#667eea;color:#fff;border-color:#667eea}.admin-content{padding:1.5rem}.admin-loading{padding:3rem;text-align:center;color:#718096}.admin-error{padding:2rem;text-align:center;color:#e53e3e}.retry-btn{margin-top:1rem;padding:.5rem 1.5rem;background:#667eea;color:#fff;border:none;border-radius:4px;cursor:pointer}.retry-btn:hover{background:#5a6fd8}.filter-bar{display:flex;align-items:center;gap:1rem;margin-bottom:1.5rem;padding:1rem;background:#f7fafc;border-radius:6px}.filter-bar label{font-weight:500;color:#4a5568}.filter-select{padding:.5rem 1rem;border:1px solid #e2e8f0;border-radius:4px;font-size:.9rem;min-width:200px}.filter-select:focus{outline:none;border-color:#667eea}.count-info{font-size:.9rem;color:#718096;margin-left:.5rem}.data-table{overflow-x:auto}.data-table table{width:100%;border-collapse:collapse}.data-table th,.data-table td{padding:.75rem 1rem;text-align:left;border-bottom:1px solid #e2e8f0}.data-table th{background:#f7fafc;font-weight:600;color:#4a5568;font-size:.85rem;text-transform:uppercase;letter-spacing:.5px}.data-table tr:hover{background:#f7fafc}.id-cell{font-family:Courier New,monospace;font-size:.85rem;color:#718096}.category-badge{display:inline-block;padding:.25rem .75rem;background:#e2e8f0;border-radius:20px;font-size:.8rem;color:#4a5568}.no-data{padding:2rem;text-align:center;color:#a0aec0;font-style:italic}.categories-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:1rem}.category-card{background:#f7fafc;border:1px solid #e2e8f0;border-radius:8px;padding:1.25rem;text-align:center;transition:all .2s}.category-card:hover{border-color:#667eea;box-shadow:0 2px 8px #667eea1a}.category-card h3{margin:0 0 .5rem;font-size:1rem;color:#2d3748}.category-card p{margin:0 0 1rem;font-size:.85rem;color:#718096}.view-btn{padding:.4rem 1rem;background:#667eea;color:#fff;border:none;border-radius:4px;font-size:.85rem;cursor:pointer;transition:background .2s}.view-btn:hover{background:#5a6fd8}.search-bar{display:flex;gap:.75rem;margin-bottom:1.5rem}.search-input{flex:1;padding:.75rem 1rem;border:1px solid #e2e8f0;border-radius:6px;font-size:1rem}.search-input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 2px #667eea33}.search-btn{padding:.75rem 1.5rem;background:#667eea;color:#fff;border:none;border-radius:6px;font-size:1rem;cursor:pointer;transition:background .2s}.search-btn:hover:not(:disabled){background:#5a6fd8}.search-btn:disabled{opacity:.6;cursor:not-allowed}.pagination{display:flex;justify-content:center;align-items:center;gap:1rem;margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid #e2e8f0}.page-btn{padding:.5rem 1rem;background:white;border:1px solid #e2e8f0;border-radius:4px;font-size:.9rem;cursor:pointer;transition:all .2s}.page-btn:hover:not(:disabled){border-color:#667eea;color:#667eea}.page-btn:disabled{opacity:.5;cursor:not-allowed}.page-info{font-size:.9rem;color:#718096}@media (max-width: 768px){.dashboard-layout{flex-direction:column}.sidebar{width:100%;border-right:none;border-bottom:1px solid #e2e8f0}.nav-list{display:flex;overflow-x:auto;padding:0 1rem}.nav-btn{white-space:nowrap;border-left:none;border-bottom:3px solid transparent}.nav-btn.active{border-left-color:transparent;border-bottom-color:#667eea}.filter-bar{flex-direction:column;align-items:stretch}.search-bar{flex-direction:column}.categories-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr))}}.admin-header-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.add-btn{padding:.5rem 1rem;background:#48bb78;color:#fff;border:none;border-radius:6px;font-size:.9rem;font-weight:500;cursor:pointer;transition:background .2s}.add-btn:hover{background:#38a169}.admin-error-banner{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;background:#fed7d7;color:#c53030;border-bottom:1px solid #feb2b2}.dismiss-btn{background:none;border:none;font-size:1.25rem;color:#c53030;cursor:pointer;padding:0 .5rem}.dismiss-btn:hover{color:#9b2c2c}.actions-cell{white-space:nowrap}.edit-btn{padding:.35rem .75rem;background:#667eea;color:#fff;border:none;border-radius:4px;font-size:.8rem;cursor:pointer;margin-right:.5rem;transition:background .2s}.edit-btn:hover{background:#5a6fd8}.delete-btn{padding:.35rem .75rem;background:#e53e3e;color:#fff;border:none;border-radius:4px;font-size:.8rem;cursor:pointer;transition:background .2s}.delete-btn:hover{background:#c53030}.delete-confirm{display:inline-flex;gap:.25rem}.confirm-yes{padding:.35rem .6rem;background:#e53e3e;color:#fff;border:none;border-radius:4px;font-size:.8rem;cursor:pointer}.confirm-yes:hover{background:#c53030}.confirm-yes:disabled{opacity:.6;cursor:not-allowed}.confirm-no{padding:.35rem .6rem;background:#a0aec0;color:#fff;border:none;border-radius:4px;font-size:.8rem;cursor:pointer}.confirm-no:hover{background:#718096}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.5);display:flex;align-items:center;justify-content:center;z-index:1000}.modal{background:white;border-radius:8px;box-shadow:0 4px 20px #0003;width:100%;max-width:500px;max-height:90vh;overflow:hidden;display:flex;flex-direction:column}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;border-bottom:1px solid #e2e8f0}.modal-header h3{margin:0;font-size:1.1rem;color:#2d3748}.modal-close{background:none;border:none;font-size:1.5rem;color:#a0aec0;cursor:pointer;padding:0;line-height:1}.modal-close:hover{color:#4a5568}.modal-body{padding:1.5rem;overflow-y:auto}.modal-body .form-group{margin-bottom:1.25rem}.modal-body .form-group:last-child{margin-bottom:0}.modal-body .form-group label{display:block;margin-bottom:.5rem;font-weight:500;color:#4a5568;font-size:.9rem}.modal-body .form-group input,.modal-body .form-group textarea{width:100%;padding:.75rem;border:1px solid #e2e8f0;border-radius:6px;font-size:.95rem;transition:border-color .2s,box-shadow .2s}.modal-body .form-group input:focus,.modal-body .form-group textarea:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.modal-body .form-group textarea{resize:vertical;min-height:80px}.modal-footer{display:flex;justify-content:flex-end;gap:.75rem;padding:1rem 1.5rem;border-top:1px solid #e2e8f0;background:#f7fafc}.cancel-btn{padding:.6rem 1.25rem;background:white;color:#4a5568;border:1px solid #e2e8f0;border-radius:6px;font-size:.9rem;cursor:pointer;transition:all .2s}.cancel-btn:hover:not(:disabled){background:#f7fafc;border-color:#cbd5e0}.cancel-btn:disabled{opacity:.6;cursor:not-allowed}.save-btn{padding:.6rem 1.25rem;background:#667eea;color:#fff;border:none;border-radius:6px;font-size:.9rem;font-weight:500;cursor:pointer;transition:background .2s}.save-btn:hover:not(:disabled){background:#5a6fd8}.save-btn:disabled{opacity:.6;cursor:not-allowed}@media (max-width: 576px){.modal{margin:1rem;max-width:calc(100% - 2rem)}.actions-cell{display:flex;flex-direction:column;gap:.25rem}.edit-btn,.delete-btn{margin-right:0}}
