.navbar{background-color:#333;color:#fff;padding:1rem 0;box-shadow:0 2px 4px #0000001a}.navbar .container{display:flex;justify-content:space-between;align-items:center}.logo{font-size:1.5rem;font-weight:700;color:#fff;text-decoration:none}.nav-links{display:flex;list-style:none;gap:2rem;align-items:center}.nav-links a{color:#fff;text-decoration:none;transition:color .3s}.nav-links a:hover{color:#007bff}.user-name{color:gold;font-weight:500}.logout-btn{background-color:#dc3545;color:#fff;padding:.5rem 1rem;border:none;border-radius:4px;cursor:pointer;transition:background-color .3s}.logout-btn:hover{background-color:#c82333}.api-test-link{background:linear-gradient(135deg,#667eea,#764ba2);padding:.5rem 1rem;border-radius:4px;transition:transform .2s}.api-test-link:hover{transform:translateY(-2px);color:#fff!important}.cart-link-wrapper{position:relative}.cart-badge{position:absolute;top:-8px;right:-10px;background-color:#dc3545;color:#fff;font-size:12px;font-weight:700;padding:2px 6px;border-radius:50%;min-width:20px;text-align:center}.product-card{background:#fff;border-radius:8px;overflow:hidden;box-shadow:0 2px 8px #0000001a;transition:transform .3s}.product-card:hover{transform:translateY(-5px)}.product-card img{width:100%;height:200px;object-fit:cover}.product-info{padding:1rem}.product-info h3{margin-bottom:.5rem;color:#333}.description{color:#666;font-size:.9rem;margin-bottom:1rem;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}.product-footer{display:flex;justify-content:space-between;align-items:center}.price{font-size:1.5rem;font-weight:700;color:#e74c3c}.btn-primary{background-color:#007bff;color:#fff}.hero{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:4rem 0;text-align:center}.hero h1{font-size:3rem;margin-bottom:1rem}.hero p{font-size:1.5rem;margin-bottom:2rem}.btn-hero{background-color:#fff;color:#667eea;font-size:1.2rem;padding:1rem 2rem;font-weight:700}.featured-products{padding:3rem 0}.featured-products h2{text-align:center;margin-bottom:2rem;font-size:2rem;color:#333}.products-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:2rem}.products-page{padding:2rem 0}.products-page h1{margin-bottom:2rem;color:#333}.search-bar{margin-bottom:2rem}.search-bar input{max-width:500px;padding:12px;font-size:16px}.product-detail{padding:2rem 0}.detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:3rem;background:#fff;padding:2rem;border-radius:8px}.image-section img{width:100%;border-radius:8px}.info-section h1{font-size:2rem;margin-bottom:1rem;color:#333}.category{color:#666;margin-bottom:1rem}.price{font-size:2rem;color:#e74c3c;font-weight:700;margin:1rem 0}.description{color:#666;line-height:1.6;margin:1.5rem 0}.stock{color:#27ae60;margin:1rem 0}.quantity-section{margin:1.5rem 0;display:flex;align-items:center;gap:1rem}.quantity-section input{width:100px}.btn-add-cart{background-color:#27ae60;color:#fff;font-size:1.1rem;padding:1rem 2rem;width:100%}.btn-add-cart:disabled{background-color:#ccc;cursor:not-allowed}.cart-page{padding:2rem 0;min-height:60vh}.cart-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.cart-header h1{margin:0}.btn-clear{background-color:#dc3545;color:#fff;padding:.5rem 1rem;border:none;border-radius:4px;cursor:pointer;transition:background-color .3s}.btn-clear:hover{background-color:#c82333}.empty-cart{text-align:center;padding:3rem 0}.empty-cart p{font-size:1.2rem;color:#666;margin-bottom:1.5rem}.btn-primary{display:inline-block;background-color:#007bff;color:#fff;padding:.75rem 2rem;text-decoration:none;border-radius:4px;transition:background-color .3s}.btn-primary:hover{background-color:#0056b3}.cart-content{display:grid;grid-template-columns:2fr 1fr;gap:2rem}.cart-items{display:flex;flex-direction:column;gap:1rem}.cart-item{display:grid;grid-template-columns:100px 2fr 150px 100px 80px;gap:1.5rem;align-items:center;background:#fff;padding:1.5rem;border-radius:8px;box-shadow:0 2px 4px #0000001a}.item-image{width:100px;height:100px;object-fit:cover;border-radius:4px}.item-info h3{margin:0 0 .5rem;font-size:1.1rem}.item-price{color:#007bff;font-weight:700;font-size:1.1rem;margin:0}.item-quantity{display:flex;align-items:center;gap:.5rem}.qty-btn{width:30px;height:30px;border:1px solid #ddd;background:#fff;cursor:pointer;border-radius:4px;transition:all .3s}.qty-btn:hover:not(:disabled){background-color:#007bff;color:#fff;border-color:#007bff}.qty-btn:disabled{opacity:.5;cursor:not-allowed}.qty-input{width:60px;text-align:center;padding:.25rem;border:1px solid #ddd;border-radius:4px}.item-total{text-align:right}.item-total p{font-size:1.2rem;font-weight:700;color:#333;margin:0}.btn-remove{background-color:#dc3545;color:#fff;padding:.5rem 1rem;border:none;border-radius:4px;cursor:pointer;transition:background-color .3s}.btn-remove:hover{background-color:#c82333}.cart-summary{background:#fff;padding:2rem;border-radius:8px;box-shadow:0 2px 4px #0000001a;height:fit-content;position:sticky;top:2rem}.cart-summary h2{margin-top:0;margin-bottom:1.5rem;font-size:1.5rem}.summary-row{display:flex;justify-content:space-between;padding:.75rem 0;border-bottom:1px solid #eee}.summary-row.total{border-bottom:none;border-top:2px solid #333;margin-top:1rem;padding-top:1rem;font-size:1.2rem;font-weight:700}.total-price{color:#dc3545;font-size:1.5rem}.btn-checkout{width:100%;background-color:#28a745;color:#fff;padding:1rem;border:none;border-radius:4px;font-size:1.1rem;cursor:pointer;margin-top:1.5rem;transition:background-color .3s}.btn-checkout:hover{background-color:#218838}.btn-continue{display:block;width:100%;text-align:center;background-color:#6c757d;color:#fff;padding:1rem;border-radius:4px;text-decoration:none;margin-top:1rem;transition:background-color .3s}.btn-continue:hover{background-color:#5a6268}@media (max-width: 768px){.cart-content{grid-template-columns:1fr}.cart-item{grid-template-columns:80px 1fr;gap:1rem}.item-quantity{grid-column:1 / -1}.item-total{grid-column:1 / -1;text-align:left}.btn-remove{grid-column:1 / -1}.cart-summary{position:static}}.auth-page{padding:3rem 0;display:flex;justify-content:center;align-items:center;min-height:80vh}.auth-form{background:#fff;padding:2rem;border-radius:8px;box-shadow:0 2px 10px #0000001a;width:100%;max-width:400px}.auth-form h1{text-align:center;margin-bottom:2rem;color:#333}.form-group{margin-bottom:1.5rem}.form-group label{display:block;margin-bottom:.5rem;color:#333;font-weight:500}.btn-submit{width:100%;background-color:#007bff;color:#fff;padding:12px;font-size:16px;margin-top:1rem}.auth-link{text-align:center;margin-top:1.5rem;color:#666}.auth-link a{color:#007bff;text-decoration:none}.auth-link a:hover{text-decoration:underline}.error-message{background-color:#f8d7da;color:#721c24;padding:12px;border-radius:4px;margin-bottom:1rem;border:1px solid #f5c6cb;font-size:14px}.btn-submit:disabled{opacity:.6;cursor:not-allowed}.form-group input:disabled{background-color:#e9ecef;cursor:not-allowed}.admin-page{padding:2rem 0;min-height:80vh}.admin-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.admin-header h1{color:#333}.btn-add{background-color:#28a745;color:#fff;padding:.75rem 1.5rem;font-size:1rem;border-radius:4px}.btn-add:hover{background-color:#218838}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000}.modal-content{background:#fff;padding:2rem;border-radius:8px;width:90%;max-width:600px;max-height:90vh;overflow-y:auto}.modal-content h2{margin-bottom:1.5rem;color:#333}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.form-actions{display:flex;gap:1rem;margin-top:1.5rem}.btn-submit{flex:1;background-color:#007bff;color:#fff;padding:.75rem;font-size:1rem}.btn-cancel{flex:1;background-color:#6c757d;color:#fff;padding:.75rem;font-size:1rem}.products-table{background:#fff;border-radius:8px;overflow:hidden;box-shadow:0 2px 8px #0000001a}table{width:100%;border-collapse:collapse}thead{background-color:#f8f9fa}th{padding:1rem;text-align:left;font-weight:600;color:#333;border-bottom:2px solid #dee2e6}td{padding:1rem;border-bottom:1px solid #dee2e6}tbody tr:hover{background-color:#f8f9fa}.product-thumb{width:60px;height:60px;object-fit:cover;border-radius:4px}.btn-edit{background-color:#ffc107;color:#333;padding:.5rem 1rem;margin-right:.5rem;border-radius:4px}.btn-edit:hover{background-color:#e0a800}.btn-delete{background-color:#dc3545;color:#fff;padding:.5rem 1rem;border-radius:4px}.btn-delete:hover{background-color:#c82333}.api-test-page{padding:2rem 0;min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2)}.test-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;background:#fff;padding:1.5rem;border-radius:8px;box-shadow:0 4px 6px #0000001a}.test-header h1{color:#333;margin:0}.btn-run-tests{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:1rem 2rem;font-size:1rem;border-radius:6px;font-weight:600;transition:transform .2s}.btn-run-tests:hover:not(:disabled){transform:translateY(-2px)}.btn-run-tests:disabled{opacity:.6;cursor:not-allowed}.test-info{background:#fff;padding:1.5rem;border-radius:8px;margin-bottom:2rem;box-shadow:0 4px 6px #0000001a}.test-info h3{color:#333;margin-bottom:1rem}.test-data-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1rem}.data-card{background:#f8f9fa;padding:1rem;border-radius:6px;border:1px solid #dee2e6}.data-card h4{color:#495057;margin-bottom:.5rem}.data-card pre{background:#fff;padding:.75rem;border-radius:4px;overflow-x:auto;font-size:.85rem;margin:0}.test-results{background:#fff;padding:1.5rem;border-radius:8px;margin-bottom:2rem;box-shadow:0 4px 6px #0000001a}.test-results h3{color:#333;margin-bottom:1rem}.no-results{text-align:center;color:#6c757d;padding:2rem}.results-list{display:flex;flex-direction:column;gap:1rem}.result-card{background:#f8f9fa;border-radius:6px;padding:1rem;transition:all .3s;border-left:4px solid #6c757d}.result-card.success{border-left-color:#28a745;background:#d4edda}.result-card.failed{border-left-color:#dc3545;background:#f8d7da}.result-card.pending{border-left-color:#ffc107;background:#fff3cd;animation:pulse 1.5s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.7}}.result-header{display:flex;align-items:center;gap:.75rem;margin-bottom:.75rem}.status-icon{font-size:1.5rem}.test-name{flex:1;font-weight:600;color:#333}.method-badge{color:#fff;padding:.25rem .75rem;border-radius:4px;font-size:.85rem;font-weight:600}.result-details{display:flex;flex-direction:column;gap:.5rem}.detail-row{display:flex;gap:.5rem;font-size:.9rem}.detail-row.error{color:#dc3545}.detail-row .label{font-weight:600;min-width:80px}.detail-row code{background:#fff;padding:.2rem .5rem;border-radius:3px;font-family:Courier New,monospace}.status-code{padding:.2rem .5rem;border-radius:3px;font-weight:600}.status-code.success{background:#28a745;color:#fff}.status-code.failed{background:#dc3545;color:#fff}.response-details{margin-top:.5rem}.response-details summary{cursor:pointer;color:#007bff;font-weight:600;-webkit-user-select:none;user-select:none}.response-details summary:hover{text-decoration:underline}.response-details pre{background:#fff;padding:1rem;border-radius:4px;margin-top:.5rem;overflow-x:auto;font-size:.85rem;border:1px solid #dee2e6}.test-summary{background:#fff;padding:1.5rem;border-radius:8px;box-shadow:0 4px 6px #0000001a}.test-summary h3{color:#333;margin-bottom:1rem}.summary-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem}.stat-card{background:linear-gradient(135deg,#667eea,#764ba2);padding:1.5rem;border-radius:8px;text-align:center;color:#fff}.stat-card.success{background:linear-gradient(135deg,#28a745,#20c997)}.stat-card.failed{background:linear-gradient(135deg,#dc3545,#fd7e14)}.stat-value{font-size:2.5rem;font-weight:700;margin-bottom:.5rem}.stat-label{font-size:.9rem;opacity:.9}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f5f5f5}.app{min-height:100vh}.container{max-width:1200px;margin:0 auto;padding:20px}button{cursor:pointer;border:none;padding:10px 20px;border-radius:4px;font-size:14px;transition:all .3s}button:hover{opacity:.8}input,textarea{width:100%;padding:10px;border:1px solid #ddd;border-radius:4px;font-size:14px}input:focus,textarea:focus{outline:none;border-color:#007bff}
