body{font-family:'Inter',system-ui,-apple-system,sans-serif;color:#1a1a1a;background-color:#ffffff}.line-clamp-2{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.line-clamp-3{display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.banner-slide{transition:opacity 0.7s ease-in-out}.toast{position:fixed;top:20px;right:20px;z-index:9999;transition:transform 0.3s ease,opacity 0.3s ease}.star-rating .star{cursor:pointer;font-size:1.5rem;color:#d1d5db;transition:color 0.2s}.star-rating .star.active,.star-rating .star:hover{color:#f59e0b}.spinner{border:3px solid #e5e7eb;border-top:3px solid #2d6a4f;border-radius:50%;width:24px;height:24px;animation:spin 0.8s linear infinite;display:inline-block}@keyframes spin{0%{transform:rotate(0deg)}100%{transform:rotate(360deg)}}.truncate-text{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.product-card{transition:box-shadow 0.2s}.product-card:hover{box-shadow:0 10px 25px rgba(0,0,0,0.1)}.qty-input{width:50px;text-align:center}.pagination .active{background:#2d6a4f;color:white}.discount-badge{position:absolute;top:8px;right:8px;background:#dc2626;color:white;font-size:0.75rem;font-weight:bold;padding:2px 8px;border-radius:4px}mark{background:#fef08a;padding:0 2px}.data-table{width:100%;border-collapse:collapse}.data-table th{background:#f9fafb;text-align:left;padding:10px 12px;font-size:0.8rem;font-weight:600;text-transform:uppercase;letter-spacing:0.05em;color:#6b7280;border-bottom:2px solid #e5e7eb}.data-table td{padding:10px 12px;border-bottom:1px solid #f3f4f6;font-size:0.875rem}.data-table tr:hover{background:#f9fafb}.admin-card{background:white;border-radius:12px;box-shadow:0 1px 3px rgba(0,0,0,0.1);padding:20px}.stat-card{background:white;border-radius:12px;padding:20px;box-shadow:0 1px 3px rgba(0,0,0,0.1)}.stat-card .stat-value{font-size:1.8rem;font-weight:700;color:#1a1a1a}.stat-card .stat-label{font-size:0.8rem;color:#6b7280;margin-top:4px}.form-input{width:100%;border:1px solid #d1d5db;border-radius:8px;padding:8px 12px;font-size:0.875rem;outline:none;transition:border-color 0.2s,box-shadow 0.2s}.form-input:focus{border-color:#2d6a4f;box-shadow:0 0 0 2px rgba(45,106,79,0.2)}.form-label{display:block;font-size:0.875rem;font-weight:500;margin-bottom:4px;color:#374151}.btn-primary{background:#2d6a4f;color:white;padding:8px 20px;border-radius:8px;font-weight:600;transition:background 0.2s;border:none;cursor:pointer;display:inline-flex;align-items:center;gap:6px}.btn-primary:hover{background:#1b4332}.btn-primary:disabled{background:#9ca3af;cursor:not-allowed}.btn-secondary{background:#f3f4f6;color:#374151;padding:8px 20px;border-radius:8px;font-weight:500;transition:background 0.2s;border:1px solid #d1d5db;cursor:pointer}.btn-secondary:hover{background:#e5e7eb}.btn-danger{background:#dc2626;color:white;padding:8px 20px;border-radius:8px;font-weight:600;transition:background 0.2s;border:none;cursor:pointer}.btn-danger:hover{background:#b91c1c}.btn-sm{padding:4px 12px;font-size:0.8rem}.badge{display:inline-block;padding:2px 10px;border-radius:9999px;font-size:0.75rem;font-weight:600}.badge-pending{background:#fef3c7;color:#92400e}.badge-processing{background:#dbeafe;color:#1e40af}.badge-shipped{background:#e0e7ff;color:#3730a3}.badge-delivered{background:#d1fae5;color:#065f46}.badge-cancelled{background:#fee2e2;color:#991b1b}.badge-paid{background:#d1fae5;color:#065f46}.badge-failed{background:#fee2e2;color:#991b1b}.image-preview{width:100px;height:100px;object-fit:cover;border-radius:8px;border:1px solid #e5e7eb}@media (max-width:768px){.table-responsive{overflow-x:auto}.data-table{font-size:0.8rem}.data-table th,.data-table td{padding:6px 8px}}.modal-overlay{z-index:999}.slider-dot{width:10px;height:10px;border-radius:50%;transition:background 0.3s}.prose ul{list-style:disc;padding-left:2em;margin:.5em 0}.prose ol{list-style:decimal;padding-left:2em;margin:.5em 0}.prose li{margin-bottom:.25em}